Package org.activemq.message

Examples of org.activemq.message.ActiveMQMessage


    protected void removeExpiredMessages() {
        long currentTime = System.currentTimeMillis();
        List list = queue.getContents();
        for (int i = 0;i < list.size();i++) {
            DurableMessagePointer msgPointer = (DurableMessagePointer) list.get(i);
            ActiveMQMessage message = msgPointer.getMessage();
            if (message.isExpired(currentTime)) {
                // TODO: remove message from message store.
                queue.remove(msgPointer);
                if (log.isDebugEnabled()) {
                    log.debug("expired message: " + msgPointer);
                }
View Full Code Here


    /**
     * Dispatch an Advisory Message
     * @param messagePointer
     */
    private synchronized void doAdvisoryDispatchMessage(DurableMessagePointer messagePointer) {
        ActiveMQMessage message = messagePointer.getMessage();
        try {

            if (message.isAdvisory() && !message.isExpired()) {
                synchronized (subscriptionsMutex) {
                    QueueListEntry entry = subscriptions.getFirstEntry();
                    while (entry != null) {
                        DurableQueueSubscription ts = (DurableQueueSubscription) entry
                                .getElement();
View Full Code Here

     * @param message
     * @throws JMSException
     */
    public void doDispatch(DurableMessagePointer message) throws JMSException {
        dispatchedQueue.enqueue(message);
        ActiveMQMessage msg = message.getMessage().shallowCopy();
        msg.setConsumerNos(new int[]{consumerInfo.getConsumerNo()});
        client.dispatch(msg);
    }
View Full Code Here

     *
     * @param id
     * @return the removed ActiveMQMessage with the associated id
     */
    public ActiveMQMessage acknowledgeMessage(String id) {
        ActiveMQMessage msg = (ActiveMQMessage) dispatchedQueue.remove(id);
        return msg;
    }
View Full Code Here

    /**
     * @return a new Packet instance
     */
    public Packet createPacket() {
        return new ActiveMQMessage();
    }
View Full Code Here

     * @param packet A Packet object
     * @param dataIn the data input stream to build the packet from
     * @throws IOException
     */
    public void buildPacket(Packet packet, DataInput dataIn) throws IOException {
        ActiveMQMessage msg = (ActiveMQMessage) packet;
        BitArray ba = msg.getBitArray();
        ba.readFromStream(dataIn);
       
        boolean receiptRequired = ba.get(AbstractPacket.RECEIPT_REQUIRED_INDEX);
        if (receiptRequired){
            msg.setReceiptRequired(receiptRequired);
            msg.setId(dataIn.readShort());
        }
        boolean externalMessageId = ba.get(ActiveMQMessage.EXTERNAL_MESSAGE_ID_INDEX);
       
        if (externalMessageId){
            msg.setExternalMessageId(externalMessageId);
            msg.setJMSMessageID(readUTF(dataIn));
        }
       
        boolean cachingEnabled = ba.get(ActiveMQMessage.CACHED_VALUES_INDEX);
        boolean cachingDestination = ba.get(ActiveMQMessage.CACHED_DESTINATION_INDEX);
       
        boolean messagePart = ba.get(ActiveMQMessage.MESSAGE_PART_INDEX);
        msg.setMessagePart(messagePart);
        if (messagePart){
            msg.setParentMessageID(dataIn.readUTF());
            msg.setNumberOfParts(dataIn.readShort());
            msg.setPartNumber(dataIn.readShort());
        }
      
        if (ba.get(AbstractPacket.BROKERS_VISITED_INDEX)){
            int visitedLen = dataIn.readShort();
            for (int i =0; i < visitedLen; i++){
                msg.addBrokerVisited(dataIn.readUTF());
            }       
        }
        if (cachingEnabled){
            short key = dataIn.readShort();
            msg.setJMSClientID((String)wireFormat.getValueFromReadCache(key));
            key = dataIn.readShort();
            msg.setProducerKey((String)wireFormat.getValueFromReadCache(key));
            if (cachingDestination){
                key = dataIn.readShort();
                msg.setJMSDestination((Destination)wireFormat.getValueFromReadCache(key));
            }else{
                msg.setJMSDestination(ActiveMQDestination.readFromStream(dataIn));
            }
            if (ba.get(ActiveMQMessage.REPLY_TO_INDEX)) {
                key = dataIn.readShort();
                msg.setJMSReplyTo((Destination)wireFormat.getValueFromReadCache(key));
            }
            if (ba.get(ActiveMQMessage.TRANSACTION_ID_INDEX)) {
                key = dataIn.readShort();
                msg.setTransactionId(wireFormat.getValueFromReadCache(key));
            }
           
        }else {
            msg.setJMSClientID(super.readUTF(dataIn));
            msg.setProducerKey(dataIn.readUTF());
            msg.setJMSDestination(ActiveMQDestination.readFromStream(dataIn));
            if (ba.get(ActiveMQMessage.REPLY_TO_INDEX)) {
                msg.setJMSReplyTo(ActiveMQDestination.readFromStream(dataIn));
            }
            if (ba.get(ActiveMQMessage.TRANSACTION_ID_INDEX)) {
                if( ba.get(ActiveMQMessage.XA_TRANS_INDEX) ) {
                    msg.setTransactionId(ActiveMQXid.read(dataIn));               
                } else {
                    msg.setTransactionId(super.readUTF(dataIn));
                }
            } else {
                msg.setTransactionId(null);
            }
        }
       
       
        msg.setJMSDeliveryMode(dataIn.readByte());
        msg.setJMSPriority(dataIn.readByte());
    
        msg.setJMSRedelivered(ba.get(ActiveMQMessage.REDELIVERED_INDEX));

        if (ba.get(ActiveMQMessage.CORRELATION_INDEX)) {
            msg.setJMSCorrelationID(super.readUTF(dataIn));
        }
        if (ba.get(ActiveMQMessage.TYPE_INDEX)) {
            msg.setJMSType(super.readUTF(dataIn));
        }
        if (ba.get(ActiveMQMessage.BROKER_NAME_INDEX)) {
            msg.setEntryBrokerName(super.readUTF(dataIn));
        }
        if (ba.get(ActiveMQMessage.CLUSTER_NAME_INDEX)) {
            msg.setEntryClusterName(super.readUTF(dataIn));
        }
       
        if (ba.get(ActiveMQMessage.TIMESTAMP_INDEX)) {
            msg.setJMSTimestamp(dataIn.readLong());
        }
        if (ba.get(ActiveMQMessage.EXPIRATION_INDEX)) {
            msg.setJMSExpiration(dataIn.readLong());
        }
        if (ba.get(ActiveMQMessage.LONG_SEQUENCE_INDEX)){
            msg.setSequenceNumber(dataIn.readLong());
        }else {
            msg.setSequenceNumber(dataIn.readInt());
        }
        msg.setDeliveryCount(dataIn.readByte());
        if (ba.get(ActiveMQMessage.DISPATCHED_FROM_DLQ_INDEX)){
            msg.setDispatchedFromDLQ(true);
        }
       
        if (ba.get(ActiveMQMessage.CID_INDEX)) {
            int cidlength = dataIn.readShort();
            if (cidlength > 0) {
                int[] cids = new int[cidlength];
                for (int i = 0; i < cids.length; i++) {
                    cids[i] = dataIn.readShort();
                }
                msg.setConsumerNos(cids);
            }
        }
        if (ba.get(ActiveMQMessage.PROPERTIES_INDEX)) {
            msg.setProperties(msg.readMapProperties(dataIn));
        }
       
        if (ba.get(ActiveMQMessage.PAYLOAD_INDEX)) {
            int payloadLength = dataIn.readInt();
            if (payloadLength >= 0) {
                if (dataIn instanceof WireByteArrayInputStream){
                    WireByteArrayInputStream wireIn = (WireByteArrayInputStream)dataIn;
                    msg.setBodyAsBytes(wireIn.getRawData(), wireIn.position(), payloadLength);
                }else {
                byte[] payload = new byte[payloadLength];
                dataIn.readFully(payload);
                msg.setBodyAsBytes(payload,0,payload.length);
                }
            }
        }
       
          
View Full Code Here

            c = persistenceAdapter.getConnection();           
            byte data[] = adapter.doGetMessage(c, id);
            if( data==null )
                return null;
           
            ActiveMQMessage answer = (ActiveMQMessage) wireFormat.fromBytes(data);;
            answer.setJMSMessageID(identity.getMessageID());
            answer.setJMSMessageIdentity(identity);
            return answer;           
        } catch (IOException e) {
            throw JMSExceptionHelper.newJMSException("Failed to broker message: " + identity.getMessageID() + " in container: " + e, e);
        } catch (SQLException e) {
            throw JMSExceptionHelper.newJMSException("Failed to broker message: " + identity.getMessageID() + " in container: " + e, e);
View Full Code Here

    /**
     * do some dispatching
     */
    public void run() {
        int count = 0;
        ActiveMQMessage message = null;
        while (started.get()) {
            try {
                message = (ActiveMQMessage) queue.dequeue(2000);
                if (message != null) {
                    if (!message.isExpired()) {
                        client.dispatch(message);
                        if (++count == 250) {
                            count = 0;
                            Thread.yield();
                        }
View Full Code Here

     * @return an ActiveMQMessage
     * @throws JMSException if the JMS provider fails to create this message due to some internal error.
     */
    public Message createMessage() throws JMSException {
        checkClosed();
        return new ActiveMQMessage();
    }
View Full Code Here

     * Optional operation, intended to be used only by Application Servers, not by ordinary JMS clients.
     *
     * @see javax.jms.ServerSession
     */
    public void run() {
        ActiveMQMessage message;
        while ((message = messageExecutor.dequeueNoWait()) != null) {
            if( deliveryListener!=null )
                deliveryListener.beforeDelivery(this, message);
            beforeMessageDelivered(message);
            deliver(message);
View Full Code Here

TOP

Related Classes of org.activemq.message.ActiveMQMessage

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.