Grabba Driver for iOS
Unified driver for Grabba devices on the iOS operating system
Enumerated Types

Description

Enumerations

enum  GrabbaBarcodeSymbology : NSInteger {
  GrabbaSymbologyAustPost, GrabbaSymbologyAztec, GrabbaSymbologyBritish, GrabbaSymbologyBC412,
  GrabbaSymbologyCanadian, GrabbaSymbologyCC, GrabbaSymbologyChina, GrabbaSymbologyCodabar,
  GrabbaSymbologyCodablock_A, GrabbaSymbologyCodablock_F, GrabbaSymbologyCodeOne, GrabbaSymbologyCode11,
  GrabbaSymbologyCode16k, GrabbaSymbologyCode26, GrabbaSymbologyCode39, GrabbaSymbologyCode49,
  GrabbaSymbologyCode93, GrabbaSymbologyCode128, GrabbaSymbologyCoupon, GrabbaSymbologyD25,
  GrabbaSymbologyDataMatrix, GrabbaSymbologyEAN128, GrabbaSymbologyEAN8, GrabbaSymbologyEAN13,
  GrabbaSymbologyEAN_Composite, GrabbaSymbologyIATA, GrabbaSymbologyIntelligentMail, GrabbaSymbologyInterleaved2Of5,
  GrabbaSymbologyISSN, GrabbaSymbologyISBN, GrabbaSymbologyItalianPharma, GrabbaSymbologyJapanese,
  GrabbaSymbologyKorea, GrabbaSymbologyMatrix2Of5, GrabbaSymbologyMaxicode, GrabbaSymbologyMicroQR,
  GrabbaSymbologyMicroPDF417, GrabbaSymbologyMSI, GrabbaSymbologyNetherlands, GrabbaSymbologyPDF417,
  GrabbaSymbologyPlanet, GrabbaSymbologyPlessey, GrabbaSymbologyPOSI, GrabbaSymbologyPostNet,
  GrabbaSymbologyQR, GrabbaSymbologyRSS14, GrabbaSymbologyRSS_Limited, GrabbaSymbologyRSS_Expanded,
  GrabbaSymbologyS_Code, GrabbaSymbologyStandard2Of5, GrabbaSymbologyTelepen, GrabbaSymbologyTLC,
  GrabbaSymbologyTrioptic39, GrabbaSymbologyUPCA, GrabbaSymbologyUPCE, GrabbaSymbologyUnknown
}
 Enumeration of supported barcode symbologies. More...
 
enum  GrabbaBER_ID_Class : NSInteger { GrabbaBER_ID_ClassUniversal, GrabbaBER_ID_ClassApplication, GrabbaBER_ID_ClassContextSpecific, GrabbaBER_ID_ClassPrivate }
 Set of supported ID class field values for BER Type structures (part of BER-TLV) More...
 
enum  GrabbaButtonBehaviour : NSInteger { GrabbaButtonCallbackOnly, GrabbaButtonBarcodePressToScan, GrabbaButtonProxcardPressToScan }
 Enumeration of supported button behaviours. More...
 
enum  GrabbaErrorCodeValue : NSInteger {
  GrabbaNoError, GrabbaNotConnected, GrabbaDriverNotOpen, GrabbaIO_Error,
  GrabbaFunctionNotSupported, GrabbaIllegalArgument, GrabbaDeviceBusy, GrabbaProxcardNoCardInField,
  GrabbaSmartcardError, GrabbaProxcardCollision, GrabbaAuthenticationFailed, GrabbaNoExclusiveAccess,
  GrabbaInternalError, GrabbaSmartcardAlreadyPowered, GrabbaSmartcardInterfaceNotPresent, GrabbaSmartcardNoCardInInterface,
  GrabbaSmartcardNotPowered, GrabbaSmartcardPPS_NotPermitted, GrabbaSmartcardPPS_Rejected, GrabbaSmartcardTimeout
}
 Set of supported error code values for the GrabbaErrorCode class. More...
 
enum  GrabbaFingerprintImageTypeID : NSInteger {
  GrabbaFingerprintImageTypeNoImage, GrabbaFingerprintImageTypeNoCompression, GrabbaFingerprintImageTypeV1Compression, GrabbaFingerprintImageTypeWSQ_Compression,
  GrabbaFingerprintImageTypePreview, GrabbaFingerprintImageTypeFullRes, GrabbaFingerprintImageTypeUnknown
}
 Fingerprint image types for capture and enrolment functions. More...
 
