Search in sources :

Example 1 with RemoteServiceReference

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

the class ChannelEndpointImpl method getAllRemoteReferences.

/**
 * Get the remote references.
 *
 * @param filter
 *            a filter, or <code>null</code>.
 * @return all remote service references which match the filter.
 */
RemoteServiceReference[] getAllRemoteReferences(final Filter filter) {
    final List result = new ArrayList();
    final RemoteServiceReferenceImpl[] refs = (RemoteServiceReferenceImpl[]) remoteServices.values().toArray(new RemoteServiceReferenceImpl[remoteServices.size()]);
    if (filter == null) {
        return refs.length > 0 ? refs : null;
    } else {
        for (int i = 0; i < refs.length; i++) {
            if (filter.match(refs[i].getProperties())) {
                result.add(refs[i]);
            }
        }
        final RemoteServiceReference[] refs2 = (RemoteServiceReference[]) result.toArray(new RemoteServiceReferenceImpl[result.size()]);
        return refs2.length > 0 ? refs2 : null;
    }
}
Also used : RemoteServiceReference(ch.ethz.iks.r_osgi.RemoteServiceReference) ArrayList(java.util.ArrayList) List(java.util.List) ArrayList(java.util.ArrayList) ChannelEndpoint(ch.ethz.iks.r_osgi.channels.ChannelEndpoint)

Example 2 with RemoteServiceReference

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

the class ChannelEndpointImpl method dispose.

/**
 * dispose the channel.
 *
 * @category ChannelEndpoint
 */
public void dispose() {
    if (networkChannel == null) {
        return;
    }
    if (RemoteOSGiServiceImpl.DEBUG) {
        RemoteOSGiServiceImpl.log.log(LogService.LOG_DEBUG, // $NON-NLS-1$
        "DISPOSING ENDPOINT " + getRemoteAddress());
    }
    RemoteOSGiServiceImpl.unregisterChannelEndpoint(getRemoteAddress().toString());
    if (handlerReg != null) {
        handlerReg.unregister();
    }
    final NetworkChannel oldchannel = networkChannel;
    networkChannel = null;
    try {
        oldchannel.close();
    } catch (final IOException ioe) {
        ioe.printStackTrace();
    }
    if (!hasRedundantLinks) {
        // inform all listeners about all services
        final RemoteServiceReference[] refs = (RemoteServiceReference[]) remoteServices.values().toArray(new RemoteServiceReference[remoteServices.size()]);
        for (int i = 0; i < refs.length; i++) {
            RemoteOSGiServiceImpl.notifyRemoteServiceListeners(new RemoteServiceEvent(RemoteServiceEvent.UNREGISTERING, refs[i]));
        }
        // uninstall the proxy bundle
        final Bundle[] proxies = (Bundle[]) proxyBundles.values().toArray(new Bundle[proxyBundles.size()]);
        for (int i = 0; i < proxies.length; i++) {
            try {
                if (proxies[i].getState() != Bundle.UNINSTALLED) {
                    proxies[i].uninstall();
                }
            } catch (final Throwable t) {
            }
        }
    }
    remoteServices = null;
    remoteTopics = null;
    timeOffset = null;
    callbacks.clear();
    localServices.clear();
    proxiedServices.clear();
    closeStreams();
    streams.clear();
    handlerReg = null;
    synchronized (callbacks) {
        callbacks.notifyAll();
    }
}
Also used : NetworkChannel(ch.ethz.iks.r_osgi.channels.NetworkChannel) RemoteServiceReference(ch.ethz.iks.r_osgi.RemoteServiceReference) Bundle(org.osgi.framework.Bundle) RemoteServiceEvent(ch.ethz.iks.r_osgi.RemoteServiceEvent) IOException(java.io.IOException) ChannelEndpoint(ch.ethz.iks.r_osgi.channels.ChannelEndpoint)

Example 3 with RemoteServiceReference

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

the class ChannelEndpointImpl method handleMessage.

/**
 * message handler method.
 *
 * @param msg
 *            the incoming message.
 * @return if reply is created, null otherwise.
 * @throws RemoteOSGiException
 *             if something goes wrong.
 */
