Test

<back to all web services

HelloWithEnumMap


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 .json suffix or ?format=json

To embed the response in a jsonp callback, append ?callback=myCallback

HTTP + JSON

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /json/oneway/HelloWithEnumMap HTTP/1.1 
Host: test.servicestack.net 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"enumProp":{"Value1":"Value1"},"enumWithValues":{"None":"None"},"nullableEnumProp":{"Value1":"Value1"},"enumFlags":{"0":0},"enumStyle":{"lower":"lower"}}