Sample code for 30+ languages & platforms
Swift

PKCS11 Initialize Normal User PIN

See more PKCS11 Examples

Initializes the Normal User PIN from the Security Officer's logged-on session. This provides a way to reset the user PIN if it has been forgotten.

Note: Requires Chilkat v9.5.0.89 or greater.

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    // Note: Chilkat's PKCS11 implementation runs on Windows, Linux, Mac OS X, and other supported operating systems.

    let pkcs11 = CkoPkcs11()!

    // See PKCS11 Find Driver Library Path for information about how to find the 
    // PKCS11 driver file (if not explicitly known) for the plugged-in token or smart card in reader.
    pkcs11.sharedLibPath = "IDPrimePKCS1164.dll"

    success = pkcs11.initialize()
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        return
    }

    // Pass -1 for the slotID to open a session on the first non-empty slot.
    var slotID: Int = -1

    // Open a session.
    var readWrite: Bool = true
    success = pkcs11.openSession(slotId: slotID, readWrite: readWrite)
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        return
    }

    // Login as the security officer.
    // The smart card PIN is passed to the Login method.
    // The user type can be one of three choices:
    // 0 - Security Officer
    // 1 - Normal User
    // 2 - Context Specific.
    var userType: Int = 0
    var pin: String? = "AA0000000000000000000000000000000000000000000000"
    success = pkcs11.login(userType: userType, pin: pin)
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        success = pkcs11.closeSession()
        return
    }

    // Reset the user PIN to 1234
    success = pkcs11.initPin(pin: "1234")
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        success = pkcs11.closeSession()
        return
    }

    // Revert to an unauthenticated session by calling Logout.
    success = pkcs11.logout()
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        success = pkcs11.closeSession()
        return
    }

    // When finished, close the session.
    // It is important to close the session (memory leaks will occur if the session is not properly closed).
    success = pkcs11.closeSession()
    if success == false {
        print("\(pkcs11.lastErrorText!)")
        return
    }

    print("Successfully reset user PIN to 1234")

}