SecuritiesSettlementTransactionAllegementNotificationV09

sese.028.001.09

Scope An account servicer sends a SecuritiesSettlementTransactionAllegementNotification to an account owner to advise the account owner that a counterparty has alleged an instruction against the account owner’s account at the account servicer and that the account servicer could not find the corresponding instruction of the account owner. The account servicer/owner relationship may be:

Usage The message may also be used to:

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
%% SecuritiesSettlementTransactionAllegementNotificationV09 recursion level 0 with max 0
class SecuritiesSettlementTransactionAllegementNotificationV09{
    TransactionIdentification IsoMax35Text
}
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "1..1" SettlementTypeAndAdditionalParameters12 : SettlementTypeAndAdditionalParameters
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" Identification14 : MarketInfrastructureTransactionIdentification
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "1..1" SecuritiesTradeDetails123 : TradeDetails
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "1..1" SecurityIdentification19 : FinancialInstrumentIdentification
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" FinancialInstrumentAttributes91 : FinancialInstrumentAttributes
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "1..1" QuantityAndAccount82 : QuantityAndAccountDetails
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" SecuritiesFinancingTransactionDetails45 : SecuritiesFinancingDetails
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "1..1" SettlementDetails187 : SettlementParameters
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" SettlementParties76 : DeliveringSettlementParties
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" SettlementParties76 : ReceivingSettlementParties
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" CashParties35 : CashParties
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" AmountAndDirection88 : SettlementAmount
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" OtherAmounts32 : OtherAmounts
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" OtherParties34 : OtherBusinessParties
SecuritiesSettlementTransactionAllegementNotificationV09 *-- "0..1" SupplementaryData1 : SupplementaryData
  

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

TransactionIdentification building block

Unambiguous identification of the transaction as known by the instructing party. Specifies a character string with a maximum length of 35 characters. For comparison, see the ISO20022 official specification This message is declared as Max35Text in the ISO specification. In our implementation, it is represented in source code as IsoMax35Text. Due to global using directives, it is treated as a System.String by the compiler and runtime.

SettlementTypeAndAdditionalParameters building block

Provides settlement type and identification information. Provides transaction type and identification information. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SettlementTypeAndAdditionalParameters12 recursion level 0 with max 1
class SettlementTypeAndAdditionalParameters12{
    SecuritiesMovementType ReceiveDelivery1Code
    Payment DeliveryReceiptType2Code
    CommonIdentification IsoMax35Text
}
  

SettlementTypeAndAdditionalParameters12 members

Member name Description Data Type / Multiplicity
SecuritiesMovementType Specifies if the movement on a securities account results from a deliver or a receive instruction. ReceiveDelivery1Code - Required 1..1
Payment Specifies how the transaction is to be settled, for example, against payment. DeliveryReceiptType2Code - Required 1..1
CommonIdentification Unique reference agreed upon by the two trade counterparties to identify the trade. IsoMax35Text - Optional 0..1

MarketInfrastructureTransactionIdentification building block

Identification of a transaction assigned by a market infrastructure other than a central securities depository, for example, Target2-Securities. Unique identifier of a document, message or transaction. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% Identification14 recursion level 0 with max 1
class Identification14{
    Identification IsoMax35Text
}
  

Identification14 members

Member name Description Data Type / Multiplicity
Identification Unique identifier of a document, message or transaction. IsoMax35Text - Required 1..1

TradeDetails building block

Details of the trade. Details of the securities trade. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SecuritiesTradeDetails123 recursion level 0 with max 1
class SecuritiesTradeDetails123{
    TradeIdentification IsoMax52Text
    CollateralTransactionIdentification IsoMax35Text
    AccountOwnerTransactionIdentification IsoMax35Text
    ProcessorTransactionIdentification IsoMax35Text
    NumberOfDaysAccrued IsoMax3Number
}
SecuritiesTradeDetails123 *-- "0..1" PlaceOfTradeIdentification1 : PlaceOfTrade
SecuritiesTradeDetails123 *-- "0..1" PlaceOfClearingIdentification2 : PlaceOfClearing
SecuritiesTradeDetails123 *-- "0..1" ITradeDate8Choice : TradeDate
SecuritiesTradeDetails123 *-- "1..1" ISettlementDate17Choice : SettlementDate
SecuritiesTradeDetails123 *-- "0..1" Price10 : DealPrice
SecuritiesTradeDetails123 *-- "0..0" ITradeTransactionCondition5Choice : TradeTransactionCondition
SecuritiesTradeDetails123 *-- "0..1" ITypeOfPrice29Choice : TypeOfPrice
%% PlaceOfTradeIdentification1 recursion level 1 with max 1
class PlaceOfTradeIdentification1{
    LEI IsoLEIIdentifier
}
PlaceOfTradeIdentification1 *-- "0..1" MarketIdentification84 : MarketTypeAndIdentification
%% PlaceOfClearingIdentification2 recursion level 1 with max 1
class PlaceOfClearingIdentification2{
    Identification IsoAnyBICDec2014Identifier
    LEI IsoLEIIdentifier
}
%% ITradeDate8Choice recursion level 1 with max 1
%% ISettlementDate17Choice recursion level 1 with max 1
%% Price10 recursion level 1 with max 1
Price10 *-- "1..1" IYieldedOrValueType2Choice : Type
Price10 *-- "1..1" IPriceRateOrAmount3Choice : Value
%% ITradeTransactionCondition5Choice recursion level 1 with max 1
%% ITypeOfPrice29Choice recursion level 1 with max 1
  

SecuritiesTradeDetails123 members

Member name Description Data Type / Multiplicity
TradeIdentification Reference assigned to the trade by the investor or the trading party. This reference will be used throughout the trade life cycle to access/update the trade details. IsoMax52Text - Unknown 0..0
CollateralTransactionIdentification Unambiguous identification of a collateral transaction as assigned by the instructing party. IsoMax35Text - Unknown 0..0
AccountOwnerTransactionIdentification Identification of an account owner transaction that could potentially match with the allegement notified. IsoMax35Text - Unknown 0..0
ProcessorTransactionIdentification Identification of the transaction assigned by the processor of the instruction other than the account owner, the account servicer and the market infrastructure. IsoMax35Text - Optional 0..1
PlaceOfTrade Market in which a trade transaction has been executed. PlaceOfTradeIdentification1 - Optional 0..1
PlaceOfClearing Infrastructure which may be a component of a clearing house and which facilitates clearing and settlement for its members by standing between the buyer and the seller. It may net transactions and it substitutes itself as settlement counterparty for each position. PlaceOfClearingIdentification2 - Optional 0..1
TradeDate Specifies the date/time on which the trade was executed. ITradeDate8Choice - Optional 0..1
SettlementDate Date and time at which the securities are to be delivered or received. ISettlementDate17Choice - Required 1..1
DealPrice Specifies the price of the traded financial instrument. This is the deal price of the individual trade transaction.
NumberOfDaysAccrued Number of days on which the interest rate accrues (daily accrual note). IsoMax3Number - Optional 0..1
TradeTransactionCondition Indicates the conditions under which the order/trade is to be/was executed. ITradeTransactionCondition5Choice - Unknown 0..0
TypeOfPrice Specifies the type of price and information about the price. ITypeOfPrice29Choice - Optional 0..1

FinancialInstrumentIdentification building block

Financial instrument representing a sum of rights of the investor vis-a-vis the issuer. Identification of a security. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SecurityIdentification19 recursion level 0 with max 1
class SecurityIdentification19{
    ISIN IsoISINOct2015Identifier
    Description IsoMax140Text
}
SecurityIdentification19 *-- "0..0" OtherIdentification1 : OtherIdentification
%% OtherIdentification1 recursion level 1 with max 1
class OtherIdentification1{
    Identification IsoMax35Text
    Suffix IsoMax16Text
}
OtherIdentification1 *-- "1..1" IIdentificationSource3Choice : Type
  

