Drivers License

Declaration

func scanDriversLicense(
    on viewController: UIViewController, 
    for country: Country, 
    doneLaunching: SybrinIdentity.doneLaunchingType? = nil, 
    success: SybrinIdentity.driversLicenseSuccessCallbackType? = nil, 
    failure: SybrinIdentity.failureCallbackType? = nil, 
    cancel: SybrinIdentity.cancelCallbackType? = nil
)

To view all the type aliases, go to the SybrinIdentity class

Handling the doneLaunching , success , failureor cancel callbacks are optional but recommended.

To find out if we support a country, check out Supported Documents! To request support for a country, contact us!

Calling the function

Parameters

Handling callback responses

doneLaunching

The doneLaunching callback will be executed after the view controller has successfully launched, or if the view controller failed to launch.

Parameters:

Example:

doneLaunching: { (didLaunch, message) in
    if didLaunch {
        print("Launched successfully!")
    } else if let message = message {
        print("Failed to launch because \(message)")
    }
}

success

The success callback will be executed after scanning has finished and the view controller has been dismissed.

Parameters:

As explained in Features, the success callback will always return the country specific model but in its parent class form. However, this can be casted to the country specific model to access that country model's specific properties.

This is not required, but is recommended if you would like to access the country model's specific properties.

Let's say that you provide the scanDriversLicense function with the .SouthAfrica country parameter. The result will be of type SouthAfricaDriversLicenseModel, but is returned in its parent form DriversLicenseModel. To access all the data specific to SouthAfricaDriversLicenseModel you will need to cast the DriversLicenseModel to that type.

Example:

success: { (model) in
    if let southAfricaDriversLicense = model as? SouthAfricaDriversLicenseModel {
        print("This is a south african drivers license model! \(southAfricaDriversLicense.identityNumber)")
    }
}

failure

The failure callback will be executed after scanning has failed and the view controller has been dismissed.

Parameters:

If you would like to report a bug, contact us!

Example:

failure: { (message) in
    print("Scan drivers license failed because \(message)")
}

cancel

The cancel callback will be executed after the user has dismissed the view controller and before scanning could finish.

Parameters:

None

Example:

cancel: {
    print("Scan drivers license canceled")
}

Full Example

SybrinIdentity.shared.scanDriversLicense(on: self, for: .SouthAfrica) 
{ (didLaunch, message) in
    if didLaunch {
        print("Launched successfully!")
    } else if let message = message {
        print("Failed to launch because \(message)")
    }
} success: { (model) in
    if let southAfricaDriversLicense = model as? SouthAfricaDriversLicenseModel {
        print("Scan drivers license success: \(southAfricaDriversLicense.identityNumber)")
    }
} failure: { (message) in
    print("Scan drivers license failed because \(message)")
} cancel: {
    print("Scan drivers license canceled")
}

Last updated