parse-server 9.6.0-alpha.30 → 9.6.0-alpha.32
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/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +3 -3
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +27 -27
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +8 -8
- package/lib/Config.js +6 -5
- package/lib/Controllers/DatabaseController.js +7 -7
- package/lib/Controllers/FilesController.js +2 -2
- package/lib/Controllers/LiveQueryController.js +2 -2
- package/lib/Controllers/ParseGraphQLController.js +3 -2
- package/lib/Controllers/SchemaController.js +2 -2
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +6 -5
- package/lib/GraphQL/transformers/query.js +2 -2
- package/lib/RestQuery.js +4 -4
- package/lib/Routers/FilesRouter.js +2 -2
- package/lib/Routers/PagesRouter.js +2 -2
- package/lib/Routers/UsersRouter.js +8 -3
- package/lib/Security/Check.js +2 -2
- package/lib/StatusHandler.js +3 -2
- package/lib/Utils.js +74 -8
- package/lib/middlewares.js +4 -3
- package/lib/triggers.js +3 -2
- package/package.json +1 -1
package/lib/Utils.js
CHANGED
|
@@ -8,6 +8,9 @@
|
|
|
8
8
|
|
|
9
9
|
const path = require('path');
|
|
10
10
|
const fs = require('fs').promises;
|
|
11
|
+
const {
|
|
12
|
+
types
|
|
13
|
+
} = require('util');
|
|
11
14
|
|
|
12
15
|
/**
|
|
13
16
|
* The general purpose utilities.
|
|
@@ -131,12 +134,75 @@ class Utils {
|
|
|
131
134
|
}
|
|
132
135
|
|
|
133
136
|
/**
|
|
134
|
-
*
|
|
135
|
-
* @param {any}
|
|
136
|
-
* @returns {Boolean} Returns true if the
|
|
137
|
+
* Realm-safe check for Date.
|
|
138
|
+
* @param {any} value The value to check.
|
|
139
|
+
* @returns {Boolean} Returns true if the value is a Date.
|
|
137
140
|
*/
|
|
138
|
-
static
|
|
139
|
-
return
|
|
141
|
+
static isDate(value) {
|
|
142
|
+
return types.isDate(value);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
/**
|
|
146
|
+
* Realm-safe check for RegExp.
|
|
147
|
+
* @param {any} value The value to check.
|
|
148
|
+
* @returns {Boolean} Returns true if the value is a RegExp.
|
|
149
|
+
*/
|
|
150
|
+
static isRegExp(value) {
|
|
151
|
+
return types.isRegExp(value);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Realm-safe check for Map.
|
|
156
|
+
* @param {any} value The value to check.
|
|
157
|
+
* @returns {Boolean} Returns true if the value is a Map.
|
|
158
|
+
*/
|
|
159
|
+
static isMap(value) {
|
|
160
|
+
return types.isMap(value);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/**
|
|
164
|
+
* Realm-safe check for Set.
|
|
165
|
+
* @param {any} value The value to check.
|
|
166
|
+
* @returns {Boolean} Returns true if the value is a Set.
|
|
167
|
+
*/
|
|
168
|
+
static isSet(value) {
|
|
169
|
+
return types.isSet(value);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Realm-safe check for native Error.
|
|
174
|
+
* @param {any} value The value to check.
|
|
175
|
+
* @returns {Boolean} Returns true if the value is a native Error.
|
|
176
|
+
*/
|
|
177
|
+
static isNativeError(value) {
|
|
178
|
+
return types.isNativeError(value);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/**
|
|
182
|
+
* Realm-safe check for Promise (duck-typed as thenable).
|
|
183
|
+
* Guards against Object.prototype pollution by ensuring `then` is not
|
|
184
|
+
* inherited solely from Object.prototype.
|
|
185
|
+
* @param {any} value The value to check.
|
|
186
|
+
* @returns {Boolean} Returns true if the value is a Promise or thenable.
|
|
187
|
+
*/
|
|
188
|
+
static isPromise(value) {
|
|
189
|
+
if (value == null || typeof value.then !== 'function') {
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
return Object.getPrototypeOf(value) !== Object.prototype || Object.prototype.hasOwnProperty.call(value, 'then');
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
* Realm-safe check for object type. Uses `typeof` instead of `instanceof Object`
|
|
197
|
+
* which fails across realms. Returns true for any non-null value where
|
|
198
|
+
* `typeof` is `'object'`, including plain objects, arrays, dates, maps, sets,
|
|
199
|
+
* regex, and boxed primitives (e.g. `new String()`). Returns false for `null`,
|
|
200
|
+
* `undefined`, unboxed primitives, and functions.
|
|
201
|
+
* @param {any} value The value to check.
|
|
202
|
+
* @returns {Boolean} Returns true if the value is a non-null object type.
|
|
203
|
+
*/
|
|
204
|
+
static isObject(value) {
|
|
205
|
+
return typeof value === 'object' && value !== null;
|
|
140
206
|
}
|
|
141
207
|
|
|
142
208
|
/**
|
|
@@ -432,10 +498,10 @@ class Utils {
|
|
|
432
498
|
static getCircularReplacer() {
|
|
433
499
|
const seen = new WeakSet();
|
|
434
500
|
return (key, value) => {
|
|
435
|
-
if (value
|
|
501
|
+
if (Utils.isMap(value)) {
|
|
436
502
|
return Object.fromEntries(value);
|
|
437
503
|
}
|
|
438
|
-
if (value
|
|
504
|
+
if (Utils.isSet(value)) {
|
|
439
505
|
return Array.from(value);
|
|
440
506
|
}
|
|
441
507
|
if (typeof value === 'object' && value !== null) {
|
|
@@ -508,4 +574,4 @@ class Utils {
|
|
|
508
574
|
}
|
|
509
575
|
}
|
|
510
576
|
module.exports = Utils;
|
|
511
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["path","require","fs","promises","Utils","getLocalizedPath","defaultPath","locale","file","basename","basePath","dirname","localePath","join","localeFileExists","fileExists","subdir","language","split","languagePath","languageFileExists","access","isPath","s","test","flattenObject","obj","parentKey","delimiter","result","key","Object","prototype","hasOwnProperty","call","newKey","isPromise","object","Promise","getObjectKeyPermutations","index","current","results","keys","values","value","nextIndex","length","assign","push","validateParams","params","types","type","isOptional","o","param","v","t","relativeTimeToDate","text","now","Date","toLowerCase","parts","filter","part","future","past","status","info","slice","pairs","shift","seconds","num","interval","val","Number","isInteger","milliseconds","valueOf","objectContainsKeyValue","isMatch","a","b","RegExp","isKeyMatch","k","isValueMatch","stack","seen","WeakSet","pop","has","add","entries","undefined","includes","toString","checkProhibitedKeywords","config","data","requestKeywordDenylist","keyword","match","JSON","stringify","addNestedKeysToRoot","encodeForUrl","input","encodeURIComponent","replace","char","charCodeAt","toUpperCase","getCircularReplacer","Map","fromEntries","Set","Array","from","getNestedProperty","parseSizeToBytes","size","isFinite","Error","Math","floor","str","String","trim","parseFloat","unit","module","exports"],"sources":["../src/Utils.js"],"sourcesContent":["/**\n * utils.js\n * @file General purpose utilities\n * @description General purpose utilities.\n */\n\nconst path = require('path');\nconst fs = require('fs').promises;\n\n/**\n * The general purpose utilities.\n */\nclass Utils {\n  /**\n   * @function getLocalizedPath\n   * @description Returns a localized file path accoring to the locale.\n   *\n   * Localized files are searched in subfolders of a given path, e.g.\n   *\n   * root/\n   * ├── base/                    // base path to files\n   * │   ├── example.html         // default file\n   * │   └── de/                  // de language folder\n   * │   │   └── example.html     // de localized file\n   * │   └── de-AT/               // de-AT locale folder\n   * │   │   └── example.html     // de-AT localized file\n   *\n   * Files are matched with the locale in the following order:\n   * 1. Locale match, e.g. locale `de-AT` matches file in folder `de-AT`.\n   * 2. Language match, e.g. locale `de-AT` matches file in folder `de`.\n   * 3. Default; file in base folder is returned.\n   *\n   * @param {String} defaultPath The absolute file path, which is also\n   * the default path returned if localization is not available.\n   * @param {String} locale The locale.\n   * @returns {Promise<Object>} The object contains:\n   * - `path`: The path to the localized file, or the original path if\n   *   localization is not available.\n   * - `subdir`: The subdirectory of the localized file, or undefined if\n   *   there is no matching localized file.\n   */\n  static async getLocalizedPath(defaultPath, locale) {\n    // Get file name and paths\n    const file = path.basename(defaultPath);\n    const basePath = path.dirname(defaultPath);\n\n    // If locale is not set return default file\n    if (!locale) {\n      return { path: defaultPath };\n    }\n\n    // Check file for locale exists\n    const localePath = path.join(basePath, locale, file);\n    const localeFileExists = await Utils.fileExists(localePath);\n\n    // If file for locale exists return file\n    if (localeFileExists) {\n      return { path: localePath, subdir: locale };\n    }\n\n    // Check file for language exists\n    const language = locale.split('-')[0];\n    const languagePath = path.join(basePath, language, file);\n    const languageFileExists = await Utils.fileExists(languagePath);\n\n    // If file for language exists return file\n    if (languageFileExists) {\n      return { path: languagePath, subdir: language };\n    }\n\n    // Return default file\n    return { path: defaultPath };\n  }\n\n  /**\n   * @function fileExists\n   * @description Checks whether a file exists.\n   * @param {String} path The file path.\n   * @returns {Promise<Boolean>} Is true if the file can be accessed, false otherwise.\n   */\n  static async fileExists(path) {\n    try {\n      await fs.access(path);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * @function isPath\n   * @description Evaluates whether a string is a file path (as opposed to a URL for example).\n   * @param {String} s The string to evaluate.\n   * @returns {Boolean} Returns true if the evaluated string is a path.\n   */\n  static isPath(s) {\n    return /(^\\/)|(^\\.\\/)|(^\\.\\.\\/)/.test(s);\n  }\n\n  /**\n   * Flattens an object and crates new keys with custom delimiters.\n   * @param {Object} obj The object to flatten.\n   * @param {String} [delimiter='.'] The delimiter of the newly generated keys.\n   * @param {Object} result\n   * @returns {Object} The flattened object.\n   **/\n  static flattenObject(obj, parentKey, delimiter = '.', result = {}) {\n    for (const key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        const newKey = parentKey ? parentKey + delimiter + key : key;\n\n        if (typeof obj[key] === 'object' && obj[key] !== null) {\n          this.flattenObject(obj[key], newKey, delimiter, result);\n        } else {\n          result[newKey] = obj[key];\n        }\n      }\n    }\n    return result;\n  }\n\n  /**\n   * Determines whether an object is a Promise.\n   * @param {any} object The object to validate.\n   * @returns {Boolean} Returns true if the object is a promise.\n   */\n  static isPromise(object) {\n    return object instanceof Promise;\n  }\n\n  /**\n   * Creates an object with all permutations of the original keys.\n   * For example, this definition:\n   * ```\n   * {\n   *   a: [true, false],\n   *   b: [1, 2],\n   *   c: ['x']\n   * }\n   * ```\n   * permutates to:\n   * ```\n   * [\n   *   { a: true, b: 1, c: 'x' },\n   *   { a: true, b: 2, c: 'x' },\n   *   { a: false, b: 1, c: 'x' },\n   *   { a: false, b: 2, c: 'x' }\n   * ]\n   * ```\n   * @param {Object} object The object to permutate.\n   * @param {Integer} [index=0] The current key index.\n   * @param {Object} [current={}] The current result entry being composed.\n   * @param {Array} [results=[]] The resulting array of permutations.\n   */\n  static getObjectKeyPermutations(object, index = 0, current = {}, results = []) {\n    const keys = Object.keys(object);\n    const key = keys[index];\n    const values = object[key];\n\n    for (const value of values) {\n      current[key] = value;\n      const nextIndex = index + 1;\n\n      if (nextIndex < keys.length) {\n        Utils.getObjectKeyPermutations(object, nextIndex, current, results);\n      } else {\n        const result = Object.assign({}, current);\n        results.push(result);\n      }\n    }\n    return results;\n  }\n\n  /**\n   * Validates parameters and throws if a parameter is invalid.\n   * Example parameter types syntax:\n   * ```\n   * {\n   *   parameterName: {\n   *      t: 'boolean',\n   *      v: isBoolean,\n   *      o: true\n   *   },\n   *   ...\n   * }\n   * ```\n   * @param {Object} params The parameters to validate.\n   * @param {Array<Object>} types The parameter types used for validation.\n   * @param {Object} types.t The parameter type; used for error message, not for validation.\n   * @param {Object} types.v The function to validate the parameter value.\n   * @param {Boolean} [types.o=false] Is true if the parameter is optional.\n   */\n  static validateParams(params, types) {\n    for (const key of Object.keys(params)) {\n      const type = types[key];\n      const isOptional = !!type.o;\n      const param = params[key];\n      if (!(isOptional && param == null) && !type.v(param)) {\n        throw `Invalid parameter ${key} must be of type ${type.t} but is ${typeof param}`;\n      }\n    }\n  }\n\n  /**\n   * Computes the relative date based on a string.\n   * @param {String} text The string to interpret the date from.\n   * @param {Date} now The date the string is comparing against.\n   * @returns {Object} The relative date object.\n   **/\n  static relativeTimeToDate(text, now = new Date()) {\n    text = text.toLowerCase();\n    let parts = text.split(' ');\n\n    // Filter out whitespace\n    parts = parts.filter(part => part !== '');\n\n    const future = parts[0] === 'in';\n    const past = parts[parts.length - 1] === 'ago';\n\n    if (!future && !past && text !== 'now') {\n      return {\n        status: 'error',\n        info: \"Time should either start with 'in' or end with 'ago'\",\n      };\n    }\n\n    if (future && past) {\n      return {\n        status: 'error',\n        info: \"Time cannot have both 'in' and 'ago'\",\n      };\n    }\n\n    // strip the 'ago' or 'in'\n    if (future) {\n      parts = parts.slice(1);\n    } else {\n      // past\n      parts = parts.slice(0, parts.length - 1);\n    }\n\n    if (parts.length % 2 !== 0 && text !== 'now') {\n      return {\n        status: 'error',\n        info: 'Invalid time string. Dangling unit or number.',\n      };\n    }\n\n    const pairs = [];\n    while (parts.length) {\n      pairs.push([parts.shift(), parts.shift()]);\n    }\n\n    let seconds = 0;\n    for (const [num, interval] of pairs) {\n      const val = Number(num);\n      if (!Number.isInteger(val)) {\n        return {\n          status: 'error',\n          info: `'${num}' is not an integer.`,\n        };\n      }\n\n      switch (interval) {\n        case 'yr':\n        case 'yrs':\n        case 'year':\n        case 'years':\n          seconds += val * 31536000; // 365 * 24 * 60 * 60\n          break;\n\n        case 'wk':\n        case 'wks':\n        case 'week':\n        case 'weeks':\n          seconds += val * 604800; // 7 * 24 * 60 * 60\n          break;\n\n        case 'd':\n        case 'day':\n        case 'days':\n          seconds += val * 86400; // 24 * 60 * 60\n          break;\n\n        case 'hr':\n        case 'hrs':\n        case 'hour':\n        case 'hours':\n          seconds += val * 3600; // 60 * 60\n          break;\n\n        case 'min':\n        case 'mins':\n        case 'minute':\n        case 'minutes':\n          seconds += val * 60;\n          break;\n\n        case 'sec':\n        case 'secs':\n        case 'second':\n        case 'seconds':\n          seconds += val;\n          break;\n\n        default:\n          return {\n            status: 'error',\n            info: `Invalid interval: '${interval}'`,\n          };\n      }\n    }\n\n    const milliseconds = seconds * 1000;\n    if (future) {\n      return {\n        status: 'success',\n        info: 'future',\n        result: new Date(now.valueOf() + milliseconds),\n      };\n    } else if (past) {\n      return {\n        status: 'success',\n        info: 'past',\n        result: new Date(now.valueOf() - milliseconds),\n      };\n    } else {\n      return {\n        status: 'success',\n        info: 'present',\n        result: new Date(now.valueOf()),\n      };\n    }\n  }\n\n  /**\n   * Deep-scans an object for a matching key/value definition.\n   * @param {Object} obj The object to scan.\n   * @param {String | undefined} key The key to match, or undefined if only the value should be matched.\n   * @param {any | undefined} value The value to match, or undefined if only the key should be matched.\n   * @returns {Boolean} True if a match was found, false otherwise.\n   */\n  static objectContainsKeyValue(obj, key, value) {\n    const isMatch = (a, b) => (typeof a === 'string' && new RegExp(b).test(a)) || a === b;\n    const isKeyMatch = k => isMatch(k, key);\n    const isValueMatch = v => isMatch(v, value);\n    const stack = [obj];\n    const seen = new WeakSet();\n    while (stack.length > 0) {\n      const current = stack.pop();\n      if (seen.has(current)) {\n        continue;\n      }\n      seen.add(current);\n      for (const [k, v] of Object.entries(current)) {\n        if (key !== undefined && value === undefined && isKeyMatch(k)) {\n          return true;\n        } else if (key === undefined && value !== undefined && isValueMatch(v)) {\n          return true;\n        } else if (key !== undefined && value !== undefined && isKeyMatch(k) && isValueMatch(v)) {\n          return true;\n        }\n        if (['[object Object]', '[object Array]'].includes(Object.prototype.toString.call(v))) {\n          stack.push(v);\n        }\n      }\n    }\n    return false;\n  }\n\n  static checkProhibitedKeywords(config, data) {\n    if (config?.requestKeywordDenylist) {\n      // Scan request data for denied keywords\n      for (const keyword of config.requestKeywordDenylist) {\n        const match = Utils.objectContainsKeyValue(data, keyword.key, keyword.value);\n        if (match) {\n          throw `Prohibited keyword in request data: ${JSON.stringify(keyword)}.`;\n        }\n      }\n    }\n  }\n\n  /**\n   * Moves the nested keys of a specified key in an object to the root of the object.\n   *\n   * @param {Object} obj The object to modify.\n   * @param {String} key The key whose nested keys will be moved to root.\n   * @returns {Object} The modified object, or the original object if no modification happened.\n   * @example\n   * const obj = {\n   *   a: 1,\n   *   b: {\n   *     c: 2,\n   *     d: 3\n   *   },\n   *   e: 4\n   * };\n   * addNestedKeysToRoot(obj, 'b');\n   * console.log(obj);\n   * // Output: { a: 1, e: 4, c: 2, d: 3 }\n  */\n  static addNestedKeysToRoot(obj, key) {\n    if (obj[key] && typeof obj[key] === 'object') {\n      // Add nested keys to root\n      Object.assign(obj, { ...obj[key] });\n      // Delete original nested key\n      delete obj[key];\n    }\n    return obj;\n  }\n\n  /**\n   * Encodes a string to be used in a URL.\n   * @param {String} input The string to encode.\n   * @returns {String} The encoded string.\n   */\n  static encodeForUrl(input) {\n    return encodeURIComponent(input).replace(/[!'.()*]/g, char =>\n      '%' + char.charCodeAt(0).toString(16).toUpperCase()\n    );\n  }\n\n  /**\n   * Creates a JSON replacer function that handles Map, Set, and circular references.\n   * This replacer can be used with JSON.stringify to safely serialize complex objects.\n   *\n   * @returns {Function} A replacer function for JSON.stringify that:\n   * - Converts Map instances to plain objects\n   * - Converts Set instances to arrays\n   * - Replaces circular references with '[Circular]' marker\n   *\n   * @example\n   * const obj = { name: 'test', map: new Map([['key', 'value']]) };\n   * obj.self = obj; // circular reference\n   * JSON.stringify(obj, Utils.getCircularReplacer());\n   * // Output: {\"name\":\"test\",\"map\":{\"key\":\"value\"},\"self\":\"[Circular]\"}\n   */\n  static getCircularReplacer() {\n    const seen = new WeakSet();\n    return (key, value) => {\n      if (value instanceof Map) {\n        return Object.fromEntries(value);\n      }\n      if (value instanceof Set) {\n        return Array.from(value);\n      }\n      if (typeof value === 'object' && value !== null) {\n        if (seen.has(value)) {\n          return '[Circular]';\n        }\n        seen.add(value);\n      }\n      return value;\n    };\n  }\n\n  /**\n   * Gets a nested property value from an object using dot notation.\n   * @param {Object} obj The object to get the property from.\n   * @param {String} path The property path in dot notation, e.g. 'databaseOptions.allowPublicExplain'.\n   * @returns {any} The property value or undefined if not found.\n   * @example\n   * const obj = { database: { options: { enabled: true } } };\n   * Utils.getNestedProperty(obj, 'database.options.enabled');\n   * // Output: true\n   */\n  static getNestedProperty(obj, path) {\n    if (!obj || !path) {\n      return undefined;\n    }\n    const keys = path.split('.');\n    let current = obj;\n    for (const key of keys) {\n      if (current == null || typeof current !== 'object') {\n        return undefined;\n      }\n      current = current[key];\n    }\n    return current;\n  }\n\n  /**\n   * Parses a human-readable size string into a byte count.\n   * @param {number | string} size - A number (floored to an integer), a numeric string\n   *   (treated as bytes), or a string with a unit suffix: `b`, `kb`, `mb`, `gb`\n   *   (case-insensitive). Examples: `'20mb'`, `'512kb'`, `'1.5gb'`, `1048576`.\n   * @returns {number} The size in bytes, floored to the nearest integer.\n   * @throws {Error} If the string does not match the expected format.\n   */\n  static parseSizeToBytes(size) {\n    if (typeof size === 'number') {\n      if (!Number.isFinite(size) || size < 0) {\n        throw new Error(`Invalid size value: ${size}`);\n      }\n      return Math.floor(size);\n    }\n    const str = String(size).trim().toLowerCase();\n    const match = str.match(/^(\\d+(?:\\.\\d+)?)\\s*(b|kb|mb|gb)?$/);\n    if (!match) {\n      throw new Error(`Invalid size value: ${size}`);\n    }\n    const num = parseFloat(match[1]);\n    const unit = match[2];\n    switch (unit) {\n      case 'kb':\n        return Math.floor(num * 1024);\n      case 'mb':\n        return Math.floor(num * 1024 * 1024);\n      case 'gb':\n        return Math.floor(num * 1024 * 1024 * 1024);\n      default:\n        return Math.floor(num);\n    }\n  }\n}\n\nmodule.exports = Utils;\n"],"mappings":"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","ignoreList":[]}
|
|
577
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["path","require","fs","promises","types","Utils","getLocalizedPath","defaultPath","locale","file","basename","basePath","dirname","localePath","join","localeFileExists","fileExists","subdir","language","split","languagePath","languageFileExists","access","isPath","s","test","flattenObject","obj","parentKey","delimiter","result","key","Object","prototype","hasOwnProperty","call","newKey","isDate","value","isRegExp","isMap","isSet","isNativeError","isPromise","then","getPrototypeOf","isObject","getObjectKeyPermutations","object","index","current","results","keys","values","nextIndex","length","assign","push","validateParams","params","type","isOptional","o","param","v","t","relativeTimeToDate","text","now","Date","toLowerCase","parts","filter","part","future","past","status","info","slice","pairs","shift","seconds","num","interval","val","Number","isInteger","milliseconds","valueOf","objectContainsKeyValue","isMatch","a","b","RegExp","isKeyMatch","k","isValueMatch","stack","seen","WeakSet","pop","has","add","entries","undefined","includes","toString","checkProhibitedKeywords","config","data","requestKeywordDenylist","keyword","match","JSON","stringify","addNestedKeysToRoot","encodeForUrl","input","encodeURIComponent","replace","char","charCodeAt","toUpperCase","getCircularReplacer","fromEntries","Array","from","getNestedProperty","parseSizeToBytes","size","isFinite","Error","Math","floor","str","String","trim","parseFloat","unit","module","exports"],"sources":["../src/Utils.js"],"sourcesContent":["/**\n * utils.js\n * @file General purpose utilities\n * @description General purpose utilities.\n */\n\nconst path = require('path');\nconst fs = require('fs').promises;\nconst { types } = require('util');\n\n/**\n * The general purpose utilities.\n */\nclass Utils {\n  /**\n   * @function getLocalizedPath\n   * @description Returns a localized file path accoring to the locale.\n   *\n   * Localized files are searched in subfolders of a given path, e.g.\n   *\n   * root/\n   * ├── base/                    // base path to files\n   * │   ├── example.html         // default file\n   * │   └── de/                  // de language folder\n   * │   │   └── example.html     // de localized file\n   * │   └── de-AT/               // de-AT locale folder\n   * │   │   └── example.html     // de-AT localized file\n   *\n   * Files are matched with the locale in the following order:\n   * 1. Locale match, e.g. locale `de-AT` matches file in folder `de-AT`.\n   * 2. Language match, e.g. locale `de-AT` matches file in folder `de`.\n   * 3. Default; file in base folder is returned.\n   *\n   * @param {String} defaultPath The absolute file path, which is also\n   * the default path returned if localization is not available.\n   * @param {String} locale The locale.\n   * @returns {Promise<Object>} The object contains:\n   * - `path`: The path to the localized file, or the original path if\n   *   localization is not available.\n   * - `subdir`: The subdirectory of the localized file, or undefined if\n   *   there is no matching localized file.\n   */\n  static async getLocalizedPath(defaultPath, locale) {\n    // Get file name and paths\n    const file = path.basename(defaultPath);\n    const basePath = path.dirname(defaultPath);\n\n    // If locale is not set return default file\n    if (!locale) {\n      return { path: defaultPath };\n    }\n\n    // Check file for locale exists\n    const localePath = path.join(basePath, locale, file);\n    const localeFileExists = await Utils.fileExists(localePath);\n\n    // If file for locale exists return file\n    if (localeFileExists) {\n      return { path: localePath, subdir: locale };\n    }\n\n    // Check file for language exists\n    const language = locale.split('-')[0];\n    const languagePath = path.join(basePath, language, file);\n    const languageFileExists = await Utils.fileExists(languagePath);\n\n    // If file for language exists return file\n    if (languageFileExists) {\n      return { path: languagePath, subdir: language };\n    }\n\n    // Return default file\n    return { path: defaultPath };\n  }\n\n  /**\n   * @function fileExists\n   * @description Checks whether a file exists.\n   * @param {String} path The file path.\n   * @returns {Promise<Boolean>} Is true if the file can be accessed, false otherwise.\n   */\n  static async fileExists(path) {\n    try {\n      await fs.access(path);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * @function isPath\n   * @description Evaluates whether a string is a file path (as opposed to a URL for example).\n   * @param {String} s The string to evaluate.\n   * @returns {Boolean} Returns true if the evaluated string is a path.\n   */\n  static isPath(s) {\n    return /(^\\/)|(^\\.\\/)|(^\\.\\.\\/)/.test(s);\n  }\n\n  /**\n   * Flattens an object and crates new keys with custom delimiters.\n   * @param {Object} obj The object to flatten.\n   * @param {String} [delimiter='.'] The delimiter of the newly generated keys.\n   * @param {Object} result\n   * @returns {Object} The flattened object.\n   **/\n  static flattenObject(obj, parentKey, delimiter = '.', result = {}) {\n    for (const key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        const newKey = parentKey ? parentKey + delimiter + key : key;\n\n        if (typeof obj[key] === 'object' && obj[key] !== null) {\n          this.flattenObject(obj[key], newKey, delimiter, result);\n        } else {\n          result[newKey] = obj[key];\n        }\n      }\n    }\n    return result;\n  }\n\n  /**\n   * Realm-safe check for Date.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a Date.\n   */\n  static isDate(value) {\n    return types.isDate(value);\n  }\n\n  /**\n   * Realm-safe check for RegExp.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a RegExp.\n   */\n  static isRegExp(value) {\n    return types.isRegExp(value);\n  }\n\n  /**\n   * Realm-safe check for Map.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a Map.\n   */\n  static isMap(value) {\n    return types.isMap(value);\n  }\n\n  /**\n   * Realm-safe check for Set.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a Set.\n   */\n  static isSet(value) {\n    return types.isSet(value);\n  }\n\n  /**\n   * Realm-safe check for native Error.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a native Error.\n   */\n  static isNativeError(value) {\n    return types.isNativeError(value);\n  }\n\n  /**\n   * Realm-safe check for Promise (duck-typed as thenable).\n   * Guards against Object.prototype pollution by ensuring `then` is not\n   * inherited solely from Object.prototype.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a Promise or thenable.\n   */\n  static isPromise(value) {\n    if (value == null || typeof value.then !== 'function') {\n      return false;\n    }\n    return Object.getPrototypeOf(value) !== Object.prototype || Object.prototype.hasOwnProperty.call(value, 'then');\n  }\n\n  /**\n   * Realm-safe check for object type. Uses `typeof` instead of `instanceof Object`\n   * which fails across realms. Returns true for any non-null value where\n   * `typeof` is `'object'`, including plain objects, arrays, dates, maps, sets,\n   * regex, and boxed primitives (e.g. `new String()`). Returns false for `null`,\n   * `undefined`, unboxed primitives, and functions.\n   * @param {any} value The value to check.\n   * @returns {Boolean} Returns true if the value is a non-null object type.\n   */\n  static isObject(value) {\n    return typeof value === 'object' && value !== null;\n  }\n\n  /**\n   * Creates an object with all permutations of the original keys.\n   * For example, this definition:\n   * ```\n   * {\n   *   a: [true, false],\n   *   b: [1, 2],\n   *   c: ['x']\n   * }\n   * ```\n   * permutates to:\n   * ```\n   * [\n   *   { a: true, b: 1, c: 'x' },\n   *   { a: true, b: 2, c: 'x' },\n   *   { a: false, b: 1, c: 'x' },\n   *   { a: false, b: 2, c: 'x' }\n   * ]\n   * ```\n   * @param {Object} object The object to permutate.\n   * @param {Integer} [index=0] The current key index.\n   * @param {Object} [current={}] The current result entry being composed.\n   * @param {Array} [results=[]] The resulting array of permutations.\n   */\n  static getObjectKeyPermutations(object, index = 0, current = {}, results = []) {\n    const keys = Object.keys(object);\n    const key = keys[index];\n    const values = object[key];\n\n    for (const value of values) {\n      current[key] = value;\n      const nextIndex = index + 1;\n\n      if (nextIndex < keys.length) {\n        Utils.getObjectKeyPermutations(object, nextIndex, current, results);\n      } else {\n        const result = Object.assign({}, current);\n        results.push(result);\n      }\n    }\n    return results;\n  }\n\n  /**\n   * Validates parameters and throws if a parameter is invalid.\n   * Example parameter types syntax:\n   * ```\n   * {\n   *   parameterName: {\n   *      t: 'boolean',\n   *      v: isBoolean,\n   *      o: true\n   *   },\n   *   ...\n   * }\n   * ```\n   * @param {Object} params The parameters to validate.\n   * @param {Array<Object>} types The parameter types used for validation.\n   * @param {Object} types.t The parameter type; used for error message, not for validation.\n   * @param {Object} types.v The function to validate the parameter value.\n   * @param {Boolean} [types.o=false] Is true if the parameter is optional.\n   */\n  static validateParams(params, types) {\n    for (const key of Object.keys(params)) {\n      const type = types[key];\n      const isOptional = !!type.o;\n      const param = params[key];\n      if (!(isOptional && param == null) && !type.v(param)) {\n        throw `Invalid parameter ${key} must be of type ${type.t} but is ${typeof param}`;\n      }\n    }\n  }\n\n  /**\n   * Computes the relative date based on a string.\n   * @param {String} text The string to interpret the date from.\n   * @param {Date} now The date the string is comparing against.\n   * @returns {Object} The relative date object.\n   **/\n  static relativeTimeToDate(text, now = new Date()) {\n    text = text.toLowerCase();\n    let parts = text.split(' ');\n\n    // Filter out whitespace\n    parts = parts.filter(part => part !== '');\n\n    const future = parts[0] === 'in';\n    const past = parts[parts.length - 1] === 'ago';\n\n    if (!future && !past && text !== 'now') {\n      return {\n        status: 'error',\n        info: \"Time should either start with 'in' or end with 'ago'\",\n      };\n    }\n\n    if (future && past) {\n      return {\n        status: 'error',\n        info: \"Time cannot have both 'in' and 'ago'\",\n      };\n    }\n\n    // strip the 'ago' or 'in'\n    if (future) {\n      parts = parts.slice(1);\n    } else {\n      // past\n      parts = parts.slice(0, parts.length - 1);\n    }\n\n    if (parts.length % 2 !== 0 && text !== 'now') {\n      return {\n        status: 'error',\n        info: 'Invalid time string. Dangling unit or number.',\n      };\n    }\n\n    const pairs = [];\n    while (parts.length) {\n      pairs.push([parts.shift(), parts.shift()]);\n    }\n\n    let seconds = 0;\n    for (const [num, interval] of pairs) {\n      const val = Number(num);\n      if (!Number.isInteger(val)) {\n        return {\n          status: 'error',\n          info: `'${num}' is not an integer.`,\n        };\n      }\n\n      switch (interval) {\n        case 'yr':\n        case 'yrs':\n        case 'year':\n        case 'years':\n          seconds += val * 31536000; // 365 * 24 * 60 * 60\n          break;\n\n        case 'wk':\n        case 'wks':\n        case 'week':\n        case 'weeks':\n          seconds += val * 604800; // 7 * 24 * 60 * 60\n          break;\n\n        case 'd':\n        case 'day':\n        case 'days':\n          seconds += val * 86400; // 24 * 60 * 60\n          break;\n\n        case 'hr':\n        case 'hrs':\n        case 'hour':\n        case 'hours':\n          seconds += val * 3600; // 60 * 60\n          break;\n\n        case 'min':\n        case 'mins':\n        case 'minute':\n        case 'minutes':\n          seconds += val * 60;\n          break;\n\n        case 'sec':\n        case 'secs':\n        case 'second':\n        case 'seconds':\n          seconds += val;\n          break;\n\n        default:\n          return {\n            status: 'error',\n            info: `Invalid interval: '${interval}'`,\n          };\n      }\n    }\n\n    const milliseconds = seconds * 1000;\n    if (future) {\n      return {\n        status: 'success',\n        info: 'future',\n        result: new Date(now.valueOf() + milliseconds),\n      };\n    } else if (past) {\n      return {\n        status: 'success',\n        info: 'past',\n        result: new Date(now.valueOf() - milliseconds),\n      };\n    } else {\n      return {\n        status: 'success',\n        info: 'present',\n        result: new Date(now.valueOf()),\n      };\n    }\n  }\n\n  /**\n   * Deep-scans an object for a matching key/value definition.\n   * @param {Object} obj The object to scan.\n   * @param {String | undefined} key The key to match, or undefined if only the value should be matched.\n   * @param {any | undefined} value The value to match, or undefined if only the key should be matched.\n   * @returns {Boolean} True if a match was found, false otherwise.\n   */\n  static objectContainsKeyValue(obj, key, value) {\n    const isMatch = (a, b) => (typeof a === 'string' && new RegExp(b).test(a)) || a === b;\n    const isKeyMatch = k => isMatch(k, key);\n    const isValueMatch = v => isMatch(v, value);\n    const stack = [obj];\n    const seen = new WeakSet();\n    while (stack.length > 0) {\n      const current = stack.pop();\n      if (seen.has(current)) {\n        continue;\n      }\n      seen.add(current);\n      for (const [k, v] of Object.entries(current)) {\n        if (key !== undefined && value === undefined && isKeyMatch(k)) {\n          return true;\n        } else if (key === undefined && value !== undefined && isValueMatch(v)) {\n          return true;\n        } else if (key !== undefined && value !== undefined && isKeyMatch(k) && isValueMatch(v)) {\n          return true;\n        }\n        if (['[object Object]', '[object Array]'].includes(Object.prototype.toString.call(v))) {\n          stack.push(v);\n        }\n      }\n    }\n    return false;\n  }\n\n  static checkProhibitedKeywords(config, data) {\n    if (config?.requestKeywordDenylist) {\n      // Scan request data for denied keywords\n      for (const keyword of config.requestKeywordDenylist) {\n        const match = Utils.objectContainsKeyValue(data, keyword.key, keyword.value);\n        if (match) {\n          throw `Prohibited keyword in request data: ${JSON.stringify(keyword)}.`;\n        }\n      }\n    }\n  }\n\n  /**\n   * Moves the nested keys of a specified key in an object to the root of the object.\n   *\n   * @param {Object} obj The object to modify.\n   * @param {String} key The key whose nested keys will be moved to root.\n   * @returns {Object} The modified object, or the original object if no modification happened.\n   * @example\n   * const obj = {\n   *   a: 1,\n   *   b: {\n   *     c: 2,\n   *     d: 3\n   *   },\n   *   e: 4\n   * };\n   * addNestedKeysToRoot(obj, 'b');\n   * console.log(obj);\n   * // Output: { a: 1, e: 4, c: 2, d: 3 }\n  */\n  static addNestedKeysToRoot(obj, key) {\n    if (obj[key] && typeof obj[key] === 'object') {\n      // Add nested keys to root\n      Object.assign(obj, { ...obj[key] });\n      // Delete original nested key\n      delete obj[key];\n    }\n    return obj;\n  }\n\n  /**\n   * Encodes a string to be used in a URL.\n   * @param {String} input The string to encode.\n   * @returns {String} The encoded string.\n   */\n  static encodeForUrl(input) {\n    return encodeURIComponent(input).replace(/[!'.()*]/g, char =>\n      '%' + char.charCodeAt(0).toString(16).toUpperCase()\n    );\n  }\n\n  /**\n   * Creates a JSON replacer function that handles Map, Set, and circular references.\n   * This replacer can be used with JSON.stringify to safely serialize complex objects.\n   *\n   * @returns {Function} A replacer function for JSON.stringify that:\n   * - Converts Map instances to plain objects\n   * - Converts Set instances to arrays\n   * - Replaces circular references with '[Circular]' marker\n   *\n   * @example\n   * const obj = { name: 'test', map: new Map([['key', 'value']]) };\n   * obj.self = obj; // circular reference\n   * JSON.stringify(obj, Utils.getCircularReplacer());\n   * // Output: {\"name\":\"test\",\"map\":{\"key\":\"value\"},\"self\":\"[Circular]\"}\n   */\n  static getCircularReplacer() {\n    const seen = new WeakSet();\n    return (key, value) => {\n      if (Utils.isMap(value)) {\n        return Object.fromEntries(value);\n      }\n      if (Utils.isSet(value)) {\n        return Array.from(value);\n      }\n      if (typeof value === 'object' && value !== null) {\n        if (seen.has(value)) {\n          return '[Circular]';\n        }\n        seen.add(value);\n      }\n      return value;\n    };\n  }\n\n  /**\n   * Gets a nested property value from an object using dot notation.\n   * @param {Object} obj The object to get the property from.\n   * @param {String} path The property path in dot notation, e.g. 'databaseOptions.allowPublicExplain'.\n   * @returns {any} The property value or undefined if not found.\n   * @example\n   * const obj = { database: { options: { enabled: true } } };\n   * Utils.getNestedProperty(obj, 'database.options.enabled');\n   * // Output: true\n   */\n  static getNestedProperty(obj, path) {\n    if (!obj || !path) {\n      return undefined;\n    }\n    const keys = path.split('.');\n    let current = obj;\n    for (const key of keys) {\n      if (current == null || typeof current !== 'object') {\n        return undefined;\n      }\n      current = current[key];\n    }\n    return current;\n  }\n\n  /**\n   * Parses a human-readable size string into a byte count.\n   * @param {number | string} size - A number (floored to an integer), a numeric string\n   *   (treated as bytes), or a string with a unit suffix: `b`, `kb`, `mb`, `gb`\n   *   (case-insensitive). Examples: `'20mb'`, `'512kb'`, `'1.5gb'`, `1048576`.\n   * @returns {number} The size in bytes, floored to the nearest integer.\n   * @throws {Error} If the string does not match the expected format.\n   */\n  static parseSizeToBytes(size) {\n    if (typeof size === 'number') {\n      if (!Number.isFinite(size) || size < 0) {\n        throw new Error(`Invalid size value: ${size}`);\n      }\n      return Math.floor(size);\n    }\n    const str = String(size).trim().toLowerCase();\n    const match = str.match(/^(\\d+(?:\\.\\d+)?)\\s*(b|kb|mb|gb)?$/);\n    if (!match) {\n      throw new Error(`Invalid size value: ${size}`);\n    }\n    const num = parseFloat(match[1]);\n    const unit = match[2];\n    switch (unit) {\n      case 'kb':\n        return Math.floor(num * 1024);\n      case 'mb':\n        return Math.floor(num * 1024 * 1024);\n      case 'gb':\n        return Math.floor(num * 1024 * 1024 * 1024);\n      default:\n        return Math.floor(num);\n    }\n  }\n}\n\nmodule.exports = Utils;\n"],"mappings":"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","ignoreList":[]}
|