ข้ามไปยังเนื้อหา

Справочник API pacs008 Справочник API pacs008

โครงการนี้จัดเตรียมทั้ง REST API และ CLI สำหรับเวิร์กโฟลว์การประมวลผลข้อความการชำระเงินเชิงปฏิบัติการ

บันทึกการติดตั้งใช้งาน บันทึกการติดตั้งใช้งาน

  • ใช้การสร้างแบบซิงโครนัสสำหรับการตรวจสอบเชิงปฏิบัติการและงานเป็นชุดขนาดเล็กเมื่อผู้เรียกต้องการ XML ทันที
  • ใช้การสร้างแบบอะซิงโครนัสเมื่อไฟล์อินพุตมีขนาดใหญ่ งานต้องลองใหม่ หรือการสร้างเป็นส่วนหนึ่งของระบบประสานงานที่กว้างกว่า
  • เก็บทั้งข้อมูลนำเข้าต้นทางและรายงานการตรวจสอบไว้ เพื่อให้ทีมสนับสนุนสามารถสร้างผลลัพธ์ XML ซ้ำได้ระหว่างเกิดเหตุการณ์
  • ตรึงเส้นทางของแม่แบบและ XSD ไว้ในค่ากำหนดการปรับใช้ เพื่อหลีกเลี่ยงการอัปเกรดแบบเงียบ

การติดตั้ง การติดตั้ง

ติดตั้งแพ็คเกจจาก PyPI ต้องใช้ Python 3.9.2 หรือสูงกว่า

bash
python -m pip install pacs008

REST API REST API

เริ่มเซิร์ฟเวอร์ FastAPI ในตัวเพื่อเปิดใช้งาน HTTP endpoints สำหรับการตรวจสอบความถูกต้องและการสร้าง

เริ่มเซิร์ฟเวอร์ เริ่มเซิร์ฟเวอร์

bash
uvicorn pacs008.api.app:app --reload --host 0.0.0.0 --port 8000

Endpoints Endpoints

Endpointคำอธิบาย
GET /healthตรวจสอบสถานะ — คืนค่าสถานะบริการ
POST /validateตรวจสอบข้อมูลการชำระเงินกับสคีมาโดยไม่สร้าง XML
POST /generateสร้าง XML แบบซิงโครนัสและส่งคืนไฟล์
POST /generate/asyncส่งงานสร้างแบบอะซิงโครนัส
GET /status/{job_id}ตรวจสอบสถานะงานตาม ID
GET /download/{job_id}ดาวน์โหลด XML ที่สร้างแล้วเมื่องานเสร็จสิ้น
DELETE /jobs/{job_id}ยกเลิกงานที่รอดำเนินการหรือกำลังดำเนินการ
GET /docsSwagger UI แบบโต้ตอบสำหรับสำรวจและทดสอบ endpoints ทั้งหมด
  • pacs.002.001.12 — รายงานสถานะการชำระเงินระหว่างสถาบันการเงิน
  • pacs.003.001.09 — การหักบัญชีลูกค้าระหว่างสถาบันการเงิน
  • pacs.004.001.11 — การคืนเงินชำระ
  • pacs.007.001.11 — การกลับรายการชำระเงินระหว่างสถาบันการเงิน
  • pacs.008.001.13 — การโอนเครดิตลูกค้าระหว่างสถาบันการเงิน
  • pacs.009.001.10 — การโอนเครดิตระหว่างสถาบันการเงิน
  • pacs.010.001.05 — การหักบัญชีระหว่างสถาบันการเงิน
  • pacs.028.001.05 — คำขอสถานะการชำระเงินระหว่างสถาบันการเงิน

ตัวอย่างการตรวจสอบความถูกต้อง ตัวอย่างการตรวจสอบความถูกต้อง

ส่งข้อมูลการชำระเงินเพื่อตรวจสอบความถูกต้องก่อนสร้าง XML

bash
curl -X POST http://localhost:8000/api/validate \
  -H "Content-Type: application/json" \
  -d '{
    "message_type": "pacs.008.001.13",
    "data": [{
      "msg_id": "MSG-2026-001",
      "creation_date_time": "2026-01-15T10:30:00",
      "nb_of_txs": "1",
      "settlement_method": "CLRG",
      "interbank_settlement_date": "2026-01-15",
      "end_to_end_id": "E2E-INV-2026-001",
      "interbank_settlement_amount": "25000.00",
      "interbank_settlement_currency": "EUR",
      "charge_bearer": "SHAR",
      "debtor_name": "Acme Corp GmbH",
      "debtor_agent_bic": "DEUTDEFF",
      "creditor_agent_bic": "COBADEFF",
      "creditor_name": "Widget Industries SA"
    }]
  }'
json
{
  "valid": true,
  "message_type": "pacs.008.001.13",
  "errors": [],
  "warnings": []
}

ตัวอย่างการสร้างแบบซิงโครนัส ตัวอย่างการสร้างแบบซิงโครนัส

สร้างไฟล์ XML pacs.008.001.13 จากข้อมูล JSON

bash
curl -X POST http://localhost:8000/api/generate \
  -H "Content-Type: application/json" \
  -d '{
    "message_type": "pacs.008.001.13",
    "template": "pacs008/templates/pacs.008.001.13/template.xml",
    "schema": "pacs008/templates/pacs.008.001.13/pacs.008.001.13.xsd",
    "data": [{
      "msg_id": "MSG-2026-001",
      "creation_date_time": "2026-01-15T10:30:00",
      "nb_of_txs": "1",
      "settlement_method": "CLRG",
      "interbank_settlement_date": "2026-01-15",
      "end_to_end_id": "E2E-INV-2026-001",
      "tx_id": "TX-001",
      "interbank_settlement_amount": "25000.00",
      "interbank_settlement_currency": "EUR",
      "charge_bearer": "SHAR",
      "debtor_name": "Acme Corp GmbH",
      "debtor_agent_bic": "DEUTDEFF",
      "creditor_agent_bic": "COBADEFF",
      "creditor_name": "Widget Industries SA"
    }]
  }' --output pacs008_output.xml

การสร้างแบบอะซิงโครนัส การสร้างแบบอะซิงโครนัส

สำหรับไฟล์ขนาดใหญ่หรือการใช้งานในไปป์ไลน์ ให้ส่งงานแบบ async และตรวจสอบจนกว่าจะเสร็จสิ้น

bash
# Submit the job
JOB=$(curl -s -X POST http://localhost:8000/api/generate/async \
  -H "Content-Type: application/json" \
  -d '{"message_type":"pacs.008.001.13","data":[...]}')

JOB_ID=$(echo $JOB | jq -r '.job_id')

# Poll for completion
curl http://localhost:8000/api/status/$JOB_ID

# Download the result
curl http://localhost:8000/api/download/$JOB_ID --output result.xml
json
{
  "job_id": "8f7f0d4b-7df9-4d1a-8d47-19f4f28b6d38",
  "status": "completed",
  "message_type": "pacs.008.001.13",
  "download_url": "/api/download/8f7f0d4b-7df9-4d1a-8d47-19f4f28b6d38"
}

CLI CLI

อินเทอร์เฟซบรรทัดคำสั่งรับไฟล์ข้อมูล เวอร์ชันข้อความ เทมเพลต และสคีมา โดยจะตรวจสอบอินพุตและเขียน XML ที่สร้างไปยังไดเรกทอรีเอาต์พุต

การใช้งานพื้นฐาน การใช้งานพื้นฐาน

bash
pacs008 -t <message_type> \
  -m <template_file> \
  -s <schema_file> \
  -d <data_file>

ตัวอย่าง ตัวอย่าง

bash
pacs008 -t pacs.008.001.13 \
  -m pacs008/templates/pacs.008.001.13/template.xml \
  -s pacs008/templates/pacs.008.001.13/pacs.008.001.13.xsd \
  -d payments.csv

โหมด Dry-run โหมด Dry-run

ใช้ --dry-run เพื่อตรวจสอบข้อมูลอินพุตโดยไม่สร้าง XML รหัสออกแสดงว่าการตรวจสอบผ่าน (0) หรือล้มเหลว (1)

bash
pacs008 -t pacs.008.001.13 \
  -m pacs008/templates/pacs.008.001.13/template.xml \
  -s pacs008/templates/pacs.008.001.13/pacs.008.001.13.xsd \
  -d payments.csv \
  --dry-run

เพิ่ม --verbose สำหรับผลลัพธ์โดยละเอียดระหว่างการสร้าง


Python API Python API

ใช้ไลบรารีโดยตรงใน Python scripts หรือบริการ

สร้าง XML จากรายการบันทึกการชำระเงิน สร้าง XML จากรายการบันทึกการชำระเงิน

python
from pacs008 import generate_xml_string

payments = [{
    "msg_id": "MSG-2026-001",
    "creation_date_time": "2026-01-15T10:30:00",
    "nb_of_txs": "1",
    "settlement_method": "CLRG",
    "interbank_settlement_date": "2026-01-15",
    "end_to_end_id": "E2E-INV-2026-001",
    "tx_id": "TX-001",
    "interbank_settlement_amount": "25000.00",
    "interbank_settlement_currency": "EUR",
    "charge_bearer": "SHAR",
    "debtor_name": "Acme Corp GmbH",
    "debtor_agent_bic": "DEUTDEFF",
    "creditor_agent_bic": "COBADEFF",
    "creditor_name": "Widget Industries SA",
}]

