Hoppa till innehåll

pacs008 API-referens pacs008 API-referens

Projektet tillhandahåller både ett REST-API och CLI för operativa arbetsflöden för betalningsmeddelanden.

Installation Installation

Installera paketet från PyPI. Kräver Python 3.9.2 eller senare.

bash
python -m pip install pacs008

REST API REST API

Starta den inbyggda FastAPI-servern för att tillhandahålla HTTP-ändpunkter för validering och generering.

Starta servern Starta servern

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

Ändpunkter Ändpunkter

EndpointBeskrivning
GET /healthHälsokontroll — returnerar tjänstens status
POST /validateValidera betalningsdata mot schema utan att generera XML
POST /generateGenerera XML synkront och returnera filen
POST /generate/asyncSkicka in ett asynkront genereringsjobb
GET /status/{job_id}Kontrollera jobbstatus med ID
GET /download/{job_id}Ladda ner genererad XML efter att jobbet är klart
DELETE /jobs/{job_id}Avbryt ett väntande eller pågående jobb
GET /docsInteraktivt Swagger UI för att utforska och testa alla ändpunkter

Valideringsexempel Valideringsexempel

Skicka in betalningsdata för validering innan XML genereras.

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": []
}

Synkront genereringsexempel Synkront genereringsexempel

Generera en XML-fil för pacs.008.001.13 från JSON-data.

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

Asynkron generering Asynkron generering

För större filer eller pipelineanvändning, skicka in ett asynkront jobb och polla tills det är klart.

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

Kommandoradsgränssnittet tar en datafil, meddelandeversion, mall och schema. Det validerar indata och skriver genererad XML till utdatakatalogen.

Grundläggande användning Grundläggande användning

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

Exempel Exempel

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

Torrkörningsläge Torrkörningsläge

Använd --dry-run för att validera indata utan att generera XML. Utgångskoden visar om valideringen lyckades (0) eller misslyckades (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

Lägg till --verbose för detaljerad utdata under generering.


Python API Python API

Använd biblioteket direkt i Python-skript eller tjänster.

Generera XML från betalningsposter Generera XML från betalningsposter

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-efterlevnadskontroll SWIFT-efterlevnadskontroll

Kontrollera och rensa data mot SWIFT:s tecken- och fältlängdsregler före generering.

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

Kör API:et i en container med den medföljande 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- och BIC-validering IBAN- och BIC-validering

Validera finansiella identifierare oberoende av XML-generering.

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)

Strömning Strömning

Ladda stora dataset i konfigurerbara block för att begränsa minnesanvändningen.

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())

Valideringstjänst Valideringstjänst

Kör hela förgenereringens valideringspipeline programmatiskt.

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)

Obligatoriska datafält Obligatoriska datafält

Varje betalningspost måste innehålla dessa fält. Versionsspecifika fält listas nedan.

FältBeskrivningBegränsning
msg_idMeddelandeidentifierareMax 35 tecken
creation_date_timeTidsstämpel för skapandeISO 8601-format
nb_of_txsAntal transaktionerPositivt heltal
settlement_methodAvvecklingsmetodCLRG, INDA, COVE eller INGA
end_to_end_idIdentifierare från början till slutMax 35 tecken
interbank_settlement_amountInterbankavvecklingsbeloppDecimal, t.ex. `25000.00`
interbank_settlement_currencyAvvecklingsvalutaISO 4217-kod
charge_bearerAvgiftsbärareDEBT, CRED, SHAR eller SLEV
debtor_nameGäldenärens namnMax 140 tecken
debtor_agent_bicGäldenärsagentens BIC8 eller 11 tecken
creditor_agent_bicBorgenärsagentens BIC8 eller 11 tecken
creditor_nameBorgenärens namnMax 140 tecken

Versionsspecifika fält Versionsspecifika fält

FältBeskrivningBegränsning
uetrUnik transaktionsreferens från början till slutUUID-format — tillgänglig från v08
mandate_idMandatidentifierareTillgänglig från v10
expiry_date_timeTidsstämpel för meddelandets utgångTillgänglig i v13

Senast uppdaterad: