Ruby  2.1.10p492(2016-04-01revision54464)
Macros | Functions | Variables
ossl_ssl.c File Reference
#include "ossl.h"

Go to the source code of this file.

Macros

#define numberof(ary)   (int)(sizeof(ary)/sizeof((ary)[0]))
 
#define TO_SOCKET(s)   (s)
 
#define ossl_sslctx_set_cert(o, v)   rb_iv_set((o),"@cert",(v))
 
#define ossl_sslctx_set_key(o, v)   rb_iv_set((o),"@key",(v))
 
#define ossl_sslctx_set_client_ca(o, v)   rb_iv_set((o),"@client_ca",(v))
 
#define ossl_sslctx_set_ca_file(o, v)   rb_iv_set((o),"@ca_file",(v))
 
#define ossl_sslctx_set_ca_path(o, v)   rb_iv_set((o),"@ca_path",(v))
 
#define ossl_sslctx_set_timeout(o, v)   rb_iv_set((o),"@timeout",(v))
 
#define ossl_sslctx_set_verify_mode(o, v)   rb_iv_set((o),"@verify_mode",(v))
 
#define ossl_sslctx_set_verify_dep(o, v)   rb_iv_set((o),"@verify_depth",(v))
 
#define ossl_sslctx_set_verify_cb(o, v)   rb_iv_set((o),"@verify_callback",(v))
 
#define ossl_sslctx_set_options(o, v)   rb_iv_set((o),"@options",(v))
 
#define ossl_sslctx_set_cert_store(o, v)   rb_iv_set((o),"@cert_store",(v))
 
#define ossl_sslctx_set_extra_cert(o, v)   rb_iv_set((o),"@extra_chain_cert",(v))
 
#define ossl_sslctx_set_client_cert_cb(o, v)   rb_iv_set((o),"@client_cert_cb",(v))
 
#define ossl_sslctx_set_tmp_dh_cb(o, v)   rb_iv_set((o),"@tmp_dh_callback",(v))
 
#define ossl_sslctx_set_sess_id_ctx(o, v)   rb_iv_set((o),"@session_id_context",(v))
 
#define ossl_sslctx_get_cert(o)   rb_iv_get((o),"@cert")
 
#define ossl_sslctx_get_key(o)   rb_iv_get((o),"@key")
 
#define ossl_sslctx_get_client_ca(o)   rb_iv_get((o),"@client_ca")
 
#define ossl_sslctx_get_ca_file(o)   rb_iv_get((o),"@ca_file")
 
#define ossl_sslctx_get_ca_path(o)   rb_iv_get((o),"@ca_path")
 
#define ossl_sslctx_get_timeout(o)   rb_iv_get((o),"@timeout")
 
#define ossl_sslctx_get_verify_mode(o)   rb_iv_get((o),"@verify_mode")
 
#define ossl_sslctx_get_verify_dep(o)   rb_iv_get((o),"@verify_depth")
 
#define ossl_sslctx_get_verify_cb(o)   rb_iv_get((o),"@verify_callback")
 
#define ossl_sslctx_get_options(o)   rb_iv_get((o),"@options")
 
#define ossl_sslctx_get_cert_store(o)   rb_iv_get((o),"@cert_store")
 
#define ossl_sslctx_get_extra_cert(o)   rb_iv_get((o),"@extra_chain_cert")
 
#define ossl_sslctx_get_client_cert_cb(o)   rb_iv_get((o),"@client_cert_cb")
 
#define ossl_sslctx_get_tmp_dh_cb(o)   rb_iv_get((o),"@tmp_dh_callback")
 
#define ossl_sslctx_get_sess_id_ctx(o)   rb_iv_get((o),"@session_id_context")
 
#define ossl_ssl_get_io(o)   rb_iv_get((o),"@io")
 
#define ossl_ssl_get_ctx(o)   rb_iv_get((o),"@context")
 
#define ossl_ssl_get_sync_close(o)   rb_iv_get((o),"@sync_close")
 
#define ossl_ssl_get_x509(o)   rb_iv_get((o),"@x509")
 
#define ossl_ssl_get_key(o)   rb_iv_get((o),"@key")
 
#define ossl_ssl_get_tmp_dh(o)   rb_iv_get((o),"@tmp_dh")
 
#define ossl_ssl_set_io(o, v)   rb_iv_set((o),"@io",(v))
 
#define ossl_ssl_set_ctx(o, v)   rb_iv_set((o),"@context",(v))
 
#define ossl_ssl_set_sync_close(o, v)   rb_iv_set((o),"@sync_close",(v))
 
#define ossl_ssl_set_x509(o, v)   rb_iv_set((o),"@x509",(v))
 
#define ossl_ssl_set_key(o, v)   rb_iv_set((o),"@key",(v))
 
#define ossl_ssl_set_tmp_dh(o, v)   rb_iv_set((o),"@tmp_dh",(v))
 
#define OSSL_SSL_METHOD_ENTRY(name)   { #name, (SSL_METHOD *(*)(void))name##_method }
 
#define ssl_get_error(ssl, ret)   SSL_get_error((ssl), (ret))
 
#define ossl_ssl_data_get_struct(v, ssl)
 
#define ossl_ssl_def_const(x)   rb_define_const(mSSL, #x, INT2NUM(SSL_##x))
 