enum  GrabbaFingerprintTemplateTypeID : NSInteger {
  GrabbaFingerprintTemplateTypeNoTemplate, GrabbaFingerprintTemplateTypePK_Comp_V2, GrabbaFingerprintTemplateTypePK_Comp_V2_Norm, GrabbaFingerprintTemplateTypePK_Mat,
  GrabbaFingerprintTemplateTypePK_Mat_Norm, GrabbaFingerprintTemplateTypeISO_PK_Data_ANSI_378, GrabbaFingerprintTemplateTypeISO_PK_Data_MINEX_A, GrabbaFingerprintTemplateTypeISO_PK_Data_FMR,
  GrabbaFingerprintTemplateTypeISO_PK_Data_FMC_NS, GrabbaFingerprintTemplateTypeISO_PK_Data_FMC_CS, GrabbaFingerprintTemplateTypeUnknown
}
 Fingerprint template types for capture and enrolment functions. More...
 
enum  GrabbaFingerprintUserMessageTypeID : NSInteger {
  GrabbaFingerprintUserMessageTypePlaceYourFinger, GrabbaFingerprintUserMessageTypeMoveUp, GrabbaFingerprintUserMessageTypeMoveDown, GrabbaFingerprintUserMessageTypeMoveLeft,
  GrabbaFingerprintUserMessageTypeMoveRight, GrabbaFingerprintUserMessageTypePressHarder, GrabbaFingerprintUserMessageTypeMoveFinger, GrabbaFingerprintUserMessageTypeRemoveFinger,
  GrabbaFingerprintUserMessageTypeAcquisitionComplete, GrabbaFingerprintUserMessageTypeImageMessage, GrabbaFingerprintUserMessageTypePlaceFingerForAcquisition, GrabbaFingerprintUserMessageTypePlaceFirstFingerForAcquisition,
  GrabbaFingerprintUserMessageTypePlaceSecondFingerForAcquisition, GrabbaFingerprintUserMessageTypeMatchSuccessful, GrabbaFingerprintUserMessageTypeMatchUnsuccessfulNotSameFinger, GrabbaFingerprintUserMessageTypeMatchUnsuccessfulDatabaseEmpty,
  GrabbaFingerprintUserMessageTypeMatchUnsuccessfulFalseFingerDetected, GrabbaFingerprintUserMessageTypeMatchUnsuccessfulMoistFinger, GrabbaFingerprintUserMessageTypeErrorAlreadyEnrolled, GrabbaFingerprintUserMessageTypeErrorInvalidUserID,
  GrabbaFingerprintUserMessageTypeErrorInvalidUserData, GrabbaFingerprintUserMessageTypeImageProgress, GrabbaFingerprintUserMessageTypeImageDetectQuality, GrabbaFingerprintUserMessageTypeImageCodeQuality,
  GrabbaFingerprintUserMessageTypeErrorOperationTimeout, GrabbaFingerprintUserMessageTypeErrorSameFinger, GrabbaFingerprintUserMessageTypeErrorNoDatabase, GrabbaFingerprintUserMessageTypeErrorCommandInProgress,
  GrabbaFingerprintUserMessageTypeErrorFingerprintDatabaseFull, GrabbaFingerprintUserMessageTypeEmptyMessage
}
 Enumeration of user messages which may be generated during fingerprint reader operations. More...
 
enum  GrabbaMRZ_Format : NSInteger {
  GrabbaMRZ_FormatUnknown, GrabbaMRZ_FormatTD1, GrabbaMRZ_FormatTD2, GrabbaMRZ_FormatTD3,
  GrabbaMRZ_FormatMRV_A, GrabbaMRZ_FormatMRV_B
}
 Enumeration of MRZ formats as defined by ICAO 9303, plus a sentinel value for unknown/invalid text. More...
 
enum  GrabbaProxcardTypeID : NSInteger {
  GrabbaProxcardTypeIClass, GrabbaProxcardTypeMifare, GrabbaProxcardTypeMifare4K, GrabbaProxcardTypeMifareUL,
  GrabbaProxcardTypeMifareProx, GrabbaProxcardTypeSLE55RXX, GrabbaProxcardTypeSLE66CL160S, GrabbaProxcardTypeICode,
  GrabbaProxcardTypeICodeSLI, GrabbaProxcardTypeTagit, GrabbaProxcardTypeTagitHFI, GrabbaProxcardTypeICodePC,
  GrabbaProxcardTypeICodeUID, GrabbaProxcardTypeISO15693, GrabbaProxcardTypeLRI512, GrabbaProxcardTypeSRF55VXXP,
  GrabbaProxcardTypeSRF55VXXS, GrabbaProxcardTypeTempSense, GrabbaProxcardTypeSR176, GrabbaProxcardTypeFeliCa,
  GrabbaProxcardTypeEM4X02, GrabbaProxcardTypeEM4X05, GrabbaProxcardTypeEM4X50, GrabbaProxcardTypeHitag1,
  GrabbaProxcardTypeHitag2, GrabbaProxcardTypeQ5, GrabbaProxcardTypeHID_Prox, GrabbaProxcardTypeISO14443A,
  GrabbaProxcardTypeISO14443B, GrabbaProxcardTypeISO14443C, GrabbaProxcardTypeIClassProgrammedID, GrabbaProxcardTypeTI_RFID,
  GrabbaProxcardTypeUHF, GrabbaProxcardTypeUnknown
}
 RFID and proximity card type identifiers which are supported by the driver. More...
 
