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 HelloWithEnumList
{
public enumProp: EnumType[] = [];
public enumWithValues: EnumWithValues[] = [];
public nullableEnumProp: EnumType[] = [];
public enumFlags: EnumFlags[] = [];
public enumStyle: EnumStyle[] = [];
public constructor(init?: Partial<HelloWithEnumList>) { (Object as any).assign(this, init); }
}
TypeScript HelloWithEnumList DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /xml/oneway/HelloWithEnumList HTTP/1.1
Host: test.servicestack.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<HelloWithEnumList xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Test.ServiceModel">
<EnumFlags>
<EnumFlags>Value0</EnumFlags>
</EnumFlags>
<EnumProp>
<EnumType>Value1</EnumType>
</EnumProp>
<EnumStyle>
<EnumStyle>lower</EnumStyle>
</EnumStyle>
<EnumWithValues>
<EnumWithValues>None</EnumWithValues>
</EnumWithValues>
<NullableEnumProp xmlns:d2p1="http://schemas.datacontract.org/2004/07/System">
<d2p1:EnumType>Value1</d2p1:EnumType>
</NullableEnumProp>
</HelloWithEnumList>