@nejs/basic-extensions 2.6.0 → 2.8.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.
Files changed (271) hide show
  1. package/.vscode/settings.json +5 -0
  2. package/README.md +6129 -1574
  3. package/dist/@nejs/basic-extensions.bundle.2.7.0.js +19 -0
  4. package/dist/@nejs/basic-extensions.bundle.2.7.0.js.map +7 -0
  5. package/dist/cjs/array.extensions.d.ts +39 -0
  6. package/dist/cjs/array.extensions.js +303 -0
  7. package/dist/cjs/array.extensions.js.map +1 -0
  8. package/dist/cjs/big.int.extension.d.ts +31 -0
  9. package/dist/cjs/big.int.extension.js +164 -0
  10. package/dist/cjs/big.int.extension.js.map +1 -0
  11. package/dist/cjs/{newClasses → classes}/asyncIterable.js +32 -44
  12. package/dist/cjs/classes/asyncIterable.js.map +1 -0
  13. package/dist/cjs/{newClasses → classes}/deferred.js +66 -138
  14. package/dist/cjs/classes/deferred.js.map +1 -0
  15. package/dist/cjs/{newClasses → classes}/descriptor.js +56 -90
  16. package/dist/cjs/classes/descriptor.js.map +1 -0
  17. package/dist/cjs/classes/index.d.ts +13 -0
  18. package/dist/cjs/classes/index.js +57 -0
  19. package/dist/cjs/classes/index.js.map +1 -0
  20. package/dist/cjs/classes/introspector.d.ts +20 -0
  21. package/dist/cjs/classes/introspector.js +130 -0
  22. package/dist/cjs/classes/introspector.js.map +1 -0
  23. package/dist/cjs/{newClasses → classes}/iterable.js +42 -63
  24. package/dist/cjs/classes/iterable.js.map +1 -0
  25. package/dist/cjs/classes/param.parser.d.ts +227 -0
  26. package/dist/cjs/classes/param.parser.js +242 -0
  27. package/dist/cjs/classes/param.parser.js.map +1 -0
  28. package/dist/cjs/classes/pluggable.proxy.d.ts +152 -0
  29. package/dist/cjs/classes/pluggable.proxy.js +444 -0
  30. package/dist/cjs/classes/pluggable.proxy.js.map +1 -0
  31. package/dist/cjs/{newClasses → classes}/refmap.js +18 -30
  32. package/dist/cjs/classes/refmap.js.map +1 -0
  33. package/dist/cjs/{newClasses → classes}/refset.js +28 -47
  34. package/dist/cjs/classes/refset.js.map +1 -0
  35. package/dist/cjs/classes/symkeys.d.ts +292 -0
  36. package/dist/cjs/classes/symkeys.js +424 -0
  37. package/dist/cjs/classes/symkeys.js.map +1 -0
  38. package/dist/cjs/classes/type.d.ts +56 -0
  39. package/dist/cjs/classes/type.js +405 -0
  40. package/dist/cjs/classes/type.js.map +1 -0
  41. package/dist/cjs/function.extensions.js +757 -0
  42. package/dist/cjs/function.extensions.js.map +1 -0
  43. package/dist/cjs/global.this.js +261 -0
  44. package/dist/cjs/global.this.js.map +1 -0
  45. package/dist/cjs/index.d.ts +4 -3
  46. package/dist/cjs/index.js +62 -32
  47. package/dist/cjs/index.js.map +1 -1
  48. package/dist/cjs/json.extensions.d.ts +2 -0
  49. package/dist/cjs/json.extensions.js +107 -0
  50. package/dist/cjs/json.extensions.js.map +1 -0
  51. package/dist/{mjs/mapextensions.d.ts → cjs/map.extensions.d.ts} +1 -0
  52. package/dist/cjs/map.extensions.js +142 -0
  53. package/dist/cjs/map.extensions.js.map +1 -0
  54. package/dist/cjs/number.extension.d.ts +44 -0
  55. package/dist/cjs/number.extension.js +260 -0
  56. package/dist/cjs/number.extension.js.map +1 -0
  57. package/dist/cjs/object.extensions.d.ts +62 -0
  58. package/dist/cjs/object.extensions.js +1116 -0
  59. package/dist/cjs/object.extensions.js.map +1 -0
  60. package/dist/cjs/proxy.extensions.d.ts +2 -0
  61. package/dist/cjs/proxy.extensions.js +207 -0
  62. package/dist/cjs/proxy.extensions.js.map +1 -0
  63. package/dist/cjs/reflect.extensions.js +316 -0
  64. package/dist/cjs/reflect.extensions.js.map +1 -0
  65. package/dist/cjs/regular.expression.extensions.d.ts +2 -0
  66. package/dist/cjs/regular.expression.extensions.js +423 -0
  67. package/dist/cjs/regular.expression.extensions.js.map +1 -0
  68. package/dist/cjs/set.extensions.d.ts +40 -0
  69. package/dist/cjs/{setextensions.js → set.extensions.js} +150 -2
  70. package/dist/cjs/set.extensions.js.map +1 -0
  71. package/dist/cjs/string.extensions.js +471 -0
  72. package/dist/cjs/string.extensions.js.map +1 -0
  73. package/dist/{mjs/symbolextensions.d.ts → cjs/symbol.extensions.d.ts} +1 -0
  74. package/dist/cjs/symbol.extensions.js +259 -0
  75. package/dist/cjs/symbol.extensions.js.map +1 -0
  76. package/dist/cjs/{weakrefextensions.js → weakref.extensions.js} +1 -1
  77. package/dist/cjs/weakref.extensions.js.map +1 -0
  78. package/dist/mjs/array.extensions.d.ts +39 -0
  79. package/dist/mjs/array.extensions.js +300 -0
  80. package/dist/mjs/array.extensions.js.map +1 -0
  81. package/dist/mjs/big.int.extension.d.ts +31 -0
  82. package/dist/mjs/big.int.extension.js +161 -0
  83. package/dist/mjs/big.int.extension.js.map +1 -0
  84. package/dist/mjs/classes/asyncIterable.js.map +1 -0
  85. package/dist/mjs/classes/deferred.js.map +1 -0
  86. package/dist/mjs/{newClasses → classes}/descriptor.js +7 -4
  87. package/dist/mjs/classes/descriptor.js.map +1 -0
  88. package/dist/mjs/classes/index.d.ts +13 -0
  89. package/dist/mjs/classes/index.js +40 -0
  90. package/dist/mjs/classes/index.js.map +1 -0
  91. package/dist/mjs/classes/introspector.d.ts +20 -0
  92. package/dist/mjs/classes/introspector.js +126 -0
  93. package/dist/mjs/classes/introspector.js.map +1 -0
  94. package/dist/mjs/classes/iterable.js.map +1 -0
  95. package/dist/mjs/classes/param.parser.d.ts +227 -0
  96. package/dist/mjs/classes/param.parser.js +238 -0
  97. package/dist/mjs/classes/param.parser.js.map +1 -0
  98. package/dist/mjs/classes/pluggable.proxy.d.ts +152 -0
  99. package/dist/mjs/classes/pluggable.proxy.js +438 -0
  100. package/dist/mjs/classes/pluggable.proxy.js.map +1 -0
  101. package/dist/mjs/{newClasses → classes}/refmap.js +3 -3
  102. package/dist/mjs/classes/refmap.js.map +1 -0
  103. package/dist/mjs/classes/refset.js.map +1 -0
  104. package/dist/mjs/classes/symkeys.d.ts +292 -0
  105. package/dist/mjs/classes/symkeys.js +420 -0
  106. package/dist/mjs/classes/symkeys.js.map +1 -0
  107. package/dist/mjs/classes/type.d.ts +56 -0
  108. package/dist/mjs/classes/type.js +401 -0
  109. package/dist/mjs/classes/type.js.map +1 -0
  110. package/dist/mjs/function.extensions.js +754 -0
  111. package/dist/mjs/function.extensions.js.map +1 -0
  112. package/dist/mjs/global.this.js +258 -0
  113. package/dist/mjs/global.this.js.map +1 -0
  114. package/dist/mjs/index.d.ts +4 -3
  115. package/dist/mjs/index.js +49 -19
  116. package/dist/mjs/index.js.map +1 -1
  117. package/dist/mjs/json.extensions.d.ts +2 -0
  118. package/dist/mjs/json.extensions.js +104 -0
  119. package/dist/mjs/json.extensions.js.map +1 -0
  120. package/dist/{cjs/mapextensions.d.ts → mjs/map.extensions.d.ts} +1 -0
  121. package/dist/mjs/map.extensions.js +139 -0
  122. package/dist/mjs/map.extensions.js.map +1 -0
  123. package/dist/mjs/number.extension.d.ts +44 -0
  124. package/dist/mjs/number.extension.js +257 -0
  125. package/dist/mjs/number.extension.js.map +1 -0
  126. package/dist/mjs/object.extensions.d.ts +62 -0
  127. package/dist/mjs/object.extensions.js +1112 -0
  128. package/dist/mjs/object.extensions.js.map +1 -0
  129. package/dist/mjs/proxy.extensions.d.ts +2 -0
  130. package/dist/mjs/proxy.extensions.js +204 -0
  131. package/dist/mjs/proxy.extensions.js.map +1 -0
  132. package/dist/mjs/reflect.extensions.js +313 -0
  133. package/dist/mjs/reflect.extensions.js.map +1 -0
  134. package/dist/mjs/regular.expression.extensions.d.ts +2 -0
  135. package/dist/mjs/regular.expression.extensions.js +420 -0
  136. package/dist/mjs/regular.expression.extensions.js.map +1 -0
  137. package/dist/mjs/set.extensions.d.ts +40 -0
  138. package/dist/mjs/{setextensions.js → set.extensions.js} +149 -1
  139. package/dist/mjs/set.extensions.js.map +1 -0
  140. package/dist/mjs/string.extensions.js +468 -0
  141. package/dist/mjs/string.extensions.js.map +1 -0
  142. package/dist/{cjs/symbolextensions.d.ts → mjs/symbol.extensions.d.ts} +1 -0
  143. package/dist/mjs/symbol.extensions.js +256 -0
  144. package/dist/mjs/symbol.extensions.js.map +1 -0
  145. package/dist/mjs/{weakrefextensions.js → weakref.extensions.js} +1 -1
  146. package/dist/mjs/weakref.extensions.js.map +1 -0
  147. package/docs/index.html +24045 -5805
  148. package/package.json +6 -4
  149. package/repl.bootstrap.js +21 -0
  150. package/src/array.extensions.js +322 -0
  151. package/src/big.int.extension.js +163 -0
  152. package/src/{newClasses → classes}/descriptor.js +16 -12
  153. package/src/classes/index.js +51 -0
  154. package/src/classes/introspector.js +167 -0
  155. package/src/classes/param.parser.js +253 -0
  156. package/src/classes/pluggable.proxy.js +485 -0
  157. package/src/{newClasses → classes}/refmap.js +5 -3
  158. package/src/classes/symkeys.js +464 -0
  159. package/src/classes/type.js +427 -0
  160. package/src/function.extensions.js +818 -0
  161. package/src/global.this.js +304 -0
  162. package/src/index.js +56 -23
  163. package/src/json.extensions.js +108 -0
  164. package/src/map.extensions.js +144 -0
  165. package/src/number.extension.js +273 -0
  166. package/src/object.extensions.js +1222 -0
  167. package/src/proxy.extensions.js +229 -0
  168. package/src/reflect.extensions.js +346 -0
  169. package/src/regular.expression.extensions.js +451 -0
  170. package/src/{setextensions.js → set.extensions.js} +151 -2
  171. package/src/string.extensions.js +515 -0
  172. package/src/symbol.extensions.js +268 -0
  173. package/tests/newClasses/refmap.test.js +3 -2
  174. package/tsconfig.base.json +5 -3
  175. package/tsconfig.cjs.json +2 -2
  176. package/tsconfig.esm.json +2 -2
  177. package/dist/@nejs/basic-extensions.bundle.2.5.0.js +0 -8
  178. package/dist/@nejs/basic-extensions.bundle.2.5.0.js.map +0 -7
  179. package/dist/cjs/arrayextensions.d.ts +0 -10
  180. package/dist/cjs/arrayextensions.js +0 -73
  181. package/dist/cjs/arrayextensions.js.map +0 -1
  182. package/dist/cjs/functionextensions.js +0 -202
  183. package/dist/cjs/functionextensions.js.map +0 -1
  184. package/dist/cjs/globals.js +0 -166
  185. package/dist/cjs/globals.js.map +0 -1
  186. package/dist/cjs/mapextensions.js +0 -32
  187. package/dist/cjs/mapextensions.js.map +0 -1
  188. package/dist/cjs/newClasses/asyncIterable.js.map +0 -1
  189. package/dist/cjs/newClasses/deferred.js.map +0 -1
  190. package/dist/cjs/newClasses/descriptor.js.map +0 -1
  191. package/dist/cjs/newClasses/iterable.js.map +0 -1
  192. package/dist/cjs/newClasses/refmap.js.map +0 -1
  193. package/dist/cjs/newClasses/refset.js.map +0 -1
  194. package/dist/cjs/objectextensions.d.ts +0 -11
  195. package/dist/cjs/objectextensions.js +0 -232
  196. package/dist/cjs/objectextensions.js.map +0 -1
  197. package/dist/cjs/reflectextensions.js +0 -111
  198. package/dist/cjs/reflectextensions.js.map +0 -1
  199. package/dist/cjs/setextensions.d.ts +0 -2
  200. package/dist/cjs/setextensions.js.map +0 -1
  201. package/dist/cjs/stringextensions.js +0 -158
  202. package/dist/cjs/stringextensions.js.map +0 -1
  203. package/dist/cjs/symbolextensions.js +0 -69
  204. package/dist/cjs/symbolextensions.js.map +0 -1
  205. package/dist/cjs/weakrefextensions.js.map +0 -1
  206. package/dist/mjs/arrayextensions.d.ts +0 -10
  207. package/dist/mjs/arrayextensions.js +0 -70
  208. package/dist/mjs/arrayextensions.js.map +0 -1
  209. package/dist/mjs/functionextensions.js +0 -199
  210. package/dist/mjs/functionextensions.js.map +0 -1
  211. package/dist/mjs/globals.js +0 -163
  212. package/dist/mjs/globals.js.map +0 -1
  213. package/dist/mjs/mapextensions.js +0 -29
  214. package/dist/mjs/mapextensions.js.map +0 -1
  215. package/dist/mjs/newClasses/asyncIterable.js.map +0 -1
  216. package/dist/mjs/newClasses/deferred.js.map +0 -1
  217. package/dist/mjs/newClasses/descriptor.js.map +0 -1
  218. package/dist/mjs/newClasses/iterable.js.map +0 -1
  219. package/dist/mjs/newClasses/refmap.js.map +0 -1
  220. package/dist/mjs/newClasses/refset.js.map +0 -1
  221. package/dist/mjs/objectextensions.d.ts +0 -11
  222. package/dist/mjs/objectextensions.js +0 -229
  223. package/dist/mjs/objectextensions.js.map +0 -1
  224. package/dist/mjs/reflectextensions.js +0 -108
  225. package/dist/mjs/reflectextensions.js.map +0 -1
  226. package/dist/mjs/setextensions.d.ts +0 -2
  227. package/dist/mjs/setextensions.js.map +0 -1
  228. package/dist/mjs/stringextensions.js +0 -155
  229. package/dist/mjs/stringextensions.js.map +0 -1
  230. package/dist/mjs/symbolextensions.js +0 -66
  231. package/dist/mjs/symbolextensions.js.map +0 -1
  232. package/dist/mjs/weakrefextensions.js.map +0 -1
  233. package/src/arrayextensions.js +0 -75
  234. package/src/functionextensions.js +0 -225
  235. package/src/globals.js +0 -196
  236. package/src/mapextensions.js +0 -32
  237. package/src/objectextensions.js +0 -256
  238. package/src/reflectextensions.js +0 -118
  239. package/src/stringextensions.js +0 -166
  240. package/src/symbolextensions.js +0 -69
  241. /package/dist/cjs/{newClasses → classes}/asyncIterable.d.ts +0 -0
  242. /package/dist/cjs/{newClasses → classes}/deferred.d.ts +0 -0
  243. /package/dist/cjs/{newClasses → classes}/descriptor.d.ts +0 -0
  244. /package/dist/cjs/{newClasses → classes}/iterable.d.ts +0 -0
  245. /package/dist/cjs/{newClasses → classes}/refmap.d.ts +0 -0
  246. /package/dist/cjs/{newClasses → classes}/refset.d.ts +0 -0
  247. /package/dist/cjs/{functionextensions.d.ts → function.extensions.d.ts} +0 -0
  248. /package/dist/cjs/{globals.d.ts → global.this.d.ts} +0 -0
  249. /package/dist/cjs/{reflectextensions.d.ts → reflect.extensions.d.ts} +0 -0
  250. /package/dist/cjs/{stringextensions.d.ts → string.extensions.d.ts} +0 -0
  251. /package/dist/cjs/{weakrefextensions.d.ts → weakref.extensions.d.ts} +0 -0
  252. /package/dist/mjs/{newClasses → classes}/asyncIterable.d.ts +0 -0
  253. /package/dist/mjs/{newClasses → classes}/asyncIterable.js +0 -0
  254. /package/dist/mjs/{newClasses → classes}/deferred.d.ts +0 -0
  255. /package/dist/mjs/{newClasses → classes}/deferred.js +0 -0
  256. /package/dist/mjs/{newClasses → classes}/descriptor.d.ts +0 -0
  257. /package/dist/mjs/{newClasses → classes}/iterable.d.ts +0 -0
  258. /package/dist/mjs/{newClasses → classes}/iterable.js +0 -0
  259. /package/dist/mjs/{newClasses → classes}/refmap.d.ts +0 -0
  260. /package/dist/mjs/{newClasses → classes}/refset.d.ts +0 -0
  261. /package/dist/mjs/{newClasses → classes}/refset.js +0 -0
  262. /package/dist/mjs/{functionextensions.d.ts → function.extensions.d.ts} +0 -0
  263. /package/dist/mjs/{globals.d.ts → global.this.d.ts} +0 -0
  264. /package/dist/mjs/{reflectextensions.d.ts → reflect.extensions.d.ts} +0 -0
  265. /package/dist/mjs/{stringextensions.d.ts → string.extensions.d.ts} +0 -0
  266. /package/dist/mjs/{weakrefextensions.d.ts → weakref.extensions.d.ts} +0 -0
  267. /package/src/{newClasses → classes}/asyncIterable.js +0 -0
  268. /package/src/{newClasses → classes}/deferred.js +0 -0
  269. /package/src/{newClasses → classes}/iterable.js +0 -0
  270. /package/src/{newClasses → classes}/refset.js +0 -0
  271. /package/src/{weakrefextensions.js → weakref.extensions.js} +0 -0