enum  GrabbaSmartcardBaud : NSInteger {
  GrabbaSmartcardBaud1, GrabbaSmartcardBaud2, GrabbaSmartcardBaud4, GrabbaSmartcardBaud8,
  GrabbaSmartcardBaud16, GrabbaSmartcardBaud32, GrabbaSmartcardBaud64, GrabbaSmartcardBaud12,
  GrabbaSmartcardBaud20
}
 Set of driver-supported baud parameter values, with representations matching those in ISO/IEC 7816-3. More...
 
enum  GrabbaSmartcardClock : NSInteger {
  GrabbaSmartcardClock372_4M, GrabbaSmartcardClock372_5M, GrabbaSmartcardClock558_6M, GrabbaSmartcardClock744_8M,
  GrabbaSmartcardClock1116_12M, GrabbaSmartcardClock1488_16M, GrabbaSmartcardClock1860_20M, GrabbaSmartcardClock512_5M,
  GrabbaSmartcardClock768_7M5, GrabbaSmartcardClock1024_10M, GrabbaSmartcardClock1536_15M, GrabbaSmartcardClock2048_20M
}
 Set of driver-supported clock values, with representations matching those in ISO/IEC 7816-3. More...
 
enum  GrabbaSmartcardInterfaceID : NSInteger { GrabbaSmartcardPrimarySlot, GrabbaSmartcardPrimarySAM }
 Enumeration of contact smart card interfaces. More...
 
enum  GrabbaSmartcardProtocolID : NSInteger { GrabbaSmartcardProtocolHalfDuplexChar, GrabbaSmartcardProtocolHalfDuplexBlock }
 Set of driver-supported protocol (T) values, with representations matching those in ISO/IEC 7816-3. More...
 

Enumeration Type Documentation

◆ GrabbaBarcodeSymbology

enum GrabbaBarcodeSymbology : NSInteger

Enumeration of supported barcode symbologies.

This is typically used in conjunction with the GrabbaBarcodeData class, where it provides identification of barcode symbologies for scanned barcodes.

The GrabbaSymbologyUnknown value is a sentinel which signifies that the barcode symbology could not be detected (e.g. if it does not match any of the supported types); the other values all represent legitimate symbologies.

Note
Not all symbologies are supported by all barcode reader types.
See also
GrabbaBarcodeData for the most common usage of this type, and for a method which generates string representations of the IDs
Enumerator
GrabbaSymbologyAustPost 

Australia Post symbology.

GrabbaSymbologyAztec 

Aztec symbology.

GrabbaSymbologyBritish 

British symbology.

GrabbaSymbologyBC412 

BC412 symbology.

GrabbaSymbologyCanadian 

Canadian symbology.

GrabbaSymbologyCC 

Composite Code symbology.

GrabbaSymbologyChina 

China post symbology.

GrabbaSymbologyCodabar 

Codabar (aka Ames Code) symbology.

GrabbaSymbologyCodablock_A 

Codablock A symbology.

GrabbaSymbologyCodablock_F 

Codablock F symbology.

GrabbaSymbologyCodeOne 

Code One symbology.

GrabbaSymbologyCode11 

Code 11 symbology.

GrabbaSymbologyCode16k 

Code 16k symbology.

GrabbaSymbologyCode26 

Code 26 symbology.

GrabbaSymbologyCode39 

Code 39 symbology.

GrabbaSymbologyCode49 

Code 49 symbology.

GrabbaSymbologyCode93 

Code 93 symbology.

GrabbaSymbologyCode128 

Code 128 symbology.

GrabbaSymbologyCoupon 

Coupon symbology.

GrabbaSymbologyD25 

D25 symbology.

GrabbaSymbologyDataMatrix 

DataMatrix symbology.

GrabbaSymbologyEAN128 

EAN-128 symbology.

GrabbaSymbologyEAN8 

EAN-8 symbology.

