1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/*******************************************************************************
* Copyright (c) 2013 Composent, Inc. All rights reserved. This
* program and the accompanying materials are made available under the terms of
* the Eclipse Public License v1.0 which accompanies this distribution, and is
* available at http://www.eclipse.org/legal/epl-v10.html
*
* Contributors: Scott Lewis - initial API and implementation
******************************************************************************/
package com.mycorp.examples.timeservice.host;
import java.util.Dictionary;
import java.util.Hashtable;
import java.util.Properties;
import org.osgi.framework.BundleActivator;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceRegistration;
import org.osgi.service.remoteserviceadmin.RemoteServiceAdminEvent;
import org.osgi.service.remoteserviceadmin.RemoteServiceAdminListener;
import com.mycorp.examples.timeservice.ITimeService;
public class Activator implements BundleActivator {
public void start(BundleContext context) throws Exception {
// If the verboseRemoteServiceAdmin system property is set
// then register debug listener
if (Boolean.getBoolean("verboseRemoteServiceAdmin"))
registerDebugListener(context);
// Create remote service properties...see
// createRemoteServiceProperties()
Dictionary<String, Object> props = createRemoteServiceProperties();
// Create MyTimeService impl and register/export as a remote service
ServiceRegistration<ITimeService> timeServiceRegistration = context
.registerService(ITimeService.class, new TimeServiceImpl(),
props);
// Print out that ITimeService remote service registration
System.out.println("TimeService host registered with registration="
+ timeServiceRegistration);
}
public void stop(BundleContext context) throws Exception {
// do nothing
}
private Dictionary<String, Object> createRemoteServiceProperties() {
// This is the only required service property to trigger remote services
Dictionary<String, Object> result = new Hashtable<String, Object>();
result.put("service.exported.interfaces", "*");
Properties props = System.getProperties();
String config = props.getProperty("service.exported.configs");
if (config != null) {
result.put("service.exported.configs", config);
String configProps = config + ".";
for (Object k : props.keySet()) {
if (k instanceof String) {
String key = (String) k;
if (key.startsWith(configProps)
|| key.equals("ecf.exported.async.interfaces"))
result.put(key, props.getProperty(key));
}
}
}
return result;
}
// Register a RemoteServiceAdminListener so we can report to sdtout
// when a remote service has actually been successfully exported by
// the RSA implementation
private void registerDebugListener(BundleContext context) {
RemoteServiceAdminListener rsaListener = new RemoteServiceAdminListener() {
public void remoteAdminEvent(RemoteServiceAdminEvent event) {
switch (event.getType()) {
case RemoteServiceAdminEvent.EXPORT_REGISTRATION:
System.out
.println("RSA: Service Exported. EndpointDescription="
+ event.getExportReference()
.getExportedEndpoint()
.getProperties());
break;
case RemoteServiceAdminEvent.EXPORT_ERROR:
Throwable t = event.getException();
System.err.println("RSA: EXPORT ERROR. Error message="
+ ((t == null) ? "none" : t.getMessage())
+ ". EndpointDescription="
+ event.getExportReference().getExportedEndpoint()
.getProperties() + "");
if (t != null)
t.printStackTrace();
break;
}
}
};
// Register our listener as service via whiteboard pattern, and
// RemoteServiceAdmin will callback
context.registerService(RemoteServiceAdminListener.class.getName(),
rsaListener, null);
}
}
|