Coverage Report

Created: 2025-11-16 06:40

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl30/crypto/cmp/cmp_asn.c
Line
Count
Source
1
/*
2
 * Copyright 2007-2023 The OpenSSL Project Authors. All Rights Reserved.
3
 * Copyright Nokia 2007-2019
4
 * Copyright Siemens AG 2015-2019
5
 *
6
 * Licensed under the Apache License 2.0 (the "License").  You may not use
7
 * this file except in compliance with the License.  You can obtain a copy
8
 * in the file LICENSE in the source distribution or at
9
 * https://www.openssl.org/source/license.html
10
 */
11
12
#include <openssl/asn1t.h>
13
14
#include "cmp_local.h"
15
16
/* explicit #includes not strictly needed since implied by the above: */
17
#include <openssl/cmp.h>
18
#include <openssl/crmf.h>
19
20
/* ASN.1 declarations from RFC4210 */
21
ASN1_SEQUENCE(OSSL_CMP_REVANNCONTENT) = {
22
    /* OSSL_CMP_PKISTATUS is effectively ASN1_INTEGER so it is used directly */
23
    ASN1_SIMPLE(OSSL_CMP_REVANNCONTENT, status, ASN1_INTEGER),
24
    ASN1_SIMPLE(OSSL_CMP_REVANNCONTENT, certId, OSSL_CRMF_CERTID),
25
    ASN1_SIMPLE(OSSL_CMP_REVANNCONTENT, willBeRevokedAt, ASN1_GENERALIZEDTIME),
26
    ASN1_SIMPLE(OSSL_CMP_REVANNCONTENT, badSinceDate, ASN1_GENERALIZEDTIME),
27
    ASN1_OPT(OSSL_CMP_REVANNCONTENT, crlDetails, X509_EXTENSIONS)
28
54
} ASN1_SEQUENCE_END(OSSL_CMP_REVANNCONTENT)
29
54
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_REVANNCONTENT)
30
54
31
54
32
54
ASN1_SEQUENCE(OSSL_CMP_CHALLENGE) = {
33
54
    ASN1_OPT(OSSL_CMP_CHALLENGE, owf, X509_ALGOR),
34
54
    ASN1_SIMPLE(OSSL_CMP_CHALLENGE, witness, ASN1_OCTET_STRING),
35
54
    ASN1_SIMPLE(OSSL_CMP_CHALLENGE, challenge, ASN1_OCTET_STRING)
36
5.19k
} ASN1_SEQUENCE_END(OSSL_CMP_CHALLENGE)
37
5.19k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CHALLENGE)
38
5.19k
39
5.19k
40
5.19k
ASN1_ITEM_TEMPLATE(OSSL_CMP_POPODECKEYCHALLCONTENT) =
41
5.19k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0,
42
5.19k
                          OSSL_CMP_POPODECKEYCHALLCONTENT, OSSL_CMP_CHALLENGE)
43
19.4k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_POPODECKEYCHALLCONTENT)
44
45
46
ASN1_ITEM_TEMPLATE(OSSL_CMP_POPODECKEYRESPCONTENT) =
47
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0,
48
                          OSSL_CMP_POPODECKEYRESPCONTENT, ASN1_INTEGER)