GrabbaSymbologyEAN13 

EAN-13 symbology.

GrabbaSymbologyEAN_Composite 

EAN-composite symbology.

GrabbaSymbologyIATA 

IATA symbology.

GrabbaSymbologyIntelligentMail 

Intelligent mail symbology.

GrabbaSymbologyInterleaved2Of5 

Interleaved 2-of-5 symbology.

GrabbaSymbologyISSN 

ISSN symbology.

GrabbaSymbologyISBN 

ISBN symbology.

GrabbaSymbologyItalianPharma 

Italian pharma symbology.

GrabbaSymbologyJapanese 

Japanese symbology.

GrabbaSymbologyKorea 

Korean symbology.

GrabbaSymbologyMatrix2Of5 

Matrix 2-of-5 symbology.

GrabbaSymbologyMaxicode 

Maxicode symbology.

GrabbaSymbologyMicroQR 

Micro QR code symbology.

GrabbaSymbologyMicroPDF417 

Micro-PDF 417 symbology.

GrabbaSymbologyMSI 

MSI symbology.

GrabbaSymbologyNetherlands 

Netherlands symbology.

GrabbaSymbologyPDF417 

PDF 417 symbology.

GrabbaSymbologyPlanet 

Planet symbology.

GrabbaSymbologyPlessey 

Plessey Code symbology.

GrabbaSymbologyPOSI 

POSI symbology.

GrabbaSymbologyPostNet 

US post office symbology.

GrabbaSymbologyQR 

QR Code symbology.

GrabbaSymbologyRSS14 

RSS-14 symbology.

GrabbaSymbologyRSS_Limited 

RSS-limited symbology.

GrabbaSymbologyRSS_Expanded 

RSS-expanded symbology.

GrabbaSymbologyS_Code 

S-Code symbology.

GrabbaSymbologyStandard2Of5 

Standard 2-of-5 (aka Industrial 2-of-5) symbology.

GrabbaSymbologyTelepen 

Telepen symbology.

GrabbaSymbologyTLC 

TLC symbology.

GrabbaSymbologyTrioptic39 

Trioptic39 symbology.

GrabbaSymbologyUPCA 

UPC-A symbology.

GrabbaSymbologyUPCE 

UPC-E symbology.

GrabbaSymbologyUnknown 

Unknown symbology - sentinel value.

◆ GrabbaBER_ID_Class

enum GrabbaBER_ID_Class : NSInteger

Set of supported ID class field values for BER Type structures (part of BER-TLV)

Note
The representation is consistent with that of the upper two bits of the first byte in a BER-TLV structure.
See also
GrabbaBER_TLV for the most common usage of this type
Enumerator
GrabbaBER_ID_ClassUniversal 

Native to ASN-1, universally applicable.

GrabbaBER_ID_ClassApplication 

Valid for one application only.

GrabbaBER_ID_ClassContextSpecific 

Meaning depends on current context.

GrabbaBER_ID_ClassPrivate 

Defined only in private specifications.

◆ GrabbaButtonBehaviour

enum GrabbaButtonBehaviour : NSInteger

Enumeration of supported button behaviours.

This enumeration describes the set of button behaviours directly supported by the driver. It applies to the left and right buttons of a connected Grabba device; they may be configured to behave identically or independently.

See also
GrabbaButtonAPI for the most common usage of this type
Enumerator
GrabbaButtonCallbackOnly 

Button events only trigger callbacks (default behaviour)

Pressing or releasing the buttons on the Grabba device has no effect within the driver beyond triggering callbacks to any active GrabbaButtonListener objects (including subclasses). Application code may use these events to trigger desired processing, but there is no requirement to do so.

GrabbaButtonBarcodePressToScan 

Button events control barcode scans in addition to triggering callbacks.

Pressing the button will trigger a barcode scan if one is not already active. This scan will continue until any of the following conditions are met:

  • The button is released and, if the other button is also configured to trigger barcode scanning, that button is also released
  • A barcode is successfully scanned
  • An error is detected during the scan process (e.g. disconnection from Grabba device)

This behaviour is the equivalent of invoking startScan when buttons are pressed and stopScan when buttons are released.

GrabbaButtonProxcardPressToScan 

Button events control proxcard/RFID scans in addition to triggering callbacks.

Pressing the button will trigger a proxcard/RFID scan if one is not already active. This scan will continue until any of the following conditions are met:

  • The button is released and, if the other button is also configured to trigger proxcard/RFID scanning, that button is also released
  • A proxcard or RFID tag is successfully scanned
  • An error is detected during the scan process (e.g. disconnection from Grabba device)

