camt.029.001.08
Scope The ResolutionOfInvestigation message is sent by a case assignee to a case creator/case assigner. This message is used to inform of the resolution of a case, and optionally provides details about.
- the corrective action undertaken by the case assignee
- information on the return where applicable Usage The ResolutionOfInvestigation message is used by the case assignee to inform a case creator or case assigner about the resolution of a:
- request to cancel payment case
- request to modify payment case
- unable to apply case
- claim non receipt case The ResolutionOfInvestigation message covers one and only one case at a time. If the case assignee needs to communicate about several cases, then several Resolution Of Investigation messages must be sent. The ResolutionOfInvestigation message provides:
- the final outcome of the case, whether positive or negative
- optionally, the details of the corrective action undertaken by the case assignee and the information of the return Whenever a payment instruction has been generated to solve the case under investigation following a claim non receipt or an unable to apply, the optional CorrectionTransaction component present in the message must be completed. Whenever the action of modifying or cancelling a payment results in funds being returned or reversed, an investigating agent may provide the details in the resolution related investigation component, to identify the return or reversal transaction. These details will facilitate the account reconciliations at the initiating bank and the intermediaries. It must be stressed that the return or reversal of funds is outside the scope of this Exceptions and Investigation service. The features given here is only meant to transmit the information of return or reversal when it is available through the resolution of the case. The ResolutionOfInvestigation message must:
- be forwarded by all subsequent case assignee(s) until it reaches the case creator
- not be used in place of a RejectCaseAssignment or CaseStatusReport or NotificationOfCaseAssignment message Take note of an exceptional rule that allows the use of ResolutionOfInvestigation in lieu of a CaseStatusReport. CaseStatusReport is a response-message to a CaseStatusReportRequest. The latter which is sent when the assigner has reached its own time-out threshold to receive a response. However it may happen that when the request arrives, the investigating agent has just obtained a resolution. In such a situation, it would be redundant to send a CaseStatusReport when then followed immediately by a ResolutionOfInvestigation. It is therefore quite acceptable for the investigating agent, the assignee, to skip the Case Status Report and send the ResolutionOfInvestigation message directly. The ResolutionOfInvestigation message should be the sole message to respond to a cancellation request. Details of the underlying transactions and the related statuses for which the cancellation request has been issued may be provided in the CancellationDetails component.
Message Construction
Every ISO20022 message has at the highest level what we call ‘building blocks’. Because the message is constructed as immutable records, the association is by composition. Below you can see the relationship between the message and its constituent building blocks: For comparison, see the ISO20022 official specification
classDiagram direction LR %% ResolutionOfInvestigationV08 recursion level 0 with max 0 ResolutionOfInvestigationV08 *-- "1..1" CaseAssignment4 : Assignment ResolutionOfInvestigationV08 *-- "0..1" Case4 : ResolvedCase ResolutionOfInvestigationV08 *-- "1..1" IInvestigationStatus4Choice : Status ResolutionOfInvestigationV08 *-- "0..1" UnderlyingTransaction19 : CancellationDetails ResolutionOfInvestigationV08 *-- "0..1" PaymentTransaction90 : ModificationDetails ResolutionOfInvestigationV08 *-- "0..1" IClaimNonReceipt1Choice : ClaimNonReceiptDetails ResolutionOfInvestigationV08 *-- "0..1" StatementResolutionEntry3 : StatementDetails ResolutionOfInvestigationV08 *-- "0..1" ICorrectiveTransaction3Choice : CorrectionTransaction ResolutionOfInvestigationV08 *-- "0..1" ResolutionInformation2 : ResolutionRelatedInformation ResolutionOfInvestigationV08 *-- "0..1" SupplementaryData1 : SupplementaryData
Now, we will zero-in one-by-one on each of these building blocks.
Assignment building block
Identifies the assignment of an investigation case from an assigner to an assignee. Usage: The Assigner must be the sender of this confirmation and the Assignee must be the receiver. Represents the assignment of a case to a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% CaseAssignment4 recursion level 0 with max 1 class CaseAssignment4{ Identification IsoMax35Text CreationDateTime IsoISODateTime } CaseAssignment4 *-- "1..1" IParty35Choice : Assigner CaseAssignment4 *-- "1..1" IParty35Choice : Assignee %% IParty35Choice recursion level 1 with max 1 %% IParty35Choice recursion level 1 with max 1
CaseAssignment4 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
Identification | Uniquely identifies the case assignment. | IsoMax35Text - Required 1..1 |
Assigner | Party who assigns the case. | Usage: This is also the sender of the message. |
Assignee | Party to which the case is assigned. | Usage: This is also the receiver of the message. |
CreationDateTime | Date and time at which the assignment was created. | IsoISODateTime - Required 1..1 |
ResolvedCase building block
Identifies a resolved case. Provides further details to identify an investigation case. For comparison, see the ISO20022 official specification
classDiagram direction tb %% Case4 recursion level 0 with max 1 class Case4{ Identification IsoMax35Text ReopenCaseIndication IsoYesNoIndicator } Case4 *-- "1..1" IParty35Choice : Creator %% IParty35Choice recursion level 1 with max 1
Case4 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
Identification | Uniquely identifies the case. | IsoMax35Text - Required 1..1 |
Creator | Party that created the investigation case. | IParty35Choice - Required 1..1 |
ReopenCaseIndication | Indicates whether or not the case was previously closed and is now re-opened. | IsoYesNoIndicator - Optional 0..1 |
Status building block
Indicates the status of the investigation. Specifies the status of an investigation case. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IInvestigationStatus4Choice recursion level 0 with max 1
InvestigationStatus4Choice members
Member name | Description | Data Type / Multiplicity |
---|
CancellationDetails building block
Specifies the details of the underlying transactions being cancelled. Identifies the underlying (group of) transaction(s) to which the resolution of investigation applies. For comparison, see the ISO20022 official specification
classDiagram direction tb %% UnderlyingTransaction19 recursion level 0 with max 1 UnderlyingTransaction19 *-- "0..1" OriginalGroupHeader9 : OriginalGroupInformationAndStatus UnderlyingTransaction19 *-- "0..0" OriginalPaymentInstruction26 : OriginalPaymentInformationAndStatus UnderlyingTransaction19 *-- "0..0" PaymentTransaction85 : TransactionInformationAndStatus %% OriginalGroupHeader9 recursion level 1 with max 1 class OriginalGroupHeader9{ OriginalGroupCancellationIdentification IsoMax35Text OriginalMessageIdentification IsoMax35Text OriginalMessageNameIdentification IsoMax35Text OriginalCreationDateTime IsoISODateTime OriginalNumberOfTransactions IsoMax15NumericText OriginalControlSum IsoDecimalNumber GroupCancellationStatus GroupCancellationStatus1Code } OriginalGroupHeader9 *-- "0..1" Case4 : ResolvedCase OriginalGroupHeader9 *-- "0..0" CancellationStatusReason3 : CancellationStatusReasonInformation OriginalGroupHeader9 *-- "0..0" NumberOfTransactionsPerStatus1 : NumberOfTransactionsPerCancellationStatus %% OriginalPaymentInstruction26 recursion level 1 with max 1 class OriginalPaymentInstruction26{ OriginalPaymentInformationCancellationIdentification IsoMax35Text OriginalPaymentInformationIdentification IsoMax35Text OriginalNumberOfTransactions IsoMax15NumericText OriginalControlSum IsoDecimalNumber PaymentInformationCancellationStatus GroupCancellationStatus1Code } OriginalPaymentInstruction26 *-- "0..1" Case4 : ResolvedCase OriginalPaymentInstruction26 *-- "0..1" OriginalGroupInformation29 : OriginalGroupInformation OriginalPaymentInstruction26 *-- "0..0" CancellationStatusReason3 : CancellationStatusReasonInformation OriginalPaymentInstruction26 *-- "0..0" NumberOfCancellationsPerStatus1 : NumberOfTransactionsPerCancellationStatus OriginalPaymentInstruction26 *-- "0..0" PaymentTransaction84 : TransactionInformationAndStatus %% PaymentTransaction85 recursion level 1 with max 1 class PaymentTransaction85{ CancellationStatusIdentification IsoMax35Text OriginalInstructionIdentification IsoMax35Text OriginalEndToEndIdentification IsoMax35Text OriginalTransactionIdentification IsoMax35Text OriginalClearingSystemReference IsoMax35Text TransactionCancellationStatus CancellationIndividualStatus1Code OriginalInterbankSettlementAmount IsoActiveOrHistoricCurrencyAndAmount OriginalInterbankSettlementDate IsoISODate } PaymentTransaction85 *-- "0..1" Case4 : ResolvedCase PaymentTransaction85 *-- "0..1" OriginalGroupInformation29 : OriginalGroupInformation PaymentTransaction85 *-- "0..0" CancellationStatusReason3 : CancellationStatusReasonInformation PaymentTransaction85 *-- "0..1" ResolutionInformation2 : ResolutionRelatedInformation PaymentTransaction85 *-- "0..1" IParty35Choice : Assigner PaymentTransaction85 *-- "0..1" IParty35Choice : Assignee PaymentTransaction85 *-- "0..1" OriginalTransactionReference27 : OriginalTransactionReference
UnderlyingTransaction19 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
OriginalGroupInformationAndStatus | Provides information on the original cancellation message, to which the resolution refers. | OriginalGroupHeader9 - Optional 0..1 |
OriginalPaymentInformationAndStatus | Provides information on the original (group of) transactions, to which the cancellation status refers. | OriginalPaymentInstruction26 - Unknown 0..0 |
TransactionInformationAndStatus | Provides details on the original transactions to which the cancellation request message refers. | PaymentTransaction85 - Unknown 0..0 |
ModificationDetails building block
Specifies the details of the underlying transaction being modified. Provides further details on the reference and status on the original transactions, included in the original instruction, to which the cancellation request message applies. For comparison, see the ISO20022 official specification
classDiagram direction tb %% PaymentTransaction90 recursion level 0 with max 1 class PaymentTransaction90{ ModificationStatusIdentification IsoMax35Text OriginalPaymentInformationIdentification IsoMax35Text OriginalInstructionIdentification IsoMax35Text OriginalEndToEndIdentification IsoMax35Text OriginalTransactionIdentification IsoMax35Text OriginalClearingSystemReference IsoMax35Text OriginalInterbankSettlementAmount IsoActiveOrHistoricCurrencyAndAmount OriginalInterbankSettlementDate IsoISODate } PaymentTransaction90 *-- "0..1" Case4 : ResolvedCase PaymentTransaction90 *-- "1..1" OriginalGroupInformation29 : OriginalGroupInformation PaymentTransaction90 *-- "0..0" ModificationStatusReason1 : ModificationStatusReasonInformation PaymentTransaction90 *-- "0..1" ResolutionInformation2 : ResolutionRelatedInformation PaymentTransaction90 *-- "0..1" IParty35Choice : Assigner PaymentTransaction90 *-- "0..1" IParty35Choice : Assignee PaymentTransaction90 *-- "0..1" OriginalTransactionReference27 : OriginalTransactionReference %% Case4 recursion level 1 with max 1 class Case4{ Identification IsoMax35Text ReopenCaseIndication IsoYesNoIndicator } Case4 *-- "1..1" IParty35Choice : Creator %% OriginalGroupInformation29 recursion level 1 with max 1 class OriginalGroupInformation29{ OriginalMessageIdentification IsoMax35Text OriginalMessageNameIdentification IsoMax35Text OriginalCreationDateTime IsoISODateTime } %% ModificationStatusReason1 recursion level 1 with max 1 class ModificationStatusReason1{ AdditionalInformation IsoMax105Text } ModificationStatusReason1 *-- "0..1" PartyIdentification125 : Originator ModificationStatusReason1 *-- "0..1" IModificationStatusReason1Choice : Reason %% ResolutionInformation2 recursion level 1 with max 1 class ResolutionInformation2{ InterbankSettlementAmount IsoActiveOrHistoricCurrencyAndAmount InterbankSettlementDate IsoISODate ClearingChannel ClearingChannel2Code } ResolutionInformation2 *-- "0..1" Compensation1 : Compensation ResolutionInformation2 *-- "0..0" Charges2 : Charges %% IParty35Choice recursion level 1 with max 1 %% IParty35Choice recursion level 1 with max 1 %% OriginalTransactionReference27 recursion level 1 with max 1 class OriginalTransactionReference27{ InterbankSettlementAmount IsoActiveOrHistoricCurrencyAndAmount InterbankSettlementDate IsoISODate RequestedCollectionDate IsoISODate PaymentMethod PaymentMethod4Code } OriginalTransactionReference27 *-- "0..1" IAmountType4Choice : Amount OriginalTransactionReference27 *-- "0..1" IDateAndDateTime2Choice : RequestedExecutionDate OriginalTransactionReference27 *-- "0..1" PartyIdentification125 : CreditorSchemeIdentification OriginalTransactionReference27 *-- "0..1" SettlementInstruction4 : SettlementInformation OriginalTransactionReference27 *-- "0..1" PaymentTypeInformation25 : PaymentTypeInformation OriginalTransactionReference27 *-- "0..1" MandateRelatedInformation12 : MandateRelatedInformation OriginalTransactionReference27 *-- "0..1" RemittanceInformation15 : RemittanceInformation OriginalTransactionReference27 *-- "0..1" IParty35Choice : UltimateDebtor OriginalTransactionReference27 *-- "0..1" IParty35Choice : Debtor OriginalTransactionReference27 *-- "0..1" CashAccount24 : DebtorAccount OriginalTransactionReference27 *-- "0..1" BranchAndFinancialInstitutionIdentification5 : DebtorAgent OriginalTransactionReference27 *-- "0..1" CashAccount24 : DebtorAgentAccount OriginalTransactionReference27 *-- "0..1" BranchAndFinancialInstitutionIdentification5 : CreditorAgent OriginalTransactionReference27 *-- "0..1" CashAccount24 : CreditorAgentAccount OriginalTransactionReference27 *-- "0..1" IParty35Choice : Creditor OriginalTransactionReference27 *-- "0..1" CashAccount24 : CreditorAccount OriginalTransactionReference27 *-- "0..1" IParty35Choice : UltimateCreditor OriginalTransactionReference27 *-- "0..1" IPurpose2Choice : Purpose
PaymentTransaction90 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
ModificationStatusIdentification | Unique and unambiguous identifier of a cancellation request status, as assigned by the assigner. | |
ResolvedCase | Identifies the resolved case. | Case4 - Optional 0..1 |
OriginalGroupInformation | Provides information on the original message. | OriginalGroupInformation29 - Required 1..1 |
OriginalPaymentInformationIdentification | Unique identification, as assigned by the original sending party, to unambiguously identify the original payment information group. | IsoMax35Text - Optional 0..1 |
OriginalInstructionIdentification | Unique identification, as assigned by the original instructing party for the original instructed party, to unambiguously identify the original instruction. | IsoMax35Text - Optional 0..1 |
OriginalEndToEndIdentification | Unique identification, as assigned by the original initiating party, to unambiguously identify the original transaction. | IsoMax35Text - Optional 0..1 |
OriginalTransactionIdentification | Unique identification, as assigned by the original first instructing agent, to unambiguously identify the transaction. | IsoMax35Text - Optional 0..1 |
OriginalClearingSystemReference | Unique reference, as assigned by the original clearing system, to unambiguously identify the original instruction. | IsoMax35Text - Optional 0..1 |
ModificationStatusReasonInformation | Provides detailed information on the modification status reason. | ModificationStatusReason1 - Unknown 0..0 |
ResolutionRelatedInformation | Reference of a return or a reversal transaction that is initiated to fix the case under investigation as part of the resolution. | ResolutionInformation2 - Optional 0..1 |
OriginalInterbankSettlementAmount | Amount of money moved between the instructing agent and the instructed agent, as provided in the original instruction. | IsoActiveOrHistoricCurrencyAndAmount - Optional 0..1 |
OriginalInterbankSettlementDate | Date, as provided in the original transaction, on which the amount of money ceases to be available to the agent that owes it and when the amount of money becomes available to the agent to which it is due. | IsoISODate - Optional 0..1 |
Assigner | Party who assigns the case. | Usage: This is also the agent that instructs the next party in the chain to carry out the (set of) cancellation request(s). |
Assignee | Party to which the case is assigned. | Usage: This is also the agent that is instructed by the previous party in the chain to carry out the (set of) cancellation request(s). |
OriginalTransactionReference | Key elements used to identify the original transaction that is being referred to. | OriginalTransactionReference27 - Optional 0..1 |
ClaimNonReceiptDetails building block
Specifies the details of the underlying transaction for which a claim non receipt has been initiated. Specifies whether the claim non receipt is accepted or rejected. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IClaimNonReceipt1Choice recursion level 0 with max 1
ClaimNonReceipt1Choice members
Member name | Description | Data Type / Multiplicity |
---|
StatementDetails building block
Details on the underlying statement entry. Provides further details on the statement entry for the resolution of the investigation. For comparison, see the ISO20022 official specification
classDiagram direction tb %% StatementResolutionEntry3 recursion level 0 with max 1 class StatementResolutionEntry3{ OriginalStatementIdentification IsoMax35Text AccountServicerReference IsoMax35Text CorrectedAmount IsoActiveOrHistoricCurrencyAndAmount } StatementResolutionEntry3 *-- "0..1" OriginalGroupInformation29 : OriginalGroupInformation StatementResolutionEntry3 *-- "0..0" Charges3 : Charges StatementResolutionEntry3 *-- "0..1" IPurpose2Choice : Purpose %% OriginalGroupInformation29 recursion level 1 with max 1 class OriginalGroupInformation29{ OriginalMessageIdentification IsoMax35Text OriginalMessageNameIdentification IsoMax35Text OriginalCreationDateTime IsoISODateTime } %% Charges3 recursion level 1 with max 1 class Charges3{ TotalChargesAndTaxAmount IsoActiveOrHistoricCurrencyAndAmount } Charges3 *-- "0..0" ChargesRecord1 : Record %% IPurpose2Choice recursion level 1 with max 1
StatementResolutionEntry3 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
OriginalGroupInformation | Provides information on the original message. | OriginalGroupInformation29 - Optional 0..1 |
OriginalStatementIdentification | Unique identification, as assigned by the account servicer, to unambiguously identify the original statement. | IsoMax35Text - Optional 0..1 |
AccountServicerReference | Unique reference, as assigned by the account servicing institution, to unambiguously identify the entry. | IsoMax35Text - Optional 0..1 |
CorrectedAmount | Corrected debit or credit amount, compared to the original entry where the amount is incorrect. | |
Charges | Provides information on the charges included in the original entry amount. | Charges3 - Unknown 0..0 |
Purpose | Underlying reason for the payment transaction. | Usage: Purpose is used by the end-customers, that is initiating party, (ultimate) debtor, (ultimate) creditor to provide information concerning the nature of the payment. Purpose is a content element, which is not used for processing by any of the agents involved in the payment chain. |
CorrectionTransaction building block
References a transaction initiated to fix the case under investigation. Specifies the corrective transaction on which the investigation is processed. For comparison, see the ISO20022 official specification
classDiagram direction tb %% ICorrectiveTransaction3Choice recursion level 0 with max 1
CorrectiveTransaction3Choice members
Member name | Description | Data Type / Multiplicity |
---|
ResolutionRelatedInformation building block
Reference of a return or a reversal initiated to fix the case under investigation as part of the resolution. Set of elements used to provide information on the return or reversal expected by the party that initiated the initial payment instruction after a cancellation or modification request. For comparison, see the ISO20022 official specification
classDiagram direction tb %% ResolutionInformation2 recursion level 0 with max 1 class ResolutionInformation2{ InterbankSettlementAmount IsoActiveOrHistoricCurrencyAndAmount InterbankSettlementDate IsoISODate ClearingChannel ClearingChannel2Code } ResolutionInformation2 *-- "0..1" Compensation1 : Compensation ResolutionInformation2 *-- "0..0" Charges2 : Charges %% Compensation1 recursion level 1 with max 1 class Compensation1{ Amount IsoActiveCurrencyAndAmount } Compensation1 *-- "1..1" BranchAndFinancialInstitutionIdentification5 : DebtorAgent Compensation1 *-- "1..1" BranchAndFinancialInstitutionIdentification5 : CreditorAgent Compensation1 *-- "1..1" ICompensationReason1Choice : Reason %% Charges2 recursion level 1 with max 1 class Charges2{ Amount IsoActiveOrHistoricCurrencyAndAmount } Charges2 *-- "1..1" BranchAndFinancialInstitutionIdentification5 : Agent
ResolutionInformation2 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
InterbankSettlementAmount | Amount of money moved between the instructing agent and the instructed agent. | IsoActiveOrHistoricCurrencyAndAmount - Optional 0..1 |
InterbankSettlementDate | Date on which the amount of money ceases to be available to the agent that owes it and when the amount of money becomes available to the agent to which it is due. | IsoISODate - Optional 0..1 |
ClearingChannel | Specifies the clearing channel to be used to process the payment instruction. | ClearingChannel2Code - Optional 0..1 |
Compensation | Provides the details of the compensation made due to the modification or cancellation of a previous payment. | Compensation1 - Optional 0..1 |
Charges | Provides information on the charges to be paid by the charge bearer(s) related to the payment transaction. | Charges2 - Unknown 0..0 |
SupplementaryData building block
Additional information that cannot be captured in the structured elements and/or any other specific block. Additional information that can not be captured in the structured fields and/or any other specific block. For comparison, see the ISO20022 official specification
classDiagram direction tb %% SupplementaryData1 recursion level 0 with max 1 class SupplementaryData1{ PlaceAndName IsoMax350Text } SupplementaryData1 *-- "1..1" IsoSupplementaryDataEnvelope1 : Envelope %% IsoSupplementaryDataEnvelope1 recursion level 1 with max 1
SupplementaryData1 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
PlaceAndName | Unambiguous reference to the location where the supplementary data must be inserted in the message instance. In the case of XML, this is expressed by a valid XPath. | IsoMax350Text - Optional 0..1 |
Envelope | Technical element wrapping the supplementary data. | IsoSupplementaryDataEnvelope1 - Required 1..1 |
Extensibility and generalization considerations
To facilitate generalized design patterns in the system, the ResolutionOfInvestigationV08 implementation follows a specific implementaiton pattern. First of all, ResolutionOfInvestigationV08 impleemnts IOuterRecord indicating it is the outermost logical part of the message definition. Like all message wrappers, ResolutionOfInvestigationV08Document implements IOuterDocument. Because ResolutionOfInvestigationV08 implements IOuterDocument, it is a suitable template parameter for IOuterDocument, and causes the internal ‘Message’ to be of type ResolutionOfInvestigationV08.
classDiagram class IOuterRecord ResolutionOfInvestigationV08 --|> IOuterRecord : Implements ResolutionOfInvestigationV08Document --|> IOuterDocument~ResolutionOfInvestigationV08~ : Implements class IOuterDocument~ResolutionOfInvestigationV08~ { ResolutionOfInvestigationV08 Message }
Document wrapper for serialization
The only real purpose ResolutionOfInvestigationV08Document serves is to cause the document to be serialized into the ‘urn:iso:std:iso:20022:tech:xsd:camt.029.001.08’ namespace. Therefore, it will probably be the usual practice to build the message and construct this wrapper at the last minute using ResolutionOfInvestigationV08.ToDocument() method. The returned ResolutionOfInvestigationV08Document value will serialize correctly according to ISO 20022 standards.
classDiagram ResolutionOfInvestigationV08Document *-- ResolutionOfInvestigationV08 : Document
Sample of message format
This is an abbreviated version of what the message should look like.
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:camt.029.001.08">
<RsltnOfInvstgtn>
<Assgnmt>
<!-- Assignment inner content -->
</Assgnmt>
<RslvdCase>
<!-- ResolvedCase inner content -->
</RslvdCase>
<Sts>
<!-- Status inner content -->
</Sts>
<CxlDtls>
<!-- CancellationDetails inner content -->
</CxlDtls>
<ModDtls>
<!-- ModificationDetails inner content -->
</ModDtls>
<ClmNonRctDtls>
<!-- ClaimNonReceiptDetails inner content -->
</ClmNonRctDtls>
<StmtDtls>
<!-- StatementDetails inner content -->
</StmtDtls>
<CrrctnTx>
<!-- CorrectionTransaction inner content -->
</CrrctnTx>
<RsltnRltdInf>
<!-- ResolutionRelatedInformation inner content -->
</RsltnRltdInf>
<SplmtryData>
<!-- SupplementaryData inner content -->
</SplmtryData>
</RsltnOfInvstgtn>
</Document>
Data from ISO specification
This is the technical data from the specification document.
<messageDefinition
xmi:id="_AOwV911tEeehlLdFiIrRgQ"
nextVersions="_eX_OZ22PEei3KuUgpx7Xcw"
previousVersion="_KncB0WXkEeap-P22vGV91g"
name="ResolutionOfInvestigationV08"
definition="Scope
The ResolutionOfInvestigation message is sent by a case assignee to a case creator/case assigner.
This message is used to inform of the resolution of a case, and optionally provides details about.
- the corrective action undertaken by the case assignee
- information on the return where applicable
Usage
The ResolutionOfInvestigation message is used by the case assignee to inform a case creator or case assigner about the resolution of a:
- request to cancel payment case
- request to modify payment case
- unable to apply case
- claim non receipt case
The ResolutionOfInvestigation message covers one and only one case at a time. If the case assignee needs to communicate about several cases, then several Resolution Of Investigation messages must be sent.
The ResolutionOfInvestigation message provides:
- the final outcome of the case, whether positive or negative
- optionally, the details of the corrective action undertaken by the case assignee and the information of the return
Whenever a payment instruction has been generated to solve the case under investigation following a claim non receipt or an unable to apply, the optional CorrectionTransaction component present in the message must be completed.
Whenever the action of modifying or cancelling a payment results in funds being returned or reversed, an investigating agent may provide the details in the resolution related investigation component, to identify the return or reversal transaction. These details will facilitate the account reconciliations at the initiating bank and the intermediaries. It must be stressed that the return or reversal of funds is outside the scope of this Exceptions and Investigation service. The features given here is only meant to transmit the information of return or reversal when it is available through the resolution of the case.
The ResolutionOfInvestigation message must:
- be forwarded by all subsequent case assignee(s) until it reaches the case creator
- not be used in place of a RejectCaseAssignment or CaseStatusReport or NotificationOfCaseAssignment message
Take note of an exceptional rule that allows the use of ResolutionOfInvestigation in lieu of a CaseStatusReport. CaseStatusReport is a response-message to a CaseStatusReportRequest. The latter which is sent when the assigner has reached its own time-out threshold to receive a response. However it may happen that when the request arrives, the investigating agent has just obtained a resolution. In such a situation, it would be redundant to send a CaseStatusReport when then followed immediately by a ResolutionOfInvestigation. It is therefore quite acceptable for the investigating agent, the assignee, to skip the Case Status Report and send the ResolutionOfInvestigation message directly.
The ResolutionOfInvestigation message should be the sole message to respond to a cancellation request. Details of the underlying transactions and the related statuses for which the cancellation request has been issued may be provided in the CancellationDetails component."
registrationStatus="Registered"
messageSet="_urpIICeJEeOCeO5e7islRQ"
xmlTag="RsltnOfInvstgtn"
rootElement="Document"
xmlns:xmi="http://www.omg.org/XMI">
<constraint
xmi:id="_AOwV-V1tEeehlLdFiIrRgQ"
nextVersions="_eX_OaW2PEei3KuUgpx7Xcw"
previousVersion="_KncB02XkEeap-P22vGV91g"
name="PartialOrRejectedCancellationRule"
definition="If Status/Confirmation is present and equal to PECR or RJCR then CancellationDetails must be present."
registrationStatus="Provisionally Registered"
expression="<RuleDefinition xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><ComplexRule xsi:type="ComplexRule"><mustBe><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[*]</leftOperand></BooleanRule></mustBe><onCondition><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/Status/Confirmation</leftOperand></BooleanRule><BooleanRule xsi:type="WithInList"><leftOperand>/Status/Confirmation</leftOperand><rightOperand>InvestigationExecutionConfirmation4Code</rightOperand></BooleanRule></onCondition></ComplexRule></RuleDefinition>
" />
<constraint
xmi:id="_AOwV-11tEeehlLdFiIrRgQ"
nextVersions="_eX_Oa22PEei3KuUgpx7Xcw"
previousVersion="_KncB1WXkEeap-P22vGV91g"
name="MessageOrGroupResolvedCaseRule"
definition="ResolvedCase may be present at either ResolvedCase, OriginalGroupInformationAndStatus, OriginalPaymentInformationAndStatus or TransactionInformationAndStatus level."
registrationStatus="Provisionally Registered"
expression="<RuleDefinition xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><ComplexRule xsi:type="ComplexRule"><mustBe><connector>AND</connector><BooleanRule xsi:type="Absence"><leftOperand>/CancellationDetails[1]/OriginalGroupInformationAndStatus/ResolvedCase</leftOperand></BooleanRule></mustBe><onCondition><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/ResolvedCase</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]/OriginalGroupInformationAndStatus[1]</leftOperand></BooleanRule></onCondition></ComplexRule></RuleDefinition>
" />
<constraint
xmi:id="_AOwV_V1tEeehlLdFiIrRgQ"
nextVersions="_eX_ObW2PEei3KuUgpx7Xcw"
previousVersion="_KncB12XkEeap-P22vGV91g"
name="MessageOrPaymentInformationResolvedCaseRule"
definition="ResolvedCase may be present at either ResolvedCase, OriginalGroupInformationAndStatus, OriginalPaymentInformationAndStatus or TransactionInformationAndStatus level."
registrationStatus="Provisionally Registered"
expression="<RuleDefinition xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><ComplexRule xsi:type="ComplexRule"><mustBe><connector>AND</connector><BooleanRule xsi:type="Absence"><leftOperand>/CancellationDetails[*]/OriginalPaymentInformationAndStatus[*]/ResolvedCase</leftOperand></BooleanRule></mustBe><onCondition><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/ResolvedCase</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]/OriginalPaymentInformationAndStatus[1]</leftOperand></BooleanRule></onCondition></ComplexRule></RuleDefinition>
" />
<constraint
xmi:id="_AOwV_11tEeehlLdFiIrRgQ"
nextVersions="_eX_Ob22PEei3KuUgpx7Xcw"
previousVersion="_KncB2WXkEeap-P22vGV91g"
name="MessageOrInitiationTransactionResolvedCaseRule"
definition="ResolvedCase may be present at either ResolvedCase, OriginalGroupInformationAndStatus, OriginalPaymentInformationAndStatus or TransactionInformationAndStatus level."
registrationStatus="Provisionally Registered"
expression="<RuleDefinition xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><ComplexRule xsi:type="ComplexRule"><mustBe><connector>AND</connector><BooleanRule xsi:type="Absence"><leftOperand>/CancellationDetails[*]/OriginalPaymentInformationAndStatus[*]/TransactionInformationAndStatus[*]/ResolvedCase</leftOperand></BooleanRule></mustBe><onCondition><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/ResolvedCase</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]/OriginalPaymentInformationAndStatus[*]</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]/OriginalPaymentInformationAndStatus[*]/TransactionInformationAndStatus[*]</leftOperand></BooleanRule></onCondition></ComplexRule></RuleDefinition>
" />
<constraint
xmi:id="_AOwWAV1tEeehlLdFiIrRgQ"
nextVersions="_eX_OcW2PEei3KuUgpx7Xcw"
previousVersion="_KncB22XkEeap-P22vGV91g"
name="MessageOrInterbankTransactionResolvedCaseRule"
definition="ResolvedCase may be present at either ResolvedCase, OriginalGroupInformationAndStatus, OriginalPaymentInformationAndStatus or TransactionInformationAndStatus level."
registrationStatus="Provisionally Registered"
expression="<RuleDefinition><ComplexRule xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="ComplexRule"><mustBe><connector>AND</connector><BooleanRule xsi:type="Absence"><leftOperand>/CancellationDetails[*]/TransactionInformationAndStatus[*]/ResolvedCase</leftOperand></BooleanRule></mustBe><onCondition><connector>AND</connector><BooleanRule xsi:type="Presence"><leftOperand>/ResolvedCase</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]</leftOperand></BooleanRule><BooleanRule xsi:type="Presence"><leftOperand>/CancellationDetails[1]/TransactionInformationAndStatus[*]</leftOperand></BooleanRule></onCondition></ComplexRule></RuleDefinition>" />
<messageBuildingBlock
xmi:id="_AOwWA11tEeehlLdFiIrRgQ"
nextVersions="_eX_Oc22PEei3KuUgpx7Xcw"
previousVersion="_KncB3WXkEeap-P22vGV91g"
name="Assignment"
definition="Identifies the assignment of an investigation case from an assigner to an assignee.
Usage: The Assigner must be the sender of this confirmation and the Assignee must be the receiver."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="1"
xmlTag="Assgnmt"
complexType="_HIRcwbTgEeef0oKPLRNatg" />
<messageBuildingBlock
xmi:id="_AOwWBV1tEeehlLdFiIrRgQ"
nextVersions="_eX_OdW2PEei3KuUgpx7Xcw"
previousVersion="_KncB32XkEeap-P22vGV91g"
name="ResolvedCase"
definition="Identifies a resolved case."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="RslvdCase"
complexType="_mm8A4bTREeeyuKckOGlwuA" />
<messageBuildingBlock
xmi:id="_AOwWB11tEeehlLdFiIrRgQ"
nextVersions="_eX_Od22PEei3KuUgpx7Xcw"
previousVersion="_KncB4WXkEeap-P22vGV91g"
name="Status"
definition="Indicates the status of the investigation."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="1"
xmlTag="Sts"
complexType="_nTQy8YmxEeeKR__nUfxjwA" />
<messageBuildingBlock
xmi:id="_AOwWCV1tEeehlLdFiIrRgQ"
nextVersions="_eX_OeW2PEei3KuUgpx7Xcw"
previousVersion="_KncB42XkEeap-P22vGV91g"
name="CancellationDetails"
definition="Specifies the details of the underlying transactions being cancelled."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="CxlDtls"
complexType="_r4psgYlrEeePr-EGJjGYzQ" />
<messageBuildingBlock
xmi:id="_HGcO4YKaEee7hrXqLO3yQg"
nextVersions="_eX_Oe22PEei3KuUgpx7Xcw"
name="ModificationDetails"
definition="Specifies the details of the underlying transaction being modified."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="ModDtls"
complexType="_aWr_XYtvEee-OJ-wXSj3YQ" />
<messageBuildingBlock
xmi:id="_ql2K0ItuEee-OJ-wXSj3YQ"
nextVersions="_eX_OfW2PEei3KuUgpx7Xcw"
name="ClaimNonReceiptDetails"
definition="Specifies the details of the underlying transaction for which a claim non receipt has been initiated."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="ClmNonRctDtls"
complexType="_qFBVgIjYEeeDW7_wB-eK_g" />
<messageBuildingBlock
xmi:id="_AOwWC11tEeehlLdFiIrRgQ"
nextVersions="_eX_Of22PEei3KuUgpx7Xcw"
previousVersion="_KncB5WXkEeap-P22vGV91g"
name="StatementDetails"
definition="Details on the underlying statement entry."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="StmtDtls"
complexType="_b3LNkdwYEee0mvR9H3APRg" />
<messageBuildingBlock
xmi:id="_AOwWDV1tEeehlLdFiIrRgQ"
nextVersions="_eX_OgW2PEei3KuUgpx7Xcw"
previousVersion="_KncB52XkEeap-P22vGV91g"
name="CorrectionTransaction"
definition="References a transaction initiated to fix the case under investigation."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="CrrctnTx"
complexType="_88-Vca6UEeexrtTFgmVD3Q" />
<messageBuildingBlock
xmi:id="_AOwWD11tEeehlLdFiIrRgQ"
nextVersions="_eX_Og22PEei3KuUgpx7Xcw"
previousVersion="_KncB6WXkEeap-P22vGV91g"
name="ResolutionRelatedInformation"
definition="Reference of a return or a reversal initiated to fix the case under investigation as part of the resolution."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="RsltnRltdInf"
complexType="_hEJnkYttEee-OJ-wXSj3YQ" />
<messageBuildingBlock
xmi:id="_AOwWEV1tEeehlLdFiIrRgQ"
nextVersions="_eX_OhW2PEei3KuUgpx7Xcw"
previousVersion="_KncB62XkEeap-P22vGV91g"
name="SupplementaryData"
definition="Additional information that cannot be captured in the structured elements and/or any other specific block."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="SplmtryData"
complexType="_Qn0zC9p-Ed-ak6NoX_4Aeg_468227563" />
<messageDefinitionIdentifier
businessArea="camt"
messageFunctionality="029"
flavour="001"
version="08" />
</messageDefinition>
ISO Building Blocks
The following items are used as building blocks to construct this message.