12#define NewX509CRL(klass) \
13 TypedData_Wrap_Struct((klass), &ossl_x509crl_type, 0)
14#define SetX509CRL(obj, crl) do { \
16 ossl_raise(rb_eRuntimeError, "CRL wasn't initialized!"); \
18 RTYPEDDATA_DATA(obj) = (crl); \
20#define GetX509CRL(obj, crl) do { \
21 TypedData_Get_Struct((obj), X509_CRL, &ossl_x509crl_type, (crl)); \
23 ossl_raise(rb_eRuntimeError, "CRL wasn't initialized!"); \
34ossl_x509crl_free(
void *
ptr)
67 tmp = crl ? X509_CRL_dup(crl) : X509_CRL_new();
84 if (!(crl = X509_CRL_new())) {
104 crl = PEM_read_bio_X509_CRL(in, &x,
NULL,
NULL);
108 crl = d2i_X509_CRL_bio(in, &x);
120 X509_CRL *a, *b, *crl;
123 if (
self == other)
return self;
126 if (!(crl = X509_CRL_dup(b))) {
136ossl_x509crl_get_version(
VALUE self)
142 ver = X509_CRL_get_version(crl);
148ossl_x509crl_set_version(
VALUE self,
VALUE version)
153 if ((ver =
NUM2LONG(version)) < 0) {
157 if (!X509_CRL_set_version(crl, ver)) {
165ossl_x509crl_get_signature_algorithm(
VALUE self)
168 const X509_ALGOR *alg;
172 if (!(out = BIO_new(BIO_s_mem()))) {
176 if (!i2a_ASN1_OBJECT(out, alg->algorithm)) {
185ossl_x509crl_get_issuer(
VALUE self)
195ossl_x509crl_set_issuer(
VALUE self,
VALUE issuer)
208ossl_x509crl_get_last_update(
VALUE self)
211 const ASN1_TIME *
time;
230 ASN1_TIME_free(asn1time);
233 ASN1_TIME_free(asn1time);
239ossl_x509crl_get_next_update(
VALUE self)
242 const ASN1_TIME *
time;
261 ASN1_TIME_free(asn1time);
264 ASN1_TIME_free(asn1time);
270ossl_x509crl_get_revoked(
VALUE self)
278 num = sk_X509_REVOKED_num(X509_CRL_get_REVOKED(crl));
284 for(
i=0;
i<num;
i++) {
286 rev = sk_X509_REVOKED_value(X509_CRL_get_REVOKED(crl),
i);
295ossl_x509crl_set_revoked(
VALUE self,
VALUE ary)
308 if ((sk = X509_CRL_get_REVOKED(crl))) {
309 while ((rev = sk_X509_REVOKED_pop(sk)))
310 X509_REVOKED_free(rev);
314 if (!X509_CRL_add0_revoked(crl, rev)) {
315 X509_REVOKED_free(rev);
325ossl_x509crl_add_revoked(
VALUE self,
VALUE revoked)
332 if (!X509_CRL_add0_revoked(crl, rev)) {
333 X509_REVOKED_free(rev);
351 if (!X509_CRL_sign(crl, pkey, md)) {
367 switch (X509_CRL_verify(crl, pkey)) {
379ossl_x509crl_to_der(
VALUE self)
385 if (!(out = BIO_new(BIO_s_mem()))) {
388 if (!i2d_X509_CRL_bio(out, crl)) {
397ossl_x509crl_to_pem(
VALUE self)
403 if (!(out = BIO_new(BIO_s_mem()))) {
406 if (!PEM_write_bio_X509_CRL(out, crl)) {
415ossl_x509crl_to_text(
VALUE self)
421 if (!(out = BIO_new(BIO_s_mem()))) {
424 if (!X509_CRL_print(out, crl)) {
436ossl_x509crl_get_extensions(
VALUE self)
444 count = X509_CRL_get_ext_count(crl);
451 ext = X509_CRL_get_ext(crl,
i);
462ossl_x509crl_set_extensions(
VALUE self,
VALUE ary)
474 while ((ext = X509_CRL_delete_ext(crl, 0)))
475 X509_EXTENSION_free(ext);
478 if (!X509_CRL_add_ext(crl, ext, -1)) {
487ossl_x509crl_add_extension(
VALUE self,
VALUE extension)
494 if (!X509_CRL_add_ext(crl, ext, -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.
#define X509_CRL_get0_signature
#define X509_CRL_get0_nextUpdate(x)
#define X509_CRL_set1_lastUpdate(x, t)
#define X509_CRL_set1_nextUpdate(x, t)
#define X509_CRL_get0_lastUpdate(x)
VALUE ossl_to_der_if_possible(VALUE obj)
void ossl_raise(VALUE exc, const char *fmt,...)
void ossl_clear_error(void)
#define OSSL_BIO_reset(bio)
#define OSSL_Check_Kind(obj, klass)
STACK_OF(X509) *ossl_x509_ary2sk(VALUE)
VALUE asn1time_to_time(const ASN1_TIME *time)
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)
ASN1_TIME * ossl_x509_time_adjust(ASN1_TIME *s, VALUE time)
VALUE ossl_x509name_new(X509_NAME *)
X509_NAME * GetX509NamePtr(VALUE)
X509_REVOKED * DupX509RevokedPtr(VALUE)
VALUE ossl_x509ext_new(X509_EXTENSION *)
VALUE ossl_x509revoked_new(X509_REVOKED *)
X509_EXTENSION * GetX509ExtPtr(VALUE)
#define NewX509CRL(klass)
#define SetX509CRL(obj, crl)
void Init_ossl_x509crl(void)
#define GetX509CRL(obj, crl)
X509_CRL * GetX509CRLPtr(VALUE obj)
VALUE ossl_x509crl_new(X509_CRL *crl)