Swiss QR

Overview

The parser supports the 1.0, 2.0 and the 2.1 versions of the Swiss QR ISO 20022 standard. For the complete documentation of the standard please refer to the official website.

Sample usage for SwissQr parser and Barcode Capture

First, you need to create a DataCaptureContext, access a Camera and create SwissQr parser:

DataCaptureContext context = DataCaptureContext.ForLicenseKey(SCANDIT_LICENSE_KEY);
Camera camera = Camera.GetDefaultCamera();
camera?.ApplySettingsAsync(BarcodeCapture.RecommendedCameraSettings);
context.SetFrameSourceAsync(camera);
camera?.SwitchToDesiredStateAsync(FrameSourceState.On);

BarcodeCaptureSettings barcodeCaptureSettings = BarcodeCaptureSettings.Create();
BarcodeCapture barcodeCapture = BarcodeCapture.Create(context, barcodeCaptureSettings);

Parser parser = Parser.Create(this.dataCaptureContext, ParserDataFormat.SwissQr);
parser.SetOptions(new Dictionary<string, object>() { { "minimalVersion", 100 } });

Then, you need to implement IBarcodeCaptureListener:

public void OnBarcodeScanned(BarcodeCapture barcodeCapture, BarcodeCaptureSession session, IFrameData frameData)
{
   var barcode = session?.NewlyRecognizedBarcode;

   if (barcode == null)
   {
         return;
   }
   try
   {
      ParsedData parsedData = parser.ParseString(barcode.Data);
      /*
      * Extract the fields relevant to your use case. Below, for example, we extract a batch/lot number,
      * which has the type String, and an expiry date, which is represented as a map with keys
      * "year", "month", "day".
      */
      string creditorName = parsedData.FieldsByName["QRCH/CdtrInf/Cdtr/Name"].Parsed.ToString();

      var hashMap = parsedData.FieldsByName["QRCH/CcyAmtDate/ReqdExctnDt"].Parsed as IDictionary<string, object>;

      int year = (int)hashMap["year"];
      int month = (int)hashMap["month"];
      int day = (int)hashMap["day"];

      // Do something with the extracted fields.
   }
   catch (ArgumentException e)
   {
      // Handle the parser errors
   }
}

Finally, add the listener to the mode to receive scan results:

barcodeCapture.AddListener(this);

For details, go to the API docs.

Example

Parsing following, SwissQr version 1, code (without quotes):

"SPC\r\n0100\r\n1\r\nCH6812345678901234567\r\nScandit AG\r\nLimmatstrasse\r\n73\r\n8005\r\nZuerich\r\nCH\r\n\r\n\r\n\r\n\r\n\r\n\r\n1234.00\r\nCHF\r\n2020-01-01\r\n\r\n\r\n\r\n\r\n\r\n\r\nNON\r\n\r\ntest code\r\nAC:Alternative scheme data first\r\nAC:Alternative scheme data second"

will result in following JSON output:

[
 {
   "name" : "QRCH/Header/QRType",
   "parsed" : "SPC",
   "rawString" : "SPC"
},
{
   "name" : "QRCH/Header/Version",
   "parsed" : "0100",
   "rawString" : "0100"
},
{
   "name" : "QRCH/Header/Coding",
   "parsed" : 1,
   "rawString" : "1"
},
{
   "name" : "QRCH/CdtrInf/IBAN",
   "parsed" : "CH6812345678901234567",
   "rawString" : "CH6812345678901234567"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/Name",
   "parsed" : "Scandit AG",
   "rawString" : "Scandit AG"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/StrtNm",
   "parsed" : "Limmatstrasse",
   "rawString" : "Limmatstrasse"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/BldgNb",
   "parsed" : "73",
   "rawString" : "73"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/PstCd",
   "parsed" : "8005",
   "rawString" : "8005"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/TwnNm",
   "parsed" : "Zuerich",
   "rawString" : "Zuerich"
},
{
   "name" : "QRCH/CdtrInf/Cdtr/Ctry",
   "parsed" : "CH",
   "rawString" : "CH"
},
{
   "name" : "QRCH/UltmtCdtr/Name",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtCdtr/StrtNm",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtCdtr/BldgNb",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtCdtr/PstCd",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtCdtr/TwnNm",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtCdtr/Ctry",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/CcyAmtDate/Amt",
   "parsed" : "1234.00",
   "rawString" : "1234.00"
},
{
   "name" : "QRCH/CcyAmtDate/Ccy",
   "parsed" : "CHF",
   "rawString" : "CHF"
},
{
   "name" : "QRCH/CcyAmtDate/ReqdExctnDt",
   "parsed" : {
      "day" : 1,
      "month" : 1,
      "year" : 2020
   },
   "rawString" : "2020-01-01"
},
{
   "name" : "QRCH/UltmtDbtr/Name",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtDbtr/StrtNm",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtDbtr/BldgNb",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtDbtr/PstCd",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtDbtr/TwnNm",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/UltmtDbtr/Ctry",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/RmtInf/Tp",
   "parsed" : "NON",
   "rawString" : "NON"
},
{
   "name" : "QRCH/RmtInf/Ref",
   "parsed" : "",
   "rawString" : ""
},
{
   "name" : "QRCH/RmtInf/Ustrd",
   "parsed" : "test code",
   "rawString" : "test code"
},
{
   "name" : "QRCH/AltPmtInf/AltPmt/1",
   "parsed" : "AC:Alternative scheme data first",
   "rawString" : "AC:Alternative scheme data first"
},
{
   "name" : "QRCH/AltPmtInf/AltPmt/2",
   "parsed" : "AC:Alternative scheme data second",
   "rawString" : "AC:Alternative scheme data second"
}
]

