61 lines
2.4 KiB
JavaScript
61 lines
2.4 KiB
JavaScript
|
"use strict";
|
||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||
|
exports.defaultPath = defaultPath;
|
||
|
/**
|
||
|
* Given a current request/response path, gives the path appropriate for storing
|
||
|
* in a cookie. This is basically the "directory" of a "file" in the path, but
|
||
|
* is specified by {@link https://www.rfc-editor.org/rfc/rfc6265.html#section-5.1.4 | RFC6265 - Section 5.1.4}.
|
||
|
*
|
||
|
* @remarks
|
||
|
* ### RFC6265 - Section 5.1.4
|
||
|
*
|
||
|
* The user agent MUST use an algorithm equivalent to the following algorithm to compute the default-path of a cookie:
|
||
|
*
|
||
|
* 1. Let uri-path be the path portion of the request-uri if such a
|
||
|
* portion exists (and empty otherwise). For example, if the
|
||
|
* request-uri contains just a path (and optional query string),
|
||
|
* then the uri-path is that path (without the %x3F ("?") character
|
||
|
* or query string), and if the request-uri contains a full
|
||
|
* absoluteURI, the uri-path is the path component of that URI.
|
||
|
*
|
||
|
* 2. If the uri-path is empty or if the first character of the uri-
|
||
|
* path is not a %x2F ("/") character, output %x2F ("/") and skip
|
||
|
* the remaining steps.
|
||
|
*
|
||
|
* 3. If the uri-path contains no more than one %x2F ("/") character,
|
||
|
* output %x2F ("/") and skip the remaining step.
|
||
|
*
|
||
|
* 4. Output the characters of the uri-path from the first character up
|
||
|
* to, but not including, the right-most %x2F ("/").
|
||
|
*
|
||
|
* @example
|
||
|
* ```
|
||
|
* defaultPath('') === '/'
|
||
|
* defaultPath('/some-path') === '/'
|
||
|
* defaultPath('/some-parent-path/some-path') === '/some-parent-path'
|
||
|
* defaultPath('relative-path') === '/'
|
||
|
* ```
|
||
|
*
|
||
|
* @param path - the path portion of the request-uri (excluding the hostname, query, fragment, and so on)
|
||
|
* @public
|
||
|
*/
|
||
|
function defaultPath(path) {
|
||
|
// "2. If the uri-path is empty or if the first character of the uri-path is not
|
||
|
// a %x2F ("/") character, output %x2F ("/") and skip the remaining steps.
|
||
|
if (!path || path.slice(0, 1) !== '/') {
|
||
|
return '/';
|
||
|
}
|
||
|
// "3. If the uri-path contains no more than one %x2F ("/") character, output
|
||
|
// %x2F ("/") and skip the remaining step."
|
||
|
if (path === '/') {
|
||
|
return path;
|
||
|
}
|
||
|
const rightSlash = path.lastIndexOf('/');
|
||
|
if (rightSlash === 0) {
|
||
|
return '/';
|
||
|
}
|
||
|
// "4. Output the characters of the uri-path from the first character up to,
|
||
|
// but not including, the right-most %x2F ("/")."
|
||
|
return path.slice(0, rightSlash);
|
||
|
}
|