| /* |
| * 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. |
| */ |
| #ifndef _ACTIVEMQ_CONNECTOR_PRODUCERINFO_H_ |
| #define _ACTIVEMQ_CONNECTOR_PRODUCERINFO_H_ |
| |
| #include <cms/Destination.h> |
| |
| #include <activemq/util/Config.h> |
| #include <activemq/connector/BaseConnectorResource.h> |
| #include <activemq/connector/SessionInfo.h> |
| |
| namespace activemq{ |
| namespace connector{ |
| |
| class AMQCPP_API ProducerInfo : public BaseConnectorResource { |
| public: |
| |
| ProducerInfo() : BaseConnectorResource() {} |
| |
| ProducerInfo( Connector* connector ) : |
| BaseConnectorResource( connector ) {} |
| |
| virtual ~ProducerInfo() {} |
| |
| /** |
| * Retrieves the default destination that this producer |
| * sends its messages to. |
| * @return Destionation, owned by this object |
| */ |
| virtual const cms::Destination* getDestination() const = 0; |
| |
| /** |
| * Sets the Default Destination for this Producer |
| * @param destination reference to a destination, copied internally |
| */ |
| virtual void setDestination( const cms::Destination* destination ) = 0; |
| |
| /** |
| * Gets the ID that is assigned to this Producer |
| * @return value of the Producer Id. |
| */ |
| virtual long long getProducerId() const = 0; |
| |
| /** |
| * Sets the ID that is assigned to this Producer |
| * @return id string value of the Producer Id. |
| */ |
| virtual void setProducerId( long long id ) = 0; |
| |
| /** |
| * Gets the Session Info that this consumer is attached too |
| * @return SessionnInfo pointer |
| */ |
| virtual const SessionInfo* getSessionInfo() const = 0; |
| |
| /** |
| * Gets the Session Info that this consumer is attached too |
| * @param session SessionnInfo pointer |
| */ |
| virtual void setSessionInfo( const SessionInfo* session ) = 0; |
| |
| /** |
| * Sets if Message's Produced by this Producer should disable the |
| * use of the MessageId field. |
| * @param value - true if message ids are disabled |
| */ |
| virtual void setDisableMessageId( bool value ) = 0; |
| |
| /** |
| * Gets if Message's Produced by this Producer should disable the |
| * use of the MessageId field. |
| * @returns true if message ids are disabled |
| */ |
| virtual bool isDisableMessageId() const = 0; |
| |
| /** |
| * Gets the set send timeout for messages from this producer, a value of |
| * zero indicates that the Producer should wait forever for a response from |
| * the broker on the send. |
| * @return default time to wait for broker response to a message being sent. |
| */ |
| virtual unsigned int getSendTimeout() const = 0; |
| |
| /** |
| * Sets the time to wait for the broker to respond to a message being sent |
| * @param timeout - The time to wait for the broker to acknowledge that a |
| * message has been received. |
| */ |
| virtual void setSendTimeout( unsigned int timeout ) = 0; |
| |
| }; |
| |
| }} |
| |
| #endif /*_ACTIVEMQ_CONNECTOR_PRODUCERINFO_H_*/ |