|  | // Copyright 2020 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef QUICHE_COMMON_PLATFORM_API_QUICHE_TIME_UTILS_H_ | 
|  | #define QUICHE_COMMON_PLATFORM_API_QUICHE_TIME_UTILS_H_ | 
|  |  | 
|  | #include <cstdint> | 
|  |  | 
|  | #include "net/quiche/common/platform/impl/quiche_time_utils_impl.h" | 
|  |  | 
|  | namespace quiche { | 
|  |  | 
|  | // Converts a civil time specified in UTC into a number of seconds since the | 
|  | // Unix epoch.  This function is strict about validity of accepted dates.  For | 
|  | // instance, it will reject February 29 on non-leap years, or 25 hours in a day. | 
|  | // As a notable exception, 60 seconds is accepted to deal with potential leap | 
|  | // seconds.  If the date predates Unix epoch, nullopt will be returned. | 
|  | inline absl::optional<int64_t> QuicheUtcDateTimeToUnixSeconds(int year, | 
|  | int month, | 
|  | int day, | 
|  | int hour, | 
|  | int minute, | 
|  | int second) { | 
|  | return QuicheUtcDateTimeToUnixSecondsImpl(year, month, day, hour, minute, | 
|  | second); | 
|  | } | 
|  |  | 
|  | }  // namespace quiche | 
|  |  | 
|  | #endif  // QUICHE_COMMON_PLATFORM_API_QUICHE_TIME_UTILS_H_ |