Functions

static void ossl_sslctx_free (SSL_CTX *ctx)
 
static VALUE ossl_sslctx_s_alloc (VALUE klass)
 
static VALUE ossl_sslctx_set_ssl_version (VALUE self, VALUE ssl_method)
 
static VALUE ossl_sslctx_initialize (int argc, VALUE *argv, VALUE self)
 
static VALUE ossl_call_client_cert_cb (VALUE obj)
 
static int ossl_client_cert_cb (SSL *ssl, X509 **x509, EVP_PKEY **pkey)
 
static VALUE ossl_call_tmp_dh_callback (VALUE *args)
 
static DH * ossl_tmp_dh_callback (SSL *ssl, int is_export, int keylength)
 
static DH * ossl_default_tmp_dh_callback (SSL *ssl, int is_export, int keylength)
 
static int ossl_ssl_verify_callback (int preverify_ok, X509_STORE_CTX *ctx)
 
static VALUE ossl_call_session_get_cb (VALUE ary)
 
static SSL_SESSION * ossl_sslctx_session_get_cb (SSL *ssl, unsigned char *buf, int len, int *copy)
 
static VALUE ossl_call_session_new_cb (VALUE ary)
 
static int ossl_sslctx_session_new_cb (SSL *ssl, SSL_SESSION *sess)
 
static VALUE ossl_call_session_remove_cb (VALUE ary)
 
static void ossl_sslctx_session_remove_cb (SSL_CTX *ctx, SSL_SESSION *sess)
 
 Data_Get_Struct (arg, SSL_CTX, ctx)
 
 if (!SSL_CTX_add_extra_chain_cert(ctx, x509))
 
static VALUE ossl_sslctx_setup (VALUE self)
 
static void ssl_renegotiation_cb (const SSL *ssl)
 
static void ssl_info_cb (const SSL *ssl, int where, int val)
 
static VALUE ossl_ssl_cipher_to_ary (SSL_CIPHER *cipher)
 
static VALUE ossl_sslctx_get_ciphers (VALUE self)
 
static VALUE ossl_sslctx_set_ciphers (VALUE self, VALUE v)
 
static VALUE ossl_sslctx_session_add (VALUE self, VALUE arg)
 
static VALUE ossl_sslctx_session_remove (VALUE self, VALUE arg)
 
static VALUE ossl_sslctx_get_session_cache_mode (VALUE self)
 
static VALUE ossl_sslctx_set_session_cache_mode (VALUE self, VALUE arg)
 
static VALUE ossl_sslctx_get_session_cache_size (VALUE self)
 
static VALUE ossl_sslctx_set_session_cache_size (VALUE self, VALUE arg)
 
static VALUE ossl_sslctx_get_session_cache_stats (VALUE self)
 
static VALUE ossl_sslctx_flush_sessions (int argc, VALUE *argv, VALUE self)
 
static void ossl_ssl_shutdown (SSL *ssl)
 
static void ossl_ssl_free (SSL *ssl)
 
static VALUE ossl_ssl_s_alloc (VALUE klass)
 
static VALUE ossl_ssl_initialize (int argc, VALUE *argv, VALUE self)
 
static VALUE ossl_ssl_setup (VALUE self)
 
static void write_would_block (int nonblock)
 
static void read_would_block (int nonblock)
 
static VALUE ossl_start_ssl (VALUE self, int(*func)(), const char *funcname, int nonblock)
 
static VALUE ossl_ssl_connect (VALUE self)
 
static VALUE ossl_ssl_connect_nonblock (VALUE self)
 
static VALUE ossl_ssl_accept (VALUE self)
 
static VALUE ossl_ssl_accept_nonblock (VALUE self)
 
static VALUE ossl_ssl_read_internal (int argc, VALUE *argv, VALUE self, int nonblock)
 
static VALUE ossl_ssl_read (int argc, VALUE *argv, VALUE self)
 
static VALUE ossl_ssl_read_nonblock (int argc, VALUE *argv, VALUE self)
 
static VALUE ossl_ssl_write_internal (VALUE self, VALUE str, int nonblock, int no_exception)
 
static VALUE ossl_ssl_write (VALUE self, VALUE str)
 
static VALUE ossl_ssl_write_nonblock (int argc, VALUE *argv, VALUE self)
 
static VALUE ossl_ssl_close (VALUE self)
 
static VALUE ossl_ssl_get_cert (VALUE self)
 
static VALUE ossl_ssl_get_peer_cert (VALUE self)
 
static VALUE ossl_ssl_get_peer_cert_chain (VALUE self)
 
static VALUE ossl_ssl_get_version (VALUE self)
 
static VALUE ossl_ssl_get_cipher (VALUE self)
 
static VALUE ossl_ssl_get_state (VALUE self)
 
static VALUE ossl_ssl_pending (VALUE self)
 
static VALUE ossl_ssl_session_reused (VALUE self)
 
static VALUE ossl_ssl_set_session (VALUE self, VALUE arg1)
 
static VALUE ossl_ssl_get_verify_result (VALUE self)
 
static VALUE ossl_ssl_get_client_ca_list (VALUE self)
 
void Init_ossl_ssl ()
 

Variables

VALUE mSSL
 
VALUE eSSLError
 
VALUE cSSLContext
 
