Sample code for 30+ languages & platforms
Unicode C

ScMinidriver - PIN Authentication for Smart Card or USB Token

See more ScMinidriver Examples

Demonstrates how to PIN authenticate with a connected smart card or USB token.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkScMinidriverW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkScMinidriverW scmd;
    const wchar_t *readerName;
    const wchar_t *cardName;
    const wchar_t *pinId;
    const wchar_t *pin;
    int retval;

    success = FALSE;

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

    scmd = CkScMinidriverW_Create();

    // Reader names (smart card readers or USB tokens) can be discovered
    // via List Readers or Find Smart Cards
    readerName = L"Alcor Micro USB Smart Card Reader 0";
    success = CkScMinidriverW_AcquireContext(scmd,readerName);
    if (success == FALSE) {
        wprintf(L"%s\n",CkScMinidriverW_lastErrorText(scmd));
        CkScMinidriverW_Dispose(scmd);
        return;
    }

    // If we are successful, the name of the currently inserted smart card is available:
    cardName = CkScMinidriverW_cardName(scmd);
    wprintf(L"Card name: %s\n",cardName);

    // Perform regular PIN authentication with the smartcard.
    // If authentication is successful, then the ScMinidriver session is authenticated and
    // operations such as signing are permissible.

    // The pin ID can be "user", "admin", or a number "3" through "7" (passed as a string).
    // The possible pin ID's for a given smartcard are obtained via the GetCardProperties method.
    // See Get Smart Card Properties for sample code.
    // You should generally use the "user" pin ID.  You would only use the other pin ID's for very specific purposes.
    pinId = L"user";

    // Change this to the PIN for your smart card.
    pin = L"0000";

    retval = CkScMinidriverW_PinAuthenticate(scmd,pinId,pin);

    // The return value is 0 for success.
    // If the retval is greater than 0, it is the number of attempts remaining before the PIN is blocked.
    // If the retval equals -1, then something else went wrong and you should consult the LastErrorText.
    if (retval < 0) {
        wprintf(L"%s\n",CkScMinidriverW_lastErrorText(scmd));
        CkScMinidriverW_Dispose(scmd);
        return;
    }

    if (retval > 0) {
        wprintf(L"PIN authentcation failed, %d attempts remaining before the PIN is blocked.\n",retval);
    }
    else {
        wprintf(L"PIN authentication successful. Your session is now authenticated and you may proceed with operations such as signing.\n");
    }

    // ...
    // ...
    // ...

    // You may deauthenticate the session when finished with operations that required authentication.
    success = CkScMinidriverW_PinDeauthenticate(scmd,pinId);
    if (success == FALSE) {
        wprintf(L"%s\n",CkScMinidriverW_lastErrorText(scmd));
    }

    // Delete the context when finished with the card.
    success = CkScMinidriverW_DeleteContext(scmd);
    if (success == FALSE) {
        wprintf(L"%s\n",CkScMinidriverW_lastErrorText(scmd));
    }



    CkScMinidriverW_Dispose(scmd);

    }