49
12.2k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_POPODECKEYRESPCONTENT)
50
51
52
ASN1_SEQUENCE(OSSL_CMP_CAKEYUPDANNCONTENT) = {
53
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
54
    ASN1_SIMPLE(OSSL_CMP_CAKEYUPDANNCONTENT, oldWithNew, X509),
55
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
56
    ASN1_SIMPLE(OSSL_CMP_CAKEYUPDANNCONTENT, newWithOld, X509),
57
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
58
    ASN1_SIMPLE(OSSL_CMP_CAKEYUPDANNCONTENT, newWithNew, X509)
59
554
} ASN1_SEQUENCE_END(OSSL_CMP_CAKEYUPDANNCONTENT)
60
554
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CAKEYUPDANNCONTENT)
61
554
62
554
63
554
ASN1_SEQUENCE(OSSL_CMP_ERRORMSGCONTENT) = {
64
554
    ASN1_SIMPLE(OSSL_CMP_ERRORMSGCONTENT, pKIStatusInfo, OSSL_CMP_PKISI),
65
554
    ASN1_OPT(OSSL_CMP_ERRORMSGCONTENT, errorCode, ASN1_INTEGER),
66
554
    /*
67
554
     * OSSL_CMP_PKIFREETEXT is effectively a sequence of ASN1_UTF8STRING
68
554
     * so it is used directly
69
554
     *
70
554
     */
71
554
    ASN1_SEQUENCE_OF_OPT(OSSL_CMP_ERRORMSGCONTENT, errorDetails,
72
554
                         ASN1_UTF8STRING)
73
84.3k
} ASN1_SEQUENCE_END(OSSL_CMP_ERRORMSGCONTENT)
74
84.3k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_ERRORMSGCONTENT)
75
84.3k
76
84.3k
ASN1_ADB_TEMPLATE(infotypeandvalue_default) = ASN1_OPT(OSSL_CMP_ITAV,
77
84.3k
                                                       infoValue.other,
78
84.3k
                                                       ASN1_ANY);
79
84.3k
/* ITAV means InfoTypeAndValue */
80
84.3k
ASN1_ADB(OSSL_CMP_ITAV) = {
81
84.3k
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
82
84.3k
    ADB_ENTRY(NID_id_it_caProtEncCert, ASN1_OPT(OSSL_CMP_ITAV,
83
84.3k
                                                infoValue.caProtEncCert, X509)),
84
84.3k
    ADB_ENTRY(NID_id_it_signKeyPairTypes,
85
84.3k
              ASN1_SEQUENCE_OF_OPT(OSSL_CMP_ITAV,
86
84.3k
                                   infoValue.signKeyPairTypes, X509_ALGOR)),
87
84.3k
    ADB_ENTRY(NID_id_it_encKeyPairTypes,
88
84.3k
              ASN1_SEQUENCE_OF_OPT(OSSL_CMP_ITAV,
89
84.3k
                                   infoValue.encKeyPairTypes, X509_ALGOR)),
90
84.3k
    ADB_ENTRY(NID_id_it_preferredSymmAlg,
91
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.preferredSymmAlg,
92
84.3k
                       X509_ALGOR)),
93
84.3k
    ADB_ENTRY(NID_id_it_caKeyUpdateInfo,
94
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.caKeyUpdateInfo,
95
84.3k
                       OSSL_CMP_CAKEYUPDANNCONTENT)),
96
84.3k
    ADB_ENTRY(NID_id_it_currentCRL,
97
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.currentCRL, X509_CRL)),
98
84.3k
    ADB_ENTRY(NID_id_it_unsupportedOIDs,
99
84.3k
              ASN1_SEQUENCE_OF_OPT(OSSL_CMP_ITAV,
100
84.3k
                                   infoValue.unsupportedOIDs, ASN1_OBJECT)),
101
84.3k
    ADB_ENTRY(NID_id_it_keyPairParamReq,
102
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.keyPairParamReq,
103
84.3k
                       ASN1_OBJECT)),
104
84.3k
    ADB_ENTRY(NID_id_it_keyPairParamRep,
105
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.keyPairParamRep,
106
84.3k
                       X509_ALGOR)),
107
84.3k
    ADB_ENTRY(NID_id_it_revPassphrase,
108
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.revPassphrase,
109
84.3k
                       OSSL_CRMF_ENCRYPTEDVALUE)),
110
84.3k
    ADB_ENTRY(NID_id_it_implicitConfirm,
111
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.implicitConfirm,
112
84.3k
                       ASN1_NULL)),
113
84.3k
    ADB_ENTRY(NID_id_it_confirmWaitTime,
114
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.confirmWaitTime,
115
84.3k
                       ASN1_GENERALIZEDTIME)),
