xref: /openssl/crypto/ts/ts_rsp_utils.c (revision e077455e)
1 /*
2  * Copyright 2006-2020 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 <stdio.h>
11 #include "internal/cryptlib.h"
12 #include <openssl/objects.h>
13 #include <openssl/ts.h>
14 #include <openssl/pkcs7.h>
15 #include "ts_local.h"
16 
TS_RESP_set_status_info(TS_RESP * a,TS_STATUS_INFO * status_info)17 int TS_RESP_set_status_info(TS_RESP *a, TS_STATUS_INFO *status_info)
18 {
19     TS_STATUS_INFO *new_status_info;
20 
21     if (a->status_info == status_info)
22         return 1;
23     new_status_info = TS_STATUS_INFO_dup(status_info);
24     if (new_status_info == NULL) {
25         ERR_raise(ERR_LIB_TS, ERR_R_TS_LIB);
26         return 0;
27     }
28     TS_STATUS_INFO_free(a->status_info);
29     a->status_info = new_status_info;
30 
31     return 1;
32 }
33 
TS_RESP_get_status_info(TS_RESP * a)34 TS_STATUS_INFO *TS_RESP_get_status_info(TS_RESP *a)
35 {
36     return a->status_info;
37 }
38 
39 /* Caller loses ownership of PKCS7 and TS_TST_INFO objects. */
TS_RESP_set_tst_info(TS_RESP * a,PKCS7 * p7,TS_TST_INFO * tst_info)40 void TS_RESP_set_tst_info(TS_RESP *a, PKCS7 *p7, TS_TST_INFO *tst_info)
41 {
42     PKCS7_free(a->token);
43     a->token = p7;
44     TS_TST_INFO_free(a->tst_info);
45     a->tst_info = tst_info;
46 }
47 
TS_RESP_get_token(TS_RESP * a)48 PKCS7 *TS_RESP_get_token(TS_RESP *a)
49 {
50     return a->token;
51 }
52 
TS_RESP_get_tst_info(TS_RESP * a)53 TS_TST_INFO *TS_RESP_get_tst_info(TS_RESP *a)
54 {
55     return a->tst_info;
56 }
57 
TS_TST_INFO_set_version(TS_TST_INFO * a,long version)58 int TS_TST_INFO_set_version(TS_TST_INFO *a, long version)
59 {
60     return ASN1_INTEGER_set(a->version, version);
61 }
62 
TS_TST_INFO_get_version(const TS_TST_INFO * a)63 long TS_TST_INFO_get_version(const TS_TST_INFO *a)
64 {
65     return ASN1_INTEGER_get(a->version);
66 }
67 
TS_TST_INFO_set_policy_id(TS_TST_INFO * a,ASN1_OBJECT * policy)68 int TS_TST_INFO_set_policy_id(TS_TST_INFO *a, ASN1_OBJECT *policy)
69 {
70     ASN1_OBJECT *new_policy;
71 
72     if (a->policy_id == policy)
73         return 1;
74     new_policy = OBJ_dup(policy);
75     if (new_policy == NULL) {
76         ERR_raise(ERR_LIB_TS, ERR_R_OBJ_LIB);
77         return 0;
78     }
79     ASN1_OBJECT_free(a->policy_id);
80     a->policy_id = new_policy;
81     return 1;
82 }
83 
TS_TST_INFO_get_policy_id(TS_TST_INFO * a)84 ASN1_OBJECT *TS_TST_INFO_get_policy_id(TS_TST_INFO *a)
85 {
86     return a->policy_id;
87 }
88 
TS_TST_INFO_set_msg_imprint(TS_TST_INFO * a,TS_MSG_IMPRINT * msg_imprint)89 int TS_TST_INFO_set_msg_imprint(TS_TST_INFO *a, TS_MSG_IMPRINT *msg_imprint)
90 {
91     TS_MSG_IMPRINT *new_msg_imprint;
92 
93     if (a->msg_imprint == msg_imprint)
94         return 1;
95     new_msg_imprint = TS_MSG_IMPRINT_dup(msg_imprint);
96     if (new_msg_imprint == NULL) {
97         ERR_raise(ERR_LIB_TS, ERR_R_TS_LIB);
98         return 0;
99     }
100     TS_MSG_IMPRINT_free(a->msg_imprint);
101     a->msg_imprint = new_msg_imprint;
102     return 1;
103 }
104 
TS_TST_INFO_get_msg_imprint(TS_TST_INFO * a)105 TS_MSG_IMPRINT *TS_TST_INFO_get_msg_imprint(TS_TST_INFO *a)
106 {
107     return a->msg_imprint;
108 }
109 
TS_TST_INFO_set_serial(TS_TST_INFO * a,const ASN1_INTEGER * serial)110 int TS_TST_INFO_set_serial(TS_TST_INFO *a, const ASN1_INTEGER *serial)
111 {
112     ASN1_INTEGER *new_serial;
113 
114     if (a->serial == serial)
115         return 1;
116     new_serial = ASN1_INTEGER_dup(serial);
117     if (new_serial == NULL) {
118         ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
119         return 0;
120     }
121     ASN1_INTEGER_free(a->serial);
122     a->serial = new_serial;
123     return 1;
124 }
125 
TS_TST_INFO_get_serial(const TS_TST_INFO * a)126 const ASN1_INTEGER *TS_TST_INFO_get_serial(const TS_TST_INFO *a)
127 {
128     return a->serial;
129 }
130 
TS_TST_INFO_set_time(TS_TST_INFO * a,const ASN1_GENERALIZEDTIME * gtime)131 int TS_TST_INFO_set_time(TS_TST_INFO *a, const ASN1_GENERALIZEDTIME *gtime)
132 {
133     ASN1_GENERALIZEDTIME *new_time;
134 
135     if (a->time == gtime)
136         return 1;
137     new_time = ASN1_STRING_dup(gtime);
138     if (new_time == NULL) {
139         ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
140         return 0;
141     }
142     ASN1_GENERALIZEDTIME_free(a->time);
143     a->time = new_time;
144     return 1;
145 }
146 
TS_TST_INFO_get_time(const TS_TST_INFO * a)147 const ASN1_GENERALIZEDTIME *TS_TST_INFO_get_time(const TS_TST_INFO *a)
148 {
149     return a->time;
150 }
151 
TS_TST_INFO_set_accuracy(TS_TST_INFO * a,TS_ACCURACY * accuracy)152 int TS_TST_INFO_set_accuracy(TS_TST_INFO *a, TS_ACCURACY *accuracy)
153 {
154     TS_ACCURACY *new_accuracy;
155 
156     if (a->accuracy == accuracy)
157         return 1;
158     new_accuracy = TS_ACCURACY_dup(accuracy);
159     if (new_accuracy == NULL) {
160         ERR_raise(ERR_LIB_TS, ERR_R_TS_LIB);
161         return 0;
162     }
163     TS_ACCURACY_free(a->accuracy);
164     a->accuracy = new_accuracy;
165     return 1;
166 }
167 
TS_TST_INFO_get_accuracy(TS_TST_INFO * a)168 TS_ACCURACY *TS_TST_INFO_get_accuracy(TS_TST_INFO *a)
169 {
170     return a->accuracy;
171 }
172 
TS_ACCURACY_set_seconds(TS_ACCURACY * a,const ASN1_INTEGER * seconds)173 int TS_ACCURACY_set_seconds(TS_ACCURACY *a, const ASN1_INTEGER *seconds)
174 {
175     ASN1_INTEGER *new_seconds;
176 
177     if (a->seconds == seconds)
178         return 1;
179     new_seconds = ASN1_INTEGER_dup(seconds);
180     if (new_seconds == NULL) {
181         ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
182         return 0;
183     }
184     ASN1_INTEGER_free(a->seconds);
185     a->seconds = new_seconds;
186     return 1;
187 }
188 
TS_ACCURACY_get_seconds(const TS_ACCURACY * a)189 const ASN1_INTEGER *TS_ACCURACY_get_seconds(const TS_ACCURACY *a)
190 {
191     return a->seconds;
192 }
193 
TS_ACCURACY_set_millis(TS_ACCURACY * a,const ASN1_INTEGER * millis)194 int TS_ACCURACY_set_millis(TS_ACCURACY *a, const ASN1_INTEGER *millis)
195 {
196     ASN1_INTEGER *new_millis = NULL;
197 
198     if (a->millis == millis)
199         return 1;
200     if (millis != NULL) {
201         new_millis = ASN1_INTEGER_dup(millis);
202         if (new_millis == NULL) {
203             ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
204             return 0;
205         }
206     }
207     ASN1_INTEGER_free(a->millis);
208     a->millis = new_millis;
209     return 1;
210 }
211 
TS_ACCURACY_get_millis(const TS_ACCURACY * a)212 const ASN1_INTEGER *TS_ACCURACY_get_millis(const TS_ACCURACY *a)
213 {
214     return a->millis;
215 }
216 
TS_ACCURACY_set_micros(TS_ACCURACY * a,const ASN1_INTEGER * micros)217 int TS_ACCURACY_set_micros(TS_ACCURACY *a, const ASN1_INTEGER *micros)
218 {
219     ASN1_INTEGER *new_micros = NULL;
220 
221     if (a->micros == micros)
222         return 1;
223     if (micros != NULL) {
224         new_micros = ASN1_INTEGER_dup(micros);
225         if (new_micros == NULL) {
226             ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
227             return 0;
228         }
229     }
230     ASN1_INTEGER_free(a->micros);
231     a->micros = new_micros;
232     return 1;
233 }
234 
TS_ACCURACY_get_micros(const TS_ACCURACY * a)235 const ASN1_INTEGER *TS_ACCURACY_get_micros(const TS_ACCURACY *a)
236 {
237     return a->micros;
238 }
239 
TS_TST_INFO_set_ordering(TS_TST_INFO * a,int ordering)240 int TS_TST_INFO_set_ordering(TS_TST_INFO *a, int ordering)
241 {
242     a->ordering = ordering ? 0xFF : 0x00;
243     return 1;
244 }
245 
TS_TST_INFO_get_ordering(const TS_TST_INFO * a)246 int TS_TST_INFO_get_ordering(const TS_TST_INFO *a)
247 {
248     return a->ordering ? 1 : 0;
249 }
250 
TS_TST_INFO_set_nonce(TS_TST_INFO * a,const ASN1_INTEGER * nonce)251 int TS_TST_INFO_set_nonce(TS_TST_INFO *a, const ASN1_INTEGER *nonce)
252 {
253     ASN1_INTEGER *new_nonce;
254 
255     if (a->nonce == nonce)
256         return 1;
257     new_nonce = ASN1_INTEGER_dup(nonce);
258     if (new_nonce == NULL) {
259         ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
260         return 0;
261     }
262     ASN1_INTEGER_free(a->nonce);
263     a->nonce = new_nonce;
264     return 1;
265 }
266 
TS_TST_INFO_get_nonce(const TS_TST_INFO * a)267 const ASN1_INTEGER *TS_TST_INFO_get_nonce(const TS_TST_INFO *a)
268 {
269     return a->nonce;
270 }
271 
TS_TST_INFO_set_tsa(TS_TST_INFO * a,GENERAL_NAME * tsa)272 int TS_TST_INFO_set_tsa(TS_TST_INFO *a, GENERAL_NAME *tsa)
273 {
274     GENERAL_NAME *new_tsa;
275 
276     if (a->tsa == tsa)
277         return 1;
278     new_tsa = GENERAL_NAME_dup(tsa);
279     if (new_tsa == NULL) {
280         ERR_raise(ERR_LIB_TS, ERR_R_ASN1_LIB);
281         return 0;
282     }
283     GENERAL_NAME_free(a->tsa);
284     a->tsa = new_tsa;
285     return 1;
286 }
287 
TS_TST_INFO_get_tsa(TS_TST_INFO * a)288 GENERAL_NAME *TS_TST_INFO_get_tsa(TS_TST_INFO *a)
289 {
290     return a->tsa;
291 }
292 
STACK_OF(X509_EXTENSION)293 STACK_OF(X509_EXTENSION) *TS_TST_INFO_get_exts(TS_TST_INFO *a)
294 {
295     return a->extensions;
296 }
297 
TS_TST_INFO_ext_free(TS_TST_INFO * a)298 void TS_TST_INFO_ext_free(TS_TST_INFO *a)
299 {
300     if (!a)
301         return;
302     sk_X509_EXTENSION_pop_free(a->extensions, X509_EXTENSION_free);
303     a->extensions = NULL;
304 }
305 
TS_TST_INFO_get_ext_count(TS_TST_INFO * a)306 int TS_TST_INFO_get_ext_count(TS_TST_INFO *a)
307 {
308     return X509v3_get_ext_count(a->extensions);
309 }
310 
TS_TST_INFO_get_ext_by_NID(TS_TST_INFO * a,int nid,int lastpos)311 int TS_TST_INFO_get_ext_by_NID(TS_TST_INFO *a, int nid, int lastpos)
312 {
313     return X509v3_get_ext_by_NID(a->extensions, nid, lastpos);
314 }
315 
TS_TST_INFO_get_ext_by_OBJ(TS_TST_INFO * a,const ASN1_OBJECT * obj,int lastpos)316 int TS_TST_INFO_get_ext_by_OBJ(TS_TST_INFO *a, const ASN1_OBJECT *obj, int lastpos)
317 {
318     return X509v3_get_ext_by_OBJ(a->extensions, obj, lastpos);
319 }
320 
TS_TST_INFO_get_ext_by_critical(TS_TST_INFO * a,int crit,int lastpos)321 int TS_TST_INFO_get_ext_by_critical(TS_TST_INFO *a, int crit, int lastpos)
322 {
323     return X509v3_get_ext_by_critical(a->extensions, crit, lastpos);
324 }
325 
TS_TST_INFO_get_ext(TS_TST_INFO * a,int loc)326 X509_EXTENSION *TS_TST_INFO_get_ext(TS_TST_INFO *a, int loc)
327 {
328     return X509v3_get_ext(a->extensions, loc);
329 }
330 
TS_TST_INFO_delete_ext(TS_TST_INFO * a,int loc)331 X509_EXTENSION *TS_TST_INFO_delete_ext(TS_TST_INFO *a, int loc)
332 {
333     return X509v3_delete_ext(a->extensions, loc);
334 }
335 
TS_TST_INFO_add_ext(TS_TST_INFO * a,X509_EXTENSION * ex,int loc)336 int TS_TST_INFO_add_ext(TS_TST_INFO *a, X509_EXTENSION *ex, int loc)
337 {
338     return X509v3_add_ext(&a->extensions, ex, loc) != NULL;
339 }
340 
TS_TST_INFO_get_ext_d2i(TS_TST_INFO * a,int nid,int * crit,int * idx)341 void *TS_TST_INFO_get_ext_d2i(TS_TST_INFO *a, int nid, int *crit, int *idx)
342 {
343     return X509V3_get_d2i(a->extensions, nid, crit, idx);
344 }
345 
TS_STATUS_INFO_set_status(TS_STATUS_INFO * a,int i)346 int TS_STATUS_INFO_set_status(TS_STATUS_INFO *a, int i)
347 {
348     return ASN1_INTEGER_set(a->status, i);
349 }
350 
TS_STATUS_INFO_get0_status(const TS_STATUS_INFO * a)351 const ASN1_INTEGER *TS_STATUS_INFO_get0_status(const TS_STATUS_INFO *a)
352 {
353     return a->status;
354 }
355 
STACK_OF(ASN1_UTF8STRING)356 const STACK_OF(ASN1_UTF8STRING) *
357 TS_STATUS_INFO_get0_text(const TS_STATUS_INFO *a)
358 {
359     return a->text;
360 }
361 
TS_STATUS_INFO_get0_failure_info(const TS_STATUS_INFO * a)362 const ASN1_BIT_STRING *TS_STATUS_INFO_get0_failure_info(const TS_STATUS_INFO *a)
363 {
364     return a->failure_info;
365 }
366