RemoteOSGiMessage handleMessage(final RemoteOSGiMessage msg) throws RemoteOSGiException {
    trace("handleMessage(msg=" + msg + ";remoteAddress=" + networkChannel.getRemoteAddress() + ")");
    switch(msg.getFuncID()) {
        // requests
        case RemoteOSGiMessage.LEASE:
            {
                final LeaseMessage lease = (LeaseMessage) msg;
                processLease(lease);
                populateLease(lease, RemoteOSGiServiceImpl.getServices(networkChannel.getProtocol()), RemoteOSGiServiceImpl.getTopics());
                return lease;
            }
        case RemoteOSGiMessage.REQUEST_SERVICE:
            {
                final RequestServiceMessage reqSrv = (RequestServiceMessage) msg;
                final String serviceID = reqSrv.getServiceID();
                final RemoteServiceRegistration reg = getServiceRegistration(serviceID);
                final DeliverServiceMessage m = reg.getDeliverServiceMessage();
                m.setXID(reqSrv.getXID());
                m.setServiceID(reqSrv.getServiceID());
                return m;
            }
        case RemoteOSGiMessage.LEASE_UPDATE:
            {
                final LeaseUpdateMessage suMsg = (LeaseUpdateMessage) msg;
                final String serviceID = suMsg.getServiceID();
                final short stateUpdate = suMsg.getType();
                final String serviceURI = getRemoteAddress().resolve("#" + serviceID).toString();
                switch(stateUpdate) {
                    case LeaseUpdateMessage.TOPIC_UPDATE:
                        {
                            // There is an older r-OSGi version that incorrectly sends an ArrayList
                            // (1.0.0.RC4_v20131016-1848)
                            Object topicsAdded = suMsg.getPayload()[0];
                            if (topicsAdded instanceof List) {
                                topicsAdded = ((List) topicsAdded).toArray(new String[0]);
                            }
                            Object topicsRemoved = suMsg.getPayload()[1];
                            if (topicsRemoved instanceof List) {
                                topicsRemoved = ((List) topicsRemoved).toArray(new String[0]);
                            }
                            updateTopics((String[]) topicsAdded, (String[]) topicsRemoved);
                            return null;
                        }
                    case LeaseUpdateMessage.SERVICE_ADDED:
                        {
                            final Dictionary properties = (Dictionary) suMsg.getPayload()[1];
                            sanitizeServiceProperties(properties, serviceURI);
                            final RemoteServiceReferenceImpl ref = new RemoteServiceReferenceImpl((String[]) suMsg.getPayload()[0], serviceID, properties, this);
                            remoteServices.put(serviceURI, ref);
                            RemoteOSGiServiceImpl.notifyRemoteServiceListeners(new RemoteServiceEvent(RemoteServiceEvent.REGISTERED, ref));
                            return null;
                        }
                    case LeaseUpdateMessage.SERVICE_MODIFIED:
                        {
                            final Dictionary properties = (Dictionary) suMsg.getPayload()[1];
                            sanitizeServiceProperties(properties, serviceURI);
                            final ServiceRegistration reg = (ServiceRegistration) proxiedServices.get(serviceID);
                            if (reg != null) {
                                reg.setProperties(properties);
                            }
                            // $NON-NLS-1$
                            final RemoteServiceReferenceImpl ref = getRemoteReference(serviceURI);
                            // (see https://bugs.eclipse.org/420433)
                            if (ref == null && reg == null) {
                                return null;
                            }
                            ref.setProperties(properties);
                            RemoteOSGiServiceImpl.notifyRemoteServiceListeners(new RemoteServiceEvent(RemoteServiceEvent.MODIFIED, ref));
                            return null;
                        }
                    case LeaseUpdateMessage.SERVICE_REMOVED:
                        {
                            if (networkChannel == null) {
                                return null;
                            }
                            final RemoteServiceReference ref = (RemoteServiceReference) remoteServices.remove(serviceURI);
                            if (ref != null) {
                                RemoteOSGiServiceImpl.notifyRemoteServiceListeners(new RemoteServiceEvent(RemoteServiceEvent.UNREGISTERING, ref));
                            }
                            final Bundle bundle = (Bundle) proxyBundles.remove(serviceID);
                            if (bundle != null) {
                                try {
                                    bundle.uninstall();
                                } catch (final BundleException be) {
                                    be.printStackTrace();
                                }
                                proxiedServices.remove(serviceID);
                                // $NON-NLS-1$
                                remoteServices.remove(serviceURI);
                            }
                            return null;
                        }
                }
                return null;
            }
        case RemoteOSGiMessage.REMOTE_CALL:
            {
                final RemoteCallMessage invMsg = (RemoteCallMessage) msg;
                try {
                    RemoteServiceRegistration serv = (RemoteServiceRegistration) localServices.get(invMsg.getServiceID());
                    if (serv == null) {
                        final RemoteServiceRegistration reg = getServiceRegistration(invMsg.getServiceID());
                        if (reg == null) {
                            throw new IllegalStateException(toString() + "Could not get " + // $NON-NLS-1$
                            invMsg.getServiceID() + ", known services " + // $NON-NLS-1$
                            localServices);
                        } else {
                            serv = reg;
                        }
                    }
                    // get the invocation arguments and the local method
                    final Object[] arguments = invMsg.getArgs();
                    for (int i = 0; i < arguments.length; i++) {
                        if (arguments[i] instanceof InputStreamHandle) {
                            arguments[i] = getInputStreamProxy((InputStreamHandle) arguments[i]);
                        } else if (arguments[i] instanceof OutputStreamHandle) {
                            arguments[i] = getOutputStreamProxy((OutputStreamHandle) arguments[i]);
                        }
                    }
                    final Method method = serv.getMethod(invMsg.getMethodSignature());
                    // invoke method
                    try {
                        Object result = method.invoke(serv.getServiceObject(), arguments);
                        final RemoteCallResultMessage m = new RemoteCallResultMessage();
                        m.setXID(invMsg.getXID());
                        Class returnType = method.getReturnType();
                        if (result instanceof InputStream) {
                            m.setResult(getInputStreamPlaceholder((InputStream) result));
                        } else if (result instanceof OutputStream) {
                            m.setResult(getOutputStreamPlaceholder((OutputStream) result));
                        } else if (serv.isOSGiAsync() && AsyncReturnUtil.isAsyncType(returnType)) {
                            m.setResult(AsyncReturnUtil.convertAsyncToReturn(result, returnType, serv.getOSGiTimeout()));
                        } else
                            m.setResult(result);
                        return m;
                    } catch (final InvocationTargetException t) {
                        t.printStackTrace();
                        throw t.getTargetException();
                    }
                } catch (final Throwable t) {
                    // TODO: send to log
                    t.printStackTrace();
                    final RemoteCallResultMessage m = new RemoteCallResultMessage();
                    m.setXID(invMsg.getXID());
                    m.setException(t);
                    return m;
                }
            }
        case RemoteOSGiMessage.REMOTE_EVENT:
            {
                final RemoteEventMessage eventMsg = (RemoteEventMessage) msg;
                final Dictionary properties = eventMsg.getProperties();
                // transform the event timestamps
                final Long remoteTs;
                if ((remoteTs = (Long) properties.get(EventConstants.TIMESTAMP)) != null) {
                    properties.put(EventConstants.TIMESTAMP, getOffset().transform(remoteTs));
                }
                final Event event = new Event(eventMsg.getTopic(), properties);
                // and deliver the event to the local framework
                if (RemoteOSGiServiceImpl.eventAdminTracker.getTrackingCount() > 0) {
                    ((EventAdmin) RemoteOSGiServiceImpl.eventAdminTracker.getService()).postEvent(event);
                } else {
                    // TODO: to log
                    System.err.println(// $NON-NLS-1$
                    "Could not deliver received event: " + event + // $NON-NLS-1$
                    ". No EventAdmin available.");
                }
                return null;
            }
        case RemoteOSGiMessage.TIME_OFFSET:
            {
                // add timestamp to the message and return the message to sender
                ((TimeOffsetMessage) msg).timestamp();
                return msg;
            }
        case RemoteOSGiMessage.STREAM_REQUEST:
            {
                final StreamRequestMessage reqMsg = (StreamRequestMessage) msg;
                try {
                    // fetch stream object
                    final Object stream = streams.get(new Integer(reqMsg.getStreamID()));
                    if (stream == null) {
                        throw new IllegalStateException(// $NON-NLS-1$
                        "Could not get stream with ID " + reqMsg.getStreamID());
                    }
                    // invoke operation on stream
                    switch(reqMsg.getOp()) {
                        case StreamRequestMessage.READ:
                            {
                                final int result = ((InputStream) stream).read();
                                final StreamResultMessage m = new StreamResultMessage();
                                m.setXID(reqMsg.getXID());
                                m.setResult((short) result);
                                return m;
                            }
                        case StreamRequestMessage.READ_ARRAY:
                            {
                                final byte[] b = new byte[reqMsg.getLenOrVal()];
                                final int len = ((InputStream) stream).read(b, 0, reqMsg.getLenOrVal());
                                final StreamResultMessage m = new StreamResultMessage();
                                m.setXID(reqMsg.getXID());
                                m.setResult(StreamResultMessage.RESULT_ARRAY);
                                m.setLen(len);
                                if (len > 0) {
                                    m.setData(b);
                                }
                                return m;
                            }
                        case StreamRequestMessage.WRITE:
                            {
                                ((OutputStream) stream).write(reqMsg.getLenOrVal());
                                final StreamResultMessage m = new StreamResultMessage();
                                m.setXID(reqMsg.getXID());
                                m.setResult(StreamResultMessage.RESULT_WRITE_OK);
                                return m;
                            }
                        case StreamRequestMessage.WRITE_ARRAY:
                            {
                                ((OutputStream) stream).write(reqMsg.getData());
                                final StreamResultMessage m = new StreamResultMessage();
                                m.setXID(reqMsg.getXID());
                                m.setResult(StreamResultMessage.RESULT_WRITE_OK);
                                return m;
                            }
                        default:
                            throw new RemoteOSGiException(// $NON-NLS-1$
                            "Unimplemented op code for stream request " + msg);
                    }
                } catch (final IOException e) {
                    final StreamResultMessage m = new StreamResultMessage();
                    m.setXID(reqMsg.getXID());
                    m.setResult(StreamResultMessage.RESULT_EXCEPTION);
                    m.setException(e);
                    return m;
                }
            }
        case RemoteOSGiMessage.REQUEST_BUNDLE:
            final RequestBundleMessage reqB = (RequestBundleMessage) msg;
            try {
                final String serviceID = reqB.getServiceID();
                final RemoteServiceRegistration reg = getServiceRegistration(serviceID);
                final byte[] bytes = RemoteOSGiServiceImpl.getBundle(reg.getReference().getBundle());
                final DeliverBundlesMessage delB = new DeliverBundlesMessage();
                delB.setXID(reqB.getXID());
                delB.setDependencies(new byte[][] { bytes });
                return delB;
            } catch (IOException ioe) {
                ioe.printStackTrace();
                return null;
            }
        case RemoteOSGiMessage.REQUEST_DEPENDENCIES:
            final RequestDependenciesMessage reqDeps = (RequestDependenciesMessage) msg;
            try {
                final byte[][] bundleBytes = RemoteOSGiServiceImpl.getBundlesForPackages(reqDeps.getPackages());
                final DeliverBundlesMessage delDeps = new DeliverBundlesMessage();
                delDeps.setXID(reqDeps.getXID());
                delDeps.setDependencies(bundleBytes);
                return delDeps;
            } catch (IOException ioe) {
                ioe.printStackTrace();
                return null;
            }
        default:
            // $NON-NLS-1$
            throw new RemoteOSGiException("Unimplemented message " + msg);
    }
}
Also used : RequestServiceMessage(ch.ethz.iks.r_osgi.messages.RequestServiceMessage) Dictionary(java.util.Dictionary) DeliverServiceMessage(ch.ethz.iks.r_osgi.messages.DeliverServiceMessage) OutputStream(java.io.OutputStream) RequestBundleMessage(ch.ethz.iks.r_osgi.messages.RequestBundleMessage) RemoteCallResultMessage(ch.ethz.iks.r_osgi.messages.RemoteCallResultMessage) StreamRequestMessage(ch.ethz.iks.r_osgi.messages.StreamRequestMessage) InputStreamHandle(ch.ethz.iks.r_osgi.streams.InputStreamHandle) RemoteEventMessage(ch.ethz.iks.r_osgi.messages.RemoteEventMessage) RemoteOSGiException(ch.ethz.iks.r_osgi.RemoteOSGiException) List(java.util.List) ArrayList(java.util.ArrayList) BundleException(org.osgi.framework.BundleException) ServiceRegistration(org.osgi.framework.ServiceRegistration) OutputStreamHandle(ch.ethz.iks.r_osgi.streams.OutputStreamHandle) RequestDependenciesMessage(ch.ethz.iks.r_osgi.messages.RequestDependenciesMessage) Bundle(org.osgi.framework.Bundle) ByteArrayInputStream(java.io.ByteArrayInputStream) InputStream(java.io.InputStream) RemoteServiceEvent(ch.ethz.iks.r_osgi.RemoteServiceEvent) Method(java.lang.reflect.Method) StreamResultMessage(ch.ethz.iks.r_osgi.messages.StreamResultMessage) IOException(java.io.IOException) LeaseUpdateMessage(ch.ethz.iks.r_osgi.messages.LeaseUpdateMessage) LeaseMessage(ch.ethz.iks.r_osgi.messages.LeaseMessage) InvocationTargetException(java.lang.reflect.InvocationTargetException) ChannelEndpoint(ch.ethz.iks.r_osgi.channels.ChannelEndpoint) RemoteCallMessage(ch.ethz.iks.r_osgi.messages.RemoteCallMessage) RemoteServiceReference(ch.ethz.iks.r_osgi.RemoteServiceReference) RemoteServiceEvent(ch.ethz.iks.r_osgi.RemoteServiceEvent) Event(org.osgi.service.event.Event) DeliverBundlesMessage(ch.ethz.iks.r_osgi.messages.DeliverBundlesMessage)

