|  |  |  | GCK Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
GckAttribute; void gck_attribute_init (GckAttribute *attr,gulong attr_type,gconstpointer value,gsize length); void gck_attribute_init_invalid (GckAttribute *attr,gulong attr_type); void gck_attribute_init_empty (GckAttribute *attr,gulong attr_type); void gck_attribute_init_boolean (GckAttribute *attr,gulong attr_type,gboolean value); void gck_attribute_init_date (GckAttribute *attr,gulong attr_type,const GDate *value); void gck_attribute_init_ulong (GckAttribute *attr,gulong attr_type,gulong value); void gck_attribute_init_string (GckAttribute *attr,gulong attr_type,const gchar *value); void gck_attribute_init_copy (GckAttribute *dest,const GckAttribute *src); GckAttribute* gck_attribute_new (gulong attr_type,gpointer value,gsize length); GckAttribute* gck_attribute_new_invalid (gulong attr_type); GckAttribute* gck_attribute_new_empty (gulong attr_type); GckAttribute* gck_attribute_new_boolean (gulong attr_type,gboolean value); GckAttribute* gck_attribute_new_date (gulong attr_type,const GDate *value); GckAttribute* gck_attribute_new_ulong (gulong attr_type,gulong value); GckAttribute* gck_attribute_new_string (gulong attr_type,const gchar *value); gboolean gck_attribute_is_invalid (GckAttribute *attr); gboolean gck_attribute_get_boolean (GckAttribute *attr); gulong gck_attribute_get_ulong (GckAttribute *attr); gchar* gck_attribute_get_string (GckAttribute *attr); void gck_attribute_get_date (GckAttribute *attr,GDate *value); GckAttribute* gck_attribute_dup (GckAttribute *attr); void gck_attribute_clear (GckAttribute *attr); void gck_attribute_free (GckAttribute *attr);
This structure represents a PKCS11 CK_ATTRIBUTE. These attributes contain information
about a PKCS11 object. Use gck_object_get() or gck_object_set() to set and retrieve
attributes on an object.
typedef struct {
	gulong type;
	gconstpointer value;
	gulong length;
} GckAttribute;
This structure represents a PKCS11 CK_ATTRIBUTE.
| gulong  | The attribute type, such as CKA_LABEL. | 
| gconstpointer  | The value of the attribute. May be NULL. | 
| gulong  | The length of the attribute. May be G_MAXULONG if the attribute is invalid. | 
void gck_attribute_init (GckAttribute *attr,gulong attr_type,gconstpointer value,gsize length);
Initialize a PKCS11 attribute. This copies the value memory into an internal buffer.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The raw value of the attribute. | 
| 
 | The length of the raw value. | 
void gck_attribute_init_invalid (GckAttribute *attr,gulong attr_type);
Initialize a PKCS11 attribute to an 'invalid' or 'not found' state. Specifically this sets the value length to (CK_ULONG)-1 as specified in the PKCS11 specification.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
void gck_attribute_init_empty (GckAttribute *attr,gulong attr_type);
Initialize a PKCS11 attribute to an empty state. The attribute type will be set, but no data will be set.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
void gck_attribute_init_boolean (GckAttribute *attr,gulong attr_type,gboolean value);
Initialize a PKCS11 attribute to boolean. This will result in a CK_BBOOL attribute from the PKCS11 specs.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The boolean value of the attribute. | 
void gck_attribute_init_date (GckAttribute *attr,gulong attr_type,const GDate *value);
Initialize a PKCS11 attribute to a date. This will result in a CK_DATE attribute from the PKCS11 specs.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The date value of the attribute. | 
void gck_attribute_init_ulong (GckAttribute *attr,gulong attr_type,gulong value);
Initialize a PKCS11 attribute to a unsigned long. This will result in a CK_ULONG attribute from the PKCS11 specs.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The ulong value of the attribute. | 
void gck_attribute_init_string (GckAttribute *attr,gulong attr_type,const gchar *value);
Initialize a PKCS11 attribute to a string. This will result in an attribute containing the text, but not the null terminator. The text in the attribute will be of the same encoding as you pass to this function.
When done with the attribute you should use gck_attribute_clear()
to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The null terminated string value of the attribute. | 
void gck_attribute_init_copy (GckAttribute *dest,const GckAttribute *src);
Initialize a PKCS11 attribute as a copy of another attribute. This copies the value memory as well.
When done with the copied attribute you should use
gck_attribute_clear() to free the internal memory.
| 
 | An uninitialized attribute. | 
