![]() |
![]() |
![]() |
PSKC Library Manual | ![]() |
---|---|---|---|---|
Top | Description |
const char * pskc_get_cryptomodule_id (pskc_key_t *key
); const char * pskc_get_device_devicebinding (pskc_key_t *key
); const struct tm * pskc_get_device_expirydate (pskc_key_t *key
); const char * pskc_get_device_issueno (pskc_key_t *key
); const char * pskc_get_device_manufacturer (pskc_key_t *key
); const char * pskc_get_device_model (pskc_key_t *key
); const char * pskc_get_device_serialno (pskc_key_t *key
); const struct tm * pskc_get_device_startdate (pskc_key_t *key
); const char * pskc_get_device_userid (pskc_key_t *key
); const char * pskc_get_key_algorithm (pskc_key_t *key
); int pskc_get_key_algparm_chall_checkdigits (pskc_key_t *key
,int *present
); pskc_valueformat pskc_get_key_algparm_chall_encoding (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_algparm_chall_max (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_algparm_chall_min (pskc_key_t *key
,int *present
); int pskc_get_key_algparm_resp_checkdigits (pskc_key_t *key
,int *present
); pskc_valueformat pskc_get_key_algparm_resp_encoding (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_algparm_resp_length (pskc_key_t *key
,int *present
); const char * pskc_get_key_algparm_suite (pskc_key_t *key
); const char * pskc_get_key_data_b64secret (pskc_key_t *key
); uint64_t pskc_get_key_data_counter (pskc_key_t *key
,int *present
); const char * pskc_get_key_data_secret (pskc_key_t *key
,size_t *len
); uint32_t pskc_get_key_data_time (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_data_timedrift (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_data_timeinterval (pskc_key_t *key
,int *present
); const char * pskc_get_key_friendlyname (pskc_key_t *key
); const char * pskc_get_key_id (pskc_key_t *key
); const char * pskc_get_key_issuer (pskc_key_t *key
); const struct tm * pskc_get_key_policy_expirydate (pskc_key_t *key
); int pskc_get_key_policy_keyusages (pskc_key_t *key
,int *present
); uint64_t pskc_get_key_policy_numberoftransactions (pskc_key_t *key
,int *present
); pskc_valueformat pskc_get_key_policy_pinencoding (pskc_key_t *key
,int *present
); const char * pskc_get_key_policy_pinkeyid (pskc_key_t *key
); uint32_t pskc_get_key_policy_pinmaxfailedattempts (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_policy_pinmaxlength (pskc_key_t *key
,int *present
); uint32_t pskc_get_key_policy_pinminlength (pskc_key_t *key
,int *present
); pskc_pinusagemode pskc_get_key_policy_pinusagemode (pskc_key_t *key
,int *present
); const struct tm * pskc_get_key_policy_startdate (pskc_key_t *key
); const char * pskc_get_key_profileid (pskc_key_t *key
); const char * pskc_get_key_reference (pskc_key_t *key
); const char * pskc_get_key_userid (pskc_key_t *key
);
While high-level PSKC structure is represented through the pskc_t
type, the data for each key package is represented through
pskc_key_t. The pskc_get_keypackage()
function is used to access
the pskc_key_t values. This section describes all the functions
that are used to access information stored in PSKC key packages.
const char * pskc_get_cryptomodule_id (pskc_key_t *key
);
Get the PSKC KeyPackage CryptoModule Id value. This element carries a unique identifier for the CryptoModule and is implementation specific. As such, it helps to identify a specific CryptoModule to which the key is being or was provisioned.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_devicebinding (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo Devicebinding value. This element allows a provisioning server to ensure that the key is going to be loaded into the device for which the key provisioning request was approved. The device is bound to the request using a device identifier, e.g., an International Mobile Equipment Identity (IMEI) for the phone, or an identifier for a class of identifiers, e.g., those for which the keys are protected by a Trusted Platform Module (TPM).
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const struct tm * pskc_get_device_expirydate (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo ExpiryDate. This element denote the end date of a device (such as the one on a payment card, used when issue numbers are not printed on cards).
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant struct (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_issueno (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo Issueno value. This element contains the issue number in case there are devices with the same serial number so that they can be distinguished by different issue numbers.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_manufacturer (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo Manufacturer value. This element indicates the manufacturer of the device.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_model (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo Model value. This element describes the model of the device (e.g., "one-button-HOTP-token-V1").
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_serialno (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo SerialNo value. This element contains the serial number of the device.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const struct tm * pskc_get_device_startdate (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo StartDate. This element denote the start date of a device (such as the one on a payment card, used when issue numbers are not printed on cards).
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant struct (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_device_userid (pskc_key_t *key
);
Get the PSKC KeyPackage DeviceInfo Userid value. This indicates the user with whom the device is associated.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_algorithm (pskc_key_t *key
);
Get the PSKC KeyPackage Key Algorithm attribute value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
int pskc_get_key_algparm_chall_checkdigits (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ChallengeFormat CheckDigits value. This attribute indicates whether a device needs to check the appended Luhn check digit, as defined in [ISOIEC7812], contained in a challenge. This is only valid if the 'Encoding' attribute is set to 'DECIMAL'. A value of TRUE indicates that the device will check the appended Luhn check digit in a provided challenge. A value of FALSE indicates that the device will not check the appended Luhn check digit in the challenge.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
1 to indicate a CheckDigits value of true, or 0 to indicate false. |
pskc_valueformat pskc_get_key_algparm_chall_encoding (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ChallengeFormat Encoding value. This attribute defines the encoding of the challenge accepted by the device.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an pskc_valueformat value |
uint32_t pskc_get_key_algparm_chall_max (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ChallengeFormat Max value. This attribute defines the maximum size of the challenge accepted by the device for CR mode and MUST be included. If the 'Encoding' attribute is set to 'DECIMAL', 'HEXADECIMAL', or 'ALPHANUMERIC', this value indicates the maximum number of digits/characters. If the 'Encoding' attribute is set to 'BASE64' or 'BINARY', this value indicates the maximum number of bytes of the unencoded value.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
uint32_t pskc_get_key_algparm_chall_min (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ChallengeFormat Min value. This attribute defines the minimum size of the challenge accepted by the device for CR mode and MUST be included. If the 'Encoding' attribute is set to 'DECIMAL', 'HEXADECIMAL', or 'ALPHANUMERIC', this value indicates the minimum number of digits/characters. If the 'Encoding' attribute is set to 'BASE64' or 'BINARY', this value indicates the minimum number of bytes of the unencoded value.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
int pskc_get_key_algparm_resp_checkdigits (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ResponseFormat CheckDigits value. This attribute indicates whether the device needs to append a Luhn check digit, as defined in [ISOIEC7812], to the response. This is only valid if the 'Encoding' attribute is set to 'DECIMAL'. If the value is TRUE, then the device will append a Luhn check digit to the response. If the value is FALSE, then the device will not append a Luhn check digit to the response.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
1 to indicate a CheckDigits value of true, or 0 to indicate false. |
pskc_valueformat pskc_get_key_algparm_resp_encoding (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ResponseFormat Encoding value. This attribute defines the encoding of the response generated by the device, it MUST be included.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an pskc_valueformat value |
uint32_t pskc_get_key_algparm_resp_length (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key AlgorithmParameters ResponseFormat Length value. This attribute defines the length of the response generated by the device and MUST be included. If the 'Encoding' attribute is set to 'DECIMAL', 'HEXADECIMAL', or ALPHANUMERIC, this value indicates the number of digits/characters. If the 'Encoding' attribute is set to 'BASE64' or 'BINARY', this value indicates the number of bytes of the unencoded value.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
const char * pskc_get_key_algparm_suite (pskc_key_t *key
);
Get the PSKC KeyPackage Key AlgorithmParameters Suite value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_data_b64secret (pskc_key_t *key
);
Get the PSKC KeyPackage Key Data Secret value in base64 as a zero-terminated string.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the
content of length *len , or NULL if not set. |
uint64_t pskc_get_key_data_counter (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Data Counter value. This element contains the event counter for event- based OTP algorithms.
If present
is non-NULL, it will be 0 if the Counter field is not
present or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
const char * pskc_get_key_data_secret (pskc_key_t *key
,size_t *len
);
Get the PSKC KeyPackage Key Data Secret value. If len
is not set,
the caller can only use the returned value for comparison against
NULL to check whether the field is present or not.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
pointer to output variable with length of returned data. |
Returns : |
a constant string (must not be deallocated) holding the
content of length *len , or NULL if not set. |
uint32_t pskc_get_key_data_time (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Data Time value. This element contains the time for time-based OTP algorithms. (If time intervals are used, this element carries the number of time intervals passed from a specific start point, normally it is algorithm dependent).
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
uint32_t pskc_get_key_data_timedrift (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Data TimeDrift value. This element contains the device clock drift value for time-based OTP algorithms. The integer value (positive or negative drift) that indicates the number of time intervals that a validation server has established the device clock drifted after the last successful authentication. So, for example, if the last successful authentication established a device time value of 8 intervals from a specific start date but the validation server determines the time value at 9 intervals, the server SHOULD record the drift as -1.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
uint32_t pskc_get_key_data_timeinterval (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Data TimeInterval value. This element carries the time interval value for time-based OTP algorithms in seconds (a typical value for this would be 30, indicating a time interval of 30 seconds).
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
const char * pskc_get_key_friendlyname (pskc_key_t *key
);
Get the PSKC KeyPackage Key Friendlyname value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_id (pskc_key_t *key
);
Get the PSKC KeyPackage Key Id attribute value. It is a syntax error for this attribute to not be available.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_issuer (pskc_key_t *key
);
Get the PSKC KeyPackage Key Issuer value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const struct tm * pskc_get_key_policy_expirydate (pskc_key_t *key
);
Get the PSKC KeyPackage Key Policy ExpiryDate. This element denote the expiry of the validity period of a key.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant struct (must not be deallocated) holding the content, or NULL if not set. |
int pskc_get_key_policy_keyusages (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy KeyUsage values. The element puts constraints on the intended usage of the key. The recipient of the PSKC document MUST enforce the key usage.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding a set of pskc_keyusage values ORed together. |
uint64_t pskc_get_key_policy_numberoftransactions (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy NumberOfTransactions value. The value in this element indicates the maximum number of times a key carried within the PSKC document can be used by an application after having received it. When this element is omitted, there is no restriction regarding the number of times a key can be used.
Note that while the PSKC specification uses the XML data type "nonNegativeInteger" for this variable, this implementation restricts the size of the value to 64-bit integers.
If present
is non-NULL, it will be 0 if the Counter field is not
present or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
pskc_valueformat pskc_get_key_policy_pinencoding (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy PINPolicy PINEncoding value. This attribute indicates the encoding of the PIN and MUST be one of the pskc_valueformat values.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an pskc_valueformat value |
const char * pskc_get_key_policy_pinkeyid (pskc_key_t *key
);
Get the PSKC KeyPackage Key Policy PINPolicy PINKeyId value. This attribute carries the unique 'Id' attribute vale of the "Key" element held within this "KeyContainer" that contains the value of the PIN that protects the key.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
uint32_t pskc_get_key_policy_pinmaxfailedattempts (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy PINPolicy MaxFailedAttempts value. This attribute indicates the maximum number of times the PIN may be entered wrongly before it MUST NOT be possible to use the key anymore (typical reasonable values are in the positive integer range of at least 2 and no more than 10).
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
uint32_t pskc_get_key_policy_pinmaxlength (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy PINPolicy MaxLength value. This attribute indicates the maximum length of a PIN that can be set to protect this key. It MUST NOT be possible to set a PIN longer than this value. If the 'PINFormat' attribute is set to 'DECIMAL', 'HEXADECIMAL', or 'ALPHANUMERIC', this value indicates the number of digits/ characters. If the 'PINFormat' attribute is set to 'BASE64' or 'BINARY', this value indicates the number of bytes of the unencoded value.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
uint32_t pskc_get_key_policy_pinminlength (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy PINPolicy MinLength value. This attribute indicates the minimum length of a PIN that can be set to protect the associated key. It MUST NOT be possible to set a PIN shorter than this value. If the 'PINFormat' attribute is set to 'DECIMAL', 'HEXADECIMAL', or 'ALPHANUMERIC', this value indicates the number of digits/ characters. If the 'PINFormat' attribute is set to 'BASE64' or 'BINARY', this value indicates the number of bytes of the unencoded value.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an integer holding the content. |
pskc_pinusagemode pskc_get_key_policy_pinusagemode (pskc_key_t *key
,int *present
);
Get the PSKC KeyPackage Key Policy PINPolicy PINUsageMode value. This mandatory attribute indicates the way the PIN is used during the usage of the key.
If present
is non-NULL, it will be 0 if the field is not present
or 1 if it was present.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
|
output variable indicating whether data was provided or not. |
Returns : |
an pskc_pinusagemode value |
const struct tm * pskc_get_key_policy_startdate (pskc_key_t *key
);
Get the PSKC KeyPackage Key Policy StartDate. This element denote the start of the validity period of a key.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant struct (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_profileid (pskc_key_t *key
);
Get the PSKC KeyPackage Key KeyProfileId value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_reference (pskc_key_t *key
);
Get the PSKC KeyPackage Key KeyReference value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |
const char * pskc_get_key_userid (pskc_key_t *key
);
Get the PSKC KeyPackage Key Userid value.
|
a pskc_key_t handle, from pskc_get_keypackage() . |
Returns : |
a constant string (must not be deallocated) holding the content, or NULL if not set. |