This behaviour is the equivalent of invoking startScan when buttons are pressed and stopScan when buttons are released.

◆ GrabbaErrorCodeValue

enum GrabbaErrorCodeValue : NSInteger

Set of supported error code values for the GrabbaErrorCode class.

Note
The position and ordering of these enumerators is likely to change, with the exception of GrabbaNoError, which should always have an underlying representation of 0 and be the lowest-numbered value in this type. Any code which uses the GrabbaErrorCode class should not make assumptions about the underlying value or ordering of the other enumerators; codes must only be accessed using the enumerator names rather than raw values.
See also
GrabbaErrorCode for the most common usage of this type, and for a method which generates message strings from the IDs
Enumerator
GrabbaNoError 

No error was detected; continue processing.

GrabbaNotConnected 

Operation failed because the driver did not have a connection to the device, or the existing connection was lost.

GrabbaDriverNotOpen 

Operation failed because the driver had not previously been opened.

GrabbaIO_Error 

Operation failed due to a low-level input/output error.

GrabbaFunctionNotSupported 

Operation failed because the current hardware does not have the necessary capability.

GrabbaIllegalArgument 

Operation failed due to an illegal argument being supplied.

GrabbaDeviceBusy 

Operation failed due to the hardware being busy with another request.

GrabbaProxcardNoCardInField 

Proxcard operation failed due to there not being a card in the reader's field

GrabbaSmartcardError 

Error response was received from smart card or smart card reader

GrabbaProxcardCollision 

Proxcard operation failed due to a collision between transmissions

GrabbaAuthenticationFailed 

Operation failed due to authentication not succeeding.

GrabbaNoExclusiveAccess 

Operation failed due to lack of exclusive access to the hardware.

GrabbaInternalError 

Operation failed due to an internal error in the driver.

GrabbaSmartcardAlreadyPowered 

An attempt was made to power up a smart card which had already been powered up.

GrabbaSmartcardInterfaceNotPresent 

Smartcard operation was requested on an interface that isn't present in the connected Grabba device.

GrabbaSmartcardNoCardInInterface 

Smartcard operation on an interface which doesn't contain a card, or card was removed mid-operation.

GrabbaSmartcardNotPowered 

Data exchange was requested to a smart card which had not been powered up.

GrabbaSmartcardPPS_NotPermitted 

Smart card PPS exchange was requested at an invalid time (i.e. after other PPS or APDU exchange request(s))

GrabbaSmartcardPPS_Rejected 

One or more of the parameters in a smart card PPS request was rejected by the Grabba device or the smart card.

GrabbaSmartcardTimeout 

Response was not received from a smart card within the allocated time period.

◆ GrabbaFingerprintImageTypeID

enum GrabbaFingerprintImageTypeID : NSInteger

Fingerprint image types for capture and enrolment functions.

See also
GrabbaFingerprintImage for the most common usage of this type, and for a method which generates string representations of the IDs
Enumerator
GrabbaFingerprintImageTypeNoImage 

No image available.

GrabbaFingerprintImageTypeNoCompression 

Final image without any compression.

GrabbaFingerprintImageTypeV1Compression 

Final image with Sagem MorphoSmart (V1) compression.

GrabbaFingerprintImageTypeWSQ_Compression 

Final image using Wavelet Scalar Quantisation (WSQ) compression.

GrabbaFingerprintImageTypePreview 

Preview image.

GrabbaFingerprintImageTypeFullRes 

Full-resolution image.

GrabbaFingerprintImageTypeUnknown 

Unknown image type (sentinel value)

◆ GrabbaFingerprintTemplateTypeID

Fingerprint template types for capture and enrolment functions.

See also
GrabbaFingerprintTemplate for the most common usage of this type, and for a method which generates string representations of the IDs
Enumerator
GrabbaFingerprintTemplateTypeNoTemplate 

No fingerprint template in use.

GrabbaFingerprintTemplateTypePK_Comp_V2 

Compressed standard template; should be used in the majority of cases.

GrabbaFingerprintTemplateTypePK_Comp_V2_Norm 

Normalised version of PK_Comp_V2.

GrabbaFingerprintTemplateTypePK_Mat 

Little-endian uncompressed template format.

GrabbaFingerprintTemplateTypePK_Mat_Norm 

Normalised version of PK_Mat.

GrabbaFingerprintTemplateTypeISO_PK_Data_ANSI_378 

Format compatible with ANSI 378.

GrabbaFingerprintTemplateTypeISO_PK_Data_MINEX_A 

Format compatible with MINEX A.

GrabbaFingerprintTemplateTypeISO_PK_Data_FMR 