| 
 | An attribute to copy. | 
GckAttribute* gck_attribute_new (gulong attr_type,gpointer value,gsize length);
Create a new PKCS11 attribute. The value will be copied into the new attribute.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The raw value of the attribute. | 
| 
 | The length of the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute*       gck_attribute_new_invalid           (gulong attr_type);
Create a new PKCS11 attribute as 'invalid' or 'not found' state. Specifically this sets the value length to (CK_ULONG)-1 as specified in the PKCS11 specification.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute*       gck_attribute_new_empty             (gulong attr_type);
Create a new PKCS11 attribute with empty data.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute* gck_attribute_new_boolean (gulong attr_type,gboolean value);
Initialize a PKCS11 attribute to boolean. This will result in a CK_BBOOL attribute from the PKCS11 specs.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The boolean value of the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute* gck_attribute_new_date (gulong attr_type,const GDate *value);
Initialize a PKCS11 attribute to a date. This will result in a CK_DATE attribute from the PKCS11 specs.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The date value of the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute* gck_attribute_new_ulong (gulong attr_type,gulong value);
Initialize a PKCS11 attribute to a unsigned long. This will result in a CK_ULONG attribute from the PKCS11 specs.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The ulong value of the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
GckAttribute* gck_attribute_new_string (gulong attr_type,const gchar *value);
Initialize a PKCS11 attribute to a string. This will result in an attribute containing the text, but not the null terminator. The text in the attribute will be of the same encoding as you pass to this function.
| 
 | The PKCS11 attribute type to set on the attribute. | 
| 
 | The null terminated string value of the attribute. | 
| Returns : | The new attribute. When done with the attribute use gck_attribute_free()to free it. | 
gboolean            gck_attribute_is_invalid            (GckAttribute *attr);
Check if the PKCS11 attribute represents 'invalid' or 'not found' according to the PKCS11 spec. That is, having length of (CK_ULONG)-1.
| 
 | The attribute to check. | 
| Returns : | Whether the attribute represents invalid or not. | 
gboolean            gck_attribute_get_boolean           (GckAttribute *attr);
Get the CK_BBOOL of a PKCS11 attribute. No conversion is performed. It is an error to pass an attribute to this function unless you're know it's supposed to contain a boolean value.
| 
 | The attribute to retrieve value from. | 
| Returns : | The boolean value of the attribute. | 
gulong              gck_attribute_get_ulong             (GckAttribute *attr);
Get the CK_ULONG value of a PKCS11 attribute. No conversion is performed. It is an error to pass an attribute to this function unless you're know it's supposed to contain a value of the right type.
| 
 | The attribute to retrieve value from. | 
| Returns : | The ulong value of the attribute. | 
gchar*              gck_attribute_get_string            (GckAttribute *attr);
Get the string value of a PKCS11 attribute. No conversion is performed. It is an error to pass an attribute to this function unless you're know it's supposed to contain a value of the right type.
| 
 | The attribute to retrieve value from. | 
| Returns : | A null terminated string, to be freed with g_free(),
or NULL if the value contained a NULL string. | 
void gck_attribute_get_date (GckAttribute *attr,GDate *value);
Get the CK_DATE of a PKCS11 attribute. No conversion is performed. It is an error to pass an attribute to this function unless you're know it's supposed to contain a value of the right type.
| 
 | The attribute to retrieve value from. | 
| 
 | The date value to fill in with the parsed date. | 
GckAttribute*       gck_attribute_dup                   (GckAttribute *attr);
Duplicate the PKCS11 attribute. All value memory is also copied.
| 
 | The attribute to duplicate. | 
| Returns : | The duplicated attribute. Use gck_attribute_free()to free it. | 
void                gck_attribute_clear                 (GckAttribute *attr);
Clear allocated memory held by a statically allocated attribute.
These are usually initialized with gck_attribute_init() or a
similar function.
The type of the attribute will remain set.
| 
 | Attribute to clear. | 
void                gck_attribute_free                  (GckAttribute *attr);
Free an attribute and its allocated memory. These is usually
used with attributes that are allocated by gck_attribute_new()
or a similar function.
| 
 | Attribute to free. |