Betting.WebApi

<back to all web services

SubmitSlip

Requires Authentication
The following routes are available for this service:
POST/cmd/slips

export class Ref
{
    public id: string;
    public val: string;

    public constructor(init?: Partial<Ref>) { (Object as any).assign(this, init); }
}

export class BettingApp
{
    public name: string;
    public version: string;

    public constructor(init?: Partial<BettingApp>) { (Object as any).assign(this, init); }
}

export class RefEx extends Ref
{
    public data: RecordDictionary<string, string>;

    public constructor(init?: Partial<RefEx>) { super(init); (Object as any).assign(this, init); }
}

export class Origin
{
    public application: BettingApp;
    public ip: string;
    public organization: RefEx;
    public region: Ref;
    public locationGroup: Ref;
    public location: RefEx;
    public device: RefEx;
    public clerk: Ref;

    public constructor(init?: Partial<Origin>) { (Object as any).assign(this, init); }
}

export class ProductReference
{
    public id: string;
    public value: string;
    public category: string;
    public productProvider: Ref;

    public constructor(init?: Partial<ProductReference>) { (Object as any).assign(this, init); }
}

export class ProductInstanceRef
{
    public id: string;
    public name: string;
    public title: string;
    public product: ProductReference;

    public constructor(init?: Partial<ProductInstanceRef>) { (Object as any).assign(this, init); }
}

export class PayinRecap
{
    public currency: string;
    public payin: number;
    public payinTaxationPolicyRef: Ref;
    public taxAmount: number;
    public stake: number;

    public constructor(init?: Partial<PayinRecap>) { (Object as any).assign(this, init); }
}

export class PayoutRecap
{
    public currency: string;
    public winnings: number;
    public winningsTaxationPolicyRef: Ref;
    public taxAmount: number;
    public payout: number;

    public constructor(init?: Partial<PayoutRecap>) { (Object as any).assign(this, init); }
}

export class BetRequest
{
    public betId: string;
    public productInstance: ProductInstanceRef;
    public payload: { [index:string]: string; };
    public payinRecap: PayinRecap;
    public possiblePayoutRecap: PayoutRecap;

    public constructor(init?: Partial<BetRequest>) { (Object as any).assign(this, init); }
}

export class SubmitSlip
{
    public id: string;
    public bettor: Ref;
    public origin: Origin;
    public betRequests: BetRequest[];
    public headerData: { [index:string]: string; };

    public constructor(init?: Partial<SubmitSlip>) { (Object as any).assign(this, init); }
}

export class Dictionary<T> { [Key: string]: T; }

export class RecordDictionary<TKey, TVal> extends Dictionary<TVal>
{

    public constructor(init?: Partial<RecordDictionary<TKey, TVal>>) { super(); (Object as any).assign(this, init); }
}

TypeScript SubmitSlip DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /cmd/slips HTTP/1.1 
Host: api.sbbet.ath.cx 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	id: String,
	bettor: 
	{
		id: String,
		val: String
	},
	origin: 
	{
		application: 
		{
			name: String,
			version: String
		},
		ip: String,
		organization: 
		{
			data: 
			{
				String: String
			},
			id: String,
			val: String
		},
		region: 
		{
			id: String,
			val: String
		},
		locationGroup: 
		{
			id: String,
			val: String
		},
		location: 
		{
			data: 
			{
				String: String
			},
			id: String,
			val: String
		},
		device: 
		{
			data: 
			{
				String: String
			},
			id: String,
			val: String
		},
		clerk: 
		{
			id: String,
			val: String
		}
	},
	betRequests: 
	[
		{
			betId: String,
			productInstance: 
			{
				id: String,
				name: String,
				title: String,
				product: 
				{
					id: String,
					value: String,
					category: String,
					productProvider: 
					{
						id: String,
						val: String
					}
				}
			},
			payload: 
			{
				String: String
			},
			payinRecap: 
			{
				currency: String,
				payin: 0,
				payinTaxationPolicyRef: 
				{
					id: String,
					val: String
				},
				taxAmount: 0,
				stake: 0
			},
			possiblePayoutRecap: 
			{
				currency: String,
				winnings: 0,
				winningsTaxationPolicyRef: 
				{
					id: String,
					val: String
				},
				taxAmount: 0,
				payout: 0
			}
		}
	],
	headerData: 
	{
		String: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	errorCode: String,
	message: String,
	stackTrace: String,
	errors: 
	[
		{
			errorCode: String,
			fieldName: String,
			message: String,
			meta: 
			{
				String: String
			}
		}
	],
	meta: 
	{
		String: String
	}
}