added the standard JMS headers to IMessage together with support for custom message headers and support for temporary destinations, IMapMessage and IBytesMessage

git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/trunk@380652 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
James Strachan 2006-02-24 12:02:46 +00:00
parent 172b2d11fa
commit f0300f1251
28 changed files with 2429 additions and 749 deletions

View File

@ -22,24 +22,14 @@ using OpenWire.Client.Core;
namespace OpenWire.Client.Commands namespace OpenWire.Client.Commands
{ {
public class ActiveMQBytesMessage : ActiveMQMessage public class ActiveMQBytesMessage : ActiveMQMessage, IBytesMessage
{ {
public const byte ID_ActiveMQBytesMessage = 24; public const byte ID_ActiveMQBytesMessage = 24;
public override byte GetDataStructureType()
{
// TODO generate Equals method
// TODO generate GetHashCode method
// TODO generate ToString method
public override byte GetDataStructureType() {
return ID_ActiveMQBytesMessage; return ID_ActiveMQBytesMessage;
} }
// Properties
} }
} }

View File

@ -18,443 +18,513 @@ using System;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
using OpenWire.Client.Core; using OpenWire.Client.Core;
namespace OpenWire.Client.Commands { namespace OpenWire.Client.Commands
{
/// <summary>
/// Summary description for ActiveMQDestination.
/// </summary>
public abstract class ActiveMQDestination : AbstractCommand, IDestination
{
/// <summary> /**
/// Summary description for ActiveMQDestination. * Topic Destination object
/// </summary> */
public abstract class ActiveMQDestination : AbstractCommand, IDestination { public const int ACTIVEMQ_TOPIC = 1;
/**
/** * Temporary Topic Destination object
* Topic Destination object */
*/ public const int ACTIVEMQ_TEMPORARY_TOPIC = 2;
public const int ACTIVEMQ_TOPIC = 1;
/** /**
* Temporary Topic Destination object * Queue Destination object
*/ */
public const int ACTIVEMQ_TEMPORARY_TOPIC = 2; public const int ACTIVEMQ_QUEUE = 3;
/**
/** * Temporary Queue Destination object
* Queue Destination object */
*/ public const int ACTIVEMQ_TEMPORARY_QUEUE = 4;
public const int ACTIVEMQ_QUEUE = 3;
/** /**
* Temporary Queue Destination object * prefix for Advisory message destinations
*/ */
public const int ACTIVEMQ_TEMPORARY_QUEUE = 4; public const String ADVISORY_PREFIX = "ActiveMQ.Advisory.";
/** /**
* prefix for Advisory message destinations * prefix for consumer advisory destinations
*/ */
public const String ADVISORY_PREFIX = "ActiveMQ.Advisory."; public const String CONSUMER_ADVISORY_PREFIX = ADVISORY_PREFIX + "Consumers.";
/** /**
* prefix for consumer advisory destinations * prefix for producer advisory destinations
*/ */
public const String CONSUMER_ADVISORY_PREFIX = ADVISORY_PREFIX + "Consumers."; public const String PRODUCER_ADVISORY_PREFIX = ADVISORY_PREFIX + "Producers.";
/** /**
* prefix for producer advisory destinations * prefix for connection advisory destinations
*/ */
public const String PRODUCER_ADVISORY_PREFIX = ADVISORY_PREFIX + "Producers."; public const String CONNECTION_ADVISORY_PREFIX = ADVISORY_PREFIX + "Connections.";
/** /**
* prefix for connection advisory destinations * The default target for ordered destinations
*/ */
public const String CONNECTION_ADVISORY_PREFIX = ADVISORY_PREFIX + "Connections."; public const String DEFAULT_ORDERED_TARGET = "coordinator";
/** private const int NULL_DESTINATION = 10;
* The default target for ordered destinations
*/ private const String TEMP_PREFIX = "{TD{";
public const String DEFAULT_ORDERED_TARGET = "coordinator"; private const String TEMP_POSTFIX = "}TD}";
private const String COMPOSITE_SEPARATOR = ",";
private const int NULL_DESTINATION = 10; private const String QUEUE_PREFIX = "queue://";
private const String TOPIC_PREFIX = "topic://";
private const String TEMP_PREFIX = "{TD{";
private const String TEMP_POSTFIX = "}TD}";
private const String COMPOSITE_SEPARATOR = ","; private String physicalName = "";
private const String QUEUE_PREFIX = "queue://";
private const String TOPIC_PREFIX = "topic://"; // Cached transient data
private bool exclusive;
private bool ordered;
private String physicalName = ""; private bool advisory;
private String orderedTarget = DEFAULT_ORDERED_TARGET;
// Cached transient data
private bool exclusive;
private bool ordered; /**
private bool advisory; * The Default Constructor
private String orderedTarget = DEFAULT_ORDERED_TARGET; */
protected ActiveMQDestination()
{
/** }
* The Default Constructor
*/ /**
protected ActiveMQDestination() { * Construct the Destination with a defined physical name;
*
* @param name
*/
protected ActiveMQDestination(String name)
{
this.physicalName = name;
this.advisory = name != null && name.StartsWith(ADVISORY_PREFIX);
}
/**
* @return Returns the advisory.
*/
public bool IsAdvisory()
{
return advisory;
}
/**
* @param advisory The advisory to set.
*/
public void SetAdvisory(bool advisory)
{
this.advisory = advisory;
}
/**
* @return true if this is a destination for Consumer advisories
*/
public bool IsConsumerAdvisory()
{
return IsAdvisory() && physicalName.StartsWith(CONSUMER_ADVISORY_PREFIX);
}
/**
* @return true if this is a destination for Producer advisories
*/
public bool IsProducerAdvisory()
{
return IsAdvisory() && physicalName.StartsWith(PRODUCER_ADVISORY_PREFIX);
}
/**
* @return true if this is a destination for Connection advisories
*/
public bool IsConnectionAdvisory()
{
return IsAdvisory() && physicalName.StartsWith(CONNECTION_ADVISORY_PREFIX);
}
/**
* @return Returns the exclusive.
*/
public bool IsExclusive()
{
return exclusive;
}
/**
* @param exclusive The exclusive to set.
*/
public void SetExclusive(bool exclusive)
{
this.exclusive = exclusive;
}
/**
* @return Returns the ordered.
*/
public bool IsOrdered()
{
return ordered;
}
/**
* @param ordered The ordered to set.
*/
public void SetOrdered(bool ordered)
{
this.ordered = ordered;
}
/**
* @return Returns the orderedTarget.
*/
public String GetOrderedTarget()
{
return orderedTarget;
}
/**
* @param orderedTarget The orderedTarget to set.
*/
public void SetOrderedTarget(String orderedTarget)
{
this.orderedTarget = orderedTarget;
}
/**
* A helper method to return a descriptive string for the topic or queue
* @param destination
*
* @return a descriptive string for this queue or topic
*/
public static String Inspect(ActiveMQDestination destination)
{
if (destination is ITopic)
{
return "Topic(" + destination.ToString() + ")";
}
else
{
return "Queue(" + destination.ToString() + ")";
}
}
/**
* @param destination
* @return @throws JMSException
* @throws javax.jms.JMSException
*/
public static ActiveMQDestination Transform(IDestination destination)
{
ActiveMQDestination result = null;
if (destination != null)
{
if (destination is ActiveMQDestination)
{
result = (ActiveMQDestination) destination;
} }
else
/** {
* Construct the Destination with a defined physical name; if (destination is ITemporaryQueue)
* {
* @param name result = new ActiveMQTempQueue(((IQueue) destination).QueueName);
*/
protected ActiveMQDestination(String name) {
this.physicalName = name;
this.advisory = name != null && name.StartsWith(ADVISORY_PREFIX);
}
/**
* @return Returns the advisory.
*/
public bool IsAdvisory() {
return advisory;
}
/**
* @param advisory The advisory to set.
*/
public void SetAdvisory(bool advisory) {
this.advisory = advisory;
}
/**
* @return true if this is a destination for Consumer advisories
*/
public bool IsConsumerAdvisory() {
return IsAdvisory() && physicalName.StartsWith(CONSUMER_ADVISORY_PREFIX);
}
/**
* @return true if this is a destination for Producer advisories
*/
public bool IsProducerAdvisory() {
return IsAdvisory() && physicalName.StartsWith(PRODUCER_ADVISORY_PREFIX);
}
/**
* @return true if this is a destination for Connection advisories
*/
public bool IsConnectionAdvisory() {
return IsAdvisory() && physicalName.StartsWith(CONNECTION_ADVISORY_PREFIX);
}
/**
* @return Returns the exclusive.
*/
public bool IsExclusive() {
return exclusive;
}
/**
* @param exclusive The exclusive to set.
*/
public void SetExclusive(bool exclusive) {
this.exclusive = exclusive;
}
/**
* @return Returns the ordered.
*/
public bool IsOrdered() {
return ordered;
}
/**
* @param ordered The ordered to set.
*/
public void SetOrdered(bool ordered) {
this.ordered = ordered;
}
/**
* @return Returns the orderedTarget.
*/
public String GetOrderedTarget() {
return orderedTarget;
}
/**
* @param orderedTarget The orderedTarget to set.
*/
public void SetOrderedTarget(String orderedTarget) {
this.orderedTarget = orderedTarget;
}
/**
* A helper method to return a descriptive string for the topic or queue
* @param destination
*
* @return a descriptive string for this queue or topic
*/
public static String Inspect(ActiveMQDestination destination) {
if (destination is ITopic) {
return "Topic(" + destination.ToString() + ")";
} else {
return "Queue(" + destination.ToString() + ")";
}
}
/**
* @param destination
* @return @throws JMSException
* @throws javax.jms.JMSException
*/
public static ActiveMQDestination Transform(IDestination destination) {
ActiveMQDestination result = null;
if (destination != null) {
if (destination is ActiveMQDestination) {
result = (ActiveMQDestination) destination;
} else {
if (destination is ITemporaryQueue) {
result = new ActiveMQTempQueue(((IQueue) destination).QueueName);
} else if (destination is ITemporaryTopic) {
result = new ActiveMQTempTopic(((ITopic) destination).TopicName);
} else if (destination is IQueue) {
result = new ActiveMQQueue(((IQueue) destination).QueueName);
} else if (destination is ITopic) {
result = new ActiveMQTopic(((ITopic) destination).TopicName);
}
}
}
return result;
}
/**
* Create a Destination
* @param type
* @param pyhsicalName
* @return
*/
public static ActiveMQDestination CreateDestination(int type, String pyhsicalName) {
ActiveMQDestination result = null;
if (type == ACTIVEMQ_TOPIC) {
result = new ActiveMQTopic(pyhsicalName);
} else if (type == ACTIVEMQ_TEMPORARY_TOPIC) {
result = new ActiveMQTempTopic(pyhsicalName);
} else if (type == ACTIVEMQ_QUEUE) {
result = new ActiveMQQueue(pyhsicalName);
} else {
result = new ActiveMQTempQueue(pyhsicalName);
}
return result;
}
/**
* Create a temporary name from the clientId
*
* @param clientId
* @return
*/
public static String CreateTemporaryName(String clientId) {
return TEMP_PREFIX + clientId + TEMP_POSTFIX;
}
/**
* From a temporary destination find the clientId of the Connection that created it
*
* @param destination
* @return the clientId or null if not a temporary destination
*/
public static String GetClientId(ActiveMQDestination destination) {
String answer = null;
if (destination != null && destination.IsTemporary()) {
String name = destination.PhysicalName;
int start = name.IndexOf(TEMP_PREFIX);
if (start >= 0) {
start += TEMP_PREFIX.Length;
int stop = name.LastIndexOf(TEMP_POSTFIX);
if (stop > start && stop < name.Length) {
answer = name.Substring(start, stop);
}
}
}
return answer;
}
/**
* @param o object to compare
* @return 1 if this is less than o else 0 if they are equal or -1 if this is less than o
*/
public int CompareTo(Object o) {
if (o is ActiveMQDestination) {
return CompareTo((ActiveMQDestination) o);
}
return -1;
}
/**
* Lets sort by name first then lets sort topics greater than queues
*
* @param that another destination to compare against
* @return 1 if this is less than o else 0 if they are equal or -1 if this is less than o
*/
public int CompareTo(ActiveMQDestination that) {
int answer = 0;
if (physicalName != that.physicalName) {
if (physicalName == null) {
return -1;
} else if (that.physicalName == null) {
return 1;
}
answer = physicalName.CompareTo(that.physicalName);
}
if (answer == 0) {
if (IsTopic()) {
if (that.IsQueue()) {
return 1;
}
} else {
if (that.IsTopic()) {
return -1;
}
}
}
return answer;
}
/**
* @return Returns the Destination type
*/
public abstract int GetDestinationType();
public String PhysicalName {
get { return this.physicalName; }
set { this.physicalName = value; }
}
/**
* Returns true if a temporary Destination
*
* @return true/false
*/
public bool IsTemporary() {
return GetDestinationType() == ACTIVEMQ_TEMPORARY_TOPIC
|| GetDestinationType() == ACTIVEMQ_TEMPORARY_QUEUE;
}
/**
* Returns true if a Topic Destination
*
* @return true/false
*/
public bool IsTopic() {
return GetDestinationType() == ACTIVEMQ_TOPIC
|| GetDestinationType() == ACTIVEMQ_TEMPORARY_TOPIC;
}
/**
* Returns true if a Queue Destination
*
* @return true/false
*/
public bool IsQueue() {
return !IsTopic();
}
/**
* Returns true if this destination represents a collection of
* destinations; allowing a set of destinations to be published to or subscribed
* from in one JMS operation.
* <p/>
* If this destination is a composite then you can call {@link #getChildDestinations()}
* to return the list of child destinations.
*
* @return true if this destination represents a collection of child destinations.
*/
public bool IsComposite() {
return physicalName.IndexOf(COMPOSITE_SEPARATOR) > 0;
}
/**
* Returns a list of child destinations if this destination represents a composite
* destination.
*
* @return
*/
/*public List GetChildDestinations() {
List answer = new ArrayList();
StringTokenizer iter = new StringTokenizer(physicalName, COMPOSITE_SEPARATOR);
while (iter.hasMoreTokens()) {
String name = iter.nextToken();
Destination child = null;
if (name.StartsWith(QUEUE_PREFIX)) {
child = new ActiveMQQueue(name.Substring(QUEUE_PREFIX.Length));
}
else if (name.StartsWith(TOPIC_PREFIX)) {
child = new ActiveMQTopic(name.Substring(TOPIC_PREFIX.Length));
}
else {
child = createDestination(name);
}
answer.add(child);
} }
if (answer.size() == 1) { else if (destination is ITemporaryTopic)
// lets put ourselves inside the collection {
// as we are not really a composite destination result = new ActiveMQTempTopic(((ITopic) destination).TopicName);
answer.set(0, this); }
else if (destination is IQueue)
{
result = new ActiveMQQueue(((IQueue) destination).QueueName);
}
else if (destination is ITopic)
{
result = new ActiveMQTopic(((ITopic) destination).TopicName);
} }
return answer;
}*/
/**
* @return string representation of this instance
*/
public override String ToString() {
return this.physicalName;
} }
}
/** return result;
* @return hashCode for this instance }
*/
/**
public override int GetHashCode() { * Create a Destination
int answer = 37; * @param type
* @param pyhsicalName
if (this.physicalName != null) { * @return
answer = physicalName.GetHashCode(); */
} public static ActiveMQDestination CreateDestination(int type, String pyhsicalName)
if (IsTopic()) { {
answer ^= 0xfabfab; ActiveMQDestination result = null;
} if (type == ACTIVEMQ_TOPIC)
return answer; {
result = new ActiveMQTopic(pyhsicalName);
}
else if (type == ACTIVEMQ_TEMPORARY_TOPIC)
{
result = new ActiveMQTempTopic(pyhsicalName);
}
else if (type == ACTIVEMQ_QUEUE)
{
result = new ActiveMQQueue(pyhsicalName);
}
else
{
result = new ActiveMQTempQueue(pyhsicalName);
}
return result;
}
/**
* Create a temporary name from the clientId
*
* @param clientId
* @return
*/
public static String CreateTemporaryName(String clientId)
{
return TEMP_PREFIX + clientId + TEMP_POSTFIX;
}
/**
* From a temporary destination find the clientId of the Connection that created it
*
* @param destination
* @return the clientId or null if not a temporary destination
*/
public static String GetClientId(ActiveMQDestination destination)
{
String answer = null;
if (destination != null && destination.IsTemporary())
{
String name = destination.PhysicalName;
int start = name.IndexOf(TEMP_PREFIX);
if (start >= 0)
{
start += TEMP_PREFIX.Length;
int stop = name.LastIndexOf(TEMP_POSTFIX);
if (stop > start && stop < name.Length)
{
answer = name.Substring(start, stop);
}
} }
}
/** return answer;
* if the object passed in is equivalent, return true }
*
* @param obj the object to compare
* @return true if this instance and obj are equivalent /**
*/ * @param o object to compare
* @return 1 if this is less than o else 0 if they are equal or -1 if this is less than o
public override bool Equals(Object obj) { */
bool result = this == obj; public int CompareTo(Object o)
if (!result && obj != null && obj is ActiveMQDestination) { {
ActiveMQDestination other = (ActiveMQDestination) obj; if (o is ActiveMQDestination)
result = this.GetDestinationType() == other.GetDestinationType() {
&& this.physicalName.Equals(other.physicalName); return CompareTo((ActiveMQDestination) o);
} }
return result; return -1;
}
/**
* Lets sort by name first then lets sort topics greater than queues
*
* @param that another destination to compare against
* @return 1 if this is less than o else 0 if they are equal or -1 if this is less than o
*/
public int CompareTo(ActiveMQDestination that)
{
int answer = 0;
if (physicalName != that.physicalName)
{
if (physicalName == null)
{
return -1;
} }
else if (that.physicalName == null)
{
/** return 1;
* @return true if the destination matches multiple possible destinations
*/
public bool IsWildcard() {
if (physicalName != null) {
return physicalName.IndexOf(DestinationFilter.ANY_CHILD) >= 0
|| physicalName.IndexOf(DestinationFilter.ANY_DESCENDENT) >= 0;
}
return false;
} }
answer = physicalName.CompareTo(that.physicalName);
}
/** if (answer == 0)
* Factory method to create a child destination if this destination is a composite {
* @param name if (IsTopic())
* @return the created Destination {
*/ if (that.IsQueue())
public abstract ActiveMQDestination CreateDestination(String name); {
} return 1;
}
}
else
{
if (that.IsTopic())
{
return -1;
}
}
}
return answer;
}
/**
* @return Returns the Destination type
*/
public abstract int GetDestinationType();
public String PhysicalName
{
get { return this.physicalName; }
set { this.physicalName = value; }
}
/**
* Returns true if a temporary Destination
*
* @return true/false
*/
public bool IsTemporary()
{
return GetDestinationType() == ACTIVEMQ_TEMPORARY_TOPIC
|| GetDestinationType() == ACTIVEMQ_TEMPORARY_QUEUE;
}
/**
* Returns true if a Topic Destination
*
* @return true/false
*/
public bool IsTopic()
{
return GetDestinationType() == ACTIVEMQ_TOPIC
|| GetDestinationType() == ACTIVEMQ_TEMPORARY_TOPIC;
}
/**
* Returns true if a Queue Destination
*
* @return true/false
*/
public bool IsQueue()
{
return !IsTopic();
}
/**
* Returns true if this destination represents a collection of
* destinations; allowing a set of destinations to be published to or subscribed
* from in one JMS operation.
* <p/>
* If this destination is a composite then you can call {@link #getChildDestinations()}
* to return the list of child destinations.
*
* @return true if this destination represents a collection of child destinations.
*/
public bool IsComposite()
{
return physicalName.IndexOf(COMPOSITE_SEPARATOR) > 0;
}
/**
* Returns a list of child destinations if this destination represents a composite
* destination.
*
* @return
*/
/*public List GetChildDestinations() {
List answer = new ArrayList();
StringTokenizer iter = new StringTokenizer(physicalName, COMPOSITE_SEPARATOR);
while (iter.hasMoreTokens()) {
String name = iter.nextToken();
Destination child = null;
if (name.StartsWith(QUEUE_PREFIX)) {
child = new ActiveMQQueue(name.Substring(QUEUE_PREFIX.Length));
}
else if (name.StartsWith(TOPIC_PREFIX)) {
child = new ActiveMQTopic(name.Substring(TOPIC_PREFIX.Length));
}
else {
child = createDestination(name);
}
answer.add(child);
}
if (answer.size() == 1) {
// lets put ourselves inside the collection
// as we are not really a composite destination
answer.set(0, this);
}
return answer;
}*/
/**
* @return string representation of this instance
*/
public override String ToString()
{
return this.physicalName;
}
/**
* @return hashCode for this instance
*/
public override int GetHashCode()
{
int answer = 37;
if (this.physicalName != null)
{
answer = physicalName.GetHashCode();
}
if (IsTopic())
{
answer ^= 0xfabfab;
}
return answer;
}
/**
* if the object passed in is equivalent, return true
*
* @param obj the object to compare
* @return true if this instance and obj are equivalent
*/
public override bool Equals(Object obj)
{
bool result = this == obj;
if (!result && obj != null && obj is ActiveMQDestination)
{
ActiveMQDestination other = (ActiveMQDestination) obj;
result = this.GetDestinationType() == other.GetDestinationType()
&& this.physicalName.Equals(other.physicalName);
}
return result;
}
/**
* @return true if the destination matches multiple possible destinations
*/
public bool IsWildcard()
{
if (physicalName != null)
{
return physicalName.IndexOf(DestinationFilter.ANY_CHILD) >= 0
|| physicalName.IndexOf(DestinationFilter.ANY_DESCENDENT) >= 0;
}
return false;
}
/**
* Factory method to create a child destination if this destination is a composite
* @param name
* @return the created Destination
*/
public abstract ActiveMQDestination CreateDestination(String name);
}
} }

