| Top |  |  |  |  | 
| GckMechanismInfo * | gck_mechanism_info_copy () | 
| void | gck_mechanism_info_free () | 
| #define | gck_mechanisms_length() | 
| #define | gck_mechanisms_at() | 
| gboolean | gck_mechanisms_check () | 
| gboolean | gck_slot_equal () | 
| guint | gck_slot_hash () | 
| GckModule * | gck_slot_get_module () | 
| gulong | gck_slot_get_handle () | 
| GckSlotInfo * | gck_slot_get_info () | 
| gboolean | gck_slot_match () | 
| GckTokenInfo * | gck_slot_get_token_info () | 
| GArray * | gck_slot_get_mechanisms () | 
| GckMechanismInfo * | gck_slot_get_mechanism_info () | 
| gboolean | gck_slot_has_flags () | 
| GckEnumerator * | gck_slot_enumerate_objects () | 
| GckEnumerator * | gck_slots_enumerate_objects () | 
| GckSession * | gck_slot_open_session () | 
| GckSession * | gck_slot_open_session_full () | 
| void | gck_slot_open_session_full_async () | 
| void | gck_slot_open_session_async () | 
| GckSession * | gck_slot_open_session_finish () | 
| GckSlot * | gck_slot_from_handle () | 
| GckSlotInfo * | gck_slot_info_copy () | 
| void | gck_slot_info_free () | 
| GckTokenInfo * | gck_token_info_copy () | 
| void | gck_token_info_free () | 
| struct | GckMechanismInfo | 
| enum | GckSessionOptions | 
| struct | GckSlot | 
| struct | GckSlotInfo | 
| struct | GckTokenInfo | 
A PKCS11 slot can contain a token. As an example, a slot might be a card reader, and the token the card. If the PKCS#11 module is not a hardware driver, often the slot and token are equivalent.
GckMechanismInfo *
gck_mechanism_info_copy (GckMechanismInfo *mech_info);
Make a copy of the mechanism info.
void
gck_mechanism_info_free (GckMechanismInfo *mech_info);
Free the GckMechanismInfo and associated resources.
#define gck_mechanisms_length(a) ((a)->len)
Get the number of GckMechanismInfo in the set.
#define gck_mechanisms_at(a, i) (g_array_index (a, CK_MECHANISM_TYPE, i))
Get a specific mechanism in a the set.
gboolean gck_mechanisms_check (GArray *mechanisms,...);
Check whether all the mechanism types are in the list.
The arguments should be a list of CKM_XXX mechanism types. The last argument should be GCK_INVALID.
| mechanisms |  A list of mechanisms, perhaps
retrieved from  | [element-type ulong] | 
| ... | A list of mechanism types followed by GCK_INVALID. | 
gboolean gck_slot_equal (gconstpointer slot1,gconstpointer slot2);
Checks equality of two slots. Two GckSlot objects can point to the same underlying PKCS#11 slot.
guint
gck_slot_hash (gconstpointer slot);
Create a hash value for the GckSlot.
This function is intended for easily hashing a GckSlot to add to a GHashTable or similar data structure.
GckModule *
gck_slot_get_module (GckSlot *self);
Get the module that this slot is on.
gulong
gck_slot_get_handle (GckSlot *self);
Get the raw PKCS#11 handle of a slot.
GckSlotInfo *
gck_slot_get_info (GckSlot *self);
Get the information for this slot.
gboolean gck_slot_match (GckSlot *self,GckUriData *uri);
Check whether the PKCS#11 URI matches the slot
GckTokenInfo *
gck_slot_get_token_info (GckSlot *self);
Get the token information for this slot.
GArray *
gck_slot_get_mechanisms (GckSlot *self);
Get the available mechanisms for this slot.
 a list of the mechanisms
for this slot, which should be freed with g_array_free(). 
[transfer full][element-type ulong]
GckMechanismInfo * gck_slot_get_mechanism_info (GckSlot *self,gulong mech_type);
Get information for the specified mechanism.
 the mechanism information, or NULL if failed; use
gck_mechanism_info_free() when done with it. 
[transfer full]
gboolean gck_slot_has_flags (GckSlot *self,gulong flags);
Check if the PKCS11 slot has the given flags.
GckEnumerator * gck_slot_enumerate_objects (GckSlot *self,GckAttributes *match,GckSessionOptions options);
Setup an enumerator for listing matching objects on the slot.
If the match
 GckAttributes is floating, it is consumed.
This call will not block but will return an enumerator immediately.
| self | a GckSlot to enumerate objects on | |
| match | attributes that the objects must match, or empty for all objects | |
| options | options for opening a session | 
GckEnumerator * gck_slots_enumerate_objects (GList *slots,GckAttributes *match,GckSessionOptions options);
Setup an enumerator for listing matching objects on the slots.
If the match
 GckAttributes is floating, it is consumed.