@@ -0,0 +1,152 @@
1
+ export class ProxyHandlerResponse {
2
+ constructor(success?: boolean, value?: undefined, context?: undefined);
3
+ }
4
+ export class ProxyHandler {
5
+ /**
6
+ * This static method is used to create a response object. The response
7
+ * object contains the success status, the value, and the context of the
8
+ * response. It also includes a getter for the Symbol.toStringTag property
9
+ * that returns the ResponseType of the ProxyHandler.
10
+ *
11
+ * @param {boolean} success - The success status of the response.
12
+ * @param {*} value - The value of the response.
13
+ * @param {Object} context - The context of the response.
14
+ * @returns {Object} The response object.
15
+ *
16
+ * @example
17
+ * // Create a response object
18
+ * const response = ProxyHandler.response(
19
+ * true, 'value', { key: 'context' }
20
+ * );
21
+ *
22
+ * // Output: { success: true, value: 'value', context: { key: 'context' },
23
+ * // [Symbol.toStringTag]: 'ProxyHandlerResponse' }
24
+ * console.log(response);
25
+ */
26
+ static response(success: boolean, value: any, context: Object): Object;
27
+ /**
28
+ * This static getter method is used to retrieve the response type
29
+ * of the ProxyHandler. It returns a string that represents the
30
+ * response type of the ProxyHandler.
31
+ *
32
+ * @property {function} ResponseType - A static getter method that
33
+ * returns the response type of the ProxyHandler.
34
+ * @returns {string} A string representing the response type of the
35
+ * ProxyHandler.
36
+ *
37
+ * @example
38
+ * // Get the response type of the ProxyHandler
39
+ * const responseType = ProxyHandler.ResponseType;
40
+ *
41
+ * // Output: 'ProxyHandlerResponse'
42
+ * console.log(responseType);
43
+ */
44
+ static get ResponseType(): string;
45
+ /**
46
+ * This static method is used to retrieve the name of a ProxyHandler type
47
+ * from a given array of arguments. If the array of arguments matches any
48
+ * of the ProxyHandler types, the name of that type is returned. If no
49
+ * match is found, or if the input is not an array, 'custom' is returned.
50
+ *
51
+ * @param {Array.<*>} proxyHandlerType - An array of arguments to match
52
+ * against the ProxyHandler types.
53
+ * @returns {string} The name of the matching ProxyHandler type, or 'custom'
54
+ * if no match is found.
55
+ *
56
+ * @example
57
+ * // Get the name of a type from its arguments
58
+ * const typeName = ProxyHandler.nameFromType(
59
+ * ['target', 'thisArg', 'argumentsList']
60
+ * );
61
+ *
62
+ * // Output: 'apply'
63
+ * console.log(typeName);
64
+ *
65
+ * @throws {TypeError} If ProxyHandler.type is undefined.
66
+ */
67
+ static nameFromType(proxyHandlerType: Array<any>): string;
68
+ /**
69
+ * This method is used to retrieve all the types of ProxyHandler available
70
+ * in the ProxyHandler.type object. It is useful when you need to iterate
71
+ * over all the types or when you need to check if a certain type exists.
72
+ *
73
+ * @property {function} typeNames - A static getter method that returns an
74
+ * array of keys from the ProxyHandler.type object.
75
+ * @returns {Array.<string>} An array of strings representing the keys of
76
+ * the ProxyHandler.type object.
77
+ *
78
+ * @example
79
+ * // Get all type names
80
+ * const types = ProxyHandler.typeNames;
81
+ *
82
+ * // Output: ['apply', 'construct', 'defineProperty', ...]
83
+ * console.log(types);
84
+ *
85
+ * @throws {TypeError} If ProxyHandler.type is undefined.
86
+ */
87
+ static get typeNames(): string[];
88
+ /**
89
+ * A static getter method that returns an object containing keyed proxy
90
+ * trap types and their associated expected arguments list by name. A
91
+ * docstring description complete with url shortening links for each entry
92
+ * are provided (links go to the MDN documentation)
93
+ *
94
+ * @property {function} type - A static getter method that returns an object
95
+ * of ProxyHandler types.
96
+ * @returns {Object.<string, function>} An object where each key is a type
97
+ * name and each value is a function that returns an array of strings
98
+ * representing the arguments for that type.
99
+ *
100
+ * @example
101
+ * // Get the 'apply' type
102
+ * const applyType = ProxyHandler.type.apply;
103
+ *
104
+ * // Output: ['target', 'thisArg', 'argumentsList']
105
+ * console.log(applyType());
106
+ *
107
+ * @throws {TypeError} If ProxyHandler.type is undefined.
108
+ */
109
+ static get type(): {
110
+ [x: string]: Function;
111
+ };
112
+ constructor(handler: any, type?: Function);
113
+ handler: any;
114
+ typeName: string;
115
+ type: any;
116
+ invoke(...args: any[]): any;
117
+ }
118
+ export class PluggableProxy {
119
+ static get kCreated(): symbol;
120
+ static get kOriginal(): symbol;
121
+ static get kProxy(): symbol;
122
+ constructor(Class: any, handlers: any, options?: {
123
+ prototype: undefined;
124
+ apply: boolean;
125
+ });
126
+ handlers: Map<any, any>;
127
+ handlersOfType(typeName: any): any;
128
+ tryEachOfType(type: any, ...args: any[]): any[];
129
+ apply(target: any, thisArg: any, argumentsList: any): any;
130
+ construct(target: any, args: any): any;
131
+ defineProperty(target: any, key: any, descriptor: any): any;
132
+ deleteProperty(target: any, property: any): any;
133
+ get(target: any, property: any, receiver: any): any;
134
+ getOwnPropertyDescriptor(target: any, property: any): any;
135
+ getPrototypeOf(target: any): any;
136
+ has(target: any, property: any): any;
137
+ isExtensible(target: any): any;
138
+ ownKeys(target: any): any;
139
+ preventExtensions(target: any): any;
140
+ set(target: any, property: any, value: any, receiver: any): any;
141
+ setPrototypeOf(target: any, prototype: any): any;
142
+ }
143
+ export const ProxyHandlerExtensions: Extension;
144
+ export const PluggableProxyExtensions: Extension;
145
+ export const PluggableProxyExtensionSet: {
146
+ name: string;
147
+ extensionObjects: Set<any>;
148
+ extensions: Set<any>;
149
+ apply(): void;
150
+ revert(): void;
151
+ };
152
+ import { Extension } from '@nejs/extension';
@@ -0,0 +1,444 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PluggableProxyExtensionSet = exports.PluggableProxyExtensions = exports.ProxyHandlerExtensions = exports.PluggableProxy = exports.ProxyHandler = exports.ProxyHandlerResponse = void 0;
4
+ const extension_1 = require("@nejs/extension");
5
+ const { toStringTag, hasInstance } = Symbol;
6
+ class ProxyHandlerResponse {
7
+ constructor(success = false, value = undefined, context = undefined) {
8
+ Object.assign(this, { succes, value, context });
9
+ }
10
+ /**
11
+ * A getter method for the toStringTag symbol.
12
+ * This method returns the name of the constructor of the instance.
13
+ * It is used to provide a custom string description of the object,
14
+ * which can be useful for debugging or logging purposes.
15
+ *
16
+ * @example
17
+ * const response = new ProxyHandlerResponse();
18
+ * console.log(response[Symbol.toStringTag]); // logs: "ProxyHandlerResponse"
19
+ *
20
+ * @returns {string} The name of the constructor of the instance.
21
+ */
22
+ get [toStringTag]() { return this.constructor.name; }
23
+ /**
24
+ * This static method is a Symbol.hasInstance method implementation.
25
+ * It checks if the provided instance is an instance of the class.
26
+ * It does this by comparing the instance's toStringTag or constructor
27
+ * to the class's name or the class itself respectively.
28
+ *
29
+ * @param {Object} instance - The instance to check.
30
+ * @returns {boolean} True if the instance is of the class, false otherwise.
31
+ *
32
+ * @example
33
+ * // Assuming MyClass has implemented this method
34
+ * const myInstance = new MyClass();
35
+ * // logs: true
36
+ * console.log(MyClass[Symbol.hasInstance](myInstance));
37
+ */
38
+ static [hasInstance](instance) {
39
+ return (instance?.[toStringTag] === this.name ||
40
+ instance?.constructor === this);
41
+ }
42
+ }
43
+ exports.ProxyHandlerResponse = ProxyHandlerResponse;
44
+ class ProxyHandler {
45
+ constructor(handler, type = ProxyHandler.type.get) {
46
+ this.handler = handler;
47
+ this.typeName = Array.isArray(type)
48
+ ? ProxyHandler.nameFromType(type) ?? 'get'
49
+ : String(type);
50
+ this.type = Array.isArray(type) ? type : ProxyHandler.type[type ?? 'get'];
51
+ }
52
+ invoke(...args) {
53
+ const context = {
54
+ defaultValue: Reflect[this.typeName](...args),
55
+ proxyHandler: this,
56
+ typeHandler: this.handler,
57
+ };
58
+ try {
59
+ const result = this.handler.apply(context, args);
60
+ if (!(result?.[Symbol.toStringTag] === ProxyHandler.ResponseType)) {
61
+ return ProxyHandler.response(!!result, result, context);
62
+ }
63
+ result.context = context;
64
+ return result;
65
+ }
66
+ catch (error) {
67
+ return ProxyHandler.response(false, error);
68
+ }
69
+ }
70
+ /**
71
+ * This static method is used to create a response object. The response
72
+ * object contains the success status, the value, and the context of the
73
+ * response. It also includes a getter for the Symbol.toStringTag property
74
+ * that returns the ResponseType of the ProxyHandler.
75
+ *
76
+ * @param {boolean} success - The success status of the response.
77
+ * @param {*} value - The value of the response.
78
+ * @param {Object} context - The context of the response.
79
+ * @returns {Object} The response object.
80
+ *
81
+ * @example
82
+ * // Create a response object
83
+ * const response = ProxyHandler.response(
84
+ * true, 'value', { key: 'context' }
85
+ * );
86
+ *
87
+ * // Output: { success: true, value: 'value', context: { key: 'context' },
88
+ * // [Symbol.toStringTag]: 'ProxyHandlerResponse' }
89
+ * console.log(response);
90
+ */
91
+ static response(success, value, context) {
92
+ return {
93
+ success, value, context,
94
+ get [Symbol.toStringTag]() { return this.ResponseType; }
95
+ };
96
+ }
97
+ /**
98
+ * This static getter method is used to retrieve the response type
99
+ * of the ProxyHandler. It returns a string that represents the
100
+ * response type of the ProxyHandler.
101
+ *
102
+ * @property {function} ResponseType - A static getter method that
103
+ * returns the response type of the ProxyHandler.
104
+ * @returns {string} A string representing the response type of the
105
+ * ProxyHandler.
106
+ *
107
+ * @example
108
+ * // Get the response type of the ProxyHandler
109
+ * const responseType = ProxyHandler.ResponseType;
110
+ *
111
+ * // Output: 'ProxyHandlerResponse'
112
+ * console.log(responseType);
113
+ */
114
+ static get ResponseType() { return 'ProxyHandlerResponse'; }
115
+ /**
116
+ * This static method is used to retrieve the name of a ProxyHandler type
117
+ * from a given array of arguments. If the array of arguments matches any
118
+ * of the ProxyHandler types, the name of that type is returned. If no
119
+ * match is found, or if the input is not an array, 'custom' is returned.
120
+ *
121
+ * @param {Array.<*>} proxyHandlerType - An array of arguments to match
122
+ * against the ProxyHandler types.
123
+ * @returns {string} The name of the matching ProxyHandler type, or 'custom'
124
+ * if no match is found.
125
+ *
126
+ * @example
127
+ * // Get the name of a type from its arguments
128
+ * const typeName = ProxyHandler.nameFromType(
129
+ * ['target', 'thisArg', 'argumentsList']
130
+ * );
131
+ *
132
+ * // Output: 'apply'
133
+ * console.log(typeName);
134
+ *
135
+ * @throws {TypeError} If ProxyHandler.type is undefined.
136
+ */
137
+ static nameFromType(proxyHandlerType) {
138
+ if (!Array.isArray(proxyHandlerType)) {
139
+ return 'custom';
140
+ }
141
+ const names = Object.entries(ProxyHandler.type);
142
+ for (const [name, args] of names) {
143
+ if (proxyHandlerType.every(element => ~args.indexOf(element))) {
144
+ return name;
145
+ }
146
+ }
147
+ return 'custom';
148
+ }
149
+ /**
150
+ * This method is used to retrieve all the types of ProxyHandler available
151
+ * in the ProxyHandler.type object. It is useful when you need to iterate
152
+ * over all the types or when you need to check if a certain type exists.
153
+ *
154
+ * @property {function} typeNames - A static getter method that returns an
155
+ * array of keys from the ProxyHandler.type object.
156
+ * @returns {Array.<string>} An array of strings representing the keys of
157
+ * the ProxyHandler.type object.
158
+ *
159
+ * @example
160
+ * // Get all type names
161
+ * const types = ProxyHandler.typeNames;
162
+ *
163
+ * // Output: ['apply', 'construct', 'defineProperty', ...]
164
+ * console.log(types);
165
+ *
166
+ * @throws {TypeError} If ProxyHandler.type is undefined.
167
+ */
168
+ static get typeNames() {
169
+ return Object.keys(ProxyHandler.type);
170
+ }
171
+ /**
172
+ * A static getter method that returns an object containing keyed proxy
173
+ * trap types and their associated expected arguments list by name. A
174
+ * docstring description complete with url shortening links for each entry
175
+ * are provided (links go to the MDN documentation)
176
+ *
177
+ * @property {function} type - A static getter method that returns an object
178
+ * of ProxyHandler types.
179
+ * @returns {Object.<string, function>} An object where each key is a type
180
+ * name and each value is a function that returns an array of strings
181
+ * representing the arguments for that type.
182
+ *
183
+ * @example
184
+ * // Get the 'apply' type
185
+ * const applyType = ProxyHandler.type.apply;
186
+ *
187
+ * // Output: ['target', 'thisArg', 'argumentsList']
188
+ * console.log(applyType());
189
+ *
190
+ * @throws {TypeError} If ProxyHandler.type is undefined.
191
+ */
192
+ static get type() {
193
+ return {
194
+ /**
195
+ * The handler.apply() method is a trap for the [[Call]] object internal
196
+ * method, which is used by operations such as function calls.
197
+ * MDN link: https://t.ly/orBsG
198
+ */
199
+ get apply() { return ['target', 'thisArg', 'argumentsList']; },
200
+ /**
201
+ * The handler.construct() method is a trap for the [[Construct]] object
202
+ * internal method, which is used by operations such as the new operator.
203
+ * In order for the new operation to be valid on the resulting Proxy
204
+ * object, the target used to initialize the proxy must itself be a
205
+ * valid constructor.
206
+ * MDN link: https://t.ly/1LukS
207
+ */
208
+ get construct() { return ['target', 'args']; },
209
+ /**
210
+ * The handler.defineProperty() method is a trap for the
211
+ * [[DefineOwnProperty]] object internal method, which is used by
212
+ * operations such as Object.defineProperty().
213
+ * MDN link: https://t.ly/3Ml9y
214
+ */
215
+ get defineProperty() { return ['target', 'key', 'descriptor']; },
216
+ /**
217
+ * The handler.deleteProperty() method is a trap for the [[Delete]]
218
+ * object internal method, which is used by operations such as the
219
+ * delete operator.
220
+ * MDN link: https://t.ly/neu2H
221
+ */
222
+ get deleteProperty() { return ['target', 'property']; },
223
+ /**
224
+ * The handler.get() method is a trap for the [[Get]] object internal
225
+ * method, which is used by operations such as property accessors.
226
+ * MDN link: https://t.ly/E419x
227
+ */
228
+ get get() { return ['target', 'property', 'receiver']; },
229
+ /**
230
+ * The handler.getOwnPropertyDescriptor() method is a trap for the
231
+ * [[GetOwnProperty]] object internal method, which is used by operations
232
+ * such as Object.getOwnPropertyDescriptor().
233
+ * MDN link: https://t.ly/wzPTX
234
+ */
235
+ get getOwnPropertyDescriptor() { return ['target', 'property']; },
236
+ /**
237
+ * The handler.getPrototypeOf() method is a trap for the
238
+ * [[GetPrototypeOf]] object internal method, which is used by operations
239
+ * such as Object.getPrototypeOf().
240
+ * MDN link: https://t.ly/Ww4S1
241
+ */
242
+ get getPrototypeOf() { return ['target']; },
243
+ /**
244
+ * The handler.has() method is a trap for the [[HasProperty]] object
245
+ * internal method, which is used by operations such as the in operator.
246
+ * MDN link: https://t.ly/UcJL-
247
+ */
248
+ get has() { return ['target', 'prototype']; },
249
+ /**
250
+ * The handler.isExtensible() method is a trap for the [[IsExtensible]]
251
+ * object internal method, which is used by operations such as
252
+ * Object.isExtensible().
253
+ * MDN link: https://t.ly/MkdIK
254
+ */
255
+ get isExtensible() { return ['target']; },
256
+ /**
257
+ * The handler.ownKeys() method is a trap for the [[OwnPropertyKeys]]
258
+ * object internal method, which is used by operations such as
259
+ * Object.keys(), Reflect.ownKeys(), etc.
260
+ * MDN link: https://t.ly/QkiTI
261
+ */
262
+ get ownKeys() { return ['target']; },
263
+ /**
264
+ * The handler.preventExtensions() method is a trap for the
265
+ * [[PreventExtensions]] object internal method, which is used by
266
+ * operations such as Object.preventExtensions().
267
+ * MDN link: https://t.ly/nvfjJ
268
+ */
269
+ get preventExtensions() { return ['target']; },
270
+ /**
271
+ * The handler.set() method is a trap for the [[Set]] object internal
272
+ * method, which is used by operations such as using property accessors
273
+ * to set a property's value.
274
+ * MDN link: https://t.ly/FDWcl
275
+ */
276
+ get set() { return ['target', 'property', 'value', 'receiver']; },
277
+ /**
278
+ * The handler.setPrototypeOf() method is a trap for the
279
+ * [[SetPrototypeOf]] object internal method, which is used by operations
280
+ * such as Object.setPrototypeOf().
281
+ * MDN link: https://t.ly/pS8ej
282
+ */
283
+ get setPrototypeOf() { return ['target', 'prototype']; },
284
+ };
285
+ }
286
+ }
287
+ exports.ProxyHandler = ProxyHandler;
288
+ class PluggableProxy {
289
+ constructor(Class, handlers, options = {
290
+ prototype: undefined, // undefined means extract from class
291
+ apply: true,
292
+ }) {
293
+ const validHandlers = handlers.filter(h => h instanceof ProxyHandler);
294
+ Object.assign(this, {
295
+ class: Class instanceof Function ? Class : Class.constructor,
296
+ instance: Class instanceof Function ? null : Class,
297
+ });
298
+ this.handlers = new Map();
299
+ for (let typeName of ProxyHandler.typeNames) {
300
+ const handlersOfType = [].concat(validHandlers.filter(h => h.typeName === typeName));
301
+ this.handlers.set(typeName, handlersOfType);
302
+ }
303
+ this[PluggableProxy.kOriginal] = (options?.prototype ?? Object.getPrototypeOf(this.class));
304
+ this[PluggableProxy.kCreated] = Object.create(this[PluggableProxy.kOriginal], this.instance);
305
+ this[PluggableProxy.kProxy] = new Proxy(this[PluggableProxy.kCreated], this);
306
+ if (options?.apply != true) {
307
+ const target = this?.instance ?? this.class;
308
+ Object.setPrototypeOf(target, this[PluggableProxy.kCreated]);
309
+ }
310
+ }
311
+ handlersOfType(typeName) {
312
+ return this.handlers.get(typeName);
313
+ }
314
+ tryEachOfType(type, ...args) {
315
+ const types = ProxyHandler.typeNames;
316
+ const failures = [];
317
+ for (const handler of types) {
318
+ const result = handler.invoke(...args);
319
+ if (result.success) {
320
+ return [result, failures];
321
+ }
322
+ failures.push(result);
323
+ }
324
+ return [undefined, failures];
325
+ }
326
+ apply(target, thisArg, argumentsList) {
327
+ const type = 'apply', args = [target, thisArg, argumentsList];
328
+ const [result, _fails] = tryEachOfType(type, ...args);
329
+ if (result) {
330
+ return result;
331
+ }
332
+ return Reflect[type](...args);
333
+ }
334
+ construct(target, args) {
335
+ const type = 'construct', _args = [target, args];
336
+ const [result, _fails] = tryEachOfType(type, ..._args);
337
+ if (result) {
338
+ return result;
339
+ }
340
+ return Reflect[type](..._args);
341
+ }
342
+ defineProperty(target, key, descriptor) {
343
+ const type = 'defineProperty', args = [target, key, descriptor];
344
+ const [result, _fails] = tryEachOfType(type, ...args);
345
+ if (result) {
346
+ return result;
347
+ }
348
+ return Reflect[type](...args);
349
+ }
350
+ deleteProperty(target, property) {
351
+ const type = 'deleteProperty', args = [target, property];
352
+ const [result, _fails] = tryEachOfType(type, ...args);
353
+ if (result) {
354
+ return result;
355
+ }
356
+ return Reflect[type](...args);
357
+ }
358
+ get(target, property, receiver) {
359
+ const type = 'get', args = [target, property, receiver];
360
+ const [result, _fails] = tryEachOfType(type, ...args);
361
+ if (result) {
362
+ return result;
363
+ }
364
+ return Reflect[type](...args);
365
+ }
366
+ getOwnPropertyDescriptor(target, property) {
367
+ const type = 'getOwnPropertyDescriptor', args = [target, property];
368
+ const [result, _fails] = tryEachOfType(type, ...args);
369
+ if (result) {
370
+ return result;
371
+ }
372
+ return Reflect[type](...args);
373
+ }
374
+ getPrototypeOf(target) {
375
+ const type = 'getPrototypeOf', args = [target];
376
+ const [result, _fails] = tryEachOfType(type, ...args);
377
+ if (result) {
378
+ return result;
379
+ }
380
+ return Reflect[type](...args);
381
+ }
382
+ has(target, property) {
383
+ const type = 'has', args = [target, property];
384
+ const [result, _fails] = tryEachOfType(type, ...args);
385
+ if (result) {
386
+ return result;
387
+ }
388
+ return Reflect[type](...args);
389
+ }
390
+ isExtensible(target) {
391
+ const type = 'isExtensible', args = [target];
392
+ const [result, _fails] = tryEachOfType(type, ...args);
393
+ if (result) {
394
+ return result;
395
+ }
396
+ return Reflect[type](...args);
397
+ }
398
+ ownKeys(target) {
399
+ const type = 'ownKeys', args = [target];
400
+ const [result, _fails] = tryEachOfType(type, ...args);
401
+ if (result) {
402
+ return result;
403
+ }
404
+ return Reflect[type](...args);
405
+ }
406
+ preventExtensions(target) {
407
+ const type = 'preventExtensions', args = [target];
408
+ const [result, _fails] = tryEachOfType(type, ...args);
409
+ if (result) {
410
+ return result;
411
+ }
412
+ return Reflect[type](...args);
413
+ }
414
+ set(target, property, value, receiver) {
415
+ const type = 'set', args = [target, property, value, receiver];
416
+ const [result, _fails] = tryEachOfType(type, ...args);
417
+ if (result) {
418
+ return result;
419
+ }
420
+ return Reflect[type](...args);
421
+ }
422
+ setPrototypeOf(target, prototype) {
423
+ const type = 'setPrototypeOf', args = [target, prototype];
424
+ const [result, _fails] = tryEachOfType(type, ...args);
425
+ if (result) {
426
+ return result;
427
+ }
428
+ return Reflect[type](...args);
429
+ }
430
+ static get kCreated() {
431
+ return Symbol.for('pp.prototype.created');
432
+ }
433
+ static get kOriginal() {
434
+ return Symbol.for('pp.prototype.original');
435
+ }
436
+ static get kProxy() {
437
+ return Symbol.for('pp.proxy');
438
+ }
439
+ }
440
+ exports.PluggableProxy = PluggableProxy;
441
+ exports.ProxyHandlerExtensions = new extension_1.Extension(ProxyHandler);
442
+ exports.PluggableProxyExtensions = new extension_1.Extension(PluggableProxy);
443
+ exports.PluggableProxyExtensionSet = new extension_1.Extension.ExtensionSet('PluggableProxyExtensionSet', exports.ProxyHandlerExtensions, exports.PluggableProxyExtensions);
444
+ //# sourceMappingURL=pluggable.proxy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pluggable.proxy.js","sourceRoot":"","sources":["../../../src/classes/pluggable.proxy.js"],"names":[],"mappings":"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"}