@terminus/ngx-tools
Version:
[![CircleCI][circle-badge]][circle-link] [![codecov][codecov-badge]][codecov-project] [![semantic-release][semantic-release-badge]][semantic-release] [![MIT License][license-image]][license-url] <br> [![NPM version][npm-version-image]][npm-url] [![Github
179 lines • 20.5 kB
JavaScript
import { __decorate, __param } from "tslib";
/**
* Sourced from MIT Licensed Library
* https://github.com/7leads/ngx-cookie-service
*/
import { DOCUMENT, isPlatformBrowser, } from '@angular/common';
import { Inject, Injectable, InjectionToken, PLATFORM_ID, } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
var MS_IN_SECONDS = 1000;
var SECONDS_IN_MINUTE = 60;
var MINUTES_IN_HOUR = 60;
var HOURS_IN_DAY = 24;
var MS_IN_DAY = MS_IN_SECONDS * SECONDS_IN_MINUTE * MINUTES_IN_HOUR * HOURS_IN_DAY;
/**
* A service to manage browser cookies
*/
var TsCookieService = /** @class */ (function () {
function TsCookieService(
// HACK: This `any` is required. See comment inside constructor.
// eslint-disable-next-line @typescript-eslint/no-explicit-any
_document, platformId) {
this._document = _document;
this.platformId = platformId;
// HACK: The angular compiler doesn't understand the type `Document` when determining the metadata for injectable parameters.
// So we are using `any` for the injection signature (making Angular happy), but coercing to a TypeScript type within the class.
// See https://github.com/angular/angular/issues/20351
this.document = _document;
// The PLATFORM_ID allows us to check if we're in a browser
this.documentIsAccessible = isPlatformBrowser(platformId);
}
/**
* Set a cookie
*
* @param name - Cookie name
* @param value - Cookie value
* @param expires - Number of days until the cookies expires or an actual `Date`
* @param path - Cookie path
* @param domain - Cookie domain
* @param secure - Secure flag
* @param sameSite - OWASP samesite token `Lax` or `Strict`
*/
TsCookieService.prototype.set = function (name, value, expires, path, domain, secure, sameSite) {
if (!this.documentIsAccessible) {
return;
}
var cookieString = encodeURIComponent(name) + "=" + encodeURIComponent(value) + ";";
if (expires) {
if (typeof expires === 'number') {
var dateExpires = new Date(new Date().getTime() + (expires * MS_IN_DAY));
cookieString += "expires=" + dateExpires.toUTCString() + ";";
}
else {
cookieString += "expires=" + expires.toUTCString() + ";";
}
}
if (path) {
cookieString += "path=" + path + ";";
}
if (domain) {
cookieString += "domain=" + domain + ";";
}
if (secure) {
cookieString += 'secure;';
}
if (sameSite) {
cookieString += "sameSite=" + sameSite + ";";
}
this.document.cookie = cookieString;
};
/**
* Verify if a cookie exists
*
* @param name - Cookie name
* @returns boolean
*/
TsCookieService.prototype.check = function (name) {
if (!this.documentIsAccessible) {
return false;
}
var regExp = this.getCookieRegExp(encodeURIComponent(name));
return regExp.test(this.document.cookie);
};
/**
* @param name - Cookie name
* @returns any
*/
TsCookieService.prototype.get = function (name) {
if (this.documentIsAccessible && this.check(name)) {
var regExp = this.getCookieRegExp(encodeURIComponent(name));
var result = regExp.exec(this.document.cookie);
return result ? decodeURIComponent(result[1]) /* istanbul ignore next - Unreachable */ : '';
}
return '';
};
/**
* Get all cookies
*
* @returns Object containing all cookies
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
TsCookieService.prototype.getAll = function () {
if (!this.documentIsAccessible) {
return {};
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
var cookies = {};
var document = this.document;
// istanbul ignore else
if (document.cookie && document.cookie !== '') {
var split = document.cookie.split(';').filter(function (v) { return v !== ''; });
// eslint-disable-next-line @typescript-eslint/prefer-for-of
for (var i = 0; i < split.length; i += 1) {
var currentCookie = split[i].split('=');
currentCookie[0] = currentCookie[0].replace(/^ /, '');
cookies[decodeURIComponent(currentCookie[0])] = decodeURIComponent(currentCookie[1]);
}
}
return cookies;
};
/**
* Delete a cookie
*
* NOTE: This clears the value and sets the cookie as expired. The browser will delete the expired cookie the next time a request
* is made to the domain.
*
* @param name - Cookie name
* @param path - Cookie path
* @param domain - Cookie domain
*/
TsCookieService.prototype.delete = function (name, path, domain) {
if (!this.documentIsAccessible) {
return;
}
this.set(name, '', new Date('Thu, 01 Jan 1970 00:00:01 GMT'), path, domain);
};
/**
* Delete all cookies
*
* @param path - Cookie path
* @param domain - Cookie domain
*/
TsCookieService.prototype.deleteAll = function (path, domain) {
if (!this.documentIsAccessible) {
return;
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
var cookies = this.getAll();
for (var cookieName in cookies) {
// istanbul ignore else
if (cookies.hasOwnProperty(cookieName)) {
this.delete(cookieName, path, domain);
}
}
};
/**
* Get a regular expression based on a cookie name
*
* @param name - Cookie name
* @returns RegExp
*/
TsCookieService.prototype.getCookieRegExp = function (name) {
var escapedName = name.replace(/([\[\]\{\}\(\)\|\=\;\+\?\,\.\*\^\$])/ig, '\\$1');
return new RegExp("(?:^" + escapedName + "|;\\s*" + escapedName + ")=(.*?)(?:;|$)", 'g');
};
TsCookieService.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: InjectionToken, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
]; };
TsCookieService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TsCookieService_Factory() { return new TsCookieService(i0.ɵɵinject(i1.DOCUMENT), i0.ɵɵinject(i0.PLATFORM_ID)); }, token: TsCookieService, providedIn: "root" });
TsCookieService = __decorate([
Injectable({ providedIn: 'root' }),
__param(0, Inject(DOCUMENT)),
__param(1, Inject(PLATFORM_ID))
], TsCookieService);
return TsCookieService;
}());
export { TsCookieService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookies.service.js","sourceRoot":"ng://@terminus/ngx-tools/browser/","sources":["cookies/cookies.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Sourced from MIT Licensed Library\n * https://github.com/7leads/ngx-cookie-service\n */\nimport {\n  DOCUMENT,\n  isPlatformBrowser,\n} from '@angular/common';\nimport {\n  Inject,\n  Injectable,\n  InjectionToken,\n  PLATFORM_ID,\n} from '@angular/core';\n\nconst MS_IN_SECONDS = 1000;\nconst SECONDS_IN_MINUTE = 60;\nconst MINUTES_IN_HOUR = 60;\nconst HOURS_IN_DAY = 24;\nconst MS_IN_DAY = MS_IN_SECONDS * SECONDS_IN_MINUTE * MINUTES_IN_HOUR * HOURS_IN_DAY;\n\n\n/**\n * A service to manage browser cookies\n */\n@Injectable({ providedIn: 'root' })\nexport class TsCookieService {\n  private readonly documentIsAccessible: boolean;\n  private readonly document: Document;\n\n  constructor(\n    // HACK: This `any` is required. See comment inside constructor.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Inject(DOCUMENT) private _document: any,\n    @Inject(PLATFORM_ID) private platformId: InjectionToken<Object>,\n  ) {\n    // HACK: The angular compiler doesn't understand the type `Document` when determining the metadata for injectable parameters.\n    // So we are using `any` for the injection signature (making Angular happy), but coercing to a TypeScript type within the class.\n    // See https://github.com/angular/angular/issues/20351\n    this.document = _document as Document;\n    // The PLATFORM_ID allows us to check if we're in a browser\n    this.documentIsAccessible = isPlatformBrowser(platformId);\n  }\n\n  /**\n   * Set a cookie\n   *\n   * @param name - Cookie name\n   * @param value - Cookie value\n   * @param expires - Number of days until the cookies expires or an actual `Date`\n   * @param path - Cookie path\n   * @param domain - Cookie domain\n   * @param secure - Secure flag\n   * @param sameSite - OWASP samesite token `Lax` or `Strict`\n   */\n  public set(\n    name: string,\n    value: string,\n    expires?: number | Date,\n    path?: string,\n    domain?: string,\n    secure?: boolean,\n    sameSite?: 'Lax' | 'Strict',\n  ): void {\n    if (!this.documentIsAccessible) {\n      return;\n    }\n\n    let cookieString = `${encodeURIComponent(name)}=${encodeURIComponent(value)};`;\n\n    if (expires) {\n      if (typeof expires === 'number') {\n        const dateExpires: Date = new Date(new Date().getTime() + (expires * MS_IN_DAY));\n\n        cookieString += `expires=${dateExpires.toUTCString()};`;\n      } else {\n        cookieString += `expires=${expires.toUTCString()};`;\n      }\n    }\n\n    if (path) {\n      cookieString += `path=${path};`;\n    }\n\n    if (domain) {\n      cookieString += `domain=${domain};`;\n    }\n\n    if (secure) {\n      cookieString += 'secure;';\n    }\n\n    if (sameSite) {\n      cookieString += `sameSite=${sameSite};`;\n    }\n\n    this.document.cookie = cookieString;\n  }\n\n  /**\n   * Verify if a cookie exists\n   *\n   * @param name - Cookie name\n   * @returns boolean\n   */\n  public check(name: string): boolean {\n    if (!this.documentIsAccessible) {\n      return false;\n    }\n\n    const regExp: RegExp = this.getCookieRegExp(encodeURIComponent(name));\n    return regExp.test(this.document.cookie);\n  }\n\n  /**\n   * @param name - Cookie name\n   * @returns any\n   */\n  public get(name: string): string {\n    if (this.documentIsAccessible && this.check(name)) {\n      const regExp: RegExp = this.getCookieRegExp(encodeURIComponent(name));\n      const result: RegExpExecArray | null = regExp.exec(this.document.cookie);\n\n      return result ? decodeURIComponent(result[1]) /* istanbul ignore next - Unreachable */ : '';\n    }\n    return '';\n  }\n\n  /**\n   * Get all cookies\n   *\n   * @returns Object containing all cookies\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public getAll(): Record<string, any> {\n    if (!this.documentIsAccessible) {\n      return {};\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const cookies: Record<string, any> = {};\n    const document = this.document;\n\n    // istanbul ignore else\n    if (document.cookie && document.cookie !== '') {\n      const split: string[] = document.cookie.split(';').filter(v => v !== '');\n\n      // eslint-disable-next-line @typescript-eslint/prefer-for-of\n      for (let i = 0; i < split.length; i += 1) {\n        const currentCookie: string[] = split[i].split('=');\n        currentCookie[0] = currentCookie[0].replace(/^ /, '');\n        cookies[decodeURIComponent(currentCookie[0])] = decodeURIComponent(currentCookie[1]);\n      }\n    }\n\n    return cookies;\n  }\n\n  /**\n   * Delete a cookie\n   *\n   * NOTE: This clears the value and sets the cookie as expired. The browser will delete the expired cookie the next time a request\n   * is made to the domain.\n   *\n   * @param name - Cookie name\n   * @param path - Cookie path\n   * @param domain - Cookie domain\n   */\n  public delete(name: string, path?: string, domain?: string): void {\n    if (!this.documentIsAccessible) {\n      return;\n    }\n    this.set(name, '', new Date('Thu, 01 Jan 1970 00:00:01 GMT'), path, domain);\n  }\n\n  /**\n   * Delete all cookies\n   *\n   * @param path - Cookie path\n   * @param domain - Cookie domain\n   */\n  public deleteAll(path?: string, domain?: string): void {\n    if (!this.documentIsAccessible) {\n      return;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const cookies: Record<string, any> = this.getAll();\n\n    for (const cookieName in cookies) {\n      // istanbul ignore else\n      if (cookies.hasOwnProperty(cookieName)) {\n        this.delete(cookieName, path, domain);\n      }\n    }\n  }\n\n  /**\n   * Get a regular expression based on a cookie name\n   *\n   * @param name - Cookie name\n   * @returns RegExp\n   */\n  private getCookieRegExp(name: string): RegExp {\n    const escapedName: string = name.replace(/([\\[\\]\\{\\}\\(\\)\\|\\=\\;\\+\\?\\,\\.\\*\\^\\$])/ig, '\\\\$1');\n    return new RegExp(`(?:^${escapedName}|;\\\\s*${escapedName})=(.*?)(?:;|$)`, 'g');\n  }\n\n}\n"]}