GS1 AI

Overview

The parser supports version 20.0 of the GS1 Application Identifier (AI) definitions standard. The latest version of the AI definitions is available in Section 3 GS1 Application Identifier definitions.

Sample usage for GS1 parser and Barcode Capture

First, you need to create a DataCaptureContext, access a Camera and create GS1 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.Gs1Ai);

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 serialNumber = parsedData.FieldsByName["10"].Parsed.ToString();

        var hashMap = parsedData.FieldsByName["17"].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.

Examples

Parsing the following code (without the quotes):

"1719060010SCANDIT123"

will result in the following JSON output:

[
    {
        "name" : "17",
        "parsed" : {
            "month" : 6,
            "year" : 2019
        },
        "rawString" : "190600"
    },
    {
        "name" : "10",
        "parsed" : "SCANDIT123",
        "rawString" : "SCANDIT123"
    }
]

And parsing the following code with strictMode disabled:

"00001834560000000018"

will result in the following JSON output:

[
    {
        "name" : "00",
        "parsed" : "001834560000000018",
        "issues" : ["check digit mismatch. Expected 8 but got 2."],
        "rawString" : "001834560000000018"
    }
]

Exposed Fields

The name of the fields correspond to the AI number. The following fields have their content parsed. Fields which are not in this list can still be accessed, but only the raw string is available.

  • “00”: parsed data is a dictionary, always contains alphanumeric subfields “extensionDigit” and “SSCC”.

  • “01”, “02”: parsed data is a dictionary, always contains “GTIN” field. It sometimes contains integer field “indicator” (if non-zero).

  • “10”: parsed data is a string (batch/lot number)

  • “11”, “12”, “13”, “15”, “16”, “17”: parsed data is a dictionary, always contains integer fields “year” (YYYY), “month” (MM) and sometimes “day” (DD)

  • “20”: parsed data is an integer (the variant)

  • “21”: parsed data is a string (the serial number)

  • “30”: parsed data is an integer (count of items, between 0 and 99999999)

  • “31ab”, “32ab”, “33ab”, “34ab”, “35ab”, “36ab” for some numbers a and b: These AI’s are represented by two fields in our result: The field “31ab” and the fields “31ax”. For example: The AI “3222” has the fields “3222” and “322x” The parsed data is a string of the floating point number (e.g. “3202000150” has the parsed data “1.50”)

  • “37”: parsed data is an integer (count of items, between 0 and 99999999)

  • “400”: parsed data is a string (customer’s purchase order number)

  • “401”: parsed data is a string (global identification number for consignment)

  • “402”: parsed data is a string (global shipment identification number)

  • “403”: parsed data is a string (routing code)

  • “410”: parsed data is a string (ship to / deliver to global location number)

  • “411”: parsed data is a string (bill to / invoice to global location number)

  • “412”: parsed data is a string (purchased from global location number)

  • “413”: parsed data is a string (ship for / deliver for - forward to global location number)

  • “414”: parsed data is a string (identification of a physical location - global location number)

  • “415”: parsed data is a string (global location number of the invoicing party)

  • “416”: parsed data is a string (global location number of the production or service location)

  • “420”: parsed data is a string (ship to / deliver to postal code within a single postal authority)

  • “421”: parsed data is a dictionary, always contains “countryCode” and “postalCode” fields (ship to / deliver to postal code with three-digit ISO country code)

  • “422”: parsed data is a string (country of origin of a trade item / ISO 3166)

  • “423”: parsed data is an array (countries of initial processing / ISO 3166)

  • “424”: parsed data is a string (country of processing / ISO 3166)

  • “425”: parsed data is an array (countries of disassembly / ISO 3166)

  • “426”: parsed data is a string (country covering full process chain / ISO 3166)

  • “427”: parsed data is a string (country subdivision of origin code for a trade item / ISO 3166-2)

  • “4300”: parsed data is a string (ship to country name supporting percent encoding for non-Latin characters)

  • “4301”: parsed data is a string (ship to contact name supporting percent encoding for non-Latin characters)

  • “4302”: parsed data is a string (ship to address line 1 supporting percent encoding for non-Latin characters)

  • “4303”: parsed data is a string (ship to address line 2 supporting percent encoding for non-Latin characters)

  • “4304”: parsed data is a string (ship to suburb information supporting percent encoding for non-Latin characters)

  • “4305”: parsed data is a string (ship to locality information supporting percent encoding for non-Latin characters)

  • “4306”: parsed data is a string (ship to region name supporting percent encoding for non-Latin characters)

  • “4326”: parsed data is a dictionary, always contains integer fields “year” (YYYY), “month” (MM), “day” (DD).

  • “4330”: parsed data is a string (temperature in degrees Fahrenheit)”

  • “4331”: parsed data is a string (temperature in degrees Celsius)”

  • “4332”: parsed data is a string (temperature in degrees Fahrenheit)”

  • “4333”: parsed data is a string (temperature in degrees Celsius)”

  • “7003”: parsed data is a dictionary, always contains integer fields “year” (YYYY), “month” (MM), “day” (DD), “hour” (HH), “minute” (MM).

  • “8017”: parsed data is a dictionary, always contains string subfield “GSRN”.

  • “8018”: parsed data is a dictionary, always contains string subfield “GSRN”.

  • “91”-“99”: parsed data is a string (when standardExtension option is not set)

Extensions

NHS

Based on Automatic Identification and Data Capture (AIDC) for Patient Identification. Standard Number: ISB 1077. When the standardExtension option is set to “nhs” we parse the following specific fields:

  • “91”: parsed data is a dictionary, always contains alphanumeric subfield “organisationCode”, “patientHospitalNumber”. Might also contain numeric subfied “organisationPrefix”.

  • “92”: parsed data is a dictionary, always contains alphanumeric subfield “numberOfBabiesIndicator” and alphabetic subfields “babyOfLastName” and “babyOfFirstName”.

  • “93”: parsed data is a dictionary, always contains alphabetic subfield “lastName”, “firstName” and alphanumeric “dateOfBirth”. Might also contain alphanumeric “timeOfBirth”.

Parser Options

Following options can be set to fine-tune the behavior of the parser:

  • “strictMode”: boolean (default:true)

    Controls the strictness of the parser. When strictMode is set to true, every error in the input (invalid checksum, invalid characters etc.) is treated as an error. Parsing is aborted upon encountering the first error. When strictMode is set to false, parsing continues for non-critical errors. The encountered problems can be queried for each field separately via the issues property.

  • “standardExtension”: string (no default value)

    Option to enable extensions of the GS1 standard. This configures how certain AIs are interpreted (e.g, ‘company internal information’ on AIs 91 to 99). See section ‘Extensions’ for more details. Currently only “nhs” is supported.

  • “allowMachineReadableCodes”: boolean (default:true)

    Makes the parser accept codes which are encoded in machine readable format (i.e. AI numbers not encapsulated in parenthesis).

  • “allowHumanReadableCodes”: boolean (default:false)

    Makes the parser accept codes which are encoded in human readable format (i.e. AI numbers encapsulated in parenthesis).

  • “outputHumanReadableString”: boolean (default: false)

    Adds the additional field “humanReadableString” at the end of the resulting JSON string. This field contains the code in human readable form (i.e. AI number encapsulated in parenthesis).