Coverage Report

Created: 2025-12-10 06:24

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/crypto/x509/v3_usernotice.c
Line
Count
Source
1
/*
2
 * Copyright 1999-2024 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the "License").  You may not use
5
 * this file except in compliance with the License.  You can obtain a copy
6
 * in the file LICENSE in the source distribution or at
7
 * https://www.openssl.org/source/license.html
8
 */
9
10
#include <openssl/asn1t.h>
11
#include <openssl/x509v3.h>
12
#include "ext_dat.h"
13
14
ASN1_ITEM_TEMPLATE(OSSL_USER_NOTICE_SYNTAX) = ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_USER_NOTICE_SYNTAX, USERNOTICE)
15
0
ASN1_ITEM_TEMPLATE_END(OSSL_USER_NOTICE_SYNTAX)
16
17
IMPLEMENT_ASN1_FUNCTIONS(OSSL_USER_NOTICE_SYNTAX)
18
19
static int print_notice(BIO *out, USERNOTICE *notice, int indent)
20
0
{
21
0
    int i;
22
0
    ASN1_INTEGER *num;
23
0
    char *tmp;
24
25
0
    if (notice->noticeref) {
26
0
        NOTICEREF *ref;
27
0
        ref = notice->noticeref;
28
0
        if (BIO_printf(out, "%*sOrganization: %.*s\n", indent, "",
29
0
                ref->organization->length,
30
0
                ref->organization->data)
31
0
            <= 0)
32
0
            return 0;
33
0
        if (BIO_printf(out, "%*sNumber%s: ", indent, "",
34
0
                sk_ASN1_INTEGER_num(ref->noticenos) > 1 ? "s" : "")
35
0
            <= 0)
36
0
            return 0;
37
0
        for (i = 0; i < sk_ASN1_INTEGER_num(ref->noticenos); i++) {
38
0
            num = sk_ASN1_INTEGER_value(ref->noticenos, i);
39
0
            if (i && BIO_puts(out, ", ") <= 0)
40
0
                return 0;
41
0
            if (num == NULL && BIO_puts(out, "(null)") <= 0)
42
0
                return 0;
43
0
            else {
44
0
                tmp = i2s_ASN1_INTEGER(NULL, num);
45
0
                if (tmp == NULL)
46
0
                    return 0;
47
0
                if (BIO_puts(out, tmp) <= 0) {
48
0
                    OPENSSL_free(tmp);
49
0
                    return 0;
50
0
                }
51
0
                OPENSSL_free(tmp);
52
0
            }
53
0
        }
54
0
        if (notice->exptext && BIO_puts(out, "\n") <= 0)
55
0
            return 0;
56
0
    }
57
0
    if (notice->exptext == NULL)
58
0
        return 1;
59
60
0
    return BIO_printf(out, "%*sExplicit Text: %.*s", indent, "",
61
0
               notice->exptext->length,
62
0
               notice->exptext->data)
63
0
        >= 0;
64
0
}
65
66
static int i2r_USER_NOTICE_SYNTAX(X509V3_EXT_METHOD *method,
67
    OSSL_USER_NOTICE_SYNTAX *uns,
68
    BIO *out, int indent)
69
0
{
70
0
    int i;
71
0
    USERNOTICE *unotice;
72
73
0
    if (BIO_printf(out, "%*sUser Notices:\n", indent, "") <= 0)
74
0
        return 0;
75
76
0
    for (i = 0; i < sk_USERNOTICE_num(uns); i++) {
77
0
        unotice = sk_USERNOTICE_value(uns, i);
78
0
        if (!print_notice(out, unotice, indent + 4))
79
0
            return 0;
80
0
        if (BIO_puts(out, "\n\n") <= 0)
81
0
            return 0;
82
0
    }
83
0
    return 1;
84
0
}
85
86
const X509V3_EXT_METHOD ossl_v3_user_notice = {
87
    NID_user_notice, 0,
88
    ASN1_ITEM_ref(OSSL_USER_NOTICE_SYNTAX),
89
    0, 0, 0, 0,
90
    0,
91
    0,
92
    0, 0,
93
    (X509V3_EXT_I2R)i2r_USER_NOTICE_SYNTAX,
94
    0,
95
    NULL
96
};