From bedd2e7ccb1595c23e159eaa952ae1b0b5a3d2ad Mon Sep 17 00:00:00 2001 From: Simon Rettberg Date: Sat, 15 Mar 2014 01:49:50 +0100 Subject: Lean and mean initial commit Not much functionality yet --- asn1oid.c | 100 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 asn1oid.c (limited to 'asn1oid.c') diff --git a/asn1oid.c b/asn1oid.c new file mode 100644 index 0000000..fa1242e --- /dev/null +++ b/asn1oid.c @@ -0,0 +1,100 @@ +#include +#include "asn1.h" + +#define ENTRY(a,b,c) { sizeof(a)-1, a, b, c } + +const struct oidlookup oid2string[] = { + + /* naming attribute OIDs */ + ENTRY("\x55\x04\x03", "commonName", X509_ATTR_COMMONNAME), + ENTRY("\x55\x04\x04", "surname", X509_ATTR_SURNAME), + ENTRY("\x55\x04\x05", "serialNumber", X509_ATTR_SERIALNUMBER), + ENTRY("\x55\x04\x06", "countryName", X509_ATTR_COUNTRY), + ENTRY("\x55\x04\x07", "localityName", X509_ATTR_LOCALITY), + ENTRY("\x55\x04\x08", "stateOrProvinceName", X509_ATTR_STATEPROVINCE), + ENTRY("\x55\x04\x09", "street", X509_ATTR_STREET), + ENTRY("\x55\x04\x0a", "organizationName", X509_ATTR_ORG), + ENTRY("\x55\x04\x0b", "organizationalUnitName", X509_ATTR_ORGUNIT), + ENTRY("\x55\x04\x0c", "title", X509_ATTR_TITLE), + ENTRY("\x55\x04\x0d", "description", X509_ATTR_DESC), + ENTRY("\x55\x04\x2a", "givenName", X509_ATTR_GIVENNAME), + ENTRY("\x55\x04\x2b", "initials", X509_ATTR_INITIALS), + ENTRY("\x55\x04\x2c", "generationQualifier", X509_ATTR_GENERATIONQUALIFIER), + ENTRY("\x55\x04\x2d", "uniqueIdentifier", X509_ATTR_UNIQID), + ENTRY("\x55\x04\x2e", "dnQualifier", X509_ATTR_DNQUALIFIER), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x09\x01", "emailAddress", X509_ATTR_EMAIL), + + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x07\x02", "signedData", X509_SIGNEDDATA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x07\x01", "data", X509_DATA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x09\x03", "contentType", X509_CONTENTTYPE), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x09\x04", "messageDigest", X509_MESSAGEDIGEST), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x09\x05", "signingTime", X509_SIGNINGTIME), + ENTRY("\x60\x86\x48\x01\x86\xf8\x42\x01\x01", "netscapeCertType", X509_NETSCAPE_CERTTYPE), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x09\x0f", "smimeCapabilities", X509_SMIME_CAPABILITIES), + + /* X.509v3 extension OIDs */ + ENTRY("\x55\x1d\x0e", "subject_key_identifier", X509_EXT_SUBJKEYID), + ENTRY("\x55\x1d\x0f", "key_usage", X509_EXT_KEYUSAGE), + ENTRY("\x55\x1d\x10", "private_key_usage_period", X509_EXT_PRIVKEYUSAGEPERIOD), + ENTRY("\x55\x1d\x11", "subject_alt_name", X509_EXT_SUBJALTNAME), + ENTRY("\x55\x1d\x12", "issuer_alt_name", X509_EXT_ISSUERALTNAME), + ENTRY("\x55\x1d\x13", "basic_constraints", X509_EXT_BASICCONSTRAINTS), + ENTRY("\x55\x1d\x14", "crl_number", X509_EXT_CRL_NUMBER), + ENTRY("\x55\x1d\x15", "reasonCode", X509_EXT_REASONCODE), + ENTRY("\x55\x1d\x17", "instruction_code", X509_EXT_INSTRUCTIONCODE), + ENTRY("\x55\x1d\x18", "invalidity_date", X509_EXT_INVALIDITYDATE), + ENTRY("\x55\x1d\x1b", "delta_crl_indicator", X509_EXT_DELTA_CRL_INDICATOR), + ENTRY("\x55\x1d\x1c", "issuing_distribution_point", X509_EXT_ISSUING_DISTRIBUTION_POINT), + ENTRY("\x55\x1d\x1e", "name_constraints", X509_EXT_NAME_CONSTRAINTS), + ENTRY("\x55\x1d\x1f", "crl_distribution_points", X509_EXT_CRL_DISTRIBUTION_POINTS), + ENTRY("\x55\x1d\x20", "certificate_policies", X509_EXT_CERT_POLICIES), + ENTRY("\x55\x1d\x23", "authority_key_identifier", X509_EXT_AUTH_KEY_ID), + ENTRY("\x55\x1d\x25", "ext_key_usage", X509_EXT_KEY_USAGE), + + /* X.509 algorithms */ + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x01", "rsaEncryption", X509_ALG_RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x02", "md2WithRSAEncryption", X509_ALG_MD2RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x03", "md4WithRSAEncryption", X509_ALG_MD4RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x04", "md5WithRSAEncryption", X509_ALG_MD5RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x05", "sha1WithRSAEncryption", X509_ALG_SHA1RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x0b", "sha256WithRSAEncryption", X509_ALG_SHA256RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x0c", "sha384WithRSAEncryption", X509_ALG_SHA384RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x0d", "sha512WithRSAEncryption", X509_ALG_SHA512RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x01\x01\x0e", "sha224WithRSAEncryption", X509_ALG_SHA224RSA), + ENTRY("\x2b\x0e\x03\x02\x03", "md5WithRSA", X509_ALG_MD5RSA), + ENTRY("\x2b\x0e\x03\x02\x06", "des_ecb", X509_ALG_DES_ECB), + ENTRY("\x2b\x0e\x03\x02\x07", "des_cbc", X509_ALG_DES_CBC), + ENTRY("\x2b\x0e\x03\x02\x08", "des_ofb64", X509_ALG_DES_OFB64), + ENTRY("\x2b\x0e\x03\x02\x08", "des_cfb64", X509_ALG_DES_CFB64), + ENTRY("\x2b\x0e\x03\x02\x0b", "rsaSignature", X509_ALG_RSASIGNATURE), + ENTRY("\x2b\x0e\x03\x02\x0c", "dsa_2", X509_ALG_DSA_2), + ENTRY("\x2b\x0e\x03\x02\x0d", "dsaWithSha", X509_ALG_DSASHA), + ENTRY("\x2b\x0e\x03\x02\x0f", "shaWithRSA", X509_ALG_SHARSA), + ENTRY("\x2b\x0e\x03\x02\x11", "des_ede_ecb", X509_ALG_DES_EDE_ECB), + ENTRY("\x2b\x0e\x03\x02\x12", "sha", X509_ALG_SHA), + ENTRY("\x2b\x0e\x03\x02\x1a", "sha1", X509_ALG_SHA1), + ENTRY("\x2b\x0e\x03\x02\x1b", "dsaWithSHA1_2", X509_ALG_DSASHA1_2), + ENTRY("\x2b\x0e\x03\x02\x1d", "sha1WithRSA", X509_ALG_SHA1RSA), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x02\x04", "md4", X509_ALG_MD4), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x02\x05", "md5", X509_ALG_MD5), + ENTRY("\x2b\x24\x03\x02\x01", "ripemd", X509_ALG_RIPEMD), + ENTRY("\x60\x86\x48\x01\x65\x03\x04\x01\x2a", "aes256_cbc", X509_ALG_AES256_CBC), + ENTRY("\x2a\x85\x03\x02\x02\x09", "GOST R 34.11-94", X509_ALG_GOSTR3411_94), + ENTRY("\x2a\x85\x03\x02\x02\x15", "GOST 28147-89", X509_ALG_GOST28147_89), + ENTRY("\x60\x86\x48\x01\x65\x03\x04\x01\x16", "aes192_cbc", X509_ALG_AES192_CBC), + ENTRY("\x60\x86\x48\x01\x65\x03\x04\x01\x02", "aes128_cbc", X509_ALG_AES128_CBC), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x03\x07", "des_ede3_cbc", X509_ALG_DES_EDE3_CBC), + ENTRY("\x2a\x86\x48\x86\xf7\x0d\x03\x02", "rc2_cbc", X509_ALG_RC2_CBC), + +}; + +#undef ENTRY + +size_t lookupoid(const char* oid,size_t l) { + size_t i; + for (i=0; i