Swift
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
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")
}