Format compatible with ISO/IEC 19794 Finger Minutiae Record.

GrabbaFingerprintTemplateTypeISO_PK_Data_FMC_NS 

Format compatible with ISO/IEC 19794 Finger Minutiae Record (normal size)

GrabbaFingerprintTemplateTypeISO_PK_Data_FMC_CS 

Format compatible with ISO/IEC 19794 Finger Minutiae Record (compact size)

GrabbaFingerprintTemplateTypeUnknown 

Unknown template type (sentinel value)

◆ GrabbaFingerprintUserMessageTypeID

Enumeration of user messages which may be generated during fingerprint reader operations.

See also
GrabbaFingerprintUserMessage for the most common usage of this type, and for a method which generates message strings from the IDs
Enumerator
GrabbaFingerprintUserMessageTypePlaceYourFinger 

User requested to place finger on sensor.

GrabbaFingerprintUserMessageTypeMoveUp 

User requested to move finger upward along sensor.

GrabbaFingerprintUserMessageTypeMoveDown 

User requested to move finger downward along sensor.

GrabbaFingerprintUserMessageTypeMoveLeft 

User requested to move finger to left along sensor.

GrabbaFingerprintUserMessageTypeMoveRight 

User requested to move finger to right along sensor.

GrabbaFingerprintUserMessageTypePressHarder 

User requested to press harder on sensor.

GrabbaFingerprintUserMessageTypeMoveFinger 

User requested to move finger along sensor.

GrabbaFingerprintUserMessageTypeRemoveFinger 

User requested to remove finger from sensor.

GrabbaFingerprintUserMessageTypeAcquisitionComplete 

Print acquisition has completed successfully.

GrabbaFingerprintUserMessageTypeImageMessage 

Fingerprint image message

GrabbaFingerprintUserMessageTypePlaceFingerForAcquisition 

User requested to place finger for acquisition.

GrabbaFingerprintUserMessageTypePlaceFirstFingerForAcquisition 

User requested to place first finger for acquisition.

GrabbaFingerprintUserMessageTypePlaceSecondFingerForAcquisition 

User requested to place second finger for acquisition.

GrabbaFingerprintUserMessageTypeMatchSuccessful 

Match was successful.

GrabbaFingerprintUserMessageTypeMatchUnsuccessfulNotSameFinger 

Match was unsuccessful due to a different finger being used.

GrabbaFingerprintUserMessageTypeMatchUnsuccessfulDatabaseEmpty 

Match was unsuccessful due to the internal database being empty.

GrabbaFingerprintUserMessageTypeMatchUnsuccessfulFalseFingerDetected 

Match was unsuccessful due to a false finger being detected.

GrabbaFingerprintUserMessageTypeMatchUnsuccessfulMoistFinger 

Match was unsuccessful due to a moist finger being detected.

GrabbaFingerprintUserMessageTypeErrorAlreadyEnrolled 

Enrolment error - finger already enrolled.

GrabbaFingerprintUserMessageTypeErrorInvalidUserID 

Enrolment error - invalid user ID.

GrabbaFingerprintUserMessageTypeErrorInvalidUserData 

Enrolment error - invalid user data.

GrabbaFingerprintUserMessageTypeImageProgress 

Fingerprint image progress message

GrabbaFingerprintUserMessageTypeImageDetectQuality 

Image detection quality message.

GrabbaFingerprintUserMessageTypeImageCodeQuality 

Image code quality message.

GrabbaFingerprintUserMessageTypeErrorOperationTimeout 

Error - operation timed out.

GrabbaFingerprintUserMessageTypeErrorSameFinger 

Error - same finger was repeated when a different finger was expected.

GrabbaFingerprintUserMessageTypeErrorNoDatabase 

Error - internal database is unavailable.

GrabbaFingerprintUserMessageTypeErrorCommandInProgress 

Error - another command is already in progress.

GrabbaFingerprintUserMessageTypeErrorFingerprintDatabaseFull 

Error - internal database is full.

GrabbaFingerprintUserMessageTypeEmptyMessage 

Empty (null) message - sentinel value.

◆ GrabbaMRZ_Format

enum GrabbaMRZ_Format : NSInteger

Enumeration of MRZ formats as defined by ICAO 9303, plus a sentinel value for unknown/invalid text.

Five sizes of MRZ are specified in ICAO 9303 - TD1, TD2, TD3, MRV-A and MRV-B. Passports use the TD3 format, official travel documents use the TD1 or TD2 formats, and visas use the MRV-A or MRV-B formats.

