13 #define WrapX509CRL(klass, obj, crl) do { \
15 ossl_raise(rb_eRuntimeError, "CRL wasn't initialized!"); \
17 (obj) = Data_Wrap_Struct((klass), 0, X509_CRL_free, (crl)); \
19 #define GetX509CRL(obj, crl) do { \
20 Data_Get_Struct((obj), X509_CRL, (crl)); \
22 ossl_raise(rb_eRuntimeError, "CRL wasn't initialized!"); \
25 #define SafeGetX509CRL(obj, crl) do { \
26 OSSL_Check_Kind((obj), cX509CRL); \
27 GetX509CRL((obj), (crl)); \
55 CRYPTO_add(&crl->references, 1, CRYPTO_LOCK_X509_CRL);
66 tmp = crl ? X509_CRL_dup(crl) : X509_CRL_new();
82 if (!(crl = X509_CRL_new())) {
102 crl = PEM_read_bio_X509_CRL(in, &x,
NULL,
NULL);
106 crl = d2i_X509_CRL_bio(in, &x);
118 X509_CRL *a, *b, *crl;
121 if (
self == other)
return self;
124 if (!(crl = X509_CRL_dup(b))) {
140 ver = X509_CRL_get_version(crl);
151 if ((ver =
NUM2LONG(version)) < 0) {
171 if (!(out = BIO_new(BIO_s_mem()))) {
174 if (!i2a_ASN1_OBJECT(out, crl->sig_alg->algorithm)) {
178 BIO_get_mem_ptr(out, &buf);
225 if (!X509_time_adj(crl->crl->lastUpdate, 0, &sec)) {
251 if (!(crl->crl->nextUpdate = X509_time_adj(crl->crl->nextUpdate, 0, &sec))){
267 num = sk_X509_REVOKED_num(X509_CRL_get_REVOKED(crl));
273 for(i=0; i<num; i++) {
275 rev = sk_X509_REVOKED_value(X509_CRL_get_REVOKED(crl), i);
296 sk_X509_REVOKED_pop_free(crl->crl->revoked, X509_REVOKED_free);
297 crl->crl->revoked =
NULL;
335 if (!X509_CRL_sign(crl, pkey, md)) {
349 if ((ret = X509_CRL_verify(crl,
GetPKeyPtr(key))) < 0) {
368 if (!(out = BIO_new(BIO_s_mem()))) {
371 if (!i2d_X509_CRL_bio(out, crl)) {
375 BIO_get_mem_ptr(out, &buf);
391 if (!(out = BIO_new(BIO_s_mem()))) {
394 if (!PEM_write_bio_X509_CRL(out, crl)) {
398 BIO_get_mem_ptr(out, &buf);
414 if (!(out = BIO_new(BIO_s_mem()))) {
417 if (!X509_CRL_print(out, crl)) {
421 BIO_get_mem_ptr(out, &buf);
440 count = X509_CRL_get_ext_count(crl);
446 for (i=0; i<
count; i++) {
447 ext = X509_CRL_get_ext(crl, i);
470 sk_X509_EXTENSION_pop_free(crl->crl->extensions, X509_EXTENSION_free);
471 crl->crl->extensions =
NULL;
474 if(!X509_CRL_add_ext(crl, ext, -1)) {
475 X509_EXTENSION_free(ext);
478 X509_EXTENSION_free(ext);
492 if (!X509_CRL_add_ext(crl, ext, -1)) {
493 X509_EXTENSION_free(ext);
496 X509_EXTENSION_free(ext);
static VALUE ossl_x509crl_add_revoked(VALUE self, VALUE revoked)
static VALUE ossl_x509crl_set_revoked(VALUE self, VALUE ary)
EVP_PKEY * GetPrivPKeyPtr(VALUE obj)
X509_CRL * DupX509CRLPtr(VALUE obj)
VALUE rb_ary_push(VALUE ary, VALUE item)
static VALUE ossl_x509crl_copy(VALUE self, VALUE other)
static VALUE ossl_x509crl_alloc(VALUE klass)
VALUE rb_define_class_under(VALUE outer, const char *name, VALUE super)
Defines a class under the namespace of outer.
static VALUE ossl_x509crl_sign(VALUE self, VALUE key, VALUE digest)
static VALUE ossl_x509crl_get_signature_algorithm(VALUE self)
void rb_define_alloc_func(VALUE, rb_alloc_func_t)
#define SafeGetX509CRL(obj, crl)
VALUE asn1time_to_time(ASN1_TIME *time)
X509_EXTENSION * DupX509ExtPtr(VALUE)
X509_NAME * GetX509NamePtr(VALUE)
static VALUE ossl_x509crl_set_extensions(VALUE self, VALUE ary)
static VALUE ossl_x509crl_to_pem(VALUE self)
static VALUE ossl_x509crl_get_issuer(VALUE self)
static VALUE ossl_x509crl_set_issuer(VALUE self, VALUE issuer)
X509_REVOKED * DupX509RevokedPtr(VALUE)
time_t time_to_time_t(VALUE time)
static VALUE ossl_x509crl_get_extensions(VALUE self)
int X509_CRL_sort(X509_CRL *c)
#define rb_define_copy_func(klass, func)
#define GetX509CRL(obj, crl)
static VALUE ossl_x509crl_verify(VALUE self, VALUE key)
VALUE ossl_to_der_if_possible(VALUE obj)
static VALUE ossl_x509crl_get_next_update(VALUE self)
RUBY_EXTERN VALUE rb_cObject
#define OSSL_BIO_reset(bio)
static VALUE ossl_x509crl_initialize(int argc, VALUE *argv, VALUE self)
static VALUE ossl_x509crl_get_last_update(VALUE self)
#define WrapX509CRL(klass, obj, crl)
const EVP_MD * GetDigestPtr(VALUE obj)
VALUE ossl_x509ext_new(X509_EXTENSION *)
static VALUE ossl_x509crl_to_text(VALUE self)
int X509_CRL_set_issuer_name(X509_CRL *x, X509_NAME *name)
void rb_define_alias(VALUE klass, const char *name1, const char *name2)
Defines an alias of a method.
static VALUE ossl_x509crl_set_next_update(VALUE self, VALUE time)
BIO * ossl_obj2bio(VALUE obj)
static VALUE ossl_x509crl_get_version(VALUE self)
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
unsigned char buf[MIME_BUF_SIZE]
VALUE ossl_x509crl_new(X509_CRL *crl)
static VALUE ossl_x509crl_get_revoked(VALUE self)
VALUE ossl_x509revoked_new(X509_REVOKED *)
int X509_CRL_add0_revoked(X509_CRL *crl, X509_REVOKED *rev)
static VALUE ossl_x509crl_set_version(VALUE self, VALUE version)
#define OSSL_Check_Kind(obj, klass)
void ossl_raise(VALUE exc, const char *fmt,...)
EVP_PKEY * GetPKeyPtr(VALUE obj)
VALUE rb_ary_new2(long capa)
static VALUE ossl_x509crl_to_der(VALUE self)
VALUE ossl_x509name_new(X509_NAME *)
#define rb_check_frozen(obj)
static void version(void)
static VALUE ossl_x509crl_add_extension(VALUE self, VALUE extension)
X509_CRL * GetX509CRLPtr(VALUE obj)
int X509_CRL_set_version(X509_CRL *x, long version)
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
static VALUE ossl_x509crl_set_last_update(VALUE self, VALUE time)
VALUE rb_str_new(const char *, long)