116
84.3k
    ADB_ENTRY(NID_id_it_origPKIMessage,
117
84.3k
              ASN1_OPT(OSSL_CMP_ITAV, infoValue.origPKIMessage,
118
84.3k
                       OSSL_CMP_MSGS)),
119
84.3k
    ADB_ENTRY(NID_id_it_suppLangTags,
120
84.3k
              ASN1_SEQUENCE_OF_OPT(OSSL_CMP_ITAV, infoValue.suppLangTagsValue,
121
84.3k
                                   ASN1_UTF8STRING)),
122
731k
} ASN1_ADB_END(OSSL_CMP_ITAV, 0, infoType, 0,
123
               &infotypeandvalue_default_tt, NULL);
124
125
126
ASN1_SEQUENCE(OSSL_CMP_ITAV) = {
127
    ASN1_SIMPLE(OSSL_CMP_ITAV, infoType, ASN1_OBJECT),
128
    ASN1_ADB_OBJECT(OSSL_CMP_ITAV)
129
623k
} ASN1_SEQUENCE_END(OSSL_CMP_ITAV)
130
623k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_ITAV)
131
623k
IMPLEMENT_ASN1_DUP_FUNCTION(OSSL_CMP_ITAV)
132
623k
133
623k
OSSL_CMP_ITAV *OSSL_CMP_ITAV_create(ASN1_OBJECT *type, ASN1_TYPE *value)
134
623k
{
135
0
    OSSL_CMP_ITAV *itav;
136
137
0
    if (type == NULL || (itav = OSSL_CMP_ITAV_new()) == NULL)
138
0
        return NULL;
139
0
    OSSL_CMP_ITAV_set0(itav, type, value);
140
0
    return itav;
141
0
}
142
143
void OSSL_CMP_ITAV_set0(OSSL_CMP_ITAV *itav, ASN1_OBJECT *type,
144
                        ASN1_TYPE *value)
145
0
{
146
0
    itav->infoType = type;
147
0
    itav->infoValue.other = value;
148
0
}
149
150
ASN1_OBJECT *OSSL_CMP_ITAV_get0_type(const OSSL_CMP_ITAV *itav)
151
0
{
152
0
    if (itav == NULL)
153
0
        return NULL;
154
0
    return itav->infoType;
155
0
}
156
157
ASN1_TYPE *OSSL_CMP_ITAV_get0_value(const OSSL_CMP_ITAV *itav)
158
0
{
159
0
    if (itav == NULL)
160
0
        return NULL;
161
0
    return itav->infoValue.other;
162
0
}
163
164
int OSSL_CMP_ITAV_push0_stack_item(STACK_OF(OSSL_CMP_ITAV) **itav_sk_p,
165
                                   OSSL_CMP_ITAV *itav)
166
0
{
167
0
    int created = 0;
168
169
0
    if (itav_sk_p == NULL || itav == NULL) {
170
0
        ERR_raise(ERR_LIB_CMP, CMP_R_NULL_ARGUMENT);
171
0
        goto err;
172
0
    }
173
174
0
    if (*itav_sk_p == NULL) {
175
0
        if ((*itav_sk_p = sk_OSSL_CMP_ITAV_new_null()) == NULL)
176
0
            goto err;
177
0
        created = 1;
178
0
    }
179
0
    if (!sk_OSSL_CMP_ITAV_push(*itav_sk_p, itav))
180
0
        goto err;
181
0
    return 1;
182
183
0
 err:
184
0
    if (created != 0) {
185
0
        sk_OSSL_CMP_ITAV_free(*itav_sk_p);
186
0
        *itav_sk_p = NULL;
187
0
    }
188
0
    return 0;
189
0
}
190
191
/* get ASN.1 encoded integer, return -2 on error; -1 is valid for certReqId */
192
int ossl_cmp_asn1_get_int(const ASN1_INTEGER *a)
193
280
{
194
280
    int64_t res;
195
196
280
    if (!ASN1_INTEGER_get_int64(&res, a)) {
197
14
        ERR_raise(ERR_LIB_CMP, ASN1_R_INVALID_NUMBER);
198
14
        return -2;
199
14
    }
200
266
    if (res < INT_MIN) {
201
66
        ERR_raise(ERR_LIB_CMP, ASN1_R_TOO_SMALL);
202
66
        return -2;
203
66
    }
204
200
    if (res > INT_MAX) {
205
7
        ERR_raise(ERR_LIB_CMP, ASN1_R_TOO_LARGE);
206
7
        return -2;
207
7
    }
208
193
    return (int)res;
209
200
}
210
211
static int ossl_cmp_msg_cb(int operation, ASN1_VALUE **pval,
212
                           const ASN1_ITEM *it, void *exarg)
