| All Verbs | /qry/bets/search |
|---|
import Foundation
import ServiceStack
public class FindBets : PaginatedQueryRequest
{
required public init(){ super.init() }
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
}
}
public class PaginatedQueryRequest : QueryRequest
{
public var currentPage:Int
public var pageSize:Int
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case currentPage
case pageSize
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
currentPage = try container.decodeIfPresent(Int.self, forKey: .currentPage)
pageSize = try container.decodeIfPresent(Int.self, forKey: .pageSize)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if currentPage != nil { try container.encode(currentPage, forKey: .currentPage) }
if pageSize != nil { try container.encode(pageSize, forKey: .pageSize) }
}
}
public class QueryRequest : Codable
{
public var qry:[String:String] = [:]
required public init(){}
}
public class PaginatedResult<T : Codable> : IPaginatedResult, Codable
{
public var data:[ResponseMetrics] = []
public var currentPage:Int
public var pageSize:Int
public var totalItems:Int
public var totalPages:Int
required public init(){}
}
public class ResponseMetrics : Codable
{
public var id:Int
public var rqc:Int
public var oc:Int
public var sc:Int
public var tc:Int
public var adr:Int
required public init(){}
}
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 /qry/bets/search HTTP/1.1
Host: api.sbbet.ath.cx
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
currentPage: 0,
pageSize: 0,
qry:
{
String: String
}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
data:
[
{
id: String,
slipId: 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
}
},
bettor:
{
id: String,
val: String
},
placedAt: 0001-01-01,
productInstance:
{
id: String,
name: String,
title: String,
product:
{
id: String,
value: String,
category: String,
productProvider:
{
id: String,
val: String
}
}
},
status: 0,
placementStatus: 0,
processingStatus: 0,
validity: 0,
payoutStatus: 0,
payload:
{
String: String
},
outcome: 0,
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
},
actualPayoutRecap:
{
currency: String,
winnings: 0,
winningsTaxationPolicyRef:
{
id: String,
val: String
},
taxAmount: 0,
payout: 0
},
payoutInfo:
{
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
}
},
performedAt: 0001-01-01
},
cancellationInfo:
{
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
}
},
performedAt: 0001-01-01
}
}
],
currentPage: 0,
pageSize: 0,
totalItems: 0,
totalPages: 0
}