This call will not block but will return an enumerator immediately.
| slots | a list of GckSlot to enumerate objects on. | [element-type Gck.Slot] | 
| match | attributes that the objects must match, or empty for all objects | |
| options | options for opening a session | 
GckSession * gck_slot_open_session (GckSlot *self,GckSessionOptions options,GCancellable *cancellable,GError **error);
Open a session on the slot. If the 'auto reuse' setting is set, then this may be a recycled session with the same flags.
This call may block for an indefinite period.
| self | The slot ot open a session on. | |
| options | The GckSessionOptions to open a session with. | |
| cancellable | An optional cancellation object, or  | |
| error | A location to return an error, or  | 
GckSession * gck_slot_open_session_full (GckSlot *self,GckSessionOptions options,gulong pkcs11_flags,gpointer app_data,CK_NOTIFY notify,GCancellable *cancellable,GError **error);
Open a session on the slot. If the 'auto reuse' setting is set, then this may be a recycled session with the same flags.
This call may block for an indefinite period.
[skip]
| self | The slot to open a session on. | |
| options | The options to open the new session with. | |
| pkcs11_flags | Additional raw PKCS#11 flags. | |
| app_data | Application data for notification callback. | |
| notify | PKCS#11 notification callback. | |
| cancellable | Optional cancellation object, or NULL. | |
| error | A location to return an error, or NULL. | 
void gck_slot_open_session_full_async (GckSlot *self,GckSessionOptions options,gulong pkcs11_flags,gpointer app_data,CK_NOTIFY notify,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Open a session on the slot. If the 'auto reuse' setting is set, then this may be a recycled session with the same flags.
This call will return immediately and complete asynchronously.
[skip]
| self | The slot to open a session on. | |
| options | Options to open the new session with. | |
| pkcs11_flags | Additional raw PKCS#11 flags. | |
| app_data | Application data for notification callback. | |
| notify | PKCS#11 notification callback. | |
| cancellable | Optional cancellation object, or NULL. | |
| callback | Called when the operation completes. | |
| user_data | Data to pass to the callback. | 
void gck_slot_open_session_async (GckSlot *self,GckSessionOptions options,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Open a session on the slot. If the 'auto reuse' setting is set, then this may be a recycled session with the same flags.
This call will return immediately and complete asynchronously.
GckSession * gck_slot_open_session_finish (GckSlot *self,GAsyncResult *result,GError **error);
Get the result of an open session operation. If the 'auto reuse' setting is set, then this may be a recycled session with the same flags.
GckSlot * gck_slot_from_handle (GckModule *module,gulong slot_id);
Create a new GckSlot object for a raw PKCS#11 handle.
GckSlotInfo *
gck_slot_info_copy (GckSlotInfo *slot_info);
Make a copy of the slot info.
void
gck_slot_info_free (GckSlotInfo *slot_info);
Free the GckSlotInfo and associated resources.
GckTokenInfo *
gck_token_info_copy (GckTokenInfo *token_info);
Make a copy of the token info.
void
gck_token_info_free (GckTokenInfo *token_info);
Free the GckTokenInfo and associated resources.
struct GckMechanismInfo {
	gulong min_key_size;
	gulong max_key_size;
	gulong flags;
};
Represents information about a PKCS11 mechanism.
This is analogous to a CK_MECHANISM_INFO structure.
When you're done with this structure it should be released with
gck_mechanism_info_free().
struct GckSlotInfo {
	gchar *slot_description;
	gchar *manufacturer_id;
	gulong flags;
	guint8 hardware_version_major;
	guint8 hardware_version_minor;
	guint8 firmware_version_major;
	guint8 firmware_version_minor;
};
Represents information about a PKCS11 slot.
This is analogous to a CK_SLOT_INFO structure, but the strings are far more usable.
When you're done with this structure it should be released with
gck_slot_info_free().
| gchar * | Description of the slot. | |
| gchar * | The manufacturer of this slot. | |
| gulong  | Various PKCS11 flags that apply to this slot. | |
| guint8  | The major version of the hardware. | |
| guint8  | The minor version of the hardware. | |
| guint8  | The major version of the firmware. | |
| guint8  | The minor version of the firmware. | 
struct GckTokenInfo {
	gchar *label;
	gchar *manufacturer_id;
	gchar *model;
	gchar *serial_number;
	gulong flags;
	glong max_session_count;
	glong session_count;
	glong max_rw_session_count;
	glong rw_session_count;
	glong max_pin_len;
	glong min_pin_len;
	glong total_public_memory;
	glong free_public_memory;
	glong total_private_memory;
	glong free_private_memory;
	guint8 hardware_version_major;
	guint8 hardware_version_minor;
	guint8 firmware_version_major;
	guint8 firmware_version_minor;
	gint64 utc_time;
};
Represents information about a PKCS11 token.
This is analogous to a CK_TOKEN_INFO structure, but the strings are far more usable.
When you're done with this structure it should be released with
gck_token_info_free().
| gchar * | The displayable token label. | |
| gchar * | The manufacturer of this slot. | |
| gchar * | The token model number as a string. | |
| gchar * | The token serial number as a string. | |
| gulong  | Various PKCS11 flags that apply to this token. | |
| glong  | The maximum number of sessions allowed on this token. | |
| glong  | The number of sessions open on this token. | |
| glong  | The maximum number of read/write sessions allowed on this token. | |
| glong  | The number of sessions open on this token. | |
| glong  | The maximum length of a PIN for locking this token. | |
| glong  | The minimum length of a PIN for locking this token. | |
| glong  | The total amount of memory on this token for storing public objects. | |
| glong  | The available amount of memory on this token for storing public objects. | |
| glong  | The total amount of memory on this token for storing private objects. | |
| glong  | The available amount of memory on this token for storing private objects. | |
| guint8  | The major version of the hardware. | |
| guint8  | The minor version of the hardware. | |
| guint8  | The major version of the firmware. | |
| guint8  | The minor version of the firmware. | |
| gint64  | If the token has a hardware clock, this is set to the number of seconds since the epoch. |