activity.iso20022
Attributes
Classes
Functions
| 
 | |
| 
 | Yields the transaction entries from the given Camt.053 or Camt.054 | 
| 
 | Extracts the QR-bill reference number from the given text. | 
| 
 | |
| Takes an ISO20022 camt.053 file and matches it with the invoice | 
Module Contents
- activity.iso20022.transaction_entries(root: lxml.etree._Element) collections.abc.Iterator[lxml.etree._Element][source]
- Yields the transaction entries from the given Camt.053 or Camt.054 xml. This works because for our purposes the entries of those two formats are identical. 
- activity.iso20022.get_esr(booking_text: str) str | None[source]
- Extracts the QR-bill reference number from the given text. QR-bill reference numbers are usually 26 or 27 characters long but can be of any length. The 27-character version includes a check digit at the end. The 26-character version doesn’t include the check digit. For any other length we don’t know if the check digit is included or not. - For example: - input: ‘Gutschrift QRR: 27 99029 05678 18860 27295 37059’ output: ‘269902905678188602729537059’ - Returns:
- The extracted reference number or None if no reference number. 
 - If the extracted reference number is only 26 characters long, the check digit is appended to the end. 
- activity.iso20022.extract_transactions(xml: str, invoice_schema: str) collections.abc.Iterator[Transaction][source]
- activity.iso20022.match_iso_20022_to_usernames(xml: str, session: sqlalchemy.orm.Session, period_id: uuid.UUID, schema: str, currency: str = 'CHF') collections.abc.Iterator[Transaction][source]
- Takes an ISO20022 camt.053 file and matches it with the invoice items in the database. - Raises an error if the given xml cannot be processed. - Returns:
- An iterator of transactions found in the xml file, together with the matching username and a confidence attribute indicating how certain the match is (1.0 indicating a sure match, 0.5 a possible match and 0.0 a non-match).