VALUE cSSLSocket
 
static VALUE eSSLErrorWaitReadable
 
static VALUE eSSLErrorWaitWritable
 
static const char * ossl_sslctx_attrs []
 
static const char * ossl_ssl_attr_readers [] = { "io", "context", }
 
static const char * ossl_ssl_attrs []
 
ID ID_callback_state
 
static VALUE sym_exception
 
struct {
   const char *   name
 
   SSL_METHOD *(*   func )(void)
 
ossl_ssl_method_tab []
 
int ossl_ssl_ex_vcb_idx
 
int ossl_ssl_ex_store_p
 
int ossl_ssl_ex_ptr_idx
 
int ossl_ssl_ex_client_cert_cb_idx
 
int ossl_ssl_ex_tmp_dh_callback_idx
 
static VALUE
 
SSL_CTX * ctx
 
 x509 = DupX509CertPtr(i)
 
return i
 

Macro Definition Documentation

#define numberof (   ary)    (int)(sizeof(ary)/sizeof((ary)[0]))

Definition at line 19 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_sslctx_initialize(), and ossl_sslctx_set_ssl_version().

#define ossl_ssl_data_get_struct (   v,
  ssl 
)
Value:
do { \
Data_Get_Struct((v), SSL, (ssl)); \
if (!(ssl)) { \
rb_warning("SSL session is not started yet."); \
} \
} while (0)
return
Definition: bigdecimal.c:5946
if(args--[1]==0)
Definition: array.c:3187
#define Qnil
Definition: enum.c:67
VALUE v
Definition: enum.c:845
#define Data_Get_Struct(obj, type, sval)
void rb_warning(const char *fmt,...)
Definition: error.c:236

Definition at line 1248 of file ossl_ssl.c.

Referenced by ossl_ssl_get_cert(), ossl_ssl_get_cipher(), ossl_ssl_get_client_ca_list(), ossl_ssl_get_peer_cert(), ossl_ssl_get_peer_cert_chain(), ossl_ssl_get_state(), ossl_ssl_get_verify_result(), ossl_ssl_get_version(), ossl_ssl_pending(), ossl_ssl_session_reused(), ossl_ssl_set_session(), and ossl_start_ssl().

#define ossl_ssl_def_const (   x)    rb_define_const(mSSL, #x, INT2NUM(SSL_##x))

Referenced by Init_ossl_ssl().

#define ossl_ssl_get_ctx (   o)    rb_iv_get((o),"@context")

Definition at line 83 of file ossl_ssl.c.

Referenced by ossl_ssl_setup().

#define ossl_ssl_get_io (   o)    rb_iv_get((o),"@io")
#define ossl_ssl_get_key (   o)    rb_iv_get((o),"@key")

Definition at line 86 of file ossl_ssl.c.

Referenced by ossl_client_cert_cb().

#define ossl_ssl_get_sync_close (   o)    rb_iv_get((o),"@sync_close")

Definition at line 84 of file ossl_ssl.c.

Referenced by ossl_ssl_close().

#define ossl_ssl_get_tmp_dh (   o)    rb_iv_get((o),"@tmp_dh")

Definition at line 87 of file ossl_ssl.c.

Referenced by ossl_tmp_dh_callback().

#define ossl_ssl_get_x509 (   o)    rb_iv_get((o),"@x509")

Definition at line 85 of file ossl_ssl.c.

Referenced by ossl_client_cert_cb().

#define OSSL_SSL_METHOD_ENTRY (   name)    { #name, (SSL_METHOD *(*)(void))name##_method }
#define ossl_ssl_set_ctx (   o,
  v 
)    rb_iv_set((o),"@context",(v))

Definition at line 90 of file ossl_ssl.c.

Referenced by ossl_ssl_initialize().

#define ossl_ssl_set_io (   o,
  v 
)    rb_iv_set((o),"@io",(v))

Definition at line 89 of file ossl_ssl.c.

Referenced by ossl_ssl_initialize().

#define ossl_ssl_set_key (   o,
  v 
)    rb_iv_set((o),"@key",(v))

Definition at line 93 of file ossl_ssl.c.

Referenced by ossl_call_client_cert_cb().

#define ossl_ssl_set_sync_close (   o,
  v 
)    rb_iv_set((o),"@sync_close",(v))

Definition at line 91 of file ossl_ssl.c.

Referenced by ossl_ssl_initialize().

#define ossl_ssl_set_tmp_dh (   o,
  v 
)    rb_iv_set((o),"@tmp_dh",(v))

Definition at line 94 of file ossl_ssl.c.

Referenced by ossl_call_tmp_dh_callback().

#define ossl_ssl_set_x509 (   o,
  v 
)    rb_iv_set((o),"@x509",(v))

Definition at line 92 of file ossl_ssl.c.

Referenced by ossl_call_client_cert_cb().

#define ossl_sslctx_get_ca_file (   o)    rb_iv_get((o),"@ca_file")

Definition at line 54 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_ca_path (   o)    rb_iv_get((o),"@ca_path")

Definition at line 55 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_cert (   o)    rb_iv_get((o),"@cert")

Definition at line 51 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_cert_store (   o)    rb_iv_get((o),"@cert_store")

Definition at line 61 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_client_ca (   o)    rb_iv_get((o),"@client_ca")