213
1.50M
{
214
1.50M
    OSSL_CMP_MSG *msg = (OSSL_CMP_MSG *)*pval;
215
216
1.50M
    switch (operation) {
217
157k
    case ASN1_OP_FREE_POST:
218
157k
        OPENSSL_free(msg->propq);
219
157k
        break;
220
221
0
    case ASN1_OP_DUP_POST:
222
0
        {
223
0
            OSSL_CMP_MSG *old = exarg;
224
225
0
            if (!ossl_cmp_msg_set0_libctx(msg, old->libctx, old->propq))
226
0
                return 0;
227
0
        }
228
0
        break;
229
0
    case ASN1_OP_GET0_LIBCTX:
230
0
        {
231
0
            OSSL_LIB_CTX **libctx = exarg;
232
233
0
            *libctx = msg->libctx;
234
0
        }
235
0
        break;
236
0
    case ASN1_OP_GET0_PROPQ:
237
0
        {
238
0
            const char **propq = exarg;
239
240
0
            *propq = msg->propq;
241
0
        }
242
0
        break;
243
1.34M
    default:
244
1.34M
        break;
245
1.50M
    }
246
247
1.50M
    return 1;
248
1.50M
}
249
250
ASN1_CHOICE(OSSL_CMP_CERTORENCCERT) = {
251
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
252
    ASN1_EXP(OSSL_CMP_CERTORENCCERT, value.certificate, X509, 0),
253
    ASN1_EXP(OSSL_CMP_CERTORENCCERT, value.encryptedCert,
254
             OSSL_CRMF_ENCRYPTEDVALUE, 1),
255
1.63k
} ASN1_CHOICE_END(OSSL_CMP_CERTORENCCERT)
256
1.63k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CERTORENCCERT)
257
1.63k
258
1.63k
259
1.63k
ASN1_SEQUENCE(OSSL_CMP_CERTIFIEDKEYPAIR) = {
260
1.63k
    ASN1_SIMPLE(OSSL_CMP_CERTIFIEDKEYPAIR, certOrEncCert,
261
1.63k
                OSSL_CMP_CERTORENCCERT),
262
1.63k
    ASN1_EXP_OPT(OSSL_CMP_CERTIFIEDKEYPAIR, privateKey,
263
1.63k
                 OSSL_CRMF_ENCRYPTEDVALUE, 0),
264
1.63k
    ASN1_EXP_OPT(OSSL_CMP_CERTIFIEDKEYPAIR, publicationInfo,
265
1.63k
                 OSSL_CRMF_PKIPUBLICATIONINFO, 1)
266
64.0k
} ASN1_SEQUENCE_END(OSSL_CMP_CERTIFIEDKEYPAIR)
267
64.0k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CERTIFIEDKEYPAIR)
268
64.0k
269
64.0k
270
64.0k
ASN1_SEQUENCE(OSSL_CMP_REVDETAILS) = {
271
64.0k
    ASN1_SIMPLE(OSSL_CMP_REVDETAILS, certDetails, OSSL_CRMF_CERTTEMPLATE),
272
64.0k
    ASN1_OPT(OSSL_CMP_REVDETAILS, crlEntryDetails, X509_EXTENSIONS)
273
1.74M
} ASN1_SEQUENCE_END(OSSL_CMP_REVDETAILS)
274
1.74M
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_REVDETAILS)
275
1.74M
276
1.74M
277
1.74M
ASN1_ITEM_TEMPLATE(OSSL_CMP_REVREQCONTENT) =
278
1.74M
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_REVREQCONTENT,
279
1.74M
                          OSSL_CMP_REVDETAILS)
