diff options
author | Kazuki Yamaguchi <k@rhe.jp> | 2016-12-10 15:47:21 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-10 15:47:21 +0900 |
commit | c083ff82a79a9e6fe5c7ed1525eb0e6bf0627de9 (patch) | |
tree | 2e1058163caec852b2be107124e181e2e320f287 /ext/openssl | |
parent | 159a24dc970cb8b521710ac38c652d219d49dc80 (diff) | |
parent | 698b52c16ba8b29533963e16a61a3bfa254a51ee (diff) | |
download | ruby-openssl-c083ff82a79a9e6fe5c7ed1525eb0e6bf0627de9.tar.gz |
Merge pull request #88 from yogo1212/generalizedtime_format
asn1: handle GENERALIZEDTIME without seconds
Diffstat (limited to 'ext/openssl')
-rw-r--r-- | ext/openssl/ossl_asn1.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/ext/openssl/ossl_asn1.c b/ext/openssl/ossl_asn1.c index af8ae2a6..534796f5 100644 --- a/ext/openssl/ossl_asn1.c +++ b/ext/openssl/ossl_asn1.c @@ -47,9 +47,15 @@ asn1time_to_time(const ASN1_TIME *time) } break; case V_ASN1_GENERALIZEDTIME: - if (sscanf((const char *)time->data, "%4d%2d%2d%2d%2d%2dZ", &tm.tm_year, &tm.tm_mon, - &tm.tm_mday, &tm.tm_hour, &tm.tm_min, &tm.tm_sec) != 6) { - ossl_raise(rb_eTypeError, "bad GENERALIZEDTIME format" ); + count = sscanf((const char *)time->data, "%4d%2d%2d%2d%2d%2dZ", + &tm.tm_year, &tm.tm_mon, &tm.tm_mday, &tm.tm_hour, &tm.tm_min, + &tm.tm_sec); + if (count == 5) { + tm.tm_sec = 0; + } + else if (count != 6) { + ossl_raise(rb_eTypeError, "bad GENERALIZEDTIME format: \"%s\"", + time->data); } break; default: |