The specifications may be found in:

  • ICAO 9303 part 3 - aspects common to all MRZ sizes
  • ICAO 9303 part 4 - passports and other TD3-size MRZs (2 lines of 44 characters each)
  • ICAO 9303 part 5 - official travel documents of TD1 size (3 lines of 30 characters each)
  • ICAO 9303 part 6 - official travel documents of TD2 size (2 lines of 36 characters each)
  • ICAO 9303 part 7 - visas of MRV-A (2 lines of 36 characters) or MRV-B (2 lines of 44 characters) sizes
Enumerator
GrabbaMRZ_FormatUnknown 

Invalid or unknown MRZ format.

GrabbaMRZ_FormatTD1 

TD1-size official travel document, 3 lines of 30 characters apiece.

GrabbaMRZ_FormatTD2 

TD2-size official travel document, 2 lines of 36 characters apiece.

GrabbaMRZ_FormatTD3 

TD3-size passport or similar document, 2 lines of 44 characters each.

GrabbaMRZ_FormatMRV_A 

MRV-A visa, 2 lines of 44 characters apiece.

GrabbaMRZ_FormatMRV_B 

MRV-B visa, 2 lines of 36 characters apiece.

◆ GrabbaProxcardTypeID

enum GrabbaProxcardTypeID : NSInteger

RFID and proximity card type identifiers which are supported by the driver.

This is typically used in conjunction with the GrabbaProxcardData class, where it provides identification of card/tag types upon successful scans.

The GrabbaProxcardTypeUnknown value is a sentinel which signifies that the card/tag could not be detected (e.g. if it does not match any of the supported types); the other values all represent legitimate types.

Note
Not all card/tag types are supported by all proxcard reader types.
See also
GrabbaProxcardData for the most common usage of this type, and for a method which generates string representations of the IDs.
Enumerator
GrabbaProxcardTypeIClass 

iClass card

GrabbaProxcardTypeMifare 

Mifare card.

GrabbaProxcardTypeMifare4K 

Mifare 4K card.

GrabbaProxcardTypeMifareUL 

Mifare UL card.

GrabbaProxcardTypeMifareProx 

MifareProx card.

GrabbaProxcardTypeSLE55RXX 

SLE55RXX card.

GrabbaProxcardTypeSLE66CL160S 

SLE66CL160S card.

GrabbaProxcardTypeICode 

ICode card.

GrabbaProxcardTypeICodeSLI 

ICode SLI card.

GrabbaProxcardTypeTagit 

Tagit card.

GrabbaProxcardTypeTagitHFI 

Tagit HFI card.

GrabbaProxcardTypeICodePC 

ICode PC card.

GrabbaProxcardTypeICodeUID 

ICode UID card.

GrabbaProxcardTypeISO15693 

ISO 15693 card.

GrabbaProxcardTypeLRI512 

LRI512 card.

GrabbaProxcardTypeSRF55VXXP 

SRF55VXXP card.

GrabbaProxcardTypeSRF55VXXS 

SRF55VXXS card.

GrabbaProxcardTypeTempSense 

TempSense card.

GrabbaProxcardTypeSR176 

SR176 card.

GrabbaProxcardTypeFeliCa 

FeliCa card.

GrabbaProxcardTypeEM4X02 

EM4x02 card.

GrabbaProxcardTypeEM4X05 

EM4x05 card.

GrabbaProxcardTypeEM4X50 

EM4x50 card.

GrabbaProxcardTypeHitag1 

Hitag 1 card.

GrabbaProxcardTypeHitag2 

Hitag 2 card.

GrabbaProxcardTypeQ5 

Q5 card.

GrabbaProxcardTypeHID_Prox 

HID proximity card.

GrabbaProxcardTypeISO14443A 

ISO 14443 type A card.

GrabbaProxcardTypeISO14443B 

ISO 14443 type B card.

GrabbaProxcardTypeISO14443C 

ISO 14443 type C card.

GrabbaProxcardTypeIClassProgrammedID 

iClass programmed ID card

GrabbaProxcardTypeTI_RFID 

TI RFID card.

GrabbaProxcardTypeUHF 

UHF card.

GrabbaProxcardTypeUnknown 

Unknown card type (sentinel value)

◆ GrabbaSmartcardBaud

enum GrabbaSmartcardBaud : NSInteger

Set of driver-supported baud parameter values, with representations matching those in ISO/IEC 7816-3.

This enumeration lists the valid values for parameter Di, which is the indicated value of the baud rate adjustment integer.

The representation used here matches that of the lower (less significant) nibble of bytes TA1 (ATR) and PPS1 (PPS) in ISO/IEC 7816-3.

The default value is GrabbaSmartcardBaud1 (Di = 1).

