@bravobit/bb-foundation 0.42.0 → 0.42.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/auth/lib/auth.interceptor.d.ts +3 -6
- package/dialog/lib/dialog-confirm/dialog-confirm.component.d.ts +2 -5
- package/dialog/lib/dialog-container/dialog-container.component.d.ts +4 -6
- package/dialog/lib/dialog-overlay/dialog-overlay.component.d.ts +5 -7
- package/esm2022/auth/lib/auth.interceptor.mjs +36 -42
- package/esm2022/auth/lib/auth.module.mjs +4 -4
- package/esm2022/auth/lib/auth.service.mjs +18 -7
- package/esm2022/auth/lib/auth.session.mjs +26 -22
- package/esm2022/auth/lib/directives/authenticated.directive.mjs +16 -12
- package/esm2022/auth/lib/helpers/jwt.helper.mjs +29 -31
- package/esm2022/auth/lib/providers/email.provider.mjs +4 -1
- package/esm2022/auth/lib/providers/verify.provider.mjs +4 -1
- package/esm2022/collections/lib/collection.mjs +17 -7
- package/esm2022/collections/lib/collections.module.mjs +6 -6
- package/esm2022/collections/lib/components/collections-actions/collections-actions.component.mjs +7 -9
- package/esm2022/collections/lib/components/collections-grid/collections-grid.component.mjs +11 -11
- package/esm2022/collections/lib/components/collections-pager/collections-pager.component.mjs +10 -10
- package/esm2022/collections/lib/components/collections-table/collections-table.component.mjs +16 -16
- package/esm2022/collections/lib/components/collections-table-label/collections-table-label.component.mjs +9 -11
- package/esm2022/collections/lib/components/collections-table-sorting/collections-table-sorting.component.mjs +12 -9
- package/esm2022/collections/lib/components/collections-viewer/collections-viewer.component.mjs +10 -7
- package/esm2022/collections/lib/directives/collections-data-row.directive.mjs +6 -3
- package/esm2022/collections/lib/directives/collections-data.directive.mjs +6 -3
- package/esm2022/collections/lib/directives/collections-empty.directive.mjs +6 -3
- package/esm2022/collections/lib/directives/collections-error.directive.mjs +6 -3
- package/esm2022/collections/lib/directives/collections-initial.directive.mjs +4 -3
- package/esm2022/collections/lib/directives/collections-item.directive.mjs +6 -3
- package/esm2022/collections/lib/providers/api-collection.provider.mjs +6 -4
- package/esm2022/collections/lib/providers/local-collection.provider.mjs +2 -2
- package/esm2022/combobox/combobox/combobox-container.directive.mjs +12 -7
- package/esm2022/combobox/combobox/combobox.component.mjs +23 -20
- package/esm2022/combobox/combobox-label.directive.mjs +3 -3
- package/esm2022/combobox/combobox-option.directive.mjs +3 -3
- package/esm2022/combobox/combobox-panel/combobox-panel.component.mjs +10 -6
- package/esm2022/dashboard/lib/dashboard/dashboard.component.mjs +13 -13
- package/esm2022/dashboard/lib/dashboard-header/dashboard-header.component.mjs +5 -7
- package/esm2022/dashboard/lib/dashboard-menu/dashboard-menu.component.mjs +8 -10
- package/esm2022/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.mjs +5 -7
- package/esm2022/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.mjs +12 -13
- package/esm2022/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.mjs +13 -12
- package/esm2022/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.mjs +7 -5
- package/esm2022/dashboard/lib/dashboard.module.mjs +5 -5
- package/esm2022/dialog/lib/dialog-actions/dialog-actions.component.mjs +3 -3
- package/esm2022/dialog/lib/dialog-confirm/dialog-confirm.component.mjs +21 -20
- package/esm2022/dialog/lib/dialog-container/dialog-container.component.mjs +19 -24
- package/esm2022/dialog/lib/dialog-header/dialog-header.component.mjs +5 -7
- package/esm2022/dialog/lib/dialog-link/dialog-link.component.mjs +3 -3
- package/esm2022/dialog/lib/dialog-modal/dialog-modal.component.mjs +9 -6
- package/esm2022/dialog/lib/dialog-overlay/dialog-overlay.component.mjs +19 -26
- package/esm2022/dialog/lib/dialog.insertion.mjs +4 -3
- package/esm2022/dialog/lib/dialog.interfaces.mjs +4 -1
- package/esm2022/dialog/lib/dialog.module.mjs +6 -6
- package/esm2022/dialog/lib/dialog.ref.mjs +4 -6
- package/esm2022/dialog/lib/dialog.service.mjs +5 -3
- package/esm2022/dialog/lib/directives/confirm.directive.mjs +12 -14
- package/esm2022/elements/lib/avatar/avatar.component.mjs +75 -77
- package/esm2022/elements/lib/button/button.component.mjs +12 -10
- package/esm2022/elements/lib/checkbox/checkbox.component.mjs +21 -17
- package/esm2022/elements/lib/checkbox-group/checkbox-group.component.mjs +8 -10
- package/esm2022/elements/lib/date-picker/date-picker.component.mjs +82 -76
- package/esm2022/elements/lib/directives/addon.directive.mjs +5 -5
- package/esm2022/elements/lib/directives/extra-error-controls.directive.mjs +7 -9
- package/esm2022/elements/lib/directives/form-submit.directive.mjs +6 -3
- package/esm2022/elements/lib/directives/form-submitter.directive.mjs +5 -7
- package/esm2022/elements/lib/directives/image-upload.directive.mjs +14 -11
- package/esm2022/elements/lib/directives/input.directive.mjs +6 -4
- package/esm2022/elements/lib/elements.module.mjs +6 -6
- package/esm2022/elements/lib/file-picker/file-picker.component.mjs +52 -51
- package/esm2022/elements/lib/form-control/form-control.component.mjs +14 -14
- package/esm2022/elements/lib/form-error/form-error.component.mjs +16 -8
- package/esm2022/elements/lib/form-group/form-group.component.mjs +5 -7
- package/esm2022/elements/lib/icon/icon.component.mjs +14 -13
- package/esm2022/elements/lib/image-picker/image-picker.component.mjs +20 -17
- package/esm2022/elements/lib/multi-file-control/multi-file-control.component.mjs +28 -24
- package/esm2022/elements/lib/pipes/date.pipe.mjs +6 -8
- package/esm2022/elements/lib/pipes/file-image.pipe.mjs +6 -3
- package/esm2022/elements/lib/pipes/file-size.pipe.mjs +13 -15
- package/esm2022/elements/lib/pipes/relative-time.pipe.mjs +37 -35
- package/esm2022/elements/lib/radio-button/radio-button.component.mjs +8 -7
- package/esm2022/elements/lib/radio-group/radio-group.component.mjs +21 -20
- package/esm2022/elements/lib/spinner/spinner.component.mjs +7 -9
- package/esm2022/http/lib/classes/http.config.mjs +19 -15
- package/esm2022/http/lib/http.interfaces.mjs +1 -1
- package/esm2022/http/lib/http.module.mjs +5 -4
- package/esm2022/http/lib/interceptors/base-url.interceptor.mjs +12 -20
- package/esm2022/http/lib/interceptors/error.interceptor.mjs +9 -14
- package/esm2022/lib/core/services/exif.service.mjs +102 -100
- package/esm2022/lib/core/services/file-loader.service.mjs +15 -17
- package/esm2022/lib/core/services/files.service.mjs +7 -3
- package/esm2022/lib/core/services/image-converter.service.mjs +33 -30
- package/esm2022/lib/core/services/languages.service.mjs +25 -24
- package/esm2022/lib/core/services/network.service.mjs +8 -5
- package/esm2022/lib/core/services/patch.service.mjs +9 -6
- package/esm2022/localize/lib/dictionary/dictionary.class.mjs +7 -1
- package/esm2022/localize/lib/dictionary/dictionary.context.mjs +2 -4
- package/esm2022/localize/lib/dictionary/dictionary.data.mjs +2 -1
- package/esm2022/localize/lib/handlers/missing.handler.mjs +2 -4
- package/esm2022/localize/lib/localize.module.mjs +5 -5
- package/esm2022/localize/lib/localize.pipe.mjs +4 -3
- package/esm2022/localize/lib/localize.service.mjs +30 -21
- package/esm2022/localize/lib/transforms/interpolate.transform.mjs +5 -1
- package/esm2022/localize/lib/transforms/plural.transform.mjs +6 -4
- package/esm2022/localize/lib/transforms/reference.transform.mjs +3 -1
- package/esm2022/localize/lib/views/localize-string/localize-string.component.mjs +14 -11
- package/esm2022/localize/lib/views/localize-template.directive.mjs +6 -5
- package/esm2022/masking/lib/directives/currency-mask.directive.mjs +11 -6
- package/esm2022/masking/lib/directives/date-mask.directive.mjs +11 -6
- package/esm2022/masking/lib/directives/input-mask.directive.mjs +21 -14
- package/esm2022/masking/lib/masking.module.mjs +5 -5
- package/esm2022/masking/lib/masking.service.mjs +4 -3
- package/esm2022/notifications/lib/notifications-item/notifications-item.component.mjs +50 -36
- package/esm2022/notifications/lib/notifications-list/notifications-list.component.mjs +8 -7
- package/esm2022/notifications/lib/notifications.interfaces.mjs +10 -1
- package/esm2022/notifications/lib/notifications.module.mjs +4 -4
- package/esm2022/notifications/lib/notifications.service.mjs +24 -10
- package/esm2022/permissions/lib/directives/permission.directive.mjs +20 -14
- package/esm2022/permissions/lib/handlers/local.handler.mjs +3 -1
- package/esm2022/permissions/lib/permissions.interface.mjs +4 -1
- package/esm2022/permissions/lib/permissions.module.mjs +4 -4
- package/esm2022/permissions/lib/permissions.service.mjs +8 -7
- package/esm2022/recaptcha/lib/recaptcha/recaptcha.component.mjs +34 -27
- package/esm2022/recaptcha/lib/recaptcha-loader.service.mjs +15 -15
- package/esm2022/recaptcha/lib/recaptcha.module.mjs +4 -4
- package/esm2022/select/lib/select/select.component.mjs +52 -47
- package/esm2022/select/lib/select-label.directive.mjs +4 -3
- package/esm2022/select/lib/select-multi-label.directive.mjs +4 -3
- package/esm2022/select/lib/select-option-group.directive.mjs +4 -3
- package/esm2022/select/lib/select-option.directive.mjs +4 -3
- package/esm2022/select/lib/select.module.mjs +5 -5
- package/esm2022/storage/lib/storage.service.mjs +25 -21
- package/esm2022/storage/lib/strategies/cookie-storage.strategy.mjs +66 -64
- package/esm2022/storage/lib/strategies/memory-storage.strategy.mjs +16 -18
- package/esm2022/storage/lib/strategies/polyfill-storage.strategy.mjs +31 -30
- package/esm2022/table/lib/components/table/table.component.mjs +30 -20
- package/esm2022/table/lib/components/table-cell/table-cell.component.mjs +3 -3
- package/esm2022/table/lib/components/table-header-cell/table-header-cell.component.mjs +15 -11
- package/esm2022/table/lib/components/table-pager/table-pager.component.mjs +18 -16
- package/esm2022/table/lib/data/datasource.data.mjs +4 -6
- package/esm2022/table/lib/data/generic.data.mjs +38 -36
- package/esm2022/table/lib/table.module.mjs +6 -6
- package/esm2022/tooltip/lib/tooltip-container/tooltip-container.component.mjs +5 -7
- package/esm2022/tooltip/lib/tooltip.directive.mjs +15 -15
- package/esm2022/tooltip/lib/tooltip.module.mjs +4 -4
- package/esm2022/utils/lib/directives/autosize.directive.mjs +9 -7
- package/esm2022/utils/lib/directives/focus-trap.directive.mjs +24 -22
- package/esm2022/utils/lib/directives/focus.directive.mjs +8 -5
- package/esm2022/utils/lib/directives/template.directive.mjs +7 -3
- package/esm2022/utils/lib/utils.module.mjs +5 -5
- package/fesm2022/bravobit-bb-foundation-auth.mjs +127 -110
- package/fesm2022/bravobit-bb-foundation-auth.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-collections.mjs +123 -93
- package/fesm2022/bravobit-bb-foundation-collections.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-combobox.mjs +46 -34
- package/fesm2022/bravobit-bb-foundation-combobox.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-dashboard.mjs +60 -64
- package/fesm2022/bravobit-bb-foundation-dashboard.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-dialog.mjs +97 -103
- package/fesm2022/bravobit-bb-foundation-dialog.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-elements.mjs +468 -440
- package/fesm2022/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-http.mjs +40 -46
- package/fesm2022/bravobit-bb-foundation-http.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-localize.mjs +74 -49
- package/fesm2022/bravobit-bb-foundation-localize.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-masking.mjs +47 -29
- package/fesm2022/bravobit-bb-foundation-masking.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-notifications.mjs +91 -53
- package/fesm2022/bravobit-bb-foundation-notifications.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-permissions.mjs +34 -22
- package/fesm2022/bravobit-bb-foundation-permissions.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-recaptcha.mjs +50 -43
- package/fesm2022/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-select.mjs +67 -58
- package/fesm2022/bravobit-bb-foundation-select.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-storage.mjs +134 -129
- package/fesm2022/bravobit-bb-foundation-storage.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-table.mjs +107 -91
- package/fesm2022/bravobit-bb-foundation-table.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-tooltip.mjs +21 -23
- package/fesm2022/bravobit-bb-foundation-tooltip.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation-utils.mjs +48 -37
- package/fesm2022/bravobit-bb-foundation-utils.mjs.map +1 -1
- package/fesm2022/bravobit-bb-foundation.mjs +192 -178
- package/fesm2022/bravobit-bb-foundation.mjs.map +1 -1
- package/http/lib/http.interfaces.d.ts +2 -1
- package/http/lib/interceptors/base-url.interceptor.d.ts +2 -4
- package/http/lib/interceptors/error.interceptor.d.ts +1 -3
- package/package.json +13 -13
|
@@ -1,70 +1,11 @@
|
|
|
1
1
|
export class CookieStorage {
|
|
2
|
+
_isBrowser;
|
|
3
|
+
_cookieString;
|
|
4
|
+
// State.
|
|
5
|
+
_isSupported = false;
|
|
2
6
|
constructor(_isBrowser, _cookieString) {
|
|
3
7
|
this._isBrowser = _isBrowser;
|
|
4
8
|
this._cookieString = _cookieString;
|
|
5
|
-
// State.
|
|
6
|
-
this._isSupported = false;
|
|
7
|
-
this.decode = (cookieString) => {
|
|
8
|
-
const result = {};
|
|
9
|
-
const cookies = cookieString ? cookieString.split('; ') : [];
|
|
10
|
-
const rdecode = /(%[0-9A-Z]{2})+/g;
|
|
11
|
-
for (let index = 0; index < cookies.length; index++) {
|
|
12
|
-
const parts = cookies[index].split('=');
|
|
13
|
-
let cookie = parts.slice(1).join('=');
|
|
14
|
-
if (cookie.charAt(0) === '"') {
|
|
15
|
-
cookie = cookie.slice(1, -1);
|
|
16
|
-
}
|
|
17
|
-
try {
|
|
18
|
-
const name = parts[0].replace(rdecode, decodeURIComponent);
|
|
19
|
-
const value = cookie.replace(rdecode, decodeURIComponent);
|
|
20
|
-
result[name] = this.jsonParse(value);
|
|
21
|
-
}
|
|
22
|
-
catch {
|
|
23
|
-
// Ignore cookies with an invalid name/value encoding.
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
return result;
|
|
27
|
-
};
|
|
28
|
-
this.jsonParse = (rawValue) => {
|
|
29
|
-
// Try to parse the data.
|
|
30
|
-
let parsedValue = undefined;
|
|
31
|
-
// Only parse the value when it is not null.
|
|
32
|
-
if (rawValue !== undefined) {
|
|
33
|
-
try {
|
|
34
|
-
parsedValue = JSON.parse(rawValue);
|
|
35
|
-
}
|
|
36
|
-
catch {
|
|
37
|
-
// The string could not be parsed to JSON.
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
// Return the parsed value.
|
|
41
|
-
return parsedValue;
|
|
42
|
-
};
|
|
43
|
-
this.stringifyAttribute = (token, value) => {
|
|
44
|
-
if (!value) {
|
|
45
|
-
return '';
|
|
46
|
-
}
|
|
47
|
-
const stringified = `; ${token}`;
|
|
48
|
-
// Boolean attributes should not have a value.
|
|
49
|
-
if (value === true) {
|
|
50
|
-
return stringified;
|
|
51
|
-
}
|
|
52
|
-
return stringified + `= ${value}`;
|
|
53
|
-
};
|
|
54
|
-
this.testIfSupported = () => {
|
|
55
|
-
// We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled
|
|
56
|
-
// it does not return the correct value at all times.
|
|
57
|
-
const testCookieString = `bbcookietest`;
|
|
58
|
-
try {
|
|
59
|
-
document.cookie = `${testCookieString}=1`;
|
|
60
|
-
const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;
|
|
61
|
-
document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;
|
|
62
|
-
return result;
|
|
63
|
-
}
|
|
64
|
-
catch {
|
|
65
|
-
return false;
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
9
|
// Check if the storage is supported.
|
|
69
10
|
this._isSupported = this.testIfSupported();
|
|
70
11
|
}
|
|
@@ -119,6 +60,42 @@ export class CookieStorage {
|
|
|
119
60
|
// Return the completed encoded string.
|
|
120
61
|
return [encodedToken, '=', encodedValue, this.stringifyCookie(attributes)].join('');
|
|
121
62
|
}
|
|
63
|
+
decode = (cookieString) => {
|
|
64
|
+
const result = {};
|
|
65
|
+
const cookies = cookieString ? cookieString.split('; ') : [];
|
|
66
|
+
const rdecode = /(%[0-9A-Z]{2})+/g;
|
|
67
|
+
for (let index = 0; index < cookies.length; index++) {
|
|
68
|
+
const parts = cookies[index].split('=');
|
|
69
|
+
let cookie = parts.slice(1).join('=');
|
|
70
|
+
if (cookie.charAt(0) === '"') {
|
|
71
|
+
cookie = cookie.slice(1, -1);
|
|
72
|
+
}
|
|
73
|
+
try {
|
|
74
|
+
const name = parts[0].replace(rdecode, decodeURIComponent);
|
|
75
|
+
const value = cookie.replace(rdecode, decodeURIComponent);
|
|
76
|
+
result[name] = this.jsonParse(value);
|
|
77
|
+
}
|
|
78
|
+
catch {
|
|
79
|
+
// Ignore cookies with an invalid name/value encoding.
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return result;
|
|
83
|
+
};
|
|
84
|
+
jsonParse = (rawValue) => {
|
|
85
|
+
// Try to parse the data.
|
|
86
|
+
let parsedValue = undefined;
|
|
87
|
+
// Only parse the value when it is not null.
|
|
88
|
+
if (rawValue !== undefined) {
|
|
89
|
+
try {
|
|
90
|
+
parsedValue = JSON.parse(rawValue);
|
|
91
|
+
}
|
|
92
|
+
catch {
|
|
93
|
+
// The string could not be parsed to JSON.
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
// Return the parsed value.
|
|
97
|
+
return parsedValue;
|
|
98
|
+
};
|
|
122
99
|
stringifyCookie(attributes) {
|
|
123
100
|
// Make sure the expires attribute is a date and not a number.
|
|
124
101
|
if (typeof attributes.expires === 'number') {
|
|
@@ -138,5 +115,30 @@ export class CookieStorage {
|
|
|
138
115
|
+ this.stringifyAttribute('Secure', attributes.secure)
|
|
139
116
|
+ this.stringifyAttribute('SameSite', attributes.sameSite);
|
|
140
117
|
}
|
|
118
|
+
stringifyAttribute = (token, value) => {
|
|
119
|
+
if (!value) {
|
|
120
|
+
return '';
|
|
121
|
+
}
|
|
122
|
+
const stringified = `; ${token}`;
|
|
123
|
+
// Boolean attributes should not have a value.
|
|
124
|
+
if (value === true) {
|
|
125
|
+
return stringified;
|
|
126
|
+
}
|
|
127
|
+
return stringified + `= ${value}`;
|
|
128
|
+
};
|
|
129
|
+
testIfSupported = () => {
|
|
130
|
+
// We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled
|
|
131
|
+
// it does not return the correct value at all times.
|
|
132
|
+
const testCookieString = `bbcookietest`;
|
|
133
|
+
try {
|
|
134
|
+
document.cookie = `${testCookieString}=1`;
|
|
135
|
+
const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;
|
|
136
|
+
document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;
|
|
137
|
+
return result;
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
return false;
|
|
141
|
+
}
|
|
142
|
+
};
|
|
141
143
|
}
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookie-storage.strategy.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/storage/src/lib/strategies/cookie-storage.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import {CookieStorageAttributes} from '../interfaces/attributes.interface';\nimport {StorageStrategy} from '../interfaces/strategy.interface';\n\nexport class CookieStorage implements StorageStrategy {\n\n    // State.\n    private readonly _isSupported: boolean = false;\n\n    constructor(private _isBrowser: boolean,\n                private _cookieString?: string) {\n        // Check if the storage is supported.\n        this._isSupported = this.testIfSupported();\n    }\n\n    get<T = any>(token: string) {\n        // Get all values and pick one out.\n        const values = this.all();\n        return values?.[token] as T;\n    }\n\n    set<T = any>(token: string, value: T, attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        // Write a new cookie.\n        document.cookie = this.encode(token, value, {path: '/', sameSite: 'Lax', ...attributes});\n    }\n\n    remove(token: string, attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        this.set(token, '', {...attributes, expires: -1});\n    }\n\n    clear(attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        const items = this.all();\n\n        for (const token in items) {\n            this.remove(token, attributes);\n        }\n    }\n\n    isSupported() {\n        return this._isSupported;\n    }\n\n    private all() {\n        const cookieString = this._isBrowser\n            ? document?.cookie\n            : this._cookieString;\n\n        return this.decode(cookieString);\n    }\n\n    private encode(token: string, value: any, attributes: CookieStorageAttributes) {\n        // Encode the token.\n        const encodedToken = encodeURIComponent(token)\n            .replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n            .replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n\n        const rawValue = JSON.stringify(value);\n\n        // Encode the value.\n        const encodedValue = encodeURIComponent(rawValue)\n            .replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n        // Return the completed encoded string.\n        return [encodedToken, '=', encodedValue, this.stringifyCookie(attributes)].join('');\n    }\n\n    private decode = (cookieString: string) => {\n        const result: { [token: string]: any } = {};\n        const cookies = cookieString ? cookieString.split('; ') : [];\n        const rdecode = /(%[0-9A-Z]{2})+/g;\n\n        for (let index = 0; index < cookies.length; index++) {\n            const parts = cookies[index].split('=');\n            let cookie = parts.slice(1).join('=');\n\n            if (cookie.charAt(0) === '\"') {\n                cookie = cookie.slice(1, -1);\n            }\n\n            try {\n                const name = parts[0].replace(rdecode, decodeURIComponent);\n                const value = cookie.replace(rdecode, decodeURIComponent);\n                result[name] = this.jsonParse(value);\n            } catch {\n                // Ignore cookies with an invalid name/value encoding.\n            }\n        }\n\n        return result;\n    };\n\n    private jsonParse = <T = any>(rawValue: string) => {\n        // Try to parse the data.\n        let parsedValue: T | undefined = undefined;\n\n        // Only parse the value when it is not null.\n        if (rawValue !== undefined) {\n            try {\n                parsedValue = JSON.parse(rawValue);\n            } catch {\n                // The string could not be parsed to JSON.\n            }\n        }\n\n        // Return the parsed value.\n        return parsedValue;\n    };\n\n    private stringifyCookie(attributes: CookieStorageAttributes) {\n        // Make sure the expires attribute is a date and not a number.\n        if (typeof attributes.expires === 'number') {\n            const expires = new Date();\n            expires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5);\n            attributes.expires = expires;\n        }\n\n        // Force secure when sameSite=None.\n        if (attributes.sameSite === 'None') {\n            attributes.secure = true;\n            console?.warn?.('Cooke was forced with secure flag because sameSite=None');\n        }\n\n        // Stringify all attributes.\n        return this.stringifyAttribute('Expires', attributes.expires ? attributes.expires.toUTCString() : '')\n            + this.stringifyAttribute('Domain', attributes.domain)\n            + this.stringifyAttribute('Path', attributes.path)\n            + this.stringifyAttribute('Secure', attributes.secure)\n            + this.stringifyAttribute('SameSite', attributes.sameSite);\n    }\n\n    private stringifyAttribute = (token: string, value: string | boolean | undefined) => {\n        if (!value) {\n            return '';\n        }\n\n        const stringified = `; ${token}`;\n\n        // Boolean attributes should not have a value.\n        if (value === true) {\n            return stringified;\n        }\n\n        return stringified + `= ${value}`;\n    };\n\n    private testIfSupported = () => {\n        // We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled\n        // it does not return the correct value at all times.\n        const testCookieString = `bbcookietest`;\n        try {\n            document.cookie = `${testCookieString}=1`;\n            const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;\n            document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;\n            return result;\n        } catch {\n            return false;\n        }\n    };\n\n}\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cookie-storage.strategy.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/storage/src/lib/strategies/cookie-storage.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import {CookieStorageAttributes} from '../interfaces/attributes.interface';\nimport {StorageStrategy} from '../interfaces/strategy.interface';\n\nexport class CookieStorage implements StorageStrategy {\n\n    // State.\n    private readonly _isSupported: boolean = false;\n\n    constructor(private _isBrowser: boolean,\n                private _cookieString?: string) {\n        // Check if the storage is supported.\n        this._isSupported = this.testIfSupported();\n    }\n\n    get<T = any>(token: string) {\n        // Get all values and pick one out.\n        const values = this.all();\n        return values?.[token] as T;\n    }\n\n    set<T = any>(token: string, value: T, attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        // Write a new cookie.\n        document.cookie = this.encode(token, value, {path: '/', sameSite: 'Lax', ...attributes});\n    }\n\n    remove(token: string, attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        this.set(token, '', {...attributes, expires: -1});\n    }\n\n    clear(attributes?: CookieStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        const items = this.all();\n\n        for (const token in items) {\n            this.remove(token, attributes);\n        }\n    }\n\n    isSupported() {\n        return this._isSupported;\n    }\n\n    private all() {\n        const cookieString = this._isBrowser\n            ? document?.cookie\n            : this._cookieString;\n\n        return this.decode(cookieString);\n    }\n\n    private encode(token: string, value: any, attributes: CookieStorageAttributes) {\n        // Encode the token.\n        const encodedToken = encodeURIComponent(token)\n            .replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)\n            .replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n\n        const rawValue = JSON.stringify(value);\n\n        // Encode the value.\n        const encodedValue = encodeURIComponent(rawValue)\n            .replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\n        // Return the completed encoded string.\n        return [encodedToken, '=', encodedValue, this.stringifyCookie(attributes)].join('');\n    }\n\n    private decode = (cookieString: string) => {\n        const result: { [token: string]: any } = {};\n        const cookies = cookieString ? cookieString.split('; ') : [];\n        const rdecode = /(%[0-9A-Z]{2})+/g;\n\n        for (let index = 0; index < cookies.length; index++) {\n            const parts = cookies[index].split('=');\n            let cookie = parts.slice(1).join('=');\n\n            if (cookie.charAt(0) === '\"') {\n                cookie = cookie.slice(1, -1);\n            }\n\n            try {\n                const name = parts[0].replace(rdecode, decodeURIComponent);\n                const value = cookie.replace(rdecode, decodeURIComponent);\n                result[name] = this.jsonParse(value);\n            } catch {\n                // Ignore cookies with an invalid name/value encoding.\n            }\n        }\n\n        return result;\n    };\n\n    private jsonParse = <T = any>(rawValue: string) => {\n        // Try to parse the data.\n        let parsedValue: T | undefined = undefined;\n\n        // Only parse the value when it is not null.\n        if (rawValue !== undefined) {\n            try {\n                parsedValue = JSON.parse(rawValue);\n            } catch {\n                // The string could not be parsed to JSON.\n            }\n        }\n\n        // Return the parsed value.\n        return parsedValue;\n    };\n\n    private stringifyCookie(attributes: CookieStorageAttributes) {\n        // Make sure the expires attribute is a date and not a number.\n        if (typeof attributes.expires === 'number') {\n            const expires = new Date();\n            expires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5);\n            attributes.expires = expires;\n        }\n\n        // Force secure when sameSite=None.\n        if (attributes.sameSite === 'None') {\n            attributes.secure = true;\n            console?.warn?.('Cooke was forced with secure flag because sameSite=None');\n        }\n\n        // Stringify all attributes.\n        return this.stringifyAttribute('Expires', attributes.expires ? attributes.expires.toUTCString() : '')\n            + this.stringifyAttribute('Domain', attributes.domain)\n            + this.stringifyAttribute('Path', attributes.path)\n            + this.stringifyAttribute('Secure', attributes.secure)\n            + this.stringifyAttribute('SameSite', attributes.sameSite);\n    }\n\n    private stringifyAttribute = (token: string, value: string | boolean | undefined) => {\n        if (!value) {\n            return '';\n        }\n\n        const stringified = `; ${token}`;\n\n        // Boolean attributes should not have a value.\n        if (value === true) {\n            return stringified;\n        }\n\n        return stringified + `= ${value}`;\n    };\n\n    private testIfSupported = () => {\n        // We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled\n        // it does not return the correct value at all times.\n        const testCookieString = `bbcookietest`;\n        try {\n            document.cookie = `${testCookieString}=1`;\n            const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;\n            document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;\n            return result;\n        } catch {\n            return false;\n        }\n    };\n\n}\n"]}
|
|
@@ -1,21 +1,6 @@
|
|
|
1
1
|
export class MemoryStorage {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
this._storage = {};
|
|
5
|
-
this.encode = (value, attributes) => {
|
|
6
|
-
const data = { value };
|
|
7
|
-
// Make sure the expires is a date object.
|
|
8
|
-
if (typeof attributes.expires === 'number') {
|
|
9
|
-
attributes.expires = new Date(attributes.expires);
|
|
10
|
-
}
|
|
11
|
-
// Add the expire date if it was set.
|
|
12
|
-
if (attributes.expires) {
|
|
13
|
-
data['expires'] = attributes.expires;
|
|
14
|
-
}
|
|
15
|
-
// Return the encoded data.
|
|
16
|
-
return data;
|
|
17
|
-
};
|
|
18
|
-
}
|
|
2
|
+
// State.
|
|
3
|
+
_storage = {};
|
|
19
4
|
get(token) {
|
|
20
5
|
// Grab the data from the memory storage.
|
|
21
6
|
const result = this._storage[token];
|
|
@@ -52,5 +37,18 @@ export class MemoryStorage {
|
|
|
52
37
|
// The memory storage is always supported.
|
|
53
38
|
return true;
|
|
54
39
|
}
|
|
40
|
+
encode = (value, attributes) => {
|
|
41
|
+
const data = { value };
|
|
42
|
+
// Make sure the expires is a date object.
|
|
43
|
+
if (typeof attributes.expires === 'number') {
|
|
44
|
+
attributes.expires = new Date(attributes.expires);
|
|
45
|
+
}
|
|
46
|
+
// Add the expire date if it was set.
|
|
47
|
+
if (attributes.expires) {
|
|
48
|
+
data['expires'] = attributes.expires;
|
|
49
|
+
}
|
|
50
|
+
// Return the encoded data.
|
|
51
|
+
return data;
|
|
52
|
+
};
|
|
55
53
|
}
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVtb3J5LXN0b3JhZ2Uuc3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYi1mb3VuZGF0aW9uL3N0b3JhZ2Uvc3JjL2xpYi9zdHJhdGVnaWVzL21lbW9yeS1zdG9yYWdlLnN0cmF0ZWd5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sT0FBTyxhQUFhO0lBRXRCLFNBQVM7SUFDRCxRQUFRLEdBQXNCLEVBQUUsQ0FBQztJQUV6QyxHQUFHLENBQVUsS0FBYTtRQUN0Qix5Q0FBeUM7UUFDekMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVwQyw0QkFBNEI7UUFDNUIsSUFBSSxNQUFNLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDdkIsT0FBTyxTQUFTLENBQUM7UUFDckIsQ0FBQztRQUVELHFDQUFxQztRQUNyQyxNQUFNLEVBQUMsS0FBSyxFQUFFLE9BQU8sRUFBQyxHQUFHLE1BQU0sQ0FBQztRQUVoQyxxQ0FBcUM7UUFDckMsSUFBSSxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDeEIsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBQ3ZCLE1BQU0sVUFBVSxHQUFHLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBRS9DLHFDQUFxQztZQUNyQyxJQUFJLFVBQVUsSUFBSSxHQUFHLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDbkIsT0FBTyxTQUFTLENBQUM7WUFDckIsQ0FBQztRQUNMLENBQUM7UUFFRCxvQkFBb0I7UUFDcEIsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztJQUVELEdBQUcsQ0FBVSxLQUFhLEVBQUUsS0FBUSxFQUFFLFVBQW9DO1FBQ3RFLDhDQUE4QztRQUM5QyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUksS0FBSyxFQUFFLEVBQUMsR0FBRyxVQUFVLEVBQUMsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBYTtRQUNoQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVELEtBQUs7UUFDRCxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsV0FBVztRQUNQLDBDQUEwQztRQUMxQyxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU8sTUFBTSxHQUFHLENBQUksS0FBUSxFQUFFLFVBQW1DLEVBQUUsRUFBRTtRQUNsRSxNQUFNLElBQUksR0FBRyxFQUFDLEtBQUssRUFBQyxDQUFDO1FBRXJCLDBDQUEwQztRQUMxQyxJQUFJLE9BQU8sVUFBVSxDQUFDLE9BQU8sS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN6QyxVQUFVLENBQUMsT0FBTyxHQUFHLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0RCxDQUFDO1FBRUQscUNBQXFDO1FBQ3JDLElBQUksVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDO1FBQ3pDLENBQUM7UUFFRCwyQkFBMkI7UUFDM0IsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0NBRUwiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge01lbW9yeVN0b3JhZ2VBdHRyaWJ1dGVzfSBmcm9tICcuLi9pbnRlcmZhY2VzL2F0dHJpYnV0ZXMuaW50ZXJmYWNlJztcbmltcG9ydCB7TWVtb3J5U3RvcmFnZURhdGF9IGZyb20gJy4uL2ludGVyZmFjZXMvbWVtb3J5LmludGVyZmFjZSc7XG5pbXBvcnQge1N0b3JhZ2VTdHJhdGVneX0gZnJvbSAnLi4vaW50ZXJmYWNlcy9zdHJhdGVneS5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY2xhc3MgTWVtb3J5U3RvcmFnZSBpbXBsZW1lbnRzIFN0b3JhZ2VTdHJhdGVneSB7XG5cbiAgICAvLyBTdGF0ZS5cbiAgICBwcml2YXRlIF9zdG9yYWdlOiBNZW1vcnlTdG9yYWdlRGF0YSA9IHt9O1xuXG4gICAgZ2V0PFQgPSBhbnk+KHRva2VuOiBzdHJpbmcpOiBUIHtcbiAgICAgICAgLy8gR3JhYiB0aGUgZGF0YSBmcm9tIHRoZSBtZW1vcnkgc3RvcmFnZS5cbiAgICAgICAgY29uc3QgcmVzdWx0ID0gdGhpcy5fc3RvcmFnZVt0b2tlbl07XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgdGhlIGRhdGEgZXhpc3RzLlxuICAgICAgICBpZiAocmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgIH1cblxuICAgICAgICAvLyBFeHRyYWN0IHRoZSB2YWx1ZSBhbmQgZXhwaXJlIGRhdGUuXG4gICAgICAgIGNvbnN0IHt2YWx1ZSwgZXhwaXJlc30gPSByZXN1bHQ7XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgdGhlIHZhbHVlIGlzIHN0aWxsIHZhbGlkLlxuICAgICAgICBpZiAoZXhwaXJlcyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICAgICAgICAgICAgY29uc3QgZXhwaXJlRGF0ZSA9IG5ldyBEYXRlKGV4cGlyZXMpLmdldFRpbWUoKTtcblxuICAgICAgICAgICAgLy8gUmVtb3ZlIHRoZSB2YWx1ZSBpZiBpdCBpcyBleHBpcmVkLlxuICAgICAgICAgICAgaWYgKGV4cGlyZURhdGUgPD0gbm93KSB7XG4gICAgICAgICAgICAgICAgdGhpcy5yZW1vdmUodG9rZW4pO1xuICAgICAgICAgICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBSZXR1cm4gdGhlIHZhbHVlLlxuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfVxuXG4gICAgc2V0PFQgPSBhbnk+KHRva2VuOiBzdHJpbmcsIHZhbHVlOiBULCBhdHRyaWJ1dGVzPzogTWVtb3J5U3RvcmFnZUF0dHJpYnV0ZXMpIHtcbiAgICAgICAgLy8gU2F2ZSB0aGUgZW5jb2RlZCB2YWx1ZSB3aXRoIHRoZSBhdHRyaWJ1dGVzLlxuICAgICAgICB0aGlzLl9zdG9yYWdlW3Rva2VuXSA9IHRoaXMuZW5jb2RlPFQ+KHZhbHVlLCB7Li4uYXR0cmlidXRlc30pO1xuICAgIH1cblxuICAgIHJlbW92ZSh0b2tlbjogc3RyaW5nKSB7XG4gICAgICAgIGRlbGV0ZSB0aGlzLl9zdG9yYWdlW3Rva2VuXTtcbiAgICB9XG5cbiAgICBjbGVhcigpIHtcbiAgICAgICAgdGhpcy5fc3RvcmFnZSA9IHt9O1xuICAgIH1cblxuICAgIGlzU3VwcG9ydGVkKCkge1xuICAgICAgICAvLyBUaGUgbWVtb3J5IHN0b3JhZ2UgaXMgYWx3YXlzIHN1cHBvcnRlZC5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBlbmNvZGUgPSA8VD4odmFsdWU6IFQsIGF0dHJpYnV0ZXM6IE1lbW9yeVN0b3JhZ2VBdHRyaWJ1dGVzKSA9PiB7XG4gICAgICAgIGNvbnN0IGRhdGEgPSB7dmFsdWV9O1xuXG4gICAgICAgIC8vIE1ha2Ugc3VyZSB0aGUgZXhwaXJlcyBpcyBhIGRhdGUgb2JqZWN0LlxuICAgICAgICBpZiAodHlwZW9mIGF0dHJpYnV0ZXMuZXhwaXJlcyA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgICAgIGF0dHJpYnV0ZXMuZXhwaXJlcyA9IG5ldyBEYXRlKGF0dHJpYnV0ZXMuZXhwaXJlcyk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyBBZGQgdGhlIGV4cGlyZSBkYXRlIGlmIGl0IHdhcyBzZXQuXG4gICAgICAgIGlmIChhdHRyaWJ1dGVzLmV4cGlyZXMpIHtcbiAgICAgICAgICAgIGRhdGFbJ2V4cGlyZXMnXSA9IGF0dHJpYnV0ZXMuZXhwaXJlcztcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIFJldHVybiB0aGUgZW5jb2RlZCBkYXRhLlxuICAgICAgICByZXR1cm4gZGF0YTtcbiAgICB9O1xuXG59XG4iXX0=
|
|
@@ -1,35 +1,9 @@
|
|
|
1
1
|
export class PolyfillStorage {
|
|
2
|
+
_storage;
|
|
3
|
+
// State.
|
|
4
|
+
_isSupported = false;
|
|
2
5
|
constructor(_storage) {
|
|
3
6
|
this._storage = _storage;
|
|
4
|
-
// State.
|
|
5
|
-
this._isSupported = false;
|
|
6
|
-
this.encode = (value, attributes) => {
|
|
7
|
-
// Make sure the expires attribute is a date and not a number.
|
|
8
|
-
const data = { value };
|
|
9
|
-
if (typeof attributes.expires === 'number') {
|
|
10
|
-
attributes.expires = new Date(attributes.expires);
|
|
11
|
-
}
|
|
12
|
-
if (attributes.expires) {
|
|
13
|
-
data['expires'] = attributes.expires;
|
|
14
|
-
}
|
|
15
|
-
return JSON.stringify(data);
|
|
16
|
-
};
|
|
17
|
-
this.testIfSupported = () => {
|
|
18
|
-
if (typeof this._storage === 'undefined') {
|
|
19
|
-
return false;
|
|
20
|
-
}
|
|
21
|
-
try {
|
|
22
|
-
const x = '__storage_test__';
|
|
23
|
-
this._storage.setItem(x, x);
|
|
24
|
-
this._storage.removeItem(x);
|
|
25
|
-
return true;
|
|
26
|
-
}
|
|
27
|
-
catch (error) {
|
|
28
|
-
return error instanceof DOMException
|
|
29
|
-
&& (error.name === 'QuotaExceededError' || error.name === 'NS_ERROR_DOM_QUOTA_REACHED')
|
|
30
|
-
&& (this._storage && this._storage.length !== 0);
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
7
|
// Check if the storage is supported.
|
|
34
8
|
this._isSupported = this.testIfSupported();
|
|
35
9
|
}
|
|
@@ -95,5 +69,32 @@ export class PolyfillStorage {
|
|
|
95
69
|
// Return the parsed data.
|
|
96
70
|
return parsedData;
|
|
97
71
|
}
|
|
72
|
+
encode = (value, attributes) => {
|
|
73
|
+
// Make sure the expires attribute is a date and not a number.
|
|
74
|
+
const data = { value };
|
|
75
|
+
if (typeof attributes.expires === 'number') {
|
|
76
|
+
attributes.expires = new Date(attributes.expires);
|
|
77
|
+
}
|
|
78
|
+
if (attributes.expires) {
|
|
79
|
+
data['expires'] = attributes.expires;
|
|
80
|
+
}
|
|
81
|
+
return JSON.stringify(data);
|
|
82
|
+
};
|
|
83
|
+
testIfSupported = () => {
|
|
84
|
+
if (typeof this._storage === 'undefined') {
|
|
85
|
+
return false;
|
|
86
|
+
}
|
|
87
|
+
try {
|
|
88
|
+
const x = '__storage_test__';
|
|
89
|
+
this._storage.setItem(x, x);
|
|
90
|
+
this._storage.removeItem(x);
|
|
91
|
+
return true;
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
return error instanceof DOMException
|
|
95
|
+
&& (error.name === 'QuotaExceededError' || error.name === 'NS_ERROR_DOM_QUOTA_REACHED')
|
|
96
|
+
&& (this._storage && this._storage.length !== 0);
|
|
97
|
+
}
|
|
98
|
+
};
|
|
98
99
|
}
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"polyfill-storage.strategy.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/storage/src/lib/strategies/polyfill-storage.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import {PolyfillStorageAttributes} from '../interfaces/attributes.interface';\nimport {StorageStrategy} from '../interfaces/strategy.interface';\n\nexport class PolyfillStorage implements StorageStrategy {\n\n    // State.\n    private readonly _isSupported: boolean = false;\n\n    constructor(private _storage?: Storage) {\n        // Check if the storage is supported.\n        this._isSupported = this.testIfSupported();\n    }\n\n    get<T = any>(token: string) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return undefined;\n        }\n\n        return this.decode<T>(token);\n    }\n\n    set<T = any>(token: string, value: T, attributes?: PolyfillStorageAttributes) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        // Stringify the data.\n        const rawData = this.encode<T>(value, {...attributes});\n\n        // Set the raw data in the storage.\n        this._storage.setItem(token, rawData);\n    }\n\n    remove(token: string) {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        // Remove the item in the storage.\n        this._storage.removeItem(token);\n    }\n\n    clear() {\n        // Validate that the storage is supported.\n        if (!this._isSupported) {\n            return;\n        }\n\n        // Clear the storage.\n        this._storage.clear();\n    }\n\n    isSupported() {\n        return this._isSupported;\n    }\n\n    private decode<T>(token: string) {\n        // Retrieve the raw data from the storage.\n        const rawData = this._storage.getItem(token);\n\n        // Try to parse the data.\n        let parsedData: T | undefined = undefined;\n\n        // Only parse the data when it is not null.\n        if (rawData !== null) {\n            try {\n                const {value, expires} = JSON.parse(rawData);\n\n                if (expires !== undefined) {\n                    const now = Date.now();\n                    const expireDate = new Date(expires).getTime();\n\n                    if (expireDate <= now) {\n                        this.remove(token);\n                        return undefined;\n                    }\n                }\n\n                parsedData = value;\n            } catch {\n                // We dont do anything with failed parsing.\n            }\n        }\n\n        // Return the parsed data.\n        return parsedData;\n    }\n\n    private encode = <T>(value: T, attributes: PolyfillStorageAttributes) => {\n        // Make sure the expires attribute is a date and not a number.\n        const data = {value};\n\n        if (typeof attributes.expires === 'number') {\n            attributes.expires = new Date(attributes.expires);\n        }\n\n        if (attributes.expires) {\n            data['expires'] = attributes.expires;\n        }\n\n        return JSON.stringify(data);\n    };\n\n    private testIfSupported = () => {\n        if (typeof this._storage === 'undefined') {\n            return false;\n        }\n\n        try {\n            const x = '__storage_test__';\n            this._storage.setItem(x, x);\n            this._storage.removeItem(x);\n            return true;\n        } catch (error) {\n            return error instanceof DOMException\n                && (error.name === 'QuotaExceededError' || error.name === 'NS_ERROR_DOM_QUOTA_REACHED')\n                && (this._storage && this._storage.length !== 0);\n        }\n    };\n\n}\n"]}
|