DTCCCASTSD1V03

supl.031.001.03

The DTCCCASTSD1 message extends ISO Corporate Action Instruction Statement Report message with DTCC corporate action elements not covered in the standard message.

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
%% DTCCCASTSD1V03 recursion level 0 with max 0
DTCCCASTSD1V03 *-- "0..1" CorporateActionBalanceSD5 : EventBalanceDetails
DTCCCASTSD1V03 *-- "0..1" CorporateActionInstructedBalanceOptionBalanceSD3 : TotalInstructedBalanceOptionBalanceDetails
DTCCCASTSD1V03 *-- "0..1" CorporateActionInstructedBalanceOptionInstructionSD3 : TotalInstructedBalanceOptionInstructionDetails
DTCCCASTSD1V03 *-- "0..1" CorporateActionInstructedBalanceOptionProtectInstructionSD3 : TotalInstructedBalanceOptionProtectInstructionDetails
  

Now, we will zero-in one-by-one on each of these building blocks.

EventBalanceDetails building block

Information to be extended as supplementary data to corporate action balance details at event level. Provides additional information regarding corporate action balance details. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% CorporateActionBalanceSD5 recursion level 0 with max 1
class CorporateActionBalanceSD5{
    PlaceAndName IsoMax350Text
}
CorporateActionBalanceSD5 *-- "0..1" SignedQuantityFormat9 : TotalUncoveredProtectBalance
%% SignedQuantityFormat9 recursion level 1 with max 1
class SignedQuantityFormat9{
    ShortLongPosition ShortLong1Code
}
SignedQuantityFormat9 *-- "1..1" IFinancialInstrumentQuantity15Choice : Quantity
  

CorporateActionBalanceSD5 members

Member name Description Data Type / Multiplicity
PlaceAndName Xpath to the element that is being extended. IsoMax350Text - Optional 0..1
TotalUncoveredProtectBalance Balance of uncovered protect transactions at an event level. SignedQuantityFormat9 - Optional 0..1

TotalInstructedBalanceOptionBalanceDetails building block

Information to be extended as supplementary data to corporate action balance details at option level. Provides additional information regarding corporate action instructed balance details at option level. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% CorporateActionInstructedBalanceOptionBalanceSD3 recursion level 0 with max 1
class CorporateActionInstructedBalanceOptionBalanceSD3{
    PlaceAndName IsoMax350Text
}
CorporateActionInstructedBalanceOptionBalanceSD3 *-- "1..1" IOptionNumber1Choice : OptionNumber
CorporateActionInstructedBalanceOptionBalanceSD3 *-- "0..1" SignedQuantityFormat9 : OptionUncoveredProtectBalance
CorporateActionInstructedBalanceOptionBalanceSD3 *-- "0..1" SignedQuantityFormat9 : OptionOversubscriptionQuantity
CorporateActionInstructedBalanceOptionBalanceSD3 *-- "0..1" SignedQuantityFormat9 : OptionUnacceptedBalance
%% IOptionNumber1Choice recursion level 1 with max 1
%% SignedQuantityFormat9 recursion level 1 with max 1
class SignedQuantityFormat9{
    ShortLongPosition ShortLong1Code
}
SignedQuantityFormat9 *-- "1..1" IFinancialInstrumentQuantity15Choice : Quantity
%% SignedQuantityFormat9 recursion level 1 with max 1
class SignedQuantityFormat9{
    ShortLongPosition ShortLong1Code
}
SignedQuantityFormat9 *-- "1..1" IFinancialInstrumentQuantity15Choice : Quantity
%% SignedQuantityFormat9 recursion level 1 with max 1
class SignedQuantityFormat9{
    ShortLongPosition ShortLong1Code
}
SignedQuantityFormat9 *-- "1..1" IFinancialInstrumentQuantity15Choice : Quantity
  

CorporateActionInstructedBalanceOptionBalanceSD3 members

Member name Description Data Type / Multiplicity
PlaceAndName Xpath to the element that is being extended. IsoMax350Text - Optional 0..1
OptionNumber Option Number of the extended balances. IOptionNumber1Choice - Required 1..1
OptionUncoveredProtectBalance Balance of uncovered protect transactions at an option level. SignedQuantityFormat9 - Optional 0..1
OptionOversubscriptionQuantity For rights subscription events, total number of oversubscribed units. When there is an oversubscription privilege, this quantity will be included within the Instructed quantity in the core message. SignedQuantityFormat9 - Optional 0..1
OptionUnacceptedBalance For election merger events, the balance that is being moved into another option number for payment due to the proration of the original option. SignedQuantityFormat9 - Optional 0..1

TotalInstructedBalanceOptionInstructionDetails building block

