export enum EnumType
{
Value1 = 'Value1',
Value2 = 'Value2',
Value3 = 'Value3',
}
// @Flags()
export enum EnumTypeFlags
{
Value1 = 0,
Value2 = 1,
Value3 = 2,
}
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 EnumAsInt
{
Value1 = 1000,
Value2 = 2000,
Value3 = 3000,
}
export enum EnumStyle
{
lower = 'lower',
UPPER = 'UPPER',
PascalCase = 'PascalCase',
camelCase = 'camelCase',
camelUPPER = 'camelUPPER',
PascalUPPER = 'PascalUPPER',
}
export enum EnumStyleMembers
{
Lower = 'lower',
Upper = 'UPPER',
PascalCase = 'PascalCase',
CamelCase = 'camelCase',
CamelUpper = 'camelUPPER',
PascalUpper = 'PascalUPPER',
}
export class HelloWithEnum
{
public enumProp: EnumType;
public enumTypeFlags: EnumTypeFlags;
public enumWithValues: EnumWithValues;
public nullableEnumProp?: EnumType;
public enumFlags: EnumFlags;
public enumAsInt: EnumAsInt;
public enumStyle: EnumStyle;
public enumStyleMembers: EnumStyleMembers;
public constructor(init?: Partial<HelloWithEnum>) { (Object as any).assign(this, init); }
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .other suffix or ?format=other
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /jsonl/oneway/HelloWithEnum HTTP/1.1
Host: test.servicestack.net
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length
{"enumProp":"Value1","enumTypeFlags":0,"enumWithValues":"None","nullableEnumProp":"Value1","enumFlags":0,"enumAsInt":"Value1","enumStyle":"lower","enumStyleMembers":"lower"}