Definition at line 53 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_client_cert_cb (   o)    rb_iv_get((o),"@client_cert_cb")

Definition at line 63 of file ossl_ssl.c.

Referenced by ossl_ssl_setup(), and ossl_sslctx_setup().

#define ossl_sslctx_get_extra_cert (   o)    rb_iv_get((o),"@extra_chain_cert")

Definition at line 62 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_key (   o)    rb_iv_get((o),"@key")

Definition at line 52 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_options (   o)    rb_iv_get((o),"@options")

Definition at line 60 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_sess_id_ctx (   o)    rb_iv_get((o),"@session_id_context")

Definition at line 65 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_timeout (   o)    rb_iv_get((o),"@timeout")

Definition at line 56 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_tmp_dh_cb (   o)    rb_iv_get((o),"@tmp_dh_callback")

Definition at line 64 of file ossl_ssl.c.

Referenced by ossl_ssl_setup(), and ossl_sslctx_setup().

#define ossl_sslctx_get_verify_cb (   o)    rb_iv_get((o),"@verify_callback")

Definition at line 59 of file ossl_ssl.c.

Referenced by ossl_ssl_setup().

#define ossl_sslctx_get_verify_dep (   o)    rb_iv_get((o),"@verify_depth")

Definition at line 58 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_get_verify_mode (   o)    rb_iv_get((o),"@verify_mode")

Definition at line 57 of file ossl_ssl.c.

Referenced by ossl_sslctx_setup().

#define ossl_sslctx_set_ca_file (   o,
  v 
)    rb_iv_set((o),"@ca_file",(v))

Definition at line 38 of file ossl_ssl.c.

#define ossl_sslctx_set_ca_path (   o,
  v 
)    rb_iv_set((o),"@ca_path",(v))

Definition at line 39 of file ossl_ssl.c.

#define ossl_sslctx_set_cert (   o,
  v 
)    rb_iv_set((o),"@cert",(v))

Definition at line 35 of file ossl_ssl.c.

#define ossl_sslctx_set_cert_store (   o,
  v 
)    rb_iv_set((o),"@cert_store",(v))

Definition at line 45 of file ossl_ssl.c.

#define ossl_sslctx_set_client_ca (   o,
  v 
)    rb_iv_set((o),"@client_ca",(v))

Definition at line 37 of file ossl_ssl.c.

#define ossl_sslctx_set_client_cert_cb (   o,
  v 
)    rb_iv_set((o),"@client_cert_cb",(v))

Definition at line 47 of file ossl_ssl.c.

#define ossl_sslctx_set_extra_cert (   o,
  v 
)    rb_iv_set((o),"@extra_chain_cert",(v))

Definition at line 46 of file ossl_ssl.c.

#define ossl_sslctx_set_key (   o,
  v 
)    rb_iv_set((o),"@key",(v))

Definition at line 36 of file ossl_ssl.c.

#define ossl_sslctx_set_options (   o,
  v 
)    rb_iv_set((o),"@options",(v))

Definition at line 44 of file ossl_ssl.c.

#define ossl_sslctx_set_sess_id_ctx (   o,
  v 
)    rb_iv_set((o),"@session_id_context",(v))

Definition at line 49 of file ossl_ssl.c.

#define ossl_sslctx_set_timeout (   o,
  v 
)    rb_iv_set((o),"@timeout",(v))

Definition at line 40 of file ossl_ssl.c.

#define ossl_sslctx_set_tmp_dh_cb (   o,
  v 
)    rb_iv_set((o),"@tmp_dh_callback",(v))

Definition at line 48 of file ossl_ssl.c.

#define ossl_sslctx_set_verify_cb (   o,
  v 
)    rb_iv_set((o),"@verify_callback",(v))

Definition at line 43 of file ossl_ssl.c.

#define ossl_sslctx_set_verify_dep (   o,
  v 
)    rb_iv_set((o),"@verify_depth",(v))

Definition at line 42 of file ossl_ssl.c.

#define ossl_sslctx_set_verify_mode (   o,
  v 
)    rb_iv_set((o),"@verify_mode",(v))

Definition at line 41 of file ossl_ssl.c.

#define ssl_get_error (   ssl,
  ret 
)    SSL_get_error((ssl), (ret))

Definition at line 1245 of file ossl_ssl.c.

Referenced by ossl_ssl_read_internal(), ossl_ssl_write_internal(), and ossl_start_ssl().

#define TO_SOCKET (   s)    (s)

Definition at line 24 of file ossl_ssl.c.

Referenced by ossl_ssl_setup().

Function Documentation

Data_Get_Struct ( arg  ,
SSL_CTX  ,
ctx   
)
if ( SSL_CTX_add_extra_chain_certctx, x509)

Definition at line 490 of file ossl_ssl.c.

References eSSLError, NULL, and ossl_raise().

void Init_ossl_ssl ( void  )

Definition at line 1880 of file ossl_ssl.c.

