@did-btcr2/common 2.2.2 → 3.0.0
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/dist/cjs/canonicalization.js +66 -54
- package/dist/cjs/canonicalization.js.map +1 -1
- package/dist/cjs/constants.js +17 -11
- package/dist/cjs/constants.js.map +1 -1
- package/dist/cjs/index.js +5 -3
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/json-patch.js +98 -0
- package/dist/cjs/json-patch.js.map +1 -0
- package/dist/cjs/logger.js +46 -12
- package/dist/cjs/logger.js.map +1 -1
- package/dist/cjs/utils/date.js +32 -0
- package/dist/cjs/utils/date.js.map +1 -0
- package/dist/cjs/utils/json.js +280 -0
- package/dist/cjs/utils/json.js.map +1 -0
- package/dist/cjs/utils/set.js +23 -0
- package/dist/cjs/utils/set.js.map +1 -0
- package/dist/cjs/utils/string.js +55 -0
- package/dist/cjs/utils/string.js.map +1 -0
- package/dist/esm/canonicalization.js +66 -54
- package/dist/esm/canonicalization.js.map +1 -1
- package/dist/esm/constants.js +17 -11
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/index.js +5 -3
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/json-patch.js +98 -0
- package/dist/esm/json-patch.js.map +1 -0
- package/dist/esm/logger.js +46 -12
- package/dist/esm/logger.js.map +1 -1
- package/dist/esm/utils/date.js +32 -0
- package/dist/esm/utils/date.js.map +1 -0
- package/dist/esm/utils/json.js +280 -0
- package/dist/esm/utils/json.js.map +1 -0
- package/dist/esm/utils/set.js +23 -0
- package/dist/esm/utils/set.js.map +1 -0
- package/dist/esm/utils/string.js +55 -0
- package/dist/esm/utils/string.js.map +1 -0
- package/dist/types/canonicalization.d.ts +38 -29
- package/dist/types/canonicalization.d.ts.map +1 -1
- package/dist/types/constants.d.ts +6 -8
- package/dist/types/constants.d.ts.map +1 -1
- package/dist/types/index.d.ts +5 -3
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/interfaces.d.ts +2 -2
- package/dist/types/interfaces.d.ts.map +1 -1
- package/dist/types/json-patch.d.ts +47 -0
- package/dist/types/json-patch.d.ts.map +1 -0
- package/dist/types/logger.d.ts +31 -8
- package/dist/types/logger.d.ts.map +1 -1
- package/dist/types/types.d.ts +11 -4
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/utils/date.d.ts +19 -0
- package/dist/types/utils/date.d.ts.map +1 -0
- package/dist/types/utils/json.d.ts +89 -0
- package/dist/types/utils/json.d.ts.map +1 -0
- package/dist/types/utils/set.d.ts +14 -0
- package/dist/types/utils/set.d.ts.map +1 -0
- package/dist/types/utils/string.d.ts +39 -0
- package/dist/types/utils/string.d.ts.map +1 -0
- package/package.json +3 -4
- package/src/canonicalization.ts +75 -58
- package/src/constants.ts +19 -12
- package/src/index.ts +5 -5
- package/src/interfaces.ts +2 -2
- package/src/json-patch.ts +103 -0
- package/src/logger.ts +59 -27
- package/src/types.ts +11 -6
- package/src/utils/date.ts +32 -0
- package/src/utils/json.ts +315 -0
- package/src/utils/set.ts +23 -0
- package/src/utils/string.ts +59 -0
- package/dist/cjs/exts.js +0 -189
- package/dist/cjs/exts.js.map +0 -1
- package/dist/cjs/patch.js +0 -163
- package/dist/cjs/patch.js.map +0 -1
- package/dist/esm/exts.js +0 -189
- package/dist/esm/exts.js.map +0 -1
- package/dist/esm/patch.js +0 -163
- package/dist/esm/patch.js.map +0 -1
- package/dist/types/exts.d.ts +0 -90
- package/dist/types/exts.d.ts.map +0 -1
- package/dist/types/patch.d.ts +0 -63
- package/dist/types/patch.d.ts.map +0 -1
- package/src/exts.ts +0 -310
- package/src/patch.ts +0 -181
- package/src/rdf-canonize.d.ts +0 -6
package/src/types.ts
CHANGED
|
@@ -72,14 +72,18 @@ export type BeaconUri = string;
|
|
|
72
72
|
export type DidPlaceholder = 'did:btcr2:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx';
|
|
73
73
|
export type CanonicalizedProofConfig = string;
|
|
74
74
|
export type CryptosuiteName = 'bip340-jcs-2025' | 'bip340-rdfc-2025';
|
|
75
|
-
export type
|
|
75
|
+
export type JsonPrimitive = string | number | boolean | null;
|
|
76
|
+
export type JsonArray = JsonValue[];
|
|
77
|
+
export type JsonValue = JsonPrimitive | JsonArray | JsonObject;
|
|
78
|
+
export type JsonObject = { [key: string]: JsonValue };
|
|
79
|
+
export type JSONObject = JsonObject; // JSON object: prototyped or unprototyped
|
|
80
|
+
export type Prototyped = JSONObject;
|
|
81
|
+
export type Unprototyped = JSONObject;
|
|
82
|
+
export type ContextObject = Record<string, JsonValue>;
|
|
76
83
|
export type Context = string | string[] | ContextObject | ContextObject[]
|
|
77
84
|
|
|
78
85
|
/* General Types */
|
|
79
|
-
export type Maybe<T> = T |
|
|
80
|
-
export type JSONObject = Record<string | number | symbol, any>; // JSON object: prototyped or unprototyped
|
|
81
|
-
export type Prototyped = JSONObject;
|
|
82
|
-
export type Unprototyped = JSONObject;
|
|
86
|
+
export type Maybe<T> = T | unknown;
|
|
83
87
|
export type TwoDigits = `${number}${number}`;
|
|
84
88
|
export type ThreeDigits = `${number}${number}${number}`;
|
|
85
89
|
export type Year = `${1 | 2}${ThreeDigits}`;
|
|
@@ -93,4 +97,5 @@ export type TzOffset = `${Hours}:${Minutes}`;
|
|
|
93
97
|
export type DateTimestamp = `${UtcTimestamp}Z` | `${UtcTimestamp}-${TzOffset}`;
|
|
94
98
|
export type CanonicalizableObject = Record<string, any>;
|
|
95
99
|
export type CanonicalizationAlgorithm = 'jcs' | 'rdfc';
|
|
96
|
-
export type
|
|
100
|
+
export type CanonicalizationEncoding = 'hex' | 'base58';
|
|
101
|
+
export type UnixTimestamp = number;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility class for date-related operations.
|
|
3
|
+
* @name DateUtils
|
|
4
|
+
* @class DateUtils
|
|
5
|
+
*/
|
|
6
|
+
export class DateUtils {
|
|
7
|
+
/**
|
|
8
|
+
* Render an ISO 8601 UTC timestamp without fractional seconds.
|
|
9
|
+
* @param {Date} [date=new Date()] - The date to format.
|
|
10
|
+
* @returns {string} The formatted date string.
|
|
11
|
+
*/
|
|
12
|
+
static getUTCDateTime(date: Date = new Date()): string {
|
|
13
|
+
const time = date.getTime();
|
|
14
|
+
if (Number.isNaN(time)) {
|
|
15
|
+
throw new Error(`Invalid date: ${date}`);
|
|
16
|
+
}
|
|
17
|
+
return date.toISOString().replace(/\.\d{3}Z$/, 'Z');
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Unix timestamp in seconds (integer).
|
|
22
|
+
* @param {Date} [date=new Date()] - The date to convert.
|
|
23
|
+
* @returns {number} The Unix timestamp in seconds.
|
|
24
|
+
*/
|
|
25
|
+
static toUnixSeconds(date: Date = new Date()): number {
|
|
26
|
+
const time = date.getTime();
|
|
27
|
+
if (Number.isNaN(time)) {
|
|
28
|
+
throw new Error(`Invalid date: ${date}`);
|
|
29
|
+
}
|
|
30
|
+
return Math.floor(date.getTime() / 1000);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
import { JSONObject, Prototyped, Unprototyped } from '../types.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Options for cloning JSON values.
|
|
5
|
+
*/
|
|
6
|
+
type CloneOptions = {
|
|
7
|
+
stripPrototypes?: boolean;
|
|
8
|
+
transform?: (value: any) => any;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Utilities for working with JSON data.
|
|
13
|
+
* @name JSONUtils
|
|
14
|
+
* @class JSONUtils
|
|
15
|
+
*/
|
|
16
|
+
export class JSONUtils {
|
|
17
|
+
/**
|
|
18
|
+
* Check if a value is a JSON object (not an array, not null, and has Object prototype).
|
|
19
|
+
* @param {unknown} value - The value to check.
|
|
20
|
+
* @returns {boolean} True if the value is a JSON object.
|
|
21
|
+
*/
|
|
22
|
+
static isObject(value: unknown): value is JSONObject {
|
|
23
|
+
if (value === null || typeof value !== 'object') return false;
|
|
24
|
+
if (Array.isArray(value)) return false;
|
|
25
|
+
const proto = Object.getPrototypeOf(value);
|
|
26
|
+
return proto === Object.prototype || proto === null;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Check if a value is a parsable JSON string.
|
|
31
|
+
* @param {unknown} value - The value to check.
|
|
32
|
+
* @returns {boolean} True if the value is a parsable JSON string.
|
|
33
|
+
*/
|
|
34
|
+
static isParsable(value: unknown): value is string {
|
|
35
|
+
if (typeof value !== 'string') return false;
|
|
36
|
+
try {
|
|
37
|
+
JSON.parse(value);
|
|
38
|
+
return true;
|
|
39
|
+
} catch {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Check if a value is an unprototyped object (i.e., Object.create(null)).
|
|
46
|
+
* @param {unknown} value - The value to check.
|
|
47
|
+
* @returns {boolean} True if the value is an unprototyped object.
|
|
48
|
+
*/
|
|
49
|
+
static isUnprototyped(value: unknown): value is Unprototyped {
|
|
50
|
+
if (value === null || typeof value !== 'object') return false;
|
|
51
|
+
return Object.getPrototypeOf(value) === null;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Normalize a JSON value by stripping prototypes from all objects within it.
|
|
56
|
+
* @param {T} value - The JSON value to normalize.
|
|
57
|
+
* @returns {Prototyped} The normalized JSON value.
|
|
58
|
+
*/
|
|
59
|
+
static normalize<T extends JSONObject | Array<any>>(value: T): Prototyped {
|
|
60
|
+
return this.cloneInternal(value, { stripPrototypes: true });
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Shallow copy of a JSON object.
|
|
65
|
+
* @param {T extends JSONObject} value - The JSON object to copy.
|
|
66
|
+
* @returns {T} The copied JSON object.
|
|
67
|
+
*/
|
|
68
|
+
static copy<T extends JSONObject>(value: T): T {
|
|
69
|
+
return { ...value };
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Deep clone a JSON value.
|
|
74
|
+
* @param {T} value - The JSON value to clone.
|
|
75
|
+
* @returns {T} The cloned JSON value.
|
|
76
|
+
*/
|
|
77
|
+
static clone<T>(value: T): T {
|
|
78
|
+
if (typeof structuredClone === 'function') {
|
|
79
|
+
return structuredClone(value);
|
|
80
|
+
}
|
|
81
|
+
return this.cloneInternal(value);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* Deep clone a JSON value, replacing strings that match a pattern.
|
|
86
|
+
* @param {T} value - The JSON value to clone.
|
|
87
|
+
* @param {RegExp} pattern - The regex pattern to match strings.
|
|
88
|
+
* @param {string} replacement - The replacement string.
|
|
89
|
+
* @returns {T} The cloned JSON value with replacements.
|
|
90
|
+
*/
|
|
91
|
+
static cloneReplace<T>(value: T, pattern: RegExp, replacement: string): T {
|
|
92
|
+
return this.cloneInternal(value, {
|
|
93
|
+
transform : (candidate) => typeof candidate === 'string'
|
|
94
|
+
? candidate.replace(pattern, replacement)
|
|
95
|
+
: candidate
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Deep equality check between two values.
|
|
101
|
+
* @param {unknown} a - The first value to compare.
|
|
102
|
+
* @param {unknown} b - The second value to compare.
|
|
103
|
+
* @param {WeakMap<object, object>} seen - A WeakMap to track seen object pairs for circular reference detection.
|
|
104
|
+
* @returns {boolean} True if the values are deeply equal.
|
|
105
|
+
*/
|
|
106
|
+
static deepEqual(
|
|
107
|
+
a: unknown,
|
|
108
|
+
b: unknown,
|
|
109
|
+
seen: WeakMap<object, object> = new WeakMap<object, object>(),
|
|
110
|
+
depth: number = 0
|
|
111
|
+
): boolean {
|
|
112
|
+
if (depth > 1024) {
|
|
113
|
+
throw new Error('Maximum comparison depth exceeded');
|
|
114
|
+
}
|
|
115
|
+
if (Object.is(a, b)) return true;
|
|
116
|
+
|
|
117
|
+
if (typeof a !== typeof b) return false;
|
|
118
|
+
if (a === null || b === null) return false;
|
|
119
|
+
if (typeof a !== 'object') return false;
|
|
120
|
+
|
|
121
|
+
if (seen.get(a as object) === b) return true;
|
|
122
|
+
seen.set(a as object, b as object);
|
|
123
|
+
|
|
124
|
+
if (ArrayBuffer.isView(a) && ArrayBuffer.isView(b)) {
|
|
125
|
+
const viewA = new Uint8Array((a as ArrayBufferView).buffer, (a as ArrayBufferView).byteOffset, (a as ArrayBufferView).byteLength);
|
|
126
|
+
const viewB = new Uint8Array((b as ArrayBufferView).buffer, (b as ArrayBufferView).byteOffset, (b as ArrayBufferView).byteLength);
|
|
127
|
+
if (viewA.byteLength !== viewB.byteLength) return false;
|
|
128
|
+
for (let i = 0; i < viewA.byteLength; i++) {
|
|
129
|
+
if (viewA[i] !== viewB[i]) return false;
|
|
130
|
+
}
|
|
131
|
+
return true;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
if (a instanceof Date && b instanceof Date) {
|
|
135
|
+
return a.getTime() === b.getTime();
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
if (a instanceof Set && b instanceof Set) {
|
|
139
|
+
if (a.size !== b.size) return false;
|
|
140
|
+
for (const itemA of a) {
|
|
141
|
+
let matched = false;
|
|
142
|
+
for (const itemB of b) {
|
|
143
|
+
if (this.deepEqual(itemA, itemB, seen, depth + 1)) {
|
|
144
|
+
matched = true;
|
|
145
|
+
break;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
if (!matched) return false;
|
|
149
|
+
}
|
|
150
|
+
return true;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
if (a instanceof Map && b instanceof Map) {
|
|
154
|
+
if (a.size !== b.size) return false;
|
|
155
|
+
for (const [keyA, valueA] of a) {
|
|
156
|
+
let matched = false;
|
|
157
|
+
if (b.has(keyA)) {
|
|
158
|
+
matched = this.deepEqual(valueA, b.get(keyA), seen, depth + 1);
|
|
159
|
+
} else {
|
|
160
|
+
for (const [keyB, valueB] of b) {
|
|
161
|
+
if (
|
|
162
|
+
this.deepEqual(keyA, keyB, seen, depth + 1)
|
|
163
|
+
&& this.deepEqual(valueA, valueB, seen, depth + 1)
|
|
164
|
+
) {
|
|
165
|
+
matched = true;
|
|
166
|
+
break;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
if (!matched) return false;
|
|
171
|
+
}
|
|
172
|
+
return true;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (Array.isArray(a) && Array.isArray(b)) {
|
|
176
|
+
if (a.length !== b.length) return false;
|
|
177
|
+
for (let i = 0; i < a.length; i++) {
|
|
178
|
+
if (!this.deepEqual(a[i], b[i], seen, depth + 1)) return false;
|
|
179
|
+
}
|
|
180
|
+
return true;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
const keysA = Object.keys(a as object);
|
|
184
|
+
const keysB = Object.keys(b as object);
|
|
185
|
+
if (keysA.length !== keysB.length) return false;
|
|
186
|
+
|
|
187
|
+
for (const key of keysA) {
|
|
188
|
+
if (!Object.prototype.hasOwnProperty.call(b, key)) return false;
|
|
189
|
+
if (!this.deepEqual((a as any)[key], (b as any)[key], seen, depth + 1)) return false;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
return true;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
* Delete specified keys from a JSON value.
|
|
197
|
+
* @param {T} value - The JSON value to process.
|
|
198
|
+
* @param {Array<string | number | symbol>} keys - The keys to delete.
|
|
199
|
+
* @returns {T} The JSON value with specified keys deleted.
|
|
200
|
+
*/
|
|
201
|
+
static deleteKeys<T>(value: T, keys: Array<string | number | symbol>): T {
|
|
202
|
+
const keySet = new Set(keys.map(key => typeof key === 'number' ? key.toString() : key));
|
|
203
|
+
|
|
204
|
+
const walk = (candidate: any): any => {
|
|
205
|
+
if (Array.isArray(candidate)) {
|
|
206
|
+
return candidate.map(item => walk(item));
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
if (candidate && typeof candidate === 'object') {
|
|
210
|
+
const result: any = Array.isArray(candidate) ? [] : {};
|
|
211
|
+
for (const key of Object.keys(candidate)) {
|
|
212
|
+
if (keySet.has(key)) continue;
|
|
213
|
+
result[key] = walk(candidate[key]);
|
|
214
|
+
}
|
|
215
|
+
return result;
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
return candidate;
|
|
219
|
+
};
|
|
220
|
+
|
|
221
|
+
return walk(value);
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
/**
|
|
225
|
+
* Sanitize a JSON value by removing undefined values from objects and arrays.
|
|
226
|
+
* @param {T} value - The JSON value to sanitize.
|
|
227
|
+
* @returns {T} The sanitized JSON value.
|
|
228
|
+
*/
|
|
229
|
+
static sanitize<T>(value: T): T {
|
|
230
|
+
const walk = (candidate: any): any => {
|
|
231
|
+
if (Array.isArray(candidate)) {
|
|
232
|
+
return candidate.map(item => walk(item));
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
if (candidate && typeof candidate === 'object') {
|
|
236
|
+
const result: any = {};
|
|
237
|
+
for (const [key, val] of Object.entries(candidate)) {
|
|
238
|
+
const sanitized = walk(val);
|
|
239
|
+
if (sanitized !== undefined) {
|
|
240
|
+
result[key] = sanitized;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
return result;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
return candidate;
|
|
247
|
+
};
|
|
248
|
+
|
|
249
|
+
return walk(value);
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
/**
|
|
253
|
+
* Internal function to clone JSON values with options.
|
|
254
|
+
* @param {T} value - The value to clone.
|
|
255
|
+
* @param {CloneOptions} options - The cloning options.
|
|
256
|
+
* @param {WeakMap<object, any>} seen - A WeakMap to track seen objects for circular reference detection.
|
|
257
|
+
* @returns {any} The cloned value.
|
|
258
|
+
*/
|
|
259
|
+
static cloneInternal<T>(
|
|
260
|
+
value: T,
|
|
261
|
+
options: CloneOptions = {},
|
|
262
|
+
seen: WeakMap<object, any> = new WeakMap<object, any>(),
|
|
263
|
+
depth: number = 0
|
|
264
|
+
): any {
|
|
265
|
+
if (depth > 1024) {
|
|
266
|
+
throw new Error('Maximum clone depth exceeded');
|
|
267
|
+
}
|
|
268
|
+
const transformed = options.transform ? options.transform(value) : value;
|
|
269
|
+
if (transformed !== value) return transformed;
|
|
270
|
+
|
|
271
|
+
if (typeof value !== 'object' || value === null) {
|
|
272
|
+
return transformed;
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
if (seen.has(value as object)) {
|
|
276
|
+
throw new Error('Cannot clone circular structure');
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Handle arrays and typed arrays
|
|
280
|
+
if (Array.isArray(value)) {
|
|
281
|
+
const clone: any[] = [];
|
|
282
|
+
seen.set(value as object, clone);
|
|
283
|
+
for (const item of value) {
|
|
284
|
+
clone.push(this.cloneInternal(item, options, seen, depth + 1));
|
|
285
|
+
}
|
|
286
|
+
return clone;
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
// Handle ArrayBuffer views (typed arrays, DataView)
|
|
290
|
+
if (ArrayBuffer.isView(value)) {
|
|
291
|
+
if (value instanceof DataView) {
|
|
292
|
+
return new DataView(
|
|
293
|
+
value.buffer.slice(value.byteOffset, value.byteOffset + value.byteLength)
|
|
294
|
+
);
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
if (typeof (value as any).slice === 'function') {
|
|
298
|
+
return (value as any).slice();
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
if (value instanceof Date) {
|
|
303
|
+
return new Date(value.getTime());
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
const result: any = options.stripPrototypes ? {} : Object.create(Object.getPrototypeOf(value));
|
|
307
|
+
seen.set(value as object, result);
|
|
308
|
+
|
|
309
|
+
for (const key of Object.keys(value as object)) {
|
|
310
|
+
result[key] = this.cloneInternal((value as any)[key], options, seen, depth + 1);
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
return result;
|
|
314
|
+
}
|
|
315
|
+
}
|
package/src/utils/set.ts
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility class for set operations.
|
|
3
|
+
* @name SetUtils
|
|
4
|
+
* @class SetUtils
|
|
5
|
+
*/
|
|
6
|
+
export class SetUtils {
|
|
7
|
+
/**
|
|
8
|
+
* Compute the set difference without mutating the inputs.
|
|
9
|
+
* @param {Set<T>} left - The left set.
|
|
10
|
+
* @param {Set<T>} right - The right set.
|
|
11
|
+
* @returns {Set<T>} A new set containing elements in `left` that are not in `right`.
|
|
12
|
+
*/
|
|
13
|
+
static difference<T>(left: Set<T>, right: Set<T>): Set<T> {
|
|
14
|
+
const result = new Set<T>();
|
|
15
|
+
for (const value of left) {
|
|
16
|
+
if (!right.has(value)) {
|
|
17
|
+
result.add(value);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility class string-related operations.
|
|
3
|
+
* @name StringUtils
|
|
4
|
+
* @class StringUtils
|
|
5
|
+
*/
|
|
6
|
+
export class StringUtils {
|
|
7
|
+
/**
|
|
8
|
+
* Escape special characters in a string for use in a regular expression.
|
|
9
|
+
* @param {string} value - The string to escape.
|
|
10
|
+
* @returns {string} The escaped string.
|
|
11
|
+
*/
|
|
12
|
+
static escapeRegExp(value: string): string {
|
|
13
|
+
return value.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Convert a camelCase string to snake_case.
|
|
18
|
+
* @param {string} value - The camelCase string to convert.
|
|
19
|
+
* @returns {string} The converted snake_case string.
|
|
20
|
+
*/
|
|
21
|
+
static toSnake(value: string): string {
|
|
22
|
+
return value
|
|
23
|
+
.replace(/([a-z0-9])([A-Z])/g, '$1_$2')
|
|
24
|
+
.toLowerCase();
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Convert a string to SNAKE_SCREAMING_CASE.
|
|
29
|
+
* @param {string} value - The string to convert.
|
|
30
|
+
* @returns {string} The converted SNAKE_SCREAMING_CASE string.
|
|
31
|
+
*/
|
|
32
|
+
static toSnakeScream(value: string): string {
|
|
33
|
+
return this.toSnake(value).toUpperCase();
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Remove the last character from a string.
|
|
38
|
+
* @param {string} value - The string to chop.
|
|
39
|
+
* @returns {string} The chopped string.
|
|
40
|
+
*/
|
|
41
|
+
static chop(value: string): string {
|
|
42
|
+
return value.length > 0 ? value.slice(0, -1) : '';
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Replace the end of a string if it matches a given pattern.
|
|
47
|
+
* @param {string} value - The string to modify.
|
|
48
|
+
* @param {string | RegExp} pattern - The pattern to match at the end of the string.
|
|
49
|
+
* @param {string} [replacement=''] - The replacement string.
|
|
50
|
+
* @returns {string} The modified string.
|
|
51
|
+
*/
|
|
52
|
+
static replaceEnd(value: string, pattern: string | RegExp, replacement: string = ''): string {
|
|
53
|
+
const regex = pattern instanceof RegExp
|
|
54
|
+
? new RegExp(pattern.source.endsWith('$') ? pattern.source : `${pattern.source}$`, pattern.flags.replace(/g/g, ''))
|
|
55
|
+
: new RegExp(`${this.escapeRegExp(pattern)}$`);
|
|
56
|
+
|
|
57
|
+
return value.replace(regex, replacement);
|
|
58
|
+
}
|
|
59
|
+
}
|
package/dist/cjs/exts.js
DELETED
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
import { Canonicalization } from './canonicalization.js';
|
|
2
|
-
import { Patch } from './patch.js';
|
|
3
|
-
/** Array Interface Extensions */
|
|
4
|
-
Array.prototype.last = function () {
|
|
5
|
-
return this[this.length - 1] ?? undefined;
|
|
6
|
-
};
|
|
7
|
-
Array.prototype[-1] = function () {
|
|
8
|
-
return this.last();
|
|
9
|
-
};
|
|
10
|
-
Array.prototype.toUint8Array = function () {
|
|
11
|
-
return new Uint8Array(this);
|
|
12
|
-
};
|
|
13
|
-
/** BufferConstructor/Buffer Interface Extensions */
|
|
14
|
-
Buffer.fromHex = function (hex) {
|
|
15
|
-
return Buffer.from(hex, 'hex');
|
|
16
|
-
};
|
|
17
|
-
Buffer.toHex = function (ui8) {
|
|
18
|
-
return Buffer.from(ui8).toString('hex');
|
|
19
|
-
};
|
|
20
|
-
Buffer.toUint8Array = function (buf) {
|
|
21
|
-
return new Uint8Array(buf);
|
|
22
|
-
};
|
|
23
|
-
/** Date Interface Extensions */
|
|
24
|
-
Date.prototype.getUTCDateTime = function () {
|
|
25
|
-
return `${this.toISOString().slice(0, -5)}Z`;
|
|
26
|
-
};
|
|
27
|
-
Date.prototype.toUnix = function () {
|
|
28
|
-
const time = this.getTime();
|
|
29
|
-
if (isNaN(time)) {
|
|
30
|
-
throw new Error(`Invalid date string: "${this}"`);
|
|
31
|
-
}
|
|
32
|
-
return time;
|
|
33
|
-
};
|
|
34
|
-
/** JSON Interface Extensions */
|
|
35
|
-
JSON.is = function (unknown) {
|
|
36
|
-
if (unknown === null || typeof unknown !== 'object')
|
|
37
|
-
return false;
|
|
38
|
-
if (Array.isArray(unknown))
|
|
39
|
-
return unknown.every(item => Object.getPrototypeOf(item) !== null);
|
|
40
|
-
else
|
|
41
|
-
return Object.getPrototypeOf(unknown) === null;
|
|
42
|
-
};
|
|
43
|
-
JSON.parsable = function (unknown) {
|
|
44
|
-
try {
|
|
45
|
-
JSON.parse(unknown);
|
|
46
|
-
return true;
|
|
47
|
-
}
|
|
48
|
-
catch {
|
|
49
|
-
return false;
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
JSON.stringifiable = function (unknown) {
|
|
53
|
-
try {
|
|
54
|
-
JSON.stringify(unknown);
|
|
55
|
-
return true;
|
|
56
|
-
}
|
|
57
|
-
catch {
|
|
58
|
-
return false;
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
JSON.unprototyped = function (unknown) {
|
|
62
|
-
if (Array.isArray(unknown)) {
|
|
63
|
-
return unknown.every(item => Object.getPrototypeOf(item) === null);
|
|
64
|
-
}
|
|
65
|
-
return Object.getPrototypeOf(unknown) === null;
|
|
66
|
-
};
|
|
67
|
-
JSON.normalize = function (unknown) {
|
|
68
|
-
try {
|
|
69
|
-
return JSON.parse(JSON.stringify(unknown));
|
|
70
|
-
}
|
|
71
|
-
catch {
|
|
72
|
-
throw new Error('The object is not unprotocyped');
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
JSON.copy = function (o) {
|
|
76
|
-
return Object.assign({}, o);
|
|
77
|
-
};
|
|
78
|
-
JSON.clone = function (o) {
|
|
79
|
-
return JSON.parse(JSON.stringify(o));
|
|
80
|
-
};
|
|
81
|
-
JSON.cloneReplace = function (o, e, r) {
|
|
82
|
-
return JSON.parse(JSON.stringify(o).replaceAll(e, r));
|
|
83
|
-
};
|
|
84
|
-
JSON.equal = function (a, b) {
|
|
85
|
-
return a === b;
|
|
86
|
-
};
|
|
87
|
-
JSON.deepEqual = function (a, b) {
|
|
88
|
-
if (JSON.equal(a, b))
|
|
89
|
-
return true;
|
|
90
|
-
if (a === null || b === null || typeof a !== typeof b)
|
|
91
|
-
return false;
|
|
92
|
-
if (typeof a === 'object') {
|
|
93
|
-
const isArrayA = Array.isArray(a);
|
|
94
|
-
const isArrayB = Array.isArray(b);
|
|
95
|
-
if (isArrayA !== isArrayB)
|
|
96
|
-
return false;
|
|
97
|
-
if (isArrayA && isArrayB) {
|
|
98
|
-
if (a.length !== b.length)
|
|
99
|
-
return false;
|
|
100
|
-
for (let i = 0; i < a.length; i++) {
|
|
101
|
-
if (!this.deepEqual(a[i], b[i]))
|
|
102
|
-
return false;
|
|
103
|
-
}
|
|
104
|
-
return true;
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
const keysA = Object.keys(a);
|
|
108
|
-
const keysB = Object.keys(b);
|
|
109
|
-
if (keysA.length !== keysB.length)
|
|
110
|
-
return false;
|
|
111
|
-
for (const key of keysA) {
|
|
112
|
-
if (!Object.prototype.hasOwnProperty.call(b, key)) {
|
|
113
|
-
return false;
|
|
114
|
-
}
|
|
115
|
-
if (!this.deepEqual(a[key], b[key])) {
|
|
116
|
-
return false;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
return true;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
return false;
|
|
123
|
-
};
|
|
124
|
-
JSON.delete = function (o, keys) {
|
|
125
|
-
if (!JSON.is(o))
|
|
126
|
-
return o;
|
|
127
|
-
for (const key of keys) {
|
|
128
|
-
if (Object.prototype.hasOwnProperty.call(o, key)) {
|
|
129
|
-
delete o[key];
|
|
130
|
-
}
|
|
131
|
-
for (const key in o) {
|
|
132
|
-
if (typeof o[key] === 'object') {
|
|
133
|
-
o[key] = this.delete(o[key], [key]);
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return o;
|
|
138
|
-
};
|
|
139
|
-
JSON.sanitize = function (o) {
|
|
140
|
-
for (const key of Object.keys(o)) {
|
|
141
|
-
if (o[key] === undefined) {
|
|
142
|
-
delete o[key];
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
return o;
|
|
146
|
-
};
|
|
147
|
-
JSON.canonicalization = new Canonicalization();
|
|
148
|
-
JSON.patch = new Patch();
|
|
149
|
-
/** Object Interface Extensions */
|
|
150
|
-
Object.json = function (o) {
|
|
151
|
-
return Object.fromEntries(Object.entries(o));
|
|
152
|
-
};
|
|
153
|
-
/** Set Interface Extensions */
|
|
154
|
-
Set.prototype.difference = function (other) {
|
|
155
|
-
const result = new Set(this);
|
|
156
|
-
for (const item of other) {
|
|
157
|
-
if (result.has(item)) {
|
|
158
|
-
result.delete(item);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
return result;
|
|
162
|
-
};
|
|
163
|
-
/** String Interface Extensions */
|
|
164
|
-
String.prototype.toSnake = function () {
|
|
165
|
-
return this
|
|
166
|
-
.replace(/([a-z])([A-Z])/g, '$1_$2')
|
|
167
|
-
.toLowerCase();
|
|
168
|
-
};
|
|
169
|
-
String.prototype.toSnakeScream = function () {
|
|
170
|
-
return this.toSnake().toUpperCase();
|
|
171
|
-
};
|
|
172
|
-
String.prototype.chop = function () {
|
|
173
|
-
return this.length > 0 ? this.slice(0, -1) : '';
|
|
174
|
-
};
|
|
175
|
-
String.prototype.replaceEnd = function (e, r) {
|
|
176
|
-
const pattern = e instanceof RegExp
|
|
177
|
-
? new RegExp(e.source.endsWith('$') ? e.source : `${e.source}$`, e.flags.replace('g', ''))
|
|
178
|
-
: new RegExp(`${e.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&')}$`);
|
|
179
|
-
return this.replace(pattern, r ?? '');
|
|
180
|
-
};
|
|
181
|
-
/** Uint8Array Interface Extensions */
|
|
182
|
-
Uint8Array.prototype.toArray = function () {
|
|
183
|
-
return Array.from(this);
|
|
184
|
-
};
|
|
185
|
-
Uint8Array.prototype.toHex = function () {
|
|
186
|
-
return Buffer.from(this).toString('hex');
|
|
187
|
-
};
|
|
188
|
-
export default global;
|
|
189
|
-
//# sourceMappingURL=exts.js.map
|
package/dist/cjs/exts.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"exts.js","sourceRoot":"","sources":["../../src/exts.ts"],"names":[],"mappings":"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"}
|