mirror of
https://github.com/guanzhi/GmSSL.git
synced 2026-05-07 00:46:17 +08:00
Update X509
This commit is contained in:
111
src/x509_ext.c
111
src/x509_ext.c
@@ -632,6 +632,41 @@ err:
|
||||
return -1;
|
||||
}
|
||||
|
||||
int x509_explicit_directory_name_to_der(int index, int tag, const uint8_t *d, size_t dlen, uint8_t **out, size_t *outlen)
|
||||
{
|
||||
int ret;
|
||||
size_t len = 0;
|
||||
|
||||
if ((ret = x509_directory_name_to_der(tag, d, dlen, NULL, &len)) != 1) {
|
||||
if (ret < 0) error_print();
|
||||
return ret;
|
||||
}
|
||||
if (asn1_explicit_header_to_der(index, len, out, outlen) != 1
|
||||
|| x509_directory_name_to_der(tag, d, dlen, out, outlen) != 1) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_explicit_directory_name_from_der(int index, int *tag, const uint8_t **d, size_t *dlen, const uint8_t **in, size_t *inlen)
|
||||
{
|
||||
int ret;
|
||||
const uint8_t *p;
|
||||
size_t len;
|
||||
|
||||
if ((ret = asn1_explicit_from_der(index, &p, &len, in, inlen)) != 1) {
|
||||
if (ret < 0) error_print();
|
||||
return ret;
|
||||
}
|
||||
if (x509_directory_name_from_der(tag, d, dlen, &p, &len) != 1
|
||||
|| asn1_length_is_zero(len) != 1) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_edi_party_name_to_der(
|
||||
int assigner_choice, const uint8_t *assigner, size_t assigner_len,
|
||||
int party_name_choice, const uint8_t *party_name, size_t party_name_len,
|
||||
@@ -1174,6 +1209,82 @@ int x509_key_usage_print(FILE *fp, int fmt, int ind, const char *label, int bits
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_display_text_check(int tag, const uint8_t *d, size_t dlen)
|
||||
{
|
||||
switch (tag) {
|
||||
case ASN1_TAG_IA5String:
|
||||
case ASN1_TAG_VisibleString:
|
||||
case ASN1_TAG_UTF8String:
|
||||
if (d && strnlen((char *)d, dlen) != dlen) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
case ASN1_TAG_BMPString:
|
||||
if (d && dlen % 2) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
if (dlen < X509_DISPLAY_TEXT_MIN_LEN || dlen > X509_DISPLAY_TEXT_MAX_LEN) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_display_text_to_der(int tag, const uint8_t *d, size_t dlen, uint8_t **out, size_t *outlen)
|
||||
{
|
||||
int ret;
|
||||
if (x509_display_text_check(tag, d, dlen) != 1) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
if ((ret = asn1_type_to_der(tag, d, dlen, out, outlen)) != 1) {
|
||||
if (ret < 0) error_print();
|
||||
return ret;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_display_text_from_der(int *tag, const uint8_t **d, size_t *dlen, const uint8_t **in, size_t *inlen)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if ((ret = asn1_tag_from_der_readonly(tag, in, inlen)) != 1) {
|
||||
if (ret < 0) error_print();
|
||||
return ret;
|
||||
}
|
||||
switch (*tag) {
|
||||
case ASN1_TAG_IA5String:
|
||||
case ASN1_TAG_VisibleString:
|
||||
case ASN1_TAG_UTF8String:
|
||||
case ASN1_TAG_BMPString:
|
||||
break;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((ret = asn1_any_type_from_der(tag, d, dlen, in, inlen)) != 1) {
|
||||
if (ret < 0) error_print();
|
||||
return ret;
|
||||
}
|
||||
if (x509_display_text_check(*tag, *d, *dlen) != 1) {
|
||||
error_print();
|
||||
return -1;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int x509_display_text_print(FILE *fp, int fmt, int ind, const char *label, int tag, const uint8_t *d, size_t dlen)
|
||||
{
|
||||
return asn1_string_print(fp, fmt, ind, label, tag, d, dlen);
|
||||
}
|
||||
|
||||
int x509_notice_reference_to_der(
|
||||
int org_tag, const uint8_t *org, size_t org_len,
|
||||
const int *notice_numbers, size_t notice_numbers_cnt,
|
||||
|
||||
Reference in New Issue
Block a user