Skip to content

🔐 Authentication / Xác thực đối tác

🧭 Giới thiệu

Hệ thống Pay2S Partner API sử dụng cơ chế xác thực hai tầng để đảm bảo an toàn cho các kết nối từ phía đối tác.

  1. Bước 1: Đối tác đăng nhập vào Pay2S.vn để lấy Access KeySecret Key.
  2. Bước 2: Sử dụng cặp khóa này để thực hiện Basic Authentication, lấy về Bearer Token tạm thời.
  3. Bước 3: Dùng Bearer Token này để gọi các API như /v1/banks, /v1/webhooks, /v1/metrics, v.v.

🧩 Luồng xác thực tổng quan

mermaid
sequenceDiagram
    participant C as Client (Partner)
    participant G as Pay2S Partner Gateway
    participant A as Auth Service
    participant API as Protected API

    C->>G: POST /v1/auth/authorize (Basic Auth)
    G->>A: Xác minh Access Key / Secret Key
    A-->>G: Trả về Bearer Token (hiệu lực 3600s)
    G-->>C: 200 OK + token
    C->>API: Authorization: Bearer {token}
    API-->>C: Trả về dữ liệu (banks, webhooks,...)

🧾 Thông tin chi tiết

Endpoint

POST https://api-partner.pay2s.vn/v1/auth/authorize

Headers

Tên headerGiá trị mẫuMô tả
AuthorizationBasic base64(access_key:secret_key)Dạng xác thực cơ bản
Content-Typeapplication/jsonBắt buộc

Ví dụ Base64

Giả sử:

access_key = e222c2c10059cca0e27bf43d0438bba372
secret_key = 83f84c5a1d94ad4a1d3810292ad55a0d

→ Ghép chuỗi:
e222c2c10059cca0e27bf43d0438bba372:83f84c5a1d94ad4a1d3810292ad55a0d
→ Mã hoá Base64 thành:
ZT222c2c10059cca0e27bf43d0438bba372OjgzZjg0YzVhMWQ5NGFkNGExZDM4MTAyOTJhZDU1YTBk

→ Header:

Authorization: Basic ZT222c2c10059cca0e27bf43d0438bba372OjgzZjg0YzVhMWQ5NGFkNGExZDM4MTAyOTJhZDU1YTBk

🧠 Phản hồi mẫu

✅ Thành công

json
{
  "success": true,
  "data": {
    "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9....",
    "expires_in": 3600
  }
}

❌ Lỗi xác thực

json
{
  "success": false,
  "error": {
    "code": "BASIC_REQUIRED",
    "message": "Use Basic base64(access_key:secret_key)"
  }
}

🧩 Gọi API bằng Token

Sau khi nhận được Bearer Token, bạn có thể gọi các endpoint bảo mật khác như sau:

Ví dụ:

GET https://api-partner.pay2s.vn/v1/banks HTTP/1.1
Host: partner.pay2s.vn
Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...

Kết quả:

json
{
  "success": true,
  "data": [
    { "bank": "ACB", "accountNumber": "123456789", "status": "active" },
    { "bank": "VCB", "accountNumber": "987654321", "status": "inactive" }
  ]
}

🔑 Gợi ý

  • Token có hiệu lực 3600 giây (1 giờ). Sau khi hết hạn, cần gọi lại /v1/auth/authorize để lấy token mới.
  • Hỗ trợ xác thực Basic Auth → Bearer Token (không cần tạo chữ ký HMAC thủ công).