Một thư viện Python bất đồng bộ (asynchronous) để tương tác với API cổng thanh toán PayOS. Thư viện này giúp bạn dễ dàng tích hợp các dịch vụ thanh toán của PayOS vào ứng dụng Python của mình.
- Tạo liên kết thanh toán cho đơn hàng.
- Truy xuất thông tin chi tiết về liên kết thanh toán.
- Huỷ bỏ liên kết thanh toán.
- Xác nhận URL webhook với PayOS.
- Xác minh an toàn dữ liệu webhook nhờ vào cơ chế checksum.
- Hỗ trợ hoàn toàn bất đồng bộ (
async) vớiaiohttpgiúp hiệu năng cao. - Hỗ trợ
type hintinggiúp dễ lập trình và kiểm tra lỗi. - Cơ chế xử lý lỗi riêng biệt cho các lỗi đặc thù từ API PayOS.
root_project/
├── payos/
│ ├── __init__.py # Biến 'payos' thành package và export các lớp chính
│ ├── constants.py # Các hằng số API, thông báo lỗi, URL gốc
│ ├── custom_error.py # Định nghĩa exception PayOSError
│ ├── index.py # Lớp chính PayOS chứa logic gọi API
│ ├── type.py # Định nghĩa các kiểu dữ liệu cho request/response
│ └── utils.py # Các hàm tiện ích (ví dụ tạo chữ ký)
├── tests/
│ ├── __init__.py
│ ├── requirements-test.txt # Dependencies dùng cho test
│ ├── test_payos.py # Unit test cho lớp PayOS
│ └── test_types.py # Unit test cho các kiểu dữ liệu
├── pyproject.toml # Thông tin build và cấu hình project
└── readme.md # File này
-
Python 3.7 trở lên (do sử dụng
async/awaitvà type hinting). -
Thư viện
aiohttpđể gửi request bất đồng bộ. -
Tài khoản merchant tại PayOS với:
Client IDAPI KeyChecksum Key
pip install payos-asyncNếu bạn muốn chỉnh sửa mã nguồn hoặc đóng góp, có thể cài đặt từ repo:
Important
Bạn cần cài đặt Python 3.7 trở lên.
Clone mã nguồn về máy:
git clone https://github.com/ShindouAris/PayOS-Async-SDK.git
cd PayOS-Async-SDKTiến hành build và cài đặt:
pip install build
python -m build
pip install dist/payos_async_sdk-0.1.0-py3-none-any.whlMọi hàm gọi API đều là bất đồng bộ, bạn cần dùng await.
from payos import PayOS, PaymentData, ItemData
payos_client = PayOS(
client_id="YOUR_CLIENT_ID",
api_key="YOUR_API_KEY",
checksum_key="YOUR_CHECKSUM_KEY"
)payment_data = PaymentData(
orderCode=123456,
amount=1000000,
description="Thanh toán đơn hàng #123456",
cancelUrl="https://domain.com/cancel",
returnUrl="https://domain.com/success",
items=[
ItemData(name="Áo thun", quantity=1, price=500000),
ItemData(name="Quần jean", quantity=1, price=500000)
]
)
result = await payos_client.createPaymentLink(payment_data)
print(result.checkoutUrl)info = await payos_client.getPaymentLinkInformation(order_id=123456)
print(info.status, info.amountPaid)await payos_client.cancelPaymentLink(order_id=123456, cancellationReason="Khách yêu cầu huỷ")webhook_data = {
# Data nhận được từ payOS khi bạn thiết đặt một webhook
}
await payos_client.confirmWebhook(webhook_data)verified = payos_client.verifyPaymentWebhookData(webhook_body_dict)
# webhook_body_dict nhận được khi thiết đặt webhook trong kênh thanh toán
print(verified.orderCode, verified.amount)Tham khảo file payos/type.py, gồm:
ItemData: Sản phẩm trong đơn hàngPaymentData: Dữ liệu tạo đơnCreatePaymentResult: Kết quả từcreatePaymentLinkTransaction: Giao dịch liên quanPaymentLinkInformation: Thông tin liên kếtWebhookData: Dữ liệu webhook đã xác minh
-
Nếu nhập sai dữ liệu đầu vào → raise
TypeError,ValueError -
Nếu API trả về lỗi → raise
PayOSError- Có
.codevà.message
- Có
-
Nếu chữ ký không khớp → raise
Exception
Ví dụ:
try:
await payos_client.createPaymentLink(payment_data)
except PayOSError as e:
print(f"Lỗi PayOS: {e.code} - {e}")
except Exception as e:
print(f"Lỗi khác: {e}")Rất hoan nghênh đóng góp!
- Fork repo
- Tạo branch mới
- Gửi pull request rõ ràng
Mã nguồn được phát hành theo giấy phép MIT.