// @DataContract
export class EmptyResponse
{
// @DataMember(Order=1)
public responseStatus: ResponseStatus;
public constructor(init?: Partial<EmptyResponse>) { (Object as any).assign(this, init); }
}
export class DeclarativeSingleValidation
{
public name: string;
// @Validate(Validator="MaximumLength(20)")
public value: string;
public constructor(init?: Partial<DeclarativeSingleValidation>) { (Object as any).assign(this, init); }
}
export class FluentSingleValidation
{
public name: string;
public value: string;
public constructor(init?: Partial<FluentSingleValidation>) { (Object as any).assign(this, init); }
}
export class DeclarativeSingleValidationTest
{
// @Validate(Validator="NotEmpty")
// @Validate(Validator="MaximumLength(20)")
public site: string;
public declarativeSingleValidation: DeclarativeSingleValidation;
public fluentSingleValidation: FluentSingleValidation;
public constructor(init?: Partial<DeclarativeSingleValidationTest>) { (Object as any).assign(this, init); }
}
TypeScript DeclarativeSingleValidationTest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /jsv/reply/DeclarativeSingleValidationTest HTTP/1.1
Host: test.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
site: String,
declarativeSingleValidation:
{
name: String,
value: String
},
fluentSingleValidation:
{
name: String,
value: String
}
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } }