reslib 1.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.
Files changed (200) hide show
  1. package/README.md +298 -0
  2. package/build/auth/index.d.ts +2034 -0
  3. package/build/auth/index.js +5 -0
  4. package/build/auth/types.d.ts +465 -0
  5. package/build/auth/types.js +1 -0
  6. package/build/countries/countries.d.ts +1454 -0
  7. package/build/countries/countries.js +1 -0
  8. package/build/countries/index.d.ts +159 -0
  9. package/build/countries/index.js +5 -0
  10. package/build/countries/types.d.ts +65 -0
  11. package/build/countries/types.js +1 -0
  12. package/build/currency/currencies.d.ts +8 -0
  13. package/build/currency/currencies.js +1 -0
  14. package/build/currency/index.d.ts +51 -0
  15. package/build/currency/index.js +5 -0
  16. package/build/currency/session.d.ts +23 -0
  17. package/build/currency/session.js +5 -0
  18. package/build/currency/types.d.ts +1039 -0
  19. package/build/currency/types.js +1 -0
  20. package/build/currency/utils.d.ts +25 -0
  21. package/build/currency/utils.js +1 -0
  22. package/build/i18n/index.d.ts +640 -0
  23. package/build/i18n/index.js +5 -0
  24. package/build/inputFormatter/index.d.ts +396 -0
  25. package/build/inputFormatter/index.js +5 -0
  26. package/build/inputFormatter/types.d.ts +544 -0
  27. package/build/inputFormatter/types.js +1 -0
  28. package/build/logger/index.d.ts +235 -0
  29. package/build/logger/index.js +5 -0
  30. package/build/observable/index.d.ts +329 -0
  31. package/build/observable/index.js +1 -0
  32. package/build/platform/index.d.ts +32 -0
  33. package/build/platform/index.js +1 -0
  34. package/build/resources/ResourcePaginationHelper.d.ts +537 -0
  35. package/build/resources/ResourcePaginationHelper.js +2 -0
  36. package/build/resources/decorators/create.decorator.d.ts +20 -0
  37. package/build/resources/decorators/create.decorator.js +1 -0
  38. package/build/resources/decorators/index.d.ts +41 -0
  39. package/build/resources/decorators/index.js +1 -0
  40. package/build/resources/fields/index.d.ts +33 -0
  41. package/build/resources/fields/index.js +1 -0
  42. package/build/resources/filters.d.ts +62 -0
  43. package/build/resources/filters.js +1 -0
  44. package/build/resources/index.d.ts +854 -0
  45. package/build/resources/index.js +6 -0
  46. package/build/resources/types/filters.d.ts +508 -0
  47. package/build/resources/types/filters.js +1 -0
  48. package/build/resources/types/index.d.ts +4138 -0
  49. package/build/resources/types/index.js +1 -0
  50. package/build/session/index.d.ts +1474 -0
  51. package/build/session/index.js +1 -0
  52. package/build/translations/auth.en.d.ts +3 -0
  53. package/build/translations/auth.en.js +1 -0
  54. package/build/translations/countries.en.d.ts +6 -0
  55. package/build/translations/countries.en.js +1 -0
  56. package/build/translations/currencies.en.d.ts +5 -0
  57. package/build/translations/currencies.en.js +1 -0
  58. package/build/translations/date.en.d.ts +19 -0
  59. package/build/translations/date.en.js +1 -0
  60. package/build/translations/index.d.ts +1583 -0
  61. package/build/translations/index.js +5 -0
  62. package/build/translations/resources.en.d.ts +6 -0
  63. package/build/translations/resources.en.js +1 -0
  64. package/build/translations/validator.en.d.ts +104 -0
  65. package/build/translations/validator.en.js +5 -0
  66. package/build/types/date.d.ts +44 -0
  67. package/build/types/date.js +1 -0
  68. package/build/types/dictionary.d.ts +29 -0
  69. package/build/types/dictionary.js +1 -0
  70. package/build/types/i18n.d.ts +121 -0
  71. package/build/types/i18n.js +1 -0
  72. package/build/types/index.d.ts +145 -0
  73. package/build/types/index.js +1 -0
  74. package/build/utils/areEquals.d.ts +19 -0
  75. package/build/utils/areEquals.js +1 -0
  76. package/build/utils/date/dateHelper.d.ts +371 -0
  77. package/build/utils/date/dateHelper.js +5 -0
  78. package/build/utils/date/index.d.ts +212 -0
  79. package/build/utils/date/index.js +5 -0
  80. package/build/utils/date/isDateObj.d.ts +14 -0
  81. package/build/utils/date/isDateObj.js +1 -0
  82. package/build/utils/debounce.d.ts +52 -0
  83. package/build/utils/debounce.js +1 -0
  84. package/build/utils/defaultArray.d.ts +18 -0
  85. package/build/utils/defaultArray.js +1 -0
  86. package/build/utils/defaultBool.d.ts +14 -0
  87. package/build/utils/defaultBool.js +1 -0
  88. package/build/utils/defaultStr.d.ts +17 -0
  89. package/build/utils/defaultStr.js +1 -0
  90. package/build/utils/defaultVal.d.ts +18 -0
  91. package/build/utils/defaultVal.js +1 -0
  92. package/build/utils/dom/index.d.ts +65 -0
  93. package/build/utils/dom/index.js +1 -0
  94. package/build/utils/dom/isDOMElement.d.ts +11 -0
  95. package/build/utils/dom/isDOMElement.js +1 -0
  96. package/build/utils/file/index.d.ts +26 -0
  97. package/build/utils/file/index.js +1 -0
  98. package/build/utils/global.d.ts +53 -0
  99. package/build/utils/global.js +1 -0
  100. package/build/utils/image.d.ts +56 -0
  101. package/build/utils/image.js +1 -0
  102. package/build/utils/index.d.ts +39 -0
  103. package/build/utils/index.js +6 -0
  104. package/build/utils/interpolate.d.ts +105 -0
  105. package/build/utils/interpolate.js +1 -0
  106. package/build/utils/isEmail.d.ts +57 -0
  107. package/build/utils/isEmail.js +1 -0
  108. package/build/utils/isEmpty.d.ts +18 -0
  109. package/build/utils/isEmpty.js +1 -0
  110. package/build/utils/isNonNullString.d.ts +17 -0
  111. package/build/utils/isNonNullString.js +1 -0
  112. package/build/utils/isNullable.d.ts +7 -0
  113. package/build/utils/isNullable.js +1 -0
  114. package/build/utils/isNumber.d.ts +36 -0
  115. package/build/utils/isNumber.js +1 -0
  116. package/build/utils/isPrimitive.d.ts +16 -0
  117. package/build/utils/isPrimitive.js +1 -0
  118. package/build/utils/isPromise.d.ts +14 -0
  119. package/build/utils/isPromise.js +1 -0
  120. package/build/utils/isRegex.d.ts +15 -0
  121. package/build/utils/isRegex.js +1 -0
  122. package/build/utils/isTime.d.ts +18 -0
  123. package/build/utils/isTime.js +1 -0
  124. package/build/utils/json.d.ts +224 -0
  125. package/build/utils/json.js +1 -0
  126. package/build/utils/numbers.d.ts +148 -0
  127. package/build/utils/numbers.js +5 -0
  128. package/build/utils/object.d.ts +567 -0
  129. package/build/utils/object.js +1 -0
  130. package/build/utils/sort.d.ts +67 -0
  131. package/build/utils/sort.js +1 -0
  132. package/build/utils/string.d.ts +165 -0
  133. package/build/utils/string.js +1 -0
  134. package/build/utils/stringify.d.ts +23 -0
  135. package/build/utils/stringify.js +1 -0
  136. package/build/utils/uniqid.d.ts +18 -0
  137. package/build/utils/uniqid.js +1 -0
  138. package/build/utils/uri/index.d.ts +333 -0
  139. package/build/utils/uri/index.js +2 -0
  140. package/build/validator/index.d.ts +4 -0
  141. package/build/validator/index.js +6 -0
  142. package/build/validator/rules/array.d.ts +848 -0
  143. package/build/validator/rules/array.js +5 -0
  144. package/build/validator/rules/boolean.d.ts +87 -0
  145. package/build/validator/rules/boolean.js +5 -0
  146. package/build/validator/rules/date.d.ts +551 -0
  147. package/build/validator/rules/date.js +5 -0
  148. package/build/validator/rules/default.d.ts +367 -0
  149. package/build/validator/rules/default.js +5 -0
  150. package/build/validator/rules/enum.d.ts +155 -0
  151. package/build/validator/rules/enum.js +5 -0
  152. package/build/validator/rules/file.d.ts +356 -0
  153. package/build/validator/rules/file.js +5 -0
  154. package/build/validator/rules/format.d.ts +2825 -0
  155. package/build/validator/rules/format.js +6 -0
  156. package/build/validator/rules/index.d.ts +16 -0
  157. package/build/validator/rules/index.js +6 -0
  158. package/build/validator/rules/multiRules.d.ts +475 -0
  159. package/build/validator/rules/multiRules.js +5 -0
  160. package/build/validator/rules/numeric.d.ts +1135 -0
  161. package/build/validator/rules/numeric.js +5 -0
  162. package/build/validator/rules/string.d.ts +504 -0
  163. package/build/validator/rules/string.js +5 -0
  164. package/build/validator/rules/target.d.ts +137 -0
  165. package/build/validator/rules/target.js +5 -0
  166. package/build/validator/rules/utils.d.ts +1 -0
  167. package/build/validator/rules/utils.js +1 -0
  168. package/build/validator/rulesMarkers.d.ts +11 -0
  169. package/build/validator/rulesMarkers.js +1 -0
  170. package/build/validator/types.d.ts +2906 -0
  171. package/build/validator/types.js +1 -0
  172. package/build/validator/validator.d.ts +3692 -0
  173. package/build/validator/validator.js +5 -0
  174. package/lib/cjs/auth.js +1 -0
  175. package/lib/cjs/countries.js +1 -0
  176. package/lib/cjs/currency.js +1 -0
  177. package/lib/cjs/i18n.js +1 -0
  178. package/lib/cjs/inputFormatter.js +1 -0
  179. package/lib/cjs/logger.js +1 -0
  180. package/lib/cjs/observable.js +1 -0
  181. package/lib/cjs/platform.js +1 -0
  182. package/lib/cjs/resources.js +1 -0
  183. package/lib/cjs/session.js +1 -0
  184. package/lib/cjs/types.js +1 -0
  185. package/lib/cjs/utils.js +1 -0
  186. package/lib/cjs/validator.js +1 -0
  187. package/lib/esm/auth.mjs +1 -0
  188. package/lib/esm/countries.mjs +1 -0
  189. package/lib/esm/currency.mjs +1 -0
  190. package/lib/esm/i18n.mjs +1 -0
  191. package/lib/esm/inputFormatter.mjs +1 -0
  192. package/lib/esm/logger.mjs +1 -0
  193. package/lib/esm/observable.mjs +1 -0
  194. package/lib/esm/platform.mjs +1 -0
  195. package/lib/esm/resources.mjs +1 -0
  196. package/lib/esm/session.mjs +1 -0
  197. package/lib/esm/types.mjs +1 -0
  198. package/lib/esm/utils.mjs +1 -0
  199. package/lib/esm/validator.mjs +1 -0
  200. package/package.json +244 -0
