Search in sources :

Example 1 with DeliverServiceMessage

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

the class ChannelEndpointImpl method getProxyBundle.

/**
 * fetch the service from the remote peer.
 *
 * @param ref
 *            the remote service reference.
 * @throws IOException
 *             in case of network errors.
 */
void getProxyBundle(final RemoteServiceReference ref) throws IOException, RemoteOSGiException {
    if (networkChannel == null) {
        // $NON-NLS-1$
        throw new RemoteOSGiException("Channel is closed.");
    }
    // build the RequestServiceMessage
    final RequestServiceMessage req = new RequestServiceMessage();
    req.setServiceID(ref.getURI().getFragment());
    // send the RequestServiceMessage and get a DeliverServiceMessage in
    // return. The DeliverServiceMessage contains a minimal description of
    // the resources
    // of a proxy bundle. This is the service interface plus type injections
    // plus import/export
    // declarations for the bundle.
    final DeliverServiceMessage deliv = (DeliverServiceMessage) sendAndWait(req);
    // generate a proxy bundle for the service
    final InputStream in = new ProxyGenerator().generateProxyBundle(ref.getURI(), deliv);
    installResolveAndStartBundle(ref, in, true);
}
Also used : RequestServiceMessage(ch.ethz.iks.r_osgi.messages.RequestServiceMessage) RemoteOSGiException(ch.ethz.iks.r_osgi.RemoteOSGiException) ByteArrayInputStream(java.io.ByteArrayInputStream) InputStream(java.io.InputStream) DeliverServiceMessage(ch.ethz.iks.r_osgi.messages.DeliverServiceMessage)

Example 2 with DeliverServiceMessage

use of ch.ethz.iks.r_osgi.messages.DeliverServiceMessage 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 3 with DeliverServiceMessage

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

the class CodeAnalyzer method analyze.

/**
 * analyze the service.
 *
 * @param iface
 *            the service interface class name.
 * @param smartProxy
 *            the smart proxy class name or <code>null</code>
 * @param explicitInjections
 *            the injection array or <code>null</code>
 * @param presentation
 *            the presentation class name or <code>null</code>
 * @return the <code>DeliverServiceMessage</code> that contains all
 *         information required to build a proxy on the client side. This
 *         message is generic, can be cached and initialized for a concrete
 *         requesting peer by calling the <code>init</code> method.
 * @throws ClassNotFoundException
 * @throws IOException
 */
DeliverServiceMessage analyze(final String[] ifaces, final String smartProxy, final String[] explicitInjections, final String presentation) throws ClassNotFoundException, IOException {
    closure.addAll(Arrays.asList(ifaces));
    if (smartProxy != null) {
        closure.add(smartProxy);
    }
    if (presentation != null) {
        closure.add(presentation);
    }
    if (explicitInjections != null) {
        closure.addAll(Arrays.asList(explicitInjections));
    }
    while (!closure.isEmpty()) {
        visit((String) closure.remove(0));
    }
    for (int i = 0; i < ifaces.length; i++) {
        proxyImports.add(packageOf(ifaces[i]));
        proxyExports.add(packageOf(ifaces[i]));
    }
    // remove the obvious imports to save network bandwidth
    // $NON-NLS-1$
    proxyImports.remove("org.osgi.framework");
    // $NON-NLS-1$
    proxyImports.remove("ch.ethz.iks.r_osgi");
    // $NON-NLS-1$
    proxyImports.remove("ch.ethz.iks.r_osgi.types");
    // $NON-NLS-1$
    proxyImports.remove("ch.ethz.iks.r_osgi.channels");
    final StringBuffer importDeclaration = new StringBuffer();
    final StringBuffer exportDeclaration = new StringBuffer();
    final String[] pi = (String[]) proxyImports.toArray(new String[proxyImports.size()]);
    for (int i = 0; i < pi.length; i++) {
        importDeclaration.append(pi[i]);
        final Object v = importsMap.get(pi[i]);
        if (v != null) {
            // $NON-NLS-1$
            importDeclaration.append("; ");
            importDeclaration.append(v);
        }
        if (i < pi.length - 1) {
            // $NON-NLS-1$
            importDeclaration.append(", ");
        }
    }
    final String[] pe = (String[]) proxyExports.toArray(new String[proxyExports.size()]);
    for (int i = 0; i < pe.length; i++) {
        exportDeclaration.append(pe[i]);
        final Object v = exportsMap.get(pe[i]);
        if (v != null) {
            // $NON-NLS-1$
            exportDeclaration.append("; ");
            exportDeclaration.append(v);
        }
        if (i < pe.length - 1) {
            // $NON-NLS-1$
            exportDeclaration.append(", ");
        }
    }
    final DeliverServiceMessage message = new DeliverServiceMessage();
    message.setInterfaceNames(ifaces);
    message.setSmartProxyName(smartProxy);
    message.setInjections((HashMap) injections.clone());
    message.setImports(importDeclaration.toString());
    message.setExports(exportDeclaration.toString());
    visited.clear();
    injections.clear();
    closure.clear();
    return message;
}
Also used : DeliverServiceMessage(ch.ethz.iks.r_osgi.messages.DeliverServiceMessage)

Aggregations

DeliverServiceMessage (ch.ethz.iks.r_osgi.messages.DeliverServiceMessage)3 RemoteOSGiException (ch.ethz.iks.r_osgi.RemoteOSGiException)2 RequestServiceMessage (ch.ethz.iks.r_osgi.messages.RequestServiceMessage)2 ByteArrayInputStream (java.io.ByteArrayInputStream)2 InputStream (java.io.InputStream)2 RemoteServiceEvent (ch.ethz.iks.r_osgi.RemoteServiceEvent)1 RemoteServiceReference (ch.ethz.iks.r_osgi.RemoteServiceReference)1 ChannelEndpoint (ch.ethz.iks.r_osgi.channels.ChannelEndpoint)1 DeliverBundlesMessage (ch.ethz.iks.r_osgi.messages.DeliverBundlesMessage)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 StreamRequestMessage (ch.ethz.iks.r_osgi.messages.StreamRequestMessage)1 StreamResultMessage (ch.ethz.iks.r_osgi.messages.StreamResultMessage)1 InputStreamHandle (ch.ethz.iks.r_osgi.streams.InputStreamHandle)1 OutputStreamHandle (ch.ethz.iks.r_osgi.streams.OutputStreamHandle)1