280
1.74M
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_REVREQCONTENT)
281
282
283
ASN1_SEQUENCE(OSSL_CMP_REVREPCONTENT) = {
284
    ASN1_SEQUENCE_OF(OSSL_CMP_REVREPCONTENT, status, OSSL_CMP_PKISI),
285
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_REVREPCONTENT, revCerts, OSSL_CRMF_CERTID,
286
                             0),
287
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_REVREPCONTENT, crls, X509_CRL, 1)
288
12.8k
} ASN1_SEQUENCE_END(OSSL_CMP_REVREPCONTENT)
289
12.8k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_REVREPCONTENT)
290
12.8k
291
12.8k
292
12.8k
ASN1_SEQUENCE(OSSL_CMP_KEYRECREPCONTENT) = {
293
12.8k
    ASN1_SIMPLE(OSSL_CMP_KEYRECREPCONTENT, status, OSSL_CMP_PKISI),
294
12.8k
    ASN1_EXP_OPT(OSSL_CMP_KEYRECREPCONTENT, newSigCert, X509, 0),
295
12.8k
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_KEYRECREPCONTENT, caCerts, X509, 1),
296
12.8k
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_KEYRECREPCONTENT, keyPairHist,
297
12.8k
                             OSSL_CMP_CERTIFIEDKEYPAIR, 2)
298
12.8k
} ASN1_SEQUENCE_END(OSSL_CMP_KEYRECREPCONTENT)
299
3.48k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_KEYRECREPCONTENT)
300
3.48k
301
3.48k
302
3.48k
ASN1_ITEM_TEMPLATE(OSSL_CMP_PKISTATUS) =
303
3.48k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_UNIVERSAL, 0, status, ASN1_INTEGER)
304
501k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_PKISTATUS)
305
306
ASN1_SEQUENCE(OSSL_CMP_PKISI) = {
307
    ASN1_SIMPLE(OSSL_CMP_PKISI, status, OSSL_CMP_PKISTATUS),
308
    /*
309
     * CMP_PKIFREETEXT is effectively a sequence of ASN1_UTF8STRING
310
     * so it is used directly
311
     */
312
    ASN1_SEQUENCE_OF_OPT(OSSL_CMP_PKISI, statusString, ASN1_UTF8STRING),
313
    /*
314
     * OSSL_CMP_PKIFAILUREINFO is effectively ASN1_BIT_STRING so used directly
315
     */
316
    ASN1_OPT(OSSL_CMP_PKISI, failInfo, ASN1_BIT_STRING)
317
342k
} ASN1_SEQUENCE_END(OSSL_CMP_PKISI)
318
342k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_PKISI)
319
342k
IMPLEMENT_ASN1_DUP_FUNCTION(OSSL_CMP_PKISI)
320
342k
321
342k
ASN1_SEQUENCE(OSSL_CMP_CERTSTATUS) = {
322
342k
    ASN1_SIMPLE(OSSL_CMP_CERTSTATUS, certHash, ASN1_OCTET_STRING),
323
342k
    ASN1_SIMPLE(OSSL_CMP_CERTSTATUS, certReqId, ASN1_INTEGER),
324
342k
    ASN1_OPT(OSSL_CMP_CERTSTATUS, statusInfo, OSSL_CMP_PKISI)
325
342k
} ASN1_SEQUENCE_END(OSSL_CMP_CERTSTATUS)
326
1.93k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CERTSTATUS)
327
1.93k
328
1.93k
ASN1_ITEM_TEMPLATE(OSSL_CMP_CERTCONFIRMCONTENT) =
329
1.93k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_CERTCONFIRMCONTENT,
330
1.93k
                          OSSL_CMP_CERTSTATUS)