References ary, cSSLContext, cSSLSocket, eOSSLError, eSSLError, eSSLErrorWaitReadable, eSSLErrorWaitWritable, i, ID2SYM, ID_callback_state, Init_ossl_ssl_session(), LONG2FIX, mOSSL, mSSL, name, numberof, ossl_ssl_accept(), ossl_ssl_accept_nonblock(), ossl_ssl_attr_readers, ossl_ssl_attrs, ossl_ssl_close(), ossl_ssl_connect(), ossl_ssl_connect_nonblock(), ossl_ssl_def_const, ossl_ssl_ex_client_cert_cb_idx, ossl_ssl_ex_ptr_idx, ossl_ssl_ex_store_p, ossl_ssl_ex_tmp_dh_callback_idx, ossl_ssl_ex_vcb_idx, ossl_ssl_get_cert(), ossl_ssl_get_cipher(), ossl_ssl_get_client_ca_list(), ossl_ssl_get_peer_cert(), ossl_ssl_get_peer_cert_chain(), ossl_ssl_get_state(), ossl_ssl_get_verify_result(), ossl_ssl_get_version(), ossl_ssl_initialize(), ossl_ssl_method_tab, ossl_ssl_pending(), ossl_ssl_read(), ossl_ssl_read_nonblock(), ossl_ssl_s_alloc(), ossl_ssl_session_reused(), ossl_ssl_set_session(), ossl_ssl_write(), ossl_ssl_write_nonblock(), ossl_sslctx_flush_sessions(), ossl_sslctx_get_ciphers(), ossl_sslctx_get_session_cache_mode(), ossl_sslctx_get_session_cache_size(), ossl_sslctx_get_session_cache_stats(), ossl_sslctx_initialize(), ossl_sslctx_s_alloc(), ossl_sslctx_session_add(), ossl_sslctx_session_remove(), ossl_sslctx_set_ciphers(), ossl_sslctx_set_session_cache_mode(), ossl_sslctx_set_session_cache_size(), ossl_sslctx_set_ssl_version(), ossl_sslctx_setup(), Qfalse, rb_ary_new2, rb_ary_push(), rb_attr(), rb_cObject, rb_define_alias(), rb_define_alloc_func(), rb_define_class_under(), rb_define_const(), rb_define_method(), rb_define_module(), rb_define_module_under(), rb_define_private_method(), rb_include_module(), rb_intern, rb_mWaitReadable, rb_mWaitWritable, rb_notimplement(), rb_obj_freeze(), and sym_exception.

Referenced by Init_openssl().

static VALUE ossl_call_client_cert_cb ( VALUE  obj)
static
static VALUE ossl_call_session_get_cb ( VALUE  ary)
static

Definition at line 340 of file ossl_ssl.c.

References Check_Type(), NIL_P(), Qnil, rb_ary_entry(), rb_funcall(), rb_intern, rb_iv_get(), and T_ARRAY.

Referenced by ossl_sslctx_session_get_cb().

static VALUE ossl_call_session_new_cb ( VALUE  ary)
static

Definition at line 387 of file ossl_ssl.c.

References Check_Type(), NIL_P(), Qnil, rb_ary_entry(), rb_funcall(), rb_intern, rb_iv_get(), and T_ARRAY.

Referenced by ossl_sslctx_session_new_cb().

static VALUE ossl_call_session_remove_cb ( VALUE  ary)
static
static VALUE ossl_call_tmp_dh_callback ( VALUE args)
static
static int ossl_client_cert_cb ( SSL *  ssl,
X509 **  x509,
EVP_PKEY **  pkey 
)
static
static DH* ossl_default_tmp_dh_callback ( SSL *  ssl,
int  is_export,
int  keylength 
)
static

Definition at line 313 of file ossl_ssl.c.

References NULL, OSSL_DEFAULT_DH_1024, OSSL_DEFAULT_DH_512, and rb_warning().

Referenced by ossl_sslctx_setup().

static VALUE ossl_ssl_accept ( VALUE  self)
static

Definition at line 1365 of file ossl_ssl.c.

References ossl_ssl_setup(), and ossl_start_ssl().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_accept_nonblock ( VALUE  self)
static

Definition at line 1390 of file ossl_ssl.c.

References ossl_ssl_setup(), and ossl_start_ssl().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_cipher_to_ary ( SSL_CIPHER *  cipher)
static

Definition at line 837 of file ossl_ssl.c.

References ary, INT2FIX, rb_ary_new2, rb_ary_push(), and rb_str_new2.

Referenced by ossl_ssl_get_cipher(), and ossl_sslctx_get_ciphers().

static VALUE ossl_ssl_close ( VALUE  self)
static
static VALUE ossl_ssl_connect ( VALUE  self)
static

Definition at line 1326 of file ossl_ssl.c.

References ossl_ssl_setup(), and ossl_start_ssl().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_connect_nonblock ( VALUE  self)
static

Definition at line 1351 of file ossl_ssl.c.

References ossl_ssl_setup(), and ossl_start_ssl().

Referenced by Init_ossl_ssl().

static void ossl_ssl_free ( SSL *  ssl)
static

Definition at line 1146 of file ossl_ssl.c.

Referenced by ossl_ssl_s_alloc().

static VALUE ossl_ssl_get_cert ( VALUE  self)
static

Definition at line 1616 of file ossl_ssl.c.

References NULL, ossl_ssl_data_get_struct, ossl_x509_new(), and Qnil.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_cipher ( VALUE  self)
static

Definition at line 1714 of file ossl_ssl.c.

References ossl_ssl_cipher_to_ary(), and ossl_ssl_data_get_struct.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_client_ca_list ( VALUE  self)
static

Definition at line 1842 of file ossl_ssl.c.

References ossl_ssl_data_get_struct, ossl_x509name_sk2ary(), and STACK_OF().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_peer_cert ( VALUE  self)
static

Definition at line 1642 of file ossl_ssl.c.

References NULL, obj, ossl_ssl_data_get_struct, ossl_x509_new(), and Qnil.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_peer_cert_chain ( VALUE  self)
static

Definition at line 1668 of file ossl_ssl.c.

References ary, i, ossl_ssl_data_get_struct, ossl_x509_new(), Qnil, rb_ary_new2, rb_ary_push(), and STACK_OF().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_state ( VALUE  self)
static

Definition at line 1733 of file ossl_ssl.c.

References ossl_ssl_data_get_struct, rb_str_cat2(), rb_str_new2, ret, and ruby_verbose.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_verify_result ( VALUE  self)
static

Definition at line 1821 of file ossl_ssl.c.

References INT2FIX, and ossl_ssl_data_get_struct.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_get_version ( VALUE  self)
static

Definition at line 1698 of file ossl_ssl.c.

References ossl_ssl_data_get_struct, and rb_str_new2.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_initialize ( int  argc,
VALUE argv,
VALUE  self 
)
static
static VALUE ossl_ssl_pending ( VALUE  self)
static

Definition at line 1755 of file ossl_ssl.c.

References INT2NUM, and ossl_ssl_data_get_struct.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_read ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1476 of file ossl_ssl.c.

References ossl_ssl_read_internal().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_read_internal ( int  argc,
VALUE argv,
VALUE  self,
int  nonblock 
)
static
static VALUE ossl_ssl_read_nonblock ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1495 of file ossl_ssl.c.

References ossl_ssl_read_internal().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_s_alloc ( VALUE  klass)
static

Definition at line 1152 of file ossl_ssl.c.

References Data_Wrap_Struct(), NULL, and ossl_ssl_free().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_session_reused ( VALUE  self)
static

Definition at line 1771 of file ossl_ssl.c.

References eSSLError, ossl_raise(), ossl_ssl_data_get_struct, Qfalse, Qtrue, and UNREACHABLE.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_set_session ( VALUE  self,
VALUE  arg1 
)
static

Definition at line 1793 of file ossl_ssl.c.

References eSSLError, ossl_raise(), ossl_ssl_data_get_struct, ossl_ssl_setup(), and SafeGetSSLSession.

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_setup ( VALUE  self)
static
static void ossl_ssl_shutdown ( SSL *  ssl)
static

Definition at line 1125 of file ossl_ssl.c.

References i.

Referenced by ossl_ssl_close().

static int ossl_ssl_verify_callback ( int  preverify_ok,
X509_STORE_CTX *  ctx 
)
static

Definition at line 328 of file ossl_ssl.c.

References ossl_ssl_ex_vcb_idx, ossl_verify_cb(), and ossl_verify_cb_idx.

Referenced by ossl_sslctx_setup().

static VALUE ossl_ssl_write ( VALUE  self,
VALUE  str 
)
static

Definition at line 1551 of file ossl_ssl.c.

References ossl_ssl_write_internal().

Referenced by Init_ossl_ssl().

static VALUE ossl_ssl_write_internal ( VALUE  self,
VALUE  str,
int  nonblock,
int  no_exception 
)
static
static VALUE ossl_ssl_write_nonblock ( int  argc,
VALUE argv,
VALUE  self 
)
static

Definition at line 1564 of file ossl_ssl.c.

References NIL_P(), opts, ossl_ssl_write_internal(), Qfalse, Qnil, rb_hash_aref(), rb_scan_args(), str, and sym_exception.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_flush_sessions ( int  argc,
VALUE argv,
VALUE  self 
)
static
static void ossl_sslctx_free ( SSL_CTX *  ctx)
static

Definition at line 156 of file ossl_ssl.c.

References NULL, and ossl_ssl_ex_store_p.

Referenced by ossl_sslctx_s_alloc().

static VALUE ossl_sslctx_get_ciphers ( VALUE  self)
static
static VALUE ossl_sslctx_get_session_cache_mode ( VALUE  self)
static

Definition at line 977 of file ossl_ssl.c.

References ctx, Data_Get_Struct, and LONG2NUM.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_get_session_cache_size ( VALUE  self)
static

Definition at line 1014 of file ossl_ssl.c.

References ctx, Data_Get_Struct, and LONG2NUM.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_get_session_cache_stats ( VALUE  self)
static

Definition at line 1065 of file ossl_ssl.c.

References ctx, Data_Get_Struct, hash, ID2SYM, LONG2NUM, rb_hash_aset(), rb_hash_new(), and rb_intern.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_initialize ( int  argc,
VALUE argv,
VALUE  self 
)
static
static VALUE ossl_sslctx_s_alloc ( VALUE  klass)
static

Definition at line 164 of file ossl_ssl.c.

References ctx, Data_Wrap_Struct(), eSSLError, mode, ossl_raise(), and ossl_sslctx_free().

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_session_add ( VALUE  self,
VALUE  arg 
)
static

Definition at line 941 of file ossl_ssl.c.

References ctx, Data_Get_Struct, Qfalse, Qtrue, and SafeGetSSLSession.

