| /** |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package org.apache.activemq; |
| |
| import javax.jms.DeliveryMode; |
| import javax.jms.Destination; |
| import javax.jms.IllegalStateException; |
| import javax.jms.JMSException; |
| import javax.jms.Message; |
| import javax.jms.MessageProducer; |
| |
| /** |
| * A useful base class for implementing a {@link MessageProducer} |
| * |
| * |
| */ |
| public abstract class ActiveMQMessageProducerSupport implements MessageProducer, Closeable { |
| protected ActiveMQSession session; |
| protected boolean disableMessageID; |
| protected boolean disableMessageTimestamp; |
| protected int defaultDeliveryMode; |
| protected int defaultPriority; |
| protected long defaultTimeToLive; |
| protected int sendTimeout=0; |
| |
| public ActiveMQMessageProducerSupport(ActiveMQSession session) { |
| this.session = session; |
| disableMessageTimestamp = session.connection.isDisableTimeStampsByDefault(); |
| } |
| |
| /** |
| * Gets the delivery delay associated with this <CODE>MessageProducer</CODE>. |
| * |
| * @return this producer's <CODE>DeliveryDely/ <CODE> |
| * @throws JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| * @since 2.0 |
| */ |
| @Override |
| public void setDeliveryDelay(long deliveryDelay) throws JMSException { |
| throw new UnsupportedOperationException("setDeliveryDelay() is not supported"); |
| } |
| |
| /** |
| * Gets the delivery delay value for this <CODE>MessageProducer</CODE>. |
| * |
| * @return the delivery delay for this messageProducer |
| * @throws javax.jms.JMSException if the JMS provider fails to determine if deliver delay is |
| * disabled due to some internal error. |
| */ |
| @Override |
| public long getDeliveryDelay() throws JMSException { |
| throw new UnsupportedOperationException("getDeliveryDelay() is not supported"); |
| } |
| |
| /** |
| * Sets whether message IDs are disabled. |
| * <P> |
| * Since message IDs take some effort to create and increase a message's |
| * size, some JMS providers may be able to optimize message overhead if |
| * they are given a hint that the message ID is not used by an application. |
| * By calling the <CODE>setDisableMessageID</CODE> method on this message |
| * producer, a JMS client enables this potential optimization for all |
| * messages sent by this message producer. If the JMS provider accepts this |
| * hint, these messages must have the message ID set to null; if the |
| * provider ignores the hint, the message ID must be set to its normal |
| * unique value. |
| * <P> |
| * Message IDs are enabled by default. |
| * |
| * @param value indicates if message IDs are disabled |
| * @throws javax.jms.JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| */ |
| public void setDisableMessageID(boolean value) throws JMSException { |
| checkClosed(); |
| this.disableMessageID = value; |
| } |
| |
| /** |
| * Gets an indication of whether message IDs are disabled. |
| * |
| * @return an indication of whether message IDs are disabled |
| * @throws javax.jms.JMSException if the JMS provider fails to determine if message IDs are |
| * disabled due to some internal error. |
| */ |
| public boolean getDisableMessageID() throws JMSException { |
| checkClosed(); |
| return this.disableMessageID; |
| } |
| |
| /** |
| * Sets whether message timestamps are disabled. |
| * <P> |
| * Since timestamps take some effort to create and increase a message's |
| * size, some JMS providers may be able to optimize message overhead if |
| * they are given a hint that the timestamp is not used by an application. |
| * By calling the <CODE>setDisableMessageTimestamp</CODE> method on this |
| * message producer, a JMS client enables this potential optimization for |
| * all messages sent by this message producer. If the JMS provider accepts |
| * this hint, these messages must have the timestamp set to zero; if the |
| * provider ignores the hint, the timestamp must be set to its normal |
| * value. |
| * <P> |
| * Message timestamps are enabled by default. |
| * |
| * @param value indicates if message timestamps are disabled |
| * @throws javax.jms.JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| */ |
| public void setDisableMessageTimestamp(boolean value) throws JMSException { |
| checkClosed(); |
| this.disableMessageTimestamp = value; |
| } |
| |
| /** |
| * Gets an indication of whether message timestamps are disabled. |
| * |
| * @return an indication of whether message timestamps are disabled |
| * @throws javax.jms.JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| */ |
| public boolean getDisableMessageTimestamp() throws JMSException { |
| checkClosed(); |
| return this.disableMessageTimestamp; |
| } |
| |
| /** |
| * Sets the producer's default delivery mode. |
| * <P> |
| * Delivery mode is set to <CODE>PERSISTENT</CODE> by default. |
| * |
| * @param newDeliveryMode the message delivery mode for this message producer; legal |
| * values are <code>DeliveryMode.NON_PERSISTENT</code> and |
| * <code>DeliveryMode.PERSISTENT</code> |
| * @throws javax.jms.JMSException if the JMS provider fails to set the delivery mode due to |
| * some internal error. |
| * @see javax.jms.MessageProducer#getDeliveryMode |
| * @see javax.jms.DeliveryMode#NON_PERSISTENT |
| * @see javax.jms.DeliveryMode#PERSISTENT |
| * @see javax.jms.Message#DEFAULT_DELIVERY_MODE |
| */ |
| public void setDeliveryMode(int newDeliveryMode) throws JMSException { |
| if (newDeliveryMode != DeliveryMode.PERSISTENT && newDeliveryMode != DeliveryMode.NON_PERSISTENT) { |
| throw new javax.jms.IllegalStateException("unknown delivery mode: " + newDeliveryMode); |
| } |
| checkClosed(); |
| this.defaultDeliveryMode = newDeliveryMode; |
| } |
| |
| /** |
| * Gets the producer's default delivery mode. |
| * |
| * @return the message delivery mode for this message producer |
| * @throws javax.jms.JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| */ |
| public int getDeliveryMode() throws JMSException { |
| checkClosed(); |
| return this.defaultDeliveryMode; |
| } |
| |
| /** |
| * Sets the producer's default priority. |
| * <P> |
| * The JMS API defines ten levels of priority value, with 0 as the lowest |
| * priority and 9 as the highest. Clients should consider priorities 0-4 as |
| * gradations of normal priority and priorities 5-9 as gradations of |
| * expedited priority. Priority is set to 4 by default. |
| * |
| * @param newDefaultPriority the message priority for this message producer; must be a |
| * value between 0 and 9 |
| * @throws javax.jms.JMSException if the JMS provider fails to set the delivery mode due to |
| * some internal error. |
| * @see javax.jms.MessageProducer#getPriority |
| * @see javax.jms.Message#DEFAULT_PRIORITY |
| */ |
| public void setPriority(int newDefaultPriority) throws JMSException { |
| if (newDefaultPriority < 0 || newDefaultPriority > 9) { |
| throw new IllegalStateException("default priority must be a value between 0 and 9"); |
| } |
| checkClosed(); |
| this.defaultPriority = newDefaultPriority; |
| } |
| |
| /** |
| * Gets the producer's default priority. |
| * |
| * @return the message priority for this message producer |
| * @throws javax.jms.JMSException if the JMS provider fails to close the producer due to |
| * some internal error. |
| * @see javax.jms.MessageProducer#setPriority |
| */ |
| public int getPriority() throws JMSException { |
| checkClosed(); |
| return this.defaultPriority; |
| } |
| |
| /** |
| * Sets the default length of time in milliseconds from its dispatch time |
| * that a produced message should be retained by the message system. |
| * <P> |
| * Time to live is set to zero by default. |
| * |
| * @param timeToLive the message time to live in milliseconds; zero is unlimited |
| * @throws javax.jms.JMSException if the JMS provider fails to set the time to live due to |
| * some internal error. |
| * @see javax.jms.MessageProducer#getTimeToLive |
| * @see javax.jms.Message#DEFAULT_TIME_TO_LIVE |
| */ |
| public void setTimeToLive(long timeToLive) throws JMSException { |
| if (timeToLive < 0L) { |
| throw new IllegalStateException("cannot set a negative timeToLive"); |
| } |
| checkClosed(); |
| this.defaultTimeToLive = timeToLive; |
| } |
| |
| /** |
| * Gets the default length of time in milliseconds from its dispatch time |
| * that a produced message should be retained by the message system. |
| * |
| * @return the message time to live in milliseconds; zero is unlimited |
| * @throws javax.jms.JMSException if the JMS provider fails to get the time to live due to |
| * some internal error. |
| * @see javax.jms.MessageProducer#setTimeToLive |
| */ |
| public long getTimeToLive() throws JMSException { |
| checkClosed(); |
| return this.defaultTimeToLive; |
| } |
| |
| /** |
| * Sends a message using the <CODE>MessageProducer</CODE>'s default |
| * delivery mode, priority, and time to live. |
| * |
| * @param message the message to send |
| * @throws javax.jms.JMSException if the JMS provider fails to send the message due to some |
| * internal error. |
| * @throws javax.jms.MessageFormatException if an invalid message is specified. |
| * @throws javax.jms.InvalidDestinationException if a client uses this method with a <CODE> |
| * MessageProducer</CODE> with an invalid destination. |
| * @throws UnsupportedOperationException |
| * if a client uses this method with a <CODE> |
| * MessageProducer</CODE> that did not specify a |
| * destination at creation time. |
| * @see javax.jms.Session#createProducer |
| * @see javax.jms.MessageProducer |
| * @since 1.1 |
| */ |
| public void send(Message message) throws JMSException { |
| this.send(this.getDestination(), |
| message, |
| this.defaultDeliveryMode, |
| this.defaultPriority, |
| this.defaultTimeToLive); |
| } |
| |
| /** |
| * Sends a message to the destination, specifying delivery mode, priority, |
| * and time to live. |
| * |
| * @param message the message to send |
| * @param deliveryMode the delivery mode to use |
| * @param priority the priority for this message |
| * @param timeToLive the message's lifetime (in milliseconds) |
| * @throws javax.jms.JMSException if the JMS provider fails to send the message due to some |
| * internal error. |
| * @throws javax.jms.MessageFormatException if an invalid message is specified. |
| * @throws javax.jms.InvalidDestinationException if a client uses this method with a <CODE> |
| * MessageProducer</CODE> with an invalid destination. |
| * @throws UnsupportedOperationException |
| * if a client uses this method with a <CODE> |
| * MessageProducer</CODE> that did not specify a |
| * destination at creation time. |
| * @see javax.jms.Session#createProducer |
| * @since 1.1 |
| */ |
| public void send(Message message, int deliveryMode, int priority, long timeToLive) throws JMSException { |
| this.send(this.getDestination(), |
| message, |
| deliveryMode, |
| priority, |
| timeToLive); |
| } |
| |
| /** |
| * Sends a message to a destination for an unidentified message producer. |
| * Uses the <CODE>MessageProducer</CODE>'s default delivery mode, |
| * priority, and time to live. |
| * <P> |
| * Typically, a message producer is assigned a destination at creation |
| * time; however, the JMS API also supports unidentified message producers, |
| * which require that the destination be supplied every time a message is |
| * sent. |
| * |
| * @param destination the destination to send this message to |
| * @param message the message to send |
| * @throws javax.jms.JMSException if the JMS provider fails to send the message due to some |
| * internal error. |
| * @throws javax.jms.MessageFormatException if an invalid message is specified. |
| * @throws javax.jms.InvalidDestinationException if a client uses this method with an invalid destination. |
| * @throws UnsupportedOperationException |
| * if a client uses this method with a <CODE> |
| * MessageProducer</CODE> that specified a destination at |
| * creation time. |
| * @see javax.jms.Session#createProducer |
| * @see javax.jms.MessageProducer |
| */ |
| public void send(Destination destination, Message message) throws JMSException { |
| this.send(destination, |
| message, |
| this.defaultDeliveryMode, |
| this.defaultPriority, |
| this.defaultTimeToLive); |
| } |
| |
| |
| protected abstract void checkClosed() throws IllegalStateException; |
| |
| /** |
| * @return the sendTimeout |
| */ |
| public int getSendTimeout() { |
| return sendTimeout; |
| } |
| |
| /** |
| * @param sendTimeout the sendTimeout to set |
| */ |
| public void setSendTimeout(int sendTimeout) { |
| this.sendTimeout = sendTimeout; |
| } |
| } |