Overview
| Comment: | Updated to keep track of required token flags | 
|---|---|
| Downloads: | Tarball | ZIP archive | SQL archive | 
| Timelines: | family | ancestors | descendants | both | trunk | 
| Files: | files | file ages | folders | 
| SHA1: | 93bbed97eb15861737b489af5f4090cb | 
| User & Date: | rkeene on 2010-05-18 14:11:05 | 
| Other Links: | manifest | tags | 
Context
| 2010-05-18 | ||
| 14:22 | Updated to support CKF_USER_PIN_FINAL_TRY check-in: 0fda67f954 user: rkeene tags: trunk | |
| 14:11 | Updated to keep track of required token flags check-in: 93bbed97eb user: rkeene tags: trunk | |
| 2010-05-17 | ||
| 23:11 | Updated debugging output check-in: 824ac1bc2e user: rkeene tags: trunk | |
Changes
Modified cackey.c from [806bbf2a79] to [86c9a91f33].
| ︙ | |||
| 516 517 518 519 520 521 522 523 524 525 526 527 528 529 | 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 | + + | 
	int pcsc_card_connected;
	SCARDHANDLE pcsc_card;
	int transaction_depth;
	int slot_reset;
	CK_FLAGS token_flags;
};
typedef enum {
	CACKEY_TLV_APP_GENERIC = 0x01,
	CACKEY_TLV_APP_SKI     = 0x02,
	CACKEY_TLV_APP_PKI     = 0x04
} cackey_tlv_apptype;
 | 
| ︙ | |||
| 2807 2808 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 | 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 | + | 
	}
	for (idx = 0; idx < (sizeof(cackey_slots) / sizeof(cackey_slots[0])); idx++) {
		cackey_slots[idx].active = 0;
		cackey_slots[idx].pcsc_reader = NULL;
		cackey_slots[idx].transaction_depth = 0;
		cackey_slots[idx].slot_reset = 0;
		cackey_slots[idx].token_flags = 0;
	}
	cackey_initialized = 1;
	if (!cackey_biglock_init) {
		mutex_init_ret = cackey_mutex_create(&cackey_biglock);
 | 
| ︙ | |||
| 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 | 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 | + | 
					/* Only update the list of slots if we are actually being supply the slot information */
					if (pSlotList) {
						cackey_slots[currslot].active = 1;
						cackey_slots[currslot].pcsc_reader = strdup(pcsc_readers);
						cackey_slots[currslot].pcsc_card_connected = 0;
						cackey_slots[currslot].transaction_depth = 0;
						cackey_slots[currslot].slot_reset = 1;
						cackey_slots[currslot].token_flags = CKF_LOGIN_REQUIRED;
					}
					currslot++;
					pcsc_readers += curr_reader_len + 1;
				}
				if (currslot > 0) {
 | 
| ︙ | |||
| 3224 3225 3226 3227 3228 3229 3230 | 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 | - + | pInfo->hardwareVersion.major = (cackey_getversion() >> 16) & 0xff; pInfo->hardwareVersion.minor = (cackey_getversion() >> 8) & 0xff; pInfo->firmwareVersion.major = 0x00; pInfo->firmwareVersion.minor = 0x00; | 
| ︙ | |||
| 3743 3744 3745 3746 3747 3748 3749 3750 3751 3752 3753 3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 | 3747 3748 3749 3750 3751 3752 3753 3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775 3776 3777 | + + + + + + | 
	login_ret = cackey_login(&cackey_slots[cackey_sessions[hSession].slotID], pPin, ulPinLen, NULL);
	if (login_ret != CACKEY_PCSC_S_OK) {
		cackey_mutex_unlock(cackey_biglock);
		if (login_ret == CACKEY_PCSC_E_LOCKED) {
			CACKEY_DEBUG_PRINTF("Error.  Token is locked.");
			cackey_slots[cackey_sessions[hSession].slotID].token_flags |= CKF_USER_PIN_LOCKED;
			return(CKR_PIN_LOCKED);
		} else if (login_ret == CACKEY_PCSC_E_BADPIN) {
			CACKEY_DEBUG_PRINTF("Error.  Invalid PIN.");
			cackey_slots[cackey_sessions[hSession].slotID].token_flags |= CKF_USER_PIN_COUNT_LOW;
			return(CKR_PIN_INCORRECT);
		}
		CACKEY_DEBUG_PRINTF("Error.  Unknown error returned from cackey_login() (%i)", login_ret);
		return(CKR_GENERAL_ERROR);
	}
	cackey_slots[cackey_sessions[hSession].slotID].token_flags &= ~(CKF_USER_PIN_LOCKED | CKF_USER_PIN_COUNT_LOW | CKF_LOGIN_REQUIRED);
	cackey_sessions[hSession].state = CKS_RO_USER_FUNCTIONS;
	mutex_retval = cackey_mutex_unlock(cackey_biglock);
	if (mutex_retval != 0) {
		CACKEY_DEBUG_PRINTF("Error.  Unlocking failed.");
 | 
| ︙ | |||
| 4057 4058 4059 4060 4061 4062 4063 4064 4065 4066 4067 4068 4069 4070 | 4067 4068 4069 4070 4071 4072 4073 4074 4075 4076 4077 4078 4079 4080 4081 | + | 
			cackey_free_identities(cackey_sessions[hSession].identities, cackey_sessions[hSession].identities_count);
			cackey_sessions[hSession].identities = NULL;
			cackey_sessions[hSession].identities_count = 0;
		}
		cackey_slots[cackey_sessions[hSession].slotID].slot_reset = 0;
		cackey_slots[cackey_sessions[hSession].slotID].token_flags = CKF_LOGIN_REQUIRED;
	}
	if (cackey_sessions[hSession].identities == NULL) {
		cackey_sessions[hSession].identities = cackey_read_identities(&cackey_slots[cackey_sessions[hSession].slotID], &cackey_sessions[hSession].identities_count);
	}
	if (pTemplate != NULL) {
 | 
| ︙ | |||
| 4916 4917 4918 4919 4920 4921 4922 | 4927 4928 4929 4930 4931 4932 4933 4934 4935 4936 4937 4938 4939 4940 4941 | - + | memcpy(cackey_sessions[hSession].sign_buf + cackey_sessions[hSession].sign_bufused, pPart, ulPartLen); cackey_sessions[hSession].sign_bufused += ulPartLen; break; case CKM_SHA1_RSA_PKCS: | 
| ︙ | |||
| 5019 5020 5021 5022 5023 5024 5025 | 5030 5031 5032 5033 5034 5035 5036 5037 5038 5039 5040 5041 5042 5043 5044 | - + | *pulSignatureLen = sigbuflen; retval = CKR_OK; } break; case CKM_SHA1_RSA_PKCS: | 
| ︙ |