// @DataContract
export class EmptyResponse
{
    // @DataMember(Order=1)
    public responseStatus?: ResponseStatus;
    public constructor(init?: Partial<EmptyResponse>) { (Object as any).assign(this, init); }
}
export class DeclarativeChildValidation
{
    public name: string;
    // @Validate(Validator="MaximumLength(20)")
    public value: string;
    public constructor(init?: Partial<DeclarativeChildValidation>) { (Object as any).assign(this, init); }
}
export class FluentChildValidation
{
    public name: string;
    public value: string;
    public constructor(init?: Partial<FluentChildValidation>) { (Object as any).assign(this, init); }
}
export class DeclarativeCollectiveValidationTest
{
    // @Validate(Validator="NotEmpty")
    // @Validate(Validator="MaximumLength(20)")
    public site: string;
    public declarativeValidations: DeclarativeChildValidation[] = [];
    public fluentValidations: FluentChildValidation[] = [];
    public constructor(init?: Partial<DeclarativeCollectiveValidationTest>) { (Object as any).assign(this, init); }
}
TypeScript DeclarativeCollectiveValidationTest 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
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /json/reply/DeclarativeCollectiveValidationTest HTTP/1.1 
Host: test.servicestack.net 
Accept: application/json
Content-Type: application/json
Content-Length: length
{"site":"String","declarativeValidations":[{"name":"String","value":"String"}],"fluentValidations":[{"name":"String","value":"String"}]}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length
{"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}