WorldFirst DocsWorldFirst Docs

Receive payout result notificationSignature required

POST /undefined

WorldFirst sends notifications of the payout result with this interface. The Partner can set up the URL for receiving payout notifications by specifying the transferToDetail.transferNotifyUrl field when calling createPayout.

The Partner needs to acknowledge the reception of the notification. For more details, refer to the Result processing logic section.

Structure

A message consists of a header and body.

Request header parameters

Field

Required

Sample

Description

Client-Id

Yes

Client-Id: *****

For detailed field descriptions, see API Overview.

Signature

Yes

Signature: algorithm=RSA256, keyVersion=2, signature=*****

Content-Type

Yes

Content-Type: application/json; charset=UTF-8

Request-Time

Yes

Request-Time: 2019-04-04T12:08:56+08:00

Request parameters

transferResult Result  REQUIRED

Indicates the result of the payout request.

Show child parameters

transferRequestId String  REQUIRED

The unique ID assigned by the Partner to identify a payout request.

More information:

  • This field is an API idempotency field.For details about API idempotency, see the Idempotency chapter.
  • Maximum length: 64 characters

transferId String  REQUIRED

The unique ID assigned by WorldFirst to identify a payout.

More information:

  • Maximum length: 64 characters

transferFinishTime DateTime  REQUIRED

Indicates the finishing time of a payout.

More information:

  • The value follows the ISO 8601 standard format. For example, "2019-11-27T12:01:01+08:00".

transferFromDetail TransferFromDetail  REQUIRED

Payout details submitted by the payer.

Show child parameters

transferToDetail TransferToDetail  REQUIRED

Payout details for the beneficiary.

Show child parameters

Response parameters

result Result  REQUIRED

Indicates whether this API is called successfully.

Show child parameters
API Explorer

Request

Request Body

Response

Response Body

Result processing logic

transferResult.resultStatus indicates the result of the payout. For more details, refer to the result codes section.

After receiving the notification, you need to send a response message to acknowledge the receipt of the notification.

The Partner needs to properly sign the message before making the response. For details, refer to the Sign a request and validate the signature chapter.

The response header observes the following structure:

  • Signature: Required. Example: Signature: algorithm=RSA256, keyVersion=2, signature=*****
  • Content-Type: Required. Example: Content-Type: application/json; charset=UTF-8
  • Client-Id: Required. Example: Client-Id: *****
  • Response-Time: Required. Example: Response-Time: 2019-04-04T12:08:56+08:00

For more details about the response message, refer to the API overview chapter.

The response body has the following fixed value:

Sample Code

In the absense of an ackowledgement reponse from the Partner, WorldFirst will resend the result.

The following policy represents how WorldFirst makes retry attempts:

  • WorldFirst retries notifications 7 times.
  • Intervals between notifications: 2m, 10m, 10m, 1h, 2h, 6h, and 15h.

result.resultCode

CodeValueMessageFurther action
SUCCESSSSuccess
UNKNOWN_EXCEPTIONUAPI failed due to unknown reason.

The service might be down, retry later.

PROCESS_FAILFA general business failure occurred. Do not retry.

Human intervention is usually needed.

transferResult.resultCode

CodeValueMessageFurther action
SUCCESSSSuccess
PROCESSINGSThe transfer is in process.

Try again later.

PROCESS_FAILFA general business failure occurred. Do not retry.

Human intervention is usually needed. It is recommended that you contact our Technical Support Team to resolve the issue.

USER_ACCOUNT_ABNORMALFThe user account status is abnormal.

Retry with a different user. If the issue persists, contact our Technical Support Team for more details.

AMOUNT_EXCEED_LIMITFThe amount exceeds the limit.

Make sure the amount submitted is correct and retry.

RISK_REJECTFThe transfer is rejected for risk control reasons.

Prompt the user that the request is rejected because the risk control failed.

ORDER_IS_CLOSEDFThe order is closed.

Retry with another payout order.

ORDER_IS_REVERSEDFThe order is reversed.

Retry with another payout order.

ORDER_NOT_FOUNDUOrder not found.

Retry with correct order information.

CARD_INFO_NOT_MATCHFThe card information does not match.

Retry with another payout order.

BALANCE_NOT_ENOUGHFBalance is not enough.

Make sure the balance is sufficient and retry.