"use strict";
/** @typedef T {any} */
export class HelloBase {
/** @param {{items?:T[],counts?:number[]}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {T[]} */
items = [];
/** @type {number[]} */
counts = [];
}
export class Hello {
/** @param {{name?:string,title?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {string} */
name;
/** @type {string} */
title;
}
export class HelloWithGenericInheritance2 extends HelloBase {
/** @param {{result?:string,items?:T[],counts?:number[]}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/** @type {string} */
result;
}
JavaScript HelloWithGenericInheritance2 DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /xml/oneway/HelloWithGenericInheritance2 HTTP/1.1
Host: test.servicestack.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<HelloWithGenericInheritance2 xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Test.ServiceModel">
<Counts xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d2p1:int>0</d2p1:int>
</Counts>
<Items>
<Hello>
<Name>String</Name>
<Title>String</Title>
</Hello>
</Items>
<Result>String</Result>
</HelloWithGenericInheritance2>