index.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.getAnalyticsController = getAnalyticsController;
  6. exports.getAuthDataManager = getAuthDataManager;
  7. exports.getCacheController = getCacheController;
  8. exports.getControllers = getControllers;
  9. exports.getDatabaseAdapter = getDatabaseAdapter;
  10. exports.getDatabaseController = getDatabaseController;
  11. exports.getFilesController = getFilesController;
  12. exports.getHooksController = getHooksController;
  13. exports.getLiveQueryController = getLiveQueryController;
  14. exports.getLoggerController = getLoggerController;
  15. exports.getParseGraphQLController = getParseGraphQLController;
  16. exports.getPushController = getPushController;
  17. exports.getUserController = getUserController;
  18. var _Auth = _interopRequireDefault(require("../Adapters/Auth"));
  19. var _Options = require("../Options");
  20. var _AdapterLoader = require("../Adapters/AdapterLoader");
  21. var _defaults = _interopRequireDefault(require("../defaults"));
  22. var _LoggerController = require("./LoggerController");
  23. var _FilesController = require("./FilesController");
  24. var _HooksController = require("./HooksController");
  25. var _UserController = require("./UserController");
  26. var _CacheController = require("./CacheController");
  27. var _LiveQueryController = require("./LiveQueryController");
  28. var _AnalyticsController = require("./AnalyticsController");
  29. var _PushController = require("./PushController");
  30. var _PushQueue = require("../Push/PushQueue");
  31. var _PushWorker = require("../Push/PushWorker");
  32. var _DatabaseController = _interopRequireDefault(require("./DatabaseController"));
  33. var _GridFSBucketAdapter = require("../Adapters/Files/GridFSBucketAdapter");
  34. var _WinstonLoggerAdapter = require("../Adapters/Logger/WinstonLoggerAdapter");
  35. var _InMemoryCacheAdapter = require("../Adapters/Cache/InMemoryCacheAdapter");
  36. var _AnalyticsAdapter = require("../Adapters/Analytics/AnalyticsAdapter");
  37. var _MongoStorageAdapter = _interopRequireDefault(require("../Adapters/Storage/Mongo/MongoStorageAdapter"));
  38. var _PostgresStorageAdapter = _interopRequireDefault(require("../Adapters/Storage/Postgres/PostgresStorageAdapter"));
  39. var _ParseGraphQLController = _interopRequireDefault(require("./ParseGraphQLController"));
  40. var _SchemaCache = _interopRequireDefault(require("../Adapters/Cache/SchemaCache"));
  41. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  42. function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
  43. function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
  44. function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
  45. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
  46. function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } // Controllers
  47. // Adapters
  48. function getControllers(options) {
  49. const loggerController = getLoggerController(options);
  50. const filesController = getFilesController(options);
  51. const userController = getUserController(options);
  52. const cacheController = getCacheController(options);
  53. const analyticsController = getAnalyticsController(options);
  54. const liveQueryController = getLiveQueryController(options);
  55. const databaseController = getDatabaseController(options);
  56. const hooksController = getHooksController(options, databaseController);
  57. const authDataManager = getAuthDataManager(options);
  58. const parseGraphQLController = getParseGraphQLController(options, {
  59. databaseController,
  60. cacheController
  61. });
  62. return {
  63. loggerController,
  64. filesController,
  65. userController,
  66. analyticsController,
  67. cacheController,
  68. parseGraphQLController,
  69. liveQueryController,
  70. databaseController,
  71. hooksController,
  72. authDataManager,
  73. schemaCache: _SchemaCache.default
  74. };
  75. }
  76. function getLoggerController(options) {
  77. const {
  78. appId,
  79. jsonLogs,
  80. logsFolder,
  81. verbose,
  82. logLevel,
  83. maxLogFiles,
  84. silent,
  85. loggerAdapter
  86. } = options;
  87. const loggerOptions = {
  88. jsonLogs,
  89. logsFolder,
  90. verbose,
  91. logLevel,
  92. silent,
  93. maxLogFiles
  94. };
  95. const loggerControllerAdapter = (0, _AdapterLoader.loadAdapter)(loggerAdapter, _WinstonLoggerAdapter.WinstonLoggerAdapter, loggerOptions);
  96. return new _LoggerController.LoggerController(loggerControllerAdapter, appId, loggerOptions);
  97. }
  98. function getFilesController(options) {
  99. const {
  100. appId,
  101. databaseURI,
  102. databaseOptions = {},
  103. filesAdapter,
  104. databaseAdapter,
  105. preserveFileName,
  106. fileKey
  107. } = options;
  108. if (!filesAdapter && databaseAdapter) {
  109. throw 'When using an explicit database adapter, you must also use an explicit filesAdapter.';
  110. }
  111. const filesControllerAdapter = (0, _AdapterLoader.loadAdapter)(filesAdapter, () => {
  112. return new _GridFSBucketAdapter.GridFSBucketAdapter(databaseURI, databaseOptions, fileKey);
  113. });
  114. return new _FilesController.FilesController(filesControllerAdapter, appId, {
  115. preserveFileName
  116. });
  117. }
  118. function getUserController(options) {
  119. const {
  120. appId,
  121. emailAdapter,
  122. verifyUserEmails
  123. } = options;
  124. const emailControllerAdapter = (0, _AdapterLoader.loadAdapter)(emailAdapter);
  125. return new _UserController.UserController(emailControllerAdapter, appId, {
  126. verifyUserEmails
  127. });
  128. }
  129. function getCacheController(options) {
  130. const {
  131. appId,
  132. cacheAdapter,
  133. cacheTTL,
  134. cacheMaxSize
  135. } = options;
  136. const cacheControllerAdapter = (0, _AdapterLoader.loadAdapter)(cacheAdapter, _InMemoryCacheAdapter.InMemoryCacheAdapter, {
  137. appId: appId,
  138. ttl: cacheTTL,
  139. maxSize: cacheMaxSize
  140. });
  141. return new _CacheController.CacheController(cacheControllerAdapter, appId);
  142. }
  143. function getParseGraphQLController(options, controllerDeps) {
  144. return new _ParseGraphQLController.default(_objectSpread({
  145. mountGraphQL: options.mountGraphQL
  146. }, controllerDeps));
  147. }
  148. function getAnalyticsController(options) {
  149. const {
  150. analyticsAdapter
  151. } = options;
  152. const analyticsControllerAdapter = (0, _AdapterLoader.loadAdapter)(analyticsAdapter, _AnalyticsAdapter.AnalyticsAdapter);
  153. return new _AnalyticsController.AnalyticsController(analyticsControllerAdapter);
  154. }
  155. function getLiveQueryController(options) {
  156. return new _LiveQueryController.LiveQueryController(options.liveQuery);
  157. }
  158. function getDatabaseController(options) {
  159. const {
  160. databaseURI,
  161. collectionPrefix,
  162. databaseOptions
  163. } = options;
  164. let {
  165. databaseAdapter
  166. } = options;
  167. if ((databaseOptions || databaseURI && databaseURI !== _defaults.default.databaseURI || collectionPrefix !== _defaults.default.collectionPrefix) && databaseAdapter) {
  168. throw 'You cannot specify both a databaseAdapter and a databaseURI/databaseOptions/collectionPrefix.';
  169. } else if (!databaseAdapter) {
  170. databaseAdapter = getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions);
  171. } else {
  172. databaseAdapter = (0, _AdapterLoader.loadAdapter)(databaseAdapter);
  173. }
  174. return new _DatabaseController.default(databaseAdapter, options);
  175. }
  176. function getHooksController(options, databaseController) {
  177. const {
  178. appId,
  179. webhookKey
  180. } = options;
  181. return new _HooksController.HooksController(appId, databaseController, webhookKey);
  182. }
  183. async function getPushController(options) {
  184. const {
  185. scheduledPush,
  186. push
  187. } = options;
  188. const pushOptions = Object.assign({}, push);
  189. const pushQueueOptions = pushOptions.queueOptions || {};
  190. if (pushOptions.queueOptions) {
  191. delete pushOptions.queueOptions;
  192. }
  193. // Pass the push options too as it works with the default
  194. const ParsePushAdapter = await (0, _AdapterLoader.loadModule)('@parse/push-adapter');
  195. const pushAdapter = (0, _AdapterLoader.loadAdapter)(pushOptions && pushOptions.adapter, ParsePushAdapter, pushOptions);
  196. // We pass the options and the base class for the adatper,
  197. // Note that passing an instance would work too
  198. const pushController = new _PushController.PushController();
  199. const hasPushSupport = !!(pushAdapter && push);
  200. const hasPushScheduledSupport = hasPushSupport && scheduledPush === true;
  201. const {
  202. disablePushWorker
  203. } = pushQueueOptions;
  204. const pushControllerQueue = new _PushQueue.PushQueue(pushQueueOptions);
  205. let pushWorker;
  206. if (!disablePushWorker) {
  207. pushWorker = new _PushWorker.PushWorker(pushAdapter, pushQueueOptions);
  208. }
  209. return {
  210. pushController,
  211. hasPushSupport,
  212. hasPushScheduledSupport,
  213. pushControllerQueue,
  214. pushWorker
  215. };
  216. }
  217. function getAuthDataManager(options) {
  218. const {
  219. auth,
  220. enableAnonymousUsers
  221. } = options;
  222. return (0, _Auth.default)(auth, enableAnonymousUsers);
  223. }
  224. function getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions) {
  225. let protocol;
  226. try {
  227. const parsedURI = new URL(databaseURI);
  228. protocol = parsedURI.protocol ? parsedURI.protocol.toLowerCase() : null;
  229. } catch (e) {
  230. /* */
  231. }
  232. switch (protocol) {
  233. case 'postgres:':
  234. case 'postgresql:':
  235. return new _PostgresStorageAdapter.default({
  236. uri: databaseURI,
  237. collectionPrefix,
  238. databaseOptions
  239. });
  240. default:
  241. return new _MongoStorageAdapter.default({
  242. uri: databaseURI,
  243. collectionPrefix,
  244. mongoOptions: databaseOptions
  245. });
  246. }
  247. }
  248. //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQXV0aCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX09wdGlvbnMiLCJfQWRhcHRlckxvYWRlciIsIl9kZWZhdWx0cyIsIl9Mb2dnZXJDb250cm9sbGVyIiwiX0ZpbGVzQ29udHJvbGxlciIsIl9Ib29rc0NvbnRyb2xsZXIiLCJfVXNlckNvbnRyb2xsZXIiLCJfQ2FjaGVDb250cm9sbGVyIiwiX0xpdmVRdWVyeUNvbnRyb2xsZXIiLCJfQW5hbHl0aWNzQ29udHJvbGxlciIsIl9QdXNoQ29udHJvbGxlciIsIl9QdXNoUXVldWUiLCJfUHVzaFdvcmtlciIsIl9EYXRhYmFzZUNvbnRyb2xsZXIiLCJfR3JpZEZTQnVja2V0QWRhcHRlciIsIl9XaW5zdG9uTG9nZ2VyQWRhcHRlciIsIl9Jbk1lbW9yeUNhY2hlQWRhcHRlciIsIl9BbmFseXRpY3NBZGFwdGVyIiwiX01vbmdvU3RvcmFnZUFkYXB0ZXIiLCJfUG9zdGdyZXNTdG9yYWdlQWRhcHRlciIsIl9QYXJzZUdyYXBoUUxDb250cm9sbGVyIiwiX1NjaGVtYUNhY2hlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0Iiwib3duS2V5cyIsInIiLCJ0IiwiT2JqZWN0Iiwia2V5cyIsImdldE93blByb3BlcnR5U3ltYm9scyIsIm8iLCJmaWx0ZXIiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJlbnVtZXJhYmxlIiwicHVzaCIsImFwcGx5IiwiX29iamVjdFNwcmVhZCIsImFyZ3VtZW50cyIsImxlbmd0aCIsImZvckVhY2giLCJfZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzIiwiZGVmaW5lUHJvcGVydGllcyIsImRlZmluZVByb3BlcnR5IiwiX3RvUHJvcGVydHlLZXkiLCJ2YWx1ZSIsImNvbmZpZ3VyYWJsZSIsIndyaXRhYmxlIiwiaSIsIl90b1ByaW1pdGl2ZSIsIlN5bWJvbCIsInRvUHJpbWl0aXZlIiwiY2FsbCIsIlR5cGVFcnJvciIsIlN0cmluZyIsIk51bWJlciIsImdldENvbnRyb2xsZXJzIiwib3B0aW9ucyIsImxvZ2dlckNvbnRyb2xsZXIiLCJnZXRMb2dnZXJDb250cm9sbGVyIiwiZmlsZXNDb250cm9sbGVyIiwiZ2V0RmlsZXNDb250cm9sbGVyIiwidXNlckNvbnRyb2xsZXIiLCJnZXRVc2VyQ29udHJvbGxlciIsImNhY2hlQ29udHJvbGxlciIsImdldENhY2hlQ29udHJvbGxlciIsImFuYWx5dGljc0NvbnRyb2xsZXIiLCJnZXRBbmFseXRpY3NDb250cm9sbGVyIiwibGl2ZVF1ZXJ5Q29udHJvbGxlciIsImdldExpdmVRdWVyeUNvbnRyb2xsZXIiLCJkYXRhYmFzZUNvbnRyb2xsZXIiLCJnZXREYXRhYmFzZUNvbnRyb2xsZXIiLCJob29rc0NvbnRyb2xsZXIiLCJnZXRIb29rc0NvbnRyb2xsZXIiLCJhdXRoRGF0YU1hbmFnZXIiLCJnZXRBdXRoRGF0YU1hbmFnZXIiLCJwYXJzZUdyYXBoUUxDb250cm9sbGVyIiwiZ2V0UGFyc2VHcmFwaFFMQ29udHJvbGxlciIsInNjaGVtYUNhY2hlIiwiU2NoZW1hQ2FjaGUiLCJhcHBJZCIsImpzb25Mb2dzIiwibG9nc0ZvbGRlciIsInZlcmJvc2UiLCJsb2dMZXZlbCIsIm1heExvZ0ZpbGVzIiwic2lsZW50IiwibG9nZ2VyQWRhcHRlciIsImxvZ2dlck9wdGlvbnMiLCJsb2dnZXJDb250cm9sbGVyQWRhcHRlciIsImxvYWRBZGFwdGVyIiwiV2luc3RvbkxvZ2dlckFkYXB0ZXIiLCJMb2dnZXJDb250cm9sbGVyIiwiZGF0YWJhc2VVUkkiLCJkYXRhYmFzZU9wdGlvbnMiLCJmaWxlc0FkYXB0ZXIiLCJkYXRhYmFzZUFkYXB0ZXIiLCJwcmVzZXJ2ZUZpbGVOYW1lIiwiZmlsZUtleSIsImZpbGVzQ29udHJvbGxlckFkYXB0ZXIiLCJHcmlkRlNCdWNrZXRBZGFwdGVyIiwiRmlsZXNDb250cm9sbGVyIiwiZW1haWxBZGFwdGVyIiwidmVyaWZ5VXNlckVtYWlscyIsImVtYWlsQ29udHJvbGxlckFkYXB0ZXIiLCJVc2VyQ29udHJvbGxlciIsImNhY2hlQWRhcHRlciIsImNhY2hlVFRMIiwiY2FjaGVNYXhTaXplIiwiY2FjaGVDb250cm9sbGVyQWRhcHRlciIsIkluTWVtb3J5Q2FjaGVBZGFwdGVyIiwidHRsIiwibWF4U2l6ZSIsIkNhY2hlQ29udHJvbGxlciIsImNvbnRyb2xsZXJEZXBzIiwiUGFyc2VHcmFwaFFMQ29udHJvbGxlciIsIm1vdW50R3JhcGhRTCIsImFuYWx5dGljc0FkYXB0ZXIiLCJhbmFseXRpY3NDb250cm9sbGVyQWRhcHRlciIsIkFuYWx5dGljc0FkYXB0ZXIiLCJBbmFseXRpY3NDb250cm9sbGVyIiwiTGl2ZVF1ZXJ5Q29udHJvbGxlciIsImxpdmVRdWVyeSIsImNvbGxlY3Rpb25QcmVmaXgiLCJkZWZhdWx0cyIsImdldERhdGFiYXNlQWRhcHRlciIsIkRhdGFiYXNlQ29udHJvbGxlciIsIndlYmhvb2tLZXkiLCJIb29rc0NvbnRyb2xsZXIiLCJnZXRQdXNoQ29udHJvbGxlciIsInNjaGVkdWxlZFB1c2giLCJwdXNoT3B0aW9ucyIsImFzc2lnbiIsInB1c2hRdWV1ZU9wdGlvbnMiLCJxdWV1ZU9wdGlvbnMiLCJQYXJzZVB1c2hBZGFwdGVyIiwibG9hZE1vZHVsZSIsInB1c2hBZGFwdGVyIiwiYWRhcHRlciIsInB1c2hDb250cm9sbGVyIiwiUHVzaENvbnRyb2xsZXIiLCJoYXNQdXNoU3VwcG9ydCIsImhhc1B1c2hTY2hlZHVsZWRTdXBwb3J0IiwiZGlzYWJsZVB1c2hXb3JrZXIiLCJwdXNoQ29udHJvbGxlclF1ZXVlIiwiUHVzaFF1ZXVlIiwicHVzaFdvcmtlciIsIlB1c2hXb3JrZXIiLCJhdXRoIiwiZW5hYmxlQW5vbnltb3VzVXNlcnMiLCJwcm90b2NvbCIsInBhcnNlZFVSSSIsIlVSTCIsInRvTG93ZXJDYXNlIiwiUG9zdGdyZXNTdG9yYWdlQWRhcHRlciIsInVyaSIsIk1vbmdvU3RvcmFnZUFkYXB0ZXIiLCJtb25nb09wdGlvbnMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvQ29udHJvbGxlcnMvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGF1dGhEYXRhTWFuYWdlciBmcm9tICcuLi9BZGFwdGVycy9BdXRoJztcbmltcG9ydCB7IFBhcnNlU2VydmVyT3B0aW9ucyB9IGZyb20gJy4uL09wdGlvbnMnO1xuaW1wb3J0IHsgbG9hZEFkYXB0ZXIsIGxvYWRNb2R1bGUgfSBmcm9tICcuLi9BZGFwdGVycy9BZGFwdGVyTG9hZGVyJztcbmltcG9ydCBkZWZhdWx0cyBmcm9tICcuLi9kZWZhdWx0cyc7XG4vLyBDb250cm9sbGVyc1xuaW1wb3J0IHsgTG9nZ2VyQ29udHJvbGxlciB9IGZyb20gJy4vTG9nZ2VyQ29udHJvbGxlcic7XG5pbXBvcnQgeyBGaWxlc0NvbnRyb2xsZXIgfSBmcm9tICcuL0ZpbGVzQ29udHJvbGxlcic7XG5pbXBvcnQgeyBIb29rc0NvbnRyb2xsZXIgfSBmcm9tICcuL0hvb2tzQ29udHJvbGxlcic7XG5pbXBvcnQgeyBVc2VyQ29udHJvbGxlciB9IGZyb20gJy4vVXNlckNvbnRyb2xsZXInO1xuaW1wb3J0IHsgQ2FjaGVDb250cm9sbGVyIH0gZnJvbSAnLi9DYWNoZUNvbnRyb2xsZXInO1xuaW1wb3J0IHsgTGl2ZVF1ZXJ5Q29udHJvbGxlciB9IGZyb20gJy4vTGl2ZVF1ZXJ5Q29udHJvbGxlcic7XG5pbXBvcnQgeyBBbmFseXRpY3NDb250cm9sbGVyIH0gZnJvbSAnLi9BbmFseXRpY3NDb250cm9sbGVyJztcbmltcG9ydCB7IFB1c2hDb250cm9sbGVyIH0gZnJvbSAnLi9QdXNoQ29udHJvbGxlcic7XG5pbXBvcnQgeyBQdXNoUXVldWUgfSBmcm9tICcuLi9QdXNoL1B1c2hRdWV1ZSc7XG5pbXBvcnQgeyBQdXNoV29ya2VyIH0gZnJvbSAnLi4vUHVzaC9QdXNoV29ya2VyJztcbmltcG9ydCBEYXRhYmFzZUNvbnRyb2xsZXIgZnJvbSAnLi9EYXRhYmFzZUNvbnRyb2xsZXInO1xuXG4vLyBBZGFwdGVyc1xuaW1wb3J0IHsgR3JpZEZTQnVja2V0QWRhcHRlciB9IGZyb20gJy4uL0FkYXB0ZXJzL0ZpbGVzL0dyaWRGU0J1Y2tldEFkYXB0ZXInO1xuaW1wb3J0IHsgV2luc3RvbkxvZ2dlckFkYXB0ZXIgfSBmcm9tICcuLi9BZGFwdGVycy9Mb2dnZXIvV2luc3RvbkxvZ2dlckFkYXB0ZXInO1xuaW1wb3J0IHsgSW5NZW1vcnlDYWNoZUFkYXB0ZXIgfSBmcm9tICcuLi9BZGFwdGVycy9DYWNoZS9Jbk1lbW9yeUNhY2hlQWRhcHRlcic7XG5pbXBvcnQgeyBBbmFseXRpY3NBZGFwdGVyIH0gZnJvbSAnLi4vQWRhcHRlcnMvQW5hbHl0aWNzL0FuYWx5dGljc0FkYXB0ZXInO1xuaW1wb3J0IE1vbmdvU3RvcmFnZUFkYXB0ZXIgZnJvbSAnLi4vQWRhcHRlcnMvU3RvcmFnZS9Nb25nby9Nb25nb1N0b3JhZ2VBZGFwdGVyJztcbmltcG9ydCBQb3N0Z3Jlc1N0b3JhZ2VBZGFwdGVyIGZyb20gJy4uL0FkYXB0ZXJzL1N0b3JhZ2UvUG9zdGdyZXMvUG9zdGdyZXNTdG9yYWdlQWRhcHRlcic7XG5pbXBvcnQgUGFyc2VHcmFwaFFMQ29udHJvbGxlciBmcm9tICcuL1BhcnNlR3JhcGhRTENvbnRyb2xsZXInO1xuaW1wb3J0IFNjaGVtYUNhY2hlIGZyb20gJy4uL0FkYXB0ZXJzL0NhY2hlL1NjaGVtYUNhY2hlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldENvbnRyb2xsZXJzKG9wdGlvbnM6IFBhcnNlU2VydmVyT3B0aW9ucykge1xuICBjb25zdCBsb2dnZXJDb250cm9sbGVyID0gZ2V0TG9nZ2VyQ29udHJvbGxlcihvcHRpb25zKTtcbiAgY29uc3QgZmlsZXNDb250cm9sbGVyID0gZ2V0RmlsZXNDb250cm9sbGVyKG9wdGlvbnMpO1xuICBjb25zdCB1c2VyQ29udHJvbGxlciA9IGdldFVzZXJDb250cm9sbGVyKG9wdGlvbnMpO1xuICBjb25zdCBjYWNoZUNvbnRyb2xsZXIgPSBnZXRDYWNoZUNvbnRyb2xsZXIob3B0aW9ucyk7XG4gIGNvbnN0IGFuYWx5dGljc0NvbnRyb2xsZXIgPSBnZXRBbmFseXRpY3NDb250cm9sbGVyKG9wdGlvbnMpO1xuICBjb25zdCBsaXZlUXVlcnlDb250cm9sbGVyID0gZ2V0TGl2ZVF1ZXJ5Q29udHJvbGxlcihvcHRpb25zKTtcbiAgY29uc3QgZGF0YWJhc2VDb250cm9sbGVyID0gZ2V0RGF0YWJhc2VDb250cm9sbGVyKG9wdGlvbnMpO1xuICBjb25zdCBob29rc0NvbnRyb2xsZXIgPSBnZXRIb29rc0NvbnRyb2xsZXIob3B0aW9ucywgZGF0YWJhc2VDb250cm9sbGVyKTtcbiAgY29uc3QgYXV0aERhdGFNYW5hZ2VyID0gZ2V0QXV0aERhdGFNYW5hZ2VyKG9wdGlvbnMpO1xuICBjb25zdCBwYXJzZUdyYXBoUUxDb250cm9sbGVyID0gZ2V0UGFyc2VHcmFwaFFMQ29udHJvbGxlcihvcHRpb25zLCB7XG4gICAgZGF0YWJhc2VDb250cm9sbGVyLFxuICAgIGNhY2hlQ29udHJvbGxlcixcbiAgfSk7XG4gIHJldHVybiB7XG4gICAgbG9nZ2VyQ29udHJvbGxlcixcbiAgICBmaWxlc0NvbnRyb2xsZXIsXG4gICAgdXNlckNvbnRyb2xsZXIsXG4gICAgYW5hbHl0aWNzQ29udHJvbGxlcixcbiAgICBjYWNoZUNvbnRyb2xsZXIsXG4gICAgcGFyc2VHcmFwaFFMQ29udHJvbGxlcixcbiAgICBsaXZlUXVlcnlDb250cm9sbGVyLFxuICAgIGRhdGFiYXNlQ29udHJvbGxlcixcbiAgICBob29rc0NvbnRyb2xsZXIsXG4gICAgYXV0aERhdGFNYW5hZ2VyLFxuICAgIHNjaGVtYUNhY2hlOiBTY2hlbWFDYWNoZSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldExvZ2dlckNvbnRyb2xsZXIob3B0aW9uczogUGFyc2VTZXJ2ZXJPcHRpb25zKTogTG9nZ2VyQ29udHJvbGxlciB7XG4gIGNvbnN0IHtcbiAgICBhcHBJZCxcbiAgICBqc29uTG9ncyxcbiAgICBsb2dzRm9sZGVyLFxuICAgIHZlcmJvc2UsXG4gICAgbG9nTGV2ZWwsXG4gICAgbWF4TG9nRmlsZXMsXG4gICAgc2lsZW50LFxuICAgIGxvZ2dlckFkYXB0ZXIsXG4gIH0gPSBvcHRpb25zO1xuICBjb25zdCBsb2dnZXJPcHRpb25zID0ge1xuICAgIGpzb25Mb2dzLFxuICAgIGxvZ3NGb2xkZXIsXG4gICAgdmVyYm9zZSxcbiAgICBsb2dMZXZlbCxcbiAgICBzaWxlbnQsXG4gICAgbWF4TG9nRmlsZXMsXG4gIH07XG4gIGNvbnN0IGxvZ2dlckNvbnRyb2xsZXJBZGFwdGVyID0gbG9hZEFkYXB0ZXIobG9nZ2VyQWRhcHRlciwgV2luc3RvbkxvZ2dlckFkYXB0ZXIsIGxvZ2dlck9wdGlvbnMpO1xuICByZXR1cm4gbmV3IExvZ2dlckNvbnRyb2xsZXIobG9nZ2VyQ29udHJvbGxlckFkYXB0ZXIsIGFwcElkLCBsb2dnZXJPcHRpb25zKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZpbGVzQ29udHJvbGxlcihvcHRpb25zOiBQYXJzZVNlcnZlck9wdGlvbnMpOiBGaWxlc0NvbnRyb2xsZXIge1xuICBjb25zdCB7XG4gICAgYXBwSWQsXG4gICAgZGF0YWJhc2VVUkksXG4gICAgZGF0YWJhc2VPcHRpb25zID0ge30sXG4gICAgZmlsZXNBZGFwdGVyLFxuICAgIGRhdGFiYXNlQWRhcHRlcixcbiAgICBwcmVzZXJ2ZUZpbGVOYW1lLFxuICAgIGZpbGVLZXksXG4gIH0gPSBvcHRpb25zO1xuICBpZiAoIWZpbGVzQWRhcHRlciAmJiBkYXRhYmFzZUFkYXB0ZXIpIHtcbiAgICB0aHJvdyAnV2hlbiB1c2luZyBhbiBleHBsaWNpdCBkYXRhYmFzZSBhZGFwdGVyLCB5b3UgbXVzdCBhbHNvIHVzZSBhbiBleHBsaWNpdCBmaWxlc0FkYXB0ZXIuJztcbiAgfVxuICBjb25zdCBmaWxlc0NvbnRyb2xsZXJBZGFwdGVyID0gbG9hZEFkYXB0ZXIoZmlsZXNBZGFwdGVyLCAoKSA9PiB7XG4gICAgcmV0dXJuIG5ldyBHcmlkRlNCdWNrZXRBZGFwdGVyKGRhdGFiYXNlVVJJLCBkYXRhYmFzZU9wdGlvbnMsIGZpbGVLZXkpO1xuICB9KTtcbiAgcmV0dXJuIG5ldyBGaWxlc0NvbnRyb2xsZXIoZmlsZXNDb250cm9sbGVyQWRhcHRlciwgYXBwSWQsIHtcbiAgICBwcmVzZXJ2ZUZpbGVOYW1lLFxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFVzZXJDb250cm9sbGVyKG9wdGlvbnM6IFBhcnNlU2VydmVyT3B0aW9ucyk6IFVzZXJDb250cm9sbGVyIHtcbiAgY29uc3QgeyBhcHBJZCwgZW1haWxBZGFwdGVyLCB2ZXJpZnlVc2VyRW1haWxzIH0gPSBvcHRpb25zO1xuICBjb25zdCBlbWFpbENvbnRyb2xsZXJBZGFwdGVyID0gbG9hZEFkYXB0ZXIoZW1haWxBZGFwdGVyKTtcbiAgcmV0dXJuIG5ldyBVc2VyQ29udHJvbGxlcihlbWFpbENvbnRyb2xsZXJBZGFwdGVyLCBhcHBJZCwge1xuICAgIHZlcmlmeVVzZXJFbWFpbHMsXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q2FjaGVDb250cm9sbGVyKG9wdGlvbnM6IFBhcnNlU2VydmVyT3B0aW9ucyk6IENhY2hlQ29udHJvbGxlciB7XG4gIGNvbnN0IHsgYXBwSWQsIGNhY2hlQWRhcHRlciwgY2FjaGVUVEwsIGNhY2hlTWF4U2l6ZSB9ID0gb3B0aW9ucztcbiAgY29uc3QgY2FjaGVDb250cm9sbGVyQWRhcHRlciA9IGxvYWRBZGFwdGVyKGNhY2hlQWRhcHRlciwgSW5NZW1vcnlDYWNoZUFkYXB0ZXIsIHtcbiAgICBhcHBJZDogYXBwSWQsXG4gICAgdHRsOiBjYWNoZVRUTCxcbiAgICBtYXhTaXplOiBjYWNoZU1heFNpemUsXG4gIH0pO1xuICByZXR1cm4gbmV3IENhY2hlQ29udHJvbGxlcihjYWNoZUNvbnRyb2xsZXJBZGFwdGVyLCBhcHBJZCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYXJzZUdyYXBoUUxDb250cm9sbGVyKFxuICBvcHRpb25zOiBQYXJzZVNlcnZlck9wdGlvbnMsXG4gIGNvbnRyb2xsZXJEZXBzXG4pOiBQYXJzZUdyYXBoUUxDb250cm9sbGVyIHtcbiAgcmV0dXJuIG5ldyBQYXJzZUdyYXBoUUxDb250cm9sbGVyKHtcbiAgICBtb3VudEdyYXBoUUw6IG9wdGlvbnMubW91bnRHcmFwaFFMLFxuICAgIC4uLmNvbnRyb2xsZXJEZXBzLFxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFuYWx5dGljc0NvbnRyb2xsZXIob3B0aW9uczogUGFyc2VTZXJ2ZXJPcHRpb25zKTogQW5hbHl0aWNzQ29udHJvbGxlciB7XG4gIGNvbnN0IHsgYW5hbHl0aWNzQWRhcHRlciB9ID0gb3B0aW9ucztcbiAgY29uc3QgYW5hbHl0aWNzQ29udHJvbGxlckFkYXB0ZXIgPSBsb2FkQWRhcHRlcihhbmFseXRpY3NBZGFwdGVyLCBBbmFseXRpY3NBZGFwdGVyKTtcbiAgcmV0dXJuIG5ldyBBbmFseXRpY3NDb250cm9sbGVyKGFuYWx5dGljc0NvbnRyb2xsZXJBZGFwdGVyKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldExpdmVRdWVyeUNvbnRyb2xsZXIob3B0aW9uczogUGFyc2VTZXJ2ZXJPcHRpb25zKTogTGl2ZVF1ZXJ5Q29udHJvbGxlciB7XG4gIHJldHVybiBuZXcgTGl2ZVF1ZXJ5Q29udHJvbGxlcihvcHRpb25zLmxpdmVRdWVyeSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREYXRhYmFzZUNvbnRyb2xsZXIob3B0aW9uczogUGFyc2VTZXJ2ZXJPcHRpb25zKTogRGF0YWJhc2VDb250cm9sbGVyIHtcbiAgY29uc3QgeyBkYXRhYmFzZVVSSSwgY29sbGVjdGlvblByZWZpeCwgZGF0YWJhc2VPcHRpb25zIH0gPSBvcHRpb25zO1xuICBsZXQgeyBkYXRhYmFzZUFkYXB0ZXIgfSA9IG9wdGlvbnM7XG4gIGlmIChcbiAgICAoZGF0YWJhc2VPcHRpb25zIHx8XG4gICAgICAoZGF0YWJhc2VVUkkgJiYgZGF0YWJhc2VVUkkgIT09IGRlZmF1bHRzLmRhdGFiYXNlVVJJKSB8fFxuICAgICAgY29sbGVjdGlvblByZWZpeCAhPT0gZGVmYXVsdHMuY29sbGVjdGlvblByZWZpeCkgJiZcbiAgICBkYXRhYmFzZUFkYXB0ZXJcbiAgKSB7XG4gICAgdGhyb3cgJ1lvdSBjYW5ub3Qgc3BlY2lmeSBib3RoIGEgZGF0YWJhc2VBZGFwdGVyIGFuZCBhIGRhdGFiYXNlVVJJL2RhdGFiYXNlT3B0aW9ucy9jb2xsZWN0aW9uUHJlZml4Lic7XG4gIH0gZWxzZSBpZiAoIWRhdGFiYXNlQWRhcHRlcikge1xuICAgIGRhdGFiYXNlQWRhcHRlciA9IGdldERhdGFiYXNlQWRhcHRlcihkYXRhYmFzZVVSSSwgY29sbGVjdGlvblByZWZpeCwgZGF0YWJhc2VPcHRpb25zKTtcbiAgfSBlbHNlIHtcbiAgICBkYXRhYmFzZUFkYXB0ZXIgPSBsb2FkQWRhcHRlcihkYXRhYmFzZUFkYXB0ZXIpO1xuICB9XG4gIHJldHVybiBuZXcgRGF0YWJhc2VDb250cm9sbGVyKGRhdGFiYXNlQWRhcHRlciwgb3B0aW9ucyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRIb29rc0NvbnRyb2xsZXIoXG4gIG9wdGlvbnM6IFBhcnNlU2VydmVyT3B0aW9ucyxcbiAgZGF0YWJhc2VDb250cm9sbGVyOiBEYXRhYmFzZUNvbnRyb2xsZXJcbik6IEhvb2tzQ29udHJvbGxlciB7XG4gIGNvbnN0IHsgYXBwSWQsIHdlYmhvb2tLZXkgfSA9IG9wdGlvbnM7XG4gIHJldHVybiBuZXcgSG9va3NDb250cm9sbGVyKGFwcElkLCBkYXRhYmFzZUNvbnRyb2xsZXIsIHdlYmhvb2tLZXkpO1xufVxuXG5pbnRlcmZhY2UgUHVzaENvbnRyb2xsaW5nIHtcbiAgcHVzaENvbnRyb2xsZXI6IFB1c2hDb250cm9sbGVyO1xuICBoYXNQdXNoU2NoZWR1bGVkU3VwcG9ydDogYm9vbGVhbjtcbiAgcHVzaENvbnRyb2xsZXJRdWV1ZTogUHVzaFF1ZXVlO1xuICBwdXNoV29ya2VyOiBQdXNoV29ya2VyO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0UHVzaENvbnRyb2xsZXIob3B0aW9uczogUGFyc2VTZXJ2ZXJPcHRpb25zKTogUHVzaENvbnRyb2xsaW5nIHtcbiAgY29uc3QgeyBzY2hlZHVsZWRQdXNoLCBwdXNoIH0gPSBvcHRpb25zO1xuXG4gIGNvbnN0IHB1c2hPcHRpb25zID0gT2JqZWN0LmFzc2lnbih7fSwgcHVzaCk7XG4gIGNvbnN0IHB1c2hRdWV1ZU9wdGlvbnMgPSBwdXNoT3B0aW9ucy5xdWV1ZU9wdGlvbnMgfHwge307XG4gIGlmIChwdXNoT3B0aW9ucy5xdWV1ZU9wdGlvbnMpIHtcbiAgICBkZWxldGUgcHVzaE9wdGlvbnMucXVldWVPcHRpb25zO1xuICB9XG5cbiAgLy8gUGFzcyB0aGUgcHVzaCBvcHRpb25zIHRvbyBhcyBpdCB3b3JrcyB3aXRoIHRoZSBkZWZhdWx0XG4gIGNvbnN0IFBhcnNlUHVzaEFkYXB0ZXIgPSBhd2FpdCBsb2FkTW9kdWxlKCdAcGFyc2UvcHVzaC1hZGFwdGVyJyk7XG4gIGNvbnN0IHB1c2hBZGFwdGVyID0gbG9hZEFkYXB0ZXIoXG4gICAgcHVzaE9wdGlvbnMgJiYgcHVzaE9wdGlvbnMuYWRhcHRlcixcbiAgICBQYXJzZVB1c2hBZGFwdGVyLFxuICAgIHB1c2hPcHRpb25zXG4gICk7XG4gIC8vIFdlIHBhc3MgdGhlIG9wdGlvbnMgYW5kIHRoZSBiYXNlIGNsYXNzIGZvciB0aGUgYWRhdHBlcixcbiAgLy8gTm90ZSB0aGF0IHBhc3NpbmcgYW4gaW5zdGFuY2Ugd291bGQgd29yayB0b29cbiAgY29uc3QgcHVzaENvbnRyb2xsZXIgPSBuZXcgUHVzaENvbnRyb2xsZXIoKTtcbiAgY29uc3QgaGFzUHVzaFN1cHBvcnQgPSAhIShwdXNoQWRhcHRlciAmJiBwdXNoKTtcbiAgY29uc3QgaGFzUHVzaFNjaGVkdWxlZFN1cHBvcnQgPSBoYXNQdXNoU3VwcG9ydCAmJiBzY2hlZHVsZWRQdXNoID09PSB0cnVlO1xuXG4gIGNvbnN0IHsgZGlzYWJsZVB1c2hXb3JrZXIgfSA9IHB1c2hRdWV1ZU9wdGlvbnM7XG5cbiAgY29uc3QgcHVzaENvbnRyb2xsZXJRdWV1ZSA9IG5ldyBQdXNoUXVldWUocHVzaFF1ZXVlT3B0aW9ucyk7XG4gIGxldCBwdXNoV29ya2VyO1xuICBpZiAoIWRpc2FibGVQdXNoV29ya2VyKSB7XG4gICAgcHVzaFdvcmtlciA9IG5ldyBQdXNoV29ya2VyKHB1c2hBZGFwdGVyLCBwdXNoUXVldWVPcHRpb25zKTtcbiAgfVxuICByZXR1cm4ge1xuICAgIHB1c2hDb250cm9sbGVyLFxuICAgIGhhc1B1c2hTdXBwb3J0LFxuICAgIGhhc1B1c2hTY2hlZHVsZWRTdXBwb3J0LFxuICAgIHB1c2hDb250cm9sbGVyUXVldWUsXG4gICAgcHVzaFdvcmtlcixcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEF1dGhEYXRhTWFuYWdlcihvcHRpb25zOiBQYXJzZVNlcnZlck9wdGlvbnMpIHtcbiAgY29uc3QgeyBhdXRoLCBlbmFibGVBbm9ueW1vdXNVc2VycyB9ID0gb3B0aW9ucztcbiAgcmV0dXJuIGF1dGhEYXRhTWFuYWdlcihhdXRoLCBlbmFibGVBbm9ueW1vdXNVc2Vycyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREYXRhYmFzZUFkYXB0ZXIoZGF0YWJhc2VVUkksIGNvbGxlY3Rpb25QcmVmaXgsIGRhdGFiYXNlT3B0aW9ucykge1xuICBsZXQgcHJvdG9jb2w7XG4gIHRyeSB7XG4gICAgY29uc3QgcGFyc2VkVVJJID0gbmV3IFVSTChkYXRhYmFzZVVSSSk7XG4gICAgcHJvdG9jb2wgPSBwYXJzZWRVUkkucHJvdG9jb2wgPyBwYXJzZWRVUkkucHJvdG9jb2wudG9Mb3dlckNhc2UoKSA6IG51bGw7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvKiAqL1xuICB9XG4gIHN3aXRjaCAocHJvdG9jb2wpIHtcbiAgICBjYXNlICdwb3N0Z3JlczonOlxuICAgIGNhc2UgJ3Bvc3RncmVzcWw6JzpcbiAgICAgIHJldHVybiBuZXcgUG9zdGdyZXNTdG9yYWdlQWRhcHRlcih7XG4gICAgICAgIHVyaTogZGF0YWJhc2VVUkksXG4gICAgICAgIGNvbGxlY3Rpb25QcmVmaXgsXG4gICAgICAgIGRhdGFiYXNlT3B0aW9ucyxcbiAgICAgIH0pO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gbmV3IE1vbmdvU3RvcmFnZUFkYXB0ZXIoe1xuICAgICAgICB1cmk6IGRhdGFiYXNlVVJJLFxuICAgICAgICBjb2xsZWN0aW9uUHJlZml4LFxuICAgICAgICBtb25nb09wdGlvbnM6IGRhdGFiYXNlT3B0aW9ucyxcbiAgICAgIH0pO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLElBQUFBLEtBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFFBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLGNBQUEsR0FBQUYsT0FBQTtBQUNBLElBQUFHLFNBQUEsR0FBQUosc0JBQUEsQ0FBQUMsT0FBQTtBQUVBLElBQUFJLGlCQUFBLEdBQUFKLE9BQUE7QUFDQSxJQUFBSyxnQkFBQSxHQUFBTCxPQUFBO0FBQ0EsSUFBQU0sZ0JBQUEsR0FBQU4sT0FBQTtBQUNBLElBQUFPLGVBQUEsR0FBQVAsT0FBQTtBQUNBLElBQUFRLGdCQUFBLEdBQUFSLE9BQUE7QUFDQSxJQUFBUyxvQkFBQSxHQUFBVCxPQUFBO0FBQ0EsSUFBQVUsb0JBQUEsR0FBQVYsT0FBQTtBQUNBLElBQUFXLGVBQUEsR0FBQVgsT0FBQTtBQUNBLElBQUFZLFVBQUEsR0FBQVosT0FBQTtBQUNBLElBQUFhLFdBQUEsR0FBQWIsT0FBQTtBQUNBLElBQUFjLG1CQUFBLEdBQUFmLHNCQUFBLENBQUFDLE9BQUE7QUFHQSxJQUFBZSxvQkFBQSxHQUFBZixPQUFBO0FBQ0EsSUFBQWdCLHFCQUFBLEdBQUFoQixPQUFBO0FBQ0EsSUFBQWlCLHFCQUFBLEdBQUFqQixPQUFBO0FBQ0EsSUFBQWtCLGlCQUFBLEdBQUFsQixPQUFBO0FBQ0EsSUFBQW1CLG9CQUFBLEdBQUFwQixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQW9CLHVCQUFBLEdBQUFyQixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQXFCLHVCQUFBLEdBQUF0QixzQkFBQSxDQUFBQyxPQUFB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