// @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 .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/DeclarativeCollectiveValidationTest HTTP/1.1
Host: test.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
site: String,
declarativeValidations:
[
{
name: String,
value: String
}
],
fluentValidations:
[
{
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 } } }