All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wombat.mama.MamaTransport Maven / Gradle / Ivy

/* $Id$
 *
 * OpenMAMA: The open middleware agnostic messaging API
 * Copyright (C) 2011 NYSE Technologies, Inc.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 * 02110-1301 USA
 */

package com.wombat.mama;

/*
* A wrapper class for the underlying C transport structure
*/
public class MamaTransport
{
    /* ****************************************************** */
    /* Nested Classes. */
    /* ****************************************************** */

    /* This class implements a transport listener which will be set up
     * whenever the transport is allocated and used to route events
     * back to any client listener installed.
     */
    private class InternalTransportListener implements MamaTransportListener
    {
        /* ****************************************************** */
        /* Private Member Variables. */
        /* ****************************************************** */

        // The client listener
        private MamaTransportListener mClientListener;

        /* ****************************************************** */
        /* Construction and Finalization. */
        /* ****************************************************** */

        /**
         * Constructor initialises all member variables.
         */
        public void InternalTransportListener()
        {
            // Ensure that the listeners are null
            mClientListener = null;
        }

        /* ****************************************************** */
        /* Interface Implementations. */
        /* ****************************************************** */

        public void onDisconnect(short cause, final Object platformInfo)
        {
            if (mClientListener != null)
            {
                mClientListener.onDisconnect(cause, platformInfo);
            }
        }

        public void onReconnect(short cause, final Object platformInfo)
        {
            if (mClientListener != null)
            {
                mClientListener.onReconnect(cause, platformInfo);
            }
        }

        public void onQuality(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onQuality(cause, platformInfo);
            }
        }

        public void onConnect(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onConnect(cause, platformInfo);
            }
        }

        public void onAccept(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onAccept(cause, platformInfo);
            }
        }

        public void onAcceptReconnect(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onAcceptReconnect(cause, platformInfo);
            }
        }

        public void onPublisherDisconnect(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onPublisherDisconnect(cause, platformInfo);
            }
        }

        public void onNamingServiceConnect(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onNamingServiceConnect(cause, platformInfo);
            }
        }

        public void onNamingServiceDisconnect(short cause, final Object platformInfo)
        {
            if(mClientListener != null)
            {
                mClientListener.onNamingServiceDisconnect(cause, platformInfo);
            }
        }

        /* ****************************************************** */
        /* Public Functions. */
        /* ****************************************************** */

        /**
         * This function will set the client listener which will then
         * receive events from the transport.
         *
         * @param clientListener The client listener.
         */
        public void setClientListener(MamaTransportListener clientListener)
        {
            /* Save argument in the member variable. */
            mClientListener = clientListener;
        }
    }

    /* This class implements a transport topic listener which will be set up
     * whenever the transport is allocated and used to route events
     * back to any client listener installed.
     */
    private class InternalTopicListener extends MamaTransportTopicListener
    {
        /* ****************************************************** */
        /* Private Member Variables. */
        /* ****************************************************** */

        // The client topic listener
        private MamaTransportTopicListener mClientTopicListener;

        /* ****************************************************** */
        /* Construction and Finalization. */
        /* ****************************************************** */

        /**
         * Constructor initialises all member variables.
         */
        public void InternalTopicListener()
        {
            // Ensure that the listeners are null
            mClientTopicListener = null;
        }

        /* ****************************************************** */
        /* Interface Implementations. */
        /* ****************************************************** */

        public void onTopicSubscribe(String topic, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicSubscribe(topic, platformInfo);
            }
        }

        public void onTopicUnsubscribe(String topic, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicUnsubscribe(topic, platformInfo);
            }
        }

        @SuppressWarnings("deprecation")
        public void onTopicSubscribe(short cause, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicSubscribe(cause, platformInfo);
            }
        }

        @SuppressWarnings("deprecation")
        public void onTopicUnsubscribe(short cause, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicUnsubscribe(cause, platformInfo);
            }
        }

        public void onTopicPublishError(String topic, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicPublishError(topic, platformInfo);
            }
        }

        public void onTopicPublishErrorNotEntitled(String topic, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicPublishErrorNotEntitled(topic, platformInfo);
            }
        }

        public void onTopicPublishErrorBadSymbol(String topic, final Object platformInfo)
        {
            /* Call the client topic listener if it has been provided. */
            if(null != mClientTopicListener)
            {
                mClientTopicListener.onTopicPublishErrorBadSymbol(topic, platformInfo);
            }
        }


        /* ****************************************************** */
        /* Public Functions. */
        /* ****************************************************** */

        /**
         * This function will set the client topic listener which will then
         * receive events from the transport.
         *
         * @param clientTopicListener The client topic listener.
         */
        public void setClientTopicListener(MamaTransportTopicListener clientTopicListener)
        {
            /* Save argument in the member variable. */
            mClientTopicListener = clientTopicListener;
        }
    }

    /* ****************************************************** */
    /* Static Functions. */
    /* ****************************************************** */

    static
    {
        initIDs();
    }

    /* ****************************************************** */
    /* Private Member Variables. */
    /* ****************************************************** */

    /* This value contains a pointer to a utility structure passed as closure
     * to the transport. It is  created in the underlying JNI C layer but must
     * be stored here for each transport.
     */
    private long closurePointer_i   =   0;

    /* The re-usable connection object is passed back up into the transport
     * and topic listeners by the JNI C layer. It is created in Java to avoid
     * bugs in the JVM.
     */
    private MamaConnection mConnection;

    /* The Mama bridge. */
    private MamaBridge myBridge;

    /* Queue for callbacks */
    private MamaQueue myQueue = null;

    /* The re-usable transport listener. */
    InternalTransportListener mListener;

    /* The re-usable transport topic listener. */
    private InternalTopicListener mTopicListener;

    /* This value contains a pointer to the underlying mamaTransport. This object
     * is created in the underlying JNI C layer but must be stored here for each
     * transport.
     */
    private long transportPointer_i =   0;

    /* ****************************************************** */
    /* Construction and Finalization. */
    /* ****************************************************** */

    /**
     * The constructor initialises all member variables and creates the
     * re-usable objects including the transport listeners.
     */
    public MamaTransport()
    {
        /* Create the re-usable connection object using the default constructor
         * so an underlying native object won't be created.
         */
        mConnection = new MamaConnection();

        // Allocate the transport
        allocateTransport(mConnection);
    }

    /* ****************************************************** */
    /* Private Functions. */
    /* ****************************************************** */

    /**
     * This function will allocate the underlying transport.
     *
     * @param connection The re-usable connection object that will be passed
     *                       back up into listener callbacks.
     */
    private native void allocateTransport(MamaConnection connection);

    /**
     * This function will register for the native transport listener.
     * This is done only once the first time that the client registers, from
     * then on the listeners will be added and removed in the Java layer.
     * Unregistration at the C layer will only occur whenever the transport
     * is destroyed.
     *
     * @param listenerEx The listener to add.
     */
    private native void nativeAddListener(MamaTransportListener listener);

    /**
     * This function will register for the native transport topic.
     * This is done only once the first time that the client registers, from
     * then on the listeners will be added and removed in the Java layer.
     * Unregistration at the C layer will only occur whenever the transport
     * is destroyed.
     *
     * @param listenerEx The listener to add.
     */
    private native void nativeAddTopicListener(MamaTransportTopicListener topicListener );

    /**
     * This will pass the MamaQueue to JNi layer so it can be passed to lower layers.
     * It also creates a global ref.
     *
     * @param queue The queue to add.
     */
    private native void nativeSetTransportCallbackQueue(MamaQueue queue);

    /* ****************************************************** */
    /* Public Functions. */
    /* ****************************************************** */

    /**
     * Set the callback queue.
     */
    public void setTransportCallbackQueue(MamaQueue queue)
    {
        myQueue = queue;
        nativeSetTransportCallbackQueue(queue);
    }

    /**
     * Get the callback queue.
     */
    MamaQueue getTransportCallbackQueue()
    {
        return myQueue;
    }

    /**
     * This function will set the client listener, note that only one
     * listener or extended listener is supported at any one time.
     *
     * @param transportListener The new listener, null can be passed to
     *                              remove the current listener.
     */
    public void addTransportListener(MamaTransportListener transportListener)
    {
        // If this internal listener hasn't been created then do so now.
        if(mListener == null)
        {
            // Allocate the listener
            mListener = new InternalTransportListener();

            // Set it in the native layer
            nativeAddListener(mListener);
        }

        /* Set the client's listener inside the re-usable object. */
        mListener.setClientListener(transportListener);
    }

    /**
     * This function will set the client topic listener, note that only one
     * topic listener is supported at any one time.
     *
     * @param transportTopicListener The new listener, null can be passed
     *                                   to remove the current listener.
     */
    public void addTransportTopicListener(MamaTransportTopicListener transportTopicListener)
    {
        // If this internal listener hasn't been created then do so now.
        if(null == mTopicListener)
        {
            // Allocate the listener
            mTopicListener = new InternalTopicListener();

            // Set it in the native layer
            nativeAddTopicListener(mTopicListener);
        }

        /* Set the client's listener inside the re-usable object. */
        mTopicListener.setClientTopicListener(transportTopicListener);
    }

    /**
     * This function will remove the current transport listener.
     * It will actually remove both the basic and extended listeners.
     *
     * @param transportListener The transport listener. Note that this
     *                              parameter is currently redundant.
     */
    public void removeTransportListener(MamaTransportListener transportListener)
    {
        // Note that the listener will only be created if it has been set once
        if(mListener != null)
        {
            /* Set both listeners to null. */
            mListener.setClientListener(null);
        }
    }

    /**
     * This function will remove the current topic listener.
     */
    public void removeTransportTopicListener()
    {
        // Note that the listener will only be created if it has been set once
        if(null != mTopicListener)
        {
            /* Set the current topic listener to null. */
            mTopicListener.setClientTopicListener(null);
        }
    }

    public long getPointerVal()
    {
        return transportPointer_i;
    }

    protected void setPointerVal(long pointerVal)
    {
        transportPointer_i = pointerVal;
    }

    public void create (MamaBridge bridge)
    {
        myBridge = bridge;
        _create (bridge);
    }
    public native void _create (MamaBridge bridge);


    public void create (String name, MamaBridge bridge)
    {
        myBridge = bridge;
        _create (name,bridge);
    }

    public native void _create (String name, MamaBridge bridge);

    /* Destroy the transport. */
    public native void destroy();

    /* Return the outbound throttle rate in messages/second. */
    private native double getOutboundThrottle (int throttleInstance);

    /* Return the outbound throttle rate in messages/second. */
    public double getOutboundThrottle (MamaThrottleInstance throttleInstance)
    {
        final String METHOD_NAME = "getOutboundThrottle(): ";

        if (null==throttleInstance) throw new
                        MamaException(METHOD_NAME + "NULL Throttle instance");

        return getOutboundThrottle (throttleInstance.getValue());
    }

    /*We need this overloaded version to satisify the pure Java samples*/
    public double getOutboundThrottle ()
    {
        return getOutboundThrottle (MamaThrottleInstance.INITIAL_THROTTLE);
    }

    /* Set the throttle rate for outbound message. */
    private native void setOutboundThrottle (int throttleInstance, double outboundThrottle);

    /* Set the throttle rate for outbound message. */
    public void setOutboundThrottle (MamaThrottleInstance throttleInstance,
                                     double outboundThrottle)
    {
        final String METHOD_NAME = "setOutboundThrottle(): ";

        if (null==throttleInstance) throw new MamaException(
                METHOD_NAME + "NULL Throttle instance");

        setOutboundThrottle (throttleInstance.getValue(), outboundThrottle);
    }

    /*We need this overloaded version to satisify the pure Java samples*/
    public void setOutboundThrottle (double outboundThrottle)
    {
         setOutboundThrottle (MamaThrottleInstance.INITIAL_THROTTLE,
                              outboundThrottle);
    }

    public native void setDescription (String description);

    public native String getDescription ();

    /*
        Set whether to invoke the quality callback for all subscriptions
        whenever a data quality event occurs (the default), or whether to
        invoke the quality callback only when data subsequently arrives for a
        subscription.
    */
    public native void setInvokeQualityForAllSubscs (
                        boolean invokeQualityForAllSubscs);

    /*
        Get whether the transport has been set to invoke the quality callback
        for all subscriptions whenever a data quality event occurs.
    */
    public native boolean getInvokeQualityForAllSubscs();

    /*
        Get the quality of the transport.
    */
    public native short getQuality();

    /*Used to cache ids for callback methods/fields*/
    private static native void initIDs();

    public MamaBridge getBridge()
    {
        return myBridge;
    }

    /*Request conflation*/
    public native void requestConflation();

    /*Request end conflation*/
    public native void requestEndConflation();

    /*Get transport name*/
    public native String getName();

    /*The String name for the transport*/
    public native void setName(String name);

}/*end class*/




© 2015 - 2025 Weber Informatics LLC | Privacy Policy