Package com.attivio.sdk.esb
Class MessageDomainManager
- java.lang.Object
- 
- com.attivio.sdk.esb.MessageDomainManager
 
- 
 public final class MessageDomainManager extends java.lang.ObjectSingleton which manages the list of queues and associated message domains. Provides methods for acquiring and releasing Semaphores associated with a domain so that domain limits will be maintained. User code should not directly interact with this class.
- 
- 
Field SummaryFields Modifier and Type Field Description static MessageDomainManagerinstance
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidacquire(java.lang.String componentName, java.lang.String domain)Acquires the semaphore associated with the componentName and domain (if any).java.lang.StringaddDomainSuffix(java.lang.String domain, java.lang.String uri)Changes the uri to a domain-specific version if domain is non-null.voidclear()Clears the internal data structures.voidcreateDomainSemaphore(MessageDomain md, java.lang.String componentName)Creates the resource semaphores that will be used when messages are received for the componentjava.lang.StringgetMessageDomain(PlatformMessage msg)Domains are always non-blankintmessageDomainMaximum(java.lang.String domain)Determines the maximum number of messages that could be processed by this domain at a single time.java.lang.String[]parseUri(java.lang.String uri)Parses the uri into the domain for the message and the uri without the domain suffix.voidrelease(java.lang.String componentName, java.lang.String domain)Releases the semaphore associated with the componentName and domain (if any).voidsetMessageDomain(PlatformMessage msg, java.lang.String domain)Sets the domain for the message.java.lang.StringtransformForDomain(PlatformMessage msg, java.lang.String uri)Transformsuriso that it points to the domain-specific uri for the domain the message is in.
 
- 
- 
- 
Field Detail- 
instancepublic static final MessageDomainManager instance 
 
- 
 - 
Method Detail- 
clearpublic void clear() Clears the internal data structures. Provided for tests. Other use is not supported.
 - 
createDomainSemaphorepublic void createDomainSemaphore(MessageDomain md, java.lang.String componentName) Creates the resource semaphores that will be used when messages are received for the component- Parameters:
- md-
- componentName-
 
 - 
transformForDomainpublic java.lang.String transformForDomain(PlatformMessage msg, java.lang.String uri) Transformsuriso that it points to the domain-specific uri for the domain the message is in.- Parameters:
- msg-
- uri-
- Returns:
- the urimodified so it points to the message's domain
 
 - 
addDomainSuffixpublic java.lang.String addDomainSuffix(java.lang.String domain, java.lang.String uri)Changes the uri to a domain-specific version if domain is non-null. Does not check to see if the uri has already been modified in this way.- Parameters:
- domain-
- uri-
- Returns:
- the updated domain
 
 - 
getMessageDomainpublic java.lang.String getMessageDomain(PlatformMessage msg) Domains are always non-blank- Parameters:
- msg-
- Returns:
- domain associated with message or null if none
 
 - 
setMessageDomainpublic void setMessageDomain(PlatformMessage msg, java.lang.String domain) Sets the domain for the message. A blank domain will result innullwhen callinggetMessageDomain(PlatformMessage)- Parameters:
- msg-
- domain-
 
 - 
messageDomainMaximumpublic int messageDomainMaximum(java.lang.String domain) Determines the maximum number of messages that could be processed by this domain at a single time.- Parameters:
- domain-
- Returns:
- the maximum number of simultaneous messages for this domain or 0 if no semaphore exists
 
 - 
parseUripublic java.lang.String[] parseUri(java.lang.String uri) Parses the uri into the domain for the message and the uri without the domain suffix. The uri will always be in the second element of the returned array. If the input uri contained a message domain suffix it will be placed in the first element of the returned array.- Parameters:
- uri-
- Returns:
 
 - 
acquirepublic void acquire(java.lang.String componentName, java.lang.String domain)Acquires the semaphore associated with the componentName and domain (if any). This method will not re-acquire the semaphore if the current thread already has acquired it. The expectation is that calls toacquirewill be paired with matching calls torelease(String, String)(generally in a finally block). Failure to do so will result in deadlocks.- Parameters:
- componentName-
- domain-
 
 - 
releasepublic void release(java.lang.String componentName, java.lang.String domain)Releases the semaphore associated with the componentName and domain (if any). If the calling thread acquired the semaphore via an earlier call with a different componentName, the semaphore will not be released. This provides a type of re-entrancy based on component name.- Parameters:
- componentName-
- domain-
 
 
- 
 
-