SecurityIdentification19 members

Member name Description Data Type / Multiplicity
ISIN International Securities Identification Number (ISIN). A numbering system designed by the United Nation’s International Organisation for Standardisation (ISO). The ISIN is composed of a 2-character prefix representing the country of issue, followed by the national security number (if one exists), and a check digit. Each country has a national numbering agency that assigns ISIN numbers for securities in that country. IsoISINOct2015Identifier - Optional 0..1
OtherIdentification Identification of a security by proprietary or domestic identification scheme. OtherIdentification1 - Unknown 0..0
Description Textual description of a security instrument. IsoMax140Text - Optional 0..1

FinancialInstrumentAttributes building block

Elements characterising a financial instrument. Elements characterising a financial instrument. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% FinancialInstrumentAttributes91 recursion level 0 with max 1
class FinancialInstrumentAttributes91{
    DenominationCurrency ActiveOrHistoricCurrencyCode
    CouponDate IsoISODate
    ExpiryDate IsoISODate
    FloatingRateFixingDate IsoISODate
    MaturityDate IsoISODate
    IssueDate IsoISODate
    NextCallableDate IsoISODate
    PutableDate IsoISODate
    DatedDate IsoISODate
    FirstPaymentDate IsoISODate
    PreviousFactor IsoBaseOneRate
    CurrentFactor IsoBaseOneRate
    NextFactor IsoBaseOneRate
    InterestRate IsoPercentageRate
    YieldToMaturityRate IsoPercentageRate
    NextInterestRate IsoPercentageRate
    IndexRateBasis IsoPercentageRate
    VariableRateIndicator IsoYesNoIndicator
    CallableIndicator IsoYesNoIndicator
    PutableIndicator IsoYesNoIndicator
    FinancialInstrumentAttributeAdditionalDetails IsoMax350Text
}
FinancialInstrumentAttributes91 *-- "0..1" IMarketIdentification3Choice : PlaceOfListing
FinancialInstrumentAttributes91 *-- "0..1" IInterestComputationMethodFormat4Choice : DayCountBasis
FinancialInstrumentAttributes91 *-- "0..1" IFormOfSecurity6Choice : RegistrationForm
FinancialInstrumentAttributes91 *-- "0..1" IFrequency23Choice : PaymentFrequency
FinancialInstrumentAttributes91 *-- "0..1" ISecuritiesPaymentStatus5Choice : PaymentStatus
FinancialInstrumentAttributes91 *-- "0..1" IFrequency23Choice : VariableRateChangeFrequency
FinancialInstrumentAttributes91 *-- "0..1" IClassificationType32Choice : ClassificationType
FinancialInstrumentAttributes91 *-- "0..1" IOptionStyle8Choice : OptionStyle
FinancialInstrumentAttributes91 *-- "0..1" IOptionType6Choice : OptionType
FinancialInstrumentAttributes91 *-- "0..1" INumber22Choice : CouponAttachedNumber
FinancialInstrumentAttributes91 *-- "0..1" GenericIdentification37 : PoolNumber
FinancialInstrumentAttributes91 *-- "0..1" IPriceType4Choice : MarketOrIndicativePrice
FinancialInstrumentAttributes91 *-- "0..1" Price7 : ExercisePrice
FinancialInstrumentAttributes91 *-- "0..1" Price7 : SubscriptionPrice
FinancialInstrumentAttributes91 *-- "0..1" Price7 : ConversionPrice
FinancialInstrumentAttributes91 *-- "0..1" Price7 : StrikePrice
FinancialInstrumentAttributes91 *-- "0..1" IFinancialInstrumentQuantity1Choice : MinimumNominalQuantity
FinancialInstrumentAttributes91 *-- "0..1" IFinancialInstrumentQuantity1Choice : ContractSize
FinancialInstrumentAttributes91 *-- "0..0" SecurityIdentification19 : UnderlyingFinancialInstrumentIdentification
%% IMarketIdentification3Choice recursion level 1 with max 1
%% IInterestComputationMethodFormat4Choice recursion level 1 with max 1
%% IFormOfSecurity6Choice recursion level 1 with max 1
%% IFrequency23Choice recursion level 1 with max 1
%% ISecuritiesPaymentStatus5Choice recursion level 1 with max 1
%% IFrequency23Choice recursion level 1 with max 1
%% IClassificationType32Choice recursion level 1 with max 1
%% IOptionStyle8Choice recursion level 1 with max 1
%% IOptionType6Choice recursion level 1 with max 1
%% INumber22Choice recursion level 1 with max 1
%% GenericIdentification37 recursion level 1 with max 1
class GenericIdentification37{
    Identification IsoMax35Text
    Issuer IsoMax35Text
}
%% IPriceType4Choice recursion level 1 with max 1
%% Price7 recursion level 1 with max 1
Price7 *-- "1..1" IYieldedOrValueType1Choice : Type
Price7 *-- "1..1" IPriceRateOrAmount3Choice : Value
%% Price7 recursion level 1 with max 1
Price7 *-- "1..1" IYieldedOrValueType1Choice : Type
Price7 *-- "1..1" IPriceRateOrAmount3Choice : Value
%% Price7 recursion level 1 with max 1
Price7 *-- "1..1" IYieldedOrValueType1Choice : Type
Price7 *-- "1..1" IPriceRateOrAmount3Choice : Value
%% Price7 recursion level 1 with max 1
Price7 *-- "1..1" IYieldedOrValueType1Choice : Type
Price7 *-- "1..1" IPriceRateOrAmount3Choice : Value
%% IFinancialInstrumentQuantity1Choice recursion level 1 with max 1
%% IFinancialInstrumentQuantity1Choice recursion level 1 with max 1
%% SecurityIdentification19 recursion level 1 with max 1
class SecurityIdentification19{
    ISIN IsoISINOct2015Identifier
    Description IsoMax140Text
}
SecurityIdentification19 *-- "0..0" OtherIdentification1 : OtherIdentification
  

FinancialInstrumentAttributes91 members