View File

@ -22,24 +22,40 @@ using OpenWire.Client.Core;
namespace OpenWire.Client.Commands namespace OpenWire.Client.Commands
{ {
public class ActiveMQMapMessage : ActiveMQMessage public class ActiveMQMapMessage : ActiveMQMessage, IMapMessage
{ {
public const byte ID_ActiveMQMapMessage = 25; public const byte ID_ActiveMQMapMessage = 25;
private PrimitiveMap body;
// TODO generate Equals method public override byte GetDataStructureType()
// TODO generate GetHashCode method {
// TODO generate ToString method
public override byte GetDataStructureType() {
return ID_ActiveMQMapMessage; return ID_ActiveMQMapMessage;
} }
public IPrimitiveMap Body
// Properties {
get {
if (body == null)
{
body = PrimitiveMap.Unmarshal(Content);
}
return body;
}
}
public void BeforeMarshall(OpenWireFormat wireFormat)
{
base.BeforeMarshall(wireFormat);
if (body == null) {
Content = null;
}
else {
Content = body.Marshal();
}
}
} }
} }

View File

@ -20,49 +20,281 @@ using System.Collections;
using OpenWire.Client; using OpenWire.Client;
using OpenWire.Client.Core; using OpenWire.Client.Core;
namespace OpenWire.Client.Commands { namespace OpenWire.Client.Commands
public class ActiveMQMessage : Message, IMessage, MarshallAware { {
public const byte ID_ActiveMQMessage = 23; public class ActiveMQMessage : Message, IMessage, MarshallAware
{
public static ActiveMQMessage Transform(IMessage message) { public const byte ID_ActiveMQMessage = 23;
return (ActiveMQMessage) message;
} protected static MessagePropertyHelper propertyHelper = new MessagePropertyHelper();
// TODO generate Equals method private PrimitiveMap properties;
// TODO generate GetHashCode method
// TODO generate ToString method
public override byte GetDataStructureType() { public static ActiveMQMessage Transform(IMessage message)
return ID_ActiveMQMessage; {
} return (ActiveMQMessage) message;
public override bool IsMarshallAware() {
return true;
}
// Properties
public IDestination FromDestination {
get { return Destination; }
set { this.Destination = ActiveMQDestination.Transform(value); }
}
public void BeforeMarshall(OpenWireFormat wireFormat) {
}
public void AfterMarshall(OpenWireFormat wireFormat) {
}
public void BeforeUnmarshall(OpenWireFormat wireFormat) {
}
public void AfterUnmarshall(OpenWireFormat wireFormat) {
}
public void SetMarshalledForm(OpenWireFormat wireFormat, byte[] data) {
}
public byte[] GetMarshalledForm(OpenWireFormat wireFormat) {
return null;
}
} }
// TODO generate Equals method
// TODO generate GetHashCode method
public override byte GetDataStructureType()
{
return ID_ActiveMQMessage;
}
// Properties
public IPrimitiveMap Properties
{
get {
if (properties == null)
{
properties = PrimitiveMap.Unmarshal(MarshalledProperties);
}
return properties;
}
}
public IDestination FromDestination
{
get { return Destination; }
set { this.Destination = ActiveMQDestination.Transform(value); }
}
// IMessage interface
// JMS headers
/// <summary>
/// The correlation ID used to correlate messages with conversations or long running business processes
/// </summary>
public string JMSCorrelationID
{
get {
return CorrelationId;
}
set {
CorrelationId = value;
}
}
/// <summary>
/// The destination of the message
/// </summary>
public IDestination JMSDestination
{
get {
return OriginalDestination;
}
}
/// <summary>
/// The time in milliseconds that this message should expire in
/// </summary>
public long JMSExpiration
{
get {
return Expiration;
}
set {
Expiration = value;
}
}
/// <summary>
/// The message ID which is set by the provider
/// </summary>
public string JMSMessageId
{
get {
return DataStreamMarshaller.ToString(MessageId);
}
}
/// <summary>
/// Whether or not this message is persistent
/// </summary>
public bool JMSPersistent
{
get {
return Persistent;
}
set {
Persistent = value;
}
}
/// <summary>
/// The Priority on this message
/// </summary>
public byte JMSPriority
{
get {
return Priority;
}
set {
Priority = value;
}
}
/// <summary>
/// Returns true if this message has been redelivered to this or another consumer before being acknowledged successfully.
/// </summary>
public bool JMSRedelivered
{
get {
return RedeliveryCounter > 0;
}
}
/// <summary>
/// The destination that the consumer of this message should send replies to
/// </summary>
public IDestination JMSReplyTo
{
get {
return ReplyTo;
}
set {
ReplyTo = ActiveMQDestination.Transform(value);
}
}
/// <summary>
/// The timestamp the broker added to the message
/// </summary>
public long JMSTimestamp
{
get {
return Timestamp;
}
}
/// <summary>
/// The type name of this message
/// </summary>
public string JMSType
{
get {
return Type;
}
set {
Type = value;
}
}
// JMS Extension headers
/// <summary>
/// Returns the number of times this message has been redelivered to other consumers without being acknowledged successfully.
/// </summary>
public int JMSXDeliveryCount
{
get {
return RedeliveryCounter + 1;
}
}
/// <summary>
/// The Message Group ID used to group messages together to the same consumer for the same group ID value
/// </summary>
public string JMSXGroupID
{
get {
return GroupID;
}
set {
GroupID = value;
}
}
/// <summary>
/// The Message Group Sequence counter to indicate the position in a group
/// </summary>
public int JMSXGroupSeq
{
get {
return GroupSequence;
}
set {
GroupSequence = value;
}
}
/// <summary>
/// Returns the ID of the producers transaction
/// </summary>
public string JMSXProducerTXID
{
get {
TransactionId txnId = OriginalTransactionId;
if (txnId == null)
{
txnId = TransactionId;
}
if (txnId != null)
{
return DataStreamMarshaller.ToString(txnId);
}
return null;
}
}
public object GetObjectProperty(string name)
{
return propertyHelper.GetObjectProperty(this, name);
}
public void SetObjectProperty(string name, object value)
{
propertyHelper.SetObjectProperty(this, name, value);
}
// MarshallAware interface
public override bool IsMarshallAware()
{
return true;
}
public void BeforeMarshall(OpenWireFormat wireFormat)
{
MarshalledProperties = null;
if (properties != null)
{
MarshalledProperties = properties.Marshal();
}
}
public void AfterMarshall(OpenWireFormat wireFormat)
{
}
public void BeforeUnmarshall(OpenWireFormat wireFormat)
{
}
public void AfterUnmarshall(OpenWireFormat wireFormat)
{
}
public void SetMarshalledForm(OpenWireFormat wireFormat, byte[] data)
{
}
public byte[] GetMarshalledForm(OpenWireFormat wireFormat)
{
return null;
}
}
} }

