...
Key Principles
Principle | Decision / Discussion |
---|
Scope is Portfolio |
|
Benchmark Data |
|
colour | Green |
---|---|
title | SPECIFIED |
Models & Figures |
|
|
|
Status | ||||
---|---|---|---|---|
|
| |
Aggregation of instruments / segments |
|
Interface "PortfolioRiskExPost"
...
Status colour Green title Implemented
Usage & contents
used to produce PO006, PO006C, CO001, RA001..RA003
Ex-post portfolio level risk figures for multiple periods.
The risk figures will only be delivered on a monthly basis, so calls for a reportingDate within a month will typically deliver risk figures for periods ending at the ultimo of the previous month.
Path
/portfolio/riskexpost
Parameters
portfolioId
string
The id of the portfolio (or consolidation) in the data source
reportingDate
string (date)
The date, the reporing is produced for.
Example call
/portfolio/riskexpost?portfolioId=E0002&reportingDate=2019-03-31
Response structure
If the API can fulfill the request (response status code 200 = OK) the response must follow the below json-schema.
Note The request part of the response has to match the path and parameters used in the API call/request
The json schema currently excludes the schemas for dataVersioning (should be designed by CSAM) as well as segmentations (will be defined separately)
Schema
Error handling
If the request can't be fulfilled an appropriate response status code (4xx or 5xx) must be used. Possible errors could be
bad request structure → expected status = 400
portfolioId not found or reportingDate in future → expected status = 404
etc.
The body of the response should contain information about the reason of the error in plain text or as json object.
Reporting business logic
aggregation of figures / effects
detection of available periods in result
top n, filtering, sorting
Consistency rules
The following rules should be adhered to by any response and will eventually be checked when consuming a response:
Consistency Rules
Code Block language js
* All figures used within a risk object should be defined in the figures declaration
* All risk objects have to name a period that ends earlier than or at the reportingDate
* All end dates of risk object periods have to be the same and have to be a month's ultimo
dateReporting business logic
aggregation of figures / effects
detection of available periods in result
top n, filtering, sorting
Potential problems
As the ex-post figures are calculated on Aladdin side, no arbitrary periods are possible
Status | ||||
---|---|---|---|---|
|
Usage & contents |
|
---|
Path
/portfolio/riskexpost
Parameters
portfolioId
string
The id of the portfolio (or consolidation) in the data source
reportingDate
string (date)
The date, the reporing is produced for.
Example call
/portfolio/riskexpost?portfolioId=E0002&reportingDate=2019-03-31
Response structure
If the API can fulfill the request (response status code 200 = OK) the response must follow the below json-schema.
Note |
---|
|
Schema
Error handling
If the request can't be fulfilled an appropriate response status code (4xx or 5xx) must be used. Possible errors could be
bad request structure → expected status = 400
portfolioId not found or reportingDate in future → expected status = 404
etc.
The body of the response should contain information about the reason of the error in plain text or as json object.
Reporting business logic |
| |||||||
---|---|---|---|---|---|---|---|---|
Consistency rules | The following rules should be adhered to by any response and will eventually be checked when consuming a response: Consistency Rules
|
Reporting business logic
aggregation of figures / effects
detection of available periods in result
top n, filtering, sorting
Potential problems
As the ex-post figures are calculated on Aladdin side, no arbitrary periods are possible
Interface "PortfolioRiskExAnte"
Status
Status | ||||
---|---|---|---|---|
|
Usage & contents
used to produce
RA001, RA003
RA006..RA008
CO001 (some metrics)
Contents
Ex-ante portfolio level risk figures for a given
|
This interface will include the previousely used interface PortfolioRiskDecompositions
Path |
|
---|
| |||
Parameters |
| string | The id of the portfolio (or consolidation) in the data source |
---|---|---|---|
| string (date) | The date, the reporing is produced for. | |
Example call |
|
|
Response structure
If the API can fulfill the request (response status code 200 = OK) the response must follow the below json-schema.
Note |
---|
|
Schema
Error handling
If the request can't be fulfilled an appropriate response status code (4xx or 5xx) must be used. Possible errors could be
bad request structure → expected status = 400
portfolioId not found or reportingDate in future → expected status = 404
etc.
The body of the response should contain information about the reason of the error in plain text or as json object.
Schema |
| ||||||
---|---|---|---|---|---|---|---|
Example |
|
Interface "PortfolioRiskExAnte"
Usage & contents | used to produce
Contents
| |||||||
---|---|---|---|---|---|---|---|---|
Reporting business logic |
| |||||||
Consistency rules | The following rules should be adhered to by any response and will eventually be checked when consuming a response: Consistency Rules
|
Reporting business logic
aggregation of figures / effects
filtering, sorting
Potential problems
Interface "PortfolioRiskStatus"
Status
StatuscolourGreentitleimplementedPath |
| ||||||
---|---|---|---|---|---|---|---|
Parameters |
| string | The id of the portfolio (or consolidation) in the data source | ||||
| string (date) | The date, the reporing is produced for. | |||||
Example call |
| ||||||
Schema |
| ||||||
Example |
|
Interface "PortfolioRiskStatus"
Usage & contents | used to produce risk status gauges on cover overviews |
---|---|
Reporting business logic | none |
Consistency rules |
|
Path |
|
Example call |
|
Parameters |
---|
calcDate and statusText are mandatory
any other attributes are only for data lineage reasons (not to be interpreted for reporting)
Schema
Error handling
If retrieving the risk status fails, an error is produced
If the retrieved risk status is none, the risk gauge is shown without any active segment
Parameters
portfolioId
reportingDate
Consistency rules
Calculation date must not be newer than reporting date
Reporting business logic
none
Example
Potential problems
|
language | js |
---|
"riskstatus": {
"calcDate": "2019-03-31",
"statusText": "moderate",
"performanceHistoryMonths": 97,
"SRRI": 3,
"SRI": 2
}
where
| |||||
Schema |
| ||||
---|---|---|---|---|---|
Example |
|