Member name Description Data Type / Multiplicity
PlaceOfListing Market(s) on which the security is listed. IMarketIdentification3Choice - Optional 0..1
DayCountBasis Specifies the computation method of (accrued) interest of the security. IInterestComputationMethodFormat4Choice - Optional 0..1
RegistrationForm Specifies the form, this is, ownership, of the security. IFormOfSecurity6Choice - Optional 0..1
PaymentFrequency Specifies the frequency of an interest payment. IFrequency23Choice - Optional 0..1
PaymentStatus Status of payment of a security at a particular time. ISecuritiesPaymentStatus5Choice - Optional 0..1
VariableRateChangeFrequency Specifies the frequency of change to the variable rate of an interest bearing instrument. IFrequency23Choice - Optional 0..1
ClassificationType Classification type of the financial instrument, as per the ISO Classification of Financial Instrument (CFI) codification, for example, common share with voting rights, fully paid, or registered. IClassificationType32Choice - Optional 0..1
OptionStyle Specifies how an option can be exercised (American, European, Bermudan). IOptionStyle8Choice - Optional 0..1
OptionType Specifies whether it is a Call option (right to purchase a specific underlying asset) or a Put option (right to sell a specific underlying asset). IOptionType6Choice - Optional 0..1
DenominationCurrency Currency in which a security is issued or redenominated. ActiveOrHistoricCurrencyCode - Optional 0..1
CouponDate Next payment date of an interest bearing financial instrument. IsoISODate - Optional 0..1
ExpiryDate Date on which a privilege expires. IsoISODate - Optional 0..1
FloatingRateFixingDate Date at which the interest rate of an interest bearing security will be calculated and reset, according to the terms of the issue. IsoISODate - Optional 0..1
MaturityDate Planned final repayment date at the time of issuance. IsoISODate - Optional 0..1
IssueDate Date at which the security was made available. IsoISODate - Optional 0..1
NextCallableDate Next date at which the issuer has the right to pay the security prior to maturity. IsoISODate - Optional 0..1
PutableDate Date at which the holder has the right to ask for redemption of the security prior to final maturity. IsoISODate - Optional 0..1
DatedDate First date at which a security begins to accrue interest. IsoISODate - Optional 0..1
FirstPaymentDate Date at which the first interest payment is due to holders of the security. IsoISODate - Optional 0..1
PreviousFactor Rate expressed as a decimal between 0 and 1 that was applicable before the current factor and defines the outstanding principal of the financial instrument (for factored securities). IsoBaseOneRate - Optional 0..1
CurrentFactor Rate expressed as a decimal between 0 and 1 defining the outstanding principal of the financial instrument (for factored securities). IsoBaseOneRate - Optional 0..1
NextFactor Rate expressed as a decimal between 0 and 1 that will be applicable as of the next factor date and defines the outstanding principal of the financial instrument (for factored securities). IsoBaseOneRate - Optional 0..1
InterestRate Per annum ratio of interest paid to the principal amount of the financial instrument for a specific period of time. IsoPercentageRate - Optional 0..1
YieldToMaturityRate Rate of return anticipated on a bond when held until maturity date. IsoPercentageRate - Optional 0..1
NextInterestRate Interest rate applicable to the next interest payment period in relation to variable rate instruments. IsoPercentageRate - Optional 0..1
IndexRateBasis Specifies the reference rate for fixed income instruments where the price of the instrument is indexed to the price of an underlying benchmark.
CouponAttachedNumber Number of the coupon attached to the physical security. INumber22Choice - Optional 0..1
PoolNumber Number identifying a group of underlying assets assigned by the issuer of a factored security. GenericIdentification37 - Optional 0..1
VariableRateIndicator Indicates whether the interest rate of an interest bearing instrument is reset periodically. IsoYesNoIndicator - Optional 0..1
CallableIndicator Indicates whether the issuer has the right to pay the security prior to maturity. Also called RetractableIndicator. IsoYesNoIndicator - Optional 0..1
PutableIndicator Indicates whether the holder has the right to ask for redemption of the security prior to final maturity. Also called RedeemableIndicator. IsoYesNoIndicator - Optional 0..1
MarketOrIndicativePrice Value of the price, for example, as a currency and value per unit or as a percentage. IPriceType4Choice - Optional 0..1
ExercisePrice Predetermined price at which the holder of a derivative will buy or sell the underlying instrument. Price7 - Optional 0..1
SubscriptionPrice Pre-determined price at which the holder of a right is entitled to buy the underlying instrument. Price7 - Optional 0..1
ConversionPrice Price of one target security in the conversion. Price7 - Optional 0..1
StrikePrice Predetermined price at which the holder will have to buy or sell the underlying instrument. Price7 - Optional 0..1
MinimumNominalQuantity Minimum nominal quantity of financial instrument. IFinancialInstrumentQuantity1Choice - Optional 0..1
ContractSize Ratio or multiplying factor used to convert one contract into a quantity. IFinancialInstrumentQuantity1Choice - Optional 0..1
UnderlyingFinancialInstrumentIdentification Identification of the underlying security. SecurityIdentification19 - Unknown 0..0
FinancialInstrumentAttributeAdditionalDetails Provides additional information about the financial instrument in narrative form. IsoMax350Text - Optional 0..1

QuantityAndAccountDetails building block

Details related to the account and quantity involved in the transaction. Details on a quantity, account and other related information. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% QuantityAndAccount82 recursion level 0 with max 1
class QuantityAndAccount82{
    DenominationChoice IsoMax210Text
}
QuantityAndAccount82 *-- "1..1" IFinancialInstrumentQuantity1Choice : SettlementQuantity
QuantityAndAccount82 *-- "0..1" PartyIdentification144 : AccountOwner
QuantityAndAccount82 *-- "1..1" SecuritiesAccount19 : SafekeepingAccount
QuantityAndAccount82 *-- "0..1" ICashAccountIdentification5Choice : CashAccount
QuantityAndAccount82 *-- "0..0" QuantityBreakdown46 : QuantityBreakdown
QuantityAndAccount82 *-- "0..1" SafeKeepingPlace3 : SafekeepingPlace
%% IFinancialInstrumentQuantity1Choice recursion level 1 with max 1
%% PartyIdentification144 recursion level 1 with max 1
class PartyIdentification144{
    LEI IsoLEIIdentifier
}
PartyIdentification144 *-- "1..1" IPartyIdentification127Choice : Identification
%% SecuritiesAccount19 recursion level 1 with max 1
class SecuritiesAccount19{
    Identification IsoMax35Text
    Name IsoMax70Text
}
SecuritiesAccount19 *-- "0..1" GenericIdentification30 : Type
%% ICashAccountIdentification5Choice recursion level 1 with max 1
%% QuantityBreakdown46 recursion level 1 with max 1
QuantityBreakdown46 *-- "0..1" GenericIdentification37 : LotNumber
QuantityBreakdown46 *-- "0..1" IFinancialInstrumentQuantity1Choice : LotQuantity
QuantityBreakdown46 *-- "0..1" IDateAndDateTime2Choice : LotDateTime
QuantityBreakdown46 *-- "0..1" Price7 : LotPrice
QuantityBreakdown46 *-- "0..1" ITypeOfPrice29Choice : TypeOfPrice
%% SafeKeepingPlace3 recursion level 1 with max 1
class SafeKeepingPlace3{
    LEI IsoLEIIdentifier
}
SafeKeepingPlace3 *-- "0..1" ISafekeepingPlaceFormat29Choice : SafekeepingPlaceFormat
  

QuantityAndAccount82 members

Member name Description Data Type / Multiplicity
SettlementQuantity Total quantity of securities to be settled. IFinancialInstrumentQuantity1Choice - Required 1..1
DenominationChoice Denomination of the security to be received or delivered. IsoMax210Text - Optional 0..1
AccountOwner Party that legally owns the account. PartyIdentification144 - Optional 0..1
SafekeepingAccount Account to or from which a securities entry is made. SecuritiesAccount19 - Required 1..1
CashAccount Account to or from which a cash entry is made. ICashAccountIdentification5Choice - Optional 0..1
QuantityBreakdown Breakdown of a quantity into lots such as tax lots, instrument series. QuantityBreakdown46 - Unknown 0..0
SafekeepingPlace Place where the securities are safe-kept, physically or notionally. This place can be, for example, a local custodian, a Central Securities Depository (CSD) or an International Central Securities Depository (ICSD). SafeKeepingPlace3 - Optional 0..1

SecuritiesFinancingDetails building block