View File

@ -1,19 +1,19 @@
/* /*
* Copyright 2006 The Apache Software Foundation or its licensors, as * Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable. * applicable.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
* You may obtain a copy of the License at * You may obtain a copy of the License at
* *
* http://www.apache.org/licenses/LICENSE-2.0 * http://www.apache.org/licenses/LICENSE-2.0
* *
* Unless required by applicable law or agreed to in writing, software * Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, * distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
using System; using System;
using System.Collections; using System.Collections;
@ -34,20 +34,18 @@ namespace OpenWire.Client.Commands
public abstract class ActiveMQTempDestination : ActiveMQDestination public abstract class ActiveMQTempDestination : ActiveMQDestination
{ {
public const byte ID_ActiveMQTempDestination = 0; public const byte ID_ActiveMQTempDestination = 0;
public ActiveMQTempDestination() : base()
{
// TODO generate Equals method }
// TODO generate GetHashCode method
// TODO generate ToString method public ActiveMQTempDestination(String name) : base(name)
{
}
public override byte GetDataStructureType() {
public override byte GetDataStructureType()
{
return ID_ActiveMQTempDestination; return ID_ActiveMQTempDestination;
} }
// Properties
} }
} }

View File

@ -22,15 +22,16 @@ using OpenWire.Client.Core;
namespace OpenWire.Client.Commands namespace OpenWire.Client.Commands
{ {
/// <summary> /// <summary>
/// Summary description for ActiveMQTempQueue. /// A Temporary Queue
/// </summary> /// </summary>
public class ActiveMQTempQueue : ActiveMQDestination, ITemporaryQueue public class ActiveMQTempQueue : ActiveMQTempDestination, ITemporaryQueue
{ {
public const byte ID_ActiveMQTempQueue = 102; public const byte ID_ActiveMQTempQueue = 102;
public ActiveMQTempQueue() : base() public ActiveMQTempQueue() : base()
{ {
} }
public ActiveMQTempQueue(String name) : base(name) public ActiveMQTempQueue(String name) : base(name)
{ {
} }

View File

@ -22,15 +22,16 @@ using OpenWire.Client.Core;
namespace OpenWire.Client.Commands namespace OpenWire.Client.Commands
{ {
/// <summary> /// <summary>
/// Summary description for ActiveMQTempTopic. /// A Temporary Topic
/// </summary> /// </summary>
public class ActiveMQTempTopic : ActiveMQDestination, ITemporaryTopic public class ActiveMQTempTopic : ActiveMQTempDestination, ITemporaryTopic
{ {
public const byte ID_ActiveMQTempTopic = 103; public const byte ID_ActiveMQTempTopic = 103;
public ActiveMQTempTopic() : base() public ActiveMQTempTopic() : base()
{ {
} }
public ActiveMQTempTopic(String name) : base(name) public ActiveMQTempTopic(String name) : base(name)
{ {
} }

View File

@ -1,19 +1,19 @@
/* /*
* Copyright 2006 The Apache Software Foundation or its licensors, as * Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable. * applicable.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
* You may obtain a copy of the License at * You may obtain a copy of the License at
* *
* http://www.apache.org/licenses/LICENSE-2.0 * http://www.apache.org/licenses/LICENSE-2.0
* *
* Unless required by applicable law or agreed to in writing, software * Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, * distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
using System; using System;
using System.Collections; using System.Collections;
@ -34,42 +34,44 @@ namespace OpenWire.Client.Commands
public class TransactionId : AbstractCommand public class TransactionId : AbstractCommand
{ {
public const byte ID_TransactionId = 0; public const byte ID_TransactionId = 0;
public override int GetHashCode() { public override int GetHashCode()
{
int answer = 0; int answer = 0;
return answer; return answer;
} }
public override bool Equals(object that) { public override bool Equals(object that)
if (that is TransactionId) { {
return Equals((TransactionId) that); if (that is TransactionId)
} {
return false; return Equals((TransactionId) that);
} }
return false;
public virtual bool Equals(TransactionId that) { }
public virtual bool Equals(TransactionId that)
{
return true; return true;
} }
public override string ToString() { public override string ToString()
{
return GetType().Name + "[" return GetType().Name + "["
+ " ]"; + " ]";
} }
public override byte GetDataStructureType() { public override byte GetDataStructureType()
{
return ID_TransactionId; return ID_TransactionId;
} }
// Properties
} }
} }

View File

@ -1,19 +1,3 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System; using System;
using System.Collections; using System.Collections;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
@ -39,7 +23,8 @@ namespace OpenWire.Client
private bool closed; private bool closed;
private AcknowledgementMode acknowledgementMode; private AcknowledgementMode acknowledgementMode;
private long sessionCounter; private long sessionCounter;
private IDictionary consumers = new Hashtable();// TODO threadsafe private long temporaryDestinationCounter;
private IDictionary consumers = new Hashtable(); // TODO threadsafe
public Connection(ITransport transport, ConnectionInfo info) public Connection(ITransport transport, ConnectionInfo info)
@ -49,7 +34,7 @@ namespace OpenWire.Client
this.transport.Command += new CommandHandler(OnCommand); this.transport.Command += new CommandHandler(OnCommand);
this.transport.Start(); this.transport.Start();
} }
/// <summary> /// <summary>
/// Starts message delivery for this connection. /// Starts message delivery for this connection.
/// </summary> /// </summary>
@ -57,7 +42,8 @@ namespace OpenWire.Client
{ {
} }
/// <summary>
/// <summary>
/// Stop message delivery for this connection. /// Stop message delivery for this connection.
/// </summary> /// </summary>
public void Stop() public void Stop()
@ -159,6 +145,18 @@ namespace OpenWire.Client
return answer; return answer;
} }
/// <summary>
/// Creates a new temporary destination name
/// </summary>
public String CreateTemporaryDestinationName()
{
lock (this)
{
return info.ConnectionId.Value + ":" + (++temporaryDestinationCounter);
}
}
protected void CheckConnected() protected void CheckConnected()
{ {
if (closed) if (closed)

View File

@ -17,10 +17,12 @@
using System; using System;
using System.IO; using System.IO;
using System.Net; using System.Net;
using System.Text;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
using OpenWire.Client.Core; using OpenWire.Client.Core;
using OpenWire.Client.IO; using OpenWire.Client.IO;
using System.Collections;
namespace OpenWire.Client.Core namespace OpenWire.Client.Core
{ {
@ -30,6 +32,36 @@ namespace OpenWire.Client.Core
/// </summary> /// </summary>
public abstract class DataStreamMarshaller public abstract class DataStreamMarshaller
{ {
public const byte NULL = 0;
public const byte BOOLEAN_TYPE = 1;
public const byte BYTE_TYPE = 2;
public const byte CHAR_TYPE = 3;
public const byte SHORT_TYPE = 4;
public const byte INTEGER_TYPE = 5;
public const byte LONG_TYPE = 6;
public const byte DOUBLE_TYPE = 7;
public const byte FLOAT_TYPE = 8;
public const byte STRING_TYPE = 9;
public const byte BYTE_ARRAY_TYPE = 10;
private static String[] HEX_TABLE = new String[]{
"00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "0a", "0b", "0c", "0d", "0e", "0f",
"10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "1a", "1b", "1c", "1d", "1e", "1f",
"20", "21", "22", "23", "24", "25", "26", "27", "28", "29", "2a", "2b", "2c", "2d", "2e", "2f",
"30", "31", "32", "33", "34", "35", "36", "37", "38", "39", "3a", "3b", "3c", "3d", "3e", "3f",
"40", "41", "42", "43", "44", "45", "46", "47", "48", "49", "4a", "4b", "4c", "4d", "4e", "4f",
"50", "51", "52", "53", "54", "55", "56", "57", "58", "59", "5a", "5b", "5c", "5d", "5e", "5f",
"60", "61", "62", "63", "64", "65", "66", "67", "68", "69", "6a", "6b", "6c", "6d", "6e", "6f",
"70", "71", "72", "73", "74", "75", "76", "77", "78", "79", "7a", "7b", "7c", "7d", "7e", "7f",
"80", "81", "82", "83", "84", "85", "86", "87", "88", "89", "8a", "8b", "8c", "8d", "8e", "8f",
"90", "91", "92", "93", "94", "95", "96", "97", "98", "99", "9a", "9b", "9c", "9d", "9e", "9f",
"a0", "a1", "a2", "a3", "a4", "a5", "a6", "a7", "a8", "a9", "aa", "ab", "ac", "ad", "ae", "af",
"b0", "b1", "b2", "b3", "b4", "b5", "b6", "b7", "b8", "b9", "ba", "bb", "bc", "bd", "be", "bf",
"c0", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "ca", "cb", "cc", "cd", "ce", "cf",
"d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "da", "db", "dc", "dd", "de", "df",
"e0", "e1", "e2", "e3", "e4", "e5", "e6", "e7", "e8", "e9", "ea", "eb", "ec", "ed", "ee", "ef",
"f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7", "f8", "f9", "fa", "fb", "fc", "fd", "fe", "ff",
};
public abstract DataStructure CreateObject(); public abstract DataStructure CreateObject();
public abstract byte GetDataStructureType(); public abstract byte GetDataStructureType();
@ -156,19 +188,11 @@ namespace OpenWire.Client.Core
{ {
if (bs.ReadBoolean()) if (bs.ReadBoolean())
{ {
int size = ReadShort(dataIn); return ReadAsciiString(dataIn);
byte[] data = new byte[size];
dataIn.Read(data, 0, size);
char[] text = new char[size];
for (int i = 0; i < size; i++)
{
text[i] = (char) data[i];
}
return new String(text);
} }
else else
{ {
return dataIn.ReadString(); return ReadUTF8(dataIn);
} }
} }
else else
@ -177,48 +201,61 @@ namespace OpenWire.Client.Core
} }
} }
protected virtual String ReadAsciiString(BinaryReader dataIn)
{
int size = ReadShort(dataIn);
byte[] data = new byte[size];
dataIn.Read(data, 0, size);
char[] text = new char[size];
for (int i = 0; i < size; i++)
{
text[i] = (char) data[i];
}
return new String(text);
}
protected virtual int WriteString(String value, BooleanStream bs) protected virtual int WriteString(String value, BooleanStream bs)
{ {
bs.WriteBoolean(value != null); bs.WriteBoolean(value != null);
if (value != null) if (value != null)
{ {
int strlen = value.Length; int strlen = value.Length;
// TODO until we get UTF8 working, lets just force ASCII // TODO until we get UTF8 working, lets just force ASCII
bs.WriteBoolean(true); bs.WriteBoolean(true);
return strlen + 2; return strlen + 2;
/* /*
int utflen = 0; int utflen = 0;
int c = 0; int c = 0;
bool isOnlyAscii = true; bool isOnlyAscii = true;
char[] charr = value.ToCharArray(); char[] charr = value.ToCharArray();
for (int i = 0; i < strlen; i++) for (int i = 0; i < strlen; i++)
{ {
c = charr[i]; c = charr[i];
if ((c >= 0x0001) && (c <= 0x007F)) if ((c >= 0x0001) && (c <= 0x007F))
{ {
utflen++; utflen++;
} }
else if (c > 0x07FF) else if (c > 0x07FF)
{ {
utflen += 3; utflen += 3;
isOnlyAscii = false; isOnlyAscii = false;
} }
else else
{ {
isOnlyAscii = false; isOnlyAscii = false;
utflen += 2; utflen += 2;
} }
} }
if (utflen >= Int16.MaxValue) if (utflen >= Int16.MaxValue)
throw new IOException("Encountered a String value that is too long to encode."); throw new IOException("Encountered a String value that is too long to encode.");
bs.WriteBoolean(isOnlyAscii); bs.WriteBoolean(isOnlyAscii);
return utflen + 2; return utflen + 2;
*/ */
} }
else else
{ {
@ -236,7 +273,8 @@ namespace OpenWire.Client.Core
WriteShort((short) value.Length, dataOut); WriteShort((short) value.Length, dataOut);
// now lets write the bytes // now lets write the bytes
char[] chars = value.ToCharArray(); char[] chars = value.ToCharArray();
for (int i = 0; i < chars.Length; i++) { for (int i = 0; i < chars.Length; i++)
{
WriteByte((byte) chars[i], dataOut); WriteByte((byte) chars[i], dataOut);
} }
} }
@ -280,7 +318,7 @@ namespace OpenWire.Client.Core
public static void WriteChar(char value, BinaryWriter dataOut) public static void WriteChar(char value, BinaryWriter dataOut)
{ {
dataOut.Write(SwitchEndian(value)); dataOut.Write(SwitchEndian((short) value));
} }
public static void WriteShort(short value, BinaryWriter dataOut) public static void WriteShort(short value, BinaryWriter dataOut)
@ -313,7 +351,8 @@ namespace OpenWire.Client.Core
public static long SwitchEndian(long x) public static long SwitchEndian(long x)
{ {
long answer = 0; long answer = 0;
for (int i = 0; i < 8; i++) { for (int i = 0; i < 8; i++)
{
long lowest = x & 0xff; long lowest = x & 0xff;
x >>= 8; x >>= 8;
answer <<= 8; answer <<= 8;
@ -528,5 +567,418 @@ namespace OpenWire.Client.Core
WriteString(o.Message, dataOut, bs); WriteString(o.Message, dataOut, bs);
} }
} }
/// <summary>
/// Marshals the primitive type map to a byte array
/// </summary>
public static byte[] MarshalPrimitiveMap(IDictionary map)
{
if (map == null)
{
return null;
}
else
{
MemoryStream memoryStream = new MemoryStream();
MarshalPrimitiveMap(map, new BinaryWriter(memoryStream));
return memoryStream.GetBuffer();
}
}
public static void MarshalPrimitiveMap(IDictionary map, BinaryWriter dataOut)
{
if (map == null)
{
WriteInt(-1, dataOut);
}
else
{
WriteInt(map.Count, dataOut);
foreach (DictionaryEntry entry in map)
{
String name = (String) entry.Key;
WriteUTF8(name, dataOut);
Object value = entry.Value;
MarshalPrimitive(dataOut, value);
}
}}
/// <summary>
/// Unmarshals the primitive type map from the given byte array
/// </summary>
public static IDictionary UnmarshalPrimitiveMap(byte[] data)
{
if (data == null)
{
return new Hashtable();
}
else
{
return UnmarshalPrimitiveMap(new BinaryReader(new MemoryStream(data)));
}
}
public static IDictionary UnmarshalPrimitiveMap(BinaryReader dataIn)
{
int size = ReadInt(dataIn);
if (size < 0)
{
return null;
}
else
{
IDictionary answer = new Hashtable(size);
for (int i=0; i < size; i++)
{
String name = ReadUTF8(dataIn);
answer[name] = UnmarshalPrimitive(dataIn);
}
return answer;
}
}
public static void MarshalPrimitive(BinaryWriter dataOut, Object value)
{
if (value == null)
{
WriteByte(NULL, dataOut);
}
else if (value is bool)
{
WriteByte(BOOLEAN_TYPE, dataOut);
WriteBoolean((bool) value, dataOut);
}
else if (value is byte)
{
WriteByte(BYTE_TYPE, dataOut);
WriteByte(((Byte)value), dataOut);
}
else if (value is char)
{
WriteByte(CHAR_TYPE, dataOut);
WriteChar((char) value, dataOut);
}
else if (value is short)
{
WriteByte(SHORT_TYPE, dataOut);
WriteShort((short) value, dataOut);
}
else if (value is int)
{
WriteByte(INTEGER_TYPE, dataOut);
WriteInt((int) value, dataOut);
}
else if (value is long)
{
WriteByte(LONG_TYPE, dataOut);
WriteLong((long) value, dataOut);
}
else if (value is float)
{
WriteByte(FLOAT_TYPE, dataOut);
WriteFloat((float) value, dataOut);
}
else if (value is double)
{
WriteByte(DOUBLE_TYPE, dataOut);
WriteDouble((double) value, dataOut);
}
else if (value is byte[])
{
byte[] data = (byte[]) value;
WriteByte(BYTE_ARRAY_TYPE, dataOut);
WriteInt(data.Length, dataOut);
dataOut.Write(data);
}
else if (value is string)
{
WriteByte(STRING_TYPE, dataOut);
WriteUTF8((string) value, dataOut);
}
else
{
throw new IOException("Object is not a primitive: " + value);
}
}
public static Object UnmarshalPrimitive(BinaryReader dataIn)
{
Object value=null;
switch (ReadByte(dataIn))
{
case BYTE_TYPE:
value = ReadByte(dataIn);
break;
case BOOLEAN_TYPE:
value = ReadBoolean(dataIn);
break;
case CHAR_TYPE:
value = ReadChar(dataIn);
break;
case SHORT_TYPE:
value = ReadShort(dataIn);
break;
case INTEGER_TYPE:
value = ReadInt(dataIn);
break;
case LONG_TYPE:
value = ReadLong(dataIn);
break;
case FLOAT_TYPE:
value = ReadFloat(dataIn);
break;
case DOUBLE_TYPE:
value = ReadDouble(dataIn);
break;
case BYTE_ARRAY_TYPE:
int size = ReadInt(dataIn);
byte[] data = new byte[size];
dataIn.Read(data, 0, size);
value = data;
break;
case STRING_TYPE:
value = ReadUTF8(dataIn);
break;
}
return value;
}
private static Object ReadDouble(BinaryReader dataIn)
{
// TODO: Implement this method
return dataIn.ReadDouble();
}
/// <summary>
/// Method ReadFloat
/// </summary>
/// <param name="dataIn">A BinaryReader</param>
/// <returns>An Object</retutns>
private static Object ReadFloat(BinaryReader dataIn)
{
// TODO: Implement this method
return (float) dataIn.ReadDouble();
}
private static Object ReadBoolean(BinaryReader dataIn)
{
// TODO: Implement this method
return dataIn.ReadBoolean();
}
private static void WriteDouble(double value, BinaryWriter dataOut)
{
// TODO: Implement this method
dataOut.Write(value);
}
private static void WriteFloat(float value, BinaryWriter dataOut)
{
// TODO: Implement this method
dataOut.Write(value);
}
private static void WriteBoolean(bool value, BinaryWriter dataOut)
{
// TODO: Implement this method
dataOut.Write(value);
}
public static void WriteUTF8(String text, BinaryWriter dataOut)
{
if (text != null)
{
int strlen = text.Length;
int utflen = 0;
int c, count = 0;
char[] charr = text.ToCharArray();
for (int i = 0; i < strlen; i++)
{
c = charr[i];
if ((c >= 0x0001) && (c <= 0x007F))
{
utflen++;
}
else if (c > 0x07FF)
{
utflen += 3;
}
else
{
utflen += 2;
}
}
WriteInt(utflen, dataOut);
byte[] bytearr = new byte[utflen];
/*
byte[] bytearr = new byte[utflen + 4];
bytearr[count++] = (byte) ((utflen >>> 24) & 0xFF);
bytearr[count++] = (byte) ((utflen >>> 16) & 0xFF);
bytearr[count++] = (byte) ((utflen >>> 8) & 0xFF);
bytearr[count++] = (byte) ((utflen >>> 0) & 0xFF);
*/
for (int i = 0; i < strlen; i++)
{
c = charr[i];
if ((c >= 0x0001) && (c <= 0x007F))
{
bytearr[count++] = (byte) c;
}
else if (c > 0x07FF)
{
bytearr[count++] = (byte) (0xE0 | ((c >> 12) & 0x0F));
bytearr[count++] = (byte) (0x80 | ((c >> 6) & 0x3F));
bytearr[count++] = (byte) (0x80 | ((c >> 0) & 0x3F));
}
else
{
bytearr[count++] = (byte) (0xC0 | ((c >> 6) & 0x1F));
bytearr[count++] = (byte) (0x80 | ((c >> 0) & 0x3F));
}
}
dataOut.Write(bytearr);
}
else
{
WriteInt(-1, dataOut);
}
}
public static String ReadUTF8(BinaryReader dataIn)
{
int utflen = ReadInt(dataIn);
if (utflen > -1)
{
StringBuilder str = new StringBuilder(utflen);
byte[] bytearr = new byte[utflen];
int c, char2, char3;
int count = 0;
dataIn.Read(bytearr, 0, utflen);
while (count < utflen)
{
c = bytearr[count] & 0xff;
switch (c >> 4)
{
case 0:
case 1:
case 2:
case 3:
case 4:
case 5:
case 6:
case 7:
/* 0xxxxxxx */
count++;
str.Append((char) c);
break;
case 12:
case 13:
/* 110x xxxx 10xx xxxx */
count += 2;
if (count > utflen)
{
throw CreateDataFormatException();
}
char2 = bytearr[count - 1];
if ((char2 & 0xC0) != 0x80)
{
throw CreateDataFormatException();
}
str.Append((char) (((c & 0x1F) << 6) | (char2 & 0x3F)));
break;
case 14:
/* 1110 xxxx 10xx xxxx 10xx xxxx */
count += 3;
if (count > utflen)
{
throw CreateDataFormatException();
}
char2 = bytearr[count - 2];
char3 = bytearr[count - 1];
if (((char2 & 0xC0) != 0x80) || ((char3 & 0xC0) != 0x80))
{
throw CreateDataFormatException();
}
str.Append((char) (((c & 0x0F) << 12) | ((char2 & 0x3F) << 6) | ((char3 & 0x3F) << 0)));
break;
default :
/* 10xx xxxx, 1111 xxxx */
throw CreateDataFormatException();
}
}
// The number of chars produced may be less than utflen
return str.ToString();
}
else
{
return null;
}
}
private static Exception CreateDataFormatException()
{
// TODO: implement a better exception
return new Exception("Data format error!");
}
/// <summary>
/// Converts the object to a String
/// </summary>
public static string ToString(MessageId id)
{
return ToString(id.ProducerId) + ":" + id.ProducerSequenceId;
}
/// <summary>
/// Converts the object to a String
/// </summary>
public static string ToString(ProducerId id)
{
return id.ConnectionId + ":" + id.SessionId + ":" + id.Value;
}
/// <summary>
/// Converts the given transaction ID into a String
/// </summary>
public static String ToString(TransactionId txnId)
{
if (txnId is LocalTransactionId)
{
LocalTransactionId ltxnId = (LocalTransactionId) txnId;
return "" + ltxnId.Value;
}
else if (txnId is XATransactionId)
{
XATransactionId xaTxnId = (XATransactionId) txnId;
return "XID:" + xaTxnId.FormatId + ":" + ToHexFromBytes(xaTxnId.GlobalTransactionId) + ":" + ToHexFromBytes(xaTxnId.BranchQualifier);
}
return null;
}
/// <summary>
/// Creates the byte array into hexidecimal
/// </summary>
public static String ToHexFromBytes(byte[] data)
{
StringBuilder buffer = new StringBuilder(data.Length * 2);
for (int i = 0; i < data.Length; i++)
{
buffer.Append(HEX_TABLE[0xFF & data[i]]);
}
return buffer.ToString();
}
} }
} }

