13 #define WrapX509(klass, obj, x509) do { \ 15 ossl_raise(rb_eRuntimeError, "CERT wasn't initialized!"); \ 17 (obj) = Data_Wrap_Struct((klass), 0, X509_free, (x509)); \ 19 #define GetX509(obj, x509) do { \ 20 Data_Get_Struct((obj), X509, (x509)); \ 22 ossl_raise(rb_eRuntimeError, "CERT wasn't initialized!"); \ 25 #define SafeGetX509(obj, x509) do { \ 26 OSSL_Check_Kind((obj), cX509Cert); \ 27 GetX509((obj), (x509)); \ 108 CRYPTO_add(&x509->references, 1, CRYPTO_LOCK_X509);
148 x509 = PEM_read_bio_X509(in, &x,
NULL,
NULL);
152 x509 = d2i_X509_bio(in, &x);
167 if (
self == other)
return self;
194 if ((len = i2d_X509(x509,
NULL)) <= 0)
198 if (i2d_X509(x509, &p) <= 0)
217 out = BIO_new(BIO_s_mem());
220 if (!PEM_write_bio_X509(out, x509)) {
242 out = BIO_new(BIO_s_mem());
245 if (!X509_print(out, x509)) {
259 ossl_x509_to_req(
VALUE self)
266 if (!(req = X509_to_X509_REQ(x509,
NULL, EVP_md5()))) {
287 return LONG2NUM(X509_get_version(x509));
304 if (!X509_set_version(x509, ver)) {
336 x509->cert_info->serialNumber =
354 out = BIO_new(BIO_s_mem());
357 if (!i2a_ASN1_OBJECT(out, x509->cert_info->signature->algorithm)) {
377 if (!(
name = X509_get_subject_name(x509))) {
412 if(!(
name = X509_get_issuer_name(x509))) {
444 ASN1_UTCTIME *asn1time;
447 if (!(asn1time = X509_get_notBefore(x509))) {
466 if (!X509_time_adj(X509_get_notBefore(x509), 0, &sec)) {
484 if (!(asn1time = X509_get_notAfter(x509))) {
503 if (!X509_time_adj(X509_get_notAfter(x509), 0, &sec)) {
521 if (!(pkey = X509_get_pubkey(x509))) {
559 if (!X509_sign(x509, pkey, md)) {
581 if ((i = X509_verify(x509, pkey)) < 0) {
606 if (!X509_check_private_key(x509, pkey)) {
627 count = X509_get_ext_count(x509);
632 for (i=0; i<
count; i++) {
633 ext = X509_get_ext(x509, i);
657 sk_X509_EXTENSION_pop_free(x509->cert_info->extensions, X509_EXTENSION_free);
658 x509->cert_info->extensions =
NULL;
662 if (!X509_add_ext(x509, ext, -1)) {
663 X509_EXTENSION_free(ext);
666 X509_EXTENSION_free(ext);
684 if (!X509_add_ext(x509, ext, -1)) {
685 X509_EXTENSION_free(ext);
688 X509_EXTENSION_free(ext);
static VALUE ossl_x509_get_signature_algorithm(VALUE self)
static VALUE ossl_x509_inspect(VALUE self)
static VALUE ossl_x509_get_subject(VALUE self)
static VALUE ossl_x509_set_serial(VALUE self, VALUE num)
EVP_PKEY * GetPrivPKeyPtr(VALUE obj)
#define ossl_str_adjust(str, p)
static VALUE ossl_x509_set_version(VALUE self, VALUE version)
VALUE rb_ary_push(VALUE ary, VALUE item)
static VALUE ossl_x509_copy(VALUE self, VALUE other)
static VALUE ossl_x509_get_extensions(VALUE self)
static VALUE ossl_x509_add_extension(VALUE self, VALUE extension)
VALUE rb_define_class_under(VALUE outer, const char *name, VALUE super)
Defines a class under the namespace of outer.
static VALUE ossl_x509_set_not_after(VALUE self, VALUE time)
void rb_define_alloc_func(VALUE, rb_alloc_func_t)
VALUE asn1time_to_time(ASN1_TIME *time)
X509_EXTENSION * DupX509ExtPtr(VALUE)
VALUE ossl_membio2str(BIO *bio)
VALUE ossl_x509_new(X509 *x509)
VALUE ossl_pkey_new(EVP_PKEY *pkey)
X509_NAME * GetX509NamePtr(VALUE)
time_t time_to_time_t(VALUE time)
#define rb_define_copy_func(klass, func)
static VALUE ossl_x509_set_not_before(VALUE self, VALUE time)
#define GetX509(obj, x509)
VALUE ossl_to_der_if_possible(VALUE obj)
RUBY_EXTERN VALUE rb_cObject
VALUE rb_str_cat2(VALUE, const char *)
#define OSSL_BIO_reset(bio)
const EVP_MD * GetDigestPtr(VALUE obj)
static VALUE ossl_x509_get_issuer(VALUE self)
VALUE ossl_x509ext_new(X509_EXTENSION *)
X509 * DupX509CertPtr(VALUE obj)
void rb_define_alias(VALUE klass, const char *name1, const char *name2)
Defines an alias of a method.
static VALUE ossl_x509_set_subject(VALUE self, VALUE subject)
static VALUE ossl_x509_get_public_key(VALUE self)
BIO * ossl_obj2bio(VALUE obj)
static VALUE ossl_x509_set_public_key(VALUE self, VALUE key)
static VALUE ossl_x509_set_extensions(VALUE self, VALUE ary)
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
#define SafeGetX509(obj, x509)
static VALUE ossl_x509_sign(VALUE self, VALUE key, VALUE digest)
const char * rb_class2name(VALUE)
VALUE ossl_x509req_new(X509_REQ *)
static VALUE ossl_x509_check_private_key(VALUE self, VALUE key)
VALUE rb_define_module_under(VALUE outer, const char *name)
static VALUE ossl_x509_verify(VALUE self, VALUE key)
void rb_fd_fix_cloexec(int fd)
static VALUE ossl_x509_get_version(VALUE self)
#define OSSL_Check_Kind(obj, klass)
RUBY_EXTERN char * strerror(int)
static VALUE ossl_x509_get_not_before(VALUE self)
static VALUE ossl_x509_get_serial(VALUE self)
static VALUE ossl_x509_to_der(VALUE self)
void ossl_raise(VALUE exc, const char *fmt,...)
static VALUE ossl_x509_to_text(VALUE self)
EVP_PKEY * GetPKeyPtr(VALUE obj)
#define SafeStringValue(v)
static VALUE ossl_x509_initialize(int argc, VALUE *argv, VALUE self)
VALUE ossl_x509name_new(X509_NAME *)
#define rb_check_frozen(obj)
void Init_ossl_x509cert()
static void version(void)
VALUE asn1integer_to_num(ASN1_INTEGER *ai)
static VALUE ossl_x509_alloc(VALUE klass)
X509 * GetX509CertPtr(VALUE obj)
static VALUE ossl_x509_set_issuer(VALUE self, VALUE issuer)
VALUE rb_define_module(const char *name)
static VALUE ossl_x509_to_pem(VALUE self)
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
VALUE rb_str_append(VALUE, VALUE)
#define WrapX509(klass, obj, x509)
VALUE ossl_x509_new_from_file(VALUE filename)
static VALUE ossl_x509_get_not_after(VALUE self)
VALUE rb_obj_class(VALUE)
VALUE rb_str_new(const char *, long)
ASN1_INTEGER * num_to_asn1integer(VALUE obj, ASN1_INTEGER *ai)