003 File Manager
Current Path:
/usr/src/crypto/openssl/crypto/x509v3
usr
/
src
/
crypto
/
openssl
/
crypto
/
x509v3
/
📁
..
📄
build.info
(444 B)
📄
ext_dat.h
(1.31 KB)
📄
pcy_cache.c
(6.23 KB)
📄
pcy_data.c
(2.27 KB)
📄
pcy_lib.c
(2.71 KB)
📄
pcy_local.h
(4.96 KB)
📄
pcy_map.c
(2.58 KB)
📄
pcy_node.c
(4.06 KB)
📄
pcy_tree.c
(21.88 KB)
📄
standard_exts.h
(1.64 KB)
📄
v3_addr.c
(40.39 KB)
📄
v3_admis.c
(11.58 KB)
📄
v3_admis.h
(1.12 KB)
📄
v3_akey.c
(6.04 KB)
📄
v3_akeya.c
(814 B)
📄
v3_alt.c
(17.3 KB)
📄
v3_asid.c
(26.45 KB)
📄
v3_bcons.c
(2.92 KB)
📄
v3_bitst.c
(3.1 KB)
📄
v3_conf.c
(14.99 KB)
📄
v3_cpols.c
(16.1 KB)
📄
v3_crld.c
(15.07 KB)
📄
v3_enum.c
(1.79 KB)
📄
v3_extku.c
(3.24 KB)
📄
v3_genn.c
(6.33 KB)
📄
v3_ia5.c
(1.93 KB)
📄
v3_info.c
(5.51 KB)
📄
v3_int.c
(1.14 KB)
📄
v3_lib.c
(8.24 KB)
📄
v3_ncons.c
(21.3 KB)
📄
v3_pci.c
(11.5 KB)
📄
v3_pcia.c
(2.62 KB)
📄
v3_pcons.c
(3.2 KB)
📄
v3_pku.c
(1.68 KB)
📄
v3_pmaps.c
(3.75 KB)
📄
v3_prn.c
(5.9 KB)
📄
v3_purp.c
(29.85 KB)
📄
v3_skey.c
(2.81 KB)
📄
v3_sxnet.c
(5.99 KB)
📄
v3_tlsf.c
(4.29 KB)
📄
v3_utl.c
(35.68 KB)
📄
v3err.c
(12.34 KB)
Editing: pcy_local.h
/* * Copyright 2004-2016 The OpenSSL Project Authors. All Rights Reserved. * * Licensed under the OpenSSL license (the "License"). You may not use * this file except in compliance with the License. You can obtain a copy * in the file LICENSE in the source distribution or at * https://www.openssl.org/source/license.html */ typedef struct X509_POLICY_DATA_st X509_POLICY_DATA; DEFINE_STACK_OF(X509_POLICY_DATA) /* Internal structures */ /* * This structure and the field names correspond to the Policy 'node' of * RFC3280. NB this structure contains no pointers to parent or child data: * X509_POLICY_NODE contains that. This means that the main policy data can * be kept static and cached with the certificate. */ struct X509_POLICY_DATA_st { unsigned int flags; /* Policy OID and qualifiers for this data */ ASN1_OBJECT *valid_policy; STACK_OF(POLICYQUALINFO) *qualifier_set; STACK_OF(ASN1_OBJECT) *expected_policy_set; }; /* X509_POLICY_DATA flags values */ /* * This flag indicates the structure has been mapped using a policy mapping * extension. If policy mapping is not active its references get deleted. */ #define POLICY_DATA_FLAG_MAPPED 0x1 /* * This flag indicates the data doesn't correspond to a policy in Certificate * Policies: it has been mapped to any policy. */ #define POLICY_DATA_FLAG_MAPPED_ANY 0x2 /* AND with flags to see if any mapping has occurred */ #define POLICY_DATA_FLAG_MAP_MASK 0x3 /* qualifiers are shared and shouldn't be freed */ #define POLICY_DATA_FLAG_SHARED_QUALIFIERS 0x4 /* Parent node is an extra node and should be freed */ #define POLICY_DATA_FLAG_EXTRA_NODE 0x8 /* Corresponding CertificatePolicies is critical */ #define POLICY_DATA_FLAG_CRITICAL 0x10 /* This structure is cached with a certificate */ struct X509_POLICY_CACHE_st { /* anyPolicy data or NULL if no anyPolicy */ X509_POLICY_DATA *anyPolicy; /* other policy data */ STACK_OF(X509_POLICY_DATA) *data; /* If InhibitAnyPolicy present this is its value or -1 if absent. */ long any_skip; /* * If policyConstraints and requireExplicitPolicy present this is its * value or -1 if absent. */ long explicit_skip; /* * If policyConstraints and policyMapping present this is its value or -1 * if absent. */ long map_skip; }; /* * #define POLICY_CACHE_FLAG_CRITICAL POLICY_DATA_FLAG_CRITICAL */ /* This structure represents the relationship between nodes */ struct X509_POLICY_NODE_st { /* node data this refers to */ const X509_POLICY_DATA *data; /* Parent node */ X509_POLICY_NODE *parent; /* Number of child nodes */ int nchild; }; struct X509_POLICY_LEVEL_st { /* Cert for this level */ X509 *cert; /* nodes at this level */ STACK_OF(X509_POLICY_NODE) *nodes; /* anyPolicy node */ X509_POLICY_NODE *anyPolicy; /* Extra data */ /* * STACK_OF(X509_POLICY_DATA) *extra_data; */ unsigned int flags; }; struct X509_POLICY_TREE_st { /* This is the tree 'level' data */ X509_POLICY_LEVEL *levels; int nlevel; /* * Extra policy data when additional nodes (not from the certificate) are * required. */ STACK_OF(X509_POLICY_DATA) *extra_data; /* This is the authority constrained policy set */ STACK_OF(X509_POLICY_NODE) *auth_policies; STACK_OF(X509_POLICY_NODE) *user_policies; unsigned int flags; }; /* Set if anyPolicy present in user policies */ #define POLICY_FLAG_ANY_POLICY 0x2 /* Useful macros */ #define node_data_critical(data) (data->flags & POLICY_DATA_FLAG_CRITICAL) #define node_critical(node) node_data_critical(node->data) /* Internal functions */ X509_POLICY_DATA *policy_data_new(POLICYINFO *policy, const ASN1_OBJECT *id, int crit); void policy_data_free(X509_POLICY_DATA *data); X509_POLICY_DATA *policy_cache_find_data(const X509_POLICY_CACHE *cache, const ASN1_OBJECT *id); int policy_cache_set_mapping(X509 *x, POLICY_MAPPINGS *maps); STACK_OF(X509_POLICY_NODE) *policy_node_cmp_new(void); void policy_cache_init(void); void policy_cache_free(X509_POLICY_CACHE *cache); X509_POLICY_NODE *level_find_node(const X509_POLICY_LEVEL *level, const X509_POLICY_NODE *parent, const ASN1_OBJECT *id); X509_POLICY_NODE *tree_find_sk(STACK_OF(X509_POLICY_NODE) *sk, const ASN1_OBJECT *id); X509_POLICY_NODE *level_add_node(X509_POLICY_LEVEL *level, X509_POLICY_DATA *data, X509_POLICY_NODE *parent, X509_POLICY_TREE *tree); void policy_node_free(X509_POLICY_NODE *node); int policy_node_match(const X509_POLICY_LEVEL *lvl, const X509_POLICY_NODE *node, const ASN1_OBJECT *oid); const X509_POLICY_CACHE *policy_cache_set(X509 *x);
Upload File
Create Folder