====== std.edi.messages ====== Infrastruktur-Nachrichten für den EDIFACT-Austausch: Empfangsquittungen, Fehlermeldungen und Freitext. Diese Nachrichten sind kein Geschäftsinhalt, sondern die technische Kommunikationsebene zwischen zwei EDI-Partnern. * **CONTRL** — Syntax-Quittung (positiv oder negativ). Jeder empfangene Interchange wird quittiert. * **APERAK** — Anwendungsebenen-Fehlermeldung. Wird nach erfolgreicher Syntax-Prüfung gesendet, wenn eine Nachricht inhaltlich abgelehnt wird. * **GENRAL** — Freitext-Nachricht für alles, was kein eigenes Message-Format hat. import std.edi.messages; // Positive Quittung auf Interchange "ICR-2026-001" senden var out: int64 := alloc(4096); var n: int64 := EdiContrlOk( "ICR-2026-001" as int64, "MYCOMPANY" as int64, "PARTNER01" as int64, out, 4096); // n = Byte-Länge des CONTRL-Segments free(out, 4096); ---- ===== Imports ===== * ''std.edi.core'' * ''std.alloc'' ---- ===== Structs ===== ==== EdiContrl (EDI_CONTRL_SIZE = 40 Bytes) ==== ^ Offset-Konstante ^ Inhalt ^ | ''EDI_CONTRL_STATUS'' | Status: ''7''=akzeptiert, ''4''=abgelehnt (Gruppen-Ebene), ''5''=abgelehnt (Nachrichten-Ebene) | | ''EDI_CONTRL_ERRCODE'' | UN/EDIFACT-Fehlercode (0 = kein Fehler) | | ''EDI_CONTRL_SEGPOS'' | Position des fehlerhaften Segments (0 = Interchange-Ebene) | | ''EDI_CONTRL_ICREF / EDI_CONTRL_ICREFLEN'' | Zeiger auf die ICR des quittierten Interchange | Status-Konstanten: ^ Konstante ^ Wert ^ Bedeutung ^ | ''EDI_CONTRL_ACCEPTED'' | 7 | Interchange vollständig akzeptiert | | ''EDI_CONTRL_REJECTED4'' | 4 | Funktionale Gruppe abgelehnt | | ''EDI_CONTRL_REJECTED5'' | 5 | Nachricht abgelehnt | Standard-Fehlercodes (UN/EDIFACT S005): ^ Konstante ^ Wert ^ Bedeutung ^ | ''EDI_ERR_SYNTAX_VER'' | 2 | Syntax-Version nicht unterstützt | | ''EDI_ERR_TEST_FLAG'' | 7 | Testflag-Mismatch | | ''EDI_ERR_INVALID_VALUE'' | 14 | Ungültiger Wert | | ''EDI_ERR_MISSING_SEG'' | 25 | Pflicht-Segment fehlt | ==== EdiAperak (EDI_APERAK_SIZE = 40 Bytes) ==== ^ Offset-Konstante ^ Inhalt ^ | ''EDI_APERAK_ERRCODE'' | Anwendungs-Fehlercode | | ''EDI_APERAK_REFMSG / EDI_APERAK_REFLEN'' | Zeiger auf referenzierte Nachrichten-ID | | ''EDI_APERAK_TEXT / EDI_APERAK_TEXTLEN'' | Zeiger auf Fehlertext | ==== EdiGenral (EDI_GENRAL_SIZE = 48 Bytes) ==== ^ Offset-Konstante ^ Inhalt ^ | ''EDI_GENRAL_SUBJECT / EDI_GENRAL_SUBJLEN'' | Betreff (aus BGM/C002) | | ''EDI_GENRAL_BODY / EDI_GENRAL_BODYLEN'' | Textkörper — **alloziert**, Caller muss freigeben | | ''EDI_GENRAL_REFMSG / EDI_GENRAL_REFLEN'' | Referenz auf die zugrundeliegende Nachricht | **Achtung GENRAL-Body**: ''EdiGenralRead'' alloziert einen Puffer für den zusammengesetzten FTX-Inhalt. Nach der Verarbeitung freigeben mit: free(peek64(result + EDI_GENRAL_BODY), peek64(result + EDI_GENRAL_BODYLEN)); ---- ===== Funktionen ===== ==== CONTRL — Syntax-Quittung ==== ^ Signatur ^ Beschreibung ^ | ''EdiContrlOk(icRef: int64, senderId: int64, receiverId: int64, out: int64, outMax: int64): int64'' | Schreibt positive CONTRL-Quittung (UCI-Status 7) | | ''EdiContrlErr(icRef: int64, segPos: int64, errCode: int64, out: int64, outMax: int64): int64'' | Schreibt negative CONTRL-Quittung mit Fehlerposition und -Code | | ''EdiContrlRead(buf: int64, bufLen: int64, result: int64): int64'' | Parst CONTRL; befüllt result (EDI_CONTRL_SIZE). Gibt ''EDI_OK'' oder Fehlercode. | ==== APERAK — Anwendungs-Fehlermeldung ==== ^ Signatur ^ Beschreibung ^ | ''EdiAperakWrite(refMsgId: int64, errCode: int64, errText: int64, out: int64, outMax: int64): int64'' | Schreibt APERAK-Nachricht; ''errText'' ist null-terminiert (oder 0 für kein Text) | | ''EdiAperakRead(buf: int64, bufLen: int64, result: int64): int64'' | Parst APERAK; befüllt result (EDI_APERAK_SIZE) | ==== GENRAL — Freitext-Nachricht ==== ^ Signatur ^ Beschreibung ^ | ''EdiGenralWrite(subject: int64, body: int64, refMsgId: int64, out: int64, outMax: int64): int64'' | Schreibt GENRAL; ''body'' wird als FTX-Segmente eingebettet | | ''EdiGenralRead(buf: int64, bufLen: int64, result: int64): int64'' | Parst GENRAL; **alloziert Puffer für Body** — nach Gebrauch freigeben | ---- ===== Codebeispiel — CONTRL-Fehler senden ===== import std.edi.messages; // Interchange "ICR-XYZ" ablehnen: Segment 5 hat ungültigen Wert var out: int64 := alloc(4096); var n: int64 := EdiContrlErr( "ICR-XYZ" as int64, 5, // Segment-Position EDI_ERR_INVALID_VALUE, // Fehlercode 14 out, 4096); // n Bytes EDIFACT-Daten in out senden ... free(out, 4096); import std.edi.messages; // Eingehende CONTRL-Quittung auswerten var result: int64 := alloc(EDI_CONTRL_SIZE); EdiContrlRead(inBuf, inBufLen, result); if (peek64(result + EDI_CONTRL_STATUS) == EDI_CONTRL_ACCEPTED) { PrintLn("Interchange akzeptiert."); } else { PrintLn("Interchange abgelehnt, Fehlercode: " + IntToStr(peek64(result + EDI_CONTRL_ERRCODE))); } free(result, EDI_CONTRL_SIZE); ---- ===== Quelldatei ===== ^ Unit ^ Datei ^ | ''std.edi.messages'' | ''std/edi/messages.lyx'' | Letzte Aktualisierung: 2026-06-16