diff options
Diffstat (limited to 'src/lib/libcrypto/asn1/x_spki.c')
-rw-r--r-- | src/lib/libcrypto/asn1/x_spki.c | 109 |
1 files changed, 12 insertions, 97 deletions
diff --git a/src/lib/libcrypto/asn1/x_spki.c b/src/lib/libcrypto/asn1/x_spki.c index 4f01888f7d..2aece077c5 100644 --- a/src/lib/libcrypto/asn1/x_spki.c +++ b/src/lib/libcrypto/asn1/x_spki.c | |||
@@ -63,104 +63,19 @@ | |||
63 | #include <stdio.h> | 63 | #include <stdio.h> |
64 | #include "cryptlib.h" | 64 | #include "cryptlib.h" |
65 | #include <openssl/x509.h> | 65 | #include <openssl/x509.h> |
66 | #include <openssl/asn1_mac.h> | 66 | #include <openssl/asn1t.h> |
67 | 67 | ||
68 | int i2d_NETSCAPE_SPKAC(NETSCAPE_SPKAC *a, unsigned char **pp) | 68 | ASN1_SEQUENCE(NETSCAPE_SPKAC) = { |
69 | { | 69 | ASN1_SIMPLE(NETSCAPE_SPKAC, pubkey, X509_PUBKEY), |
70 | M_ASN1_I2D_vars(a); | 70 | ASN1_SIMPLE(NETSCAPE_SPKAC, challenge, ASN1_IA5STRING) |
71 | } ASN1_SEQUENCE_END(NETSCAPE_SPKAC) | ||
71 | 72 | ||
72 | M_ASN1_I2D_len(a->pubkey, i2d_X509_PUBKEY); | 73 | IMPLEMENT_ASN1_FUNCTIONS(NETSCAPE_SPKAC) |
73 | M_ASN1_I2D_len(a->challenge, i2d_ASN1_IA5STRING); | ||
74 | 74 | ||
75 | M_ASN1_I2D_seq_total(); | 75 | ASN1_SEQUENCE(NETSCAPE_SPKI) = { |
76 | 76 | ASN1_SIMPLE(NETSCAPE_SPKI, spkac, NETSCAPE_SPKAC), | |
77 | M_ASN1_I2D_put(a->pubkey, i2d_X509_PUBKEY); | 77 | ASN1_SIMPLE(NETSCAPE_SPKI, sig_algor, X509_ALGOR), |
78 | M_ASN1_I2D_put(a->challenge, i2d_ASN1_IA5STRING); | 78 | ASN1_SIMPLE(NETSCAPE_SPKI, signature, ASN1_BIT_STRING) |
79 | 79 | } ASN1_SEQUENCE_END(NETSCAPE_SPKI) | |
80 | M_ASN1_I2D_finish(); | ||
81 | } | ||
82 | |||
83 | NETSCAPE_SPKAC *d2i_NETSCAPE_SPKAC(NETSCAPE_SPKAC **a, unsigned char **pp, | ||
84 | long length) | ||
85 | { | ||
86 | M_ASN1_D2I_vars(a,NETSCAPE_SPKAC *,NETSCAPE_SPKAC_new); | ||
87 | |||
88 | M_ASN1_D2I_Init(); | ||
89 | M_ASN1_D2I_start_sequence(); | ||
90 | M_ASN1_D2I_get(ret->pubkey,d2i_X509_PUBKEY); | ||
91 | M_ASN1_D2I_get(ret->challenge,d2i_ASN1_IA5STRING); | ||
92 | M_ASN1_D2I_Finish(a,NETSCAPE_SPKAC_free,ASN1_F_D2I_NETSCAPE_SPKAC); | ||
93 | } | ||
94 | |||
95 | NETSCAPE_SPKAC *NETSCAPE_SPKAC_new(void) | ||
96 | { | ||
97 | NETSCAPE_SPKAC *ret=NULL; | ||
98 | ASN1_CTX c; | ||
99 | |||
100 | M_ASN1_New_Malloc(ret,NETSCAPE_SPKAC); | ||
101 | M_ASN1_New(ret->pubkey,X509_PUBKEY_new); | ||
102 | M_ASN1_New(ret->challenge,M_ASN1_IA5STRING_new); | ||
103 | return(ret); | ||
104 | M_ASN1_New_Error(ASN1_F_NETSCAPE_SPKAC_NEW); | ||
105 | } | ||
106 | |||
107 | void NETSCAPE_SPKAC_free(NETSCAPE_SPKAC *a) | ||
108 | { | ||
109 | if (a == NULL) return; | ||
110 | X509_PUBKEY_free(a->pubkey); | ||
111 | M_ASN1_IA5STRING_free(a->challenge); | ||
112 | OPENSSL_free(a); | ||
113 | } | ||
114 | |||
115 | int i2d_NETSCAPE_SPKI(NETSCAPE_SPKI *a, unsigned char **pp) | ||
116 | { | ||
117 | M_ASN1_I2D_vars(a); | ||
118 | |||
119 | M_ASN1_I2D_len(a->spkac, i2d_NETSCAPE_SPKAC); | ||
120 | M_ASN1_I2D_len(a->sig_algor, i2d_X509_ALGOR); | ||
121 | M_ASN1_I2D_len(a->signature, i2d_ASN1_BIT_STRING); | ||
122 | |||
123 | M_ASN1_I2D_seq_total(); | ||
124 | |||
125 | M_ASN1_I2D_put(a->spkac, i2d_NETSCAPE_SPKAC); | ||
126 | M_ASN1_I2D_put(a->sig_algor, i2d_X509_ALGOR); | ||
127 | M_ASN1_I2D_put(a->signature, i2d_ASN1_BIT_STRING); | ||
128 | |||
129 | M_ASN1_I2D_finish(); | ||
130 | } | ||
131 | |||
132 | NETSCAPE_SPKI *d2i_NETSCAPE_SPKI(NETSCAPE_SPKI **a, unsigned char **pp, | ||
133 | long length) | ||
134 | { | ||
135 | M_ASN1_D2I_vars(a,NETSCAPE_SPKI *,NETSCAPE_SPKI_new); | ||
136 | |||
137 | M_ASN1_D2I_Init(); | ||
138 | M_ASN1_D2I_start_sequence(); | ||
139 | M_ASN1_D2I_get(ret->spkac,d2i_NETSCAPE_SPKAC); | ||
140 | M_ASN1_D2I_get(ret->sig_algor,d2i_X509_ALGOR); | ||
141 | M_ASN1_D2I_get(ret->signature,d2i_ASN1_BIT_STRING); | ||
142 | M_ASN1_D2I_Finish(a,NETSCAPE_SPKI_free,ASN1_F_D2I_NETSCAPE_SPKI); | ||
143 | } | ||
144 | |||
145 | NETSCAPE_SPKI *NETSCAPE_SPKI_new(void) | ||
146 | { | ||
147 | NETSCAPE_SPKI *ret=NULL; | ||
148 | ASN1_CTX c; | ||
149 | |||
150 | M_ASN1_New_Malloc(ret,NETSCAPE_SPKI); | ||
151 | M_ASN1_New(ret->spkac,NETSCAPE_SPKAC_new); | ||
152 | M_ASN1_New(ret->sig_algor,X509_ALGOR_new); | ||
153 | M_ASN1_New(ret->signature,M_ASN1_BIT_STRING_new); | ||
154 | return(ret); | ||
155 | M_ASN1_New_Error(ASN1_F_NETSCAPE_SPKI_NEW); | ||
156 | } | ||
157 | |||
158 | void NETSCAPE_SPKI_free(NETSCAPE_SPKI *a) | ||
159 | { | ||
160 | if (a == NULL) return; | ||
161 | NETSCAPE_SPKAC_free(a->spkac); | ||
162 | X509_ALGOR_free(a->sig_algor); | ||
163 | M_ASN1_BIT_STRING_free(a->signature); | ||
164 | OPENSSL_free(a); | ||
165 | } | ||
166 | 80 | ||
81 | IMPLEMENT_ASN1_FUNCTIONS(NETSCAPE_SPKI) | ||