; | |
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); | |
} | |