Referenced by Init_ossl_ssl().

static SSL_SESSION* ossl_sslctx_session_get_cb ( SSL *  ssl,
unsigned char *  buf,
int  len,
int copy 
)
static
static int ossl_sslctx_session_new_cb ( SSL *  ssl,
SSL_SESSION *  sess 
)
static
static VALUE ossl_sslctx_session_remove ( VALUE  self,
VALUE  arg 
)
static

Definition at line 959 of file ossl_ssl.c.

References ctx, Data_Get_Struct, Qfalse, Qtrue, and SafeGetSSLSession.

Referenced by Init_ossl_ssl().

static void ossl_sslctx_session_remove_cb ( SSL_CTX *  ctx,
SSL_SESSION *  sess 
)
static
static VALUE ossl_sslctx_set_ciphers ( VALUE  self,
VALUE  v 
)
static
static VALUE ossl_sslctx_set_session_cache_mode ( VALUE  self,
VALUE  arg 
)
static

Definition at line 995 of file ossl_ssl.c.

References arg, ctx, Data_Get_Struct, and NUM2LONG.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_set_session_cache_size ( VALUE  self,
VALUE  arg 
)
static

Definition at line 1031 of file ossl_ssl.c.

References arg, ctx, Data_Get_Struct, and NUM2LONG.

Referenced by Init_ossl_ssl().

static VALUE ossl_sslctx_set_ssl_version ( VALUE  self,
VALUE  ssl_method 
)
static
static VALUE ossl_sslctx_setup ( VALUE  self)
static
static VALUE ossl_start_ssl ( VALUE  self,
int(*)()  func,
const char *  funcname,
int  nonblock 
)
static
static DH* ossl_tmp_dh_callback ( SSL *  ssl,
int  is_export,
int  keylength 
)
static
static void read_would_block ( int  nonblock)
static
static void ssl_info_cb ( const SSL *  ssl,
int  where,
int  val 
)
static

Definition at line 660 of file ossl_ssl.c.

References ssl_renegotiation_cb().

Referenced by ossl_ssl_setup().

static void ssl_renegotiation_cb ( const SSL *  ssl)
static

Definition at line 558 of file ossl_ssl.c.

References eSSLError, NIL_P(), NULL, ossl_raise(), ossl_ssl_ex_ptr_idx, ptr, rb_funcall(), rb_intern, rb_iv_get(), and void.

Referenced by ssl_info_cb().

static void write_would_block ( int  nonblock)
static

Variable Documentation

VALUE cSSLContext

Definition at line 29 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), and ossl_ssl_initialize().

VALUE cSSLSocket

Definition at line 30 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), and ossl_ssl_session_initialize().

SSL_CTX* ctx

Definition at line 486 of file ossl_ssl.c.

Referenced by EVP_MD_CTX_create(), GetCipherPtr(), GetDigestPtr(), ossl_cipher_final(), ossl_cipher_init(), ossl_cipher_initialize(), ossl_cipher_name(), ossl_cipher_new(), ossl_cipher_pkcs5_keyivgen(), ossl_cipher_reset(), ossl_cipher_set_iv(), ossl_cipher_set_key(), ossl_cipher_set_key_length(), ossl_cipher_update(), ossl_digest_alloc(), ossl_digest_block_length(), ossl_digest_finish(), ossl_digest_initialize(), ossl_digest_name(), ossl_digest_new(), ossl_digest_reset(), ossl_digest_size(), ossl_digest_update(), ossl_hmac_alloc(), ossl_hmac_digest(), ossl_hmac_hexdigest(), ossl_hmac_initialize(), ossl_hmac_reset(), ossl_hmac_update(), ossl_pkey_sign(), ossl_pkey_verify(), ossl_ssl_initialize(), ossl_ssl_session_get_time(), ossl_ssl_session_get_timeout(), ossl_ssl_session_initialize(), ossl_ssl_session_set_time(), ossl_ssl_session_set_timeout(), ossl_ssl_session_to_der(), ossl_ssl_session_to_pem(), ossl_ssl_session_to_text(), ossl_ssl_setup(), ossl_sslctx_flush_sessions(), ossl_sslctx_get_ciphers(), ossl_sslctx_get_session_cache_mode(), ossl_sslctx_get_session_cache_size(), ossl_sslctx_get_session_cache_stats(), ossl_sslctx_s_alloc(), ossl_sslctx_session_add(), ossl_sslctx_session_remove(), ossl_sslctx_set_ciphers(), ossl_sslctx_set_session_cache_mode(), ossl_sslctx_set_session_cache_size(), ossl_sslctx_set_ssl_version(), ossl_sslctx_setup(), ossl_x509extfactory_alloc(), ossl_x509extfactory_create_ext(), ossl_x509extfactory_set_crl(), ossl_x509extfactory_set_issuer_cert(), ossl_x509extfactory_set_subject_cert(), ossl_x509extfactory_set_subject_req(), ossl_x509stctx_alloc(), ossl_x509stctx_get_chain(), ossl_x509stctx_get_curr_cert(), ossl_x509stctx_get_curr_crl(), ossl_x509stctx_get_err(), ossl_x509stctx_get_err_depth(), ossl_x509stctx_get_err_string(), ossl_x509stctx_initialize(), ossl_x509stctx_set_error(), ossl_x509stctx_verify(), and ossl_x509store_verify().