View File

@ -18,7 +18,7 @@ using System.Collections;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
using System; using System;
namespace OpenWire.Client namespace OpenWire.Client.Core
{ {
/// <summary> /// <summary>
/// Handles the multi-threaded dispatching between the transport and the consumers /// Handles the multi-threaded dispatching between the transport and the consumers
@ -42,8 +42,10 @@ namespace OpenWire.Client
/// <returns>An IMessage</retutns> /// <returns>An IMessage</retutns>
public IMessage DequeueNoWait() public IMessage DequeueNoWait()
{ {
lock (queue) { lock (queue)
if (queue.Peek() != null) { {
if (queue.Peek() != null)
{
return (IMessage) queue.Dequeue(); return (IMessage) queue.Dequeue();
} }
} }
@ -69,7 +71,7 @@ namespace OpenWire.Client
{ {
return (IMessage) queue.Dequeue(); return (IMessage) queue.Dequeue();
} }
} }
} }

View File

@ -0,0 +1,57 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.Collections;
using OpenWire.Client;
using OpenWire.Client.Core;
using OpenWire.Client.Commands;
namespace OpenWire.Client.Core
{
public delegate object PropertyGetter(ActiveMQMessage message);
public delegate void PropertySetter(ActiveMQMessage message, object value);
public class MessagePropertyHelper
{
private IDictionary setters = new Hashtable();
private IDictionary getters = new Hashtable();
public MessagePropertyHelper()
{
// TODO find all of the JMS properties via introspection
}
public object GetObjectProperty(ActiveMQMessage message, string name) {
object getter = getters[name];
if (getter != null) {
}
return message.Properties[name];
}
public void SetObjectProperty(ActiveMQMessage message, string name, object value) {
PropertySetter setter = (PropertySetter) setters[name];
if (setter != null) {
setter(message, value);
}
else {
message.Properties[name] = value;
}
}
}
}

