Skip to main content

RetryBet - Bet Retry

When item and Operator Card bet operations timeout or fail due to network issues or system exceptions, VP will call this API until the operator responds with transaction success

Request Parameters

Request Before Decryption

{
"cipherText": "G0ZMDELeJwx+7JcIfIFOLJjkSzANPu6krGM2uw==..."
}
info

For encryption description, please refer to [Operator API Implementation Guide](./overview.md#1-Security Requirements)

Request After Decryption

{
"action": "retryBet",
"uid": "testaccount01",
"roundId": "testroundId001",
"transferId": "testroundId001",
"betId": "7634846433511800000",
"brand": "VP",
"currency": "THB",
"gameCode": "VP_230001_1",
"betTime": "2025-11-17T16:01:13.155Z",
"txTime": "2025-11-17T16:01:13.155Z",
"gameInfo": "{\"featureBuy\":0,\"spinID\":[\"7634278403511200000\",\"7634278403512200000\",\"7634278403513700000\"],\"cardType\":1,\"isFeatureGame\":\"\",\"deviceType\":0}",
"actualBetAmt": 0,
"validBetAmt": 0,
"winAmt": 1.3,
"jackpotWin": 0,
"jackpotContribute": 0,
"betSourceId": 1
}
ParameterTypeRequiredDescription
actionstringYesFixed as "retryBet"
uidstringYesPlayer Account
roundIdstringYesGames Round Number, used to identify a specific Games round
transferIdstringYesTransaction Unique Identifier (expected to be removed)
betIdstringYesBet ID, unique VP value
brandstringYesBrand code, fixed as VP
currencystringYesCurrency Code
gameCodestringYesGame Code
betTimestringYesBet Time
txTimestringYesSettlement Time
gameInfostringYesJSON string of Games related information
actualBetAmtnumberYesActual Bet Amount
validBetAmtnumberYesValid Bet Amount (used for turnover calculation)
winAmtnumberYesWin Amount, can be 0 or positive
jackpotWinnumberYesJackpot Win Amount, default is 0
jackpotContributenumberYesJackpot Contribution Amount, default is 0
betSourceIdnumberYesTransaction Source Code

Response Format

Success Response

{
"status": "0000",
"errText": "",
"balance": 16.00,
"responseTime": "2025-11-11T01:23:38.271Z"
}
FieldTypeDescription
statusstringStatus Code, see Status Code Description below
errTextstringError message, empty string on Success
balancenumberPlayer Balance after operation
responseTimestringResponse Time

Response Status and Transaction Result

CodeDetermineWhether to Trigger RetryBet Slip Status
0000SuccessNoEstablished
2001SuccessNoEstablished
9999FailedYesPending retry
TimeoutFailedYesPending retry

Important Notes

  1. Trigger Timing: When item and Operator Card transaction responses timeout or error, this API will be called to retry
  2. Transaction Source: Transaction source codes can be referred to in the Appendix
  3. Retry Strategy: If no Success is received, retries will continue
    • Retry Frequency: Retries once every half hour, 5 times per retry, each retry uses an an exponential backoff policy (1s, 3s, 5s, 7s, 9s)
    • Retry Duration: Maximum 7 days; if no Success response is received within 7 days, retries stop
  4. Idempotency: Must ensure that the same roundId + betId combination only processes one transaction
  5. Balance Consistency: Ensure retries do not lead to duplicate deductions or credits
  6. Parameter Adjustment: transferId will be removed and replaced by betId
  7. Jackpot Parameters: Currently no jackpot function, related parameters are reserved Fields, current default is 0