Data Fields
_PurpleCertificateScheme Struct Reference

A certificate type. More...

#include <certificate.h>

Data Fields

gchar * name
 Name of the certificate type ex: "x509", "pgp", etc.
gchar * fullname
 User-friendly name for this type ex: N_("X.509 Certificates") When this is displayed anywhere, it should be i18ned ex: _(scheme->fullname)
PurpleCertificate *(* import_certificate )(const gchar *filename)
 Imports a certificate from a file.
gboolean(* export_certificate )(const gchar *filename, PurpleCertificate *crt)
 Exports a certificate to a file.
PurpleCertificate *(* copy_certificate )(PurpleCertificate *crt)
 Duplicates a certificate.
void(* destroy_certificate )(PurpleCertificate *crt)
 Destroys and frees a Certificate structure.
gboolean(* signed_by )(PurpleCertificate *crt, PurpleCertificate *issuer)
 Find whether "crt" has a valid signature from "issuer," including appropriate values for the CA flag in the basic constraints extension.
GByteArray *(* get_fingerprint_sha1 )(PurpleCertificate *crt)
 Retrieves the certificate public key fingerprint using SHA1.
gchar *(* get_unique_id )(PurpleCertificate *crt)
 Retrieves a unique certificate identifier.
gchar *(* get_issuer_unique_id )(PurpleCertificate *crt)
 Retrieves a unique identifier for the certificate's issuer.
gchar *(* get_subject_name )(PurpleCertificate *crt)
 Gets the certificate subject's name.
gboolean(* check_subject_name )(PurpleCertificate *crt, const gchar *name)
 Check the subject name against that on the certificate.
gboolean(* get_times )(PurpleCertificate *crt, time_t *activation, time_t *expiration)
 Retrieve the certificate activation/expiration times.
GSList *(* import_certificates )(const gchar *filename)
 Imports certificates from a file.
gboolean(* register_trusted_tls_cert )(PurpleCertificate *crt, gboolean ca)
 Register a certificate as "trusted.".
void(* verify_cert )(PurpleCertificateVerificationRequest *vrq, PurpleCertificateInvalidityFlags *flags)
 Verify that a certificate is valid, performing all necessary checks including date range, valid cert chain, recognized and valid CAs, etc.
void(* _purple_reserved3 )(void)

Detailed Description

A certificate type.

A CertificateScheme must implement all of the fields in the structure, and register it using purple_certificate_register_scheme()

There may be only ONE CertificateScheme provided for each certificate type, as specified by the "name" field.

Definition at line 190 of file certificate.h.


Field Documentation

Check the subject name against that on the certificate.

See also:
purple_certificate_check_subject_name()
Returns:
TRUE if it is a match, else FALSE

Definition at line 294 of file certificate.h.

Duplicates a certificate.

Certificates are generally assumed to be read-only, so feel free to do any sort of reference-counting magic you want here. If this ever changes, please remember to change the magic accordingly.

Returns:
Reference to the new copy

Definition at line 232 of file certificate.h.

Destroys and frees a Certificate structure.

Destroys a Certificate's internal data structures and calls free(crt)

Parameters:
crtCertificate instance to be destroyed. It WILL NOT be destroyed if it is not of the correct CertificateScheme. Can be NULL

Definition at line 243 of file certificate.h.

gboolean(* _PurpleCertificateScheme::export_certificate)(const gchar *filename, PurpleCertificate *crt)

Exports a certificate to a file.

Parameters:
filenameFile to export the certificate to
crtCertificate to export
Returns:
TRUE if the export succeeded, otherwise FALSE
See also:
purple_certificate_export()

Definition at line 222 of file certificate.h.

Retrieves the certificate public key fingerprint using SHA1.

Parameters:
crtCertificate instance
Returns:
Binary representation of SHA1 hash - must be freed using g_byte_array_free()

Definition at line 256 of file certificate.h.

Retrieves a unique identifier for the certificate's issuer.

Parameters:
crtCertificate instance
Returns:
Newly allocated string that can be used to uniquely identify the issuer's certificate.

Definition at line 274 of file certificate.h.

Gets the certificate subject's name.

For X.509, this is the "Common Name" field, as we're only using it for hostname verification at the moment

See also:
purple_certificate_get_subject_name()
Parameters:
crtCertificate instance
Returns:
Newly allocated string with the certificate subject.

Definition at line 287 of file certificate.h.

Retrieves a unique certificate identifier.

Parameters:
crtCertificate instance
Returns:
Newly allocated string that can be used to uniquely identify the certificate.

Definition at line 265 of file certificate.h.

Imports a certificate from a file.

Parameters:
filenameFile to import the certificate from
Returns:
Pointer to the newly allocated Certificate struct or NULL on failure.

Definition at line 212 of file certificate.h.

GSList*(* _PurpleCertificateScheme::import_certificates)(const gchar *filename)

Imports certificates from a file.

Parameters:
filenameFile to import the certificates from
Returns:
GSList of pointers to the newly allocated Certificate structs or NULL on failure.

Definition at line 305 of file certificate.h.

Name of the certificate type ex: "x509", "pgp", etc.

This must be globally unique - you may not register more than one CertificateScheme of the same name at a time.

Definition at line 197 of file certificate.h.

Find whether "crt" has a valid signature from "issuer," including appropriate values for the CA flag in the basic constraints extension.

See also:
purple_certificate_signed_by()

Definition at line 248 of file certificate.h.


The documentation for this struct was generated from the following file: