Ruby 2.4
OpenSSL

OpenSSL::X509::ExtensionFactory

class OpenSSL::X509::ExtensionFactory

父类:Object

属性

configRW

crlR

issuer_certificateR

subject_certificateR

subject_requestR

公共类方法

新(p1 = v1,p2 = v2,p3 = v3,p4 = v4)显示源

static VALUE ossl_x509extfactory_initialize(int argc, VALUE *argv, VALUE self) { /*X509V3_CTX *ctx;*/ VALUE issuer_cert, subject_cert, subject_req, crl; /*GetX509ExtFactory(self, ctx*/ rb_scan_args(argc, argv, "04", &issuer_cert, &subject_cert, &subject_req, &crl if (!NIL_P(issuer_cert)) ossl_x509extfactory_set_issuer_cert(self, issuer_cert if (!NIL_P(subject_cert)) ossl_x509extfactory_set_subject_cert(self, subject_cert if (!NIL_P(subject_req)) ossl_x509extfactory_set_subject_req(self, subject_req if (!NIL_P(crl)) ossl_x509extfactory_set_crl(self, crl return self; }

公共实例方法

create_ext(ln_or_sn,“value”,critical = false)→X509 ::扩展显示源

create_ext(ln_or_sn,“critical,value”)→X509 :: Extension

用传递的值创建一个新的X509 ::扩展。另请参见x509v3_config(5)。

static VALUE ossl_x509extfactory_create_ext(int argc, VALUE *argv, VALUE self) { X509V3_CTX *ctx; X509_EXTENSION *ext; VALUE oid, value, critical, valstr, obj; int nid; VALUE rconf; CONF *conf; rb_scan_args(argc, argv, "21", &oid, &value, &critical StringValueCStr(oid StringValue(value if(NIL_P(critical)) critical = Qfalse; nid = OBJ_ln2nid(RSTRING_PTR(oid) if(!nid) nid = OBJ_sn2nid(RSTRING_PTR(oid) if(!nid) ossl_raise(eX509ExtError, "unknown OID `%"PRIsVALUE"'", oid valstr = rb_str_new2(RTEST(critical) ? "critical," : "" rb_str_append(valstr, value StringValueCStr(valstr GetX509ExtFactory(self, ctx obj = NewX509Ext(cX509Ext rconf = rb_iv_get(self, "@config" conf = NIL_P(rconf) ? NULL : DupConfigPtr(rconf X509V3_set_nconf(ctx, conf ext = X509V3_EXT_nconf_nid(conf, ctx, nid, RSTRING_PTR(valstr) X509V3_set_ctx_nodb(ctx NCONF_free(conf if (!ext){ ossl_raise(eX509ExtError, "%"PRIsVALUE" = %"PRIsVALUE, oid, valstr } SetX509Ext(obj, ext return obj; }

create_ext_from_array(ary)显示源文件

# File ext/openssl/lib/openssl/x509.rb, line 25 def create_ext_from_array(ary) raise ExtensionError, "unexpected array form" if ary.size > 3 create_ext(ary[0], ary[1], ary[2]) end

create_ext_from_hash(哈希)显示源文件

# File ext/openssl/lib/openssl/x509.rb, line 37 def create_ext_from_hash(hash) create_ext(hash["oid"], hash["value"], hash["critical"]) end

create_ext_from_string(str)显示源文件

# File ext/openssl/lib/openssl/x509.rb, line 30 def create_ext_from_string(str) # "oid = critical, value" oid, value = str.split(/=/, 2) oid.strip! value.strip! create_ext(oid, value) end

create_extension(* arg)显示源文件

# File ext/openssl/lib/openssl/x509.rb, line 17 def create_extension(*arg) if arg.size > 1 create_ext(*arg) else send("create_ext_from_"+arg[0].class.name.downcase, arg[0]) end end

crl =(p1)显示源文件

static VALUE ossl_x509extfactory_set_crl(VALUE self, VALUE crl) { X509V3_CTX *ctx; GetX509ExtFactory(self, ctx rb_iv_set(self, "@crl", crl ctx->crl = GetX509CRLPtr(crl /* NO DUP NEEDED */ return crl; }

issuer_certificate =(p1)显示源

static VALUE ossl_x509extfactory_set_issuer_cert(VALUE self, VALUE cert) { X509V3_CTX *ctx; GetX509ExtFactory(self, ctx rb_iv_set(self, "@issuer_certificate", cert ctx->issuer_cert = GetX509CertPtr(cert /* NO DUP NEEDED */ return cert; }

subject_certificate =(p1)显示来源

static VALUE ossl_x509extfactory_set_subject_cert(VALUE self, VALUE cert) { X509V3_CTX *ctx; GetX509ExtFactory(self, ctx rb_iv_set(self, "@subject_certificate", cert ctx->subject_cert = GetX509CertPtr(cert /* NO DUP NEEDED */ return cert; }

subject_request =(p1)显示源

static VALUE ossl_x509extfactory_set_subject_req(VALUE self, VALUE req) { X509V3_CTX *ctx; GetX509ExtFactory(self, ctx rb_iv_set(self, "@subject_request", req ctx->subject_req = GetX509ReqPtr(req /* NO DUP NEEDED */ return req; }