Source code for fints.segments.message

from fints.fields import (
    CodeField, DataElementField, DataElementGroupField,
    SegmentSequenceField, ZeroPaddedNumericField,
)
from fints.formals import (
    Certificate, CompressionFunction, EncryptionAlgorithm,
    HashAlgorithm, KeyName, ReferenceMessage, SecurityApplicationArea,
    SecurityDateTime, SecurityIdentificationDetails, SecurityProfile,
    SecurityRole, SignatureAlgorithm, UserDefinedSignature,
)

from .base import FinTS3Segment


[docs]class HNHBK3(FinTS3Segment): """Nachrichtenkopf""" message_size = ZeroPaddedNumericField(length=12, _d="Größe der Nachricht (nach Verschlüsselung und Komprimierung)") hbci_version = DataElementField(type='num', max_length=3, _d="HBCI-Version") dialog_id = DataElementField(type='id', _d="Dialog-ID") message_number = DataElementField(type='num', max_length=4, _d="Nachrichtennummer") reference_message = DataElementGroupField(type=ReferenceMessage, required=False, _d="Bezugsnachricht")
[docs]class HNHBS1(FinTS3Segment): """Nachrichtenabschluss""" message_number = DataElementField(type='num', max_length=4, _d="Nachrichtennummer")
[docs]class HNVSK3(FinTS3Segment): """Verschlüsselungskopf, version 3 Source: FinTS Financial Transaction Services, Sicherheitsverfahren HBCI""" security_profile = DataElementGroupField(type=SecurityProfile, _d="Sicherheitsprofil") security_function = DataElementField(type='code', max_length=3, _d="Sicherheitsfunktion, kodiert") security_role = CodeField(SecurityRole, max_length=3, _d="Rolle des Sicherheitslieferanten, kodiert") security_identification_details = DataElementGroupField(type=SecurityIdentificationDetails, _d="Sicherheitsidentifikation, Details") security_datetime = DataElementGroupField(type=SecurityDateTime, _d="Sicherheitsdatum und -uhrzeit") encryption_algorithm = DataElementGroupField(type=EncryptionAlgorithm, _d="Verschlüsselungsalgorithmus") key_name = DataElementGroupField(type=KeyName, _d="Schlüsselname") compression_function = CodeField(CompressionFunction, max_length=3, _d="Komprimierungsfunktion") certificate = DataElementGroupField(type=Certificate, required=False, _d="Zertifikat")
[docs]class HNVSD1(FinTS3Segment): """Verschlüsselte Daten, version 1 Source: FinTS Financial Transaction Services, Sicherheitsverfahren HBCI""" data = SegmentSequenceField(_d="Daten, verschlüsselt")
[docs]class HNSHK4(FinTS3Segment): """Signaturkopf, version 4 Source: FinTS Financial Transaction Services, Sicherheitsverfahren HBCI""" security_profile = DataElementGroupField(type=SecurityProfile, _d="Sicherheitsprofil") security_function = DataElementField(type='code', max_length=3, _d="Sicherheitsfunktion, kodiert") security_reference = DataElementField(type='an', max_length=14, _d="Sicherheitskontrollreferenz") security_application_area = CodeField(SecurityApplicationArea, max_length=3, _d="Bereich der Sicherheitsapplikation, kodiert") security_role = CodeField(SecurityRole, max_length=3, _d="Rolle des Sicherheitslieferanten, kodiert") security_identification_details = DataElementGroupField(type=SecurityIdentificationDetails, _d="Sicherheitsidentifikation, Details") security_reference_number = DataElementField(type='num', max_length=16, _d="Sicherheitsreferenznummer") security_datetime = DataElementGroupField(type=SecurityDateTime, _d="Sicherheitsdatum und -uhrzeit") hash_algorithm = DataElementGroupField(type=HashAlgorithm, _d="Hashalgorithmus") signature_algorithm = DataElementGroupField(type=SignatureAlgorithm, _d="Signaturalgorithmus") key_name = DataElementGroupField(type=KeyName, _d="Schlüsselname") certificate = DataElementGroupField(type=Certificate, required=False, _d="Zertifikat")
[docs]class HNSHA2(FinTS3Segment): """Signaturabschluss, version 2 Source: FinTS Financial Transaction Services, Sicherheitsverfahren HBCI""" security_reference = DataElementField(type='an', max_length=14, _d="Sicherheitskontrollreferenz") validation_result = DataElementField(type='bin', max_length=512, required=False, _d="Validierungsresultat") user_defined_signature = DataElementGroupField(type=UserDefinedSignature, required=False, _d="Benutzerdefinierte Signatur")