All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.helidon.http.DateTime Maven / Gradle / Ivy

/*
 * Copyright (c) 2023 Oracle and/or its affiliates.
 *
 * 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
 *
 *     http://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.
 */

package io.helidon.http;

import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;

/**
 * Support for HTTP date formats based on RFC2616.
 */
public final class DateTime {
    /**
     * The RFC850 date-time formatter, such as {@code 'Sunday, 06-Nov-94 08:49:37 GMT'}.
     * 

* This is obsolete standard (obsoleted by RFC1036). Headers MUST NOT be generated in this format. * However it should be used as a fallback for parsing to achieve compatibility with older HTTP standards. *

* Since the format accepts 2 digits year representation formatter works well for dates between * {@code (now - 50 Years)} and {@code (now + 49 Years)}. */ public static final DateTimeFormatter RFC_850_DATE_TIME = DateTimeHelper.RFC_850_DATE_TIME; /** * The RFC1123 date-time formatter, such as {@code 'Tue, 3 Jun 2008 11:05:30 GMT'}. *

* This is standard for RFC2616 and all created headers MUST be in this format! However implementation must * accept headers also in RFC850 and ANSI C {@code asctime()} format. *

* This is just copy of convenient copy of {@link java.time.format.DateTimeFormatter#RFC_1123_DATE_TIME}. */ public static final DateTimeFormatter RFC_1123_DATE_TIME = DateTimeFormatter.RFC_1123_DATE_TIME; /** * The ANSI C's {@code asctime()} format, such as {@code 'Sun Nov 6 08:49:37 1994'}. *

* Headers MUST NOT be generated in this format. * However it should be used as a fallback for parsing to achieve compatibility with older HTTP standards. */ public static final DateTimeFormatter ASCTIME_DATE_TIME = DateTimeHelper.ASCTIME_DATE_TIME; private DateTime() { } /** * Parse provided text to {@link java.time.ZonedDateTime} using any possible date / time format specified * by RFC2616 Hypertext Transfer Protocol. *

* Formats are specified by {@link #RFC_1123_DATE_TIME}, {@link #RFC_850_DATE_TIME} and {@link #ASCTIME_DATE_TIME}. * * @param text a text to parse. * @return parsed date time. * @throws java.time.format.DateTimeParseException if not in any of supported formats. */ public static ZonedDateTime parse(String text) { return DateTimeHelper.parse(text); } /** * Last recorded timestamp. * * @return timestamp */ public static ZonedDateTime timestamp() { return DateTimeHelper.timestamp(); } /** * Get current time as RFC-1123 string. * * @return formatted current time * @see #RFC_1123_DATE_TIME */ public static String rfc1123String() { return DateTimeHelper.rfc1123String(); } /** * Formatted date time terminated by carriage return and new line. * * @return date bytes for HTTP/1 */ public static byte[] http1Bytes() { return DateTimeHelper.http1Bytes(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy