| POST | /cmd/bettingPolicies/config |
|---|
"use strict";
/** @typedef {number} */
export var PayinConstraintType;
(function (PayinConstraintType) {
PayinConstraintType[PayinConstraintType["SingleBet"] = 0] = "SingleBet"
PayinConstraintType[PayinConstraintType["MultiBet"] = 1] = "MultiBet"
PayinConstraintType[PayinConstraintType["SystemBet"] = 2] = "SystemBet"
})(PayinConstraintType || (PayinConstraintType = {}));
export class Money {
/** @param {{amount?:number,currency?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {number} */
amount;
/** @type {string} */
currency;
}
export class PayinConstraint {
/** @param {{type?:PayinConstraintType,min?:Money,default?:Money,warningThreshold?:Money,max?:Money}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {PayinConstraintType} */
type;
/** @type {Money} */
min;
/** @type {Money} */
default;
/** @type {Money} */
warningThreshold;
/** @type {Money} */
max;
}
/** @typedef {number} */
export var WinningsCapType;
(function (WinningsCapType) {
WinningsCapType[WinningsCapType["SingleBet"] = 0] = "SingleBet"
WinningsCapType[WinningsCapType["MultiBet"] = 1] = "MultiBet"
WinningsCapType[WinningsCapType["SystemBet"] = 2] = "SystemBet"
})(WinningsCapType || (WinningsCapType = {}));
export class WinningsCap {
/** @param {{type?:WinningsCapType,cap?:Money}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {WinningsCapType} */
type;
/** @type {Money} */
cap;
}
export class BettingPolicies {
/** @param {{payinConstraints?:RecordList<PayinConstraint>,payinTaxationPolicyId?:string,winningsCaps?:RecordList<WinningsCap>,winningsTaxationPolicyId?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {RecordList<PayinConstraint>} */
payinConstraints;
/** @type {string} */
payinTaxationPolicyId;
/** @type {RecordList<WinningsCap>} */
winningsCaps;
/** @type {string} */
winningsTaxationPolicyId;
}
export class Ref {
/** @param {{id?:string,val?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {string} */
id;
/** @type {string} */
val;
}
export class SetBettingPoliciesConfig {
/** @param {{id?:string,policies?:BettingPolicies,productInstanceRef?:Ref,ownerRef?:Ref,isActive?:boolean}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {string} */
id;
/** @type {BettingPolicies} */
policies;
/** @type {Ref} */
productInstanceRef;
/** @type {Ref} */
ownerRef;
/** @type {boolean} */
isActive;
}
/** @typedef T {any} */
export class RecordList extends Array {
constructor(init) { super(init); Object.assign(this, init) }
}
JavaScript SetBettingPoliciesConfig 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 /cmd/bettingPolicies/config HTTP/1.1
Host: api.sbbet.ath.cx
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
id: String,
policies:
{
payinConstraints:
[
{
type: 0,
min:
{
amount: 0,
currency: String
},
default:
{
amount: 0,
currency: String
},
warningThreshold:
{
amount: 0,
currency: String
},
max:
{
amount: 0,
currency: String
}
}
],
payinTaxationPolicyId: String,
winningsCaps:
[
{
type: 0,
cap:
{
amount: 0,
currency: String
}
}
],
winningsTaxationPolicyId: String
},
productInstanceRef:
{
id: String,
val: String
},
ownerRef:
{
id: String,
val: String
},
isActive: False
}
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
}
}