Search in sources :

Example 11 with RemoteOSGiException

use of ch.ethz.iks.r_osgi.RemoteOSGiException in project ecf by eclipse.

the class RemoteOSGiServiceImpl method getRemoteServiceReferences.

/**
 * @see ch.ethz.iks.r_osgi.RemoteOSGiService#getRemoteServiceReferences(ch.ethz.iks.r_osgi.URI,
 *      java.lang.String, org.osgi.framework.Filter)
 */
public RemoteServiceReference[] getRemoteServiceReferences(final URI service, final String clazz, final Filter filter) {
    final String uri = getChannelURI(service);
    ChannelEndpointImpl channel = (ChannelEndpointImpl) channels.get(uri);
    if (channel == null) {
        try {
            connect(service);
            channel = (ChannelEndpointImpl) channels.get(uri);
        } catch (final IOException ioe) {
            // $NON-NLS-1$
            throw new RemoteOSGiException("Cannot connect to " + uri);
        }
    }
    if (clazz == null) {
        return channel.getAllRemoteReferences(null);
    }
    try {
        return channel.getAllRemoteReferences(RemoteOSGiActivator.getActivator().getContext().createFilter(filter != null ? // $NON-NLS-1$ //$NON-NLS-2$
        "(&" + filter + "(" + Constants.OBJECTCLASS + "=" + clazz + "))" : // $NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
        "(" + Constants.OBJECTCLASS + "=" + clazz + // $NON-NLS-1$ //$NON-NLS-2$
        ")"));
    } catch (final InvalidSyntaxException ise) {
        ise.printStackTrace();
        return null;
    }
}
Also used : RemoteOSGiException(ch.ethz.iks.r_osgi.RemoteOSGiException) InvalidSyntaxException(org.osgi.framework.InvalidSyntaxException) IOException(java.io.IOException)

Example 12 with RemoteOSGiException

use of ch.ethz.iks.r_osgi.RemoteOSGiException in project ecf by eclipse.

the class RemoteOSGiServiceImpl method fetchService.

/**
 * fetch the discovered remote service. The service will be fetched from the
 * service providing host and a proxy bundle is registered with the local
 * framework.
 *
 * @param service
 *            the <code>ServiceURL</code>.
 * @throws RemoteOSGiException
 *             if the fetching fails.
 * @see ch.ethz.iks.r_osgi.RemoteOSGiService#getProxyBundle(ch.ethz.iks.slp.ServiceURL)
 * @since 0.1
 * @category RemoteOSGiService
 */
private void fetchService(final RemoteServiceReference ref) throws RemoteOSGiException {
    try {
        ChannelEndpointImpl channel;
        channel = ((RemoteServiceReferenceImpl) ref).getChannel();
        channel.getProxyBundle(ref);
    } catch (final UnknownHostException e) {
        throw new RemoteOSGiException("Cannot resolve host " + ref.getURI(), // $NON-NLS-1$
        e);
    } catch (final IOException ioe) {
        // $NON-NLS-1$
        throw new RemoteOSGiException("Proxy generation error", ioe);
    }
}
Also used : UnknownHostException(java.net.UnknownHostException) RemoteOSGiException(ch.ethz.iks.r_osgi.RemoteOSGiException) IOException(java.io.IOException)

Example 13 with RemoteOSGiException

use of ch.ethz.iks.r_osgi.RemoteOSGiException in project ecf by eclipse.

the class RemoteOSGiServiceImpl method setupTrackers.

private void setupTrackers(final BundleContext context) throws IOException {
    // initialize service trackers
    eventAdminTracker = new ServiceTracker(context, EventAdmin.class.getName(), null);
    eventAdminTracker.open();
    if (eventAdminTracker.getTrackingCount() == 0 && log != null) {
        log.log(LogService.LOG_WARNING, // $NON-NLS-1$
        "NO EVENT ADMIN FOUND. REMOTE EVENT DELIVERY TEMPORARILY DISABLED.");
    }
    try {
        eventHandlerTracker = new ServiceTracker(context, context.createFilter(// $NON-NLS-1$ //$NON-NLS-2$
        "(&(" + Constants.OBJECTCLASS + "=" + EventHandler.class.getName() + // $NON-NLS-1$
        ")(|(!(" + R_OSGi_INTERNAL + // $NON-NLS-1$
        "=*))" + // https://bugs.eclipse.org/418740
        "(!(" + // $NON-NLS-1$
        EventConstants.EVENT_TOPIC + // $NON-NLS-1$
        "=org/osgi/service/remoteserviceadmin/*))))"), new ServiceTrackerCustomizer() {

            public Object addingService(final ServiceReference reference) {
                // https://bugs.eclipse.org/bugs/show_bug.cgi?id=326033
                Collection theTopics;
                Object topic = reference.getProperty(EventConstants.EVENT_TOPIC);
                if (topic instanceof String)
                    theTopics = Arrays.asList(new String[] { (String) topic });
                else
                    theTopics = Arrays.asList((String[]) topic);
                // Remove filtered topics
                theTopics = StringUtils.rightDifference(topicFilters, theTopics);
                final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                lu.setType(LeaseUpdateMessage.TOPIC_UPDATE);
                // $NON-NLS-1$
                lu.setServiceID("");
                lu.setPayload(new Object[] { theTopics.toArray(new String[theTopics.size()]), null });
                updateLeases(lu);
                return theTopics;
            }

            public void modifiedService(final ServiceReference reference, final Object oldTopics) {
                final List oldTopicList = (List) oldTopics;
                // https://bugs.eclipse.org/bugs/show_bug.cgi?id=326033
                Collection newTopicList;
                Object topic = reference.getProperty(EventConstants.EVENT_TOPIC);
                if (topic instanceof String)
                    newTopicList = Arrays.asList(new String[] { (String) topic });
                else
                    newTopicList = Arrays.asList((String[]) topic);
                // Remove filtered topics
                newTopicList = StringUtils.rightDifference(topicFilters, newTopicList);
                final Collection removed = CollectionUtils.rightDifference(newTopicList, oldTopicList);
                final Collection added = CollectionUtils.leftDifference(newTopicList, oldTopicList);
                final String[] addedTopics = (String[]) added.toArray(new String[removed.size()]);
                final String[] removedTopics = (String[]) removed.toArray(addedTopics);
                oldTopicList.removeAll(removed);
                oldTopicList.addAll(added);
                final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                lu.setType(LeaseUpdateMessage.TOPIC_UPDATE);
                // $NON-NLS-1$
                lu.setServiceID("");
                lu.setPayload(new Object[] { addedTopics, removedTopics });
                updateLeases(lu);
            }

            public void removedService(final ServiceReference reference, final Object oldTopics) {
                final List oldTopicsList = (List) oldTopics;
                final String[] removedTopics = (String[]) oldTopicsList.toArray(new String[oldTopicsList.size()]);
                final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                lu.setType(LeaseUpdateMessage.TOPIC_UPDATE);
                // $NON-NLS-1$
                lu.setServiceID("");
                lu.setPayload(new Object[] { null, removedTopics });
                updateLeases(lu);
            }
        });
        eventHandlerTracker.open();
        if (DEBUG) {
            log.log(LogService.LOG_DEBUG, // $NON-NLS-1$
            "Local topic space " + Arrays.asList(getTopics()));
        }
        remoteServiceListenerTracker = new ServiceTracker(context, RemoteServiceListener.class.getName(), null);
        remoteServiceListenerTracker.open();
        serviceDiscoveryHandlerTracker = new ServiceTracker(context, ServiceDiscoveryHandler.class.getName(), new ServiceTrackerCustomizer() {

            public Object addingService(final ServiceReference reference) {
                // register all known services for discovery
                final ServiceDiscoveryHandler handler = (ServiceDiscoveryHandler) context.getService(reference);
                RemoteServiceRegistration[] regs = null;
                synchronized (serviceRegistrations) {
                    regs = (RemoteServiceRegistration[]) serviceRegistrations.values().toArray(new RemoteServiceRegistration[serviceRegistrations.size()]);
                }
                for (int i = 0; i < regs.length; i++) {
                    handler.registerService(regs[i].getReference(), regs[i].getProperties(), URI.create(// $NON-NLS-1$
                    "r-osgi://" + RemoteOSGiServiceImpl.MY_ADDRESS + // $NON-NLS-1$
                    ":" + RemoteOSGiServiceImpl.R_OSGI_PORT + // $NON-NLS-1$
                    "#" + regs[i].getServiceID()));
                }
                return handler;
            }

            public void modifiedService(final ServiceReference reference, final Object service) {
            }

            public void removedService(final ServiceReference reference, final Object service) {
            }
        });
        serviceDiscoveryHandlerTracker.open();
        remoteServiceTracker = new ServiceTracker(context, context.createFilter(// $NON-NLS-1$
        "(" + RemoteOSGiService.R_OSGi_REGISTRATION + "=*)"), new // $NON-NLS-1$
        ServiceTrackerCustomizer() {

            public Object addingService(final ServiceReference reference) {
                // FIXME: Surrogates have to be monitored
                // separately!!!
                final ServiceReference service = Arrays.asList((String[]) reference.getProperty(Constants.OBJECTCLASS)).contains(SurrogateRegistration.class.getName()) ? (ServiceReference) reference.getProperty(SurrogateRegistration.SERVICE_REFERENCE) : reference;
                try {
                    final RemoteServiceRegistration reg = new RemoteServiceRegistration(reference, service);
                    if (log != null) {
                        log.log(LogService.LOG_INFO, // $NON-NLS-1$
                        "REGISTERING " + reference + // $NON-NLS-1$
                        " AS PROXIED SERVICES");
                    }
                    synchronized (serviceRegistrations) {
                        serviceRegistrations.put(service, reg);
                    }
                    registerWithServiceDiscovery(reg);
                    final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                    lu.setType(LeaseUpdateMessage.SERVICE_ADDED);
                    lu.setServiceID(String.valueOf(reg.getServiceID()));
                    lu.setPayload(new Object[] { reg.getInterfaceNames(), reg.getProperties() });
                    updateLeases(lu);
                    return service;
                } catch (final ClassNotFoundException e) {
                    e.printStackTrace();
                    throw new RemoteOSGiException("Cannot find class " + service, // $NON-NLS-1$
                    e);
                }
            }

            public void modifiedService(final ServiceReference reference, final Object service) {
                if (reference.getProperty(R_OSGi_REGISTRATION) == null) {
                    removedService(reference, service);
                    return;
                }
                final RemoteServiceRegistration reg = (RemoteServiceRegistration) serviceRegistrations.get(reference);
                registerWithServiceDiscovery(reg);
                final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                lu.setType(LeaseUpdateMessage.SERVICE_MODIFIED);
                lu.setServiceID(String.valueOf(reg.getServiceID()));
                lu.setPayload(new Object[] { null, reg.getProperties() });
                updateLeases(lu);
            }

            public void removedService(final ServiceReference reference, final Object service) {
                final ServiceReference sref = Arrays.asList((String[]) reference.getProperty(Constants.OBJECTCLASS)).contains(SurrogateRegistration.class.getName()) ? (ServiceReference) reference.getProperty(SurrogateRegistration.SERVICE_REFERENCE) : reference;
                final RemoteServiceRegistration reg = (RemoteServiceRegistration) serviceRegistrations.remove(sref);
                unregisterFromServiceDiscovery(reg);
                final LeaseUpdateMessage lu = new LeaseUpdateMessage();
                lu.setType(LeaseUpdateMessage.SERVICE_REMOVED);
                lu.setServiceID(String.valueOf(reg.getServiceID()));
                lu.setPayload(new Object[] { null, null });
                updateLeases(lu);
            }
        });
        remoteServiceTracker.open(true);
        networkChannelFactoryTracker = new ServiceTracker(context, context.createFilter(// $NON-NLS-1$ //$NON-NLS-2$
        "(" + Constants.OBJECTCLASS + "=" + NetworkChannelFactory.class.getName() + ")"), new // $NON-NLS-1$
        ServiceTrackerCustomizer() {

            public Object addingService(final ServiceReference reference) {
                final NetworkChannelFactory factory = (NetworkChannelFactory) context.getService(reference);
                try {
                    factory.activate(RemoteOSGiServiceImpl.this);
                } catch (final IOException ioe) {
                    if (log != null) {
                        log.log(LogService.LOG_ERROR, ioe.getMessage(), ioe);
                    }
                }
                return factory;
            }

            public void modifiedService(final ServiceReference reference, final Object factory) {
            }

            public void removedService(final ServiceReference reference, final Object factory) {
            }
        });
        networkChannelFactoryTracker.open();
    } catch (final InvalidSyntaxException ise) {
        ise.printStackTrace();
    }
}
Also used : NetworkChannelFactory(ch.ethz.iks.r_osgi.channels.NetworkChannelFactory) ServiceTracker(org.osgi.util.tracker.ServiceTracker) ServiceTrackerCustomizer(org.osgi.util.tracker.ServiceTrackerCustomizer) IOException(java.io.IOException) LeaseUpdateMessage(ch.ethz.iks.r_osgi.messages.LeaseUpdateMessage) ChannelEndpoint(ch.ethz.iks.r_osgi.channels.ChannelEndpoint) ServiceReference(org.osgi.framework.ServiceReference) RemoteServiceReference(ch.ethz.iks.r_osgi.RemoteServiceReference) ServiceDiscoveryHandler(ch.ethz.iks.r_osgi.service_discovery.ServiceDiscoveryHandler) RemoteOSGiException(ch.ethz.iks.r_osgi.RemoteOSGiException) Collection(java.util.Collection) List(java.util.List) ArrayList(java.util.ArrayList) InvalidSyntaxException(org.osgi.framework.InvalidSyntaxException)