View File

@ -0,0 +1,241 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.Collections;
using OpenWire.Client;
using OpenWire.Client.Core;
namespace OpenWire.Client.Core
{
/// <summary>
/// A default implementation of IPrimitiveMap
/// </summary>
public class PrimitiveMap : IPrimitiveMap
{
private IDictionary dictionary = new Hashtable();
/// <summary>
/// Unmarshalls the map from the given data or if the data is null just
/// return an empty map
/// </summary>
public static PrimitiveMap Unmarshal(byte[] data)
{
PrimitiveMap answer = new PrimitiveMap();
answer.dictionary = DataStreamMarshaller.UnmarshalPrimitiveMap(data);
return answer;
}
public byte[] Marshal()
{
return DataStreamMarshaller.MarshalPrimitiveMap(dictionary);
}
public void Clear()
{
dictionary.Clear();
}
public bool Contains(Object key)
{
return dictionary.Contains(key);
}
public void Remove(Object key)
{
dictionary.Remove(key);
}
public int Count
{
get {
return dictionary.Count;
}
}
public ICollection Keys
{
get {
return dictionary.Keys;
}
}
public ICollection Values
{
get {
return dictionary.Values;
}
}
public object this[string key]
{
get {
return GetValue(key);
}
set {
CheckValidType(value);
SetValue(key, value);
}
}
public string GetString(string key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(string));
return (string) value;
}
public void SetString(string key, string value)
{
SetValue(key, value);
}
public bool GetBool(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(bool));
return (bool) value;
}
public void SetByte(String key, bool value)
{
SetValue(key, value);
}
public byte GetByte(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(byte));
return (byte) value;
}
public void SetByte(String key, byte value)
{
SetValue(key, value);
}
public char GetChar(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(char));
return (char) value;
}
public void SetChar(String key, char value)
{
SetValue(key, value);
}
public short GetShort(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(short));
return (short) value;
}
public void SetShort(String key, short value)
{
SetValue(key, value);
}
public int GetInt(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(int));
return (int) value;
}
public void SetInt(String key, int value)
{
SetValue(key, value);
}
public long GetLong(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(long));
return (long) value;
}
public void SetLong(String key, long value)
{
SetValue(key, value);
}
public float GetFloat(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(float));
return (float) value;
}
public void SetFloat(String key, float value)
{
SetValue(key, value);
}
public double GetDouble(String key)
{
Object value = GetValue(key);
CheckValueType(value, typeof(double));
return (double) value;
}
public void SetDouble(String key, double value)
{
SetValue(key, value);
}
protected virtual void SetValue(String key, Object value)
{
dictionary[key] = value;
}
protected virtual Object GetValue(String key)
{
return dictionary[key];
}
protected virtual void CheckValueType(Object value, Type type)
{
if (! type.IsInstanceOfType(value))
{
throw new OpenWireException("Expected type: " + type.Name + " but was: " + value);
}
}
protected virtual void CheckValidType(Object value)
{
if (value != null)
{
Type type = value.GetType();
if (! type.IsPrimitive && !type.IsValueType && !type.IsAssignableFrom(typeof(string)))
{
throw new OpenWireException("Invalid type: " + type.Name + " for value: " + value);
}
}
}
}
}