xml = generate_xml_string(
    payments,
    "pacs.008.001.13",
    "pacs008/templates/pacs.008.001.13/template.xml",
    "pacs008/templates/pacs.008.001.13/pacs.008.001.13.xsd",
)
print(xml)

การตรวจสอบความสอดคล้อง SWIFT การตรวจสอบความสอดคล้อง SWIFT

ตรวจสอบและทำความสะอาดข้อมูลตามกฎชุดอักขระและความยาวฟิลด์ของ SWIFT ก่อนสร้าง

python
from pacs008.compliance import cleanse_data_with_report

raw = [{"debtor_name": "Müller & Söhne™", "msg_id": "X" * 50}]
clean, report = cleanse_data_with_report(raw)
print(report.summary())

Docker Docker

รัน API ในคอนเทนเนอร์โดยใช้ Dockerfile ที่แนบมา

bash
docker build -t pacs008:latest .
docker run -p 8000:8000 pacs008:latest
bash
docker run --rm   -e PACS008_LOG_LEVEL=INFO   -v $PWD/examples:/data   -p 8000:8000 pacs008:latest

การตรวจสอบ IBAN และ BIC การตรวจสอบ IBAN และ BIC

ตรวจสอบตัวระบุทางการเงินโดยไม่ขึ้นกับการสร้าง XML

python
from pacs008.validation import validate_iban, validate_bic

is_valid, error = validate_iban("DE89370400440532013000", strict=False)
is_valid, error = validate_bic("DEUTDEFF", strict=False)

การประมวลผลแบบสตรีม การประมวลผลแบบสตรีม

โหลดชุดข้อมูลขนาดใหญ่ในส่วนย่อยที่กำหนดค่าได้เพื่อจำกัดการใช้หน่วยความจำ

python
from pacs008.data.loader import load_payment_data_streaming

for chunk in load_payment_data_streaming("large_payments.csv", chunk_size=500):
    print(f"Processing {len(chunk)} records")
python
from pacs008.validation import validate_batch

for chunk in load_payment_data_streaming("large_payments.csv", chunk_size=500):
    report = validate_batch(chunk, "pacs.008.001.13")
    print(report.summary())

บริการตรวจสอบ บริการตรวจสอบ

เรียกใช้ pipeline การตรวจสอบก่อนสร้างแบบเต็มรูปแบบโดยทางโปรแกรม

python
from pacs008.validation import ValidationService, ValidationConfig

service = ValidationService()
report = service.validate_all(ValidationConfig(
    xml_message_type="pacs.008.001.13",
    xml_template_file_path="pacs008/templates/pacs.008.001.13/template.xml",
    xsd_schema_file_path="pacs008/templates/pacs.008.001.13/pacs.008.001.13.xsd",
    data_file_path="payments.csv",
))
print(report.is_valid, report.errors)

ฟิลด์ข้อมูลที่จำเป็น ฟิลด์ข้อมูลที่จำเป็น

ทุกบันทึกการชำระเงินต้องมีฟิลด์ต่อไปนี้ ฟิลด์เฉพาะเวอร์ชันจะระบุไว้ตามความเหมาะสม

ฟิลด์คำอธิบายข้อจำกัด
msg_idตัวระบุข้อความสูงสุด 35 อักขระ
creation_date_timeประทับเวลาการสร้างรูปแบบ ISO 8601
nb_of_txsจำนวนธุรกรรมจำนวนเต็มบวก
settlement_methodวิธีการชำระบัญชีCLRG, INDA, COVE หรือ INGA
end_to_end_idตัวระบุแบบครบวงจรสูงสุด 35 อักขระ
interbank_settlement_amountจำนวนเงินชำระบัญชีระหว่างธนาคารทศนิยม เช่น `25000.00`
interbank_settlement_currencyสกุลเงินชำระบัญชีรหัส ISO 4217
charge_bearerผู้รับผิดชอบค่าธรรมเนียมDEBT, CRED, SHAR หรือ SLEV
debtor_nameชื่อลูกหนี้สูงสุด 140 อักขระ
debtor_agent_bicBIC ตัวแทนลูกหนี้8 หรือ 11 อักขระ
creditor_agent_bicBIC ตัวแทนเจ้าหนี้8 หรือ 11 อักขระ
creditor_nameชื่อเจ้าหนี้สูงสุด 140 อักขระ

ฟิลด์เฉพาะเวอร์ชัน ฟิลด์เฉพาะเวอร์ชัน

ฟิลด์คำอธิบายข้อจำกัด
uetrการอ้างอิงธุรกรรมแบบครบวงจรที่ไม่ซ้ำกันรูปแบบ UUID — ใช้ได้ตั้งแต่ v08
mandate_idตัวระบุคำสั่งมอบอำนาจใช้ได้ตั้งแต่ v10
expiry_date_timeประทับเวลาหมดอายุข้อความใช้ได้ใน v13

อัปเดตล่าสุด: