"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 .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/HelloWithInheritance HTTP/1.1
Host: test.servicestack.net
Accept: application/json
Content-Type: application/json
Content-Length: length
{"name":"String","id":0}
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"result":"String","refId":0}