View File

@ -13,11 +13,22 @@
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
using System;
using OpenWire.Client.Commands;
namespace OpenWire.Client namespace OpenWire.Client
{ {
public interface IStopable /// <summary>
/// Represents a binary based message
/// </summary>
public interface IBytesMessage : IMessage
{ {
void Stop();
byte[] Content
{
get;
set;
}
} }
} }

View File

@ -20,14 +20,14 @@ using OpenWire.Client.Commands;
namespace OpenWire.Client { namespace OpenWire.Client {
public enum AcknowledgementMode { public enum AcknowledgementMode {
Unknown, AutoAcknowledge, ClientAcknowledge, Transactional Unknown, AutoAcknowledge, ClientAcknowledge, Transactional
} }
/// <summary> /// <summary>
/// Represents a connection with a message broker /// Represents a connection with a message broker
/// </summary> /// </summary>
public interface IConnection : IDisposable, IStartable, IStopable { public interface IConnection : IDisposable, IStartable {
/// <summary> /// <summary>
/// Creates a new session to work on this connection /// Creates a new session to work on this connection
@ -44,20 +44,20 @@ namespace OpenWire.Client {
bool Transacted { bool Transacted {
get; get;
set; set;
} }
AcknowledgementMode AcknowledgementMode { AcknowledgementMode AcknowledgementMode {
get; get;
set; set;
} }
String ClientId String ClientId
{ {
get; get;
set; set;
} }
} }
} }

View File

@ -0,0 +1,33 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using OpenWire.Client.Commands;
namespace OpenWire.Client
{
/// <summary>
/// Represents a Map message which contains key and value pairs which are
/// of primitive types
/// </summary>
public interface IMapMessage : IMessage
{
IPrimitiveMap Body {
get;
}
}
}

View File

@ -17,16 +17,145 @@
using System; using System;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
namespace OpenWire.Client { namespace OpenWire.Client
{
/// <summary> /// <summary>
/// Represents a message either to be sent to a message broker or received from a message broker /// Represents a message either to be sent to a message broker or received from a message broker
/// </summary> /// </summary>
public interface IMessage { public interface IMessage
{
IDestination FromDestination {
get; /// <summary>
/// Provides access to the message properties (headers)
/// </summary>
IPrimitiveMap Properties {
get;
} }
/// <summary>
} /// The correlation ID used to correlate messages from conversations or long running business processes
/// </summary>
string JMSCorrelationID
{
get;
set;
}
/// <summary>
/// The destination of the message
/// </summary>
IDestination JMSDestination
{
get;
}
/// <summary>
/// The time in milliseconds that this message should expire in
/// </summary>
long JMSExpiration
{
get;
set;
}
/// <summary>
/// The message ID which is set by the provider
/// </summary>
string JMSMessageId
{
get;
}
/// <summary>
/// Whether or not this message is persistent
/// </summary>
bool JMSPersistent
{
get;
set;
}
/// <summary>
/// The Priority on this message
/// </summary>
byte JMSPriority
{
get;
set;
}
/// <summary>
/// Returns true if this message has been redelivered to this or another consumer before being acknowledged successfully.
/// </summary>
bool JMSRedelivered
{
get;
}
/// <summary>
/// The destination that the consumer of this message should send replies to
/// </summary>
IDestination JMSReplyTo
{
get;
set;
}
/// <summary>
/// The timestamp the broker added to the message
/// </summary>
long JMSTimestamp
{
get;
}
/// <summary>
/// The type name of this message
/// </summary>
string JMSType
{
get;
set;
}
// JMS Extension headers
/// <summary>
/// Returns the number of times this message has been redelivered to other consumers without being acknowledged successfully.
/// </summary>
int JMSXDeliveryCount
{
get;
}
/// <summary>
/// The Message Group ID used to group messages together to the same consumer for the same group ID value
/// </summary>
string JMSXGroupID
{
get;
set;
}
/// <summary>
/// The Message Group Sequence counter to indicate the position in a group
/// </summary>
int JMSXGroupSeq
{
get;
set;
}
/// <summary>
/// Returns the ID of the producers transaction
/// </summary>
string JMSXProducerTXID
{
get;
}
}
} }

View File

@ -0,0 +1,86 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.Collections;
using OpenWire.Client.Commands;
namespace OpenWire.Client
{
/// <summary>
/// Represents a Map of primitive types where the keys are all string instances
/// and the values are strings or numbers.
/// </summary>
public interface IPrimitiveMap
{
void Clear();
bool Contains(object key);
void Remove(object key);
int Count
{
get;
}
ICollection Keys
{
get;
}
ICollection Values
{
get;
}
object this[string key]
{
get;
set;
}
string GetString(string key);
void SetString(string key, string value);
bool GetBool(string key);
void SetByte(string key, bool value);
byte GetByte(string key);
void SetByte(string key, byte value);
char GetChar(string key);
void SetChar(string key, char value);
short GetShort(string key);
void SetShort(string key, short value);
int GetInt(string key);
void SetInt(string key, int value);
long GetLong(string key);
void SetLong(string key, long value);
float GetFloat(string key);
void SetFloat(string key, float value);
double GetDouble(string key);
void SetDouble(string key, double value);
}
}

View File

@ -17,34 +17,39 @@
using System; using System;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
namespace OpenWire.Client { namespace OpenWire.Client
{
/// <summary> /// <summary>
/// Represents a single unit of work on an IConnection. /// Represents a single unit of work on an IConnection.
/// So the ISession can be used to perform transactional receive and sends /// So the ISession can be used to perform transactional receive and sends
/// </summary> /// </summary>
public interface ISession : IDisposable { public interface ISession : IDisposable
{
/// <summary> /// <summary>
/// Creates a producer of messages /// Creates a producer of messages
/// </summary> /// </summary>
IMessageProducer CreateProducer(); IMessageProducer CreateProducer();
/// <summary> /// <summary>
/// Creates a producer of messages on a given destination /// Creates a producer of messages on a given destination
/// </summary> /// </summary>
IMessageProducer CreateProducer(IDestination destination); IMessageProducer CreateProducer(IDestination destination);
/// <summary> /// <summary>
/// Creates a consumer of messages on a given destination /// Creates a consumer of messages on a given destination
/// </summary> /// </summary>
IMessageConsumer CreateConsumer(IDestination destination); IMessageConsumer CreateConsumer(IDestination destination);
/// <summary> /// <summary>
/// Creates a consumer of messages on a given destination with a selector /// Creates a consumer of messages on a given destination with a selector
/// </summary> /// </summary>
IMessageConsumer CreateConsumer(IDestination destination, string selector); IMessageConsumer CreateConsumer(IDestination destination, string selector);
/// <summary> /// <summary>
/// Creates a named durable consumer of messages on a given destination with a selector /// Creates a named durable consumer of messages on a given destination with a selector
/// </summary> /// </summary>
IMessageConsumer CreateDurableConsumer(ITopic destination, string name, string selector, bool noLocal); IMessageConsumer CreateDurableConsumer(ITopic destination, string name, string selector, bool noLocal);
@ -52,26 +57,56 @@ namespace OpenWire.Client {
/// <summary> /// <summary>
/// Returns the queue for the given name /// Returns the queue for the given name
/// </summary> /// </summary>
IQueue GetQueue(string name); IQueue GetQueue(string name);
/// <summary> /// <summary>
/// Returns the topic for the given name /// Returns the topic for the given name
/// </summary> /// </summary>
ITopic GetTopic(string name); ITopic GetTopic(string name);
/// <summary>
/// Creates a temporary queue
/// </summary>
ITemporaryQueue CreateTemporaryQueue();
/// <summary>
/// Creates a temporary topic
/// </summary>
ITemporaryTopic CreateTemporaryTopic();
// Factory methods to create messages
/// <summary> /// <summary>
/// Creates a new message with an empty body /// Creates a new message with an empty body
/// </summary> /// </summary>
IMessage CreateMessage(); IMessage CreateMessage();
/// <summary> /// <summary>
/// Creates a new text message with an empty body /// Creates a new text message with an empty body
/// </summary> /// </summary>
ITextMessage CreateTextMessage(); ITextMessage CreateTextMessage();
/// <summary> /// <summary>
/// Creates a new text message with the given body /// Creates a new text message with the given body
/// </summary> /// </summary>
ITextMessage CreateTextMessage(string text); ITextMessage CreateTextMessage(string text);
}
/// <summary>
/// Creates a new Map message which contains primitive key and value pairs
/// </summary>
IMapMessage CreateMapMessage();
/// <summary>
/// Creates a new binary message
/// </summary>
IBytesMessage CreateBytesMessage();
/// <summary>
/// Creates a new binary message with the given body
/// </summary>
IBytesMessage CreateBytesMessage(byte[] body);
}
} }

View File

@ -17,15 +17,18 @@
using System; using System;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
namespace OpenWire.Client { namespace OpenWire.Client
/// <summary> {
/// Represents a text based message /// <summary>
/// </summary> /// Represents a text based message
public interface ITextMessage : IMessage { /// </summary>
public interface ITextMessage : IMessage
string Text { {
get;
set; string Text
} {
} get;
set;
}
}
} }

View File

@ -18,6 +18,7 @@ using System;
using System.Collections; using System.Collections;
using System.Threading; using System.Threading;
using OpenWire.Client.Commands; using OpenWire.Client.Commands;
using OpenWire.Client.Core;
namespace OpenWire.Client namespace OpenWire.Client
{ {

View File

@ -28,13 +28,13 @@ namespace OpenWire.Client
private Session session; private Session session;
private ProducerInfo info; private ProducerInfo info;
private long messageCounter; private long messageCounter;
bool persistent; bool persistent;
long timeToLive; long timeToLive;
int priority; int priority;
bool disableMessageID; bool disableMessageID;
bool disableMessageTimestamp; bool disableMessageTimestamp;
public MessageProducer(Session session, ProducerInfo info) public MessageProducer(Session session, ProducerInfo info)
{ {
this.session = session; this.session = session;
@ -57,7 +57,7 @@ namespace OpenWire.Client
ActiveMQMessage activeMessage = (ActiveMQMessage) message; ActiveMQMessage activeMessage = (ActiveMQMessage) message;
activeMessage.MessageId = id; activeMessage.MessageId = id;
activeMessage.ProducerId = info.ProducerId; activeMessage.ProducerId = info.ProducerId;
activeMessage.Destination = (ActiveMQDestination) destination; activeMessage.Destination = ActiveMQDestination.Transform(destination);
session.DoSend(destination, message); session.DoSend(destination, message);
} }
@ -71,14 +71,13 @@ namespace OpenWire.Client
{ {
get { return persistent; } get { return persistent; }
set { this.persistent = value; } set { this.persistent = value; }
} }
public long TimeToLive public long TimeToLive
{ {
get { return timeToLive; } get { return timeToLive; }
set { this.timeToLive = value; } set { this.timeToLive = value; }
} }
public int Priority public int Priority
{ {
get { return priority; } get { return priority; }

View File

@ -124,6 +124,18 @@ namespace OpenWire.Client
return new ActiveMQTopic(name); return new ActiveMQTopic(name);
} }
public ITemporaryQueue CreateTemporaryQueue()
{
return new ActiveMQTempQueue(connection.CreateTemporaryDestinationName());
}
public ITemporaryTopic CreateTemporaryTopic()
{
return new ActiveMQTempTopic(connection.CreateTemporaryDestinationName());
}
public IMessage CreateMessage() public IMessage CreateMessage()
{ {
ActiveMQMessage answer = new ActiveMQMessage(); ActiveMQMessage answer = new ActiveMQMessage();
@ -146,6 +158,26 @@ namespace OpenWire.Client
return answer; return answer;
} }
public IMapMessage CreateMapMessage()
{
return new ActiveMQMapMessage();
}
public IBytesMessage CreateBytesMessage()
{
return new ActiveMQBytesMessage();
}
public IBytesMessage CreateBytesMessage(byte[] body)
{
ActiveMQBytesMessage answer = new ActiveMQBytesMessage();
answer.Content = body;
return answer;
}
// Implementation methods // Implementation methods
public void DoSend(IDestination destination, IMessage message) public void DoSend(IDestination destination, IMessage message)
{ {
@ -181,7 +213,7 @@ namespace OpenWire.Client
id.Value = ++consumerCounter; id.Value = ++consumerCounter;
} }
answer.ConsumerId = id; answer.ConsumerId = id;
answer.Destination = (ActiveMQDestination) destination; answer.Destination = ActiveMQDestination.Transform(destination);
answer.Selector = selector; answer.Selector = selector;
answer.PrefetchSize = prefetchSize; answer.PrefetchSize = prefetchSize;
@ -200,7 +232,7 @@ namespace OpenWire.Client
id.Value = ++producerCounter; id.Value = ++producerCounter;
} }
answer.ProducerId = id; answer.ProducerId = id;
answer.Destination = (ActiveMQDestination) destination; answer.Destination = ActiveMQDestination.Transform(destination);
return answer; return answer;
} }

