// @DataContract
export class HelloWithDataContract
{
// @DataMember(Name="name", Order=1, IsRequired=true, EmitDefaultValue=false)
public name: string;
// @DataMember(Name="id", Order=2, EmitDefaultValue=false)
public id: number;
public constructor(init?: Partial<HelloWithDataContract>) { (Object as any).assign(this, init); }
}
// @DataContract
export class HelloWithDataContractResponse
{
// @DataMember(Name="result", Order=1, IsRequired=true, EmitDefaultValue=false)
public result: string;
public constructor(init?: Partial<HelloWithDataContractResponse>) { (Object as any).assign(this, init); }
}
TypeScript HelloWithDataContract 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/HelloWithDataContract HTTP/1.1
Host: test.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
name: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { result: String }