EnsLib.ITK.Framework.Process.ITKMessageRouter
persistent class EnsLib.ITK.Framework.Process.ITKMessageRouter extends Ens.BusinessProcess
SQL Table Name: EnsLib_ITK_Framework_Process.ITKMessageRouter
Performs ITK subscript, fault, queue collection and distribution envelope routing.Property Inventory
Method Inventory
- GetContentRoutes()
- GetDistributionRoutes()
- GetSubscriptionRoutes()
- OnError()
- OnGetConnections()
- OnRequest()
- OnResponse()
- ResolveMessageRelationships()
- RouteQueueCollection()
- RouteReply()
- RouteStandardMessage()
- SimulateResponse()
- ValidateAddressing()
- ValidateContent()
Parameters
parameter SETTINGS = SendReponsesTo,BadMessageHandler,FaultVocabulary,FaultReporterURI;
Inherited description: List of properties can be set as settings in the configuration file
format is a comma separated list of property names
Properties
property BadMessageHandler as %String (MAXLEN = 1000);
Configuration item to which to send bad messages
Property methods: BadMessageHandlerDisplayToLogical(), BadMessageHandlerGet(), BadMessageHandlerGetStored(), BadMessageHandlerIsValid(), BadMessageHandlerLogicalToDisplay(), BadMessageHandlerLogicalToOdbc(), BadMessageHandlerNormalize(), BadMessageHandlerSet()
property FaultReporterURI as %String;
The reportor uri to report any technical errors against
Property methods: FaultReporterURIDisplayToLogical(), FaultReporterURIGet(), FaultReporterURIGetStored(), FaultReporterURIIsValid(), FaultReporterURILogicalToDisplay(), FaultReporterURILogicalToOdbc(), FaultReporterURINormalize(), FaultReporterURISet()
property FaultVocabulary as %String;
Vocabulary to use for creating fault messages from this Service.
Property methods: FaultVocabularyDisplayToLogical(), FaultVocabularyGet(), FaultVocabularyGetStored(), FaultVocabularyIsValid(), FaultVocabularyLogicalToDisplay(), FaultVocabularyLogicalToOdbc(), FaultVocabularyNormalize(), FaultVocabularySet()
property SendReponsesTo as %String;
Configuration item to which to send responses
Property methods: SendReponsesToDisplayToLogical(), SendReponsesToGet(), SendReponsesToGetStored(), SendReponsesToIsValid(), SendReponsesToLogicalToDisplay(), SendReponsesToLogicalToOdbc(), SendReponsesToNormalize(), SendReponsesToSet()
Methods
method GetContentRoutes(pRequest As EnsLib.ITK.Framework.RequestData, service As EnsLib.ITK.Setup.ServiceDefinition) as %String
Call to find the routes based on the content of the message
method GetDistributionRoutes(pRequest As EnsLib.ITK.Framework.RequestData) as %String
Call to find the routes to distribute the message onto given the address list
in the distribution rules.
This method will process the Subscription Rules to determine a comma separate list
of consumers to send onto
method OnError(request As %Library.Persistent, ByRef response As %Library.Persistent, callrequest As %Library.Persistent, pErrorStatus As %Status, pCompletionKey As %String) as %Status
This method is called when an error response is received
Returning the same error will cause the BusinessProcess to set its status to error and close down
Returning $$$OK from this method causes the BusinessProcess to recover from this error
classmethod OnGetConnections(Output pArray As %String, pItem As Ens.Config.Item)
IRIS Callback to work out which config items we connect to
method OnRequest(pRequest As Ens.Request, Output pResponse As Ens.Response) as %Status
Inherited description: Handle a 'Request'
method OnResponse(request As %Library.Persistent, ByRef response As %Library.Persistent, callrequest As %Library.Persistent, callresponse As %Library.Persistent, pCompletionKey As %String) as %Status
Handle a 'Response' by passing it to the 'SendResponsesTo' component.
This is typically the DispatchResponse component
method ResolveMessageRelationships(pRequest As EnsLib.ITK.Framework.RequestData, Output pOriginalMessage As EnsLib.ITK.Framework.RequestData) as %Status
When handling an async response this tues the request back up and determines
where we are going to send the response to (based on original request that had
the replyTo address).
method RouteQueueCollection(pRequest As EnsLib.ITK.Framework.RequestData)
Route if a Queue Collection request
method RouteReply(pRequest As EnsLib.ITK.Framework.RequestData, pOriginalMessage As EnsLib.ITK.Framework.RequestData) as %Status
This method actually routes a reply to a request-response message by
either sending the reply (pRequest) onto deferred handler or by sending
the response asychronously back to the call
method RouteStandardMessage(pRequest As EnsLib.ITK.Framework.RequestData, service As EnsLib.ITK.Setup.ServiceDefinition)
Resolves the endpoints and passes the message onto each unique end point found
method SimulateResponse(pRequest As EnsLib.ITK.Framework.RequestData, pOriginalMessage As EnsLib.ITK.Framework.RequestData, sc As %Status)
Called to send a response back (usually an error!!)
method ValidateAddressing(pRequest As EnsLib.ITK.Framework.RequestData) as %Status
Ensures that there is a business operation under the given replyTo address
If there is not this switchboard is not capable to routing the async reply!
method ValidateContent(pRequest As EnsLib.ITK.Framework.RequestData) as %Status
Called to validate the content, if content validation is turned on for the given sender.
TODO: ITK 2.0, when validating may have distribution envelope wrapping given requestClass, need to handle!! (also should be virtual XML Doc!)
Inherited Members
Inherited Properties
- %ConfigName
- %ConfigQueueName
- %CurrentResponseHeader
- %IsCompleted
- %IsTerminated
- %IsTimerInterrupted
- %LastActionTime
- %LastHandledTime
- %LastReportedError
- %MasterPendingResponses
- %MasterPendingResponsesOld
- %MessagesReceived
- %MessagesReceivedOld
- %MessagesSent
- %MessagesSentOld
- %PrimaryRequestHeader
- %PrimaryResponseHeader
- %QuitTask
- %RepliedStatus
- %SessionId
- %StatusCode
- %SuperSession
- %TimeCompleted
- %TimeCreated
- %WarnedLatest
- %isShadow
- %request
- %response
- %responseClassName
- %responseId
- Adapter
- AlertGroups
- AlertOnError
- AlertRetryGracePeriod
- BusinessPartner
- FailureTimeout
- InactivityTimeout
- QueueCountAlert
- QueueWaitAlert
- ReplyCodeActions
- Retry
- RetryInterval
- SuspendMessage
- ThrottleDelay
Inherited Methods
- %%CLASSNAMELogicalToStorage()
- %%CLASSNAMEStorageToLogical()
- %AddToSaveSet()
- %AddToSyncSet()
- %BMEBuilt()
- %BuildIndicesAsync()
- %BuildIndicesAsyncResponse()
- %CheckConstraints()
- %CheckConstraintsForExtent()
- %ClassIsLatestVersion()
- %ClassName()
- %ComposeOid()
- %ConstructClone()
- %Delete()
- %DeleteExtent()
- %DeleteId()
- %DispatchClassMethod()
- %DispatchGetModified()
- %DispatchGetProperty()
- %DispatchMethod()
- %DispatchSetModified()
- %DispatchSetMultidimProperty()
- %DispatchSetProperty()
- %Exists()
- %ExistsId()
- %Extends()
- %GUID()
- %GUIDSet()
- %GetLock()
- %GetParameter()
- %GetSwizzleObject()
- %Id()
- %InsertBatch()
- %IsA()
- %IsModified()
- %IsNull()
- %KillExtent()
- %KillExtentData()
- %LoadFromMemory()
- %LockExtent()
- %LockId()
- %New()
- %NormalizeObject()
- %ObjectIsNull()
- %ObjectModified()
- %Oid()
- %OnBeforeAddToSync()
- %OnClose()
- %OnDeleteFinally()
- %OnDetermineClass()
- %OnNew()
- %OnOpenFinally()
- %OnSaveFinally()
- %Open()
- %OpenId()
- %OriginalNamespace()
- %PackageName()
- %PhysicalAddress()
- %PurgeIndices()
- %Reload()
- %RemoveFromSaveSet()
- %ResolveConcurrencyConflict()
- %RollBack()
- %Save()
- %SaveDirect()
- %SaveIndices()
- %SerializeObject()
- %SetModified()
- %SortBegin()
- %SortEnd()
- %SuperSessionSet()
- %SyncObjectIn()
- %SyncTransport()
- %UnlockExtent()
- %UnlockId()
- %ValidateIndices()
- %ValidateObject()
- %ValidateTable()
- AdapterName()
- AssignOneSetting()
- ClearAllPendingResponses()
- DeferResponse()
- EnumerateSettingsClose()
- EnumerateSettingsExecute()
- EnumerateSettingsFetch()
- GenerateSuperSession()
- GetDeferredResponseToken()
- GetMsgHdrRequestKey()
- GetProductionSettingValue()
- GetProductionSettings()
- GetPropertyConnections()
- GetSettings()
- GetShadowInstance()
- IsResponsePending()
- OnComplete()
- OnErroredResponse()
- OnFailureTimeout()
- OnGenerateSuperSession()
- OnGetReplyAction()
- OnInit()
- OnKeepalive()
- OnMonitor()
- OnProductionStart()
- OnProductionStop()
- OnTearDown()
- OnTimeout()
- QueueName()
- RemovePendingResponse()
- Reply()
- ReplyError()
- SendAlert()
- SendDeferredResponse()
- SendRequestAsync()
- SendRequestSync()
- SetTimer()
- WillHandleErroredResponse()
Storage
Gray indicates storage defined by superclasses.
Storage Model: Storage (Ens.BusinessProcess)
^Ens.BusinessProcessD(ID,"received",n) |
= | %MessagesReceived(n) |
Storage Model: Storage (Ens.BusinessProcess)
^Ens.BusinessProcessD(ID,"sent",n) |
= | %MessagesSent(n) |
Storage Model: Storage (Ens.BusinessProcess)
^Ens.BusinessProcessD(ID) |
= | %%CLASSNAME
%ConfigQueueName
%IsCompleted
%MasterPendingResponsesOld
%PrimaryRequestHeader
%PrimaryResponseHeader
%RepliedStatus
%responseId
Adapter
%SessionId
%TimeCompleted
%TimeCreated
%ConfigName
%QuitTask
AlertOnError
%responseClassName
%IsTimerInterrupted
%IsTerminated
%StatusCode
%MessagesReceivedOld
%MessagesSentOld
ReplyCodeActions
RetryInterval
AlertRetryGracePeriod
FailureTimeout
Retry
SuspendMessage
QueueCountAlert
QueueWaitAlert
InactivityTimeout
BusinessPartner
AlertGroups
%SuperSession
|
Storage Model: Storage (EnsLib.ITK.Framework.Process.ITKMessageRouter)
^Ens.BusinessProcessD(ID,"ITKMessageRouter") |
= | SendReponsesTo
BadMessageHandler
FaultReporterURI
FaultVocabulary
|