Aggregations

RemoteOSGiException (ch.ethz.iks.r_osgi.RemoteOSGiException)13 IOException (java.io.IOException)6 ChannelEndpoint (ch.ethz.iks.r_osgi.channels.ChannelEndpoint)5 ByteArrayInputStream (java.io.ByteArrayInputStream)5 InputStream (java.io.InputStream)4 RemoteServiceReference (ch.ethz.iks.r_osgi.RemoteServiceReference)3 RemoteCallMessage (ch.ethz.iks.r_osgi.messages.RemoteCallMessage)3 RemoteCallResultMessage (ch.ethz.iks.r_osgi.messages.RemoteCallResultMessage)3 RemoteOSGiMessage (ch.ethz.iks.r_osgi.messages.RemoteOSGiMessage)3 InputStreamHandle (ch.ethz.iks.r_osgi.streams.InputStreamHandle)3 OutputStreamHandle (ch.ethz.iks.r_osgi.streams.OutputStreamHandle)3 OutputStream (java.io.OutputStream)3 InvalidSyntaxException (org.osgi.framework.InvalidSyntaxException)3 NetworkChannelFactory (ch.ethz.iks.r_osgi.channels.NetworkChannelFactory)2 DeliverBundlesMessage (ch.ethz.iks.r_osgi.messages.DeliverBundlesMessage)2 DeliverServiceMessage (ch.ethz.iks.r_osgi.messages.DeliverServiceMessage)2 LeaseUpdateMessage (ch.ethz.iks.r_osgi.messages.LeaseUpdateMessage)2 RequestBundleMessage (ch.ethz.iks.r_osgi.messages.RequestBundleMessage)2 RequestServiceMessage (ch.ethz.iks.r_osgi.messages.RequestServiceMessage)2 ArrayList (java.util.ArrayList)2