|  |  |  | wocky Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | ||||
#define WOCKY_TYPE_TLS_CONNECTION #define WOCKY_TYPE_TLS_SESSION #define WOCKY_TLS_SESSION (inst) #define WOCKY_TLS_CONNECTION (inst) typedef WockyTLSConnection; typedef WockyTLSSession; enum WockyTLSVerificationLevel; GQuark wocky_tls_cert_error_quark (void); #define WOCKY_TLS_CERT_ERROR GQuark wocky_tls_error_quark (void); #define WOCKY_TLS_ERROR enum WockyTLSCertStatus; enum WockyTLSCertType; GType wocky_tls_connection_get_type (void); GType wocky_tls_session_get_type (void); int wocky_tls_session_verify_peer (WockyTLSSession *session,const gchar *peername,WockyTLSVerificationLevel level,WockyTLSCertStatus *status); GPtrArray * wocky_tls_session_get_peers_certificate (WockyTLSSession *session,WockyTLSCertType *type); WockyTLSConnection * wocky_tls_session_handshake (WockyTLSSession *session,GCancellable *cancellable,GError **error); void wocky_tls_session_handshake_async (WockyTLSSession *session,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data); WockyTLSConnection * wocky_tls_session_handshake_finish (WockyTLSSession *session,GAsyncResult *result,GError **error); void wocky_tls_session_add_ca (WockyTLSSession *session,const gchar *path); void wocky_tls_session_add_crl (WockyTLSSession *session,const gchar *path); WockyTLSSession * wocky_tls_session_new (GIOStream *stream); WockyTLSSession * wocky_tls_session_server_new (GIOStream *stream,guint dhbits,const gchar *key,const gchar *cert);
"session" WockyTLSSession* : Write / Construct Only "base-stream" GIOStream* : Write / Construct Only "dh-bits" guint : Write / Construct Only "server" gboolean : Write / Construct Only "x509-cert" gchar* : Write / Construct Only "x509-key" gchar* : Write / Construct Only
The WOCKY_TLS_DEBUG_LEVEL environment variable can be used to print debug output from OpenSSL. To enable it, set it to a value from 1 to 9. Higher values will print more information.
Increasing the value past certain thresholds will also trigger increased debugging output from within wocky-openssl.c as well.
typedef enum
{
  WOCKY_TLS_VERIFY_STRICT = 0,
  WOCKY_TLS_VERIFY_NORMAL,
  WOCKY_TLS_VERIFY_LENIENT,
} WockyTLSVerificationLevel;
typedef enum
{
  WOCKY_TLS_CERT_OK = 0,
  WOCKY_TLS_CERT_INVALID,
  WOCKY_TLS_CERT_NAME_MISMATCH,
  WOCKY_TLS_CERT_REVOKED,
  WOCKY_TLS_CERT_SIGNER_UNKNOWN,
  WOCKY_TLS_CERT_SIGNER_UNAUTHORISED,
  WOCKY_TLS_CERT_INSECURE,
  WOCKY_TLS_CERT_NOT_ACTIVE,
  WOCKY_TLS_CERT_EXPIRED,
  WOCKY_TLS_CERT_NO_CERTIFICATE,
  WOCKY_TLS_CERT_MAYBE_DOS,
  WOCKY_TLS_CERT_INTERNAL_ERROR,
  WOCKY_TLS_CERT_UNKNOWN_ERROR,
} WockyTLSCertStatus;
typedef enum
{
  WOCKY_TLS_CERT_TYPE_NONE = 0,
  WOCKY_TLS_CERT_TYPE_X509,
  WOCKY_TLS_CERT_TYPE_OPENPGP,
} WockyTLSCertType;
int wocky_tls_session_verify_peer (WockyTLSSession *session,const gchar *peername,WockyTLSVerificationLevel level,WockyTLSCertStatus *status);
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| Returns : | 
GPtrArray * wocky_tls_session_get_peers_certificate (WockyTLSSession *session,WockyTLSCertType *type);
| 
 | |
| 
 | |
| Returns : | 
WockyTLSConnection * wocky_tls_session_handshake (WockyTLSSession *session,GCancellable *cancellable,GError **error);
| 
 | |
| 
 | |
| 
 | |
| Returns : | 
void wocky_tls_session_handshake_async (WockyTLSSession *session,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | 
WockyTLSConnection * wocky_tls_session_handshake_finish (WockyTLSSession *session,GAsyncResult *result,GError **error);
| 
 | |
| 
 | |
| 
 | |
| Returns : | 
void wocky_tls_session_add_ca (WockyTLSSession *session,const gchar *path);
| 
 | |
| 
 | 
void wocky_tls_session_add_crl (WockyTLSSession *session,const gchar *path);
| 
 | |
| 
 | 
WockyTLSSession *   wocky_tls_session_new               (GIOStream *stream);
| 
 | |
| Returns : | 
WockyTLSSession * wocky_tls_session_server_new (GIOStream *stream,guint dhbits,const gchar *key,const gchar *cert);
Create a new TLS server session
| 
 | a GIOStream on which we expect to receive the client TLS handshake | 
| 
 | size of the DH parameters | 
| 
 | the path to the X509 PEM key file | 
| 
 | the path to the X509 PEM certificate | 
| Returns : | a WockyTLSSession object | 
"session" property"session" WockyTLSSession* : Write / Construct Only
the TLS session object for this connection.
"base-stream" property"base-stream" GIOStream* : Write / Construct Only
the stream that TLS communicates over.
"dh-bits" property"dh-bits" guint : Write / Construct Only
Diffie-Hellmann bits: 768, 1024, 2048, 3072 0r 4096.
Allowed values: [768,4096]
Default value: 1024
"server" property"server" gboolean : Write / Construct Only
whether this is a server.
Default value: FALSE
"x509-cert" property"x509-cert" gchar* : Write / Construct Only
x509 PEM certificate file.
Default value: NULL
"x509-key" property"x509-key" gchar* : Write / Construct Only
x509 PEM key file.
Default value: NULL