331
16.6k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_CERTCONFIRMCONTENT)
332
333
ASN1_SEQUENCE(OSSL_CMP_CERTRESPONSE) = {
334
    ASN1_SIMPLE(OSSL_CMP_CERTRESPONSE, certReqId, ASN1_INTEGER),
335
    ASN1_SIMPLE(OSSL_CMP_CERTRESPONSE, status, OSSL_CMP_PKISI),
336
    ASN1_OPT(OSSL_CMP_CERTRESPONSE, certifiedKeyPair,
337
             OSSL_CMP_CERTIFIEDKEYPAIR),
338
    ASN1_OPT(OSSL_CMP_CERTRESPONSE, rspInfo, ASN1_OCTET_STRING)
339
57.4k
} ASN1_SEQUENCE_END(OSSL_CMP_CERTRESPONSE)
340
57.4k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CERTRESPONSE)
341
57.4k
342
57.4k
ASN1_SEQUENCE(OSSL_CMP_POLLREQ) = {
343
57.4k
    ASN1_SIMPLE(OSSL_CMP_POLLREQ, certReqId, ASN1_INTEGER)
344
57.4k
} ASN1_SEQUENCE_END(OSSL_CMP_POLLREQ)
345
7.12k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_POLLREQ)
346
7.12k
347
7.12k
ASN1_ITEM_TEMPLATE(OSSL_CMP_POLLREQCONTENT) =
348
7.12k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_POLLREQCONTENT,
349
7.12k
                          OSSL_CMP_POLLREQ)
350
7.12k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_POLLREQCONTENT)
351
352
ASN1_SEQUENCE(OSSL_CMP_POLLREP) = {
353
    ASN1_SIMPLE(OSSL_CMP_POLLREP, certReqId, ASN1_INTEGER),
354
    ASN1_SIMPLE(OSSL_CMP_POLLREP, checkAfter, ASN1_INTEGER),
355
    ASN1_SEQUENCE_OF_OPT(OSSL_CMP_POLLREP, reason, ASN1_UTF8STRING),
356
5.39k
} ASN1_SEQUENCE_END(OSSL_CMP_POLLREP)
357
5.39k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_POLLREP)
358
5.39k
359
5.39k
ASN1_ITEM_TEMPLATE(OSSL_CMP_POLLREPCONTENT) =
360
5.39k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0,
361
5.39k
                          OSSL_CMP_POLLREPCONTENT,
362
5.39k
                          OSSL_CMP_POLLREP)
363
47.8k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_POLLREPCONTENT)
364
365
ASN1_SEQUENCE(OSSL_CMP_CERTREPMESSAGE) = {
366
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
367
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_CERTREPMESSAGE, caPubs, X509, 1),
368
    ASN1_SEQUENCE_OF(OSSL_CMP_CERTREPMESSAGE, response, OSSL_CMP_CERTRESPONSE)
369
49.8k
} ASN1_SEQUENCE_END(OSSL_CMP_CERTREPMESSAGE)
370
49.8k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_CERTREPMESSAGE)
371
49.8k
372
49.8k
ASN1_ITEM_TEMPLATE(OSSL_CMP_GENMSGCONTENT) =
373
49.8k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_GENMSGCONTENT,
374
49.8k
                          OSSL_CMP_ITAV)
375
49.8k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_GENMSGCONTENT)
376
377
ASN1_ITEM_TEMPLATE(OSSL_CMP_GENREPCONTENT) =
378
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_GENREPCONTENT,
379
                          OSSL_CMP_ITAV)
380
11.8k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_GENREPCONTENT)
381
382
ASN1_ITEM_TEMPLATE(OSSL_CMP_CRLANNCONTENT) =
383
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0,
384
                          OSSL_CMP_CRLANNCONTENT, X509_CRL)
