diff options
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libcrypto/asn1/a_time_tm.c | 40 |
1 files changed, 14 insertions, 26 deletions
diff --git a/src/lib/libcrypto/asn1/a_time_tm.c b/src/lib/libcrypto/asn1/a_time_tm.c index 986c1e735d..c8eabec08f 100644 --- a/src/lib/libcrypto/asn1/a_time_tm.c +++ b/src/lib/libcrypto/asn1/a_time_tm.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: a_time_tm.c,v 1.33 2024/03/02 09:10:42 tb Exp $ */ | 1 | /* $OpenBSD: a_time_tm.c,v 1.34 2024/04/08 19:57:40 beck Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright (c) 2015 Bob Beck <beck@openbsd.org> | 3 | * Copyright (c) 2015 Bob Beck <beck@openbsd.org> |
| 4 | * | 4 | * |
| @@ -160,15 +160,7 @@ tm_to_utctime(struct tm *tm, ASN1_TIME *atime) | |||
| 160 | ASN1_TIME * | 160 | ASN1_TIME * |
| 161 | tm_to_rfc5280_time(struct tm *tm, ASN1_TIME *atime) | 161 | tm_to_rfc5280_time(struct tm *tm, ASN1_TIME *atime) |
| 162 | { | 162 | { |
| 163 | int year; | 163 | if (tm->tm_year >= 50 && tm->tm_year < 150) |
| 164 | |||
| 165 | year = tm->tm_year + 1900; | ||
| 166 | if (year < 1950 || year > 9999) { | ||
| 167 | ASN1error(ASN1_R_ILLEGAL_TIME_VALUE); | ||
| 168 | return (NULL); | ||
| 169 | } | ||
| 170 | |||
| 171 | if (year < 2050) | ||
| 172 | return (tm_to_utctime(tm, atime)); | 164 | return (tm_to_utctime(tm, atime)); |
| 173 | 165 | ||
| 174 | return (tm_to_gentime(tm, atime)); | 166 | return (tm_to_gentime(tm, atime)); |
| @@ -352,25 +344,21 @@ ASN1_time_parse(const char *bytes, size_t len, struct tm *tm, int mode) | |||
| 352 | static int | 344 | static int |
| 353 | ASN1_TIME_set_string_internal(ASN1_TIME *s, const char *str, int mode) | 345 | ASN1_TIME_set_string_internal(ASN1_TIME *s, const char *str, int mode) |
| 354 | { | 346 | { |
| 347 | struct tm tm; | ||
| 355 | int type; | 348 | int type; |
| 356 | char *tmp; | ||
| 357 | 349 | ||
| 358 | if ((type = ASN1_time_parse(str, strlen(str), NULL, mode)) == -1) | 350 | if ((type = ASN1_time_parse(str, strlen(str), &tm, mode)) == -1) |
| 359 | return (0); | ||
| 360 | if (mode != 0 && mode != type) | ||
| 361 | return (0); | 351 | return (0); |
| 362 | 352 | switch(mode) { | |
| 363 | if (s == NULL) | 353 | case V_ASN1_UTCTIME: |
| 364 | return (1); | 354 | return (type == mode && tm_to_utctime(&tm, s) != NULL); |
| 365 | 355 | case V_ASN1_GENERALIZEDTIME: | |
| 366 | if ((tmp = strdup(str)) == NULL) | 356 | return (type == mode && tm_to_gentime(&tm, s) != NULL); |
| 357 | case RFC5280: | ||
| 358 | return (tm_to_rfc5280_time(&tm, s) != NULL); | ||
| 359 | default: | ||
| 367 | return (0); | 360 | return (0); |
| 368 | free(s->data); | 361 | } |
| 369 | s->data = tmp; | ||
| 370 | s->length = strlen(tmp); | ||
| 371 | s->type = type; | ||
| 372 | |||
| 373 | return (1); | ||
| 374 | } | 362 | } |
| 375 | 363 | ||
| 376 | static ASN1_TIME * | 364 | static ASN1_TIME * |
| @@ -448,7 +436,7 @@ LCRYPTO_ALIAS(ASN1_TIME_to_generalizedtime); | |||
| 448 | int | 436 | int |
| 449 | ASN1_TIME_set_string(ASN1_TIME *s, const char *str) | 437 | ASN1_TIME_set_string(ASN1_TIME *s, const char *str) |
| 450 | { | 438 | { |
| 451 | return (ASN1_TIME_set_string_internal(s, str, 0)); | 439 | return (ASN1_TIME_set_string_internal(s, str, RFC5280)); |
| 452 | } | 440 | } |
| 453 | LCRYPTO_ALIAS(ASN1_TIME_set_string); | 441 | LCRYPTO_ALIAS(ASN1_TIME_set_string); |
| 454 | 442 | ||