Example 4 with RemoteServiceReference

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

the class RemoteOSGiServiceImpl method getRemoteService.

/**
 * @param ref
 *            the <code>RemoteServiceReference</code>.
 * @return the service object or <code>null</code> if the service is not
 *         (yet) present.
 * @see ch.ethz.iks.r_osgi.RemoteOSGiService#getRemoteService(ch.ethz.iks.r_osgi.RemoteServiceReference)
 * @category RemoteOSGiService
 * @since 0.6
 */
public Object getRemoteService(final RemoteServiceReference ref) {
    if (ref == null) {
        // $NON-NLS-1$
        throw new IllegalArgumentException("Remote Reference is null.");
    }
    ServiceReference sref = getFetchedServiceReference(ref);
    if (sref == null) {
        fetchService(ref);
        sref = getFetchedServiceReference(ref);
    }
    return sref == null ? null : RemoteOSGiActivator.getActivator().getContext().getService(sref);
}
Also used : ServiceReference(org.osgi.framework.ServiceReference) RemoteServiceReference(ch.ethz.iks.r_osgi.RemoteServiceReference)

Aggregations

RemoteServiceReference (ch.ethz.iks.r_osgi.RemoteServiceReference)4 ChannelEndpoint (ch.ethz.iks.r_osgi.channels.ChannelEndpoint)3 RemoteServiceEvent (ch.ethz.iks.r_osgi.RemoteServiceEvent)2 IOException (java.io.IOException)2 ArrayList (java.util.ArrayList)2 List (java.util.List)2 Bundle (org.osgi.framework.Bundle)2 RemoteOSGiException (ch.ethz.iks.r_osgi.RemoteOSGiException)1 NetworkChannel (ch.ethz.iks.r_osgi.channels.NetworkChannel)1 DeliverBundlesMessage (ch.ethz.iks.r_osgi.messages.DeliverBundlesMessage)1 DeliverServiceMessage (ch.ethz.iks.r_osgi.messages.DeliverServiceMessage)1 LeaseMessage (ch.ethz.iks.r_osgi.messages.LeaseMessage)1 LeaseUpdateMessage (ch.ethz.iks.r_osgi.messages.LeaseUpdateMessage)1 RemoteCallMessage (ch.ethz.iks.r_osgi.messages.RemoteCallMessage)1 RemoteCallResultMessage (ch.ethz.iks.r_osgi.messages.RemoteCallResultMessage)1 RemoteEventMessage (ch.ethz.iks.r_osgi.messages.RemoteEventMessage)1 RequestBundleMessage (ch.ethz.iks.r_osgi.messages.RequestBundleMessage)1 RequestDependenciesMessage (ch.ethz.iks.r_osgi.messages.RequestDependenciesMessage)1 RequestServiceMessage (ch.ethz.iks.r_osgi.messages.RequestServiceMessage)1 StreamRequestMessage (ch.ethz.iks.r_osgi.messages.StreamRequestMessage)1