385
14.8k
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_CRLANNCONTENT)
386
387
ASN1_CHOICE(OSSL_CMP_PKIBODY) = {
388
    ASN1_EXP(OSSL_CMP_PKIBODY, value.ir, OSSL_CRMF_MSGS, 0),
389
    ASN1_EXP(OSSL_CMP_PKIBODY, value.ip, OSSL_CMP_CERTREPMESSAGE, 1),
390
    ASN1_EXP(OSSL_CMP_PKIBODY, value.cr, OSSL_CRMF_MSGS, 2),
391
    ASN1_EXP(OSSL_CMP_PKIBODY, value.cp, OSSL_CMP_CERTREPMESSAGE, 3),
392
    ASN1_EXP(OSSL_CMP_PKIBODY, value.p10cr, X509_REQ, 4),
393
    ASN1_EXP(OSSL_CMP_PKIBODY, value.popdecc,
394
             OSSL_CMP_POPODECKEYCHALLCONTENT, 5),
395
    ASN1_EXP(OSSL_CMP_PKIBODY, value.popdecr,
396
             OSSL_CMP_POPODECKEYRESPCONTENT, 6),
397
    ASN1_EXP(OSSL_CMP_PKIBODY, value.kur, OSSL_CRMF_MSGS, 7),
398
    ASN1_EXP(OSSL_CMP_PKIBODY, value.kup, OSSL_CMP_CERTREPMESSAGE, 8),
399
    ASN1_EXP(OSSL_CMP_PKIBODY, value.krr, OSSL_CRMF_MSGS, 9),
400
    ASN1_EXP(OSSL_CMP_PKIBODY, value.krp, OSSL_CMP_KEYRECREPCONTENT, 10),
401
    ASN1_EXP(OSSL_CMP_PKIBODY, value.rr, OSSL_CMP_REVREQCONTENT, 11),
402
    ASN1_EXP(OSSL_CMP_PKIBODY, value.rp, OSSL_CMP_REVREPCONTENT, 12),
403
    ASN1_EXP(OSSL_CMP_PKIBODY, value.ccr, OSSL_CRMF_MSGS, 13),
404
    ASN1_EXP(OSSL_CMP_PKIBODY, value.ccp, OSSL_CMP_CERTREPMESSAGE, 14),
405
    ASN1_EXP(OSSL_CMP_PKIBODY, value.ckuann, OSSL_CMP_CAKEYUPDANNCONTENT, 15),
406
    ASN1_EXP(OSSL_CMP_PKIBODY, value.cann, X509, 16),
407
    ASN1_EXP(OSSL_CMP_PKIBODY, value.rann, OSSL_CMP_REVANNCONTENT, 17),
408
    ASN1_EXP(OSSL_CMP_PKIBODY, value.crlann, OSSL_CMP_CRLANNCONTENT, 18),
409
    ASN1_EXP(OSSL_CMP_PKIBODY, value.pkiconf, ASN1_ANY, 19),
410
    ASN1_EXP(OSSL_CMP_PKIBODY, value.nested, OSSL_CMP_MSGS, 20),
411
    ASN1_EXP(OSSL_CMP_PKIBODY, value.genm, OSSL_CMP_GENMSGCONTENT, 21),
412
    ASN1_EXP(OSSL_CMP_PKIBODY, value.genp, OSSL_CMP_GENREPCONTENT, 22),
413
    ASN1_EXP(OSSL_CMP_PKIBODY, value.error, OSSL_CMP_ERRORMSGCONTENT, 23),
414
    ASN1_EXP(OSSL_CMP_PKIBODY, value.certConf, OSSL_CMP_CERTCONFIRMCONTENT, 24),
415
    ASN1_EXP(OSSL_CMP_PKIBODY, value.pollReq, OSSL_CMP_POLLREQCONTENT, 25),
416
    ASN1_EXP(OSSL_CMP_PKIBODY, value.pollRep, OSSL_CMP_POLLREPCONTENT, 26),
417
2.08M
} ASN1_CHOICE_END(OSSL_CMP_PKIBODY)
418
2.08M
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_PKIBODY)
419
2.08M
420
2.08M
ASN1_SEQUENCE(OSSL_CMP_PKIHEADER) = {
421
2.08M
    ASN1_SIMPLE(OSSL_CMP_PKIHEADER, pvno, ASN1_INTEGER),
422
2.08M
    ASN1_SIMPLE(OSSL_CMP_PKIHEADER, sender, GENERAL_NAME),
423
2.08M
    ASN1_SIMPLE(OSSL_CMP_PKIHEADER, recipient, GENERAL_NAME),
424
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, messageTime, ASN1_GENERALIZEDTIME, 0),
425
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, protectionAlg, X509_ALGOR, 1),
426
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, senderKID, ASN1_OCTET_STRING, 2),
427
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, recipKID, ASN1_OCTET_STRING, 3),
428
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, transactionID, ASN1_OCTET_STRING, 4),
429
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, senderNonce, ASN1_OCTET_STRING, 5),
430
2.08M
    ASN1_EXP_OPT(OSSL_CMP_PKIHEADER, recipNonce, ASN1_OCTET_STRING, 6),
