export enum EnumType
{
Value1 = 'Value1',
Value2 = 'Value2',
Value3 = 'Value3',
}
export enum EnumWithValues
{
None = 'None',
Value1 = 'Member 1',
Value2 = 'Value2',
}
// @Flags()
export enum EnumFlags
{
Value0 = 0,
Value1 = 1,
Value2 = 2,
Value3 = 4,
Value123 = 7,
}
export enum EnumStyle
{
lower = 'lower',
UPPER = 'UPPER',
PascalCase = 'PascalCase',
camelCase = 'camelCase',
camelUPPER = 'camelUPPER',
PascalUPPER = 'PascalUPPER',
}
export class HelloWithEnumMap
{
public enumProp: { [index:string]: EnumType; } = {};
public enumWithValues: { [index:string]: EnumWithValues; } = {};
public nullableEnumProp: { [index:string]: EnumType; } = {};
public enumFlags: { [index:string]: EnumFlags; } = {};
public enumStyle: { [index:string]: EnumStyle; } = {};
public constructor(init?: Partial<HelloWithEnumMap>) { (Object as any).assign(this, init); }
}
TypeScript HelloWithEnumMap DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /csv/oneway/HelloWithEnumMap HTTP/1.1
Host: test.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"enumProp":{"Value1":"Value1"},"enumWithValues":{"None":"None"},"nullableEnumProp":{"Value1":"Value1"},"enumFlags":{"0":0},"enumStyle":{"lower":"lower"}}