Information to be extended as supplementary data to corporate action balance details at option instruction details level. Option level instruction details are referenced by unique instruction identification, instruction date, quantity and status of instruction. Provides additional information regarding corporate action instructed balance details at option level. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% CorporateActionInstructedBalanceOptionInstructionSD3 recursion level 0 with max 1
class CorporateActionInstructedBalanceOptionInstructionSD3{
    PlaceAndName IsoMax350Text
    TransactionIdentificationStatus DTCInstructionStatus2Code
}
CorporateActionInstructedBalanceOptionInstructionSD3 *-- "1..1" IOptionNumber1Choice : OptionNumber
CorporateActionInstructedBalanceOptionInstructionSD3 *-- "0..1" OtherIdentification2 : TransactionContraCUSIP
CorporateActionInstructedBalanceOptionInstructionSD3 *-- "0..1" IFinancialInstrumentQuantity15Choice : TransactionIdentificationOversubscriptionQuantity
%% IOptionNumber1Choice recursion level 1 with max 1
%% OtherIdentification2 recursion level 1 with max 1
class OtherIdentification2{
    Identification IsoRestrictedFINXMax31Text
    Suffix IsoMax16Text
}
OtherIdentification2 *-- "1..1" IIdentificationSource4Choice : Type
%% IFinancialInstrumentQuantity15Choice recursion level 1 with max 1
  

CorporateActionInstructedBalanceOptionInstructionSD3 members

Member name Description Data Type / Multiplicity
PlaceAndName Xpath to the element that is being extended. IsoMax350Text - Optional 0..1
OptionNumber Number identifying the available corporate action options. IOptionNumber1Choice - Required 1..1
TransactionContraCUSIP Contra CUSIP Identification of the option instruction. OtherIdentification2 - Optional 0..1
TransactionIdentificationOversubscriptionQuantity Quantity relating only to the oversubscription. IFinancialInstrumentQuantity15Choice - Optional 0..1
TransactionIdentificationStatus Status of the instruction. DTCInstructionStatus2Code - Required 1..1

TotalInstructedBalanceOptionProtectInstructionDetails building block

Information to be extended as supplementary data to corporate action balance details at option protect instruction details level. Provides additional information regarding corporate action instructed balance details at option protect level. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% CorporateActionInstructedBalanceOptionProtectInstructionSD3 recursion level 0 with max 1
class CorporateActionInstructedBalanceOptionProtectInstructionSD3{
    PlaceAndName IsoMax350Text
    ProtectSafekeepingAccount IsoRestrictedFINMax35Text
    ProtectIdentificationStatus DTCProtectInstructionStatus1Code
}
CorporateActionInstructedBalanceOptionProtectInstructionSD3 *-- "1..1" IOptionNumber1Choice : OptionNumber
CorporateActionInstructedBalanceOptionProtectInstructionSD3 *-- "0..1" IFinancialInstrumentQuantity15Choice : ProtectIdentificationUncoveredQuantity
CorporateActionInstructedBalanceOptionProtectInstructionSD3 *-- "0..1" IFinancialInstrumentQuantity15Choice : ProtectIdentificationOversubscriptionQuantity
%% IOptionNumber1Choice recursion level 1 with max 1
%% IFinancialInstrumentQuantity15Choice recursion level 1 with max 1
%% IFinancialInstrumentQuantity15Choice recursion level 1 with max 1
  

CorporateActionInstructedBalanceOptionProtectInstructionSD3 members

Member name Description Data Type / Multiplicity
PlaceAndName Xpath to the element that is being extended. IsoMax350Text - Optional 0..1
OptionNumber Option number of the protect instruction. IOptionNumber1Choice - Required 1..1
ProtectSafekeepingAccount For cover protect instructions whereby one safekeeping account is covering on behalf of another safekeeping account. The protect safekeeping account will be the account which submitted the original protect instruction. IsoRestrictedFINMax35Text - Optional 0..1
ProtectIdentificationUncoveredQuantity Quantity of the protect instruction which has not been covered. IFinancialInstrumentQuantity15Choice - Optional 0..1
ProtectIdentificationOversubscriptionQuantity Protect oversubscription quantity. IFinancialInstrumentQuantity15Choice - Optional 0..1
ProtectIdentificationStatus Status of the protect instruction. DTCProtectInstructionStatus1Code - Optional 0..1

Extensibility and generalization considerations

To facilitate generalized design patterns in the system, the DTCCCASTSD1V03 implementation follows a specific implementaiton pattern. First of all, DTCCCASTSD1V03 impleemnts IOuterRecord indicating it is the outermost logical part of the message definition. Like all message wrappers, DTCCCASTSD1V03Document implements IOuterDocument. Because DTCCCASTSD1V03 implements IOuterDocument, it is a suitable template parameter for IOuterDocument, and causes the internal ‘Message’ to be of type DTCCCASTSD1V03.

classDiagram
    class IOuterRecord
    DTCCCASTSD1V03 --|> IOuterRecord : Implements
    DTCCCASTSD1V03Document --|> IOuterDocument~DTCCCASTSD1V03~ : Implements
    class IOuterDocument~DTCCCASTSD1V03~ {
        DTCCCASTSD1V03 Message
     }
  

