import type { Nullable } from '../utils'; | |
/** | |
* Parse a cookie date string into a {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date | Date}. Parses according to | |
* {@link https://www.rfc-editor.org/rfc/rfc6265.html#section-5.1.1 | RFC6265 - Section 5.1.1}, not | |
* {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/parse | Date.parse()}. | |
* | |
* @remarks | |
* | |
* ### RFC6265 - 5.1.1. Dates | |
* | |
* The user agent MUST use an algorithm equivalent to the following | |
* algorithm to parse a cookie-date. Note that the various boolean | |
* flags defined as a part of the algorithm (i.e., found-time, found- | |
* day-of-month, found-month, found-year) are initially "not set". | |
* | |
* 1. Using the grammar below, divide the cookie-date into date-tokens. | |
* | |
* ``` | |
* cookie-date = *delimiter date-token-list *delimiter | |
* date-token-list = date-token *( 1*delimiter date-token ) | |
* date-token = 1*non-delimiter | |
* | |
* delimiter = %x09 / %x20-2F / %x3B-40 / %x5B-60 / %x7B-7E | |
* non-delimiter = %x00-08 / %x0A-1F / DIGIT / ":" / ALPHA / %x7F-FF | |
* non-digit = %x00-2F / %x3A-FF | |
* | |
* day-of-month = 1*2DIGIT ( non-digit *OCTET ) | |
* month = ( "jan" / "feb" / "mar" / "apr" / | |
* "may" / "jun" / "jul" / "aug" / | |
* "sep" / "oct" / "nov" / "dec" ) *OCTET | |
* year = 2*4DIGIT ( non-digit *OCTET ) | |
* time = hms-time ( non-digit *OCTET ) | |
* hms-time = time-field ":" time-field ":" time-field | |
* time-field = 1*2DIGIT | |
* ``` | |
* | |
* 2. Process each date-token sequentially in the order the date-tokens | |
* appear in the cookie-date: | |
* | |
* 1. If the found-time flag is not set and the token matches the | |
* time production, set the found-time flag and set the hour- | |
* value, minute-value, and second-value to the numbers denoted | |
* by the digits in the date-token, respectively. Skip the | |
* remaining sub-steps and continue to the next date-token. | |
* | |
* 2. If the found-day-of-month flag is not set and the date-token | |
* matches the day-of-month production, set the found-day-of- | |
* month flag and set the day-of-month-value to the number | |
* denoted by the date-token. Skip the remaining sub-steps and | |
* continue to the next date-token. | |
* | |
* 3. If the found-month flag is not set and the date-token matches | |
* the month production, set the found-month flag and set the | |
* month-value to the month denoted by the date-token. Skip the | |
* remaining sub-steps and continue to the next date-token. | |
* | |
* 4. If the found-year flag is not set and the date-token matches | |
* the year production, set the found-year flag and set the | |
* year-value to the number denoted by the date-token. Skip the | |
* remaining sub-steps and continue to the next date-token. | |
* | |
* 3. If the year-value is greater than or equal to 70 and less than or | |
* equal to 99, increment the year-value by 1900. | |
* | |
* 4. If the year-value is greater than or equal to 0 and less than or | |
* equal to 69, increment the year-value by 2000. | |
* | |
* 1. NOTE: Some existing user agents interpret two-digit years differently. | |
* | |
* 5. Abort these steps and fail to parse the cookie-date if: | |
* | |
* - at least one of the found-day-of-month, found-month, found- | |
* year, or found-time flags is not set, | |
* | |
* - the day-of-month-value is less than 1 or greater than 31, | |
* | |
* - the year-value is less than 1601, | |
* | |
* - the hour-value is greater than 23, | |
* | |
* - the minute-value is greater than 59, or | |
* | |
* - the second-value is greater than 59. | |
* | |
* (Note that leap seconds cannot be represented in this syntax.) | |
* | |
* 6. Let the parsed-cookie-date be the date whose day-of-month, month, | |
* year, hour, minute, and second (in UTC) are the day-of-month- | |
* value, the month-value, the year-value, the hour-value, the | |
* minute-value, and the second-value, respectively. If no such | |
* date exists, abort these steps and fail to parse the cookie-date. | |
* | |
* 7. Return the parsed-cookie-date as the result of this algorithm. | |
* | |
* @example | |
* ``` | |
* parseDate('Wed, 09 Jun 2021 10:18:14 GMT') | |
* ``` | |
* | |
* @param cookieDate - the cookie date string | |
* @public | |
*/ | |
export declare function parseDate(cookieDate: Nullable<string>): Date | undefined; | |