View File

@ -0,0 +1,58 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.IO;
using NUnit.Framework;
using OpenWire.Client;
using OpenWire.Client.Core;
namespace OpenWire.Client
{
[ TestFixture ]
public class BytesMessageTest : TestSupport
{
byte[] expected = {1, 2, 3, 4, 5, 6, 7, 8};
[ Test ]
public override void SendAndSyncReceive()
{
base.SendAndSyncReceive();
}
protected override IMessage CreateMessage(ISession session)
{
IBytesMessage request = session.CreateBytesMessage(expected);
return request;
}
protected override void AssertValidMessage(IMessage message)
{
Assert.IsTrue(message is IBytesMessage, "Did not receive a IBytesMessage: " + message);
Console.WriteLine("Received IBytesMessage: " + message);
IBytesMessage bytesMessage = (IBytesMessage) message;
byte[] actual = bytesMessage.Content;
Console.WriteLine("Received message with content: " + actual);
Assert.AreEqual(expected, actual, "the message content");
}
}
}

View File

@ -27,46 +27,28 @@ namespace OpenWire.Client
[ TestFixture ] [ TestFixture ]
public class ClientTest : TestSupport public class ClientTest : TestSupport
{ {
string expected = "Hello World!";
[ Test ] [ Test ]
public void SendAndSyncReceive() public override void SendAndSyncReceive()
{ {
IConnectionFactory factory = new ConnectionFactory("localhost", 61616); base.SendAndSyncReceive();
Assert.IsTrue(factory != null, "no factory created");
using (IConnection connection = factory.CreateConnection())
{
try
{
Assert.IsTrue(connection != null, "no connection created");
Console.WriteLine("Connected to ActiveMQ!");
ISession session = connection.CreateSession();
IDestination destination = session.GetQueue("FOO.BAR");
Assert.IsTrue(destination != null, "No queue available!");
IMessageConsumer consumer = session.CreateConsumer(destination);
IMessageProducer producer = session.CreateProducer(destination);
string expected = "Hello World!";
ITextMessage request = session.CreateTextMessage(expected);
producer.Send(request);
ITextMessage message = (ITextMessage) consumer.Receive();
Assert.IsNotNull(message, "No message returned!");
Assert.AreEqual(expected, message.Text, "the message text");
}
catch (Exception e)
{
Console.WriteLine("Caught: " + e);
}
}
} }
protected override IMessage CreateMessage(ISession session)
{
IMessage request = session.CreateTextMessage(expected);
return request;
}
protected override void AssertValidMessage(IMessage message)
{
ITextMessage textMessage = (ITextMessage) message;
String text = textMessage.Text;
Console.WriteLine("Received message with text: " + text);
Assert.AreEqual(expected, text, "the message text");
}
} }
} }