@@ -0,0 +1,165 @@
1
+ /**
2
+ * Removes all occurrences of the specified string from the left side of the current string.
3
+ *
4
+ * This function takes two parameters: the current string and the string to remove.
5
+ * If the string to remove is not provided, it defaults to an empty string and the function simply trims the current string.
6
+ *
7
+ * @param {string} current The string to modify.
8
+ * @param {string} [str=""] The string to remove from the left side of the current string.
9
+ * @returns {string} The modified string with all occurrences of the specified string removed from the left side.
10
+ * @example
11
+ * ```typescript
12
+ * console.log(ltrim(" hello world", " ")); // Output: "hello world"
13
+ * console.log(ltrim("hello world", " ")); // Output: "hello world"
14
+ * console.log(ltrim(" hello world")); // Output: "hello world"
15
+ * ```
16
+ */
17
+ export declare const ltrim: (current: string, str?: string) => string;
18
+ /**
19
+ * Removes all occurrences of the specified string from the right side of the current string.
20
+ *
21
+ * This function takes two parameters: the current string and the string to remove.
22
+ * If the string to remove is not provided, it defaults to an empty string and the function simply trims the current string.
23
+ *
24
+ * @param {string} current The string to modify.
25
+ * @param {string} [str=""] The string to remove from the right side of the current string.
26
+ * @returns {string} The modified string with all occurrences of the specified string removed from the right side.
27
+ * @example
28
+ * ```typescript
29
+ * console.log(rtrim("test heee", "e")); // Output: "test h"
30
+ * console.log(rtrim("hello world", " ")); // Output: "hello world"
31
+ * console.log(rtrim(" hello world")); // Output: " hello world"
32
+ * ```
33
+ */
34
+ export declare const rtrim: (current: string, str?: string) => string;
35
+ /**
36
+ * Checks if the provided string consists only of numbers.
37
+ *
38
+ * This function takes two parameters: the string to check and an optional flag to indicate whether to consider decimal points.
39
+ *
40
+ * @param {string} str The string to check.
41
+ * @param {boolean} [withDecimal=true] Whether to consider decimal points in the check.
42
+ * @returns {boolean} True if the string consists only of numbers, false otherwise.
43
+ * @example
44
+ * ```typescript
45
+ * console.log(isStringNumber("123")); // Output: true
46
+ * console.log(isStringNumber("123.45")); // Output: true
47
+ * console.log(isStringNumber("123.45", false)); // Output: false
48
+ * console.log(isStringNumber("abc")); // Output: false
49
+ * ```
50
+ */
51
+ export declare const isStringNumber: (str: string, withDecimal?: boolean) => boolean;
52
+ /**
53
+ * Extends the String interface with additional methods for string manipulation.
54
+ */
55
+ declare global {
56
+ interface String {
57
+ /**
58
+ * Removes all occurrences of the specified string from the left side of the string.
59
+ * @param {string} [str=""] The string to remove from the left side.
60
+ * @returns {string} The modified string with all occurrences of the specified string removed from the left side.
61
+ */
62
+ ltrim(str?: string): string;
63
+ /**
64
+ * Removes all occurrences of the specified string from the right side of the string.
65
+ * @param {string} [str=""] The string to remove from the right side.
66
+ * @returns {string} The modified string with all occurrences of the specified string removed from the right side.
67
+ */
68
+ rtrim(str?: string): string;
69
+ /**
70
+ * Checks if the string consists only of numbers.
71
+ * @param {boolean} [withDecimal=true] Whether to consider decimal points in the check.
72
+ * @returns {boolean} True if the string consists only of numbers, false otherwise.
73
+ */
74
+ isNumber(withDecimal?: boolean): boolean;
75
+ /**
76
+ * Converts the string to snake case (e.g. "hello world" becomes "hello_world").
77
+ * @returns {string} The string in snake case.
78
+ */
79
+ toSnakeCase(): string;
80
+ /**
81
+ * Converts the string to camel case (e.g. "hello world" becomes "helloWorld").
82
+ * @returns {string} The string in camel case.
83
+ */
84
+ toCamelCase(): string;
85
+ /**
86
+ * Converts the first character of the string to uppercase.
87
+ * @returns {string} The string with the first character in uppercase.
88
+ */
89
+ upperFirst(): string;
90
+ /**
91
+ * Converts the first character of the string to lowercase.
92
+ * @returns {string} The string with the first character in lowercase.
93
+ */
94
+ lowerFirst(): string;
95
+ /**
96
+ * Replaces all occurrences of the specified string with another string.
97
+ * @param {string} find The string to replace.
98
+ * @param {string} replace The string to replace with.
99
+ * @returns {string} The string with all occurrences replaced.
100
+ */
101
+ replaceAll(find: string, replace: string): string;
102
+ }
103
+ }
104
+ /**
105
+ * Converts a string from camel case to snake case (e.g. "addElementComponent" becomes "ADD_ELEMENT_COMPONENT").
106
+ *
107
+ * This function takes a string as input, trims it, and then replaces all occurrences of camel case with underscores.
108
+ * The resulting string is then converted to uppercase.
109
+ *
110
+ * @param {string} text The string to convert.
111
+ * @returns {string} The string in snake case.
112
+ * @example
113
+ * ```typescript
114
+ * console.log(toSnakeCase("thisISDifficult")); // Output: "THIS_IS_DIFFICULT"
115
+ * console.log(toSnakeCase("thisISNT")); // Output: "THIS_ISNT"
116
+ * console.log(toSnakeCase("addElementComponent")); // Output: "ADD_ELEMENT_COMPONENT"
117
+ * ```
118
+ */
119
+ export declare const toSnakeCase: (text: string) => string;
120
+ /**
121
+ * Converts a string from snake case to camel case (e.g. "ADD_ELEMENT_COMPONENT" becomes "addElementComponent").
122
+ *
123
+ * This function takes a string as input, trims it, and then replaces all occurrences of underscores with uppercase letters.
124
+ * The resulting string is then converted to camel case by making the first character lowercase.
125
+ *
126
+ * @param {string} text The string to convert.
127
+ * @returns {string} The string in camel case.
128
+ * @example
129
+ * ```typescript
130
+ * console.log(toCamelCase("THIS_IS_DIFFICULT")); // Output: "thisISDifficult"
131
+ * console.log(toCamelCase("THIS_ISNT")); // Output: "thisISNT"
132
+ * console.log(toCamelCase("ADD_ELEMENT_COMPONENT")); // Output: "addElementComponent"
133
+ * ```
134
+ */
135
+ export declare const toCamelCase: (text: string) => string;
136
+ /**
137
+ * Converts the first character of a string to uppercase.
138
+ *
139
+ * This function takes a string as input, trims it, and then converts the first character to uppercase.
140
+ *
141
+ * @param {string} str The string to modify.
142
+ * @returns {string} The modified string with the first character in uppercase.
143
+ * @example
144
+ * ```typescript
145
+ * console.log(upperFirst("hello world")); // Output: "Hello world"
146
+ * console.log(upperFirst("HELLO WORLD")); // Output: "HELLO WORLD"
147
+ * console.log(upperFirst("")); // Output: ""
148
+ * ```
149
+ */
150
+ export declare const upperFirst: (str: string) => string;
151
+ /**
152
+ * Converts the first character of a string to lowercase.
153
+ *
154
+ * This function takes a string as input, trims it, and then converts the first character to lowercase.
155
+ *
156
+ * @param {string} str The string to modify.
157
+ * @returns {string} The modified string with the first character in lowercase.
158
+ * @example
159
+ * ```typescript
160
+ * console.log(lowerFirst("Hello World")); // Output: "hello World"
161
+ * console.log(lowerFirst("HELLO WORLD")); // Output: "hello WORLD"
162
+ * console.log(lowerFirst("")); // Output: ""
163
+ * ```
164
+ */
165
+ export declare const lowerFirst: (str: string) => string;
@@ -0,0 +1 @@
1
+ 'use strict';function n(t){return !!(t&&typeof t=="string")}var e=function(t,r=""){if(!t||typeof t!="string")return "";if(!r||typeof r!="string")return t.trim();let i=t.length;for(;t.startsWith(r)&&i>=0;)t=t.slice(r.length),--i;return t.toString()},o=function(t,r=""){if(!t||typeof t!="string")return "";if(!r||typeof r!="string")return t.trim();let i=t.length;for(;t.endsWith(r)&&i>=0;)t=t.slice(0,-r.length),--i;return t.toString()},s=(t,r=true)=>typeof t!="string"?false:r!==false?/^\d*\.?\d+$/.test(t):/^\d+$/.test(t);String.prototype.ltrim=function(t){return e(this.toString(),t)};String.prototype.rtrim=function(t){return o(this.toString(),t)};String.prototype.isNumber=function(t=true){return s(this.toString(),t)};String.prototype.replaceAll=function(t,r){return !n(t)||!n(r)?this.toString():this.toString().split(t).join(r)};var g=t=>n(t)?(t=t.trim(),t.replace(/(.)([A-Z][a-z]+)/,"$1_$2").replace(/([a-z0-9])([A-Z])/,"$1_$2").toUpperCase()):"";String.prototype.toSnakeCase=function(){return g(this.toString())};var p=t=>n(t)?(t=t.trim(),t.charAt(0)+t.replace(/(_\w)/g,r=>r[1].toUpperCase()).substring(1)):"";String.prototype.toCamelCase=function(){return p(this.toString())};var l=function(t){return !t||typeof t!="string"?"":(t=t.trim(),t.charAt(0).toUpperCase()+t.slice(1))};String.prototype.upperFirst=function(){return l(this.toString())};var a=function(t){return !t||typeof t!="string"?"":(t=t.trim(),t.charAt(0).toLowerCase()+t.slice(1))};String.prototype.lowerFirst=function(){return a(this.toString())};exports.isStringNumber=s;exports.lowerFirst=a;exports.ltrim=e;exports.rtrim=o;exports.toCamelCase=p;exports.toSnakeCase=g;exports.upperFirst=l;
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Converts a variable to a string representation.
3
+ *
4
+ * This function takes a variable as input and returns a string representation of it.
5
+ * It works similarly to the JSON.stringify function, but with additional options.
6
+ *
7
+ * @param {any} obj The variable to convert to a string.
8
+ * @param {{parenthesis: boolean}} [options] Additional options.
9
+ * @param {boolean} [options.parenthesis=false] Whether to wrap the result in parentheses.
10
+ * @param {boolean} [options.escapeString=true] Whether to escape quotes and other special characters in the string representation.
11
+ * @returns {string} The string representation of the variable.
12
+ * @example
13
+ * ```typescript
14
+ * console.log(stringify({ a: 1, b: 2 })); // Output: "{a:1,b:2}"
15
+ * console.log(stringify({ a: 1, b: 2 }, { parenthesis: true })); // Output: "({a:1,b:2})"
16
+ * console.log(stringify(null)); // Output: "null"
17
+ * console.log(stringify(undefined)); // Output: "undefined"
18
+ * ```
19
+ */
20
+ export declare function stringify(obj: any, options?: {
21
+ parenthesis?: boolean;
22
+ escapeString?: boolean;
23
+ }): string;
@@ -0,0 +1 @@
1
+ 'use strict';function f(r){return !!(r&&typeof r=="string")}function u(...r){for(var e in r){let t=r[e];if(f(t))return t}return ""}function g(r){return typeof r=="number"&&!isNaN(r)&&isFinite(r)}function p(r){return u(r).replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t").replace(/\v/g,"\\v").replace(/[\b]/g,"\\b").replace(/\f/g,"\\f")}function i(r,e){var t=Object.prototype.toString.call(r);return t==="[object "+e+"]"}function a(r,e){if(["boolean","undefined"].includes(typeof r)||r===null)return String(r);if(g(r))return r.formatNumber();if(r instanceof Date)return r.toFormat();if(r instanceof Error)return r==null?void 0:r.toString();e=Object.assign({},e);let{parenthesis:t}=e,c=t?"(":"",s=t?")":"";return typeof r=="string"?(e==null?void 0:e.escapeString)!==false?"'"+p(r)+"'":r:i(r,"RegExp")||i(r,"Number")||i(r,"Boolean")?r.toString():i(r,"Date")?"new Date("+r.getTime()+")":Array.isArray(r)?"["+r.map(n=>a(n,e)).join(",")+"]":typeof r=="object"?c+"{"+Object.keys(r).map(n=>{var l=r[n];return a(n,e)+":"+a(l,e)}).join(",")+"}"+s:r&&typeof(r==null?void 0:r.toString)=="function"?r==null?void 0:r.toString():String(r)}exports.stringify=a;
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Generates a unique identifier.
3
+ *
4
+ * This function takes three parameters: a prefix, a maximum length, and a separator.
5
+ * It generates a unique identifier with the specified prefix, length, and separator.
6
+ *
7
+ * @param {string} [prefix=""] The prefix to use for the identifier.
8
+ * @param {number} [idStrLen=16] The maximum length of the identifier.
9
+ * @param {string} [separator=""] The separator to use in the identifier.
10
+ * @returns {string} The generated unique identifier.
11
+ * @example
12
+ * ```typescript
13
+ * console.log(uniqid()); // Output: a random unique identifier
14
+ * console.log(uniqid("prefix", 16)); // Output: a unique identifier with prefix and length 16
15
+ * console.log(uniqid("prefix", 16, "-")); // Output: a unique identifier with prefix, length 16, and separator "-"
16
+ * ```
17
+ */
18
+ export declare function uniqid(prefix: string, idStrLen?: number, separator?: string): string;
@@ -0,0 +1 @@
1
+ 'use strict';function h(g,t=16,n=""){n=n||"",g=g||"",t<=0&&(t=16),t=Math.floor(t);var o=g+(Math.floor(Math.random()*25)+10).toString(36)+n;o+=new Date().getTime().toString(36)+n;do o+=Math.floor(Math.random()*35).toString(36);while(o.length<t);return o}exports.uniqid=h;
@@ -0,0 +1,333 @@
1
+ import { IParseBaseOptions, IStringifyBaseOptions } from 'qs';
2
+ import { Dictionary } from '../../types';
3
+ /**
4
+ * Returns the query string from a given URL.
5
+ *
6
+ * This function takes a URL and an optional flag as input.
7
+ * It parses the URL to extract the query string, which is the part of the URL after the `?` character.
8
+ * If the `addQuestionSeparator` flag is true, the query string is returned with a leading `?` character.
9
+ *
10
+ * @param uri The URL to extract the query string from.
11
+ * @param addQuestionSeparator Whether to include the `?` character in the returned query string (default: true).
12
+ * @returns The query string associated with the given URL.
13
+ * @example
14
+ * ```typescript
15
+ * const url = 'https://example.com/path?a=1&b=2';
16
+ * console.log(extractQueryString(url)); // Output: "?a=1&b=2"
17
+ * console.log(extractQueryString(url, false)); // Output: "a=1&b=2"
18
+ * ```
19
+ */
20
+ export declare const extractQueryString: (uri?: string, addQuestionSeparator?: boolean) => string;
21
+ /**
22
+ * Returns the query parameters from a given URL as an object.
23
+ *
24
+ * This function takes a URL and an optional options object as input.
25
+ * It extracts the query string from the URL using the `extractQueryString` function and then parses it into an object using the `queryString.parse` method.
26
+ * The `queryString.parse` method is configured to allow sparse arrays and to merge the provided options with the default options.
27
+ *
28
+ * @param uri The URL to extract the query parameters from.
29
+ * @param queryStringOpts Options for the `queryString.parse` method (default: {}).
30
+ * @returns An object containing the query parameters.
31
+ * @example
32
+ * ```typescript
33
+ * const url = 'https://example.com/path?a=1&b=2&c[]=3&c[]=4';
34
+ * console.log(getQueryParams(url)); // Output: { a: '1', b: '2', c: [ '3', '4' ] }
35
+ * ```
36
+ */
37
+ export declare const getQueryParams: (uri: string | null | undefined, queryStringOpts?: IParseBaseOptions) => Dictionary;
38
+ /**
39
+ * Removes the query string from a given URL and returns the resulting URL.
40
+ *
41
+ * This function takes a URL and an optional flag as input.
42
+ * It removes the query string and any fragment identifier from the URL using regular expressions.
43
+ * If the `_decodeURIComponent` flag is true, the resulting URL is decoded using the `decodeURIComponent` function.
44
+ *
45
+ * @param uri The URL to remove the query string from.
46
+ * @param _decodeURIComponent Whether to decode the resulting URL using `decodeURIComponent` (default: false).
47
+ * @returns The URL with the query string removed.
48
+ * @example
49
+ * ```typescript
50
+ * const url = 'https://example.com/path?a=1&b=2#fragment';
51
+ * console.log(removeQueryString(url)); // Output: "https://example.com/path"
52
+ * console.log(removeQueryString(url, true)); // Output: "https://example.com/path" (decoded)
53
+ * ```
54
+ */
55
+ export declare const removeQueryString: (uri: string | undefined | null, _decodeURIComponent?: boolean) => string;
56
+ /**
57
+ * Adds query parameters to a given URL.
58
+ *
59
+ * This function takes a URL, a key-value pair or an object of key-value pairs, and optional options as input.
60
+ * It removes any existing query string from the URL, merges the new query parameters with the existing ones, and then appends the resulting query string to the URL.
61
+ *
62
+ * @param url The URL to add query parameters to.
63
+ * @param key A string key or an object of key-value pairs to add to the query string.
64
+ * @param value The value associated with the key, only applicable when key is a string.
65
+ * @param options Options for the `queryString.stringify` method (default: {}).
66
+ * @returns The URL with the query parameters added.
67
+ * @example
68
+ * ```typescript
69
+ * const url = 'https://example.com/path';
70
+ * console.log(setQueryParams(url, 'a', 1)); // Output: "https://example.com/path?a=1"
71
+ * console.log(setQueryParams(url, { a: 1, b: 2 })); // Output: "https://example.com/path?a=1&b=2"
72
+ * ```
73
+ */
74
+ export declare function setQueryParams(url: string | undefined | null, key: any, value?: any, options?: IStringifyBaseOptions): string;
75
+ /**
76
+ * Converts an object to a query string.
77
+ *
78
+ * This function takes an object and an optional flag as input.
79
+ * It recursively iterates through the object's properties and converts them to a query string format.
80
+ * If the `encodeURI` flag is true, the values are encoded using the `encodeURIComponent` function.
81
+ *
82
+ * @param o The object to convert to a query string.
83
+ * @param encodeURI Whether to encode the values using `encodeURIComponent` (default: false).
84
+ * @returns The object converted to a query string.
85
+ * @example
86
+ * ```typescript
87
+ * const obj = { a: 1, b: 2, c: { d: 3, e: 4 } };
88
+ * console.log(objectToQueryString(obj)); // Output: "a=1&b=2&c[d]=3&c[e]=4"
89
+ * console.log(objectToQueryString(obj, true)); // Output: "a=1&b=2&c%5Bd%5D=3&c%5Be%5D=4"
90
+ * ```
91
+ */
92
+ export declare function objectToQueryString(o: any, encodeURI?: boolean): string;
93
+ /**
94
+ * Parses a URI and returns the parsed object.
95
+ *
96
+ * This function takes a URI as input and returns an object containing the parsed components of the URI.
97
+ * The object includes properties for the hash, host, hostname, href, origin, pathname, port, protocol, search, username, and password.
98
+ *
99
+ * @param uri The URI to parse.
100
+ * @returns The parsed URI object.
101
+ * @example
102
+ * ```typescript
103
+ * const uri = 'http://username:password@localhost:257/deploy/?asd=asd#asd';
104
+ * console.log(parseURI(uri));
105
+ * // Output:
106
+ * // {
107
+ * // hash: "#asd",
108
+ * // host: "localhost:257",
109
+ * // hostname: "localhost",
110
+ * // href: "http://username:password@localhost:257/deploy/?asd=asd#asd",
111
+ * // origin: "http://username:password@localhost:257",
112
+ * // pathname: "/deploy/",
113
+ * // port: "257",
114
+ * // protocol: "http:",
115
+ * // search: "?asd=asd",
116
+ * // username: "username",
117
+ * // password: "password"
118
+ * // }
119
+ * ```
120
+ */
121
+ export declare const parseURI: (uri: string | null | undefined) => {
122
+ hash?: string;
123
+ host?: string;
124
+ hostname?: string;
125
+ href?: string;
126
+ origin?: string;
127
+ pathname?: string;
128
+ port?: string;
129
+ protocol?: string;
130
+ search?: string;
131
+ username?: string;
132
+ password?: string;
133
+ };
134
+ /**
135
+ * Options for configuring URL validation behavior.
136
+ *
137
+ * @public
138
+ */
139
+ export interface IsUrlOptions {
140
+ /**
141
+ * If true, only allows protocols that require a hostname (http, https, ftp, etc.).
142
+ * If false, allows all valid protocols including mailto, tel, data, etc.
143
+ *
144
+ * @defaultValue true
145
+ */
146
+ requireHost?: boolean;
147
+ /**
148
+ * List of allowed protocols. If provided, only URLs with these protocols are considered valid.
149
+ * Protocols should be specified without the trailing colon (e.g., 'http', not 'http:').
150
+ *
151
+ * @defaultValue undefined (all protocols allowed based on requireHost setting)
152
+ *
153
+ * @example
154
+ * ```typescript
155
+ * // Only allow HTTPS URLs
156
+ * isUrl('https://example.com', { allowedProtocols: ['https'] }); // true
157
+ * isUrl('http://example.com', { allowedProtocols: ['https'] }); // false
158
+ * ```
159
+ */
160
+ allowedProtocols?: string[];
161
+ }
162
+ /**
163
+ * Validates whether a given string is a valid, full URL.
164
+ *
165
+ * @remarks
166
+ * This function uses a dual-approach validation strategy:
167
+ * 1. First attempts to use the native URL constructor if available (modern environments)
168
+ * 2. Falls back to a comprehensive regex pattern for environments without URL support
169
+ *
170
+ * By default, a valid full URL must include:
171
+ * - A protocol (http, https, ftp, etc.)
172
+ * - A domain/host (for protocols that require one)
173
+ * - Optional path, query parameters, and hash fragments
174
+ *
175
+ * The function can be configured to:
176
+ * - Accept only host-requiring protocols (default)
177
+ * - Accept any valid URI including mailto:, tel:, data:, etc.
178
+ * - Restrict to specific protocols only
179
+ *
180
+ * @param value - The string to test for URL validity
181
+ * @param options - Optional configuration for validation behavior
182
+ *
183
+ * @returns `true` if the string is a valid full URL, `false` otherwise
184
+ *
185
+ * @example
186
+ * Basic usage:
187
+ * ```typescript
188
+ * isUrl('https://example.com'); // true
189
+ * isUrl('example.com'); // false (missing protocol)
190
+ * isUrl('mailto:user@example.com'); // false (default requires host)
191
+ * ```
192
+ *
193
+ * @example
194
+ * Allow all valid URIs:
195
+ * ```typescript
196
+ * isUrl('mailto:user@example.com', { requireHost: false }); // true
197
+ * isUrl('tel:+1234567890', { requireHost: false }); // true
198
+ * isUrl('data:text/plain,hello', { requireHost: false }); // true
199
+ * ```
200
+ *
201
+ * @example
202
+ * Restrict to specific protocols:
203
+ * ```typescript
204
+ * isUrl('https://example.com', { allowedProtocols: ['https'] }); // true
205
+ * isUrl('http://example.com', { allowedProtocols: ['https'] }); // false
206
+ * ```
207
+ *
208
+ * @public
209
+ */
210
+ export declare function isUrl(value: string, options?: IsUrlOptions): boolean;
211
+ /**
212
+ * Detects if a URL string has been encoded using encodeURIComponent.
213
+ *
214
+ * This function uses multiple heuristics to determine if a string has been
215
+ * encoded with encodeURIComponent. It checks for:
216
+ * 1. Presence of valid encoded character sequences (%XX where XX are hex digits)
217
+ * 2. Whether decoding changes the string (indicating encoded content)
218
+ * 3. Handles mixed encoded/unencoded content properly
219
+ *
220
+ * @param {any} str - The string to check for encoding
221
+ * @returns {boolean} - Returns true if the string appears to be encoded, false otherwise
222
+ *
223
+ * @example
224
+ * console.log(isUriEncoded('hello%20world')); // true
225
+ * console.log(isUriEncoded('hello world')); // false
226
+ * console.log(isUriEncoded('hello%2Bworld')); // true
227
+ * console.log(isUriEncoded('hello+world')); // false
228
+ * console.log(isUriEncoded('https%3A%2F%2Fexample.com')); // true
229
+ * console.log(isUriEncoded('https://example.com')); // false
230
+ * console.log(isUriEncoded('hello%20world%21normal')); // true (mixed)
231
+ */
232
+ export declare const isUriEncoded: (str: string) => boolean;
233
+ /**
234
+ * Options for configuring Data URL validation behavior.
235
+ *
236
+ * @public
237
+ */
238
+ export interface IsDataUrlOptions {
239
+ /**
240
+ * List of allowed MIME types. If provided, only Data URLs with these MIME types are considered valid.
241
+ * MIME types should be specified in lowercase (e.g., 'image/png', 'text/plain').
242
+ *
243
+ * @defaultValue undefined (all MIME types allowed)
244
+ *
245
+ * @example
246
+ * ```typescript
247
+ * // Only allow image Data URLs
248
+ * isDataUrl('', { allowedMimeTypes: ['image/png', 'image/jpeg'] }); // true
249
+ * isDataUrl('data:text/plain;base64,ABC', { allowedMimeTypes: ['image/png'] }); // false
250
+ * ```
251
+ */
252
+ allowedMimeTypes?: string[];
253
+ /**
254
+ * If true, requires the Data URL to use base64 encoding.
255
+ * If false, allows both base64 and URL-encoded data.
256
+ *
257
+ * @defaultValue false
258
+ *
259
+ * @example
260
+ * ```typescript
261
+ * isDataUrl('data:text/plain;base64,SGVsbG8=', { requireBase64: true }); // true
262
+ * isDataUrl('data:text/plain,Hello', { requireBase64: true }); // false
263
+ * ```
264
+ */
265
+ requireBase64?: boolean;
266
+ /**
267
+ * If true, validates that base64-encoded data appears to be valid base64.
268
+ * Performs basic validation of base64 character set and padding.
269
+ *
270
+ * @defaultValue false
271
+ *
272
+ * @example
273
+ * ```typescript
274
+ * isDataUrl('data:text/plain;base64,SGVsbG8=', { validateBase64: true }); // true
275
+ * isDataUrl('data:text/plain;base64,!!!invalid', { validateBase64: true }); // false
276
+ * ```
277
+ */
278
+ validateBase64?: boolean;
279
+ }
280
+ /**
281
+ * Validates whether a given string is a valid Data URL (RFC 2897).
282
+ *
283
+ * @remarks
284
+ * Data URLs allow embedding small files inline in documents using the format:
285
+ * `data:[<mediatype>][;base64],<data>`
286
+ *
287
+ * This function validates:
288
+ * - Proper data: protocol prefix
289
+ * - Valid MIME type format (if present)
290
+ * - Proper encoding declaration (base64 or URL-encoded)
291
+ * - Data payload presence
292
+ *
293
+ * Components of a Data URL:
294
+ * - Protocol: Always "data:"
295
+ * - Media type (optional): MIME type like "text/plain" or "image/png" (defaults to "text/plain;charset=US-ASCII")
296
+ * - Encoding (optional): ";base64" for base64 encoding (defaults to URL encoding)
297
+ * - Data: The actual content after the comma
298
+ *
299
+ * The function uses a dual-approach validation strategy:
300
+ * 1. First attempts to use the native URL constructor if available (modern environments)
301
+ * 2. Falls back to a comprehensive regex pattern for environments without URL support
302
+ *
303
+ * @param value - The string to test for Data URL validity
304
+ * @param options - Optional configuration for validation behavior
305
+ *
306
+ * @returns `true` if the string is a valid Data URL, `false` otherwise
307
+ *
308
+ * @example
309
+ * Basic usage:
310
+ * ```typescript
311
+ * isDataUrl('data:text/plain,Hello%20World'); // true
312
+ * isDataUrl('data:text/plain;base64,SGVsbG8gV29ybGQ='); // true
313
+ * isDataUrl('...'); // true
314
+ * isDataUrl('not a data url'); // false
315
+ * ```
316
+ *
317
+ * @example
318
+ * With MIME type filtering:
319
+ * ```typescript
320
+ * isDataUrl('', { allowedMimeTypes: ['image/png'] }); // true
321
+ * isDataUrl('data:text/plain,Hello', { allowedMimeTypes: ['image/png'] }); // false
322
+ * ```
323
+ *
324
+ * @example
325
+ * Require base64 encoding:
326
+ * ```typescript
327
+ * isDataUrl('data:text/plain;base64,SGVsbG8=', { requireBase64: true }); // true
328
+ * isDataUrl('data:text/plain,Hello', { requireBase64: true }); // false
329
+ * ```
330
+ *
331
+ * @public
332
+ */
333
+ export declare function isDataUrl(value: string, options?: IsDataUrlOptions): boolean;
@@ -0,0 +1,2 @@
1
+ 'use strict';var R=require('qs');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var R__default=/*#__PURE__*/_interopDefault(R);var L=Object.defineProperty;var P=Object.getOwnPropertySymbols;var T=Object.prototype.hasOwnProperty,B=Object.prototype.propertyIsEnumerable;var A=(t,e,r)=>e in t?L(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r,w=(t,e)=>{for(var r in e||(e={}))T.call(e,r)&&A(t,r,e[r]);if(P)for(var r of P(e))B.call(e,r)&&A(t,r,e[r]);return t};function g(t){return !!(t&&typeof t=="string")}var U=function(t,e=""){if(!t||typeof t!="string")return "";if(!e||typeof e!="string")return t.trim();let r=t.length;for(;t.startsWith(e)&&r>=0;)t=t.slice(e.length),--r;return t.toString()},C=function(t,e=""){if(!t||typeof t!="string")return "";if(!e||typeof e!="string")return t.trim();let r=t.length;for(;t.endsWith(e)&&r>=0;)t=t.slice(0,-e.length),--r;return t.toString()},N=(t,e=true)=>typeof t!="string"?false:e!==false?/^\d*\.?\d+$/.test(t):/^\d+$/.test(t);String.prototype.ltrim=function(t){return U(this.toString(),t)};String.prototype.rtrim=function(t){return C(this.toString(),t)};String.prototype.isNumber=function(t=true){return N(this.toString(),t)};String.prototype.replaceAll=function(t,e){return !g(t)||!g(e)?this.toString():this.toString().split(t).join(e)};var q=t=>g(t)?(t=t.trim(),t.replace(/(.)([A-Z][a-z]+)/,"$1_$2").replace(/([a-z0-9])([A-Z])/,"$1_$2").toUpperCase()):"";String.prototype.toSnakeCase=function(){return q(this.toString())};var D=t=>g(t)?(t=t.trim(),t.charAt(0)+t.replace(/(_\w)/g,e=>e[1].toUpperCase()).substring(1)):"";String.prototype.toCamelCase=function(){return D(this.toString())};var F=function(t){return !t||typeof t!="string"?"":(t=t.trim(),t.charAt(0).toUpperCase()+t.slice(1))};String.prototype.upperFirst=function(){return F(this.toString())};var M=function(t){return !t||typeof t!="string"?"":(t=t.trim(),t.charAt(0).toLowerCase()+t.slice(1))};String.prototype.lowerFirst=function(){return M(this.toString())};var W=(t,e=true)=>{if(typeof t!="string")return "";let r=V(t);return t=typeof r.search=="string"?r.search:"",e&&t?"?"+U(t,"?"):(t=C(U(t.trim(),"?"),"?"),t)},Z=function(t,e={}){return typeof t!="string"?{}:R__default.default.parse(W(t,false),w({allowSparse:true,decoder:r=>decodeURIComponent(r.replace(/\+/g," "))},Object.assign({},e)))},E=function(t,e=false){return typeof t!="string"?"":(t=t.replace(/#.*$/,"").replace(/\?.*$/,""),e===true?decodeURIComponent(t):t)},Q={indices:true,encodeValuesOnly:false,skipNulls:false,arrayFormat:"indices",encoder:t=>encodeURIComponent(t).replace(/%5B/g,"[").replace(/%5D/g,"]")};function rt(t,e,r,s={}){if(typeof t!="string")return "";t||(t="");let i=Z(t),n=t.split("#"),a=n[0],d=n[1]?"#"+n[1]:"";t=E(a),typeof e=="object"?(e||(e={}),s=typeof s=="object"&&s?s:typeof r=="object"&&r?r:{}):typeof e=="string"&&(e={[e]:r}),typeof e=="object"&&e&&!Array.isArray(e)&&Object.assign(i,e);let u=R__default.default.stringify(i,w(w({},Q),Object.assign({},s)));return t+(u?"?"+u:"")+d}function nt(t,e=false){if(t==null||typeof t!="object")return "";function r(i,n){if(Array.isArray(i)){i.forEach(function(a){r(a,n+"[]");});return}if(i!==null&&typeof i=="object"){Object.keys(i).forEach(function(a){r(i[a],n+"["+a+"]");});return}s.push((e?encodeURIComponent(n):n)+"="+(e?encodeURIComponent(i):i));}let s=[];return Object.keys(t).forEach(function(i){r(t[i],i);}),s.join("&")}var V=t=>{if(typeof t!="string")return {};if(typeof URL!="undefined"&&URL&&H(t))try{return new URL(t)}catch(s){}t=_(t)?decodeURIComponent(t):t;var e=t.match(/^(([^:\\/?#]+:)?(?:\/\/((?:([^\\/?#:]*):([^\\/?#:]*)@)?([^\\/?#:]*)(?::([^\\/?#:]*))?)))?([^?#]*)(\?[^#]*)?(#.*)?$/);let r=e?{hash:e[10]||"",host:e[3]||"",hostname:e[6]||"",href:e[0]||"",origin:e[1]||"",pathname:e[8]||(e[1]?"/":""),port:e[7]||"",protocol:e[2]||"",search:e[9]||"",username:e[4]||"",password:e[5]||""}:{};return r.protocol&&r.protocol.length==2&&(r.protocol="file:///"+r.protocol.toUpperCase(),r.origin=r.protocol+"//"+r.host),r.protocol&&(r.href=r.origin+r.pathname+r.search+r.hash),r};function H(t,e={}){let{requireHost:r=true,allowedProtocols:s}=Object.assign({},e);if(!g(t)||!g(t.trim()))return false;let i=t;if(typeof URL!="undefined"&&URL)try{let n=new URL(i);if(!n.protocol||n.protocol===":")return !1;let a=n.protocol.slice(0,-1);if(s&&s.length>0&&!s.includes(a))return !1;if(r)if(["http","https","ftp","ftps","ws","wss"].includes(a)){if(!g(n.hostname)||!n.hostname.trim()||!g(n.host)||!n.host.trim())return !1;let u=`${a}://`;if(!i.startsWith(u)||i.slice(u.length).startsWith("/"))return !1;let p=/^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$/,h=n.hostname.match(p);if(h&&!h.slice(1,5).map(Number).every(o=>o>=0&&o<=255))return !1}else return !1;return !0}catch(n){return false}if(r){let n=i.indexOf("://");if(n===-1)return false;let a=i.slice(0,n);if(!a||s&&s.length>0&&!s.includes(a))return false;let d=i.slice(n+3);if(d==="")return false;let u=d.indexOf("@"),c=u>=0?d.slice(u+1):d;if(c===""||c.startsWith("/"))return false;let p=c.indexOf("/"),h=c.indexOf("?"),x=c.indexOf("#"),b=Math.min(p>=0?p:c.length,h>=0?h:c.length,x>=0?x:c.length),o=c.slice(0,b);if(!o)return false;let l=o;if(o.startsWith("[")){let f=o.indexOf("]");if(f===-1)return false;l=o.slice(0,f+1);let m=o.slice(f+1);if(m&&!m.startsWith(":"))return false}else {let f=o.indexOf(":");f>=0&&(l=o.slice(0,f));}if(!l)return false;if(l==="localhost")return true;if(/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/.test(l))return !l.split(".").map(Number).some(m=>m>255||m<0);if(/^\[.*\]$/.test(l)){let f=l.slice(1,-1);return !(!f||f.includes(":::"))}return !!(/^[a-zA-Z\d-]*(\.[a-zA-Z\d-]+)*$/.test(l)&&l!=="")}else {let n="[a-zA-Z][a-zA-Z\\d+\\-.]*";return s&&s.length>0&&(n=`(?:${s.join("|")})`),new RegExp(`^(${n}):.+$`).test(i)}}var _=t=>{if(!g(t)||!t.includes("%"))return false;let e=/%[0-9A-Fa-f]{2}/g;if(!t.match(e))return false;try{let s=decodeURIComponent(t);if(s!==t)return !0;try{if(decodeURIComponent(s)!==s)return !0}catch(i){return !0}}catch(s){return false}return false};function st(t,e={}){let{allowedMimeTypes:r,requireBase64:s=false,validateBase64:i=false}=Object.assign({},e);if(typeof t!="string"||t.trim()==="")return false;let n=t.trim();if(!n.toLowerCase().startsWith("data:"))return false;if(typeof URL!="undefined")try{if(new URL(n).protocol!=="data:")return !1;let o=/^data:([^,;]*)(;[^,]*)?,(.*)$/i,l=n.match(o);if(!l)return !1;let[,f,m,y]=l;if(y===void 0||y.length===0)return !1;let I=(f||"text/plain").trim().toLowerCase();if(f&&f.trim()!==""&&!/^[a-z]+\/[a-z0-9][a-z0-9\-+.]*$/i.test(I)||r&&r.length>0&&!r.some(S=>S.toLowerCase()===I))return !1;let O=(m==null?void 0:m.toLowerCase().includes("base64"))||!1;if(s&&!O)return !1;if(i&&O){if(!/^[A-Za-z0-9+/]*={0,2}$/.test(y)||y.length%4!==0)return !1;let S=y.match(/=+$/);if(S&&S[0].length>2)return !1;if(y.includes("=")){let j=y.indexOf("="),z=y.slice(j);if(!/^=+$/.test(z))return !1}}return !0}catch(b){return false}let a=/^data:([^,;]*)(;[^,]*)?,(.+)$/i,d=n.match(a);if(!d)return false;let[,u,c,p]=d,h=(u||"text/plain").trim().toLowerCase();if(u&&u.trim()!==""&&!/^[a-z]+\/[a-z0-9][a-z0-9\-+.]*$/i.test(h)||r&&r.length>0&&!r.some(o=>o.toLowerCase()===h))return false;let x=(c==null?void 0:c.toLowerCase().includes("base64"))||false;if(s&&!x)return false;if(i&&x){if(!/^[A-Za-z0-9+/]*={0,2}$/.test(p)||p.length%4!==0)return false;let o=p.match(/=+$/);if(o&&o[0].length>2)return false;if(p.includes("=")){let l=p.indexOf("="),f=p.slice(l);if(!/^=+$/.test(f))return false}}return true}
2
+ exports.extractQueryString=W;exports.getQueryParams=Z;exports.isDataUrl=st;exports.isUriEncoded=_;exports.isUrl=H;exports.objectToQueryString=nt;exports.parseURI=V;exports.removeQueryString=E;exports.setQueryParams=rt;
@@ -0,0 +1,4 @@
1
+ import 'reflect-metadata';
2
+ export * from './rules';
3
+ export * from './types';
4
+ export * from './validator';