| GET | /api/riskstore/eventset/search | Search for event sets |
|---|
// @DataContract
export class QueryBase
{
// @DataMember(Order=1)
public skip?: number;
// @DataMember(Order=2)
public take?: number;
// @DataMember(Order=3)
public orderBy: string;
// @DataMember(Order=4)
public orderByDesc: string;
// @DataMember(Order=5)
public include: string;
// @DataMember(Order=6)
public fields: string;
// @DataMember(Order=7)
public meta: { [index:string]: string; };
public constructor(init?: Partial<QueryBase>) { (Object as any).assign(this, init); }
}
export class QueryDb<T> extends QueryBase
{
public constructor(init?: Partial<QueryDb<T>>) { super(init); (Object as any).assign(this, init); }
}
export enum ProcessingStatus
{
New = 0,
Processing = 1,
Failed = 10,
Successful = 20,
}
export class EventSetTelemetry
{
public eventSetId: number;
public startedDateTimeUtc?: string;
public endedDateTimeUct?: string;
public eventLossCount: number;
public constructor(init?: Partial<EventSetTelemetry>) { (Object as any).assign(this, init); }
}
export class EventSet
{
public eventSetId: number;
public processingStatus: ProcessingStatus;
public sourceModelSystem: string;
public sourceEventSetId: string;
public modelId: string;
public perspectiveId: number;
public simulationCount: number;
public programCalculationId: string;
public description: string;
public limit: number;
public reinstatements: number;
public eventSourceType: string;
public eventSetOriginId: string;
public eventSetOriginName: string;
public eventSetOriginType: string;
public sourceEventSetLossContainer: string;
public sourceEventSetLossPath: string;
public resolution: string;
public resultsHash: string;
public expectedLossAggregate: number;
public expectedLossOccurrence: number;
public probabilityOfAttachment: number;
public probabilityOfExhaustion: number;
public approvedDateTimeUtc: string;
public approvedBy: string;
public eventSourceId: number;
public validFromUtc: string;
public validToUtc: string;
public container: string;
public blobName: string;
public updatedDateUtc: string;
public isArchived: boolean;
public archivedLossDataBlobPath: string;
public archivedLossDataHash: string;
public eventSetTelemetry: EventSetTelemetry;
public constructor(init?: Partial<EventSet>) { (Object as any).assign(this, init); }
}
export class FindEventSetRequest extends QueryDb<EventSet>
{
/** @description Source Model System */
// @ApiMember(DataType="string", Description="Source Model System")
public sourceModelSystem: string;
/** @description Model Id */
// @ApiMember(DataType="string", Description="Model Id")
public modelId: string;
/** @description The perspective id for the event set */
// @ApiMember(DataType="integer", Description="The perspective id for the event set", Format="int32")
public perspectiveId?: number;
/** @description Source Event Set Id */
// @ApiMember(DataType="string", Description="Source Event Set Id", Format="uuid")
public sourceEventSetId?: string;
public constructor(init?: Partial<FindEventSetRequest>) { super(init); (Object as any).assign(this, init); }
}
export enum ResultOutputLevel
{
NotSet = 'NotSet',
PortfolioMetrics = 'PortfolioMetrics',
Curve = 'Curve',
YLT = 'YLT',
TailIntensity = 'TailIntensity',
DealYlt = 'DealYlt',
DealElt = 'DealElt',
DealEltWithIndustryLoss = 'DealEltWithIndustryLoss',
PortfolioElt = 'PortfolioElt',
PortfolioEltWithIndustryLoss = 'PortfolioEltWithIndustryLoss',
EventSetGeneration = 'EventSetGeneration',
PortfolioRaps = 'PortfolioRaps',
DealRaps = 'DealRaps',
PortfolioSepyIndustryLoss = 'PortfolioSepyIndustryLoss',
DealSepyIndustryLoss = 'DealSepyIndustryLoss',
}
export class AnalysisPortfolioEventSetConfiguration implements IObjectWithId, IHasAnalysisId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public analysisId: number;
// @DataMember(Order=3)
public analysisConfigurationId: number;
// @DataMember(Order=4)
public portfolioName: string;
// @DataMember(Order=5)
public modelId: string;
// @DataMember(Order=6)
public rowIdentifier: string;
public constructor(init?: Partial<AnalysisPortfolioEventSetConfiguration>) { (Object as any).assign(this, init); }
}
// @DataContract
export class AnalysisConfiguration implements IObjectWithId, IHasAnalysisId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public analysisId: number;
// @DataMember(Order=3)
public windowStartDate?: string;
// @DataMember(Order=4)
public windowEndDate?: string;
// @DataMember(Order=5)
public standardEnabled: boolean;
// @DataMember(Order=6)
public runOffEnabled: boolean;
// @DataMember(Order=7)
public aggregateEnabled: boolean;
// @DataMember(Order=8)
public occurrenceEnabled: boolean;
// @DataMember(Order=9)
public nettEnabled: boolean;
// @DataMember(Order=10)
public grossEnabled: boolean;
// @DataMember(Order=11)
public tailIntensityPercentageStart?: number;
// @DataMember(Order=12)
public tailIntensityPercentageEnd?: number;
// @DataMember(Order=13)
public metaRiskId: number;
// @DataMember(Order=14)
public outputLevel: ResultOutputLevel;
// @DataMember(Order=15)
public processingStatus: ProcessingStatus;
// @DataMember(Order=16)
public eventLossFloorStartRange?: number;
// @DataMember(Order=17)
public eventLossFloorEndRange?: number;
// @DataMember(Order=18)
public analysisPortfolioEventSetConfigurations: AnalysisPortfolioEventSetConfiguration[];
// @DataMember(Order=19)
public rowIdentifier: string;
public constructor(init?: Partial<AnalysisConfiguration>) { (Object as any).assign(this, init); }
}
export enum TransactionType
{
NotSet = 'NotSet',
S = 'S',
B = 'B',
}
// @DataContract
export class AnalysisPortfolioAllocation implements IObjectWithId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public analysisDealId: number;
// @DataMember(Order=3)
// @Validate(Validator="NotEmpty", Message="PortfolioName is mandatory")
public portfolioName: string;
// @DataMember(Order=4)
public allocationPercentage: number;
// @DataMember(Order=5)
public rowIdentifier: string;
public constructor(init?: Partial<AnalysisPortfolioAllocation>) { (Object as any).assign(this, init); }
}
// @DataContract
export class AnalysisDeal implements IObjectWithId, IHasAnalysisId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public analysisId: number;
// @DataMember(Order=3)
public sourceDealId: string;
// @DataMember(Order=4)
public dealRef: string;
// @DataMember(Order=5)
public sourceDealSystem: string;
// @DataMember(Order=6)
public eventSetId: number;
// @DataMember(Order=7)
public rol: number;
// @DataMember(Order=8)
public limit: number;
// @DataMember(Order=9)
public inceptionDate: string;
// @DataMember(Order=10)
public expiryDate: string;
// @DataMember(Order=11)
public transactionType: TransactionType;
// @DataMember(Order=12)
public allocations: AnalysisPortfolioAllocation[];
// @DataMember(Order=13)
public perspectiveIdOverride?: number;
// @DataMember(Order=14)
public eventSetIdOverride?: number;
// @DataMember(Order=15)
public modelAsOfDateOverride?: string;
// @DataMember(Order=16)
public sourceModelSystemOverride: string;
// @DataMember(Order=17)
public sourceModelIdOverride: string;
// @DataMember(Order=18)
public sourceEventSetIdOverride: string;
// @DataMember(Order=19)
public eventSourceSystemOverride: string;
// @DataMember(Order=20)
public rowIdentifier: string;
public constructor(init?: Partial<AnalysisDeal>) { (Object as any).assign(this, init); }
}
// @DataContract
export class AnalysisEventIdFilter implements IObjectWithId, IHasAnalysisId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public analysisId: number;
// @DataMember(Order=3)
public eventSourceId: number;
// @DataMember(Order=4)
public eventId: number;
// @DataMember(Order=5)
public rowIdentifier: string;
public constructor(init?: Partial<AnalysisEventIdFilter>) { (Object as any).assign(this, init); }
}
export enum MessageType
{
NotSet = 'NotSet',
Persistence = 'Persistence',
Archival = 'Archival',
}
// @DataContract
export class MessageTracking
{
// @DataMember(Order=1)
public id: string;
// @DataMember(Order=2)
public analysisId?: number;
// @DataMember(Order=3)
public processingStatus: ProcessingStatus;
// @DataMember(Order=4)
public messageType: MessageType;
// @DataMember(Order=5)
public createdDateUtc: string;
// @DataMember(Order=6)
public updatedDateUtc: string;
public constructor(init?: Partial<MessageTracking>) { (Object as any).assign(this, init); }
}
// @DataContract
export class Analysis implements IObjectWithId
{
// @DataMember(Order=1)
public id: number;
// @DataMember(Order=2)
public name: string;
// @DataMember(Order=3)
public modelAsOfDate?: string;
// @DataMember(Order=4)
public perspectiveId: number;
// @DataMember(Order=5)
public configurations: AnalysisConfiguration[];
// @DataMember(Order=6)
public deals: AnalysisDeal[];
// @DataMember(Order=7)
public eventIdFilters: AnalysisEventIdFilter[];
// @DataMember(Order=8)
public createdBy: string;
// @DataMember(Order=9)
public createdDateUtc: string;
// @DataMember(Order=10)
public completedDateUtc?: string;
// @DataMember(Order=11)
public legacyAnalysisId?: number;
// @DataMember(Order=12)
public resultPersistenceTracking: MessageTracking[];
// @DataMember(Order=13)
public processingStatus: ProcessingStatus;
// @DataMember(Order=14)
public saveResults: boolean;
// @DataMember(Order=15)
public eventSourceSystem: string;
// @DataMember(Order=16)
public updatedDateUtc: string;
// @DataMember(Order=17)
public isExpired: boolean;
// @DataMember(Order=18)
public rowIdentifier: string;
// @DataMember(Order=19)
public errorMessage: string;
/** @description Take the minimum simulation count when we have different simulations between event sets */
// @DataMember(Order=20)
// @ApiMember(DataType="boolean", Description="Take the minimum simulation count when we have different simulations between event sets")
public ignoreSimulationCountMismatch: boolean;
// @DataMember(Order=21)
// @Ignore()
public finalStatus: ProcessingStatus;
public constructor(init?: Partial<Analysis>) { (Object as any).assign(this, init); }
}
// @DataContract
export class QueryResponse<T>
{
// @DataMember(Order=1)
public offset: number;
// @DataMember(Order=2)
public total: number;
// @DataMember(Order=3)
public results: Analysis[];
// @DataMember(Order=4)
public meta: { [index:string]: string; };
// @DataMember(Order=5)
public responseStatus: ResponseStatus;
public constructor(init?: Partial<QueryResponse<T>>) { (Object as any).assign(this, init); }
}
TypeScript FindEventSetRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /api/riskstore/eventset/search HTTP/1.1 Host: riskstoreng-dev.nephila.com Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
offset: 0,
total: 0,
results:
[
{
eventSetId: 0,
processingStatus: New,
sourceModelSystem: String,
sourceEventSetId: String,
modelId: String,
perspectiveId: 0,
simulationCount: 0,
programCalculationId: String,
description: String,
limit: 0,
reinstatements: 0,
eventSourceType: String,
eventSetOriginId: String,
eventSetOriginName: String,
eventSetOriginType: String,
sourceEventSetLossContainer: String,
sourceEventSetLossPath: String,
resolution: String,
resultsHash: String,
expectedLossAggregate: 0,
expectedLossOccurrence: 0,
probabilityOfAttachment: 0,
probabilityOfExhaustion: 0,
approvedDateTimeUtc: 0001-01-01,
approvedBy: String,
eventSourceId: 0,
validFromUtc: 0001-01-01,
validToUtc: 0001-01-01,
container: String,
blobName: String,
updatedDateUtc: 0001-01-01,
isArchived: False,
archivedLossDataBlobPath: String,
archivedLossDataHash: String,
eventSetTelemetry:
{
eventSetId: 0,
startedDateTimeUtc: 0001-01-01,
endedDateTimeUct: 0001-01-01,
eventLossCount: 0
}
}
],
meta:
{
String: String
},
responseStatus:
{
errorCode: String,
message: String,
stackTrace: String,
errors:
[
{
errorCode: String,
fieldName: String,
message: String,
meta:
{
String: String
}
}
],
meta:
{
String: String
}
}
}