Open chrisisla opened 3 hours ago
The design will be presented at the TAWG meeting on November 14th (details of the meeting can be found here: #3212).
The community will then have 3 weeks to review the design and pose any questions or comments that they may have. The expectation is that objections, if any, should be concrete, material and include alternative approaches so that a final review can address the pros and cons.
At the following meeting of the TAWG on December 5th any outstanding questions on the design will be answered, with a view to the final design being accepted at that meeting.
Background
To meet its promise of interoperability, CDM requires a defined standard for the exchange of information. Unfortunately, after a detailed analysis, the community determined that the current JSON format had gaps that prevented it from becoming that standard. In November 2023, the SWG approved recommendations made by a TAWG task force for a phased approach to changes to the data standard.
As part of its commitment to promoting the CDM as a standard, ISLA is funding the first phase of this work, working in conjunction with CLOUDRISK, FT Advisory, ISDA and REGnosys. The following provides an overview of the plan for the changes.
The high level goals for this phase of the Serialization project were to focus on:
The design, once accepted by the community, will move into development with a targeted release of CDM version 6.
Principles
When evaluating serialization design alternatives the followed ordered list of principles served as reference:
Some may not be absolute and the final design may have had to make compromises on the extent to which it meets the principles.
Proposal
The CDM object serialization will be enhanced to now include the following new special attributes.
@model
"@model": "cdm"
@version
"@version": "1.2.3"
@type
"@type": "cdm.event.common.TradeState"
@data
"@data": "54930084UKLVMY22DS16"
value
annotation@key
"@key": "abcd1234"
globalKey
metadata annotation@ref
"@ref": "abcd1234"
globalReference
metadata annotation@key:external
"@key:external": "my-external-key"
externalKey
metadata annotation@ref:external
"@ref:external": "my-external-key"
externalReference
metadata annotation@key:scoped
"@key:scoped": "my-scoped-key"
scope
andlocation
annotations@ref:scoped
"@ref:scoped": "my-scoped-key"
scope
andaddress
annotations@scheme
"@scheme": "http://www.fpml.org/coding-scheme/external/iso17442"
scheme
metadata annotationWhen serializing:
When deserializing:
In summary the new serialized format:
For more details of the proposed structure and processing please refer to the full design document available here: Serialization Specification v0.9.pdf
Feedback
If you have any questions on the design then please add them as new comments to this issue.