seev.039.001.04
Scope An account servicer sends the CorporateActionCancellationAdvice message to an account owner or its designated agent to cancel a previously announced corporate action event in case of error from the account servicer or in case of withdrawal by the issuer. Usage The message may also be used to:
- re-send a message previously sent (the sub-function of the message is Duplicate),
- provide a third party with a copy of a message for information (the sub-function of the message is Copy),
- re-send to a third party a copy of a message for information (the sub-function of the message is Copy Duplicate), using the relevant elements in the business application header (BAH). ISO 15022 - 20022 COEXISTENCE This ISO 20022 message is reversed engineered from ISO 15022. Both standards will coexist for a certain number of years. Until this coexistence period ends, the usage of certain data types is restricted to ensure interoperability between ISO 15022 and 20022 users. Compliance to these rules is mandatory in a coexistence environment. The coexistence restrictions are described in a Textual Rule linked to the Message Items they concern. These coexistence textual rules are clearly identified as follows: “CoexistenceXxxxRule”.
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 %% CorporateActionCancellationAdviceV04 recursion level 0 with max 0 CorporateActionCancellationAdviceV04 *-- "1..1" CorporateActionCancellation1 : CancellationAdviceGeneralInformation CorporateActionCancellationAdviceV04 *-- "1..1" CorporateActionGeneralInformation56 : CorporateActionGeneralInformation CorporateActionCancellationAdviceV04 *-- "1..1" IAccountIdentification13Choice : AccountsDetails CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : IssuerAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : PayingAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : SubPayingAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : Registrar CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : ResellingAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : PhysicalSecuritiesAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : DropAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : SolicitationAgent CorporateActionCancellationAdviceV04 *-- "0..1" IPartyIdentification46Choice : InformationAgent CorporateActionCancellationAdviceV04 *-- "0..1" SupplementaryData1 : SupplementaryData
Now, we will zero-in one-by-one on each of these building blocks.
CancellationAdviceGeneralInformation building block
General information about the event cancellation status and cancellation reason. Corporate action event cancellation status and reason. For comparison, see the ISO20022 official specification
classDiagram direction tb %% CorporateActionCancellation1 recursion level 0 with max 1 class CorporateActionCancellation1{ CancellationReasonCode CorporateActionCancellationReason1Code CancellationReason IsoMax140Text } CorporateActionCancellation1 *-- "1..1" ICorporateActionProcessingStatus1Choice : ProcessingStatus %% ICorporateActionProcessingStatus1Choice recursion level 1 with max 1
CorporateActionCancellation1 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
CancellationReasonCode | Specifies reasons for cancellation of a corporate action event. | CorporateActionCancellationReason1Code - Required 1..1 |
CancellationReason | Additional information about cancellation of a corporate action event. | IsoMax140Text - Optional 0..1 |
ProcessingStatus | Specifies the status of the details of the event. | ICorporateActionProcessingStatus1Choice - Required 1..1 |
CorporateActionGeneralInformation building block
General information about the corporate action event. General information about the corporate action event. For comparison, see the ISO20022 official specification
classDiagram direction tb %% CorporateActionGeneralInformation56 recursion level 0 with max 1 class CorporateActionGeneralInformation56{ CorporateActionEventIdentification IsoMax35Text OfficialCorporateActionEventIdentification IsoMax35Text ClassActionNumber IsoMax35Text } CorporateActionGeneralInformation56 *-- "1..1" ICorporateActionEventType13Choice : EventType CorporateActionGeneralInformation56 *-- "1..1" ICorporateActionMandatoryVoluntary1Choice : MandatoryVoluntaryEventType CorporateActionGeneralInformation56 *-- "1..1" SecurityIdentification14 : FinancialInstrumentIdentification %% ICorporateActionEventType13Choice recursion level 1 with max 1 %% ICorporateActionMandatoryVoluntary1Choice recursion level 1 with max 1 %% SecurityIdentification14 recursion level 1 with max 1 class SecurityIdentification14{ ISIN IsoISINIdentifier Description IsoMax140Text } SecurityIdentification14 *-- "0..0" OtherIdentification1 : OtherIdentification
CorporateActionGeneralInformation56 members
Member name | Description | Data Type / Multiplicity |
---|---|---|
CorporateActionEventIdentification | Reference assigned by the account servicer to unambiguously identify a corporate action event. | IsoMax35Text - Required 1..1 |
OfficialCorporateActionEventIdentification | Official and unique reference assigned by the official central body/entity within each market at the beginning of a corporate action event. | IsoMax35Text - Optional 0..1 |
ClassActionNumber | Reference assigned by a court to a class action. | IsoMax35Text - Optional 0..1 |
EventType | Type of corporate action event. | ICorporateActionEventType13Choice - Required 1..1 |
MandatoryVoluntaryEventType | Specifies whether the event is mandatory, mandatory with options or voluntary. | ICorporateActionMandatoryVoluntary1Choice - Required 1..1 |
FinancialInstrumentIdentification | Identification of the security concerned by the corporate action. | SecurityIdentification14 - Required 1..1 |
AccountsDetails building block
General information about the safekeeping account and the account owner. Choice between all accounts (GENR - General in ISO 15022) or one or more selected accounts. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IAccountIdentification13Choice recursion level 0 with max 1
AccountIdentification13Choice members
Member name | Description | Data Type / Multiplicity |
---|
IssuerAgent building block
Party appointed to administer the event on behalf of the issuer company/offeror. The party may be contacted for more information about the event. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
PayingAgent building block
Agent (principal or fiscal paying agent) appointed to execute the payment for the corporate action event on behalf of the issuer company/offeror. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
SubPayingAgent building block
Sub-agent appointed to execute the payment for the corporate action event on behalf of the issuer company/offeror. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
Registrar building block
Party/agent responsible for maintaining the register of a security. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
ResellingAgent building block
A broker-dealer responsible for reselling to new investors securities (usually bonds) that have been tendered for purchase by their owner. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
PhysicalSecuritiesAgent building block
A trust company, bank or similar financial institution assigned by an issuer to accept presentations of instruments, usually bonds, for transfer and or exchange. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
DropAgent building block
A trust company, bank or similar financial institution who acts on behalf of an out of town agent or event agent where securities can be delivered in person. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
SolicitationAgent building block
A trust company, bank or similar financial institution assigned by an issuer to maintain records of investors and account balances and transactions for the consent of a material change. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
InformationAgent building block
A trust company, bank or similar financial institution assigned by an Issuer to provide information and copies of the offering documentation. Choice of identification of a party. For comparison, see the ISO20022 official specification
classDiagram direction tb %% IPartyIdentification46Choice recursion level 0 with max 1
PartyIdentification46Choice members
Member name | Description | Data Type / Multiplicity |
---|
SupplementaryData building block
Additional information that can not be captured in the structured fields 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 CorporateActionCancellationAdviceV04 implementation follows a specific implementaiton pattern. First of all, CorporateActionCancellationAdviceV04 impleemnts IOuterRecord indicating it is the outermost logical part of the message definition. Like all message wrappers, CorporateActionCancellationAdviceV04Document implements IOuterDocument. Because CorporateActionCancellationAdviceV04 implements IOuterDocument, it is a suitable template parameter for IOuterDocument, and causes the internal ‘Message’ to be of type CorporateActionCancellationAdviceV04.
classDiagram class IOuterRecord CorporateActionCancellationAdviceV04 --|> IOuterRecord : Implements CorporateActionCancellationAdviceV04Document --|> IOuterDocument~CorporateActionCancellationAdviceV04~ : Implements class IOuterDocument~CorporateActionCancellationAdviceV04~ { CorporateActionCancellationAdviceV04 Message }
Document wrapper for serialization
The only real purpose CorporateActionCancellationAdviceV04Document serves is to cause the document to be serialized into the ‘urn:iso:std:iso:20022:tech:xsd:seev.039.001.04’ namespace. Therefore, it will probably be the usual practice to build the message and construct this wrapper at the last minute using CorporateActionCancellationAdviceV04.ToDocument() method. The returned CorporateActionCancellationAdviceV04Document value will serialize correctly according to ISO 20022 standards.
classDiagram CorporateActionCancellationAdviceV04Document *-- CorporateActionCancellationAdviceV04 : 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:seev.039.001.04">
<CorpActnCxlAdvc>
<CxlAdvcGnlInf>
<!-- CancellationAdviceGeneralInformation inner content -->
</CxlAdvcGnlInf>
<CorpActnGnlInf>
<!-- CorporateActionGeneralInformation inner content -->
</CorpActnGnlInf>
<AcctsDtls>
<!-- AccountsDetails inner content -->
</AcctsDtls>
<IssrAgt>
<!-- IssuerAgent inner content -->
</IssrAgt>
<PngAgt>
<!-- PayingAgent inner content -->
</PngAgt>
<SubPngAgt>
<!-- SubPayingAgent inner content -->
</SubPngAgt>
<Regar>
<!-- Registrar inner content -->
</Regar>
<RsellngAgt>
<!-- ResellingAgent inner content -->
</RsellngAgt>
<PhysSctiesAgt>
<!-- PhysicalSecuritiesAgent inner content -->
</PhysSctiesAgt>
<DrpAgt>
<!-- DropAgent inner content -->
</DrpAgt>
<SlctnAgt>
<!-- SolicitationAgent inner content -->
</SlctnAgt>
<InfAgt>
<!-- InformationAgent inner content -->
</InfAgt>
<SplmtryData>
<!-- SupplementaryData inner content -->
</SplmtryData>
</CorpActnCxlAdvc>
</Document>
Data from ISO specification
This is the technical data from the specification document.
<messageDefinition
xmi:id="_yldEwQx1EeKMmbvHOtE4SA"
nextVersions="_qXIiMRbDEeOb5dMswipsLQ"
previousVersion="_9HpTcfmMEeC_eLZALo-S0A"
name="CorporateActionCancellationAdviceV04"
definition="Scope
An account servicer sends the CorporateActionCancellationAdvice message to an account owner or its designated agent to cancel a previously announced corporate action event in case of error from the account servicer or in case of withdrawal by the issuer.
Usage
The message may also be used to:
- re-send a message previously sent (the sub-function of the message is Duplicate),
- provide a third party with a copy of a message for information (the sub-function of the message is Copy),
- re-send to a third party a copy of a message for information (the sub-function of the message is Copy Duplicate),
using the relevant elements in the business application header (BAH).
ISO 15022 - 20022 COEXISTENCE
This ISO 20022 message is reversed engineered from ISO 15022. Both standards will coexist for a certain number of years. Until this coexistence period ends, the usage of certain data types is restricted to ensure interoperability between ISO 15022 and 20022 users. Compliance to these rules is mandatory in a coexistence environment. The coexistence restrictions are described in a Textual Rule linked to the Message Items they concern. These coexistence textual rules are clearly identified as follows: “CoexistenceXxxxRule”."
registrationStatus="Registered"
messageSet="_urpIICeJEeOCeO5e7islRQ"
xmlTag="CorpActnCxlAdvc"
rootElement="Document"
xmlns:xmi="http://www.omg.org/XMI">
<constraint
xmi:id="_yldEwwx1EeKMmbvHOtE4SA"
nextVersions="_qXIiMxbDEeOb5dMswipsLQ"
name="CoexistenceCharacterSetXRule"
definition="During ISO 15022 – 20022 coexistence, characters used in all text fields must correspond to character set X, that is, a-z A-Z / - ? : ( ) . , ‘ + { } CR LF."
registrationStatus="Provisionally Registered" />
<constraint
xmi:id="_yldExwx1EeKMmbvHOtE4SA"
nextVersions="_qXIiNRbDEeOb5dMswipsLQ"
name="CoexistenceIdentificationRule"
definition="During ISO 15022 – 20022 coexistence, all transaction and document identifications or references must be 16 characters or less. The field must not start or end with a slash ‘/’ or contain two consecutive slashes ‘//’."
registrationStatus="Provisionally Registered" />
<messageBuildingBlock
xmi:id="_yldEywx1EeKMmbvHOtE4SA"
nextVersions="_qXIiNxbDEeOb5dMswipsLQ"
name="CancellationAdviceGeneralInformation"
definition="General information about the event cancellation status and cancellation reason."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="1"
xmlTag="CxlAdvcGnlInf"
complexType="_UKK4Ytp-Ed-ak6NoX_4Aeg_237834559" />
<messageBuildingBlock
xmi:id="_yldEzwx1EeKMmbvHOtE4SA"
nextVersions="_qXIiORbDEeOb5dMswipsLQ"
name="CorporateActionGeneralInformation"
definition="General information about the corporate action event."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="1"
xmlTag="CorpActnGnlInf"
complexType="_0lj38REuEeKp2ZN13DI_pA" />
<messageBuildingBlock
xmi:id="_yldE0wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiOxbDEeOb5dMswipsLQ"
name="AccountsDetails"
definition="General information about the safekeeping account and the account owner."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="1"
xmlTag="AcctsDtls"
complexType="_qVGz5-aPEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE1wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiPRbDEeOb5dMswipsLQ"
name="IssuerAgent"
definition="Party appointed to administer the event on behalf of the issuer company/offeror. The party may be contacted for more information about the event."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="IssrAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE2wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiPxbDEeOb5dMswipsLQ"
name="PayingAgent"
definition="Agent (principal or fiscal paying agent) appointed to execute the payment for the corporate action event on behalf of the issuer company/offeror."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="PngAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE3wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiQRbDEeOb5dMswipsLQ"
name="SubPayingAgent"
definition="Sub-agent appointed to execute the payment for the corporate action event on behalf of the issuer company/offeror."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="SubPngAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE4wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiQxbDEeOb5dMswipsLQ"
name="Registrar"
definition="Party/agent responsible for maintaining the register of a security."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="Regar"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE5wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiRRbDEeOb5dMswipsLQ"
name="ResellingAgent"
definition="A broker-dealer responsible for reselling to new investors securities (usually bonds) that have been tendered for purchase by their owner."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="RsellngAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE6wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiRxbDEeOb5dMswipsLQ"
name="PhysicalSecuritiesAgent"
definition="A trust company, bank or similar financial institution assigned by an issuer to accept presentations of instruments, usually bonds, for transfer and or exchange."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="PhysSctiesAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE7wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiSRbDEeOb5dMswipsLQ"
name="DropAgent"
definition="A trust company, bank or similar financial institution who acts on behalf of an out of town agent or event agent where securities can be delivered in person."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="DrpAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE8wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiSxbDEeOb5dMswipsLQ"
name="SolicitationAgent"
definition="A trust company, bank or similar financial institution assigned by an issuer to maintain records of investors and account balances and transactions for the consent of a material change."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="SlctnAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE9wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiTRbDEeOb5dMswipsLQ"
name="InformationAgent"
definition="A trust company, bank or similar financial institution assigned by an Issuer to provide information and copies of the offering documentation."
registrationStatus="Provisionally Registered"
maxOccurs="1"
minOccurs="0"
xmlTag="InfAgt"
complexType="_0amvIeaNEd-q8fx_Zl_34A" />
<messageBuildingBlock
xmi:id="_yldE-wx1EeKMmbvHOtE4SA"
nextVersions="_qXIiTxbDEeOb5dMswipsLQ"
name="SupplementaryData"
definition="Additional information that can not be captured in the structured fields and/or any other specific block."
registrationStatus="Provisionally Registered"
minOccurs="0"
xmlTag="SplmtryData"
complexType="_Qn0zC9p-Ed-ak6NoX_4Aeg_468227563" />
<messageDefinitionIdentifier
businessArea="seev"
messageFunctionality="039"
flavour="001"
version="04" />
</messageDefinition>
ISO Building Blocks
The following items are used as building blocks to construct this message.