| All Verbs | /echo/complex | 
|---|
"use strict";
export class SubType {
    /** @param {{id?:number,name?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /** @type {number} */
    id;
    /** @type {string} */
    name;
}
export class EchoComplexTypes {
    /** @param {{subType?:SubType,subTypes?:SubType[],subTypeMap?:{ [index:string]: SubType; },stringMap?:{ [index:string]: string; },intStringMap?:{ [index:number]: string; }}} [init] */
    constructor(init) { Object.assign(this, init) }
    /** @type {SubType} */
    subType;
    /** @type {SubType[]} */
    subTypes;
    /** @type {{ [index:string]: SubType; }} */
    subTypeMap;
    /** @type {{ [index:string]: string; }} */
    stringMap;
    /** @type {{ [index:number]: string; }} */
    intStringMap;
}
JavaScript EchoComplexTypes 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 /echo/complex HTTP/1.1 
Host: test.servicestack.net 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
	subType: 
	{
		id: 0,
		name: String
	},
	subTypes: 
	[
		{
			id: 0,
			name: String
		}
	],
	subTypeMap: 
	{
		String: 
		{
			id: 0,
			name: String
		}
	},
	stringMap: 
	{
		String: String
	},
	intStringMap: 
	{
		0: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
	subType: 
	{
		id: 0,
		name: String
	},
	subTypes: 
	[
		{
			id: 0,
			name: String
		}
	],
	subTypeMap: 
	{
		String: 
		{
			id: 0,
			name: String
		}
	},
	stringMap: 
	{
		String: String
	},
	intStringMap: 
	{
		0: String
	}
}