Document wrapper for serialization

The only real purpose DTCCCASTSD1V03Document serves is to cause the document to be serialized into the ‘urn:iso:std:iso:20022:tech:xsd:supl.031.001.03’ namespace. Therefore, it will probably be the usual practice to build the message and construct this wrapper at the last minute using DTCCCASTSD1V03.ToDocument() method. The returned DTCCCASTSD1V03Document value will serialize correctly according to ISO 20022 standards.

classDiagram
    DTCCCASTSD1V03Document *-- DTCCCASTSD1V03 : 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:supl.031.001.03">
    <DTCCCASTSD1>
        <EvtBalDtls>
            <!-- EventBalanceDetails inner content -->
        </EvtBalDtls>
        <TtlInstdBalOptnBalDtls>
            <!-- TotalInstructedBalanceOptionBalanceDetails inner content -->
        </TtlInstdBalOptnBalDtls>
        <TtlInstdBalOptnInstrDtls>
            <!-- TotalInstructedBalanceOptionInstructionDetails inner content -->
        </TtlInstdBalOptnInstrDtls>
        <TtlInstdBalOptnPrtctInstrDtls>
            <!-- TotalInstructedBalanceOptionProtectInstructionDetails inner content -->
        </TtlInstdBalOptnPrtctInstrDtls>
    </DTCCCASTSD1>
</Document>

Data from ISO specification

This is the technical data from the specification document.

<messageDefinition
  xmi:id="_b_h_Y-aHEei5aPS232E3Mw"
  nextVersions="_q_pK-Q4zEeuIpNw_GxsBOw"
  previousVersion="_LAGyq75MEeexmbB7KsjCwA"
  name="DTCCCASTSD1V03"
  definition="The DTCCCASTSD1 message extends ISO Corporate Action Instruction Statement Report message with DTCC corporate action elements not covered in the standard message."
  registrationStatus="Registered"
  messageSet="_urpIICeJEeOCeO5e7islRQ"
  xmlTag="DTCCCASTSD1"
  rootElement="Document"
  xmlns:xmi="http://www.omg.org/XMI">
  <messageBuildingBlock
    xmi:id="_b_h_ZeaHEei5aPS232E3Mw"
    nextVersions="_q_pK-w4zEeuIpNw_GxsBOw"
    previousVersion="_LAGyrb5MEeexmbB7KsjCwA"
    name="EventBalanceDetails"
    definition="Information to be extended as supplementary data to corporate action balance details at event level."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="EvtBalDtls"
    complexType="__1Zacb-zEeeb2ZBoAlSG1Q" />
  <messageBuildingBlock
    xmi:id="_b_h_Z-aHEei5aPS232E3Mw"
    nextVersions="_q_pK_Q4zEeuIpNw_GxsBOw"
    previousVersion="_LAGyr75MEeexmbB7KsjCwA"
    name="TotalInstructedBalanceOptionBalanceDetails"
    definition="Information to be extended as supplementary data to corporate action balance details at option level."
    registrationStatus="Provisionally Registered"
    minOccurs="0"
    xmlTag="TtlInstdBalOptnBalDtls"
    complexType="_EqhGsegXEei5aPS232E3Mw" />
  <messageBuildingBlock
    xmi:id="_b_h_aeaHEei5aPS232E3Mw"
    nextVersions="_q_pK_w4zEeuIpNw_GxsBOw"
    previousVersion="_LAGysb5MEeexmbB7KsjCwA"
    name="TotalInstructedBalanceOptionInstructionDetails"
    definition="Information to be extended as supplementary data to corporate action balance details at option instruction details level. Option level instruction details are referenced by unique instruction identification, instruction date, quantity and status of instruction."
    registrationStatus="Provisionally Registered"
    minOccurs="0"
    xmlTag="TtlInstdBalOptnInstrDtls"
    complexType="_aq9fEegXEei5aPS232E3Mw" />
  <messageBuildingBlock
    xmi:id="_b_h_a-aHEei5aPS232E3Mw"
    nextVersions="_q_pLAQ4zEeuIpNw_GxsBOw"
    previousVersion="_LAGys75MEeexmbB7KsjCwA"
    name="TotalInstructedBalanceOptionProtectInstructionDetails"
    definition="Information to be extended as supplementary data to corporate action balance details at option protect instruction details level."
    registrationStatus="Provisionally Registered"
    minOccurs="0"
    xmlTag="TtlInstdBalOptnPrtctInstrDtls"
    complexType="_lycUYegYEei5aPS232E3Mw" />
  <messageDefinitionIdentifier
    businessArea="supl"
    messageFunctionality="031"
    flavour="001"
    version="03" />
</messageDefinition>

ISO Building Blocks

The following items are used as building blocks to construct this message.