1. OpenSSL::
  2. X509::
  3. Revoked

class OpenSSL::X509::Revoked

Public Class Methods

Source
static VALUEossl_x509revoked_initialize(int argc, VALUE *argv, VALUE self){    /* EMPTY */    return self;}

Public Instance Methods

Source
# File ext/openssl/lib/openssl/x509.rb, line 385def==(other)returnfalseunlessRevoked===otherto_der==other.to_derend
Source
static VALUEossl_x509revoked_add_extension(VALUE self, VALUE ext){    X509_REVOKED *rev;    GetX509Rev(self, rev);    if (!X509_REVOKED_add_ext(rev, GetX509ExtPtr(ext), -1)) {        ossl_raise(eX509RevError, NULL);    }    return ext;}
Source
static VALUEossl_x509revoked_get_extensions(VALUE self){    X509_REVOKED *rev;    int count, i;    X509_EXTENSION *ext;    VALUE ary;    GetX509Rev(self, rev);    count = X509_REVOKED_get_ext_count(rev);    ary = rb_ary_new_capa(count);    for (i=0; i<count; i++) {        ext = X509_REVOKED_get_ext(rev, i);        rb_ary_push(ary, ossl_x509ext_new(ext));    }    return ary;}

Gets X509v3 extensions as array of X509Ext objects

Source
static VALUEossl_x509revoked_set_extensions(VALUE self, VALUE ary){    X509_REVOKED *rev;    X509_EXTENSION *ext;    long i;    VALUE item;    Check_Type(ary, T_ARRAY);    for (i=0; i<RARRAY_LEN(ary); i++) {        OSSL_Check_Kind(RARRAY_AREF(ary, i), cX509Ext);    }    GetX509Rev(self, rev);    for (i = X509_REVOKED_get_ext_count(rev); i > 0; i--)        X509_EXTENSION_free(X509_REVOKED_delete_ext(rev, 0));    for (i=0; i<RARRAY_LEN(ary); i++) {        item = RARRAY_AREF(ary, i);        ext = GetX509ExtPtr(item);        if(!X509_REVOKED_add_ext(rev, ext, -1)) {            ossl_raise(eX509RevError, "X509_REVOKED_add_ext");        }    }    return ary;}

Sets X509_EXTENSIONs

Source
static VALUEossl_x509revoked_get_serial(VALUE self){    X509_REVOKED *rev;    GetX509Rev(self, rev);    return asn1integer_to_num(X509_REVOKED_get0_serialNumber(rev));}
Source
static VALUEossl_x509revoked_set_serial(VALUE self, VALUE num){    X509_REVOKED *rev;    ASN1_INTEGER *asn1int;    GetX509Rev(self, rev);    asn1int = num_to_asn1integer(num, NULL);    if (!X509_REVOKED_set_serialNumber(rev, asn1int)) {        ASN1_INTEGER_free(asn1int);        ossl_raise(eX509RevError, "X509_REVOKED_set_serialNumber");    }    ASN1_INTEGER_free(asn1int);    return num;}
Source
static VALUEossl_x509revoked_get_time(VALUE self){    X509_REVOKED *rev;    const ASN1_TIME *time;    GetX509Rev(self, rev);    time = X509_REVOKED_get0_revocationDate(rev);    if (!time)        return Qnil;    return asn1time_to_time(time);}
Source
static VALUEossl_x509revoked_set_time(VALUE self, VALUE time){    X509_REVOKED *rev;    ASN1_TIME *asn1time;    GetX509Rev(self, rev);    asn1time = ossl_x509_time_adjust(NULL, time);    if (!X509_REVOKED_set_revocationDate(rev, asn1time)) {        ASN1_TIME_free(asn1time);        ossl_raise(eX509RevError, "X509_REVOKED_set_revocationDate");    }    ASN1_TIME_free(asn1time);    return time;}
Source
static VALUEossl_x509revoked_to_der(VALUE self){    X509_REVOKED *rev;    VALUE str;    int len;    unsigned char *p;    GetX509Rev(self, rev);    len = i2d_X509_REVOKED(rev, NULL);    if (len <= 0)        ossl_raise(eX509RevError, "i2d_X509_REVOKED");    str = rb_str_new(NULL, len);    p = (unsigned char *)RSTRING_PTR(str);    if (i2d_X509_REVOKED(rev, &p) <= 0)        ossl_raise(eX509RevError, "i2d_X509_REVOKED");    ossl_str_adjust(str, p);    return str;}