Note
Values 0, 10, 11, 12, 13, 14 and 15 are reserved for future use by ISO/IEC 7816-3.
See also
GrabbaSmartcardAPI for the most common usage of this type
Enumerator
GrabbaSmartcardBaud1 

Di = 1.

GrabbaSmartcardBaud2 

Di = 2.

GrabbaSmartcardBaud4 

Di = 4.

GrabbaSmartcardBaud8 

Di = 8.

GrabbaSmartcardBaud16 

Di = 16.

GrabbaSmartcardBaud32 

Di = 32.

GrabbaSmartcardBaud64 

Di = 64.

GrabbaSmartcardBaud12 

Di = 12.

GrabbaSmartcardBaud20 

Di = 20.

◆ GrabbaSmartcardClock

enum GrabbaSmartcardClock : NSInteger

Set of driver-supported clock values, with representations matching those in ISO/IEC 7816-3.

This enumeration covers the valid combinations of a pair of parameters:

  • Fi - Indicated value of clock rate conversion integer
  • f_max - Maximum frequency supported by the card

The representation used here matches that of the upper (more significant) nibble of bytes TA1 (ATR) and PPS1 (PPS) in ISO/IEC 7816-3.

The default value is GrabbaSmartcardClock372_5M, with Fi = 372 and f_max = 5MHz.

Note
Values 7, 8, 14 and 15 are reserved for future use by ISO/IEC 7816-3.
See also
GrabbaSmartcardAPI for the most common usage of this type
Enumerator
GrabbaSmartcardClock372_4M 

Fi = 372, f_max = 4MHz.

GrabbaSmartcardClock372_5M 

Fi = 372, f_max = 5MHz.

GrabbaSmartcardClock558_6M 

Fi = 558, f_max = 6MHz.

GrabbaSmartcardClock744_8M 

Fi = 744, f_max = 8MHz.

GrabbaSmartcardClock1116_12M 

Fi = 1116, f_max = 12MHz.

GrabbaSmartcardClock1488_16M 

Fi = 1488, f_max = 16MHz.

GrabbaSmartcardClock1860_20M 

Fi = 1860, f_max = 20MHz.

GrabbaSmartcardClock512_5M 

Fi = 512, f_max = 5MHz.

GrabbaSmartcardClock768_7M5 

Fi = 768, f_max = 7.5MHz.

GrabbaSmartcardClock1024_10M 

Fi = 1024, f_max = 10MHz.

GrabbaSmartcardClock1536_15M 

Fi = 1536, f_max = 15MHz.

GrabbaSmartcardClock2048_20M 

Fi = 2048, f_max = 20MHz.

◆ GrabbaSmartcardInterfaceID

enum GrabbaSmartcardInterfaceID : NSInteger

Enumeration of contact smart card interfaces.

For Grabba devices containing more than one contact smart card interface, this enumeration allows selection of which interface (and, if present, card) is to be accessed for each command (e.g. APDU exchange).

Contact smart card interfaces provided by Grabba devices fall into one of two categories:

  • Slot - holds a full-sized (ISO/IEC 7816 ID-1) smart card, which may be inserted or removed at any time
  • SAM (Secure Access Module) - holds a miniature (ISO/IEC 7816 ID-0) card, which can't be inserted or removed when the device is powered on

Grabba devices with contact smart card support will contain either a slot interface, a SAM interface, or both. Devices with more than one slot interface and/or more than one SAM interface may be added in future, but are not supported by the current version of the driver.

Note
The ordering and underlying representation of enumeration literals in this type are subject to change. Code which uses it must not make any assumptions about these aspects; i.e. comparisons should be limited to equality tests, and conversions to or from other types should be avoided.
See also
GrabbaSmartcardAPI and GrabbaSmartcardListener for the most common usages of this type
Enumerator
GrabbaSmartcardPrimarySlot 

First slot interface (if present)

GrabbaSmartcardPrimarySAM 

First SAM interface (if present)

◆ GrabbaSmartcardProtocolID

enum GrabbaSmartcardProtocolID : NSInteger

Set of driver-supported protocol (T) values, with representations matching those in ISO/IEC 7816-3.

The default value is GrabbaSmartcardProtocolHalfDuplexChar (T0).

See also
GrabbaSmartcardAPI for the most common usage of this type
Enumerator
GrabbaSmartcardProtocolHalfDuplexChar 

Half-duplex transmission of characters (T0), as per ISO/IEC 7816-3:2006(E) section 10.

GrabbaSmartcardProtocolHalfDuplexBlock 

Half-duplex transmission of blocks (T1), as per ISO/IEC 7816-3:2006(E) section 11.