Exposed fields for Version 1.0

The exposed fields correspond one-to-one with the fields defined in the specs. The full list is given below:

Element Name

Meaning

Always Present

May be empty

Parsed Content

QRCH/Header/QRType

Indicator for Swiss QR Code, always ‘SPC’

yes

no

QRCH/Header/Version

Version string, ‘0100’ for v1.0

yes

no

QRCH/Header/Coding

Character set code, always 1

yes

no

parsed Integer

QRCH/CdtrInf/IBAN

IBAN (string of 21 characters)

yes

no

QRCH/CdtrInf/Cdtr/Name

Creditor’s name

yes

no

QRCH/CdtrInf/Cdtr/StrtNm

Creditor’s street name

yes

yes

QRCH/CdtrInf/Cdtr/BldgNb

Creditor’s house number

yes

yes

QRCH/CdtrInf/Cdtr/PstCd

Creditor’s postal code

yes

no

QRCH/CdtrInf/Cdtr/TwnNm

Creditor’s city

yes

no

QRCH/CdtrInf/Cdtr/Ctry

Creditor’s country (2 digit ISO 3166-1)

yes

no

QRCH/UltmtCdtr/Name

Ultimate Creditor’s name

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/StrtNm

Ultimate Creditor’s street name

yes

yes

QRCH/UltmtCdtr/BldgNb

Ultimate Creditor’s house number

yes

yes

QRCH/UltmtCdtr/PstCd

Ultimate Creditor’s postal code

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/TwnNm

Ultimate Creditor’s city

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/Ctry

Ultimate Creditor’s country (2 digit ISO 3166-1)

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/CcyAmtDate/Amt

Payment amount

yes

yes

QRCH/CcyAmtDate/Ccy

Currency (‘CHF’ or ‘EUR’)

yes

no

QRCH/CcyAmtDate/ReqdExctnDt

Due date

yes

yes

key/value pairs:

  • ‘year’ : YYYY,

  • ‘month’ : MM,

  • ‘day’ : DD

with YYYY, MM, DD integers

QRCH/UltmtDbtr/Name

Ultimate Debitor’s name

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/StrtNm

Ultimate Debitor’s street name

yes

yes

QRCH/UltmtDbtr/BldgNb

Ultimate Debitor’s house number

yes

yes

QRCH/UltmtDbtr/PstCd

Ultimate Debitor’s postal code

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/TwnNm

Ultimate Debitor’s city

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/Ctry

Ultimate Debitor’s country (2 digit ISO 3166-1)

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/RmtInf/Tp

Reference type (QRR for QR reference, SCOR for Creditor Reference, NON wihtout reference)

yes

no

QRCH/RmtInf/Ref

Reference number

yes

yes

QRCH/AltPmtInf/AltPmt/1

Additional scheme parameters (first)

no

yes

QRCH/AltPmtInf/AltPmt/1

Additional scheme parameters (second)

no

yes

Exposed fields for Version 2.0 and 2.1

The exposed fields correspond one-to-one with the fields defined in the specs (link). The full list is given below:

Element Name

Meaning

Always Present

May be empty

Parsed Content

QRCH/Header/QRType

Indicator for Swiss QR Code, always ‘SPC’

yes

no

QRCH/Header/Version

Version string, ‘0200’ for v2.0 and ‘0210 for v2.1

yes

no

QRCH/Header/Coding

Character set code, always 1

yes

no

parsed Integer

