parse-server 9.7.0-alpha.3 → 9.7.0-alpha.4

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.
@@ -10,6 +10,11 @@
10
10
  * or set to an empty string if the current key will be removed without replacement.
11
11
  * - `changeNewDefault` {String}: Set the new default value if the key's default value
12
12
  * will change in a future version.
13
+ * - `resolvedValue` {any}: The option value that suppresses the deprecation warning,
14
+ * indicating the user has already adopted the future behavior. Only applicable when
15
+ * `changeNewKey` is an empty string (option will be removed without replacement).
16
+ * For example, `false` for an option that will be removed, if setting it to `false`
17
+ * disables the deprecated feature.
13
18
  * - `solution`: The instruction to resolve this deprecation warning. Optional. This
14
19
  * instruction must not include the deprecation warning which is auto-generated.
15
20
  * It should only contain additional instruction regarding the deprecation if
@@ -68,10 +73,12 @@ module.exports = [{
68
73
  }, {
69
74
  optionKey: 'enableProductPurchaseLegacyApi',
70
75
  changeNewKey: '',
76
+ resolvedValue: false,
71
77
  solution: "The product purchase API is an undocumented, unmaintained legacy feature that may not function as expected and will be removed in a future major version. We strongly advise against using it. Set 'enableProductPurchaseLegacyApi' to 'false' to disable it, or remove the option to accept the future removal."
72
78
  }, {
73
79
  optionKey: 'allowExpiredAuthDataToken',
74
80
  changeNewKey: '',
81
+ resolvedValue: false,
75
82
  solution: "Auth providers are always validated on login regardless of this setting. Set 'allowExpiredAuthDataToken' to 'false' or remove the option to accept the future removal."
76
83
  }, {
77
84
  optionKey: 'protectedFieldsOwnerExempt',
@@ -86,4 +93,4 @@ module.exports = [{
86
93
  changeNewDefault: 'false',
87
94
  solution: "Set 'protectedFieldsSaveResponseExempt' to 'false' to strip protected fields from write operation responses (create, update), consistent with how they are stripped from query results. Set to 'true' to keep the current behavior where protected fields are included in write responses."
88
95
  }];
89
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["module","exports","optionKey","changeNewDefault","solution","changeNewKey"],"sources":["../../src/Deprecator/Deprecations.js"],"sourcesContent":["/**\n * The deprecations.\n *\n * Add deprecations to the array using the following keys:\n * - `optionKey` {String}: The option key incl. its path, e.g. `security.enableCheck`.\n * - `envKey` {String}: The environment key, e.g. `PARSE_SERVER_SECURITY`.\n * - `changeNewKey` {String}: Set the new key name if the current key will be replaced,\n * or set to an empty string if the current key will be removed without replacement.\n * - `changeNewDefault` {String}: Set the new default value if the key's default value\n * will change in a future version.\n * - `solution`: The instruction to resolve this deprecation warning. Optional. This\n * instruction must not include the deprecation warning which is auto-generated.\n * It should only contain additional instruction regarding the deprecation if\n * necessary.\n *\n * If there are no deprecations, this must return an empty array.\n */\nmodule.exports = [\n  {\n    optionKey: 'fileUpload.allowedFileUrlDomains',\n    changeNewDefault: '[]',\n    solution: \"Set 'fileUpload.allowedFileUrlDomains' to the domains you want to allow, or to '[]' to block all file URLs.\",\n  },\n  {\n    optionKey: 'pages.encodePageParamHeaders',\n    changeNewDefault: 'true',\n    solution: \"Set 'pages.encodePageParamHeaders' to 'true' to URI-encode non-ASCII characters in page parameter headers.\",\n  },\n  {\n    optionKey: 'readOnlyMasterKeyIps',\n    changeNewDefault: '[\"127.0.0.1\", \"::1\"]',\n    solution: \"Set 'readOnlyMasterKeyIps' to the IP addresses that should be allowed to use the read-only master key, or to '[\\\"127.0.0.1\\\", \\\"::1\\\"]' to restrict access to localhost.\",\n  },\n  {\n    optionKey: 'mountPlayground',\n    changeNewKey: '',\n    solution: \"Use Parse Dashboard as GraphQL IDE or configure a third-party GraphQL client such as Apollo Sandbox, GraphiQL, or Insomnia with custom request headers.\",\n  },\n  {\n    optionKey: 'playgroundPath',\n    changeNewKey: '',\n    solution: \"Use Parse Dashboard as GraphQL IDE or configure a third-party GraphQL client such as Apollo Sandbox, GraphiQL, or Insomnia with custom request headers.\",\n  },\n  {\n    optionKey: 'requestComplexity.includeDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.includeDepth' to a positive integer appropriate for your app to limit include pointer chain depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.includeCount',\n    changeNewDefault: '100',\n    solution: \"Set 'requestComplexity.includeCount' to a positive integer appropriate for your app to limit the number of include paths per query, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.subqueryDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.subqueryDepth' to a positive integer appropriate for your app to limit subquery nesting depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.queryDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.queryDepth' to a positive integer appropriate for your app to limit query condition nesting depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.graphQLDepth',\n    changeNewDefault: '20',\n    solution: \"Set 'requestComplexity.graphQLDepth' to a positive integer appropriate for your app to limit GraphQL field selection depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.graphQLFields',\n    changeNewDefault: '200',\n    solution: \"Set 'requestComplexity.graphQLFields' to a positive integer appropriate for your app to limit the number of GraphQL field selections, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.batchRequestLimit',\n    changeNewDefault: '100',\n    solution: \"Set 'requestComplexity.batchRequestLimit' to a positive integer appropriate for your app to limit the number of sub-requests per batch request, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'enableProductPurchaseLegacyApi',\n    changeNewKey: '',\n    solution: \"The product purchase API is an undocumented, unmaintained legacy feature that may not function as expected and will be removed in a future major version. We strongly advise against using it. Set 'enableProductPurchaseLegacyApi' to 'false' to disable it, or remove the option to accept the future removal.\",\n  },\n  {\n    optionKey: 'allowExpiredAuthDataToken',\n    changeNewKey: '',\n    solution: \"Auth providers are always validated on login regardless of this setting. Set 'allowExpiredAuthDataToken' to 'false' or remove the option to accept the future removal.\",\n  },\n  {\n    optionKey: 'protectedFieldsOwnerExempt',\n    changeNewDefault: 'false',\n    solution: \"Set 'protectedFieldsOwnerExempt' to 'false' to apply protectedFields consistently to the user's own _User object (same as all other classes), or to 'true' to keep the current behavior where a user can see all their own fields.\",\n  },\n  {\n    optionKey: 'protectedFieldsTriggerExempt',\n    changeNewDefault: 'true',\n    solution: \"Set 'protectedFieldsTriggerExempt' to 'true' to make Cloud Code triggers (e.g. beforeSave, afterSave) receive the full object including protected fields, or to 'false' to keep the current behavior where protected fields are stripped from trigger objects.\",\n  },\n  {\n    optionKey: 'protectedFieldsSaveResponseExempt',\n    changeNewDefault: 'false',\n    solution: \"Set 'protectedFieldsSaveResponseExempt' to 'false' to strip protected fields from write operation responses (create, update), consistent with how they are stripped from query results. Set to 'true' to keep the current behavior where protected fields are included in write responses.\",\n  },\n];\n"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACAA,MAAM,CAACC,OAAO,GAAG,CACf;EACEC,SAAS,EAAE,kCAAkC;EAC7CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,MAAM;EACxBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,sBAAsB;EACjCC,gBAAgB,EAAE,sBAAsB;EACxCC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iBAAiB;EAC5BG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gBAAgB;EAC3BG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iCAAiC;EAC5CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iCAAiC;EAC5CC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,qCAAqC;EAChDC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,2BAA2B;EACtCG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,4BAA4B;EACvCC,gBAAgB,EAAE,OAAO;EACzBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,MAAM;EACxBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,mCAAmC;EAC9CC,gBAAgB,EAAE,OAAO;EACzBC,QAAQ,EAAE;AACZ,CAAC,CACF","ignoreList":[]}
96
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["module","exports","optionKey","changeNewDefault","solution","changeNewKey","resolvedValue"],"sources":["../../src/Deprecator/Deprecations.js"],"sourcesContent":["/**\n * The deprecations.\n *\n * Add deprecations to the array using the following keys:\n * - `optionKey` {String}: The option key incl. its path, e.g. `security.enableCheck`.\n * - `envKey` {String}: The environment key, e.g. `PARSE_SERVER_SECURITY`.\n * - `changeNewKey` {String}: Set the new key name if the current key will be replaced,\n * or set to an empty string if the current key will be removed without replacement.\n * - `changeNewDefault` {String}: Set the new default value if the key's default value\n * will change in a future version.\n * - `resolvedValue` {any}: The option value that suppresses the deprecation warning,\n * indicating the user has already adopted the future behavior. Only applicable when\n * `changeNewKey` is an empty string (option will be removed without replacement).\n * For example, `false` for an option that will be removed, if setting it to `false`\n * disables the deprecated feature.\n * - `solution`: The instruction to resolve this deprecation warning. Optional. This\n * instruction must not include the deprecation warning which is auto-generated.\n * It should only contain additional instruction regarding the deprecation if\n * necessary.\n *\n * If there are no deprecations, this must return an empty array.\n */\nmodule.exports = [\n  {\n    optionKey: 'fileUpload.allowedFileUrlDomains',\n    changeNewDefault: '[]',\n    solution: \"Set 'fileUpload.allowedFileUrlDomains' to the domains you want to allow, or to '[]' to block all file URLs.\",\n  },\n  {\n    optionKey: 'pages.encodePageParamHeaders',\n    changeNewDefault: 'true',\n    solution: \"Set 'pages.encodePageParamHeaders' to 'true' to URI-encode non-ASCII characters in page parameter headers.\",\n  },\n  {\n    optionKey: 'readOnlyMasterKeyIps',\n    changeNewDefault: '[\"127.0.0.1\", \"::1\"]',\n    solution: \"Set 'readOnlyMasterKeyIps' to the IP addresses that should be allowed to use the read-only master key, or to '[\\\"127.0.0.1\\\", \\\"::1\\\"]' to restrict access to localhost.\",\n  },\n  {\n    optionKey: 'mountPlayground',\n    changeNewKey: '',\n    solution: \"Use Parse Dashboard as GraphQL IDE or configure a third-party GraphQL client such as Apollo Sandbox, GraphiQL, or Insomnia with custom request headers.\",\n  },\n  {\n    optionKey: 'playgroundPath',\n    changeNewKey: '',\n    solution: \"Use Parse Dashboard as GraphQL IDE or configure a third-party GraphQL client such as Apollo Sandbox, GraphiQL, or Insomnia with custom request headers.\",\n  },\n  {\n    optionKey: 'requestComplexity.includeDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.includeDepth' to a positive integer appropriate for your app to limit include pointer chain depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.includeCount',\n    changeNewDefault: '100',\n    solution: \"Set 'requestComplexity.includeCount' to a positive integer appropriate for your app to limit the number of include paths per query, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.subqueryDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.subqueryDepth' to a positive integer appropriate for your app to limit subquery nesting depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.queryDepth',\n    changeNewDefault: '10',\n    solution: \"Set 'requestComplexity.queryDepth' to a positive integer appropriate for your app to limit query condition nesting depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.graphQLDepth',\n    changeNewDefault: '20',\n    solution: \"Set 'requestComplexity.graphQLDepth' to a positive integer appropriate for your app to limit GraphQL field selection depth, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.graphQLFields',\n    changeNewDefault: '200',\n    solution: \"Set 'requestComplexity.graphQLFields' to a positive integer appropriate for your app to limit the number of GraphQL field selections, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'requestComplexity.batchRequestLimit',\n    changeNewDefault: '100',\n    solution: \"Set 'requestComplexity.batchRequestLimit' to a positive integer appropriate for your app to limit the number of sub-requests per batch request, or to '-1' to disable.\",\n  },\n  {\n    optionKey: 'enableProductPurchaseLegacyApi',\n    changeNewKey: '',\n    resolvedValue: false,\n    solution: \"The product purchase API is an undocumented, unmaintained legacy feature that may not function as expected and will be removed in a future major version. We strongly advise against using it. Set 'enableProductPurchaseLegacyApi' to 'false' to disable it, or remove the option to accept the future removal.\",\n  },\n  {\n    optionKey: 'allowExpiredAuthDataToken',\n    changeNewKey: '',\n    resolvedValue: false,\n    solution: \"Auth providers are always validated on login regardless of this setting. Set 'allowExpiredAuthDataToken' to 'false' or remove the option to accept the future removal.\",\n  },\n  {\n    optionKey: 'protectedFieldsOwnerExempt',\n    changeNewDefault: 'false',\n    solution: \"Set 'protectedFieldsOwnerExempt' to 'false' to apply protectedFields consistently to the user's own _User object (same as all other classes), or to 'true' to keep the current behavior where a user can see all their own fields.\",\n  },\n  {\n    optionKey: 'protectedFieldsTriggerExempt',\n    changeNewDefault: 'true',\n    solution: \"Set 'protectedFieldsTriggerExempt' to 'true' to make Cloud Code triggers (e.g. beforeSave, afterSave) receive the full object including protected fields, or to 'false' to keep the current behavior where protected fields are stripped from trigger objects.\",\n  },\n  {\n    optionKey: 'protectedFieldsSaveResponseExempt',\n    changeNewDefault: 'false',\n    solution: \"Set 'protectedFieldsSaveResponseExempt' to 'false' to strip protected fields from write operation responses (create, update), consistent with how they are stripped from query results. Set to 'true' to keep the current behavior where protected fields are included in write responses.\",\n  },\n];\n"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACAA,MAAM,CAACC,OAAO,GAAG,CACf;EACEC,SAAS,EAAE,kCAAkC;EAC7CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,MAAM;EACxBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,sBAAsB;EACjCC,gBAAgB,EAAE,sBAAsB;EACxCC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iBAAiB;EAC5BG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gBAAgB;EAC3BG,YAAY,EAAE,EAAE;EAChBD,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iCAAiC;EAC5CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CC,gBAAgB,EAAE,IAAI;EACtBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,iCAAiC;EAC5CC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,qCAAqC;EAChDC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,gCAAgC;EAC3CG,YAAY,EAAE,EAAE;EAChBC,aAAa,EAAE,KAAK;EACpBF,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,2BAA2B;EACtCG,YAAY,EAAE,EAAE;EAChBC,aAAa,EAAE,KAAK;EACpBF,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,4BAA4B;EACvCC,gBAAgB,EAAE,OAAO;EACzBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,8BAA8B;EACzCC,gBAAgB,EAAE,MAAM;EACxBC,QAAQ,EAAE;AACZ,CAAC,EACD;EACEF,SAAS,EAAE,mCAAmC;EAC9CC,gBAAgB,EAAE,OAAO;EACzBC,QAAQ,EAAE;AACZ,CAAC,CACF","ignoreList":[]}
@@ -33,8 +33,11 @@ class Deprecator {
33
33
  });
34
34
  }
35
35
 
36
- // If key will be removed or renamed, only throw a warning if option is set
37
- if (changeNewKey != null && _Utils.default.getNestedProperty(options, optionKey) != null) {
36
+ // If key will be removed or renamed, only throw a warning if option is set;
37
+ // skip if option is set to the resolved value that suppresses the deprecation
38
+ const resolvedValue = deprecation.resolvedValue;
39
+ const optionValue = _Utils.default.getNestedProperty(options, optionKey);
40
+ if (changeNewKey != null && optionValue != null && optionValue !== resolvedValue) {
38
41
  Deprecator._logOption({
39
42
  optionKey,
40
43
  changeNewKey,
@@ -134,4 +137,4 @@ class Deprecator {
134
137
  }
135
138
  }
136
139
  module.exports = Deprecator;
137
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","_interopRequireDefault","require","_Deprecations","_Utils","e","__esModule","default","Deprecator","scanParseServerOptions","options","deprecation","_getDeprecations","solution","optionKey","changeNewDefault","changeNewKey","Utils","getNestedProperty","_logOption","logRuntimeDeprecation","_logGeneric","Deprecations","usage","output","logger","warn","envKey","type","key","keyAction","undefined","length","module","exports"],"sources":["../../src/Deprecator/Deprecator.js"],"sourcesContent":["import logger from '../logger';\nimport Deprecations from './Deprecations';\nimport Utils from '../Utils';\n\n/**\n * The deprecator class.\n */\nclass Deprecator {\n  /**\n   * Scans the Parse Server for deprecated options.\n   * This needs to be called before setting option defaults, otherwise it\n   * becomes indistinguishable whether an option has been set manually or\n   * by default.\n   * @param {any} options The Parse Server options.\n   */\n  static scanParseServerOptions(options) {\n    // Scan for deprecations\n    for (const deprecation of Deprecator._getDeprecations()) {\n      // Get deprecation properties\n      const solution = deprecation.solution;\n      const optionKey = deprecation.optionKey;\n      const changeNewDefault = deprecation.changeNewDefault;\n      const changeNewKey = deprecation.changeNewKey;\n\n      // If default will change, only throw a warning if option is not set\n      if (changeNewDefault != null && Utils.getNestedProperty(options, optionKey) == null) {\n        Deprecator._logOption({ optionKey, changeNewDefault, solution });\n      }\n\n      // If key will be removed or renamed, only throw a warning if option is set\n      if (changeNewKey != null && Utils.getNestedProperty(options, optionKey) != null) {\n        Deprecator._logOption({ optionKey, changeNewKey, solution });\n      }\n    }\n  }\n\n  /**\n   * Logs a deprecation warning for a parameter that can only be determined dynamically\n   * during runtime.\n   *\n   * Note: Do not use this to log deprecations of Parse Server options, but add such\n   * deprecations to `Deprecations.js` instead. See the contribution docs for more\n   * details.\n   *\n   * For consistency, the deprecation warning is composed of the following parts:\n   *\n   * > DeprecationWarning: `usage` is deprecated and will be removed in a future version.\n   * `solution`.\n   *\n   * - `usage`: The deprecated usage.\n   * - `solution`: The instruction to resolve this deprecation warning.\n   *\n   * For example:\n   * > DeprecationWarning: `Prefixing field names with dollar sign ($) in aggregation query`\n   * is deprecated and will be removed in a future version. `Reference field names without\n   * dollar sign prefix.`\n   *\n   * @param {Object} options The deprecation options.\n   * @param {String} options.usage The usage that is deprecated.\n   * @param {String} [options.solution] The instruction to resolve this deprecation warning.\n   * Optional. It is recommended to add an instruction for the convenience of the developer.\n   */\n  static logRuntimeDeprecation(options) {\n    Deprecator._logGeneric(options);\n  }\n\n  /**\n   * Returns the deprecation definitions.\n   * @returns {Array<Object>} The deprecations.\n   */\n  static _getDeprecations() {\n    return Deprecations;\n  }\n\n  /**\n   * Logs a generic deprecation warning.\n   *\n   * @param {Object} options The deprecation options.\n   * @param {String} options.usage The usage that is deprecated.\n   * @param {String} [options.solution] The instruction to resolve this deprecation warning.\n   * Optional. It is recommended to add an instruction for the convenience of the developer.\n   */\n  static _logGeneric({ usage, solution }) {\n    // Compose message\n    let output = `DeprecationWarning: ${usage} is deprecated and will be removed in a future version.`;\n    output += solution ? ` ${solution}` : '';\n    logger.warn(output);\n  }\n\n  /**\n   * Logs a deprecation warning for a Parse Server option.\n   *\n   * @param {String} optionKey The option key incl. its path, e.g. `security.enableCheck`.\n   * @param {String} envKey The environment key, e.g. `PARSE_SERVER_SECURITY`.\n   * @param {String} changeNewKey Set the new key name if the current key will be replaced,\n   * or set to an empty string if the current key will be removed without replacement.\n   * @param {String} changeNewDefault Set the new default value if the key's default value\n   * will change in a future version.\n   * @param {String} [solution] The instruction to resolve this deprecation warning. This\n   * message must not include the warning that the parameter is deprecated, that is\n   * automatically added to the message. It should only contain the instruction on how\n   * to resolve this warning.\n   */\n  static _logOption({ optionKey, envKey, changeNewKey, changeNewDefault, solution }) {\n    const type = optionKey ? 'option' : 'environment key';\n    const key = optionKey ? optionKey : envKey;\n    const keyAction =\n      changeNewKey == null\n        ? undefined\n        : changeNewKey.length > 0\n          ? `renamed to '${changeNewKey}'`\n          : `removed`;\n\n    // Compose message\n    let output = `DeprecationWarning: The Parse Server ${type} '${key}' `;\n    output += changeNewKey != null ? `is deprecated and will be ${keyAction} in a future version.` : '';\n    output += changeNewDefault\n      ? `default will change to '${changeNewDefault}' in a future version.`\n      : '';\n    output += solution ? ` ${solution}` : '';\n    logger.warn(output);\n  }\n}\n\nmodule.exports = Deprecator;\n"],"mappings":"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","ignoreList":[]}
140
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","_interopRequireDefault","require","_Deprecations","_Utils","e","__esModule","default","Deprecator","scanParseServerOptions","options","deprecation","_getDeprecations","solution","optionKey","changeNewDefault","changeNewKey","Utils","getNestedProperty","_logOption","resolvedValue","optionValue","logRuntimeDeprecation","_logGeneric","Deprecations","usage","output","logger","warn","envKey","type","key","keyAction","undefined","length","module","exports"],"sources":["../../src/Deprecator/Deprecator.js"],"sourcesContent":["import logger from '../logger';\nimport Deprecations from './Deprecations';\nimport Utils from '../Utils';\n\n/**\n * The deprecator class.\n */\nclass Deprecator {\n  /**\n   * Scans the Parse Server for deprecated options.\n   * This needs to be called before setting option defaults, otherwise it\n   * becomes indistinguishable whether an option has been set manually or\n   * by default.\n   * @param {any} options The Parse Server options.\n   */\n  static scanParseServerOptions(options) {\n    // Scan for deprecations\n    for (const deprecation of Deprecator._getDeprecations()) {\n      // Get deprecation properties\n      const solution = deprecation.solution;\n      const optionKey = deprecation.optionKey;\n      const changeNewDefault = deprecation.changeNewDefault;\n      const changeNewKey = deprecation.changeNewKey;\n\n      // If default will change, only throw a warning if option is not set\n      if (changeNewDefault != null && Utils.getNestedProperty(options, optionKey) == null) {\n        Deprecator._logOption({ optionKey, changeNewDefault, solution });\n      }\n\n      // If key will be removed or renamed, only throw a warning if option is set;\n      // skip if option is set to the resolved value that suppresses the deprecation\n      const resolvedValue = deprecation.resolvedValue;\n      const optionValue = Utils.getNestedProperty(options, optionKey);\n      if (changeNewKey != null && optionValue != null && optionValue !== resolvedValue) {\n        Deprecator._logOption({ optionKey, changeNewKey, solution });\n      }\n    }\n  }\n\n  /**\n   * Logs a deprecation warning for a parameter that can only be determined dynamically\n   * during runtime.\n   *\n   * Note: Do not use this to log deprecations of Parse Server options, but add such\n   * deprecations to `Deprecations.js` instead. See the contribution docs for more\n   * details.\n   *\n   * For consistency, the deprecation warning is composed of the following parts:\n   *\n   * > DeprecationWarning: `usage` is deprecated and will be removed in a future version.\n   * `solution`.\n   *\n   * - `usage`: The deprecated usage.\n   * - `solution`: The instruction to resolve this deprecation warning.\n   *\n   * For example:\n   * > DeprecationWarning: `Prefixing field names with dollar sign ($) in aggregation query`\n   * is deprecated and will be removed in a future version. `Reference field names without\n   * dollar sign prefix.`\n   *\n   * @param {Object} options The deprecation options.\n   * @param {String} options.usage The usage that is deprecated.\n   * @param {String} [options.solution] The instruction to resolve this deprecation warning.\n   * Optional. It is recommended to add an instruction for the convenience of the developer.\n   */\n  static logRuntimeDeprecation(options) {\n    Deprecator._logGeneric(options);\n  }\n\n  /**\n   * Returns the deprecation definitions.\n   * @returns {Array<Object>} The deprecations.\n   */\n  static _getDeprecations() {\n    return Deprecations;\n  }\n\n  /**\n   * Logs a generic deprecation warning.\n   *\n   * @param {Object} options The deprecation options.\n   * @param {String} options.usage The usage that is deprecated.\n   * @param {String} [options.solution] The instruction to resolve this deprecation warning.\n   * Optional. It is recommended to add an instruction for the convenience of the developer.\n   */\n  static _logGeneric({ usage, solution }) {\n    // Compose message\n    let output = `DeprecationWarning: ${usage} is deprecated and will be removed in a future version.`;\n    output += solution ? ` ${solution}` : '';\n    logger.warn(output);\n  }\n\n  /**\n   * Logs a deprecation warning for a Parse Server option.\n   *\n   * @param {String} optionKey The option key incl. its path, e.g. `security.enableCheck`.\n   * @param {String} envKey The environment key, e.g. `PARSE_SERVER_SECURITY`.\n   * @param {String} changeNewKey Set the new key name if the current key will be replaced,\n   * or set to an empty string if the current key will be removed without replacement.\n   * @param {String} changeNewDefault Set the new default value if the key's default value\n   * will change in a future version.\n   * @param {String} [solution] The instruction to resolve this deprecation warning. This\n   * message must not include the warning that the parameter is deprecated, that is\n   * automatically added to the message. It should only contain the instruction on how\n   * to resolve this warning.\n   */\n  static _logOption({ optionKey, envKey, changeNewKey, changeNewDefault, solution }) {\n    const type = optionKey ? 'option' : 'environment key';\n    const key = optionKey ? optionKey : envKey;\n    const keyAction =\n      changeNewKey == null\n        ? undefined\n        : changeNewKey.length > 0\n          ? `renamed to '${changeNewKey}'`\n          : `removed`;\n\n    // Compose message\n    let output = `DeprecationWarning: The Parse Server ${type} '${key}' `;\n    output += changeNewKey != null ? `is deprecated and will be ${keyAction} in a future version.` : '';\n    output += changeNewDefault\n      ? `default will change to '${changeNewDefault}' in a future version.`\n      : '';\n    output += solution ? ` ${solution}` : '';\n    logger.warn(output);\n  }\n}\n\nmodule.exports = Deprecator;\n"],"mappings":"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","ignoreList":[]}