parse-server 6.0.0-alpha.2 → 6.0.0-alpha.21

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 (191) hide show
  1. package/README.md +45 -17
  2. package/lib/AccountLockout.js +11 -26
  3. package/lib/Adapters/AdapterLoader.js +8 -14
  4. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  5. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  6. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  7. package/lib/Adapters/Auth/apple.js +6 -22
  8. package/lib/Adapters/Auth/facebook.js +7 -37
  9. package/lib/Adapters/Auth/gcenter.js +8 -37
  10. package/lib/Adapters/Auth/github.js +7 -10
  11. package/lib/Adapters/Auth/google.js +11 -34
  12. package/lib/Adapters/Auth/gpgames.js +5 -8
  13. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  14. package/lib/Adapters/Auth/index.js +20 -65
  15. package/lib/Adapters/Auth/instagram.js +5 -9
  16. package/lib/Adapters/Auth/janraincapture.js +8 -12
  17. package/lib/Adapters/Auth/janrainengage.js +7 -11
  18. package/lib/Adapters/Auth/keycloak.js +5 -19
  19. package/lib/Adapters/Auth/ldap.js +1 -15
  20. package/lib/Adapters/Auth/line.js +7 -10
  21. package/lib/Adapters/Auth/linkedin.js +7 -12
  22. package/lib/Adapters/Auth/meetup.js +7 -10
  23. package/lib/Adapters/Auth/microsoft.js +7 -10
  24. package/lib/Adapters/Auth/oauth2.js +6 -18
  25. package/lib/Adapters/Auth/phantauth.js +8 -10
  26. package/lib/Adapters/Auth/qq.js +7 -13
  27. package/lib/Adapters/Auth/spotify.js +7 -14
  28. package/lib/Adapters/Auth/twitter.js +5 -15
  29. package/lib/Adapters/Auth/vkontakte.js +9 -15
  30. package/lib/Adapters/Auth/wechat.js +7 -10
  31. package/lib/Adapters/Auth/weibo.js +7 -11
  32. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  33. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  34. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  35. package/lib/Adapters/Cache/LRUCache.js +1 -11
  36. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  37. package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
  38. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  39. package/lib/Adapters/Email/MailAdapter.js +2 -7
  40. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  41. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  42. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  43. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  44. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  45. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  46. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  47. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  48. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  49. package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
  50. package/lib/Adapters/Push/PushAdapter.js +2 -8
  51. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  52. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  53. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  54. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  55. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  56. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  57. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  58. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  59. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  60. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  61. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  62. package/lib/Auth.js +54 -121
  63. package/lib/ClientSDK.js +3 -11
  64. package/lib/Config.js +69 -113
  65. package/lib/Controllers/AdaptableController.js +6 -18
  66. package/lib/Controllers/AnalyticsController.js +1 -9
  67. package/lib/Controllers/CacheController.js +3 -23
  68. package/lib/Controllers/DatabaseController.js +147 -345
  69. package/lib/Controllers/FilesController.js +5 -34
  70. package/lib/Controllers/HooksController.js +1 -51
  71. package/lib/Controllers/LiveQueryController.js +4 -23
  72. package/lib/Controllers/LoggerController.js +15 -54
  73. package/lib/Controllers/ParseGraphQLController.js +49 -104
  74. package/lib/Controllers/PushController.js +20 -59
  75. package/lib/Controllers/SchemaController.js +154 -344
  76. package/lib/Controllers/UserController.js +11 -72
  77. package/lib/Controllers/index.js +19 -68
  78. package/lib/Controllers/types.js +1 -1
  79. package/lib/Deprecator/Deprecations.js +1 -8
  80. package/lib/Deprecator/Deprecator.js +9 -18
  81. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  82. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  83. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  84. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  85. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  86. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  87. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  88. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  89. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  90. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  91. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  92. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  93. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  94. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  95. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  96. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  97. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  98. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  99. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  100. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  101. package/lib/GraphQL/transformers/className.js +1 -4
  102. package/lib/GraphQL/transformers/constraintType.js +1 -20
  103. package/lib/GraphQL/transformers/inputType.js +1 -20
  104. package/lib/GraphQL/transformers/mutation.js +6 -51
  105. package/lib/GraphQL/transformers/outputType.js +1 -20
  106. package/lib/GraphQL/transformers/query.js +6 -42
  107. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  108. package/lib/KeyPromiseQueue.js +1 -12
  109. package/lib/LiveQuery/Client.js +1 -25
  110. package/lib/LiveQuery/Id.js +1 -7
  111. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  112. package/lib/LiveQuery/ParseLiveQueryServer.js +92 -306
  113. package/lib/LiveQuery/ParsePubSub.js +1 -12
  114. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  115. package/lib/LiveQuery/QueryTools.js +14 -116
  116. package/lib/LiveQuery/RequestSchema.js +1 -1
  117. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  118. package/lib/LiveQuery/Subscription.js +4 -18
  119. package/lib/LiveQuery/equalObjects.js +2 -14
  120. package/lib/Options/Definitions.js +79 -10
  121. package/lib/Options/docs.js +23 -3
  122. package/lib/Options/index.js +4 -12
  123. package/lib/Options/parsers.js +1 -18
  124. package/lib/Page.js +1 -9
  125. package/lib/ParseMessageQueue.js +1 -10
  126. package/lib/ParseServer.js +144 -182
  127. package/lib/ParseServerRESTController.js +6 -33
  128. package/lib/PromiseRouter.js +16 -50
  129. package/lib/Push/PushQueue.js +3 -15
  130. package/lib/Push/PushWorker.js +7 -32
  131. package/lib/Push/utils.js +9 -38
  132. package/lib/RestQuery.js +105 -242
  133. package/lib/RestWrite.js +212 -377
  134. package/lib/Routers/AggregateRouter.js +14 -51
  135. package/lib/Routers/AnalyticsRouter.js +2 -8
  136. package/lib/Routers/AudiencesRouter.js +1 -15
  137. package/lib/Routers/ClassesRouter.js +3 -53
  138. package/lib/Routers/CloudCodeRouter.js +1 -19
  139. package/lib/Routers/FeaturesRouter.js +1 -10
  140. package/lib/Routers/FilesRouter.js +29 -76
  141. package/lib/Routers/FunctionsRouter.js +5 -28
  142. package/lib/Routers/GlobalConfigRouter.js +4 -18
  143. package/lib/Routers/GraphQLRouter.js +1 -14
  144. package/lib/Routers/HooksRouter.js +1 -29
  145. package/lib/Routers/IAPValidationRouter.js +6 -29
  146. package/lib/Routers/InstallationsRouter.js +2 -12
  147. package/lib/Routers/LogsRouter.js +4 -16
  148. package/lib/Routers/PagesRouter.js +69 -129
  149. package/lib/Routers/PublicAPIRouter.js +3 -62
  150. package/lib/Routers/PurgeRouter.js +1 -15
  151. package/lib/Routers/PushRouter.js +2 -18
  152. package/lib/Routers/RolesRouter.js +1 -7
  153. package/lib/Routers/SchemasRouter.js +4 -34
  154. package/lib/Routers/SecurityRouter.js +1 -12
  155. package/lib/Routers/SessionsRouter.js +3 -19
  156. package/lib/Routers/UsersRouter.js +58 -155
  157. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  158. package/lib/SchemaMigrations/Migrations.js +2 -8
  159. package/lib/Security/Check.js +8 -16
  160. package/lib/Security/CheckGroup.js +4 -11
  161. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  162. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  163. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  164. package/lib/Security/CheckRunner.js +22 -41
  165. package/lib/StatusHandler.js +12 -69
  166. package/lib/TestUtils.js +1 -6
  167. package/lib/Utils.js +27 -66
  168. package/lib/batch.js +17 -28
  169. package/lib/cache.js +1 -3
  170. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  171. package/lib/cli/definitions/parse-server.js +1 -3
  172. package/lib/cli/parse-live-query-server.js +1 -6
  173. package/lib/cli/parse-server.js +11 -21
  174. package/lib/cli/utils/commander.js +13 -51
  175. package/lib/cli/utils/runner.js +1 -14
  176. package/lib/cloud-code/Parse.Cloud.js +71 -92
  177. package/lib/cryptoUtils.js +11 -19
  178. package/lib/defaults.js +2 -14
  179. package/lib/deprecated.js +1 -2
  180. package/lib/index.js +16 -34
  181. package/lib/logger.js +6 -13
  182. package/lib/middlewares.js +147 -151
  183. package/lib/password.js +6 -10
  184. package/lib/request.js +173 -2
  185. package/lib/requiredParameter.js +1 -3
  186. package/lib/rest.js +19 -41
  187. package/lib/triggers.js +54 -252
  188. package/lib/vendor/mongodbUrl.js +125 -305
  189. package/package.json +22 -19
  190. package/lib/cloud-code/HTTPResponse.js +0 -73
  191. package/lib/cloud-code/httpRequest.js +0 -192
@@ -5,32 +5,23 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.ParseServerRESTController = ParseServerRESTController;
7
7
  exports.default = void 0;
8
-
9
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
10
-
11
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
12
-
13
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
14
-
8
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
9
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
10
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
11
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
12
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
15
13
  const Config = require('./Config');
16
-
17
14
  const Auth = require('./Auth');
18
-
19
15
  const RESTController = require('parse/lib/node/RESTController');
20
-
21
16
  const Parse = require('parse/node');
22
-
23
17
  function getSessionToken(options) {
24
18
  if (options && typeof options.sessionToken === 'string') {
25
19
  return Promise.resolve(options.sessionToken);
26
20
  }
27
-
28
21
  return Promise.resolve(null);
29
22
  }
30
-
31
23
  function getAuth(options = {}, config) {
32
24
  const installationId = options.installationId || 'cloud';
33
-
34
25
  if (options.useMasterKey) {
35
26
  return Promise.resolve(new Auth.Auth({
36
27
  config,
@@ -38,7 +29,6 @@ function getAuth(options = {}, config) {
38
29
  installationId
39
30
  }));
40
31
  }
41
-
42
32
  return getSessionToken(options).then(sessionToken => {
43
33
  if (sessionToken) {
44
34
  options.sessionToken = sessionToken;
@@ -55,34 +45,26 @@ function getAuth(options = {}, config) {
55
45
  }
56
46
  });
57
47
  }
58
-
59
48
  function ParseServerRESTController(applicationId, router) {
60
49
  function handleRequest(method, path, data = {}, options = {}, config) {
61
50
  // Store the arguments, for later use if internal fails
62
51
  const args = arguments;
63
-
64
52
  if (!config) {
65
53
  config = Config.get(applicationId);
66
54
  }
67
-
68
55
  const serverURL = new URL(config.serverURL);
69
-
70
56
  if (path.indexOf(serverURL.pathname) === 0) {
71
57
  path = path.slice(serverURL.pathname.length, path.length);
72
58
  }
73
-
74
59
  if (path[0] !== '/') {
75
60
  path = '/' + path;
76
61
  }
77
-
78
62
  if (path === '/batch') {
79
63
  const batch = transactionRetries => {
80
64
  let initialPromise = Promise.resolve();
81
-
82
65
  if (data.transaction === true) {
83
66
  initialPromise = config.database.createTransactionalSession();
84
67
  }
85
-
86
68
  return initialPromise.then(() => {
87
69
  const promises = data.requests.map(request => {
88
70
  return handleRequest(request.method, request.path, request.body, options, config).then(response => {
@@ -94,7 +76,6 @@ function ParseServerRESTController(applicationId, router) {
94
76
  _status: status
95
77
  };
96
78
  }
97
-
98
79
  return {
99
80
  success: response
100
81
  };
@@ -125,21 +106,16 @@ function ParseServerRESTController(applicationId, router) {
125
106
  if (error && error.find(errorItem => typeof errorItem.error === 'object' && errorItem.error.code === 251) && transactionRetries > 0) {
126
107
  return batch(transactionRetries - 1);
127
108
  }
128
-
129
109
  throw error;
130
110
  });
131
111
  });
132
112
  };
133
-
134
113
  return batch(5);
135
114
  }
136
-
137
115
  let query;
138
-
139
116
  if (method === 'GET') {
140
117
  query = data;
141
118
  }
142
-
143
119
  return new Promise((resolve, reject) => {
144
120
  getAuth(options, config).then(auth => {
145
121
  const request = {
@@ -161,7 +137,6 @@ function ParseServerRESTController(applicationId, router) {
161
137
  response,
162
138
  status
163
139
  } = resp;
164
-
165
140
  if (options.returnStatus) {
166
141
  resolve(_objectSpread(_objectSpread({}, response), {}, {
167
142
  _status: status
@@ -179,14 +154,12 @@ function ParseServerRESTController(applicationId, router) {
179
154
  }, reject);
180
155
  });
181
156
  }
182
-
183
157
  return {
184
158
  request: handleRequest,
185
159
  ajax: RESTController.ajax,
186
160
  handleError: RESTController.handleError
187
161
  };
188
162
  }
189
-
190
163
  var _default = ParseServerRESTController;
191
164
  exports.default = _default;
192
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ParseServerRESTController.js"],"names":["Config","require","Auth","RESTController","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","URL","indexOf","pathname","slice","length","batch","transactionRetries","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","success","error","code","message","all","result","find","resultItem","abortTransactionalSession","reject","commitTransactionalSession","catch","errorItem","query","auth","info","context","tryRouteRequest","resp","err","Error","INVALID_JSON","apply","ajax","handleError"],"mappings":"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","sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nconst RESTController = require('parse/lib/node/RESTController');\nconst Parse = require('parse/node');\n\nfunction getSessionToken(options) {\n  if (options && typeof options.sessionToken === 'string') {\n    return Promise.resolve(options.sessionToken);\n  }\n  return Promise.resolve(null);\n}\n\nfunction getAuth(options = {}, config) {\n  const installationId = options.installationId || 'cloud';\n  if (options.useMasterKey) {\n    return Promise.resolve(new Auth.Auth({ config, isMaster: true, installationId }));\n  }\n  return getSessionToken(options).then(sessionToken => {\n    if (sessionToken) {\n      options.sessionToken = sessionToken;\n      return Auth.getAuthForSessionToken({\n        config,\n        sessionToken: sessionToken,\n        installationId,\n      });\n    } else {\n      return Promise.resolve(new Auth.Auth({ config, installationId }));\n    }\n  });\n}\n\nfunction ParseServerRESTController(applicationId, router) {\n  function handleRequest(method, path, data = {}, options = {}, config) {\n    // Store the arguments, for later use if internal fails\n    const args = arguments;\n\n    if (!config) {\n      config = Config.get(applicationId);\n    }\n    const serverURL = new URL(config.serverURL);\n    if (path.indexOf(serverURL.pathname) === 0) {\n      path = path.slice(serverURL.pathname.length, path.length);\n    }\n\n    if (path[0] !== '/') {\n      path = '/' + path;\n    }\n\n    if (path === '/batch') {\n      const batch = transactionRetries => {\n        let initialPromise = Promise.resolve();\n        if (data.transaction === true) {\n          initialPromise = config.database.createTransactionalSession();\n        }\n        return initialPromise.then(() => {\n          const promises = data.requests.map(request => {\n            return handleRequest(request.method, request.path, request.body, options, config).then(\n              response => {\n                if (options.returnStatus) {\n                  const status = response._status;\n                  delete response._status;\n                  return { success: response, _status: status };\n                }\n                return { success: response };\n              },\n              error => {\n                return {\n                  error: { code: error.code, error: error.message },\n                };\n              }\n            );\n          });\n          return Promise.all(promises)\n            .then(result => {\n              if (data.transaction === true) {\n                if (result.find(resultItem => typeof resultItem.error === 'object')) {\n                  return config.database.abortTransactionalSession().then(() => {\n                    return Promise.reject(result);\n                  });\n                } else {\n                  return config.database.commitTransactionalSession().then(() => {\n                    return result;\n                  });\n                }\n              } else {\n                return result;\n              }\n            })\n            .catch(error => {\n              if (\n                error &&\n                error.find(\n                  errorItem => typeof errorItem.error === 'object' && errorItem.error.code === 251\n                ) &&\n                transactionRetries > 0\n              ) {\n                return batch(transactionRetries - 1);\n              }\n              throw error;\n            });\n        });\n      };\n      return batch(5);\n    }\n\n    let query;\n    if (method === 'GET') {\n      query = data;\n    }\n\n    return new Promise((resolve, reject) => {\n      getAuth(options, config).then(auth => {\n        const request = {\n          body: data,\n          config,\n          auth,\n          info: {\n            applicationId: applicationId,\n            sessionToken: options.sessionToken,\n            installationId: options.installationId,\n            context: options.context || {},\n          },\n          query,\n        };\n        return Promise.resolve()\n          .then(() => {\n            return router.tryRouteRequest(method, path, request);\n          })\n          .then(\n            resp => {\n              const { response, status } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status });\n              } else {\n                resolve(response);\n              }\n            },\n            err => {\n              if (\n                err instanceof Parse.Error &&\n                err.code == Parse.Error.INVALID_JSON &&\n                err.message == `cannot route ${method} ${path}`\n              ) {\n                RESTController.request.apply(null, args).then(resolve, reject);\n              } else {\n                reject(err);\n              }\n            }\n          );\n      }, reject);\n    });\n  }\n\n  return {\n    request: handleRequest,\n    ajax: RESTController.ajax,\n    handleError: RESTController.handleError,\n  };\n}\n\nexport default ParseServerRESTController;\nexport { ParseServerRESTController };\n"]}
165
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Config","require","Auth","RESTController","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","URL","indexOf","pathname","slice","length","batch","transactionRetries","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","success","error","code","message","all","result","find","resultItem","abortTransactionalSession","reject","commitTransactionalSession","catch","errorItem","query","auth","info","context","tryRouteRequest","resp","err","Error","INVALID_JSON","apply","ajax","handleError"],"sources":["../src/ParseServerRESTController.js"],"sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nconst RESTController = require('parse/lib/node/RESTController');\nconst Parse = require('parse/node');\n\nfunction getSessionToken(options) {\n  if (options && typeof options.sessionToken === 'string') {\n    return Promise.resolve(options.sessionToken);\n  }\n  return Promise.resolve(null);\n}\n\nfunction getAuth(options = {}, config) {\n  const installationId = options.installationId || 'cloud';\n  if (options.useMasterKey) {\n    return Promise.resolve(new Auth.Auth({ config, isMaster: true, installationId }));\n  }\n  return getSessionToken(options).then(sessionToken => {\n    if (sessionToken) {\n      options.sessionToken = sessionToken;\n      return Auth.getAuthForSessionToken({\n        config,\n        sessionToken: sessionToken,\n        installationId,\n      });\n    } else {\n      return Promise.resolve(new Auth.Auth({ config, installationId }));\n    }\n  });\n}\n\nfunction ParseServerRESTController(applicationId, router) {\n  function handleRequest(method, path, data = {}, options = {}, config) {\n    // Store the arguments, for later use if internal fails\n    const args = arguments;\n\n    if (!config) {\n      config = Config.get(applicationId);\n    }\n    const serverURL = new URL(config.serverURL);\n    if (path.indexOf(serverURL.pathname) === 0) {\n      path = path.slice(serverURL.pathname.length, path.length);\n    }\n\n    if (path[0] !== '/') {\n      path = '/' + path;\n    }\n\n    if (path === '/batch') {\n      const batch = transactionRetries => {\n        let initialPromise = Promise.resolve();\n        if (data.transaction === true) {\n          initialPromise = config.database.createTransactionalSession();\n        }\n        return initialPromise.then(() => {\n          const promises = data.requests.map(request => {\n            return handleRequest(request.method, request.path, request.body, options, config).then(\n              response => {\n                if (options.returnStatus) {\n                  const status = response._status;\n                  delete response._status;\n                  return { success: response, _status: status };\n                }\n                return { success: response };\n              },\n              error => {\n                return {\n                  error: { code: error.code, error: error.message },\n                };\n              }\n            );\n          });\n          return Promise.all(promises)\n            .then(result => {\n              if (data.transaction === true) {\n                if (result.find(resultItem => typeof resultItem.error === 'object')) {\n                  return config.database.abortTransactionalSession().then(() => {\n                    return Promise.reject(result);\n                  });\n                } else {\n                  return config.database.commitTransactionalSession().then(() => {\n                    return result;\n                  });\n                }\n              } else {\n                return result;\n              }\n            })\n            .catch(error => {\n              if (\n                error &&\n                error.find(\n                  errorItem => typeof errorItem.error === 'object' && errorItem.error.code === 251\n                ) &&\n                transactionRetries > 0\n              ) {\n                return batch(transactionRetries - 1);\n              }\n              throw error;\n            });\n        });\n      };\n      return batch(5);\n    }\n\n    let query;\n    if (method === 'GET') {\n      query = data;\n    }\n\n    return new Promise((resolve, reject) => {\n      getAuth(options, config).then(auth => {\n        const request = {\n          body: data,\n          config,\n          auth,\n          info: {\n            applicationId: applicationId,\n            sessionToken: options.sessionToken,\n            installationId: options.installationId,\n            context: options.context || {},\n          },\n          query,\n        };\n        return Promise.resolve()\n          .then(() => {\n            return router.tryRouteRequest(method, path, request);\n          })\n          .then(\n            resp => {\n              const { response, status } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status });\n              } else {\n                resolve(response);\n              }\n            },\n            err => {\n              if (\n                err instanceof Parse.Error &&\n                err.code == Parse.Error.INVALID_JSON &&\n                err.message == `cannot route ${method} ${path}`\n              ) {\n                RESTController.request.apply(null, args).then(resolve, reject);\n              } else {\n                reject(err);\n              }\n            }\n          );\n      }, reject);\n    });\n  }\n\n  return {\n    request: handleRequest,\n    ajax: RESTController.ajax,\n    handleError: RESTController.handleError,\n  };\n}\n\nexport default ParseServerRESTController;\nexport { ParseServerRESTController };\n"],"mappings":"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"}
@@ -4,25 +4,19 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
-
8
7
  var _node = _interopRequireDefault(require("parse/node"));
9
-
10
8
  var _express = _interopRequireDefault(require("express"));
11
-
12
9
  var _logger = _interopRequireDefault(require("./logger"));
13
-
14
10
  var _util = require("util");
15
-
16
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
-
18
12
  // A router that is based on promises rather than req/res/next.
19
13
  // This is intended to replace the use of express.Router to handle
20
14
  // subsections of the API surface.
21
15
  // This will make it easier to have methods like 'batch' that
22
16
  // themselves use our routing information, without disturbing express
23
17
  // components that external developers may be modifying.
24
- const Layer = require('express/lib/router/layer');
25
18
 
19
+ const Layer = require('express/lib/router/layer');
26
20
  function validateParameter(key, value) {
27
21
  if (key == 'className') {
28
22
  if (value.match(/_?[A-Za-z][A-Za-z_0-9]*/)) {
@@ -36,7 +30,6 @@ function validateParameter(key, value) {
36
30
  return value;
37
31
  }
38
32
  }
39
-
40
33
  class PromiseRouter {
41
34
  // Each entry should be an object with:
42
35
  // path: the path to route, in express format
@@ -51,19 +44,18 @@ class PromiseRouter {
51
44
  this.routes = routes;
52
45
  this.appId = appId;
53
46
  this.mountRoutes();
54
- } // Leave the opportunity to
55
- // subclasses to mount their routes by overriding
56
-
57
-
58
- mountRoutes() {} // Merge the routes into this one
47
+ }
59
48
 
49
+ // Leave the opportunity to
50
+ // subclasses to mount their routes by overriding
51
+ mountRoutes() {}
60
52
 
53
+ // Merge the routes into this one
61
54
  merge(router) {
62
55
  for (var route of router.routes) {
63
56
  this.routes.push(route);
64
57
  }
65
58
  }
66
-
67
59
  route(method, path, ...handlers) {
68
60
  switch (method) {
69
61
  case 'POST':
@@ -71,13 +63,10 @@ class PromiseRouter {
71
63
  case 'PUT':
72
64
  case 'DELETE':
73
65
  break;
74
-
75
66
  default:
76
67
  throw 'cannot route method: ' + method;
77
68
  }
78
-
79
69
  let handler = handlers[0];
80
-
81
70
  if (handlers.length > 1) {
82
71
  handler = function (req) {
83
72
  return handlers.reduce((promise, handler) => {
@@ -87,28 +76,25 @@ class PromiseRouter {
87
76
  }, Promise.resolve());
88
77
  };
89
78
  }
90
-
91
79
  this.routes.push({
92
80
  path: path,
93
81
  method: method,
94
82
  handler: handler,
95
83
  layer: new Layer(path, null, handler)
96
84
  });
97
- } // Returns an object with:
85
+ }
86
+
87
+ // Returns an object with:
98
88
  // handler: the handler that should deal with this request
99
89
  // params: any :-params that got parsed from the path
100
90
  // Returns undefined if there is no match.
101
-
102
-
103
91
  match(method, path) {
104
92
  for (var route of this.routes) {
105
93
  if (route.method != method) {
106
94
  continue;
107
95
  }
108
-
109
96
  const layer = route.layer || new Layer(route.path, null, route.handler);
110
97
  const match = layer.match(path);
111
-
112
98
  if (match) {
113
99
  const params = layer.params;
114
100
  Object.keys(params).forEach(key => {
@@ -120,9 +106,9 @@ class PromiseRouter {
120
106
  };
121
107
  }
122
108
  }
123
- } // Mount the routes on this router onto an express app (or express router)
124
-
109
+ }
125
110
 
111
+ // Mount the routes on this router onto an express app (or express router)
126
112
  mountOnto(expressApp) {
127
113
  this.routes.forEach(route => {
128
114
  const method = route.method.toLowerCase();
@@ -131,32 +117,26 @@ class PromiseRouter {
131
117
  });
132
118
  return expressApp;
133
119
  }
134
-
135
120
  expressRouter() {
136
121
  return this.mountOnto(_express.default.Router());
137
122
  }
138
-
139
123
  tryRouteRequest(method, path, request) {
140
124
  var match = this.match(method, path);
141
-
142
125
  if (!match) {
143
126
  throw new _node.default.Error(_node.default.Error.INVALID_JSON, 'cannot route ' + method + ' ' + path);
144
127
  }
145
-
146
128
  request.params = match.params;
147
129
  return new Promise((resolve, reject) => {
148
130
  match.handler(request).then(resolve, reject);
149
131
  });
150
132
  }
133
+ }
151
134
 
152
- } // A helper function to make an express handler out of a a promise
135
+ // A helper function to make an express handler out of a a promise
153
136
  // handler.
154
137
  // Express handlers should never throw; if a promise handler throws we
155
138
  // just treat it like it resolved to an error.
156
-
157
-
158
139
  exports.default = PromiseRouter;
159
-
160
140
  function makeExpressHandler(appId, promiseHandler) {
161
141
  return function (req, res, next) {
162
142
  try {
@@ -164,51 +144,42 @@ function makeExpressHandler(appId, promiseHandler) {
164
144
  const body = Object.assign({}, req.body);
165
145
  const method = req.method;
166
146
  const headers = req.headers;
167
-
168
147
  _logger.default.logRequest({
169
148
  method,
170
149
  url,
171
150
  headers,
172
151
  body
173
152
  });
174
-
175
153
  promiseHandler(req).then(result => {
176
154
  if (!result.response && !result.location && !result.text) {
177
155
  _logger.default.error('the handler did not include a "response" or a "location" field');
178
-
179
156
  throw 'control should not get here';
180
157
  }
181
-
182
158
  _logger.default.logResponse({
183
159
  method,
184
160
  url,
185
161
  result
186
162
  });
187
-
188
163
  var status = result.status || 200;
189
164
  res.status(status);
190
-
191
165
  if (result.headers) {
192
166
  Object.keys(result.headers).forEach(header => {
193
167
  res.set(header, result.headers[header]);
194
168
  });
195
169
  }
196
-
197
170
  if (result.text) {
198
171
  res.send(result.text);
199
172
  return;
200
173
  }
201
-
202
174
  if (result.location) {
203
- res.set('Location', result.location); // Override the default expressjs response
175
+ res.set('Location', result.location);
176
+ // Override the default expressjs response
204
177
  // as it double encodes %encoded chars in URL
205
-
206
178
  if (!result.response) {
207
179
  res.send('Found. Redirecting to ' + result.location);
208
180
  return;
209
181
  }
210
182
  }
211
-
212
183
  res.json(result.response);
213
184
  }, error => {
214
185
  next(error);
@@ -216,27 +187,22 @@ function makeExpressHandler(appId, promiseHandler) {
216
187
  _logger.default.error(`Error generating response. ${(0, _util.inspect)(e)}`, {
217
188
  error: e
218
189
  });
219
-
220
190
  next(e);
221
191
  });
222
192
  } catch (e) {
223
193
  _logger.default.error(`Error handling request: ${(0, _util.inspect)(e)}`, {
224
194
  error: e
225
195
  });
226
-
227
196
  next(e);
228
197
  }
229
198
  };
230
199
  }
231
-
232
200
  function maskSensitiveUrl(req) {
233
201
  let maskUrl = req.originalUrl.toString();
234
202
  const shouldMaskUrl = req.method === 'GET' && req.originalUrl.includes('/login') && !req.originalUrl.includes('classes');
235
-
236
203
  if (shouldMaskUrl) {
237
204
  maskUrl = _logger.default.maskSensitiveUrl(maskUrl);
238
205
  }
239
-
240
206
  return maskUrl;
241
207
  }
242
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/PromiseRouter.js"],"names":["Layer","require","validateParameter","key","value","match","PromiseRouter","constructor","routes","appId","mountRoutes","merge","router","route","push","method","path","handlers","handler","length","req","reduce","promise","then","Promise","resolve","layer","params","Object","keys","forEach","mountOnto","expressApp","toLowerCase","makeExpressHandler","call","expressRouter","express","Router","tryRouteRequest","request","Parse","Error","INVALID_JSON","reject","promiseHandler","res","next","url","maskSensitiveUrl","body","assign","headers","log","logRequest","result","response","location","text","error","logResponse","status","header","set","send","json","catch","e","maskUrl","originalUrl","toString","shouldMaskUrl","includes"],"mappings":";;;;;;;AAOA;;AACA;;AACA;;AACA;;;;AAVA;AACA;AACA;AACA;AACA;AACA;AAMA,MAAMA,KAAK,GAAGC,OAAO,CAAC,0BAAD,CAArB;;AAEA,SAASC,iBAAT,CAA2BC,GAA3B,EAAgCC,KAAhC,EAAuC;AACrC,MAAID,GAAG,IAAI,WAAX,EAAwB;AACtB,QAAIC,KAAK,CAACC,KAAN,CAAY,yBAAZ,CAAJ,EAA4C;AAC1C,aAAOD,KAAP;AACD;AACF,GAJD,MAIO,IAAID,GAAG,IAAI,UAAX,EAAuB;AAC5B,QAAIC,KAAK,CAACC,KAAN,CAAY,cAAZ,CAAJ,EAAiC;AAC/B,aAAOD,KAAP;AACD;AACF,GAJM,MAIA;AACL,WAAOA,KAAP;AACD;AACF;;AAEc,MAAME,aAAN,CAAoB;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACAC,EAAAA,WAAW,CAACC,MAAM,GAAG,EAAV,EAAcC,KAAd,EAAqB;AAC9B,SAAKD,MAAL,GAAcA,MAAd;AACA,SAAKC,KAAL,GAAaA,KAAb;AACA,SAAKC,WAAL;AACD,GAdgC,CAgBjC;AACA;;;AACAA,EAAAA,WAAW,GAAG,CAAE,CAlBiB,CAoBjC;;;AACAC,EAAAA,KAAK,CAACC,MAAD,EAAS;AACZ,SAAK,IAAIC,KAAT,IAAkBD,MAAM,CAACJ,MAAzB,EAAiC;AAC/B,WAAKA,MAAL,CAAYM,IAAZ,CAAiBD,KAAjB;AACD;AACF;;AAEDA,EAAAA,KAAK,CAACE,MAAD,EAASC,IAAT,EAAe,GAAGC,QAAlB,EAA4B;AAC/B,YAAQF,MAAR;AACE,WAAK,MAAL;AACA,WAAK,KAAL;AACA,WAAK,KAAL;AACA,WAAK,QAAL;AACE;;AACF;AACE,cAAM,0BAA0BA,MAAhC;AAPJ;;AAUA,QAAIG,OAAO,GAAGD,QAAQ,CAAC,CAAD,CAAtB;;AAEA,QAAIA,QAAQ,CAACE,MAAT,GAAkB,CAAtB,EAAyB;AACvBD,MAAAA,OAAO,GAAG,UAAUE,GAAV,EAAe;AACvB,eAAOH,QAAQ,CAACI,MAAT,CAAgB,CAACC,OAAD,EAAUJ,OAAV,KAAsB;AAC3C,iBAAOI,OAAO,CAACC,IAAR,CAAa,MAAM;AACxB,mBAAOL,OAAO,CAACE,GAAD,CAAd;AACD,WAFM,CAAP;AAGD,SAJM,EAIJI,OAAO,CAACC,OAAR,EAJI,CAAP;AAKD,OAND;AAOD;;AAED,SAAKjB,MAAL,CAAYM,IAAZ,CAAiB;AACfE,MAAAA,IAAI,EAAEA,IADS;AAEfD,MAAAA,MAAM,EAAEA,MAFO;AAGfG,MAAAA,OAAO,EAAEA,OAHM;AAIfQ,MAAAA,KAAK,EAAE,IAAI1B,KAAJ,CAAUgB,IAAV,EAAgB,IAAhB,EAAsBE,OAAtB;AAJQ,KAAjB;AAMD,GAxDgC,CA0DjC;AACA;AACA;AACA;;;AACAb,EAAAA,KAAK,CAACU,MAAD,EAASC,IAAT,EAAe;AAClB,SAAK,IAAIH,KAAT,IAAkB,KAAKL,MAAvB,EAA+B;AAC7B,UAAIK,KAAK,CAACE,MAAN,IAAgBA,MAApB,EAA4B;AAC1B;AACD;;AACD,YAAMW,KAAK,GAAGb,KAAK,CAACa,KAAN,IAAe,IAAI1B,KAAJ,CAAUa,KAAK,CAACG,IAAhB,EAAsB,IAAtB,EAA4BH,KAAK,CAACK,OAAlC,CAA7B;AACA,YAAMb,KAAK,GAAGqB,KAAK,CAACrB,KAAN,CAAYW,IAAZ,CAAd;;AACA,UAAIX,KAAJ,EAAW;AACT,cAAMsB,MAAM,GAAGD,KAAK,CAACC,MAArB;AACAC,QAAAA,MAAM,CAACC,IAAP,CAAYF,MAAZ,EAAoBG,OAApB,CAA4B3B,GAAG,IAAI;AACjCwB,UAAAA,MAAM,CAACxB,GAAD,CAAN,GAAcD,iBAAiB,CAACC,GAAD,EAAMwB,MAAM,CAACxB,GAAD,CAAZ,CAA/B;AACD,SAFD;AAGA,eAAO;AAAEwB,UAAAA,MAAM,EAAEA,MAAV;AAAkBT,UAAAA,OAAO,EAAEL,KAAK,CAACK;AAAjC,SAAP;AACD;AACF;AACF,GA7EgC,CA+EjC;;;AACAa,EAAAA,SAAS,CAACC,UAAD,EAAa;AACpB,SAAKxB,MAAL,CAAYsB,OAAZ,CAAoBjB,KAAK,IAAI;AAC3B,YAAME,MAAM,GAAGF,KAAK,CAACE,MAAN,CAAakB,WAAb,EAAf;AACA,YAAMf,OAAO,GAAGgB,kBAAkB,CAAC,KAAKzB,KAAN,EAAaI,KAAK,CAACK,OAAnB,CAAlC;AACAc,MAAAA,UAAU,CAACjB,MAAD,CAAV,CAAmBoB,IAAnB,CAAwBH,UAAxB,EAAoCnB,KAAK,CAACG,IAA1C,EAAgDE,OAAhD;AACD,KAJD;AAKA,WAAOc,UAAP;AACD;;AAEDI,EAAAA,aAAa,GAAG;AACd,WAAO,KAAKL,SAAL,CAAeM,iBAAQC,MAAR,EAAf,CAAP;AACD;;AAEDC,EAAAA,eAAe,CAACxB,MAAD,EAASC,IAAT,EAAewB,OAAf,EAAwB;AACrC,QAAInC,KAAK,GAAG,KAAKA,KAAL,CAAWU,MAAX,EAAmBC,IAAnB,CAAZ;;AACA,QAAI,CAACX,KAAL,EAAY;AACV,YAAM,IAAIoC,cAAMC,KAAV,CAAgBD,cAAMC,KAAN,CAAYC,YAA5B,EAA0C,kBAAkB5B,MAAlB,GAA2B,GAA3B,GAAiCC,IAA3E,CAAN;AACD;;AACDwB,IAAAA,OAAO,CAACb,MAAR,GAAiBtB,KAAK,CAACsB,MAAvB;AACA,WAAO,IAAIH,OAAJ,CAAY,CAACC,OAAD,EAAUmB,MAAV,KAAqB;AACtCvC,MAAAA,KAAK,CAACa,OAAN,CAAcsB,OAAd,EAAuBjB,IAAvB,CAA4BE,OAA5B,EAAqCmB,MAArC;AACD,KAFM,CAAP;AAGD;;AAtGgC,C,CAyGnC;AACA;AACA;AACA;;;;;AACA,SAASV,kBAAT,CAA4BzB,KAA5B,EAAmCoC,cAAnC,EAAmD;AACjD,SAAO,UAAUzB,GAAV,EAAe0B,GAAf,EAAoBC,IAApB,EAA0B;AAC/B,QAAI;AACF,YAAMC,GAAG,GAAGC,gBAAgB,CAAC7B,GAAD,CAA5B;AACA,YAAM8B,IAAI,GAAGtB,MAAM,CAACuB,MAAP,CAAc,EAAd,EAAkB/B,GAAG,CAAC8B,IAAtB,CAAb;AACA,YAAMnC,MAAM,GAAGK,GAAG,CAACL,MAAnB;AACA,YAAMqC,OAAO,GAAGhC,GAAG,CAACgC,OAApB;;AACAC,sBAAIC,UAAJ,CAAe;AACbvC,QAAAA,MADa;AAEbiC,QAAAA,GAFa;AAGbI,QAAAA,OAHa;AAIbF,QAAAA;AAJa,OAAf;;AAMAL,MAAAA,cAAc,CAACzB,GAAD,CAAd,CACGG,IADH,CAEIgC,MAAM,IAAI;AACR,YAAI,CAACA,MAAM,CAACC,QAAR,IAAoB,CAACD,MAAM,CAACE,QAA5B,IAAwC,CAACF,MAAM,CAACG,IAApD,EAA0D;AACxDL,0BAAIM,KAAJ,CAAU,gEAAV;;AACA,gBAAM,6BAAN;AACD;;AAEDN,wBAAIO,WAAJ,CAAgB;AAAE7C,UAAAA,MAAF;AAAUiC,UAAAA,GAAV;AAAeO,UAAAA;AAAf,SAAhB;;AAEA,YAAIM,MAAM,GAAGN,MAAM,CAACM,MAAP,IAAiB,GAA9B;AACAf,QAAAA,GAAG,CAACe,MAAJ,CAAWA,MAAX;;AAEA,YAAIN,MAAM,CAACH,OAAX,EAAoB;AAClBxB,UAAAA,MAAM,CAACC,IAAP,CAAY0B,MAAM,CAACH,OAAnB,EAA4BtB,OAA5B,CAAoCgC,MAAM,IAAI;AAC5ChB,YAAAA,GAAG,CAACiB,GAAJ,CAAQD,MAAR,EAAgBP,MAAM,CAACH,OAAP,CAAeU,MAAf,CAAhB;AACD,WAFD;AAGD;;AAED,YAAIP,MAAM,CAACG,IAAX,EAAiB;AACfZ,UAAAA,GAAG,CAACkB,IAAJ,CAAST,MAAM,CAACG,IAAhB;AACA;AACD;;AAED,YAAIH,MAAM,CAACE,QAAX,EAAqB;AACnBX,UAAAA,GAAG,CAACiB,GAAJ,CAAQ,UAAR,EAAoBR,MAAM,CAACE,QAA3B,EADmB,CAEnB;AACA;;AACA,cAAI,CAACF,MAAM,CAACC,QAAZ,EAAsB;AACpBV,YAAAA,GAAG,CAACkB,IAAJ,CAAS,2BAA2BT,MAAM,CAACE,QAA3C;AACA;AACD;AACF;;AACDX,QAAAA,GAAG,CAACmB,IAAJ,CAASV,MAAM,CAACC,QAAhB;AACD,OAlCL,EAmCIG,KAAK,IAAI;AACPZ,QAAAA,IAAI,CAACY,KAAD,CAAJ;AACD,OArCL,EAuCGO,KAvCH,CAuCSC,CAAC,IAAI;AACVd,wBAAIM,KAAJ,CAAW,8BAA6B,mBAAQQ,CAAR,CAAW,EAAnD,EAAsD;AAAER,UAAAA,KAAK,EAAEQ;AAAT,SAAtD;;AACApB,QAAAA,IAAI,CAACoB,CAAD,CAAJ;AACD,OA1CH;AA2CD,KAtDD,CAsDE,OAAOA,CAAP,EAAU;AACVd,sBAAIM,KAAJ,CAAW,2BAA0B,mBAAQQ,CAAR,CAAW,EAAhD,EAAmD;AAAER,QAAAA,KAAK,EAAEQ;AAAT,OAAnD;;AACApB,MAAAA,IAAI,CAACoB,CAAD,CAAJ;AACD;AACF,GA3DD;AA4DD;;AAED,SAASlB,gBAAT,CAA0B7B,GAA1B,EAA+B;AAC7B,MAAIgD,OAAO,GAAGhD,GAAG,CAACiD,WAAJ,CAAgBC,QAAhB,EAAd;AACA,QAAMC,aAAa,GACjBnD,GAAG,CAACL,MAAJ,KAAe,KAAf,IACAK,GAAG,CAACiD,WAAJ,CAAgBG,QAAhB,CAAyB,QAAzB,CADA,IAEA,CAACpD,GAAG,CAACiD,WAAJ,CAAgBG,QAAhB,CAAyB,SAAzB,CAHH;;AAIA,MAAID,aAAJ,EAAmB;AACjBH,IAAAA,OAAO,GAAGf,gBAAIJ,gBAAJ,CAAqBmB,OAArB,CAAV;AACD;;AACD,SAAOA,OAAP;AACD","sourcesContent":["// A router that is based on promises rather than req/res/next.\n// This is intended to replace the use of express.Router to handle\n// subsections of the API surface.\n// This will make it easier to have methods like 'batch' that\n// themselves use our routing information, without disturbing express\n// components that external developers may be modifying.\n\nimport Parse from 'parse/node';\nimport express from 'express';\nimport log from './logger';\nimport { inspect } from 'util';\nconst Layer = require('express/lib/router/layer');\n\nfunction validateParameter(key, value) {\n  if (key == 'className') {\n    if (value.match(/_?[A-Za-z][A-Za-z_0-9]*/)) {\n      return value;\n    }\n  } else if (key == 'objectId') {\n    if (value.match(/[A-Za-z0-9]+/)) {\n      return value;\n    }\n  } else {\n    return value;\n  }\n}\n\nexport default class PromiseRouter {\n  // Each entry should be an object with:\n  // path: the path to route, in express format\n  // method: the HTTP method that this route handles.\n  //   Must be one of: POST, GET, PUT, DELETE\n  // handler: a function that takes request, and returns a promise.\n  //   Successful handlers should resolve to an object with fields:\n  //     status: optional. the http status code. defaults to 200\n  //     response: a json object with the content of the response\n  //     location: optional. a location header\n  constructor(routes = [], appId) {\n    this.routes = routes;\n    this.appId = appId;\n    this.mountRoutes();\n  }\n\n  // Leave the opportunity to\n  // subclasses to mount their routes by overriding\n  mountRoutes() {}\n\n  // Merge the routes into this one\n  merge(router) {\n    for (var route of router.routes) {\n      this.routes.push(route);\n    }\n  }\n\n  route(method, path, ...handlers) {\n    switch (method) {\n      case 'POST':\n      case 'GET':\n      case 'PUT':\n      case 'DELETE':\n        break;\n      default:\n        throw 'cannot route method: ' + method;\n    }\n\n    let handler = handlers[0];\n\n    if (handlers.length > 1) {\n      handler = function (req) {\n        return handlers.reduce((promise, handler) => {\n          return promise.then(() => {\n            return handler(req);\n          });\n        }, Promise.resolve());\n      };\n    }\n\n    this.routes.push({\n      path: path,\n      method: method,\n      handler: handler,\n      layer: new Layer(path, null, handler),\n    });\n  }\n\n  // Returns an object with:\n  //   handler: the handler that should deal with this request\n  //   params: any :-params that got parsed from the path\n  // Returns undefined if there is no match.\n  match(method, path) {\n    for (var route of this.routes) {\n      if (route.method != method) {\n        continue;\n      }\n      const layer = route.layer || new Layer(route.path, null, route.handler);\n      const match = layer.match(path);\n      if (match) {\n        const params = layer.params;\n        Object.keys(params).forEach(key => {\n          params[key] = validateParameter(key, params[key]);\n        });\n        return { params: params, handler: route.handler };\n      }\n    }\n  }\n\n  // Mount the routes on this router onto an express app (or express router)\n  mountOnto(expressApp) {\n    this.routes.forEach(route => {\n      const method = route.method.toLowerCase();\n      const handler = makeExpressHandler(this.appId, route.handler);\n      expressApp[method].call(expressApp, route.path, handler);\n    });\n    return expressApp;\n  }\n\n  expressRouter() {\n    return this.mountOnto(express.Router());\n  }\n\n  tryRouteRequest(method, path, request) {\n    var match = this.match(method, path);\n    if (!match) {\n      throw new Parse.Error(Parse.Error.INVALID_JSON, 'cannot route ' + method + ' ' + path);\n    }\n    request.params = match.params;\n    return new Promise((resolve, reject) => {\n      match.handler(request).then(resolve, reject);\n    });\n  }\n}\n\n// A helper function to make an express handler out of a a promise\n// handler.\n// Express handlers should never throw; if a promise handler throws we\n// just treat it like it resolved to an error.\nfunction makeExpressHandler(appId, promiseHandler) {\n  return function (req, res, next) {\n    try {\n      const url = maskSensitiveUrl(req);\n      const body = Object.assign({}, req.body);\n      const method = req.method;\n      const headers = req.headers;\n      log.logRequest({\n        method,\n        url,\n        headers,\n        body,\n      });\n      promiseHandler(req)\n        .then(\n          result => {\n            if (!result.response && !result.location && !result.text) {\n              log.error('the handler did not include a \"response\" or a \"location\" field');\n              throw 'control should not get here';\n            }\n\n            log.logResponse({ method, url, result });\n\n            var status = result.status || 200;\n            res.status(status);\n\n            if (result.headers) {\n              Object.keys(result.headers).forEach(header => {\n                res.set(header, result.headers[header]);\n              });\n            }\n\n            if (result.text) {\n              res.send(result.text);\n              return;\n            }\n\n            if (result.location) {\n              res.set('Location', result.location);\n              // Override the default expressjs response\n              // as it double encodes %encoded chars in URL\n              if (!result.response) {\n                res.send('Found. Redirecting to ' + result.location);\n                return;\n              }\n            }\n            res.json(result.response);\n          },\n          error => {\n            next(error);\n          }\n        )\n        .catch(e => {\n          log.error(`Error generating response. ${inspect(e)}`, { error: e });\n          next(e);\n        });\n    } catch (e) {\n      log.error(`Error handling request: ${inspect(e)}`, { error: e });\n      next(e);\n    }\n  };\n}\n\nfunction maskSensitiveUrl(req) {\n  let maskUrl = req.originalUrl.toString();\n  const shouldMaskUrl =\n    req.method === 'GET' &&\n    req.originalUrl.includes('/login') &&\n    !req.originalUrl.includes('classes');\n  if (shouldMaskUrl) {\n    maskUrl = log.maskSensitiveUrl(maskUrl);\n  }\n  return maskUrl;\n}\n"]}
208
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Layer","require","validateParameter","key","value","match","PromiseRouter","constructor","routes","appId","mountRoutes","merge","router","route","push","method","path","handlers","handler","length","req","reduce","promise","then","Promise","resolve","layer","params","Object","keys","forEach","mountOnto","expressApp","toLowerCase","makeExpressHandler","call","expressRouter","express","Router","tryRouteRequest","request","Parse","Error","INVALID_JSON","reject","promiseHandler","res","next","url","maskSensitiveUrl","body","assign","headers","log","logRequest","result","response","location","text","error","logResponse","status","header","set","send","json","catch","e","inspect","maskUrl","originalUrl","toString","shouldMaskUrl","includes"],"sources":["../src/PromiseRouter.js"],"sourcesContent":["// A router that is based on promises rather than req/res/next.\n// This is intended to replace the use of express.Router to handle\n// subsections of the API surface.\n// This will make it easier to have methods like 'batch' that\n// themselves use our routing information, without disturbing express\n// components that external developers may be modifying.\n\nimport Parse from 'parse/node';\nimport express from 'express';\nimport log from './logger';\nimport { inspect } from 'util';\nconst Layer = require('express/lib/router/layer');\n\nfunction validateParameter(key, value) {\n  if (key == 'className') {\n    if (value.match(/_?[A-Za-z][A-Za-z_0-9]*/)) {\n      return value;\n    }\n  } else if (key == 'objectId') {\n    if (value.match(/[A-Za-z0-9]+/)) {\n      return value;\n    }\n  } else {\n    return value;\n  }\n}\n\nexport default class PromiseRouter {\n  // Each entry should be an object with:\n  // path: the path to route, in express format\n  // method: the HTTP method that this route handles.\n  //   Must be one of: POST, GET, PUT, DELETE\n  // handler: a function that takes request, and returns a promise.\n  //   Successful handlers should resolve to an object with fields:\n  //     status: optional. the http status code. defaults to 200\n  //     response: a json object with the content of the response\n  //     location: optional. a location header\n  constructor(routes = [], appId) {\n    this.routes = routes;\n    this.appId = appId;\n    this.mountRoutes();\n  }\n\n  // Leave the opportunity to\n  // subclasses to mount their routes by overriding\n  mountRoutes() {}\n\n  // Merge the routes into this one\n  merge(router) {\n    for (var route of router.routes) {\n      this.routes.push(route);\n    }\n  }\n\n  route(method, path, ...handlers) {\n    switch (method) {\n      case 'POST':\n      case 'GET':\n      case 'PUT':\n      case 'DELETE':\n        break;\n      default:\n        throw 'cannot route method: ' + method;\n    }\n\n    let handler = handlers[0];\n\n    if (handlers.length > 1) {\n      handler = function (req) {\n        return handlers.reduce((promise, handler) => {\n          return promise.then(() => {\n            return handler(req);\n          });\n        }, Promise.resolve());\n      };\n    }\n\n    this.routes.push({\n      path: path,\n      method: method,\n      handler: handler,\n      layer: new Layer(path, null, handler),\n    });\n  }\n\n  // Returns an object with:\n  //   handler: the handler that should deal with this request\n  //   params: any :-params that got parsed from the path\n  // Returns undefined if there is no match.\n  match(method, path) {\n    for (var route of this.routes) {\n      if (route.method != method) {\n        continue;\n      }\n      const layer = route.layer || new Layer(route.path, null, route.handler);\n      const match = layer.match(path);\n      if (match) {\n        const params = layer.params;\n        Object.keys(params).forEach(key => {\n          params[key] = validateParameter(key, params[key]);\n        });\n        return { params: params, handler: route.handler };\n      }\n    }\n  }\n\n  // Mount the routes on this router onto an express app (or express router)\n  mountOnto(expressApp) {\n    this.routes.forEach(route => {\n      const method = route.method.toLowerCase();\n      const handler = makeExpressHandler(this.appId, route.handler);\n      expressApp[method].call(expressApp, route.path, handler);\n    });\n    return expressApp;\n  }\n\n  expressRouter() {\n    return this.mountOnto(express.Router());\n  }\n\n  tryRouteRequest(method, path, request) {\n    var match = this.match(method, path);\n    if (!match) {\n      throw new Parse.Error(Parse.Error.INVALID_JSON, 'cannot route ' + method + ' ' + path);\n    }\n    request.params = match.params;\n    return new Promise((resolve, reject) => {\n      match.handler(request).then(resolve, reject);\n    });\n  }\n}\n\n// A helper function to make an express handler out of a a promise\n// handler.\n// Express handlers should never throw; if a promise handler throws we\n// just treat it like it resolved to an error.\nfunction makeExpressHandler(appId, promiseHandler) {\n  return function (req, res, next) {\n    try {\n      const url = maskSensitiveUrl(req);\n      const body = Object.assign({}, req.body);\n      const method = req.method;\n      const headers = req.headers;\n      log.logRequest({\n        method,\n        url,\n        headers,\n        body,\n      });\n      promiseHandler(req)\n        .then(\n          result => {\n            if (!result.response && !result.location && !result.text) {\n              log.error('the handler did not include a \"response\" or a \"location\" field');\n              throw 'control should not get here';\n            }\n\n            log.logResponse({ method, url, result });\n\n            var status = result.status || 200;\n            res.status(status);\n\n            if (result.headers) {\n              Object.keys(result.headers).forEach(header => {\n                res.set(header, result.headers[header]);\n              });\n            }\n\n            if (result.text) {\n              res.send(result.text);\n              return;\n            }\n\n            if (result.location) {\n              res.set('Location', result.location);\n              // Override the default expressjs response\n              // as it double encodes %encoded chars in URL\n              if (!result.response) {\n                res.send('Found. Redirecting to ' + result.location);\n                return;\n              }\n            }\n            res.json(result.response);\n          },\n          error => {\n            next(error);\n          }\n        )\n        .catch(e => {\n          log.error(`Error generating response. ${inspect(e)}`, { error: e });\n          next(e);\n        });\n    } catch (e) {\n      log.error(`Error handling request: ${inspect(e)}`, { error: e });\n      next(e);\n    }\n  };\n}\n\nfunction maskSensitiveUrl(req) {\n  let maskUrl = req.originalUrl.toString();\n  const shouldMaskUrl =\n    req.method === 'GET' &&\n    req.originalUrl.includes('/login') &&\n    !req.originalUrl.includes('classes');\n  if (shouldMaskUrl) {\n    maskUrl = log.maskSensitiveUrl(maskUrl);\n  }\n  return maskUrl;\n}\n"],"mappings":"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"}
@@ -4,20 +4,13 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.PushQueue = void 0;
7
-
8
7
  var _ParseMessageQueue = require("../ParseMessageQueue");
9
-
10
8
  var _rest = _interopRequireDefault(require("../rest"));
11
-
12
9
  var _utils = require("./utils");
13
-
14
10
  var _node = _interopRequireDefault(require("parse/node"));
15
-
16
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
-
18
12
  const PUSH_CHANNEL = 'parse-server-push';
19
13
  const DEFAULT_BATCH_SIZE = 100;
20
-
21
14
  class PushQueue {
22
15
  // config object of the publisher, right now it only contains the redisURL,
23
16
  // but we may extend it later.
@@ -26,15 +19,14 @@ class PushQueue {
26
19
  this.batchSize = config.batchSize || DEFAULT_BATCH_SIZE;
27
20
  this.parsePublisher = _ParseMessageQueue.ParseMessageQueue.createPublisher(config);
28
21
  }
29
-
30
22
  static defaultPushChannel() {
31
23
  return `${_node.default.applicationId}-${PUSH_CHANNEL}`;
32
24
  }
33
-
34
25
  enqueue(body, where, config, auth, pushStatus) {
35
26
  const limit = this.batchSize;
36
- where = (0, _utils.applyDeviceTokenExists)(where); // Order by objectId so no impact on the DB
27
+ where = (0, _utils.applyDeviceTokenExists)(where);
37
28
 
29
+ // Order by objectId so no impact on the DB
38
30
  const order = 'objectId';
39
31
  return Promise.resolve().then(() => {
40
32
  return _rest.default.find(config, auth, '_Installation', where, {
@@ -48,10 +40,8 @@ class PushQueue {
48
40
  if (!results || count == 0) {
49
41
  return pushStatus.complete();
50
42
  }
51
-
52
43
  pushStatus.setRunning(Math.ceil(count / limit));
53
44
  let skip = 0;
54
-
55
45
  while (skip < count) {
56
46
  const query = {
57
47
  where,
@@ -72,8 +62,6 @@ class PushQueue {
72
62
  }
73
63
  });
74
64
  }
75
-
76
65
  }
77
-
78
66
  exports.PushQueue = PushQueue;
79
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9QdXNoL1B1c2hRdWV1ZS5qcyJdLCJuYW1lcyI6WyJQVVNIX0NIQU5ORUwiLCJERUZBVUxUX0JBVENIX1NJWkUiLCJQdXNoUXVldWUiLCJjb25zdHJ1Y3RvciIsImNvbmZpZyIsImNoYW5uZWwiLCJkZWZhdWx0UHVzaENoYW5uZWwiLCJiYXRjaFNpemUiLCJwYXJzZVB1Ymxpc2hlciIsIlBhcnNlTWVzc2FnZVF1ZXVlIiwiY3JlYXRlUHVibGlzaGVyIiwiUGFyc2UiLCJhcHBsaWNhdGlvbklkIiwiZW5xdWV1ZSIsImJvZHkiLCJ3aGVyZSIsImF1dGgiLCJwdXNoU3RhdHVzIiwibGltaXQiLCJvcmRlciIsIlByb21pc2UiLCJyZXNvbHZlIiwidGhlbiIsInJlc3QiLCJmaW5kIiwiY291bnQiLCJyZXN1bHRzIiwiY29tcGxldGUiLCJzZXRSdW5uaW5nIiwiTWF0aCIsImNlaWwiLCJza2lwIiwicXVlcnkiLCJwdXNoV29ya0l0ZW0iLCJvYmplY3RJZCIsInB1Ymxpc2giLCJKU09OIiwic3RyaW5naWZ5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFFQSxNQUFNQSxZQUFZLEdBQUcsbUJBQXJCO0FBQ0EsTUFBTUMsa0JBQWtCLEdBQUcsR0FBM0I7O0FBRU8sTUFBTUMsU0FBTixDQUFnQjtBQUtyQjtBQUNBO0FBQ0FDLEVBQUFBLFdBQVcsQ0FBQ0MsTUFBVyxHQUFHLEVBQWYsRUFBbUI7QUFDNUIsU0FBS0MsT0FBTCxHQUFlRCxNQUFNLENBQUNDLE9BQVAsSUFBa0JILFNBQVMsQ0FBQ0ksa0JBQVYsRUFBakM7QUFDQSxTQUFLQyxTQUFMLEdBQWlCSCxNQUFNLENBQUNHLFNBQVAsSUFBb0JOLGtCQUFyQztBQUNBLFNBQUtPLGNBQUwsR0FBc0JDLHFDQUFrQkMsZUFBbEIsQ0FBa0NOLE1BQWxDLENBQXRCO0FBQ0Q7O0FBRXdCLFNBQWxCRSxrQkFBa0IsR0FBRztBQUMxQixXQUFRLEdBQUVLLGNBQU1DLGFBQWMsSUFBR1osWUFBYSxFQUE5QztBQUNEOztBQUVEYSxFQUFBQSxPQUFPLENBQUNDLElBQUQsRUFBT0MsS0FBUCxFQUFjWCxNQUFkLEVBQXNCWSxJQUF0QixFQUE0QkMsVUFBNUIsRUFBd0M7QUFDN0MsVUFBTUMsS0FBSyxHQUFHLEtBQUtYLFNBQW5CO0FBRUFRLElBQUFBLEtBQUssR0FBRyxtQ0FBdUJBLEtBQXZCLENBQVIsQ0FINkMsQ0FLN0M7O0FBQ0EsVUFBTUksS0FBSyxHQUFHLFVBQWQ7QUFDQSxXQUFPQyxPQUFPLENBQUNDLE9BQVIsR0FDSkMsSUFESSxDQUNDLE1BQU07QUFDVixhQUFPQyxjQUFLQyxJQUFMLENBQVVwQixNQUFWLEVBQWtCWSxJQUFsQixFQUF3QixlQUF4QixFQUF5Q0QsS0FBekMsRUFBZ0Q7QUFDckRHLFFBQUFBLEtBQUssRUFBRSxDQUQ4QztBQUVyRE8sUUFBQUEsS0FBSyxFQUFFO0FBRjhDLE9BQWhELENBQVA7QUFJRCxLQU5JLEVBT0pILElBUEksQ0FPQyxDQUFDO0FBQUVJLE1BQUFBLE9BQUY7QUFBV0QsTUFBQUE7QUFBWCxLQUFELEtBQXdCO0FBQzVCLFVBQUksQ0FBQ0MsT0FBRCxJQUFZRCxLQUFLLElBQUksQ0FBekIsRUFBNEI7QUFDMUIsZUFBT1IsVUFBVSxDQUFDVSxRQUFYLEVBQVA7QUFDRDs7QUFDRFYsTUFBQUEsVUFBVSxDQUFDVyxVQUFYLENBQXNCQyxJQUFJLENBQUNDLElBQUwsQ0FBVUwsS0FBSyxHQUFHUCxLQUFsQixDQUF0QjtBQUNBLFVBQUlhLElBQUksR0FBRyxDQUFYOztBQUNBLGFBQU9BLElBQUksR0FBR04sS0FBZCxFQUFxQjtBQUNuQixjQUFNTyxLQUFLLEdBQUc7QUFDWmpCLFVBQUFBLEtBRFk7QUFFWkcsVUFBQUEsS0FGWTtBQUdaYSxVQUFBQSxJQUhZO0FBSVpaLFVBQUFBO0FBSlksU0FBZDtBQU9BLGNBQU1jLFlBQVksR0FBRztBQUNuQm5CLFVBQUFBLElBRG1CO0FBRW5Ca0IsVUFBQUEsS0FGbUI7QUFHbkJmLFVBQUFBLFVBQVUsRUFBRTtBQUFFaUIsWUFBQUEsUUFBUSxFQUFFakIsVUFBVSxDQUFDaUI7QUFBdkIsV0FITztBQUluQnRCLFVBQUFBLGFBQWEsRUFBRVIsTUFBTSxDQUFDUTtBQUpILFNBQXJCO0FBTUEsYUFBS0osY0FBTCxDQUFvQjJCLE9BQXBCLENBQTRCLEtBQUs5QixPQUFqQyxFQUEwQytCLElBQUksQ0FBQ0MsU0FBTCxDQUFlSixZQUFmLENBQTFDO0FBQ0FGLFFBQUFBLElBQUksSUFBSWIsS0FBUjtBQUNEO0FBQ0YsS0E5QkksQ0FBUDtBQStCRDs7QUF2RG9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGFyc2VNZXNzYWdlUXVldWUgfSBmcm9tICcuLi9QYXJzZU1lc3NhZ2VRdWV1ZSc7XG5pbXBvcnQgcmVzdCBmcm9tICcuLi9yZXN0JztcbmltcG9ydCB7IGFwcGx5RGV2aWNlVG9rZW5FeGlzdHMgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCBQYXJzZSBmcm9tICdwYXJzZS9ub2RlJztcblxuY29uc3QgUFVTSF9DSEFOTkVMID0gJ3BhcnNlLXNlcnZlci1wdXNoJztcbmNvbnN0IERFRkFVTFRfQkFUQ0hfU0laRSA9IDEwMDtcblxuZXhwb3J0IGNsYXNzIFB1c2hRdWV1ZSB7XG4gIHBhcnNlUHVibGlzaGVyOiBPYmplY3Q7XG4gIGNoYW5uZWw6IFN0cmluZztcbiAgYmF0Y2hTaXplOiBOdW1iZXI7XG5cbiAgLy8gY29uZmlnIG9iamVjdCBvZiB0aGUgcHVibGlzaGVyLCByaWdodCBub3cgaXQgb25seSBjb250YWlucyB0aGUgcmVkaXNVUkwsXG4gIC8vIGJ1dCB3ZSBtYXkgZXh0ZW5kIGl0IGxhdGVyLlxuICBjb25zdHJ1Y3Rvcihjb25maWc6IGFueSA9IHt9KSB7XG4gICAgdGhpcy5jaGFubmVsID0gY29uZmlnLmNoYW5uZWwgfHwgUHVzaFF1ZXVlLmRlZmF1bHRQdXNoQ2hhbm5lbCgpO1xuICAgIHRoaXMuYmF0Y2hTaXplID0gY29uZmlnLmJhdGNoU2l6ZSB8fCBERUZBVUxUX0JBVENIX1NJWkU7XG4gICAgdGhpcy5wYXJzZVB1Ymxpc2hlciA9IFBhcnNlTWVzc2FnZVF1ZXVlLmNyZWF0ZVB1Ymxpc2hlcihjb25maWcpO1xuICB9XG5cbiAgc3RhdGljIGRlZmF1bHRQdXNoQ2hhbm5lbCgpIHtcbiAgICByZXR1cm4gYCR7UGFyc2UuYXBwbGljYXRpb25JZH0tJHtQVVNIX0NIQU5ORUx9YDtcbiAgfVxuXG4gIGVucXVldWUoYm9keSwgd2hlcmUsIGNvbmZpZywgYXV0aCwgcHVzaFN0YXR1cykge1xuICAgIGNvbnN0IGxpbWl0ID0gdGhpcy5iYXRjaFNpemU7XG5cbiAgICB3aGVyZSA9IGFwcGx5RGV2aWNlVG9rZW5FeGlzdHMod2hlcmUpO1xuXG4gICAgLy8gT3JkZXIgYnkgb2JqZWN0SWQgc28gbm8gaW1wYWN0IG9uIHRoZSBEQlxuICAgIGNvbnN0IG9yZGVyID0gJ29iamVjdElkJztcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKClcbiAgICAgIC50aGVuKCgpID0+IHtcbiAgICAgICAgcmV0dXJuIHJlc3QuZmluZChjb25maWcsIGF1dGgsICdfSW5zdGFsbGF0aW9uJywgd2hlcmUsIHtcbiAgICAgICAgICBsaW1pdDogMCxcbiAgICAgICAgICBjb3VudDogdHJ1ZSxcbiAgICAgICAgfSk7XG4gICAgICB9KVxuICAgICAgLnRoZW4oKHsgcmVzdWx0cywgY291bnQgfSkgPT4ge1xuICAgICAgICBpZiAoIXJlc3VsdHMgfHwgY291bnQgPT0gMCkge1xuICAgICAgICAgIHJldHVybiBwdXNoU3RhdHVzLmNvbXBsZXRlKCk7XG4gICAgICAgIH1cbiAgICAgICAgcHVzaFN0YXR1cy5zZXRSdW5uaW5nKE1hdGguY2VpbChjb3VudCAvIGxpbWl0KSk7XG4gICAgICAgIGxldCBza2lwID0gMDtcbiAgICAgICAgd2hpbGUgKHNraXAgPCBjb3VudCkge1xuICAgICAgICAgIGNvbnN0IHF1ZXJ5ID0ge1xuICAgICAgICAgICAgd2hlcmUsXG4gICAgICAgICAgICBsaW1pdCxcbiAgICAgICAgICAgIHNraXAsXG4gICAgICAgICAgICBvcmRlcixcbiAgICAgICAgICB9O1xuXG4gICAgICAgICAgY29uc3QgcHVzaFdvcmtJdGVtID0ge1xuICAgICAgICAgICAgYm9keSxcbiAgICAgICAgICAgIHF1ZXJ5LFxuICAgICAgICAgICAgcHVzaFN0YXR1czogeyBvYmplY3RJZDogcHVzaFN0YXR1cy5vYmplY3RJZCB9LFxuICAgICAgICAgICAgYXBwbGljYXRpb25JZDogY29uZmlnLmFwcGxpY2F0aW9uSWQsXG4gICAgICAgICAgfTtcbiAgICAgICAgICB0aGlzLnBhcnNlUHVibGlzaGVyLnB1Ymxpc2godGhpcy5jaGFubmVsLCBKU09OLnN0cmluZ2lmeShwdXNoV29ya0l0ZW0pKTtcbiAgICAgICAgICBza2lwICs9IGxpbWl0O1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgfVxufVxuIl19
67
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQVVNIX0NIQU5ORUwiLCJERUZBVUxUX0JBVENIX1NJWkUiLCJQdXNoUXVldWUiLCJjb25zdHJ1Y3RvciIsImNvbmZpZyIsImNoYW5uZWwiLCJkZWZhdWx0UHVzaENoYW5uZWwiLCJiYXRjaFNpemUiLCJwYXJzZVB1Ymxpc2hlciIsIlBhcnNlTWVzc2FnZVF1ZXVlIiwiY3JlYXRlUHVibGlzaGVyIiwiUGFyc2UiLCJhcHBsaWNhdGlvbklkIiwiZW5xdWV1ZSIsImJvZHkiLCJ3aGVyZSIsImF1dGgiLCJwdXNoU3RhdHVzIiwibGltaXQiLCJhcHBseURldmljZVRva2VuRXhpc3RzIiwib3JkZXIiLCJQcm9taXNlIiwicmVzb2x2ZSIsInRoZW4iLCJyZXN0IiwiZmluZCIsImNvdW50IiwicmVzdWx0cyIsImNvbXBsZXRlIiwic2V0UnVubmluZyIsIk1hdGgiLCJjZWlsIiwic2tpcCIsInF1ZXJ5IiwicHVzaFdvcmtJdGVtIiwib2JqZWN0SWQiLCJwdWJsaXNoIiwiSlNPTiIsInN0cmluZ2lmeSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9QdXNoL1B1c2hRdWV1ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYXJzZU1lc3NhZ2VRdWV1ZSB9IGZyb20gJy4uL1BhcnNlTWVzc2FnZVF1ZXVlJztcbmltcG9ydCByZXN0IGZyb20gJy4uL3Jlc3QnO1xuaW1wb3J0IHsgYXBwbHlEZXZpY2VUb2tlbkV4aXN0cyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IFBhcnNlIGZyb20gJ3BhcnNlL25vZGUnO1xuXG5jb25zdCBQVVNIX0NIQU5ORUwgPSAncGFyc2Utc2VydmVyLXB1c2gnO1xuY29uc3QgREVGQVVMVF9CQVRDSF9TSVpFID0gMTAwO1xuXG5leHBvcnQgY2xhc3MgUHVzaFF1ZXVlIHtcbiAgcGFyc2VQdWJsaXNoZXI6IE9iamVjdDtcbiAgY2hhbm5lbDogU3RyaW5nO1xuICBiYXRjaFNpemU6IE51bWJlcjtcblxuICAvLyBjb25maWcgb2JqZWN0IG9mIHRoZSBwdWJsaXNoZXIsIHJpZ2h0IG5vdyBpdCBvbmx5IGNvbnRhaW5zIHRoZSByZWRpc1VSTCxcbiAgLy8gYnV0IHdlIG1heSBleHRlbmQgaXQgbGF0ZXIuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogYW55ID0ge30pIHtcbiAgICB0aGlzLmNoYW5uZWwgPSBjb25maWcuY2hhbm5lbCB8fCBQdXNoUXVldWUuZGVmYXVsdFB1c2hDaGFubmVsKCk7XG4gICAgdGhpcy5iYXRjaFNpemUgPSBjb25maWcuYmF0Y2hTaXplIHx8IERFRkFVTFRfQkFUQ0hfU0laRTtcbiAgICB0aGlzLnBhcnNlUHVibGlzaGVyID0gUGFyc2VNZXNzYWdlUXVldWUuY3JlYXRlUHVibGlzaGVyKGNvbmZpZyk7XG4gIH1cblxuICBzdGF0aWMgZGVmYXVsdFB1c2hDaGFubmVsKCkge1xuICAgIHJldHVybiBgJHtQYXJzZS5hcHBsaWNhdGlvbklkfS0ke1BVU0hfQ0hBTk5FTH1gO1xuICB9XG5cbiAgZW5xdWV1ZShib2R5LCB3aGVyZSwgY29uZmlnLCBhdXRoLCBwdXNoU3RhdHVzKSB7XG4gICAgY29uc3QgbGltaXQgPSB0aGlzLmJhdGNoU2l6ZTtcblxuICAgIHdoZXJlID0gYXBwbHlEZXZpY2VUb2tlbkV4aXN0cyh3aGVyZSk7XG5cbiAgICAvLyBPcmRlciBieSBvYmplY3RJZCBzbyBubyBpbXBhY3Qgb24gdGhlIERCXG4gICAgY29uc3Qgb3JkZXIgPSAnb2JqZWN0SWQnO1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKVxuICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICByZXR1cm4gcmVzdC5maW5kKGNvbmZpZywgYXV0aCwgJ19JbnN0YWxsYXRpb24nLCB3aGVyZSwge1xuICAgICAgICAgIGxpbWl0OiAwLFxuICAgICAgICAgIGNvdW50OiB0cnVlLFxuICAgICAgICB9KTtcbiAgICAgIH0pXG4gICAgICAudGhlbigoeyByZXN1bHRzLCBjb3VudCB9KSA9PiB7XG4gICAgICAgIGlmICghcmVzdWx0cyB8fCBjb3VudCA9PSAwKSB7XG4gICAgICAgICAgcmV0dXJuIHB1c2hTdGF0dXMuY29tcGxldGUoKTtcbiAgICAgICAgfVxuICAgICAgICBwdXNoU3RhdHVzLnNldFJ1bm5pbmcoTWF0aC5jZWlsKGNvdW50IC8gbGltaXQpKTtcbiAgICAgICAgbGV0IHNraXAgPSAwO1xuICAgICAgICB3aGlsZSAoc2tpcCA8IGNvdW50KSB7XG4gICAgICAgICAgY29uc3QgcXVlcnkgPSB7XG4gICAgICAgICAgICB3aGVyZSxcbiAgICAgICAgICAgIGxpbWl0LFxuICAgICAgICAgICAgc2tpcCxcbiAgICAgICAgICAgIG9yZGVyLFxuICAgICAgICAgIH07XG5cbiAgICAgICAgICBjb25zdCBwdXNoV29ya0l0ZW0gPSB7XG4gICAgICAgICAgICBib2R5LFxuICAgICAgICAgICAgcXVlcnksXG4gICAgICAgICAgICBwdXNoU3RhdHVzOiB7IG9iamVjdElkOiBwdXNoU3RhdHVzLm9iamVjdElkIH0sXG4gICAgICAgICAgICBhcHBsaWNhdGlvbklkOiBjb25maWcuYXBwbGljYXRpb25JZCxcbiAgICAgICAgICB9O1xuICAgICAgICAgIHRoaXMucGFyc2VQdWJsaXNoZXIucHVibGlzaCh0aGlzLmNoYW5uZWwsIEpTT04uc3RyaW5naWZ5KHB1c2hXb3JrSXRlbSkpO1xuICAgICAgICAgIHNraXAgKz0gbGltaXQ7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQStCO0FBRS9CLE1BQU1BLFlBQVksR0FBRyxtQkFBbUI7QUFDeEMsTUFBTUMsa0JBQWtCLEdBQUcsR0FBRztBQUV2QixNQUFNQyxTQUFTLENBQUM7RUFLckI7RUFDQTtFQUNBQyxXQUFXLENBQUNDLE1BQVcsR0FBRyxDQUFDLENBQUMsRUFBRTtJQUM1QixJQUFJLENBQUNDLE9BQU8sR0FBR0QsTUFBTSxDQUFDQyxPQUFPLElBQUlILFNBQVMsQ0FBQ0ksa0JBQWtCLEVBQUU7SUFDL0QsSUFBSSxDQUFDQyxTQUFTLEdBQUdILE1BQU0sQ0FBQ0csU0FBUyxJQUFJTixrQkFBa0I7SUFDdkQsSUFBSSxDQUFDTyxjQUFjLEdBQUdDLG9DQUFpQixDQUFDQyxlQUFlLENBQUNOLE1BQU0sQ0FBQztFQUNqRTtFQUVBLE9BQU9FLGtCQUFrQixHQUFHO0lBQzFCLE9BQVEsR0FBRUssYUFBSyxDQUFDQyxhQUFjLElBQUdaLFlBQWEsRUFBQztFQUNqRDtFQUVBYSxPQUFPLENBQUNDLElBQUksRUFBRUMsS0FBSyxFQUFFWCxNQUFNLEVBQUVZLElBQUksRUFBRUMsVUFBVSxFQUFFO0lBQzdDLE1BQU1DLEtBQUssR0FBRyxJQUFJLENBQUNYLFNBQVM7SUFFNUJRLEtBQUssR0FBRyxJQUFBSSw2QkFBc0IsRUFBQ0osS0FBSyxDQUFDOztJQUVyQztJQUNBLE1BQU1LLEtBQUssR0FBRyxVQUFVO0lBQ3hCLE9BQU9DLE9BQU8sQ0FBQ0MsT0FBTyxFQUFFLENBQ3JCQyxJQUFJLENBQUMsTUFBTTtNQUNWLE9BQU9DLGFBQUksQ0FBQ0MsSUFBSSxDQUFDckIsTUFBTSxFQUFFWSxJQUFJLEVBQUUsZUFBZSxFQUFFRCxLQUFLLEVBQUU7UUFDckRHLEtBQUssRUFBRSxDQUFDO1FBQ1JRLEtBQUssRUFBRTtNQUNULENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQyxDQUNESCxJQUFJLENBQUMsQ0FBQztNQUFFSSxPQUFPO01BQUVEO0lBQU0sQ0FBQyxLQUFLO01BQzVCLElBQUksQ0FBQ0MsT0FBTyxJQUFJRCxLQUFLLElBQUksQ0FBQyxFQUFFO1FBQzFCLE9BQU9ULFVBQVUsQ0FBQ1csUUFBUSxFQUFFO01BQzlCO01BQ0FYLFVBQVUsQ0FBQ1ksVUFBVSxDQUFDQyxJQUFJLENBQUNDLElBQUksQ0FBQ0wsS0FBSyxHQUFHUixLQUFLLENBQUMsQ0FBQztNQUMvQyxJQUFJYyxJQUFJLEdBQUcsQ0FBQztNQUNaLE9BQU9BLElBQUksR0FBR04sS0FBSyxFQUFFO1FBQ25CLE1BQU1PLEtBQUssR0FBRztVQUNabEIsS0FBSztVQUNMRyxLQUFLO1VBQ0xjLElBQUk7VUFDSlo7UUFDRixDQUFDO1FBRUQsTUFBTWMsWUFBWSxHQUFHO1VBQ25CcEIsSUFBSTtVQUNKbUIsS0FBSztVQUNMaEIsVUFBVSxFQUFFO1lBQUVrQixRQUFRLEVBQUVsQixVQUFVLENBQUNrQjtVQUFTLENBQUM7VUFDN0N2QixhQUFhLEVBQUVSLE1BQU0sQ0FBQ1E7UUFDeEIsQ0FBQztRQUNELElBQUksQ0FBQ0osY0FBYyxDQUFDNEIsT0FBTyxDQUFDLElBQUksQ0FBQy9CLE9BQU8sRUFBRWdDLElBQUksQ0FBQ0MsU0FBUyxDQUFDSixZQUFZLENBQUMsQ0FBQztRQUN2RUYsSUFBSSxJQUFJZCxLQUFLO01BQ2Y7SUFDRixDQUFDLENBQUM7RUFDTjtBQUNGO0FBQUMifQ==