QRCH/CdtrInf/IBAN

IBAN (string of 21 characters)

yes

no

QRCH/CdtrInf/Cdtr/AdrTp

Address type

yes

yes

S for structured address, K for combined address

QRCH/CdtrInf/Cdtr/Name

Creditor’s name

yes

no

QRCH/CdtrInf/Cdtr/StrtNmOrAdrLine1

Creditor’s street name

yes

yes for structured address, no for combined address

QRCH/CdtrInf/Cdtr/BldgNbOrAdrLine2

Creditor’s house number

yes

yes for structured address, no for combined address

QRCH/CdtrInf/Cdtr/PstCd

Creditor’s postal code

yes

no for structured address, yes for combined address

QRCH/CdtrInf/Cdtr/TwnNm

Creditor’s city

yes

no for structured address, yes for combined address

QRCH/CdtrInf/Cdtr/Ctry

Creditor’s country (2 digit ISO 3166-1)

yes

no

QRCH/UltmtCdtr/AdrTp

Ultimate Creditor’s address type

yes

yes

S for structured address, K for combined address

QRCH/UltmtCdtr/Name

Ultimate Creditor’s name

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/StrtNmOrAdrLine1

Ultimate Creditor’s street name

yes

yes for structured address, no for combined address

QRCH/UltmtCdtr/BldgNbOrAdrLine2

Ultimate Creditor’s house number

yes

yes for structured address, no for combined address

QRCH/UltmtCdtr/PstCd

Ultimate Creditor’s postal code

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/TwnNm

Ultimate Creditor’s city

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/UltmtCdtr/Ctry

Ultimate Creditor’s country (2 digit ISO 3166-1)

yes

yes (but only if all other QRCH/UltmtCdtr/* fields are empty)

QRCH/CcyAmtDate/Amt

Payment amount

yes

yes

QRCH/CcyAmtDate/Ccy

Currency (‘CHF’ or ‘EUR’)

yes

no

QRCH/UltmtDbtr/AdrTp

Ultimate Debitor’s address type

yes

yes

S for structured address, K for combined address

QRCH/UltmtDbtr/Name

Ultimate Debitor’s name

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/StrtNmOrAdrLine1

Ultimate Debitor’s street name

yes

yes for structured address, no for combined address

QRCH/UltmtDbtr/BldgNbOrAdrLine2

Ultimate Debitor’s house number

yes

yes for structured address, no for combined address

QRCH/UltmtDbtr/PstCd

Ultimate Debitor’s postal code

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/TwnNm

Ultimate Debitor’s city

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/UltmtDbtr/Ctry

Ultimate Debitor’s country (2 digit ISO 3166-1)

yes

yes (but only if all other QRCH/UltmtDbtr/* fields are empty)

QRCH/RmtInf/Tp

Reference type (QRR for QR reference, SCOR for Creditor Reference, NON wihtout reference)

yes

no

QRCH/RmtInf/Ref

Reference number

yes

yes

QRCH/RmtInf/AddInf/Ustrd

Unstructured message

yes

yes

QRCH/RmtInf/AddInf/Trailer

Unambigous information for the end of payment data, always ‘EPD’

yes

no

QRCH/RmtInf/AddInf/StrdBkgInf

Bill information

yes

yes

QRCH/AltPmtInf/AltPmt/1

Additional scheme parameters (first)

no

yes

QRCH/AltPmtInf/AltPmt/2

Additional scheme parameters (second)

no

yes

Parser Options

The parser can be configured by providing a JSON string containing key / value pairs. The following configuration options are available:

Key

Value Type

Description

minimalVersion

Int

Sets minimal version of Swiss Payment Standard that will be parsed. Available options are: 100 (1.0 version), 200 (2.0 version) and 210 (2.1 version). By default it is 200.

strictMode

boolean

Controls the strictness of the parser. When strictMode is set to false, parsing continues for non-critical errors (missing required field, fields containing incorrect characters, invalid separator or character etc.). The encountered problems can be queried via the issues property. By default option is set to true.

Strict Mode

By default the parser operates in strict mode - that means parsing is going to fail whenever the parsed code deviates from the standard.

When strictMode is set to false, parsing continues for the following non-critical errors:

  • A mandatory field is empty or missing;

  • The code mixes CR + LF and LF separators between elements;

  • QRCH/CcyAmtDate/Ccy (currency) contains non-alphanumeric characters or is of incorrect length;

  • QRCH/CdtrInf/IBAN (IBAN) contains whitespace characters;

  • PstCd (postal code) and/or TwnNm (town) are present for an address defined as combined (“K”).