431
2.08M
    /*
432
2.08M
     * OSSL_CMP_PKIFREETEXT is effectively a sequence of ASN1_UTF8STRING
433
2.08M
     * so it is used directly
434
2.08M
     */
435
2.08M
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_PKIHEADER, freeText, ASN1_UTF8STRING, 7),
436
2.08M
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_PKIHEADER, generalInfo,
437
2.08M
                             OSSL_CMP_ITAV, 8)
438
2.08M
} ASN1_SEQUENCE_END(OSSL_CMP_PKIHEADER)
439
1.06M
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_PKIHEADER)
440
1.06M
441
1.06M
ASN1_SEQUENCE(OSSL_CMP_PROTECTEDPART) = {
442
1.06M
    ASN1_SIMPLE(OSSL_CMP_MSG, header, OSSL_CMP_PKIHEADER),
443
1.06M
    ASN1_SIMPLE(OSSL_CMP_MSG, body, OSSL_CMP_PKIBODY)
444
1.06M
} ASN1_SEQUENCE_END(OSSL_CMP_PROTECTEDPART)
445
3.77k
IMPLEMENT_ASN1_FUNCTIONS(OSSL_CMP_PROTECTEDPART)
446
3.77k
447
3.77k
ASN1_SEQUENCE_cb(OSSL_CMP_MSG, ossl_cmp_msg_cb) = {
448
3.77k
    ASN1_SIMPLE(OSSL_CMP_MSG, header, OSSL_CMP_PKIHEADER),
449
3.77k
    ASN1_SIMPLE(OSSL_CMP_MSG, body, OSSL_CMP_PKIBODY),
450
3.77k
    ASN1_EXP_OPT(OSSL_CMP_MSG, protection, ASN1_BIT_STRING, 0),
451
3.77k
    /* OSSL_CMP_CMPCERTIFICATE is effectively X509 so it is used directly */
452
3.77k
    ASN1_EXP_SEQUENCE_OF_OPT(OSSL_CMP_MSG, extraCerts, X509, 1)
453
3.77k
} ASN1_SEQUENCE_END_cb(OSSL_CMP_MSG, OSSL_CMP_MSG)
454
3.77k
IMPLEMENT_ASN1_DUP_FUNCTION(OSSL_CMP_MSG)
455
3.77k
456
3.77k
ASN1_ITEM_TEMPLATE(OSSL_CMP_MSGS) =
457
3.77k
    ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, OSSL_CMP_MSGS,
458
3.77k
                          OSSL_CMP_MSG)
459
ASN1_ITEM_TEMPLATE_END(OSSL_CMP_MSGS)