Details of the closing of the securities financing transaction. Details of the closing of the securities financing transaction. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SecuritiesFinancingTransactionDetails45 recursion level 0 with max 1
class SecuritiesFinancingTransactionDetails45{
    SecuritiesFinancingTradeIdentification IsoMax52Text
    ClosingLegIdentification IsoMax35Text
    MaturityDateModification IsoYesNoIndicator
    InterestPayment IsoYesNoIndicator
    TransactionCallDelay IsoExact3NumericText
    SecondLegNarrative IsoMax140Text
}
SecuritiesFinancingTransactionDetails45 *-- "0..1" ITerminationDate6Choice : TerminationDate
SecuritiesFinancingTransactionDetails45 *-- "0..1" IRateType35Choice : RateType
SecuritiesFinancingTransactionDetails45 *-- "0..1" ILegalFramework3Choice : LegalFramework
SecuritiesFinancingTransactionDetails45 *-- "0..1" RateName1 : VariableRateSupport
SecuritiesFinancingTransactionDetails45 *-- "0..1" Rate2 : RepurchaseRate
SecuritiesFinancingTransactionDetails45 *-- "0..1" AmountAndDirection21 : AccruedInterestAmount
SecuritiesFinancingTransactionDetails45 *-- "0..1" AmountAndDirection21 : TerminationTransactionAmount
%% ITerminationDate6Choice recursion level 1 with max 1
%% IRateType35Choice recursion level 1 with max 1
%% ILegalFramework3Choice recursion level 1 with max 1
%% RateName1 recursion level 1 with max 1
class RateName1{
    Issuer IsoMax8Text
    RateName IsoMax35Text
}
%% Rate2 recursion level 1 with max 1
class Rate2{
    Sign IsoPlusOrMinusIndicator
    Rate IsoPercentageRate
}
%% AmountAndDirection21 recursion level 1 with max 1
class AmountAndDirection21{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
%% AmountAndDirection21 recursion level 1 with max 1
class AmountAndDirection21{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
  

SecuritiesFinancingTransactionDetails45 members

Member name Description Data Type / Multiplicity
SecuritiesFinancingTradeIdentification Unambiguous identification of the underlying securities financing trade as assigned by the instructing party. The identification is common to all collateral pieces (one or many). IsoMax52Text - Optional 0..1
ClosingLegIdentification Unambiguous identification of the second leg of the transaction as known by the account owner (or the instructing party acting on its behalf). IsoMax35Text - Optional 0..1
TerminationDate Closing date/time or maturity date/time of the transaction. ITerminationDate6Choice - Optional 0..1
RateType Specifies whether the rate is fixed or variable. IRateType35Choice - Optional 0..1
LegalFramework Legal framework of the transaction. ILegalFramework3Choice - Optional 0..1
MaturityDateModification Indicates whether the maturity date of the securities financing transaction may be modified. IsoYesNoIndicator - Optional 0..1
InterestPayment Indicates whether the interest is to be paid to the collateral taker. If set to no, the interest is paid to the collateral giver. IsoYesNoIndicator - Optional 0..1
VariableRateSupport Index or support rate used together with the spread to calculate the repurchase rate. RateName1 - Optional 0..1
RepurchaseRate Rate to be used to recalculate the repurchase amount. Rate2 - Optional 0..1
TransactionCallDelay Minimum number of days’ notice a counterparty needs for terminating the transaction. IsoExact3NumericText - Optional 0..1
AccruedInterestAmount Interest amount that has accrued in between coupon payment periods. AmountAndDirection21 - Optional 0..1
TerminationTransactionAmount Total amount of money to be settled to terminate the transaction. AmountAndDirection21 - Optional 0..1
SecondLegNarrative Provides additional information about the second leg in narrative form. IsoMax140Text - Optional 0..1

SettlementParameters building block

Parameters which explicitly state the conditions that must be fulfilled before a particular transaction of a financial instrument can be settled. These parameters are defined by the instructing party in compliance with settlement rules in the market the transaction will settle in. Details of settlement of a transaction. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SettlementDetails187 recursion level 0 with max 1
class SettlementDetails187{
    HoldIndicator IsoYesNoIndicator
    PartialSettlementIndicator SettlementTransactionCondition5Code
}
SettlementDetails187 *-- "1..1" ISecuritiesTransactionType45Choice : SecuritiesTransactionType
SettlementDetails187 *-- "0..0" ISettlementTransactionCondition35Choice : SettlementTransactionCondition
SettlementDetails187 *-- "0..1" IBeneficialOwnership4Choice : BeneficialOwnership
SettlementDetails187 *-- "0..1" ICashSettlementSystem4Choice : CashClearingSystem
SettlementDetails187 *-- "0..1" IMarketClientSide6Choice : MarketClientSide
SettlementDetails187 *-- "0..1" IRegistration9Choice : Registration
SettlementDetails187 *-- "0..1" IRepurchaseType13Choice : RepurchaseType
SettlementDetails187 *-- "0..1" ISecuritiesRTGS4Choice : SecuritiesRTGS
SettlementDetails187 *-- "0..1" GenericIdentification30 : StampDutyTaxBasis
%% ISecuritiesTransactionType45Choice recursion level 1 with max 1
%% ISettlementTransactionCondition35Choice recursion level 1 with max 1
%% IBeneficialOwnership4Choice recursion level 1 with max 1
%% ICashSettlementSystem4Choice recursion level 1 with max 1
%% IMarketClientSide6Choice recursion level 1 with max 1
%% IRegistration9Choice recursion level 1 with max 1
%% IRepurchaseType13Choice recursion level 1 with max 1
%% ISecuritiesRTGS4Choice recursion level 1 with max 1
%% GenericIdentification30 recursion level 1 with max 1
class GenericIdentification30{
    Identification IsoExact4AlphaNumericText
    Issuer IsoMax35Text
    SchemeName IsoMax35Text
}
  

SettlementDetails187 members

Member name Description Data Type / Multiplicity
HoldIndicator Indicates whether the transaction is on hold/blocked/frozen. IsoYesNoIndicator - Optional 0..1
SecuritiesTransactionType Identifies the type of securities transaction. ISecuritiesTransactionType45Choice - Required 1..1
SettlementTransactionCondition Conditions under which the order/trade is to be settled. ISettlementTransactionCondition35Choice - Unknown 0..0
PartialSettlementIndicator Specifies whether partial settlement is allowed. SettlementTransactionCondition5Code - Optional 0..1
BeneficialOwnership Specifies whether there is change of beneficial ownership. IBeneficialOwnership4Choice - Optional 0..1
CashClearingSystem Specifies the category of cash clearing system, for example, cheque clearing. ICashSettlementSystem4Choice - Optional 0..1
MarketClientSide Specifies if an instruction is for a market side or a client side transaction. IMarketClientSide6Choice - Optional 0..1
Registration Specifies whether registration should occur upon receipt. IRegistration9Choice - Optional 0..1
RepurchaseType Specifies whether the rate is fixed, variable or a forfeit. IRepurchaseType13Choice - Optional 0..1
SecuritiesRTGS Specifies whether the settlement transaction is to be settled through an RTGS or a non RTGS system. ISecuritiesRTGS4Choice - Optional 0..1
StampDutyTaxBasis Specifies the stamp duty type or exemption reason applicable to the settlement transaction. GenericIdentification30 - Optional 0..1

DeliveringSettlementParties building block

Identifies the chain of delivering settlement parties. Chain of parties involved in the settlement of a transaction, including receipts and deliveries, book transfers, treasury deals, or other activities, resulting in the movement of a security or amount of money from one account to another. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SettlementParties76 recursion level 0 with max 1
SettlementParties76 *-- "0..1" PartyIdentification146 : Depository
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party1
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party2
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party3
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party4
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party5
%% PartyIdentification146 recursion level 1 with max 1
class PartyIdentification146{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentification146 *-- "1..1" IPartyIdentification122Choice : Identification
PartyIdentification146 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentification146 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentification146 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
  

SettlementParties76 members

Member name Description Data Type / Multiplicity
Depository First party in the settlement chain. In a plain vanilla settlement, it is the Central Securities Depository where the counterparty requests to receive the financial instrument or from where the counterparty delivers the financial instruments. PartyIdentification146 - Optional 0..1
Party1 Party that, in a settlement chain interacts with the depository. PartyIdentificationAndAccount168 - Optional 0..1
Party2 Party that, in a settlement chain interacts with the party 1. PartyIdentificationAndAccount168 - Optional 0..1
Party3 Party that, in a settlement chain interacts with the party 2. PartyIdentificationAndAccount168 - Optional 0..1
Party4 Party that, in a settlement chain interacts with the party 3. PartyIdentificationAndAccount168 - Optional 0..1
Party5 Party that, in a settlement chain interacts with the party 4. PartyIdentificationAndAccount168 - Optional 0..1

ReceivingSettlementParties building block

Identifies the chain of receiving settlement parties. Chain of parties involved in the settlement of a transaction, including receipts and deliveries, book transfers, treasury deals, or other activities, resulting in the movement of a security or amount of money from one account to another. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% SettlementParties76 recursion level 0 with max 1
SettlementParties76 *-- "0..1" PartyIdentification146 : Depository
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party1
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party2
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party3
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party4
SettlementParties76 *-- "0..1" PartyIdentificationAndAccount168 : Party5
%% PartyIdentification146 recursion level 1 with max 1
class PartyIdentification146{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentification146 *-- "1..1" IPartyIdentification122Choice : Identification
PartyIdentification146 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentification146 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentification146 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
%% PartyIdentificationAndAccount168 recursion level 1 with max 1
class PartyIdentificationAndAccount168{
    LEI IsoLEIIdentifier
    ProcessingIdentification IsoMax35Text
}
PartyIdentificationAndAccount168 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount168 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount168 *-- "0..1" SecuritiesAccount19 : SafekeepingAccount
PartyIdentificationAndAccount168 *-- "0..1" IDateAndDateTime2Choice : ProcessingDate
PartyIdentificationAndAccount168 *-- "0..1" PartyTextInformation1 : AdditionalInformation
  

SettlementParties76 members

Member name Description Data Type / Multiplicity
Depository First party in the settlement chain. In a plain vanilla settlement, it is the Central Securities Depository where the counterparty requests to receive the financial instrument or from where the counterparty delivers the financial instruments. PartyIdentification146 - Optional 0..1
Party1 Party that, in a settlement chain interacts with the depository. PartyIdentificationAndAccount168 - Optional 0..1
Party2 Party that, in a settlement chain interacts with the party 1. PartyIdentificationAndAccount168 - Optional 0..1
Party3 Party that, in a settlement chain interacts with the party 2. PartyIdentificationAndAccount168 - Optional 0..1
Party4 Party that, in a settlement chain interacts with the party 3. PartyIdentificationAndAccount168 - Optional 0..1
Party5 Party that, in a settlement chain interacts with the party 4. PartyIdentificationAndAccount168 - Optional 0..1

CashParties building block

Specifies cash parties in the framework of a corporate action event. Payment processes required to transfer cash from the debtor to the creditor. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% CashParties35 recursion level 0 with max 1
CashParties35 *-- "0..1" PartyIdentificationAndAccount164 : Debtor
CashParties35 *-- "0..1" PartyIdentificationAndAccount171 : DebtorAgent
CashParties35 *-- "0..1" PartyIdentificationAndAccount164 : Creditor
CashParties35 *-- "0..1" PartyIdentificationAndAccount171 : CreditorAgent
%% PartyIdentificationAndAccount164 recursion level 1 with max 1
class PartyIdentificationAndAccount164{
    LEI IsoLEIIdentifier
}
PartyIdentificationAndAccount164 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount164 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : CashAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : ChargesAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : CommissionAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : TaxAccount
PartyIdentificationAndAccount164 *-- "0..1" PartyTextInformation2 : AdditionalInformation
%% PartyIdentificationAndAccount171 recursion level 1 with max 1
class PartyIdentificationAndAccount171{
    LEI IsoLEIIdentifier
}
PartyIdentificationAndAccount171 *-- "1..1" IPartyIdentification133Choice : Identification
PartyIdentificationAndAccount171 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : CashAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : ChargesAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : CommissionAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : TaxAccount
PartyIdentificationAndAccount171 *-- "0..1" PartyTextInformation2 : AdditionalInformation
%% PartyIdentificationAndAccount164 recursion level 1 with max 1
class PartyIdentificationAndAccount164{
    LEI IsoLEIIdentifier
}
PartyIdentificationAndAccount164 *-- "1..1" IPartyIdentification120Choice : Identification
PartyIdentificationAndAccount164 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : CashAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : ChargesAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : CommissionAccount
PartyIdentificationAndAccount164 *-- "0..1" ICashAccountIdentification5Choice : TaxAccount
PartyIdentificationAndAccount164 *-- "0..1" PartyTextInformation2 : AdditionalInformation
%% PartyIdentificationAndAccount171 recursion level 1 with max 1
class PartyIdentificationAndAccount171{
    LEI IsoLEIIdentifier
}
PartyIdentificationAndAccount171 *-- "1..1" IPartyIdentification133Choice : Identification
PartyIdentificationAndAccount171 *-- "0..1" AlternatePartyIdentification7 : AlternateIdentification
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : CashAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : ChargesAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : CommissionAccount
PartyIdentificationAndAccount171 *-- "0..1" ICashAccountIdentification5Choice : TaxAccount
PartyIdentificationAndAccount171 *-- "0..1" PartyTextInformation2 : AdditionalInformation
  

CashParties35 members

Member name Description Data Type / Multiplicity
Debtor Party that owes an amount of money to the (ultimate) creditor. PartyIdentificationAndAccount164 - Optional 0..1
DebtorAgent Financial institution servicing an account for the debtor. PartyIdentificationAndAccount171 - Optional 0..1
Creditor Party to which an amount of money is due. PartyIdentificationAndAccount164 - Optional 0..1
CreditorAgent Financial institution servicing an account for the creditor. PartyIdentificationAndAccount171 - Optional 0..1

SettlementAmount building block

Total amount of money to be paid or received in exchange for the securities. Posting of an item to a cash account, in the context of a cash transaction, that results in an increase or decrease to the balance of the account. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% AmountAndDirection88 recursion level 0 with max 1
class AmountAndDirection88{
    Amount IsoActiveCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
    OriginalCurrencyAndOrderedAmount IsoActiveOrHistoricCurrencyAndAmount
}
AmountAndDirection88 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
AmountAndDirection88 *-- "0..1" IDateAndDateTime2Choice : ValueDate
%% ForeignExchangeTerms23 recursion level 1 with max 1
class ForeignExchangeTerms23{
    UnitCurrency ActiveCurrencyCode
    QuotedCurrency ActiveCurrencyCode
    ExchangeRate IsoBaseOneRate
    ResultingAmount IsoActiveCurrencyAndAmount
}
%% IDateAndDateTime2Choice recursion level 1 with max 1
  

AmountAndDirection88 members

Member name Description Data Type / Multiplicity
Amount Amount of money in the cash entry. IsoActiveCurrencyAndAmount - Required 1..1
CreditDebitIndicator Indicates whether an entry is a credit or a debit. CreditDebitCode - Required 1..1
OriginalCurrencyAndOrderedAmount Posting/settlement amount in its original currency when conversion from/into another currency has occurred. IsoActiveOrHistoricCurrencyAndAmount - Optional 0..1
ForeignExchangeDetails Information needed to process a currency exchange or conversion. ForeignExchangeTerms23 - Optional 0..1
ValueDate Date and time at which the cash is at the disposal of the credit account owner, or ceases to be at the disposal of the debit account owner. IDateAndDateTime2Choice - Optional 0..1

OtherAmounts building block

Other amounts than the settlement amount. Identifies other amounts pertaining to the transaction. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% OtherAmounts32 recursion level 0 with max 1
OtherAmounts32 *-- "0..1" AmountAndDirection47 : AccruedInterestAmount
OtherAmounts32 *-- "0..1" AmountAndDirection47 : ChargesFees
OtherAmounts32 *-- "0..1" AmountAndDirection47 : TradeAmount
OtherAmounts32 *-- "0..1" AmountAndDirection47 : ExecutingBrokerAmount
OtherAmounts32 *-- "0..1" AmountAndDirection47 : LocalTax
OtherAmounts32 *-- "0..1" AmountAndDirection47 : LocalBrokerCommission
OtherAmounts32 *-- "0..1" AmountAndDirection47 : Other
OtherAmounts32 *-- "0..1" AmountAndDirection47 : StampDuty
OtherAmounts32 *-- "0..1" AmountAndDirection47 : TransactionTax
OtherAmounts32 *-- "0..1" AmountAndDirection47 : WithholdingTax
OtherAmounts32 *-- "0..1" AmountAndDirection47 : ConsumptionTax
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
%% AmountAndDirection47 recursion level 1 with max 1
class AmountAndDirection47{
    Amount IsoActiveOrHistoricCurrencyAndAmount
    CreditDebitIndicator CreditDebitCode
}
AmountAndDirection47 *-- "0..1" ForeignExchangeTerms23 : ForeignExchangeDetails
  

OtherAmounts32 members

Member name Description Data Type / Multiplicity
AccruedInterestAmount Interest amount that has accrued in between coupon payment periods. AmountAndDirection47 - Optional 0..1
ChargesFees Amount of money paid for the provision of financial services that cannot be categorised by another qualifier. AmountAndDirection47 - Optional 0..1
TradeAmount Principal amount of a trade (price multiplied by quantity). AmountAndDirection47 - Optional 0..1
ExecutingBrokerAmount Amount of money paid to an executing broker as a commission. AmountAndDirection47 - Optional 0..1
LocalTax Tax charged by the jurisdiction in which the financial instrument settles. AmountAndDirection47 - Optional 0..1
LocalBrokerCommission Amount of commission paid to a local broker. AmountAndDirection47 - Optional 0..1
Other An amount that is not indicated by a known business denomination. AmountAndDirection47 - Optional 0..1
StampDuty Amount of stamp duty. AmountAndDirection47 - Optional 0..1
TransactionTax Amount of transaction tax. AmountAndDirection47 - Optional 0..1
WithholdingTax Amount of money that will be withheld by a tax authority. AmountAndDirection47 - Optional 0..1
ConsumptionTax Amount of consumption tax. AmountAndDirection47 - Optional 0..1

OtherBusinessParties building block

Other business parties relevant to the transaction. Identification of other parties. For comparison, see the ISO20022 official specification

classDiagram
   direction tb
%% OtherParties34 recursion level 0 with max 1
OtherParties34 *-- "0..1" PartyIdentification149 : Investor
OtherParties34 *-- "0..1" PartyIdentification136 : QualifiedForeignIntermediary
OtherParties34 *-- "0..1" PartyIdentification136 : StockExchange
OtherParties34 *-- "0..1" PartyIdentification136 : TradeRegulator
OtherParties34 *-- "0..1" PartyIdentification136 : TripartyAgent
%% PartyIdentification149 recursion level 1 with max 1
class PartyIdentification149{
    LEI IsoLEIIdentifier
}
PartyIdentification149 *-- "1..1" IPartyIdentification134Choice : Identification
%% PartyIdentification136 recursion level 1 with max 1
class PartyIdentification136{
    LEI IsoLEIIdentifier
}
PartyIdentification136 *-- "1..1" IPartyIdentification120Choice : Identification
%% PartyIdentification136 recursion level 1 with max 1
class PartyIdentification136{
    LEI IsoLEIIdentifier
}
PartyIdentification136 *-- "1..1" IPartyIdentification120Choice : Identification
%% PartyIdentification136 recursion level 1 with max 1
class PartyIdentification136{
    LEI IsoLEIIdentifier
}
PartyIdentification136 *-- "1..1" IPartyIdentification120Choice : Identification
%% PartyIdentification136 recursion level 1 with max 1
class PartyIdentification136{
    LEI IsoLEIIdentifier
}
PartyIdentification136 *-- "1..1" IPartyIdentification120Choice : Identification
  

OtherParties34 members

Member name Description Data Type / Multiplicity
Investor Party, either an individual or organisation, whose assets are being invested. PartyIdentification149 - Optional 0..1
QualifiedForeignIntermediary Foreign financial institution which has been authorised by local authorities to act as account management institution in the country. PartyIdentification136 - Optional 0..1
StockExchange Identification of the stock exchange to which transaction reporting will be done. PartyIdentification136 - Optional 0..1
TradeRegulator Institution to which a trade must be reported. PartyIdentification136 - Optional 0..1
TripartyAgent Party responsible for the administration of a tri-party collateral transaction including collateral allocation, marking to market and substitution of collateral. PartyIdentification136 - Optional 0..1

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 SecuritiesSettlementTransactionAllegementNotificationV09 implementation follows a specific implementaiton pattern. First of all, SecuritiesSettlementTransactionAllegementNotificationV09 impleemnts IOuterRecord indicating it is the outermost logical part of the message definition. Like all message wrappers, SecuritiesSettlementTransactionAllegementNotificationV09Document implements IOuterDocument. Because SecuritiesSettlementTransactionAllegementNotificationV09 implements IOuterDocument, it is a suitable template parameter for IOuterDocument, and causes the internal ‘Message’ to be of type SecuritiesSettlementTransactionAllegementNotificationV09.

classDiagram
    class IOuterRecord
    SecuritiesSettlementTransactionAllegementNotificationV09 --|> IOuterRecord : Implements
    SecuritiesSettlementTransactionAllegementNotificationV09Document --|> IOuterDocument~SecuritiesSettlementTransactionAllegementNotificationV09~ : Implements
    class IOuterDocument~SecuritiesSettlementTransactionAllegementNotificationV09~ {
        SecuritiesSettlementTransactionAllegementNotificationV09 Message
     }
  

Document wrapper for serialization

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

classDiagram
    SecuritiesSettlementTransactionAllegementNotificationV09Document *-- SecuritiesSettlementTransactionAllegementNotificationV09 : 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:sese.028.001.09">
    <SctiesSttlmTxAllgmtNtfctn>
        <TxId>
            <!-- TransactionIdentification inner content -->
        </TxId>
        <SttlmTpAndAddtlParams>
            <!-- SettlementTypeAndAdditionalParameters inner content -->
        </SttlmTpAndAddtlParams>
        <MktInfrstrctrTxId>
            <!-- MarketInfrastructureTransactionIdentification inner content -->
        </MktInfrstrctrTxId>
        <TradDtls>
            <!-- TradeDetails inner content -->
        </TradDtls>
        <FinInstrmId>
            <!-- FinancialInstrumentIdentification inner content -->
        </FinInstrmId>
        <FinInstrmAttrbts>
            <!-- FinancialInstrumentAttributes inner content -->
        </FinInstrmAttrbts>
        <QtyAndAcctDtls>
            <!-- QuantityAndAccountDetails inner content -->
        </QtyAndAcctDtls>
        <SctiesFincgDtls>
            <!-- SecuritiesFinancingDetails inner content -->
        </SctiesFincgDtls>
        <SttlmParams>
            <!-- SettlementParameters inner content -->
        </SttlmParams>
        <DlvrgSttlmPties>
            <!-- DeliveringSettlementParties inner content -->
        </DlvrgSttlmPties>
        <RcvgSttlmPties>
            <!-- ReceivingSettlementParties inner content -->
        </RcvgSttlmPties>
        <CshPties>
            <!-- CashParties inner content -->
        </CshPties>
        <SttlmAmt>
            <!-- SettlementAmount inner content -->
        </SttlmAmt>
        <OthrAmts>
            <!-- OtherAmounts inner content -->
        </OthrAmts>
        <OthrBizPties>
            <!-- OtherBusinessParties inner content -->
        </OthrBizPties>
        <SplmtryData>
            <!-- SupplementaryData inner content -->
        </SplmtryData>
    </SctiesSttlmTxAllgmtNtfctn>
</Document>

Data from ISO specification

This is the technical data from the specification document.

<messageDefinition
  xmi:id="_rbOIwQzPEeuTPv2wqaotHg"
  nextVersions="_Kr5RMSgWEeym1_Zp1BTvEw"
  previousVersion="_rKSA4dBgEeihG9bKfarOOA"
  name="SecuritiesSettlementTransactionAllegementNotificationV09"
  definition="Scope&#xD;&#xA;An account servicer sends a SecuritiesSettlementTransactionAllegementNotification to an account owner to advise the account owner that a counterparty has alleged an instruction against the account owner's account at the account servicer and that the account servicer could not find the corresponding instruction of the account owner.&#xD;&#xA;The account servicer/owner relationship may be:&#xD;&#xA;- a central securities depository or another settlement market infrastructure acting on behalf of their participants&#xD;&#xA;- an agent (sub-custodian) acting on behalf of their global custodian customer, or&#xD;&#xA;- a custodian acting on behalf of an investment management institution or a broker/dealer.&#xD;&#xA;&#xD;&#xA;Usage&#xD;&#xA;The message may also be used to:&#xD;&#xA;- re-send a message previously sent,&#xD;&#xA;- provide a third party with a copy of a message for information,&#xD;&#xA;- re-send to a third party a copy of a message for information using the relevant elements in the Business Application Header."
  registrationStatus="Registered"
  messageSet="_JB4xh_8rEeCQ-IWv9MUPeQ"
  xmlTag="SctiesSttlmTxAllgmtNtfctn"
  rootElement="Document"
  xmlns:xmi="http://www.omg.org/XMI">
  <constraint
    xmi:id="_rbOIwwzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RMygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA49BgEeihG9bKfarOOA"
    name="SettlementAmountRule"
    definition="If the instruction is against payment, then SettlementAmount must be present."
    registrationStatus="Provisionally Registered"
    expression="&lt;RuleDefinition xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&gt;&lt;ComplexRule xsi:type=&quot;ComplexRule&quot;&gt;&lt;mustBe&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;Presence&quot;&gt;&lt;leftOperand&gt;/SettlementAmount&lt;/leftOperand&gt;&lt;/BooleanRule&gt;&lt;/mustBe&gt;&lt;onCondition&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;EqualToValue&quot;&gt;&lt;leftOperand&gt;/SettlementTypeAndAdditionalParameters/Payment&lt;/leftOperand&gt;&lt;rightOperand&gt;AgainstPaymentSettlement&lt;/rightOperand&gt;&lt;/BooleanRule&gt;&lt;/onCondition&gt;&lt;/ComplexRule&gt;&lt;/RuleDefinition&gt;&#xA;" />
  <constraint
    xmi:id="_rbOIxQzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RNSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA5dBgEeihG9bKfarOOA"
    name="ReceivingParty1Rule"
    definition="If the instruction is a delivery, then ReceivingParty 1 must be present."
    registrationStatus="Provisionally Registered"
    expression="&lt;RuleDefinition xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&gt;&lt;ComplexRule xsi:type=&quot;ComplexRule&quot;&gt;&lt;mustBe&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;Presence&quot;&gt;&lt;leftOperand&gt;/ReceivingSettlementParties&lt;/leftOperand&gt;&lt;/BooleanRule&gt;&lt;BooleanRule xsi:type=&quot;Presence&quot;&gt;&lt;leftOperand&gt;/ReceivingSettlementParties/Party1&lt;/leftOperand&gt;&lt;/BooleanRule&gt;&lt;/mustBe&gt;&lt;onCondition&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;EqualToValue&quot;&gt;&lt;leftOperand&gt;/SettlementTypeAndAdditionalParameters/SecuritiesMovementType&lt;/leftOperand&gt;&lt;rightOperand&gt;Delivery&lt;/rightOperand&gt;&lt;/BooleanRule&gt;&lt;/onCondition&gt;&lt;/ComplexRule&gt;&lt;/RuleDefinition&gt;&#xA;" />
  <constraint
    xmi:id="_rbOIxwzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RNygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA59BgEeihG9bKfarOOA"
    name="DeliveringParty1Rule"
    definition="If the instruction is a receive, then DeliveringParty1 must be present."
    registrationStatus="Provisionally Registered"
    expression="&lt;RuleDefinition xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&gt;&lt;ComplexRule xsi:type=&quot;ComplexRule&quot;&gt;&lt;mustBe&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;Presence&quot;&gt;&lt;leftOperand&gt;/DeliveringSettlementParties&lt;/leftOperand&gt;&lt;/BooleanRule&gt;&lt;BooleanRule xsi:type=&quot;Presence&quot;&gt;&lt;leftOperand&gt;/DeliveringSettlementParties/Party1&lt;/leftOperand&gt;&lt;/BooleanRule&gt;&lt;/mustBe&gt;&lt;onCondition&gt;&lt;connector&gt;AND&lt;/connector&gt;&lt;BooleanRule xsi:type=&quot;EqualToValue&quot;&gt;&lt;leftOperand&gt;/SettlementTypeAndAdditionalParameters/SecuritiesMovementType&lt;/leftOperand&gt;&lt;rightOperand&gt;Receive&lt;/rightOperand&gt;&lt;/BooleanRule&gt;&lt;/onCondition&gt;&lt;/ComplexRule&gt;&lt;/RuleDefinition&gt;&#xA;" />
  <constraint
    xmi:id="_rbOIyQzPEeuTPv2wqaotHg"
    nextVersions="_Kr5ROSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA6dBgEeihG9bKfarOOA"
    name="SecuritiesMarketPracticeGroupGuideline"
    definition="The Securities Market Practice Group (SMPG) has published market practice recommendations on the use of this message.&#xD;&#xA;These market practices are available on www.smpg.info."
    registrationStatus="Provisionally Registered" />
  <constraint
    xmi:id="_rbOIywzPEeuTPv2wqaotHg"
    nextVersions="_Kr5ROygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA69BgEeihG9bKfarOOA"
    name="TwoLegTransactionOpeningClosing1Rule"
    definition="For settlement of two part transactions (Securities Financing), the opening/initiation and closing/return of the transaction is confirmed by sending the following combination of TransactionIdentificationDetails/SecuritiesMovementType codes and SettlementParameters/SecuritiesTransactionType codes:&#xD;&#xA;&#xD;&#xA;Repo Opening&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: Repo (REPU)&#xD;&#xA;Repo Closing&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: Repo (REPU)&#xD;&#xA;&#xD;&#xA;Reverse Repo Opening&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: ReverseRepo (RVPO)&#xD;&#xA;Reverse Repo Closing&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI) &#xD;&#xA;SettlementParameters/SecuritiesTransactionType: ReverseRepo (RVPO)&#xD;&#xA;&#xD;&#xA;TriParty Repo Opening&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: TriPartyRepo (TRPO)&#xD;&#xA;TriParty Repo Closing&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: TriPartyRepo (TRPO)&#xD;&#xA;&#xD;&#xA;TriParty Reverse Repo Opening&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: TriPartyReverseRepo (TRVO)&#xD;&#xA;TriParty Reverse Repo Closing&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI) &#xD;&#xA;SettlementParameters/SecuritiesTransactionType: TriPartyReverseRepo (TRVO)&#xD;&#xA;&#xD;&#xA;Securities Lending Initiation&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SecuritiesLending (SECL)&#xD;&#xA;Securities Lending Return&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SecuritiesLending (SECL)&#xD;&#xA;&#xD;&#xA;Securities Borrowing Initiation&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SecuritiesBorrowing (SECB)&#xD;&#xA;Securities Borrowing Return&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI) &#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SecuritiesBorrowing (SECB)."
    registrationStatus="Provisionally Registered" />
  <constraint
    xmi:id="_rbOIzQzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RPSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA7dBgEeihG9bKfarOOA"
    name="TwoLegTransactionOpeningClosing2Rule"
    definition="For settlement of two part transactions (buy-sell back, sell buy-back, collateral in and out), the opening/initiation and closing/return of the transaction is alleged by sending the following combination of SettlementTypeAndAdditionalParameters/SecuritiesMovementType codes and SettlementParameters/SecuritiesTransactionType codes:&#xD;&#xA;&#xD;&#xA;Sell-Buy Back: Sell&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SellBuyBack (SBBK)&#xD;&#xA;Sell-Buy Back: Buy Back&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: SellBuyBack (SBBK)&#xD;&#xA;&#xD;&#xA;Buy-Sell Back: Buy&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: BuySellBack (BSBK)&#xD;&#xA;Buy-Sell Back: Sell Back&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI) &#xD;&#xA;SettlementParameters/SecuritiesTransactionType: BuySellBack (BSBK)&#xD;&#xA;&#xD;&#xA;Collateral (giver) Out Initiation&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: CollateralOut (COLO)&#xD;&#xA;Collateral (giver) Out Return&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: CollateralOut (COLO)&#xD;&#xA;&#xD;&#xA;Collateral (taker) In Initiation&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Receive (RECE)&#xD;&#xA;SettlementParameters/SecuritiesTransactionType: CollateralIn (COLI)&#xD;&#xA;Collateral (taker) In Return&#xD;&#xA;SettlementTypeAndAdditionalParameters/SecuritiesMovementType: Delivery (DELI) &#xD;&#xA;SettlementParameters/SecuritiesTransactionType: CollateralIn (COLI)."
    registrationStatus="Provisionally Registered" />
  <messageBuildingBlock
    xmi:id="_rbOI1QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RSygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA79BgEeihG9bKfarOOA"
    name="TransactionIdentification"
    definition="Unambiguous identification of the transaction as known by the instructing party."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="TxId"
    simpleType="_YW1tKdp-Ed-ak6NoX_4Aeg_1913463446" />
  <messageBuildingBlock
    xmi:id="_rbOI1wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RTSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA8dBgEeihG9bKfarOOA"
    name="SettlementTypeAndAdditionalParameters"
    definition="Provides settlement type and identification information."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="SttlmTpAndAddtlParams"
    complexType="_mXKRcTtrEeWHYdqXF6YZmg" />
  <messageBuildingBlock
    xmi:id="_rbOI2QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RTygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA89BgEeihG9bKfarOOA"
    name="MarketInfrastructureTransactionIdentification"
    definition="Identification of a transaction assigned by a market infrastructure other than a central securities depository, for example, Target2-Securities."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="MktInfrstrctrTxId"
    complexType="_jXzlYu5NEeCisYr99QEiWA_-2122254183" />
  <messageBuildingBlock
    xmi:id="_rbOI2wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RUSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA9dBgEeihG9bKfarOOA"
    name="TradeDetails"
    definition="Details of the trade."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="TradDtls"
    complexType="_zA0BIQzPEeuTPv2wqaotHg" />
  <messageBuildingBlock
    xmi:id="_rbOI3QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RUygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA99BgEeihG9bKfarOOA"
    name="FinancialInstrumentIdentification"
    definition="Financial instrument representing a sum of rights of the investor vis-a-vis the issuer."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="FinInstrmId"
    complexType="_ho6XQYlXEeWPSZi0kAOXhg" />
  <messageBuildingBlock
    xmi:id="_rbOI3wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RVSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA-dBgEeihG9bKfarOOA"
    name="FinancialInstrumentAttributes"
    definition="Elements characterising a financial instrument."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="FinInstrmAttrbts"
    complexType="_yehJZbQBEee1Ke-6rZgsrA" />
  <messageBuildingBlock
    xmi:id="_rbOI4QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RVygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA-9BgEeihG9bKfarOOA"
    name="QuantityAndAccountDetails"
    definition="Details related to the account and quantity involved in the transaction."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="QtyAndAcctDtls"
    complexType="_aBAwr9LCEeiN28wlpBQScw" />
  <messageBuildingBlock
    xmi:id="_rbOI4wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RWSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSA_dBgEeihG9bKfarOOA"
    name="SecuritiesFinancingDetails"
    definition="Details of the closing of the securities financing transaction."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="SctiesFincgDtls"
    complexType="_Jl3mUdBxEeihG9bKfarOOA" />
  <messageBuildingBlock
    xmi:id="_rbOI5QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RWygWEeym1_Zp1BTvEw"
    previousVersion="_rKSA_9BgEeihG9bKfarOOA"
    name="SettlementParameters"
    definition="Parameters which explicitly state the conditions that must be fulfilled before a particular transaction of a financial instrument can be settled. These parameters are defined by the instructing party in compliance with settlement rules in the market the transaction will settle in."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="1"
    xmlTag="SttlmParams"
    complexType="_wAVV4QzTEeuTPv2wqaotHg" />
  <messageBuildingBlock
    xmi:id="_rbOI5wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RXSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSBAdBgEeihG9bKfarOOA"
    name="DeliveringSettlementParties"
    definition="Identifies the chain of delivering settlement parties."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="DlvrgSttlmPties"
    complexType="_7HPx59LCEeiN28wlpBQScw" />
  <messageBuildingBlock
    xmi:id="_rbOI6QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RXygWEeym1_Zp1BTvEw"
    previousVersion="_rKSBA9BgEeihG9bKfarOOA"
    name="ReceivingSettlementParties"
    definition="Identifies the chain of receiving settlement parties."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="RcvgSttlmPties"
    complexType="_7HPx59LCEeiN28wlpBQScw" />
  <messageBuildingBlock
    xmi:id="_rbOI6wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RYSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSBBdBgEeihG9bKfarOOA"
    name="CashParties"
    definition="Specifies cash parties in the framework of a corporate action event."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="CshPties"
    complexType="_5Pe-0dLCEeiN28wlpBQScw" />
  <messageBuildingBlock
    xmi:id="_rbOI7QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RYygWEeym1_Zp1BTvEw"
    previousVersion="_rKSBB9BgEeihG9bKfarOOA"
    name="SettlementAmount"
    definition="Total amount of money to be paid or received in exchange for the securities."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="SttlmAmt"
    complexType="_4r9oQbPvEeelzbgsFa3sqQ" />
  <messageBuildingBlock
    xmi:id="_rbOI7wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RZSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSBCdBgEeihG9bKfarOOA"
    name="OtherAmounts"
    definition="Other amounts than the settlement amount."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="OthrAmts"
    complexType="_-4p5Azp8EeWVrPy0StzzSg" />
  <messageBuildingBlock
    xmi:id="_rbOI8QzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RZygWEeym1_Zp1BTvEw"
    previousVersion="_rKSBC9BgEeihG9bKfarOOA"
    name="OtherBusinessParties"
    definition="Other business parties relevant to the transaction."
    registrationStatus="Provisionally Registered"
    maxOccurs="1"
    minOccurs="0"
    xmlTag="OthrBizPties"
    complexType="__eyZsdLCEeiN28wlpBQScw" />
  <messageBuildingBlock
    xmi:id="_rbOI8wzPEeuTPv2wqaotHg"
    nextVersions="_Kr5RaSgWEeym1_Zp1BTvEw"
    previousVersion="_rKSBDdBgEeihG9bKfarOOA"
    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="sese"
    messageFunctionality="028"
    flavour="001"
    version="09" />
</messageDefinition>

ISO Building Blocks

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