blob: 8b42ffcbcb2da73cd1112b2cdaf16ddab6a095c4 [file] [log] [blame] [edit]
// Copyright 2019 The Chromium Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "revocation_util.h"
#include "encode_values.h"
#include "parse_values.h"
BSSL_NAMESPACE_BEGIN
namespace {
constexpr int64_t kMinValidTime = -62167219200; // 0000-01-01 00:00:00 UTC
constexpr int64_t kMaxValidTime = 253402300799; // 9999-12-31 23:59:59 UTC
} // namespace
bool CheckRevocationDateValid(const der::GeneralizedTime &this_update,
const der::GeneralizedTime *next_update,
int64_t verify_time_epoch_seconds,
std::optional<int64_t> max_age_seconds) {
if (verify_time_epoch_seconds > kMaxValidTime ||
verify_time_epoch_seconds < kMinValidTime ||
(max_age_seconds.has_value() &&
(max_age_seconds.value() > kMaxValidTime ||
max_age_seconds.value() < 0))) {
return false;
}
der::GeneralizedTime verify_time;
if (!der::EncodePosixTimeAsGeneralizedTime(verify_time_epoch_seconds,
&verify_time)) {
return false;
}
if (this_update > verify_time) {
return false; // Response is not yet valid.
}
if (next_update && (*next_update <= verify_time)) {
return false; // Response is no longer valid.
}
if (max_age_seconds.has_value()) {
der::GeneralizedTime earliest_this_update;
if (!der::EncodePosixTimeAsGeneralizedTime(
verify_time_epoch_seconds - max_age_seconds.value(),
&earliest_this_update)) {
return false;
}
if (this_update < earliest_this_update) {
return false; // Response is too old.
}
}
return true;
}
BSSL_NAMESPACE_END