|  |  |  | Gcr Library Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | Signals | ||||
#define GCR_DATA_ERROR enum GcrDataError; enum GcrDataFormat; struct GcrParser; struct GcrParserClass; GcrParser * gcr_parser_new (void); gboolean gcr_parser_parse_data (GcrParser *self,const guchar *data,gsize n_data,GError **error); gboolean gcr_parser_parse_stream (GcrParser *self,GInputStream *input,GCancellable *cancellable,GError **error); void gcr_parser_parse_stream_async (GcrParser *self,GInputStream *input,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data); gboolean gcr_parser_parse_stream_finish (GcrParser *self,GAsyncResult *result,GError **error); void gcr_parser_format_enable (GcrParser *self,GcrDataFormat format); void gcr_parser_format_disable (GcrParser *self,GcrDataFormat format); gboolean gcr_parser_format_supported (GcrParser *self,GcrDataFormat format); void gcr_parser_add_password (GcrParser *self,const gchar *password); const gchar * gcr_parser_get_parsed_label (GcrParser *self); const gchar * gcr_parser_get_parsed_description (GcrParser *self); GckAttributes * gcr_parser_get_parsed_attributes (GcrParser *self); const guchar * gcr_parser_get_parsed_block (GcrParser *self,gsize *n_block); GcrDataFormat gcr_parser_get_parsed_format (GcrParser *self); GcrParsed; GcrParsed * gcr_parsed_ref (GcrParsed *parsed); void gcr_parsed_unref (gpointer parsed); GckAttributes * gcr_parsed_get_attributes (GcrParsed *parsed); const guchar * gcr_parsed_get_data (GcrParsed *parsed,gsize *n_data); const gchar * gcr_parsed_get_description (GcrParsed *parsed); GcrDataFormat gcr_parsed_get_format (GcrParsed *parsed); const gchar * gcr_parsed_get_label (GcrParsed *parsed); GcrParsed * gcr_parser_get_parsed (GcrParser *self);
"parsed-attributes" GckAttributes* : Read "parsed-description" gchar* : Read "parsed-label" gchar* : Read
A GcrParser can parse various certificate and key files such as OpenSSL PEM files, DER encoded certifictes, PKCS#8 keys and so on. Each various format is identified by a value in the GcrDataFormat enumeration.
In order to parse data, a new parser is created with gcr_parser_new() and
then the GcrParser::authenticate and GcrParser::parsed signals should be
connected to. Data is then fed to the parser via gcr_parser_parse_data()
or gcr_parser_parse_stream().
During the GcrParsed::parsed signal the attributes that make up the currently
parsed item can be retrieved using the gcr_parser_get_parsed_attributes()
function.
#define GCR_DATA_ERROR (gcr_data_error_get_domain ())
The GError domain for data parsing errors.
typedef enum {
	GCR_ERROR_FAILURE = -1,
	GCR_ERROR_UNRECOGNIZED = 1,
	GCR_ERROR_CANCELLED = 2,
	GCR_ERROR_LOCKED = 3
} GcrDataError;
Values responding to error codes for parsing and serializing data.
typedef enum {
	GCR_FORMAT_ALL = -1,
	GCR_FORMAT_INVALID = 0,
	GCR_FORMAT_DER_PRIVATE_KEY = 100,
	GCR_FORMAT_DER_PRIVATE_KEY_RSA,
	GCR_FORMAT_DER_PRIVATE_KEY_DSA,
	GCR_FORMAT_DER_SUBJECT_PUBLIC_KEY = 150,
	GCR_FORMAT_DER_CERTIFICATE_X509 = 200,
	GCR_FORMAT_DER_PKCS7 = 300,
	GCR_FORMAT_DER_PKCS8 = 400,
	GCR_FORMAT_DER_PKCS8_PLAIN,
	GCR_FORMAT_DER_PKCS8_ENCRYPTED,
	GCR_FORMAT_DER_PKCS10 = 450,
	GCR_FORMAT_DER_SPKAC = 455,
	GCR_FORMAT_BASE64_SPKAC,
	GCR_FORMAT_DER_PKCS12 = 500,
	GCR_FORMAT_OPENSSH_PUBLIC = 600,
	GCR_FORMAT_OPENPGP_PACKET = 700,
	GCR_FORMAT_OPENPGP_ARMOR,
	GCR_FORMAT_PEM = 1000,
	GCR_FORMAT_PEM_PRIVATE_KEY_RSA,
	GCR_FORMAT_PEM_PRIVATE_KEY_DSA,
	GCR_FORMAT_PEM_CERTIFICATE_X509,
	GCR_FORMAT_PEM_PKCS7,
	GCR_FORMAT_PEM_PKCS8_PLAIN,
	GCR_FORMAT_PEM_PKCS8_ENCRYPTED,
	GCR_FORMAT_PEM_PKCS12,
	GCR_FORMAT_PEM_PRIVATE_KEY,
	GCR_FORMAT_PEM_PKCS10,
} GcrDataFormat;
The various format identifiers.
| Represents all the formats, when enabling or disabling | |
| Not a valid format | |
| DER encoded private key | |
| DER encoded RSA private key | |
| DER encoded DSA private key | |
| DER encoded SubjectPublicKeyInfo | |
| DER encoded X.509 certificate | |
| DER encoded PKCS#7 container file which can contain certificates | |
| DER encoded PKCS#8 file which can contain a key | |
| Unencrypted DER encoded PKCS#8 file which can contain a key | |
| Encrypted DER encoded PKCS#8 file which can contain a key | |
| DER encoded PKCS#10 certificate request file | |
| DER encoded SPKAC as generated by HTML5 keygen element | |
| OpenSSL style SPKAC data | |
| DER encoded PKCS#12 file which can contain certificates and/or keys | |
| OpenSSH v1 or v2 public key | |
| OpenPGP key packet(s) | |
| OpenPGP public or private key armor encoded data | |
| An OpenSSL style PEM file with unspecified contents | |
| An OpenSSL style PEM file with a private RSA key | |
| An OpenSSL style PEM file with a private DSA key | |
| An OpenSSL style PEM file with an X.509 certificate | |
| An OpenSSL style PEM file containing PKCS#7 | |
| Unencrypted OpenSSL style PEM file containing PKCS#8 | |
| Encrypted OpenSSL style PEM file containing PKCS#8 | |
| An OpenSSL style PEM file containing PKCS#12 | |
| An OpenSSL style PEM file with a private key | |
| An OpenSSL style PEM file containing PKCS#10 | 
struct GcrParserClass {
	GObjectClass parent_class;
	/* signals --------------------------------------------------------- */
	/* A callback for each password needed */
	gboolean (*authenticate) (GcrParser *self, gint count);
	void     (*parsed) (GcrParser *self);
};
The class for GcrParser
| GObjectClass  | The parent class | 
| The default handler for the authenticate signal. | |
| The default handler for the parsed signal. | 
GcrParser *         gcr_parser_new                      (void);
Create a new GcrParser
| Returns : | a newly allocated GcrParser. [transfer full] | 
gboolean gcr_parser_parse_data (GcrParser *self,const guchar *data,gsize n_data,GError **error);
Parse the data. The GcrParser::parsed and GcrParser::authenticate signals may fire during the parsing.
| 
 | The parser | 
