XAgent Transfer Wallet API Document V3.0
Preface
Connection Process
- Provide relevant information and contact us to open an account for you in the UAT environment
- Provide your server IP to add the server IP whitelist.
- After the account is opened, we provide publicKey, logo, site and other parameters, and the game background address
- According to your game needs, we provide the corresponding game coding table for docking
- Create game-related data (name, code, cover material, etc.) on your platform
- Start docking the interface through the interface document
- The interface docking is completed and the joint debugging test is correct
- The formal environment is ready for access, and our business intervenes to discuss business matters with you
- The formal environment account is opened, and the interface address and parameters are switched
- Provide your background IP whitelist and configure the whitelist in the game background
- Pre-operation and acceptance of the formal environment
- Access is completed and officially launched
Docking instructions
All our interface parameters are case sensitive (case will not be ignored), please pay attention to the value
After configuring the game entrance on your WEB / H5 / APP platform, the user clicks on the game entrance, calls the user registration/login interface provided by us, and passes in parameters such as account, game code, gameType, etc.
After success, get the interface return value, where the url field is the form or url link that carries the user's login token
By accessing and embedding the url field, you can jump into the game body
You need to take the user's unique ID as the account, splice it according to certain rules, and pass it to the interface
If you need to get the trial entrance of the game, pass isAnonymous true in the interface parameters.
You can create different proxy lines in the game console (backstage) provided by us. Each line can be configured with an independent RTP configuration, and the users of each line are also separated and independent.
When we open an account for you, we will create a default proxy line for you to use. If you need more later, you can add them in the background.
You can also create your sub-agent in the background, assign different proxy lines to your sub-agent management, and attach the sub-agent background, which can view the relevant game data, user order records, reports, adjust RTP parameters, etc. assigned to the sub-agent.
Whitelist restrictions
All our interface domain names and the game backends we opened for you have set IP whitelist restrictions. If they are not configured, you cannot call the interface/access the backend. Therefore, before the connection starts, you need to provide the following IP information for us to pre-configure:
The IP address of the server in each environment
The IP address of the device you need to access the game backend
API Document
Interface Domain Name
UAT Environment: https://xagent-open-api-uat.ncfc.cc
Formal Environment: Contact Business to Obtain
Preparation before Access
Headers:
Parameter Name | Parameter Value | Required | Example | Remarks |
---|---|---|---|---|
Content-Type | application/json | Yes | application/json | |
businessAccount | The unique ID of the general agent provided by us | Yes | ballGame | |
site | Agent line identification in XAgent merchant backend | Yes | xaDefault |
Parameter encryption example:
//Parameters
Map<String, String> param = new HashMap<>();
param.put("account", "username");
param.put("password", "password");
//rsa encryption
byte[] encodedData = RSAUtil.encrypt(JSON.toJSONString(param).getBytes(), publicKey);
//base64
String base64String = Base64Util.encode(encodedData);
System.out.println("encoded: " + base64String);
Map<String, String> encryptParam = new HashMap<>();
encryptParam.put("data",base64String);
//Call API httpPost(encryptParam);
// Param
$param = array(
"account" => "username",
"password" => "password"
);
// JSON Encode
$jsonData = json_encode($param);
// RSA Encrypt
$publicKey = "your-public-key"; // Replace your public key
$publicKeyResource = openssl_pkey_get_public($publicKey);
openssl_public_encrypt($jsonData, $encryptedData, $publicKeyResource);
// Base64 Encode
$base64String = base64_encode($encryptedData);
echo "encoded: " . $base64String . "\n";
// Build Request Param
$encryptParam = array(
"data" => $base64String
);
// Call API
$response = httpPost($encryptParam);
echo $response;
// HTTP POST
function httpPost($params) {
$url = 'your-api-endpoint'; // replace api address
$options = array(
'http' => array(
'header' => "Content-type: application/x-www-form-urlencoded\r\n",
'method' => 'POST',
'content' => http_build_query($params),
),
);
$context = stream_context_create($options);
$result = file_get_contents($url, false, $context);
return $result;
}
import json
import base64
import requests
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP
# param
param = {
"account": "username",
"password": "password"
}
# JSON encode
json_data = json.dumps(param)
# RSA Encrypt
public_key =
"
-----BEGIN PUBLIC KEY-----
your-public-key-here
-----END PUBLIC KEY-----
"
rsa_key = RSA.import_key(public_key)
cipher = PKCS1_OAEP.new(rsa_key)
encoded_data = cipher.encrypt(json_data.encode('utf-8'))
# Base64 encode
base64_string = base64.b64encode(encoded_data).decode('utf-8')
print("encoded:", base64_string)
# build request param
encrypt_param = {
"data": base64_string
}
# call api
response = requests.post('your-api-endpoint', data=encrypt_param)
print(response.text)
package main
import (
"bytes"
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/base64"
"encoding/json"
"encoding/pem"
"fmt"
"net/http"
)
func main() {
// param
param := map[string]string{
"account": "username",
"password": "password",
}
// JSON encode
jsonData, err := json.Marshal(param)
if err != nil {
fmt.Println("JSON Marshal error:", err)
return
}
// RSA encrypt
publicKey := `-----BEGIN PUBLIC KEY-----
your-public-key-here
-----END PUBLIC KEY-----`
encodedData, err := rsaEncrypt(jsonData, publicKey)
if err != nil {
fmt.Println("RSA Encryption error:", err)
return
}
// Base64 encode
base64String := base64.StdEncoding.EncodeToString(encodedData)
fmt.Println("encoded:", base64String)
// build request param
encryptParam := map[string]string{
"data": base64String,
}
// call api
response, err := httpPost("your-api-endpoint", encryptParam)
if err != nil {
fmt.Println("HTTP Post error:", err)
return
}
fmt.Println("Response:", response)
}
const crypto = require('crypto');
const axios = require('axios');
// param
const param = {
account: 'username',
password: 'password'
};
// JSON encode
const jsonData = JSON.stringify(param);
// RSA encrypt
const publicKey = `-----BEGIN PUBLIC KEY-----
your-public-key-here
-----END PUBLIC KEY-----`;
const buffer = Buffer.from(jsonData, 'utf8');
const encryptedData = crypto.publicEncrypt(publicKey, buffer);
// Base64 encode
const base64String = encryptedData.toString('base64');
console.log("encoded: " + base64String);
// build request param
const encryptParam = {
data: base64String
};
// call api
axios.post('your-api-endpoint', encryptParam)
.then(response => {
console.log(response.data);
})
.catch(error => {
console.error(error);
});
- Content-Type: application/json.
- You need to add the two fixed values provided by us to the request header, with the header keys being site and businessAccount
- You need to use the public key to perform RSA encryption on the request body, then convert the encrypted byte array into a Base64 string, and finally assemble it into a json format of {"data":"encrypted Base64 string"} and submit it to the interface
- In the http return object, code is the return code 200 = normal, and the data is in data. When code is not 200, message is an error message.
- Request example
- Example XAgent server domain name is https://xagent-open-api-uat.ncfc.cc
- The address of a certain interface is /v3/single/act
- The merchant end public key is MIGfMA0GCSqGSIb3DQEBAQUAA4GNADC...
- Business parameter json data {"field_1":"value_1","field_2":"value_2"}
- First encrypt the business parameters with RSA to get the ciphertext Os977UOvhnqN+0xY4YBg95vlBpaKmgWAHnTa...
- Set the request header businessAccount site content-type
- After encoding the ciphertext with base64, build a unified request parameter entity {"data":"Os977UOvhnqN+0xY4YBg95vlBpaKmgWAHnTa..."}
- Submit the request using post https://xagent-open-api-uat.ncfc.cc/v3/single/act
- Get the response data {"code":200,"message":"success","data":{"field_a":"value_a","field_b":"value_b"}}
- Determine whether the code is 200. If it is 200, it is strongly recommended that the merchant verify the response data. If it is not 200, there will be no signature value. The signature value is obtained from the response header signature
- Concatenate the data in the Body with the public key to obtain {"code":200,"message":"success","data":{"field_a":"value_a","field_b":"value_b"}}MIGfMA0GCSqGSIb3DQEBAQUAA4GNADC...
- Obtain the information summary of the concatenated string through the MD5 algorithm, and then compare it with the signature value in the response header. If they are consistent, the response data is safe
- Then make subsequent business logic judgments based on business parameters
User registration / login (game entry)
Interface path
POST /v3/transfer/user/login
Interface description
Request this interface to register/login a user, and at the same time obtain the URL entry with the user token. The account must be unique.
Request parameters
Body:
Parameters | Data type | Required | Description |
---|---|---|---|
account | string | Y | Player account (supports only (2~13) lowercase characters or numbers) ^[a-z0-9]{2,8}$ |
password | string | Y | Account password (no more than 20 characters) |
gameType | string | Y | Game category code (see Appendix) |
isMobile | bool | Y | Whether it is a mobile terminal |
gameCode | string | Y | Game code, the code of the specific game |
lang | string | Y | Language type (see Appendix) |
coin | string | Y | Currency type (see Appendix) |
line | string | N | Line, supported by some venues, if supported, use this value to fill in the required parameters of the "line/site" system of the three parties, if not passed, it will be the default value |
lobby | string | N | Lobby address, supported by some venues, such as jumping back from the venue game page to the merchant page, empty if not passed |
isAnonymous | bool | N | Anonymous account/trial account |
userIP | string | N | Player IP |
orderNoMerchant | string | N | Order number for points increase, length does not exceed 50 digits |
inAmount | decimal | N | Transfer amount, 2 decimal places |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | Required | 200 | Error code, 200 for successful call, other values for failure, see error code definition | |
message | string | Optional | When the error code is not 200, this field displays the error message | ||
data | object | optional | For specific data fields, see data definition | *Note:* Specific data content |
data data:
parameter | data type | required | description |
---|---|---|---|
urlType | int | Y | url type [1:direct redirect url 2:automatic redirect form] |
url | string | Y | game address |
orderNo | string | N | order number - XAgent |
orderNoMerchant | string | N | order number - downstream merchant |
status | int | N | transfer result [0: initialization/unknown status; 1: success; 2: failure;] |
Get player balance
Interface path
POST /v3/transfer/user/balance
Interface description
This interface is used to obtain the balance of your platform users in our designated venues
Request parameters
Body:
Parameter | Data type | Required | Description |
---|---|---|---|
account | string | Y | Player account (only supports (2~8) lowercase characters or numbers) ^[a-z0-9]{2,8}$ |
password | string | Y | Account password (no more than 20 characters) |
gameType | string | Y | Game category code (see Appendix) |
coin | string | Y | Currency type (see Appendix) |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | required | 200 | error code, 200 for successful call, other values for failure, see error code definition | |
message | string | optional | When the error code is not 200, this field displays the error message | ||
data | object | optional | For specific data fields, see data data definition | *Note:* Specific data content |
data
parameter | data type | required | description |
---|---|---|---|
balance | decimal | Y | balance, 2 decimal places |
coin | string | Y | currency in the request parameter |
Transfer (up/down)
Interface path
POST /v3/transfer/user/transfer
Interface description
This interface is used to add and deduct points for a specified user
Request parameters
Body:
Parameters | Data type | Required | Description |
---|---|---|---|
account | string | Y | Player account (supports only (2~8) lowercase characters or numbers) ^[a-z0-9]{2,8}$ |
password | string | Y | Account password (no more than 20 characters) |
gameType | string | Y | Game category code (refer to the appendix) |
coin | string | Y | Currency type (refer to the appendix) |
orderNoMerchant | string | Y | Up/down order number, no more than 50 characters |
type | string | Y | Transfer category [in is up (transfer in), out is down (transfer out)] |
amount | decimal | Y | Amount, 2 decimal places |
Return data
Name | Type | Required | Default value | Notes | Other information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failure, see error code definition | ||
message | string | Optional | When the error code is not 200, this field displays the error message | ||
data | object | Optional | Specific data field, see data data definition | *Note:* Specific data content |
data data:
Parameter | Data type | Required | Description |
---|---|---|---|
orderNo | string | Y | Order number - XAgent's |
orderNoMerchant | string | Y | Order number - downstream merchant's |
status | int | Y | Transfer result [0: Initialization/unknown status; 1: Success; 2: Failure;] |
Get historical bets
Interface path
POST /v3/transfer/bet/betting
Interface description
Interface for querying historical game bets (A maximum of 5,000 pieces of data can be returned in one call)
Request parameters
Body:
Parameter | Data type | Required | Description |
---|---|---|---|
gameType | string | Y | Game category code (refer to Appendix) |
startTimestampMs | string | Y | Start timestamp |
endTimestampMs | string | Y | End timestamp, start and end time cannot exceed 12 hours |
pageIndex | string | Y | Page number |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failed call, see error code definition | ||
message | string | optional | When the error code is not 200, this field displays the error message | ||
data | String | optional | For specific data fields, see the data definition below |
data data:
parameter | data type | required | description |
---|---|---|---|
pageIndex | string | Y | page number |
pageTotal | string | Y | total number of pages |
bets | BetItemModel[] | Y | historical bet collection |
BetItemModel:
parameter | data type | required | description |
---|---|---|---|
betNoVenue | string | Y | venue bet number |
account | string | Y | player account |
coin | string | Y | currency (Refer to Appendix) |
gameType | string | Y | Game category (Refer to Appendix) |
gameCode | string | Y | Game code |
betAmount | decimal | Y | Bet amount |
validAmount | decimal | Y | Valid bet |
netWinningAmount | decimal | Y | Net win or loss |
betTimestampMs | long | Y | Bet timestamp |
settlementTimestampMs | long | Y | Settlement timestamp |
isTrial | bool | Y | Trial bet |
betState | int | Y | Bet state (Refer to Appendix) |
settlementState | int | Y | Settlement state (Refer to Appendix) |
extend | object | Y | Extended bet information, different types of bets have different extended information (Refer to Appendix) |
Transfer order query
Interface path
POST /v3/transfer/user/transfer-search
Interface description
Interface for querying transfer order details based on order number
Request parameters
Body:
Parameter | Data type | Required | Description |
---|---|---|---|
orderNoMerchant | string | Y | Up/down order number, length not exceeding 50 characters |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failure, see error code definition | ||
message | string | Not required | When the error code is not 200, this field displays the error message | ||
data | object | Not required | For specific data fields, see the TransferOrder data definition below |
data
Parameter | Data type | Required | Description |
---|---|---|---|
orderNo | string | Y | Order number - XAgent's |
orderNoMerchant | string | Y | Order number - Downstream merchant's |
status | int | Y | Transfer result [0: Initialization/unknown status; 1: Success; 2: Failure;] |
Get the game list
Interface path
POST /v3/transfer/game/list-gamecode
Interface description
Interface for getting the game list
Request parameters
Body:
Parameter | Data type | Required | Description |
---|---|---|---|
gameType | string | Y | Game category code (refer to Appendix) |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failed call, see error code definition | ||
message | string | Required | When the error code is not 200, this field displays the error message | ||
data | GameCodeList[] | Required | game collection (see appendix) |
Get game category list
interface path
POST /v3/transfer/game/list-gametype
interface description
Interface for getting game category list
request parameters
Body:
parameter | data type | required | description |
---|---|---|---|
coin | string | Y | currency type (see appendix) |
return data
name | type | required | default value | notes | other information |
---|---|---|---|---|---|
code | number | required | Error code, 200 for successful call, other values for failed call, see error code definition | ||
message | string | required | When the error code is not 200, this field displays the error message | ||
data | GameTypeList[] | required | game category collection (data structure refers to the appendix) |
Member Kickout Interface(PG Venus)
Interface Path
POST /v3/transfer/game/pgKickOut
Interface Description
PG game-specific, kick-off member offline interface, after calling, the member will be forced offline
Request Parameters
Body:
Parameter | Data Type | Required | Description |
---|---|---|---|
account | string | Y | Player Account |
gameType | string | Y | Game Category Code (refer to Appendix) |
Return Data
Name | Type | Required | Default Value | Remarks | Other Information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failure, see Error Code Definition | ||
message | string | Required | When the error code is not 200, this field displays the error message |
View order details (PG Venus)
Interface path
POST /v3/transfer/game/pgSnapshot
Interface description
PG game only, you can view the detailed game screenshot details of a certain member's PG game order. After calling the interface, it is returned in the form of a URL, and you can view it directly by visiting
Request parameters
Body:
Parameter | Data type | Required | Description |
---|---|---|---|
account | string | Y | Player account |
gameType | string | Y | Game category code (refer to Appendix) |
gameCode | string | Y | Game code (refer to Appendix) |
orderNo | string | Y | Order number |
Return data
Name | Type | Required | Default value | Remarks | Other information |
---|---|---|---|---|---|
code | number | Required | Error code, 200 for successful call, other values for failed call, see error code definition | ||
message | string | Required | When the error code is not 200, this field displays the error message | ||
data | string | Required | URL of the game order details page, you can view it by visiting it directly |
Appendix
GameType Game Category
Only some GameTypes are shown here for reference only. For details, please check the XAgent Game List document. Subsequent additions will be reflected in the document, or View the latest data through the merchant backend
Code | Name | Description |
---|---|---|
xg_electronic | XG Electronic | |
ag_electronic | AsiaGaming Electronic | |
ag_live | AsiaGaming Live | |
ax_electronic | Aviatrix Electronic | |
bng_electronic | BNG Electronic | |
cr_sport | Crown Sports | |
dg_live | DreamGaming Live | |
evo_live | Evolution Live | |
fb_sport | FB Sports | |
fg_brand | FunGaming Chess | |
imty_sport | InplayMatrix Sports | |
jdb_electronic | Duobao Electronic | |
ky_brand | Kaiyuan Chess | |
mg_electronic | MicroGaming Electronic | |
nlc_electronic | NoLimitCity Electronic | |
ob_live | DB (formerly OB) Live | |
obty_sport | Panda Sports | |
pg_electronic | PocketGames Electronic | |
png_electronic | PlayNGo Electronic | |
pp_electronic | PragmaticPlay Electronic | |
pp_live | PragmaticPlay Live | |
rt_electronic | Red Tiger Electronic | |
sc_lottery | SHI CAI Lottery | |
sexy_live | Sexy Live | |
shb_sport | Sabah Sports |
Coin Currency
Subsequent additions will be reflected in the document, or you can view the latest data through the merchant backend
Code | Name | Description |
---|---|---|
aud | Australian Dollar | |
bdt | Bangladeshi Taka | |
brl | Brazilian Real | |
cny | Chinese Yuan | |
eur | Euro | |
hkd | Hong Kong dollar | |
idr | Indonesian rupiah | |
inr | Indian rupee | |
irr | Iranian rial | |
jpy | Japanese yen | |
khr | Cambodian riel | |
krw | Korean won | |
mmk | Myanmar kyat | |
myr | Malaysian ringgit | |
ngn | Nigerian naira | |
npr | Nepalese rupee | |
php | Philippine peso | |
pkr | Pakistani rupee | |
pyg | Paraguayan jalan | |
rub | Russian ruble | |
sgd | Singapore dollar | |
thb | Thai baht | |
twd | Taiwan dollar | |
usd | US dollar | |
vnd | Vietnamese dong | |
usdt | USDT |
Lang language
Subsequent additions will be reflected in the document, or you can view the latest data through the merchant backend
Code | Name | Description |
---|---|---|
en | English | |
hi | Hindi | |
id | Indonesian | |
ja | Japanese | |
ko | Korean | |
pt | Portuguese | |
ta | Tamil | |
th | Thai | |
vi | Vietnamese | |
zh | Chinese | |
zh_hant | Chinese-Traditional |
BetOperateStates bet processing results
Code | Name | Description |
---|---|---|
0 | Unknown, default value when no value is assigned or any situation where it is uncertain whether it is successful, also a failure | |
1 | Success | |
2 | Failure | |
3 | Insufficient balance | |
4 | Player does not exist | |
20 | Bet does not exist | |
21 | Duplicate bet | |
22 | Bet settled | |
23 | Bet canceled | |
24 | Bet rolled back |
BillOperateStates Bill processing results
Code | Name | Description |
---|---|---|
0 | Unknown, default value when no value is assigned, or any situation where success is uncertain, also a failure | |
1 | Success | |
2 | Failure | |
3 | Insufficient balance | |
4 | Player does not exist | |
20 | Bill does not exist | |
21 | Duplicate bill | |
23 | Bill canceled |
VenueResultCodes Common error codes
Code | Name | Description |
---|---|---|
200 | Success, all others are failures | |
400 | Parameter error | |
9*** | Internal service error | |
9999 | Including any failure | |
3000 | XAgent-System maintenance | |
3001 | XAgent-IP whitelist restriction | |
3002 | The merchant has not opened this game hall or currency | |
5000 | Game hall system maintenance | |
5001 | Game hall IP whitelist restriction | |
5002 | Game hall is not accessible | |
5003 | Game hall system is busy | |
5004 | Cannot enter the lobby directly | |
5005 | Order processing | |
5006 | Insufficient balance | |
7000 | Merchant-side system maintenance | |
7001 | Merchant-side IP whitelist restriction | |
7003 | The merchant system is busy | |
7004 | The merchant account does not exist |
- 3*** series are XAgent related error codes
- 5*** series are game hall related error codes
- 7*** series are error codes returned for some specific scenarios of the merchant callback interface. When the merchant handles the callback, it can return the corresponding error code according to the actual situation
- Other error codes are general error codes, such as 200/9999
BetStates Bet Status
Code | Name | Transfer Mode | Single Wallet | Description |
---|---|---|---|---|
0 | Unknown Status | Available | Available | |
1 | The bet has been accepted and is valid | Available | Available | |
2 | Rejection/failed betting | Available | Unavailable | |
3 | Cancellation/cancellation/third-party forced withdrawal/refund | Available | Unavailable | |
4 | Order canceled | Available | Available | |
5 | Reclaim/sell | Available | Unavailable |
- The bet status of a single wallet only has two states: valid and canceled
- The unknown status will only appear when it is not available or the acquisition is wrong, and it will not appear normally
SettlementState settlement status
Code | Name |
---|---|
1 | Unsettled/Undrawn/Waiting for draw |
3 | Win/Win |
4 | Lost/didn’t win |
5 | Tie/Draw |
- This field is for reference only for some games, so please finalize the winning or losing result based on the net winning or losing calculated from the amount of bets and settlements.
GameTypeList Game category entity
Parameter | Data type | Required | Description |
---|---|---|---|
gameType | string | Y | Game category |
name | string | Y | Corresponding Chinese name |
isEnable | int | Y | Whether to enable 1. Yes 2. No |
GameCodeList Game list entity
Parameter | Data type | Required | Description |
---|---|---|---|
gameType | string | Y | Game category |
gameCode | string | Y | Game code, specific game code |
gameNameEnus | string | Y | Game English name |
gameNamePtbr | string | Y | Game Portuguese name |
gameNameZhcn | string | Y | Game Chinese name |
isEnable | int | Y | Whether to enable 1. Yes 2. No |
logoUrl | string | Y | game logo |
remark | string | Y | remark |