View File

@ -0,0 +1,127 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.IO;
using NUnit.Framework;
using OpenWire.Client;
using OpenWire.Client.Core;
namespace OpenWire.Client
{
[ TestFixture ]
public class JMSPropertyTest : TestSupport
{
// standard JMS properties
string expectedText = "Hey this works!";
string correlationID = "abc";
ITemporaryQueue replyTo;
bool persistent = true;
byte priority = 5;
String type = "FooType";
String groupID = "MyGroup";
int groupSeq = 1;
// custom properties
string customText = "Cheese";
bool custom1 = true;
byte custom2 = 12;
short custom3 = 0x1234;
int custom4 = 0x12345678;
long custom5 = 0x1234567812345678;
char custom6 = 'J';
[ Test ]
public override void SendAndSyncReceive()
{
base.SendAndSyncReceive();
}
protected override IMessage CreateMessage(ISession session)
{
ITextMessage message = session.CreateTextMessage(expectedText);
replyTo = session.CreateTemporaryQueue();
// lets set the headers
message.JMSCorrelationID = correlationID;
message.JMSReplyTo = replyTo;
message.JMSPersistent = persistent;
message.JMSPriority = priority;
message.JMSType = type;
message.JMSXGroupID = groupID;
message.JMSXGroupSeq = groupSeq;
// lets set the custom headers
message.Properties["customText"] = customText;
message.Properties["custom1"] = custom1;
message.Properties["custom2"] = custom2;
message.Properties["custom3"] = custom3;
message.Properties["custom4"] = custom4;
message.Properties["custom5"] = custom5;
message.Properties["custom6"] = custom6;
return message;
}
protected override void AssertValidMessage(IMessage message)
{
Assert.IsTrue(message is ITextMessage, "Did not receive a ITextMessage!");
Console.WriteLine("Received Message: " + message);
ITextMessage textMessage = (ITextMessage) message;
String text = textMessage.Text;
Assert.AreEqual(expectedText, text, "the message text");
// compare standard JMS headers
Assert.AreEqual(correlationID, message.JMSCorrelationID, "JMSCorrelationID");
Assert.AreEqual(replyTo, message.JMSReplyTo, "JMSReplyTo");
Assert.AreEqual(persistent, message.JMSPersistent, "JMSPersistent");
Assert.AreEqual(priority, message.JMSPriority, "JMSPriority");
Assert.AreEqual(type, message.JMSType, "JMSType");
Assert.AreEqual(groupID, message.JMSXGroupID, "JMSXGroupID");
Assert.AreEqual(groupSeq, message.JMSXGroupSeq, "JMSXGroupSeq");
// compare custom headers
Assert.AreEqual(customText, message.Properties["customText"], "customText");
Assert.AreEqual(custom1, message.Properties["custom1"], "custom1");
Assert.AreEqual(custom2, message.Properties["custom2"], "custom2");
Assert.AreEqual(custom3, message.Properties["custom3"], "custom3");
Assert.AreEqual(custom4, message.Properties["custom4"], "custom4");
// TODO
//Assert.AreEqual(custom5, message.Properties["custom5"], "custom5");
Assert.AreEqual(custom4, message.Properties["custom6"], "custom6");
Assert.AreEqual(custom1, message.Properties.GetBool("custom1"), "custom1");
Assert.AreEqual(custom2, message.Properties.GetByte("custom2"), "custom2");
Assert.AreEqual(custom3, message.Properties.GetShort("custom3"), "custom3");
Assert.AreEqual(custom4, message.Properties.GetInt("custom4"), "custom4");
//Assert.AreEqual(custom5, message.Properties.GetLong("custom5"), "custom5");
Assert.AreEqual(custom4, message.Properties.GetChar("custom6"), "custom6");
// lets now look at some standard JMS headers
Console.WriteLine("JMSExpiration: " + message.JMSExpiration);
Console.WriteLine("JMSMessageId: " + message.JMSMessageId);
Console.WriteLine("JMSRedelivered: " + message.JMSRedelivered);
Console.WriteLine("JMSTimestamp: " + message.JMSTimestamp);
Console.WriteLine("JMSXDeliveryCount: " + message.JMSXDeliveryCount);
Console.WriteLine("JMSXProducerTXID: " + message.JMSXProducerTXID);
}
}
}

View File

@ -0,0 +1,65 @@
/*
* Copyright 2006 The Apache Software Foundation or its licensors, as
* applicable.
*
* Licensed 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.
*/
using System;
using System.IO;
using NUnit.Framework;
using OpenWire.Client;
using OpenWire.Client.Core;
namespace OpenWire.Client
{
[ TestFixture ]
public class MapMessageTest : TestSupport
{
bool a = true;
byte b = 123;
char c = 'c';
short d = 0x1234;
int e = 0x12345678;
long f = 0x1234567812345678;
string g = "Hello World!";
[ Test ]
public override void SendAndSyncReceive()
{
base.SendAndSyncReceive();
}
protected override IMessage CreateMessage(ISession session)
{
IMapMessage request = session.CreateMapMessage();
return request;
}
protected override void AssertValidMessage(IMessage message)
{
Assert.IsTrue(message is IMapMessage, "Did not receive a MapMessage!");
Console.WriteLine("Received MapMessage: " + message);
IMapMessage mapMessage = (IMapMessage) message;
/*
String text = mapMessage.Text;
Assert.AreEqual(expected, text, "the message text");
*/
}
}
}

View File

@ -17,13 +17,72 @@
using System; using System;
using System.IO; using System.IO;
using NUnit.Framework;
using OpenWire.Client; using OpenWire.Client;
using OpenWire.Client.Core;
namespace OpenWire.Client {
/// <summary> namespace OpenWire.Client
/// useful base class for test cases {
/// </summary>
public abstract class TestSupport { /// <summary>
} /// useful base class for test cases
/// </summary>
[ TestFixture ]
public abstract class TestSupport
{
[ Test ]
public virtual void SendAndSyncReceive()
{
IConnectionFactory factory = new ConnectionFactory("localhost", 61616);
Assert.IsTrue(factory != null, "no factory created");
using (IConnection connection = factory.CreateConnection())
{
try
{
Assert.IsTrue(connection != null, "no connection created");
Console.WriteLine("Connected to ActiveMQ!");
ISession session = connection.CreateSession();
IDestination destination = CreateDestination(session);
Assert.IsTrue(destination != null, "No queue available!");
IMessageConsumer consumer = session.CreateConsumer(destination);
IMessageProducer producer = session.CreateProducer(destination);
IMessage request = CreateMessage(session);
producer.Send(request);
IMessage message = consumer.Receive();
Assert.IsNotNull(message, "No message returned!");
AssertValidMessage(message);
}
catch (Exception e)
{
Console.WriteLine("Caught: " + e);
}
}
}
protected virtual IDestination CreateDestination(ISession session)
{
string name = "Test.DotNet." + GetType().Name;
IDestination destination = session.GetQueue(name);
Console.WriteLine("Using queue: " + destination);
return destination;
}
protected abstract IMessage CreateMessage(ISession session);
protected abstract void AssertValidMessage(IMessage message);
}
} }