Copyright consolidation 08/10
[openssl.git] / crypto / asn1 / x_algor.c
1 /*
2  * Copyright 1998-2016 The OpenSSL Project Authors. All Rights Reserved.
3  *
4  * Licensed under the OpenSSL license (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 <stddef.h>
11 #include <openssl/x509.h>
12 #include <openssl/asn1.h>
13 #include <openssl/asn1t.h>
14 #include "internal/evp_int.h"
15
16 ASN1_SEQUENCE(X509_ALGOR) = {
17         ASN1_SIMPLE(X509_ALGOR, algorithm, ASN1_OBJECT),
18         ASN1_OPT(X509_ALGOR, parameter, ASN1_ANY)
19 } ASN1_SEQUENCE_END(X509_ALGOR)
20
21 ASN1_ITEM_TEMPLATE(X509_ALGORS) =
22         ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_SEQUENCE_OF, 0, algorithms, X509_ALGOR)
23 ASN1_ITEM_TEMPLATE_END(X509_ALGORS)
24
25 IMPLEMENT_ASN1_FUNCTIONS(X509_ALGOR)
26 IMPLEMENT_ASN1_ENCODE_FUNCTIONS_fname(X509_ALGORS, X509_ALGORS, X509_ALGORS)
27 IMPLEMENT_ASN1_DUP_FUNCTION(X509_ALGOR)
28
29 int X509_ALGOR_set0(X509_ALGOR *alg, ASN1_OBJECT *aobj, int ptype, void *pval)
30 {
31     if (!alg)
32         return 0;
33     if (ptype != V_ASN1_UNDEF) {
34         if (alg->parameter == NULL)
35             alg->parameter = ASN1_TYPE_new();
36         if (alg->parameter == NULL)
37             return 0;
38     }
39     if (alg) {
40         ASN1_OBJECT_free(alg->algorithm);
41         alg->algorithm = aobj;
42     }
43     if (ptype == 0)
44         return 1;
45     if (ptype == V_ASN1_UNDEF) {
46         ASN1_TYPE_free(alg->parameter);
47         alg->parameter = NULL;
48     } else
49         ASN1_TYPE_set(alg->parameter, ptype, pval);
50     return 1;
51 }
52
53 void X509_ALGOR_get0(ASN1_OBJECT **paobj, int *pptype, void **ppval,
54                      X509_ALGOR *algor)
55 {
56     if (paobj)
57         *paobj = algor->algorithm;
58     if (pptype) {
59         if (algor->parameter == NULL) {
60             *pptype = V_ASN1_UNDEF;
61             return;
62         } else
63             *pptype = algor->parameter->type;
64         if (ppval)
65             *ppval = algor->parameter->value.ptr;
66     }
67 }
68
69 /* Set up an X509_ALGOR DigestAlgorithmIdentifier from an EVP_MD */
70
71 void X509_ALGOR_set_md(X509_ALGOR *alg, const EVP_MD *md)
72 {
73     int param_type;
74
75     if (md->flags & EVP_MD_FLAG_DIGALGID_ABSENT)
76         param_type = V_ASN1_UNDEF;
77     else
78         param_type = V_ASN1_NULL;
79
80     X509_ALGOR_set0(alg, OBJ_nid2obj(EVP_MD_type(md)), param_type, NULL);
81
82 }
83
84 int X509_ALGOR_cmp(const X509_ALGOR *a, const X509_ALGOR *b)
85 {
86     int rv;
87     rv = OBJ_cmp(a->algorithm, b->algorithm);
88     if (rv)
89         return rv;
90     if (!a->parameter && !b->parameter)
91         return 0;
92     return ASN1_TYPE_cmp(a->parameter, b->parameter);
93 }