"use strict";
export class HelloBase {
/** @param {{id?:number}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {number} */
id;
}
export class HelloWithInheritance extends HelloBase {
/** @param {{name?:string,id?:number}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/** @type {string} */
name;
}
export class HelloResponseBase {
/** @param {{refId?:number}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {number} */
refId;
}
export class HelloWithInheritanceResponse extends HelloResponseBase {
/** @param {{result?:string,refId?:number}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/** @type {string} */
result;
}
JavaScript HelloWithInheritance 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/HelloWithInheritance HTTP/1.1
Host: test.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
name: String,
id: 0
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { result: String, refId: 0 }