> ## Documentation Index
> Fetch the complete documentation index at: https://doc.haipay.net/llms.txt
> Use this file to discover all available pages before exploring further.

# ZAR Disbursement Application

<div class="flex flex-col gap-4">
  <div class="api-section-heading flex flex-col gap-y-4 w-full">
    <div class="flex items-baseline border-b pb-2.5 border-gray-100 dark:border-gray-800 w-full">
      <h4 class="api-section-heading-title flex-1 mb-0">Secret Key & Private Key (Generate Signature)</h4>
    </div>

    <div />
  </div>

  <input id="secret-key" placeholder="Secret Key" class="px-3 py-2 border rounded-md" />

  <input id="private-key" placeholder="Private Key" class="px-3 py-2 border rounded-md" />
</div>

## Related Topics

* [South Africa Payment API](/docs/en/api/version2/SouthAfrica)
* [HaiPay API Reference Overview](/docs/en/api-reference/overview)
* [HaiPay Configuration and Signature Guide](/docs/en/guide/config_settings_and_signature_rules_guide)


## OpenAPI

````yaml docs/en/api-reference/zar/zar.openapi.json POST /zar/pay/apply
openapi: 3.0.1
info:
  title: 默认模块
  description: ''
  version: 1.0.0
servers:
  - url: https://uat-interface.haipay.asia
    description: 测试-interface
security: []
tags: []
paths:
  /zar/pay/apply:
    post:
      tags: []
      summary: ZAR Disbursement Application
      parameters: []
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                appId:
                  type: integer
                  description: >-
                    Business ID (obtained from backend, must match the currency
                    in the URL)
                orderId:
                  type: string
                  description: Merchant order ID (must be unique, length ≤ 48)
                  maxLength: 48
                amount:
                  type: string
                  description: 'Transaction amount (unit: ZAR) Range: 2-1,000,000'
                accountType:
                  type: string
                  description: 'Account type: BANK_ACCOUNT'
                  enum:
                    - BANK_ACCOUNT
                bankCode:
                  type: string
                  description: Bank code
                accountNo:
                  type: string
                  description: User bank account number
                name:
                  type: string
                  description: >-
                    Recipient name (Format: English characters only, 1–30
                    characters, "firstName middleName lastName" (middleName is
                    optional and does not support special characters or
                    numbers.))
                  minLength: 1
                  maxLength: 30
                phone:
                  type: string
                  description: Real phone number
                email:
                  type: string
                  description: Real email address
                  format: email
                notifyUrl:
                  type: string
                  description: Callback URL
                  format: uri
                subject:
                  type: string
                  description: >-
                    Payment note (transaction title, product name, payment
                    reason)
                body:
                  type: string
                  description: Detailed note
                partnerUserId:
                  type: string
                  description: >-
                    User unique identifier (e.g., userId). Used by risk control,
                    must be valid. Format: numbers, letters, or common symbols
                    -~!@#$%&*()_.
                  pattern: ^[A-Za-z0-9\-~!@#$%&*()_]+$
                sign:
                  type: string
                  description: Signature
              required:
                - appId
                - orderId
                - amount
                - accountType
                - bankCode
                - accountNo
                - name
                - phone
                - email
                - partnerUserId
                - sign
              additionalProperties: false
            examples: {}
        required: true
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  status:
                    type: string
                    description: '1: Normal, 0: Exception'
                  error:
                    type: string
                    description: Error code
                  msg:
                    type: string
                    description: Error description
                  data:
                    type: object
                    properties:
                      orderId:
                        type: string
                        description: Merchant order ID (must be unique)
                      orderNo:
                        type: string
                        description: Platform order ID
                      sign:
                        type: string
                        description: Signature
                    additionalProperties: true
                additionalProperties: true
      deprecated: false
      security: []

````