12#define NewX509(klass) \
13 TypedData_Wrap_Struct((klass), &ossl_x509_type, 0)
14#define SetX509(obj, x509) do { \
16 ossl_raise(rb_eRuntimeError, "CERT wasn't initialized!"); \
18 RTYPEDDATA_DATA(obj) = (x509); \
20#define GetX509(obj, x509) do { \
21 TypedData_Get_Struct((obj), X509, &ossl_x509_type, (x509)); \
23 ossl_raise(rb_eRuntimeError, "CERT wasn't initialized!"); \
34ossl_x509_free(
void *
ptr)
127 x509 = PEM_read_bio_X509(in, &x,
NULL,
NULL);
131 x509 = d2i_X509_bio(in, &x);
146 if (
self == other)
return self;
165ossl_x509_to_der(
VALUE self)
173 if ((
len = i2d_X509(x509,
NULL)) <= 0)
177 if (i2d_X509(x509, &p) <= 0)
189ossl_x509_to_pem(
VALUE self)
196 out = BIO_new(BIO_s_mem());
199 if (!PEM_write_bio_X509(out, x509)) {
213ossl_x509_to_text(
VALUE self)
221 out = BIO_new(BIO_s_mem());
224 if (!X509_print(out, x509)) {
238ossl_x509_to_req(
VALUE self)
245 if (!(req = X509_to_X509_REQ(x509,
NULL, EVP_md5()))) {
248 obj = ossl_x509req_new(req);
260ossl_x509_get_version(
VALUE self)
266 return LONG2NUM(X509_get_version(x509));
274ossl_x509_set_version(
VALUE self,
VALUE version)
279 if ((ver =
NUM2LONG(version)) < 0) {
283 if (!X509_set_version(x509, ver)) {
295ossl_x509_get_serial(
VALUE self)
324ossl_x509_get_signature_algorithm(
VALUE self)
331 out = BIO_new(BIO_s_mem());
348ossl_x509_get_subject(
VALUE self)
354 if (!(
name = X509_get_subject_name(x509))) {
366ossl_x509_set_subject(
VALUE self,
VALUE subject)
383ossl_x509_get_issuer(
VALUE self)
389 if(!(
name = X509_get_issuer_name(x509))) {
418ossl_x509_get_not_before(
VALUE self)
421 const ASN1_TIME *asn1time;
444 ASN1_TIME_free(asn1time);
447 ASN1_TIME_free(asn1time);
457ossl_x509_get_not_after(
VALUE self)
460 const ASN1_TIME *asn1time;
483 ASN1_TIME_free(asn1time);
486 ASN1_TIME_free(asn1time);
496ossl_x509_get_public_key(
VALUE self)
502 if (!(pkey = X509_get_pubkey(x509))) {
522 if (!X509_set_pubkey(x509, pkey))
541 if (!X509_sign(x509, pkey, md)) {
564 switch (X509_verify(x509, pkey)) {
591 if (!X509_check_private_key(x509, pkey)) {
604ossl_x509_get_extensions(
VALUE self)
612 count = X509_get_ext_count(x509);
618 ext = X509_get_ext(x509,
i);
630ossl_x509_set_extensions(
VALUE self,
VALUE ary)
642 while ((ext = X509_delete_ext(x509, 0)))
643 X509_EXTENSION_free(ext);
646 if (!X509_add_ext(x509, ext, -1)) {
659ossl_x509_add_extension(
VALUE self,
VALUE extension)
666 if (!X509_add_ext(x509, ext, -1)) {
674ossl_x509_inspect(
VALUE self)
680 ossl_x509_get_subject(
self),
681 ossl_x509_get_issuer(
self),
682 ossl_x509_get_serial(
self),
683 ossl_x509_get_not_before(
self),
684 ossl_x509_get_not_after(
self));
char str[HTML_ESCAPE_MAX_LEN+1]
VALUE rb_define_class_under(VALUE, const char *, VALUE)
Defines a class under the namespace of outer.
VALUE rb_define_module(const char *)
VALUE rb_define_module_under(VALUE, const char *)
void rb_define_alias(VALUE, const char *, const char *)
Defines an alias of a method.
VALUE rb_cObject
Object class.
VALUE rb_obj_class(VALUE)
Equivalent to Object#class in Ruby.
VALUE rb_obj_is_kind_of(VALUE, VALUE)
Determines if obj is a kind of c.
#define X509_get0_notAfter(x)
#define X509_set1_notAfter(x, t)
#define X509_get0_notBefore(x)
#define X509_set1_notBefore(x, t)
#define X509_get0_tbs_sigalg(x)
VALUE ossl_to_der_if_possible(VALUE obj)
void ossl_raise(VALUE exc, const char *fmt,...)
void ossl_clear_error(void)
#define ossl_str_adjust(str, p)
#define OSSL_BIO_reset(bio)
#define OSSL_Check_Kind(obj, klass)
VALUE asn1integer_to_num(const ASN1_INTEGER *ai)
VALUE asn1time_to_time(const ASN1_TIME *time)
ASN1_INTEGER * num_to_asn1integer(VALUE obj, ASN1_INTEGER *ai)
BIO * ossl_obj2bio(volatile VALUE *pobj)
VALUE ossl_membio2str(BIO *bio)
const EVP_MD * ossl_evp_get_digestbyname(VALUE obj)
EVP_PKEY * GetPrivPKeyPtr(VALUE obj)
void ossl_pkey_check_public_key(const EVP_PKEY *pkey)
EVP_PKEY * GetPKeyPtr(VALUE obj)
VALUE ossl_pkey_new(EVP_PKEY *pkey)
ASN1_TIME * ossl_x509_time_adjust(ASN1_TIME *s, VALUE time)
VALUE ossl_x509name_new(X509_NAME *)
X509_NAME * GetX509NamePtr(VALUE)
VALUE ossl_x509ext_new(X509_EXTENSION *)
X509_EXTENSION * GetX509ExtPtr(VALUE)
X509 * GetX509CertPtr(VALUE obj)
#define SetX509(obj, x509)
void Init_ossl_x509cert(void)
VALUE ossl_x509_new(X509 *x509)
X509 * DupX509CertPtr(VALUE obj)
#define GetX509(obj, x509)