VALUE eSSLError
VALUE eSSLErrorWaitReadable
static

Definition at line 32 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), and read_would_block().

VALUE eSSLErrorWaitWritable
static

Definition at line 33 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), and write_would_block().

callq func = func

Definition at line 113 of file ossl_ssl.c.

Referenced by alloc_event_hook(), backtrace_collect(), call_cfunc_0(), call_cfunc_1(), call_cfunc_10(), call_cfunc_11(), call_cfunc_12(), call_cfunc_13(), call_cfunc_14(), call_cfunc_15(), call_cfunc_2(), call_cfunc_3(), call_cfunc_4(), call_cfunc_5(), call_cfunc_6(), call_cfunc_7(), call_cfunc_8(), call_cfunc_9(), call_cfunc_m1(), call_cfunc_m2(), call_without_gvl(), check_cfunc(), class_instance_method_list(), console_emulator_p(), default_handler(), define_filetest_function(), dlhandle_sym(), enum_count(), enum_find_index(), exec_recursive(), extract_fd(), f_addsub(), f_divide(), f_format(), f_round_common(), fiddle_handle_sym(), get_freefunc(), if(), lazy_zip(), obj_ivar_each(), onig_foreach_name(), ossl_start_ssl(), parser_here_document(), parser_heredoc_identifier(), parser_parse_string(), postponed_job_register(), rb_add_method_cfunc(), rb_bug_reporter_add(), rb_catch(), rb_catch_obj(), rb_define_alloc_func(), rb_define_global_function(), rb_define_method(), rb_define_method_id(), rb_define_module_function(), rb_define_private_method(), rb_define_protected_method(), rb_define_singleton_method(), rb_dlcfunc2ptr(), rb_dlcfunc_new(), rb_dlptr_new2(), rb_enc_foreach_name(), rb_exec_recursive(), rb_exec_recursive_outer(), rb_exec_recursive_paired(), rb_exec_recursive_paired_outer(), rb_fiber_new(), rb_fiddle_ptr_new2(), rb_get_values_at(), rb_glob(), rb_glob2(), rb_hash_foreach(), rb_hash_update_by(), rb_iseq_line_trace_each(), rb_ivar_foreach(), rb_mutex_synchronize(), rb_objspace_reachable_objects_from(), rb_objspace_reachable_objects_from_root(), rb_proc_new(), rb_set_end_proc(), rb_stat_inspect(), rb_str_locktmp_ensure(), rb_thread_blocking_region(), rb_thread_call_without_gvl(), rb_thread_call_without_gvl2(), rb_thread_io_blocking_region(), rb_tracepoint_new(), rb_w32_asynchronize(), rollback_ensure_stack(), rsock_bsock_send(), rsock_connect(), ruby_brace_glob0(), ruby_vm_at_exit(), ruby_vm_run_at_exit_hooks(), set_unblock_function(), setup_method_cfunc_struct(), sig_trap(), signal_ignored(), st_foreach_safe(), syserr_initialize(), tbl_update(), tracepoint_new(), trap_handler(), ttymode(), and zstream_init().

return i

Definition at line 494 of file ossl_ssl.c.

ID ID_callback_state
VALUE mSSL

Definition at line 27 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), and Init_ossl_ssl_session().

const char* name

Definition at line 112 of file ossl_ssl.c.

const char* ossl_ssl_attr_readers[] = { "io", "context", }
static

Definition at line 96 of file ossl_ssl.c.

Referenced by Init_ossl_ssl().

const char* ossl_ssl_attrs[]
static
Initial value:
= {
"sync_close",
}

Definition at line 97 of file ossl_ssl.c.

Referenced by Init_ossl_ssl().

int ossl_ssl_ex_client_cert_cb_idx

Definition at line 152 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_call_client_cert_cb(), and ossl_ssl_setup().

int ossl_ssl_ex_ptr_idx
int ossl_ssl_ex_store_p

Definition at line 150 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_sslctx_free(), and ossl_sslctx_setup().

int ossl_ssl_ex_tmp_dh_callback_idx

Definition at line 153 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_call_tmp_dh_callback(), and ossl_ssl_setup().

int ossl_ssl_ex_vcb_idx

Definition at line 149 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_ssl_setup(), and ossl_ssl_verify_callback().

struct { ... } ossl_ssl_method_tab[]
const char* ossl_sslctx_attrs[]
static
Initial value:
= {
"cert", "key", "client_ca", "ca_file", "ca_path",
"timeout", "verify_mode", "verify_depth", "renegotiation_cb",
"verify_callback", "options", "cert_store", "extra_chain_cert",
"client_cert_cb", "tmp_dh_callback", "session_id_context",
"session_get_cb", "session_new_cb", "session_remove_cb",
}

Definition at line 67 of file ossl_ssl.c.

Referenced by ossl_sslctx_initialize().

VALUE sym_exception
static

Definition at line 106 of file ossl_ssl.c.

Referenced by Init_ossl_ssl(), ossl_ssl_read_internal(), and ossl_ssl_write_nonblock().

VALUE
static
Initial value:
{
X509 *x509
x509
Definition: ossl_ssl.c:489

Definition at line 484 of file ossl_ssl.c.

x509 = DupX509CertPtr(i)