| 
 | the data to parse. [array length=n_data] | 
| 
 | The length of the data | 
| 
 | A location to raise an error on failure. | 
| Returns : | Whether the data was parsed successfully or not. | 
gboolean gcr_parser_parse_stream (GcrParser *self,GInputStream *input,GCancellable *cancellable,GError **error);
Parse items from the data in a GInputStream. This function may block while
reading from the input stream. Use gcr_parser_parse_stream_async() for
a non-blocking variant.
The GcrParser::parsed and GcrParser::authenticate signals may fire during the parsing.
| 
 | The parser | 
| 
 | The input stream | 
| 
 | An optional cancellation object | 
| 
 | A location to raise an error on failure | 
| Returns : | Whether the parsing completed successfully or not. | 
void gcr_parser_parse_stream_async (GcrParser *self,GInputStream *input,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Parse items from the data in a GInputStream. This function completes asyncronously and doesn't block.
The GcrParser::parsed and GcrParser::authenticate signals may fire during the parsing.
| 
 | The parser | 
| 
 | The input stream | 
| 
 | An optional cancellation object | 
| 
 | Called when the operation result is ready. | 
| 
 | Data to pass to callback | 
gboolean gcr_parser_parse_stream_finish (GcrParser *self,GAsyncResult *result,GError **error);
Complete an operation to parse a stream.
| 
 | The parser | 
| 
 | The operation result | 
| 
 | A location to raise an error on failure | 
| Returns : | Whether the parsing completed successfully or not. | 
void gcr_parser_format_enable (GcrParser *self,GcrDataFormat format);
Enable parsing of the given format. Use GCR_FORMAT_ALL to enable all the formats.
| 
 | The parser | 
| 
 | The format identifier | 
void gcr_parser_format_disable (GcrParser *self,GcrDataFormat format);
Disable parsing of the given format. Use GCR_FORMAT_ALL to disable all the formats.
| 
 | The parser | 
| 
 | The format identifier | 
gboolean gcr_parser_format_supported (GcrParser *self,GcrDataFormat format);
Check whether the given format is supported by the parser.
| 
 | The parser | 
| 
 | The format identifier | 
| Returns : | Whether the format is supported. | 
void gcr_parser_add_password (GcrParser *self,const gchar *password);
Add a password to the set of passwords to try when parsing locked or encrypted items. This is usually called from the GcrParser::authenticate signal.
| 
 | The parser | 
| 
 | a password to try. [allow-none] | 
const gchar *       gcr_parser_get_parsed_label         (GcrParser *self);
Get the label of the currently parsed item. This is generally only valid during the GcrParser::parsed signal.
| 
 | The parser | 
| Returns : | the label of the currently parsed item. The value is owned by the parser and should not be freed. [allow-none] | 
const gchar *       gcr_parser_get_parsed_description   (GcrParser *self);
Get a description for the type of the currently parsed item. This is generally only valid during the GcrParser::parsed signal.
| 
 | The parser | 
| Returns : | the description for the current item; this is owned by the parser and should not be freed. [allow-none] | 
GckAttributes *     gcr_parser_get_parsed_attributes    (GcrParser *self);
Get the attributes which make up the currently parsed item. This is generally only valid during the GcrParser::parsed signal.
| 
 | The parser | 
| Returns : | the attributes for the current item, which are owned by the parser and should not be freed. [transfer none][allow-none] | 
const guchar * gcr_parser_get_parsed_block (GcrParser *self,gsize *n_block);
Get the raw data block that represents this parsed object. This is only valid during the GcrParser::parsed signal.
| 
 | a parser | 
| 
 | a location to place the size of the block | 
| Returns : | the raw data block of the currently parsed item; the value is owned by the parser and should not be freed. [transfer none][array length=n_block][allow-none] | 
GcrDataFormat       gcr_parser_get_parsed_format        (GcrParser *self);
Get the format of the raw data block that represents this parsed object.
This corresponds with the data returned from gcr_parser_get_parsed_block().
This is only valid during the GcrParser::parsed signal.
| 
 | a parser | 
| Returns : | the data format of the currently parsed item | 
GcrParsed *         gcr_parsed_ref                      (GcrParsed *parsed);
Add a reference to a parsed item. An item may not be shared across threads until it has been referenced at least once.
| 
 | a parsed item | 
| Returns : | the parsed item. [transfer full] | 
void                gcr_parsed_unref                    (gpointer parsed);
Unreferences a parsed item which was referenced with gcr_parsed_ref()
| 
 | a parsed item | 
GckAttributes *     gcr_parsed_get_attributes           (GcrParsed *parsed);
Get the attributes which make up the parsed item.
| 
 | a parsed item | 
| Returns : | the attributes for the item; these are owned by the parsed item and should not be freed. [transfer none][allow-none] | 
const guchar * gcr_parsed_get_data (GcrParsed *parsed,gsize *n_data);
Get the raw data block for the parsed item.
| 
 | a parsed item | 
| 
 | location to store size of returned data | 
| Returns : | the raw data of
the parsed item, or NULL. [transfer full][array length=n_data][allow-none] | 
const gchar *       gcr_parsed_get_description          (GcrParsed *parsed);
Get the descirption for a parsed item.
| 
 | a parsed item | 
| Returns : | the description. [allow-none] | 
GcrDataFormat       gcr_parsed_get_format               (GcrParsed *parsed);
Get the format of the parsed item.
| 
 | a parsed item | 
| Returns : | the data format of the item | 
const gchar *       gcr_parsed_get_label                (GcrParsed *parsed);
Get the label for the parsed item.
| 
 | a parsed item | 
| Returns : | the label for the item. [allow-none] | 
"parsed-attributes" property"parsed-attributes" GckAttributes* : Read
Get the attributes that make up the currently parsed item. This is generally only valid during a "parsed" signal.
"parsed-description" property"parsed-description" gchar* : Read
The description of the type of the currently parsed item. This is generally only valid during a "parsed" signal.
Default value: ""
"authenticate" signalgboolean            user_function                      (GcrParser *count,
                                                        gpointer   Returns,
                                                        gpointer   user_data)      : Run Last
This signal is emitted when an item needs to be unlocked or decrypted before
it can be parsed. The count argument specifies the number of times
the signal has been emitted for a given item. This can be used to
display a message saying the previous password was incorrect.
Typically the gcr_parser_add_password() function is called in
response to this signal.
If FALSE is returned, then the authentication was not handled. If
no handlers return TRUE then the item is not parsed and an error
with the code GCR_ERROR_CANCELLED will be raised.
| 
 | The number of times this item has been authenticated. | 
| 
 | user data set when the signal handler was connected. | 
| Returns : | Whether the authentication was handled. | 
"parsed" signalvoid                user_function                      (GcrParser *arg0,
                                                        gpointer   user_data)      : Run First
This signal is emitted when an item is sucessfully parsed. To access
the information about the item use the gcr_parser_get_parsed_label(),
gcr_parser_get_parsed_attributes() and gcr_parser_get_parsed_description()
functions.
| 
 | user data set when the signal handler was connected. |