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.
- package/README.md +45 -17
- package/lib/AccountLockout.js +11 -26
- package/lib/Adapters/AdapterLoader.js +8 -14
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
- package/lib/Adapters/Auth/AuthAdapter.js +7 -16
- package/lib/Adapters/Auth/OAuth1Client.js +32 -57
- package/lib/Adapters/Auth/apple.js +6 -22
- package/lib/Adapters/Auth/facebook.js +7 -37
- package/lib/Adapters/Auth/gcenter.js +8 -37
- package/lib/Adapters/Auth/github.js +7 -10
- package/lib/Adapters/Auth/google.js +11 -34
- package/lib/Adapters/Auth/gpgames.js +5 -8
- package/lib/Adapters/Auth/httpsRequest.js +1 -7
- package/lib/Adapters/Auth/index.js +20 -65
- package/lib/Adapters/Auth/instagram.js +5 -9
- package/lib/Adapters/Auth/janraincapture.js +8 -12
- package/lib/Adapters/Auth/janrainengage.js +7 -11
- package/lib/Adapters/Auth/keycloak.js +5 -19
- package/lib/Adapters/Auth/ldap.js +1 -15
- package/lib/Adapters/Auth/line.js +7 -10
- package/lib/Adapters/Auth/linkedin.js +7 -12
- package/lib/Adapters/Auth/meetup.js +7 -10
- package/lib/Adapters/Auth/microsoft.js +7 -10
- package/lib/Adapters/Auth/oauth2.js +6 -18
- package/lib/Adapters/Auth/phantauth.js +8 -10
- package/lib/Adapters/Auth/qq.js +7 -13
- package/lib/Adapters/Auth/spotify.js +7 -14
- package/lib/Adapters/Auth/twitter.js +5 -15
- package/lib/Adapters/Auth/vkontakte.js +9 -15
- package/lib/Adapters/Auth/wechat.js +7 -10
- package/lib/Adapters/Auth/weibo.js +7 -11
- package/lib/Adapters/Cache/CacheAdapter.js +4 -12
- package/lib/Adapters/Cache/InMemoryCache.js +5 -19
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
- package/lib/Adapters/Cache/LRUCache.js +1 -11
- package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
- package/lib/Adapters/Cache/SchemaCache.js +1 -6
- package/lib/Adapters/Email/MailAdapter.js +2 -7
- package/lib/Adapters/Files/FilesAdapter.js +7 -21
- package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
- package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
- package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
- package/lib/Adapters/Logger/WinstonLogger.js +3 -30
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
- package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
- package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
- package/lib/Adapters/Push/PushAdapter.js +2 -8
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
- package/lib/Auth.js +54 -121
- package/lib/ClientSDK.js +3 -11
- package/lib/Config.js +69 -113
- package/lib/Controllers/AdaptableController.js +6 -18
- package/lib/Controllers/AnalyticsController.js +1 -9
- package/lib/Controllers/CacheController.js +3 -23
- package/lib/Controllers/DatabaseController.js +147 -345
- package/lib/Controllers/FilesController.js +5 -34
- package/lib/Controllers/HooksController.js +1 -51
- package/lib/Controllers/LiveQueryController.js +4 -23
- package/lib/Controllers/LoggerController.js +15 -54
- package/lib/Controllers/ParseGraphQLController.js +49 -104
- package/lib/Controllers/PushController.js +20 -59
- package/lib/Controllers/SchemaController.js +154 -344
- package/lib/Controllers/UserController.js +11 -72
- package/lib/Controllers/index.js +19 -68
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +1 -8
- package/lib/Deprecator/Deprecator.js +9 -18
- package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
- package/lib/GraphQL/ParseGraphQLServer.js +2 -29
- package/lib/GraphQL/helpers/objectsMutations.js +2 -12
- package/lib/GraphQL/helpers/objectsQueries.js +18 -76
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
- package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
- package/lib/GraphQL/loaders/filesMutations.js +2 -19
- package/lib/GraphQL/loaders/functionsMutations.js +6 -17
- package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
- package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
- package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
- package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
- package/lib/GraphQL/loaders/schemaMutations.js +1 -20
- package/lib/GraphQL/loaders/schemaQueries.js +1 -14
- package/lib/GraphQL/loaders/schemaTypes.js +2 -6
- package/lib/GraphQL/loaders/usersMutations.js +6 -28
- package/lib/GraphQL/loaders/usersQueries.js +4 -26
- package/lib/GraphQL/parseGraphQLUtils.js +6 -19
- package/lib/GraphQL/transformers/className.js +1 -4
- package/lib/GraphQL/transformers/constraintType.js +1 -20
- package/lib/GraphQL/transformers/inputType.js +1 -20
- package/lib/GraphQL/transformers/mutation.js +6 -51
- package/lib/GraphQL/transformers/outputType.js +1 -20
- package/lib/GraphQL/transformers/query.js +6 -42
- package/lib/GraphQL/transformers/schemaFields.js +7 -34
- package/lib/KeyPromiseQueue.js +1 -12
- package/lib/LiveQuery/Client.js +1 -25
- package/lib/LiveQuery/Id.js +1 -7
- package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
- package/lib/LiveQuery/ParseLiveQueryServer.js +92 -306
- package/lib/LiveQuery/ParsePubSub.js +1 -12
- package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
- package/lib/LiveQuery/QueryTools.js +14 -116
- package/lib/LiveQuery/RequestSchema.js +1 -1
- package/lib/LiveQuery/SessionTokenCache.js +1 -17
- package/lib/LiveQuery/Subscription.js +4 -18
- package/lib/LiveQuery/equalObjects.js +2 -14
- package/lib/Options/Definitions.js +79 -10
- package/lib/Options/docs.js +23 -3
- package/lib/Options/index.js +4 -12
- package/lib/Options/parsers.js +1 -18
- package/lib/Page.js +1 -9
- package/lib/ParseMessageQueue.js +1 -10
- package/lib/ParseServer.js +144 -182
- package/lib/ParseServerRESTController.js +6 -33
- package/lib/PromiseRouter.js +16 -50
- package/lib/Push/PushQueue.js +3 -15
- package/lib/Push/PushWorker.js +7 -32
- package/lib/Push/utils.js +9 -38
- package/lib/RestQuery.js +105 -242
- package/lib/RestWrite.js +212 -377
- package/lib/Routers/AggregateRouter.js +14 -51
- package/lib/Routers/AnalyticsRouter.js +2 -8
- package/lib/Routers/AudiencesRouter.js +1 -15
- package/lib/Routers/ClassesRouter.js +3 -53
- package/lib/Routers/CloudCodeRouter.js +1 -19
- package/lib/Routers/FeaturesRouter.js +1 -10
- package/lib/Routers/FilesRouter.js +29 -76
- package/lib/Routers/FunctionsRouter.js +5 -28
- package/lib/Routers/GlobalConfigRouter.js +4 -18
- package/lib/Routers/GraphQLRouter.js +1 -14
- package/lib/Routers/HooksRouter.js +1 -29
- package/lib/Routers/IAPValidationRouter.js +6 -29
- package/lib/Routers/InstallationsRouter.js +2 -12
- package/lib/Routers/LogsRouter.js +4 -16
- package/lib/Routers/PagesRouter.js +69 -129
- package/lib/Routers/PublicAPIRouter.js +3 -62
- package/lib/Routers/PurgeRouter.js +1 -15
- package/lib/Routers/PushRouter.js +2 -18
- package/lib/Routers/RolesRouter.js +1 -7
- package/lib/Routers/SchemasRouter.js +4 -34
- package/lib/Routers/SecurityRouter.js +1 -12
- package/lib/Routers/SessionsRouter.js +3 -19
- package/lib/Routers/UsersRouter.js +58 -155
- package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
- package/lib/SchemaMigrations/Migrations.js +2 -8
- package/lib/Security/Check.js +8 -16
- package/lib/Security/CheckGroup.js +4 -11
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
- package/lib/Security/CheckGroups/CheckGroups.js +1 -4
- package/lib/Security/CheckRunner.js +22 -41
- package/lib/StatusHandler.js +12 -69
- package/lib/TestUtils.js +1 -6
- package/lib/Utils.js +27 -66
- package/lib/batch.js +17 -28
- package/lib/cache.js +1 -3
- package/lib/cli/definitions/parse-live-query-server.js +1 -3
- package/lib/cli/definitions/parse-server.js +1 -3
- package/lib/cli/parse-live-query-server.js +1 -6
- package/lib/cli/parse-server.js +11 -21
- package/lib/cli/utils/commander.js +13 -51
- package/lib/cli/utils/runner.js +1 -14
- package/lib/cloud-code/Parse.Cloud.js +71 -92
- package/lib/cryptoUtils.js +11 -19
- package/lib/defaults.js +2 -14
- package/lib/deprecated.js +1 -2
- package/lib/index.js +16 -34
- package/lib/logger.js +6 -13
- package/lib/middlewares.js +147 -151
- package/lib/password.js +6 -10
- package/lib/request.js +173 -2
- package/lib/requiredParameter.js +1 -3
- package/lib/rest.js +19 -41
- package/lib/triggers.js +54 -252
- package/lib/vendor/mongodbUrl.js +125 -305
- package/package.json +22 -19
- package/lib/cloud-code/HTTPResponse.js +0 -73
- package/lib/cloud-code/httpRequest.js +0 -192
|
@@ -3,16 +3,11 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.default = exports.LoggerController = exports.LogOrder = exports.LogLevel = void 0;
|
|
7
|
-
|
|
6
|
+
exports.logLevels = exports.default = exports.LoggerController = exports.LogOrder = exports.LogLevel = void 0;
|
|
8
7
|
var _node = require("parse/node");
|
|
9
|
-
|
|
10
8
|
var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
|
|
11
|
-
|
|
12
9
|
var _LoggerAdapter = require("../Adapters/Logger/LoggerAdapter");
|
|
13
|
-
|
|
14
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
-
|
|
16
11
|
const MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;
|
|
17
12
|
const LOG_STRING_TRUNCATE_LENGTH = 1000;
|
|
18
13
|
const truncationMarker = '... (truncated)';
|
|
@@ -27,24 +22,20 @@ const LogOrder = {
|
|
|
27
22
|
};
|
|
28
23
|
exports.LogOrder = LogOrder;
|
|
29
24
|
const logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];
|
|
30
|
-
|
|
25
|
+
exports.logLevels = logLevels;
|
|
31
26
|
class LoggerController extends _AdaptableController.default {
|
|
32
27
|
constructor(adapter, appId, options = {
|
|
33
28
|
logLevel: 'info'
|
|
34
29
|
}) {
|
|
35
30
|
super(adapter, appId, options);
|
|
36
31
|
let level = 'info';
|
|
37
|
-
|
|
38
32
|
if (options.verbose) {
|
|
39
33
|
level = 'verbose';
|
|
40
34
|
}
|
|
41
|
-
|
|
42
35
|
if (options.logLevel) {
|
|
43
36
|
level = options.logLevel;
|
|
44
37
|
}
|
|
45
|
-
|
|
46
38
|
const index = logLevels.indexOf(level); // info by default
|
|
47
|
-
|
|
48
39
|
logLevels.forEach((level, levelIndex) => {
|
|
49
40
|
if (levelIndex > index) {
|
|
50
41
|
// silence the levels that are > maxIndex
|
|
@@ -52,14 +43,11 @@ class LoggerController extends _AdaptableController.default {
|
|
|
52
43
|
}
|
|
53
44
|
});
|
|
54
45
|
}
|
|
55
|
-
|
|
56
46
|
maskSensitiveUrl(path) {
|
|
57
47
|
const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL
|
|
58
|
-
|
|
59
48
|
const urlObj = new URL(urlString);
|
|
60
49
|
const query = urlObj.searchParams;
|
|
61
50
|
let sanitizedQuery = '?';
|
|
62
|
-
|
|
63
51
|
for (const [key, value] of query) {
|
|
64
52
|
if (key !== 'password') {
|
|
65
53
|
// normal value
|
|
@@ -68,26 +56,25 @@ class LoggerController extends _AdaptableController.default {
|
|
|
68
56
|
// password value, redact it
|
|
69
57
|
sanitizedQuery += key + '=' + '********' + '&';
|
|
70
58
|
}
|
|
71
|
-
}
|
|
72
|
-
|
|
59
|
+
}
|
|
73
60
|
|
|
74
|
-
|
|
61
|
+
// trim last character, ? or &
|
|
62
|
+
sanitizedQuery = sanitizedQuery.slice(0, -1);
|
|
75
63
|
|
|
64
|
+
// return original path name with sanitized params attached
|
|
76
65
|
return urlObj.pathname + sanitizedQuery;
|
|
77
66
|
}
|
|
78
|
-
|
|
79
67
|
maskSensitive(argArray) {
|
|
80
68
|
return argArray.map(e => {
|
|
81
69
|
if (!e) {
|
|
82
70
|
return e;
|
|
83
71
|
}
|
|
84
|
-
|
|
85
72
|
if (typeof e === 'string') {
|
|
86
73
|
return e.replace(/(password".?:.?")[^"]*"/g, '$1********"');
|
|
87
|
-
}
|
|
88
|
-
//
|
|
89
|
-
|
|
74
|
+
}
|
|
75
|
+
// else it is an object...
|
|
90
76
|
|
|
77
|
+
// check the url
|
|
91
78
|
if (e.url) {
|
|
92
79
|
// for strings
|
|
93
80
|
if (typeof e.url === 'string') {
|
|
@@ -98,12 +85,10 @@ class LoggerController extends _AdaptableController.default {
|
|
|
98
85
|
if (typeof item === 'string') {
|
|
99
86
|
return this.maskSensitiveUrl(item);
|
|
100
87
|
}
|
|
101
|
-
|
|
102
88
|
return item;
|
|
103
89
|
});
|
|
104
90
|
}
|
|
105
91
|
}
|
|
106
|
-
|
|
107
92
|
if (e.body) {
|
|
108
93
|
for (const key of Object.keys(e.body)) {
|
|
109
94
|
if (key === 'password') {
|
|
@@ -112,7 +97,6 @@ class LoggerController extends _AdaptableController.default {
|
|
|
112
97
|
}
|
|
113
98
|
}
|
|
114
99
|
}
|
|
115
|
-
|
|
116
100
|
if (e.params) {
|
|
117
101
|
for (const key of Object.keys(e.params)) {
|
|
118
102
|
if (key === 'password') {
|
|
@@ -121,11 +105,9 @@ class LoggerController extends _AdaptableController.default {
|
|
|
121
105
|
}
|
|
122
106
|
}
|
|
123
107
|
}
|
|
124
|
-
|
|
125
108
|
return e;
|
|
126
109
|
});
|
|
127
110
|
}
|
|
128
|
-
|
|
129
111
|
log(level, args) {
|
|
130
112
|
// make the passed in arguments object an array with the spread operator
|
|
131
113
|
args = this.maskSensitive([...args]);
|
|
@@ -133,36 +115,28 @@ class LoggerController extends _AdaptableController.default {
|
|
|
133
115
|
if (typeof arg === 'function') {
|
|
134
116
|
return arg();
|
|
135
117
|
}
|
|
136
|
-
|
|
137
118
|
return arg;
|
|
138
119
|
}));
|
|
139
120
|
this.adapter.log.apply(this.adapter, args);
|
|
140
121
|
}
|
|
141
|
-
|
|
142
122
|
info() {
|
|
143
123
|
return this.log('info', arguments);
|
|
144
124
|
}
|
|
145
|
-
|
|
146
125
|
error() {
|
|
147
126
|
return this.log('error', arguments);
|
|
148
127
|
}
|
|
149
|
-
|
|
150
128
|
warn() {
|
|
151
129
|
return this.log('warn', arguments);
|
|
152
130
|
}
|
|
153
|
-
|
|
154
131
|
verbose() {
|
|
155
132
|
return this.log('verbose', arguments);
|
|
156
133
|
}
|
|
157
|
-
|
|
158
134
|
debug() {
|
|
159
135
|
return this.log('debug', arguments);
|
|
160
136
|
}
|
|
161
|
-
|
|
162
137
|
silly() {
|
|
163
138
|
return this.log('silly', arguments);
|
|
164
139
|
}
|
|
165
|
-
|
|
166
140
|
logRequest({
|
|
167
141
|
method,
|
|
168
142
|
url,
|
|
@@ -179,7 +153,6 @@ class LoggerController extends _AdaptableController.default {
|
|
|
179
153
|
body
|
|
180
154
|
});
|
|
181
155
|
}
|
|
182
|
-
|
|
183
156
|
logResponse({
|
|
184
157
|
method,
|
|
185
158
|
url,
|
|
@@ -191,32 +164,25 @@ class LoggerController extends _AdaptableController.default {
|
|
|
191
164
|
}, {
|
|
192
165
|
result: result
|
|
193
166
|
});
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
|
|
167
|
+
}
|
|
168
|
+
// check that date input is valid
|
|
197
169
|
static validDateTime(date) {
|
|
198
170
|
if (!date) {
|
|
199
171
|
return null;
|
|
200
172
|
}
|
|
201
|
-
|
|
202
173
|
date = new Date(date);
|
|
203
|
-
|
|
204
174
|
if (!isNaN(date.getTime())) {
|
|
205
175
|
return date;
|
|
206
176
|
}
|
|
207
|
-
|
|
208
177
|
return null;
|
|
209
178
|
}
|
|
210
|
-
|
|
211
179
|
truncateLogMessage(string) {
|
|
212
180
|
if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {
|
|
213
181
|
const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;
|
|
214
182
|
return truncated;
|
|
215
183
|
}
|
|
216
|
-
|
|
217
184
|
return string;
|
|
218
185
|
}
|
|
219
|
-
|
|
220
186
|
static parseOptions(options = {}) {
|
|
221
187
|
const from = LoggerController.validDateTime(options.from) || new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);
|
|
222
188
|
const until = LoggerController.validDateTime(options.until) || new Date();
|
|
@@ -230,35 +196,30 @@ class LoggerController extends _AdaptableController.default {
|
|
|
230
196
|
order,
|
|
231
197
|
level
|
|
232
198
|
};
|
|
233
|
-
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
// Returns a promise for a {response} object.
|
|
234
202
|
// query params:
|
|
235
203
|
// level (optional) Level of logging you want to query for (info || error)
|
|
236
204
|
// from (optional) Start time for the search. Defaults to 1 week ago.
|
|
237
205
|
// until (optional) End time for the search. Defaults to current time.
|
|
238
206
|
// order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.
|
|
239
207
|
// size (optional) Number of rows returned by search. Defaults to 10
|
|
240
|
-
|
|
241
|
-
|
|
242
208
|
getLogs(options = {}) {
|
|
243
209
|
if (!this.adapter) {
|
|
244
210
|
throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not available');
|
|
245
211
|
}
|
|
246
|
-
|
|
247
212
|
if (typeof this.adapter.query !== 'function') {
|
|
248
213
|
throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Querying logs is not supported with this adapter');
|
|
249
214
|
}
|
|
250
|
-
|
|
251
215
|
options = LoggerController.parseOptions(options);
|
|
252
216
|
return this.adapter.query(options);
|
|
253
217
|
}
|
|
254
|
-
|
|
255
218
|
expectedAdapterType() {
|
|
256
219
|
return _LoggerAdapter.LoggerAdapter;
|
|
257
220
|
}
|
|
258
|
-
|
|
259
221
|
}
|
|
260
|
-
|
|
261
222
|
exports.LoggerController = LoggerController;
|
|
262
223
|
var _default = LoggerController;
|
|
263
224
|
exports.default = _default;
|
|
264
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/LoggerController.js"],"names":["MILLISECONDS_IN_A_DAY","LOG_STRING_TRUNCATE_LENGTH","truncationMarker","LogLevel","INFO","ERROR","LogOrder","DESCENDING","ASCENDING","logLevels","LoggerController","AdaptableController","constructor","adapter","appId","options","logLevel","level","verbose","index","indexOf","forEach","levelIndex","maskSensitiveUrl","path","urlString","urlObj","URL","query","searchParams","sanitizedQuery","key","value","slice","pathname","maskSensitive","argArray","map","e","replace","url","Array","isArray","item","body","Object","keys","params","log","args","concat","arg","apply","info","arguments","error","warn","debug","silly","logRequest","method","headers","stringifiedBody","JSON","stringify","logResponse","result","stringifiedResponse","validDateTime","date","Date","isNaN","getTime","truncateLogMessage","string","length","truncated","substring","parseOptions","from","now","until","size","Number","order","getLogs","Parse","Error","PUSH_MISCONFIGURED","expectedAdapterType","LoggerAdapter"],"mappings":"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","sourcesContent":["import { Parse } from 'parse/node';\nimport AdaptableController from './AdaptableController';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\n\nconst MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;\nconst LOG_STRING_TRUNCATE_LENGTH = 1000;\nconst truncationMarker = '... (truncated)';\n\nexport const LogLevel = {\n  INFO: 'info',\n  ERROR: 'error',\n};\n\nexport const LogOrder = {\n  DESCENDING: 'desc',\n  ASCENDING: 'asc',\n};\n\nconst logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];\n\nexport class LoggerController extends AdaptableController {\n  constructor(adapter, appId, options = { logLevel: 'info' }) {\n    super(adapter, appId, options);\n    let level = 'info';\n    if (options.verbose) {\n      level = 'verbose';\n    }\n    if (options.logLevel) {\n      level = options.logLevel;\n    }\n    const index = logLevels.indexOf(level); // info by default\n    logLevels.forEach((level, levelIndex) => {\n      if (levelIndex > index) {\n        // silence the levels that are > maxIndex\n        this[level] = () => {};\n      }\n    });\n  }\n\n  maskSensitiveUrl(path) {\n    const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL\n    const urlObj = new URL(urlString);\n    const query = urlObj.searchParams;\n    let sanitizedQuery = '?';\n\n    for (const [key, value] of query) {\n      if (key !== 'password') {\n        // normal value\n        sanitizedQuery += key + '=' + value + '&';\n      } else {\n        // password value, redact it\n        sanitizedQuery += key + '=' + '********' + '&';\n      }\n    }\n\n    // trim last character, ? or &\n    sanitizedQuery = sanitizedQuery.slice(0, -1);\n\n    // return original path name with sanitized params attached\n    return urlObj.pathname + sanitizedQuery;\n  }\n\n  maskSensitive(argArray) {\n    return argArray.map(e => {\n      if (!e) {\n        return e;\n      }\n\n      if (typeof e === 'string') {\n        return e.replace(/(password\".?:.?\")[^\"]*\"/g, '$1********\"');\n      }\n      // else it is an object...\n\n      // check the url\n      if (e.url) {\n        // for strings\n        if (typeof e.url === 'string') {\n          e.url = this.maskSensitiveUrl(e.url);\n        } else if (Array.isArray(e.url)) {\n          // for strings in array\n          e.url = e.url.map(item => {\n            if (typeof item === 'string') {\n              return this.maskSensitiveUrl(item);\n            }\n\n            return item;\n          });\n        }\n      }\n\n      if (e.body) {\n        for (const key of Object.keys(e.body)) {\n          if (key === 'password') {\n            e.body[key] = '********';\n            break;\n          }\n        }\n      }\n\n      if (e.params) {\n        for (const key of Object.keys(e.params)) {\n          if (key === 'password') {\n            e.params[key] = '********';\n            break;\n          }\n        }\n      }\n\n      return e;\n    });\n  }\n\n  log(level, args) {\n    // make the passed in arguments object an array with the spread operator\n    args = this.maskSensitive([...args]);\n    args = [].concat(\n      level,\n      args.map(arg => {\n        if (typeof arg === 'function') {\n          return arg();\n        }\n        return arg;\n      })\n    );\n    this.adapter.log.apply(this.adapter, args);\n  }\n\n  info() {\n    return this.log('info', arguments);\n  }\n\n  error() {\n    return this.log('error', arguments);\n  }\n\n  warn() {\n    return this.log('warn', arguments);\n  }\n\n  verbose() {\n    return this.log('verbose', arguments);\n  }\n\n  debug() {\n    return this.log('debug', arguments);\n  }\n\n  silly() {\n    return this.log('silly', arguments);\n  }\n\n  logRequest({ method, url, headers, body }) {\n    this.verbose(\n      () => {\n        const stringifiedBody = JSON.stringify(body, null, 2);\n        return `REQUEST for [${method}] ${url}: ${stringifiedBody}`;\n      },\n      {\n        method,\n        url,\n        headers,\n        body,\n      }\n    );\n  }\n\n  logResponse({ method, url, result }) {\n    this.verbose(\n      () => {\n        const stringifiedResponse = JSON.stringify(result, null, 2);\n        return `RESPONSE from [${method}] ${url}: ${stringifiedResponse}`;\n      },\n      { result: result }\n    );\n  }\n  // check that date input is valid\n  static validDateTime(date) {\n    if (!date) {\n      return null;\n    }\n    date = new Date(date);\n\n    if (!isNaN(date.getTime())) {\n      return date;\n    }\n\n    return null;\n  }\n\n  truncateLogMessage(string) {\n    if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {\n      const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;\n      return truncated;\n    }\n\n    return string;\n  }\n\n  static parseOptions(options = {}) {\n    const from =\n      LoggerController.validDateTime(options.from) ||\n      new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);\n    const until = LoggerController.validDateTime(options.until) || new Date();\n    const size = Number(options.size) || 10;\n    const order = options.order || LogOrder.DESCENDING;\n    const level = options.level || LogLevel.INFO;\n\n    return {\n      from,\n      until,\n      size,\n      order,\n      level,\n    };\n  }\n\n  // Returns a promise for a {response} object.\n  // query params:\n  // level (optional) Level of logging you want to query for (info || error)\n  // from (optional) Start time for the search. Defaults to 1 week ago.\n  // until (optional) End time for the search. Defaults to current time.\n  // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.\n  // size (optional) Number of rows returned by search. Defaults to 10\n  getLogs(options = {}) {\n    if (!this.adapter) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not available');\n    }\n    if (typeof this.adapter.query !== 'function') {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Querying logs is not supported with this adapter'\n      );\n    }\n    options = LoggerController.parseOptions(options);\n    return this.adapter.query(options);\n  }\n\n  expectedAdapterType() {\n    return LoggerAdapter;\n  }\n}\n\nexport default LoggerController;\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["MILLISECONDS_IN_A_DAY","LOG_STRING_TRUNCATE_LENGTH","truncationMarker","LogLevel","INFO","ERROR","LogOrder","DESCENDING","ASCENDING","logLevels","LoggerController","AdaptableController","constructor","adapter","appId","options","logLevel","level","verbose","index","indexOf","forEach","levelIndex","maskSensitiveUrl","path","urlString","urlObj","URL","query","searchParams","sanitizedQuery","key","value","slice","pathname","maskSensitive","argArray","map","e","replace","url","Array","isArray","item","body","Object","keys","params","log","args","concat","arg","apply","info","arguments","error","warn","debug","silly","logRequest","method","headers","stringifiedBody","JSON","stringify","logResponse","result","stringifiedResponse","validDateTime","date","Date","isNaN","getTime","truncateLogMessage","string","length","truncated","substring","parseOptions","from","now","until","size","Number","order","getLogs","Parse","Error","PUSH_MISCONFIGURED","expectedAdapterType","LoggerAdapter"],"sources":["../../src/Controllers/LoggerController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport AdaptableController from './AdaptableController';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\n\nconst MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;\nconst LOG_STRING_TRUNCATE_LENGTH = 1000;\nconst truncationMarker = '... (truncated)';\n\nexport const LogLevel = {\n  INFO: 'info',\n  ERROR: 'error',\n};\n\nexport const LogOrder = {\n  DESCENDING: 'desc',\n  ASCENDING: 'asc',\n};\n\nexport const logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];\n\nexport class LoggerController extends AdaptableController {\n  constructor(adapter, appId, options = { logLevel: 'info' }) {\n    super(adapter, appId, options);\n    let level = 'info';\n    if (options.verbose) {\n      level = 'verbose';\n    }\n    if (options.logLevel) {\n      level = options.logLevel;\n    }\n    const index = logLevels.indexOf(level); // info by default\n    logLevels.forEach((level, levelIndex) => {\n      if (levelIndex > index) {\n        // silence the levels that are > maxIndex\n        this[level] = () => {};\n      }\n    });\n  }\n\n  maskSensitiveUrl(path) {\n    const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL\n    const urlObj = new URL(urlString);\n    const query = urlObj.searchParams;\n    let sanitizedQuery = '?';\n\n    for (const [key, value] of query) {\n      if (key !== 'password') {\n        // normal value\n        sanitizedQuery += key + '=' + value + '&';\n      } else {\n        // password value, redact it\n        sanitizedQuery += key + '=' + '********' + '&';\n      }\n    }\n\n    // trim last character, ? or &\n    sanitizedQuery = sanitizedQuery.slice(0, -1);\n\n    // return original path name with sanitized params attached\n    return urlObj.pathname + sanitizedQuery;\n  }\n\n  maskSensitive(argArray) {\n    return argArray.map(e => {\n      if (!e) {\n        return e;\n      }\n\n      if (typeof e === 'string') {\n        return e.replace(/(password\".?:.?\")[^\"]*\"/g, '$1********\"');\n      }\n      // else it is an object...\n\n      // check the url\n      if (e.url) {\n        // for strings\n        if (typeof e.url === 'string') {\n          e.url = this.maskSensitiveUrl(e.url);\n        } else if (Array.isArray(e.url)) {\n          // for strings in array\n          e.url = e.url.map(item => {\n            if (typeof item === 'string') {\n              return this.maskSensitiveUrl(item);\n            }\n\n            return item;\n          });\n        }\n      }\n\n      if (e.body) {\n        for (const key of Object.keys(e.body)) {\n          if (key === 'password') {\n            e.body[key] = '********';\n            break;\n          }\n        }\n      }\n\n      if (e.params) {\n        for (const key of Object.keys(e.params)) {\n          if (key === 'password') {\n            e.params[key] = '********';\n            break;\n          }\n        }\n      }\n\n      return e;\n    });\n  }\n\n  log(level, args) {\n    // make the passed in arguments object an array with the spread operator\n    args = this.maskSensitive([...args]);\n    args = [].concat(\n      level,\n      args.map(arg => {\n        if (typeof arg === 'function') {\n          return arg();\n        }\n        return arg;\n      })\n    );\n    this.adapter.log.apply(this.adapter, args);\n  }\n\n  info() {\n    return this.log('info', arguments);\n  }\n\n  error() {\n    return this.log('error', arguments);\n  }\n\n  warn() {\n    return this.log('warn', arguments);\n  }\n\n  verbose() {\n    return this.log('verbose', arguments);\n  }\n\n  debug() {\n    return this.log('debug', arguments);\n  }\n\n  silly() {\n    return this.log('silly', arguments);\n  }\n\n  logRequest({ method, url, headers, body }) {\n    this.verbose(\n      () => {\n        const stringifiedBody = JSON.stringify(body, null, 2);\n        return `REQUEST for [${method}] ${url}: ${stringifiedBody}`;\n      },\n      {\n        method,\n        url,\n        headers,\n        body,\n      }\n    );\n  }\n\n  logResponse({ method, url, result }) {\n    this.verbose(\n      () => {\n        const stringifiedResponse = JSON.stringify(result, null, 2);\n        return `RESPONSE from [${method}] ${url}: ${stringifiedResponse}`;\n      },\n      { result: result }\n    );\n  }\n  // check that date input is valid\n  static validDateTime(date) {\n    if (!date) {\n      return null;\n    }\n    date = new Date(date);\n\n    if (!isNaN(date.getTime())) {\n      return date;\n    }\n\n    return null;\n  }\n\n  truncateLogMessage(string) {\n    if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {\n      const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;\n      return truncated;\n    }\n\n    return string;\n  }\n\n  static parseOptions(options = {}) {\n    const from =\n      LoggerController.validDateTime(options.from) ||\n      new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);\n    const until = LoggerController.validDateTime(options.until) || new Date();\n    const size = Number(options.size) || 10;\n    const order = options.order || LogOrder.DESCENDING;\n    const level = options.level || LogLevel.INFO;\n\n    return {\n      from,\n      until,\n      size,\n      order,\n      level,\n    };\n  }\n\n  // Returns a promise for a {response} object.\n  // query params:\n  // level (optional) Level of logging you want to query for (info || error)\n  // from (optional) Start time for the search. Defaults to 1 week ago.\n  // until (optional) End time for the search. Defaults to current time.\n  // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.\n  // size (optional) Number of rows returned by search. Defaults to 10\n  getLogs(options = {}) {\n    if (!this.adapter) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not available');\n    }\n    if (typeof this.adapter.query !== 'function') {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Querying logs is not supported with this adapter'\n      );\n    }\n    options = LoggerController.parseOptions(options);\n    return this.adapter.query(options);\n  }\n\n  expectedAdapterType() {\n    return LoggerAdapter;\n  }\n}\n\nexport default LoggerController;\n"],"mappings":";;;;;;AAAA;AACA;AACA;AAAiE;AAEjE,MAAMA,qBAAqB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;AACjD,MAAMC,0BAA0B,GAAG,IAAI;AACvC,MAAMC,gBAAgB,GAAG,iBAAiB;AAEnC,MAAMC,QAAQ,GAAG;EACtBC,IAAI,EAAE,MAAM;EACZC,KAAK,EAAE;AACT,CAAC;AAAC;AAEK,MAAMC,QAAQ,GAAG;EACtBC,UAAU,EAAE,MAAM;EAClBC,SAAS,EAAE;AACb,CAAC;AAAC;AAEK,MAAMC,SAAS,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC;AAAC;AAEzE,MAAMC,gBAAgB,SAASC,4BAAmB,CAAC;EACxDC,WAAW,CAACC,OAAO,EAAEC,KAAK,EAAEC,OAAO,GAAG;IAAEC,QAAQ,EAAE;EAAO,CAAC,EAAE;IAC1D,KAAK,CAACH,OAAO,EAAEC,KAAK,EAAEC,OAAO,CAAC;IAC9B,IAAIE,KAAK,GAAG,MAAM;IAClB,IAAIF,OAAO,CAACG,OAAO,EAAE;MACnBD,KAAK,GAAG,SAAS;IACnB;IACA,IAAIF,OAAO,CAACC,QAAQ,EAAE;MACpBC,KAAK,GAAGF,OAAO,CAACC,QAAQ;IAC1B;IACA,MAAMG,KAAK,GAAGV,SAAS,CAACW,OAAO,CAACH,KAAK,CAAC,CAAC,CAAC;IACxCR,SAAS,CAACY,OAAO,CAAC,CAACJ,KAAK,EAAEK,UAAU,KAAK;MACvC,IAAIA,UAAU,GAAGH,KAAK,EAAE;QACtB;QACA,IAAI,CAACF,KAAK,CAAC,GAAG,MAAM,CAAC,CAAC;MACxB;IACF,CAAC,CAAC;EACJ;EAEAM,gBAAgB,CAACC,IAAI,EAAE;IACrB,MAAMC,SAAS,GAAG,kBAAkB,GAAGD,IAAI,CAAC,CAAC;IAC7C,MAAME,MAAM,GAAG,IAAIC,GAAG,CAACF,SAAS,CAAC;IACjC,MAAMG,KAAK,GAAGF,MAAM,CAACG,YAAY;IACjC,IAAIC,cAAc,GAAG,GAAG;IAExB,KAAK,MAAM,CAACC,GAAG,EAAEC,KAAK,CAAC,IAAIJ,KAAK,EAAE;MAChC,IAAIG,GAAG,KAAK,UAAU,EAAE;QACtB;QACAD,cAAc,IAAIC,GAAG,GAAG,GAAG,GAAGC,KAAK,GAAG,GAAG;MAC3C,CAAC,MAAM;QACL;QACAF,cAAc,IAAIC,GAAG,GAAG,GAAG,GAAG,UAAU,GAAG,GAAG;MAChD;IACF;;IAEA;IACAD,cAAc,GAAGA,cAAc,CAACG,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;;IAE5C;IACA,OAAOP,MAAM,CAACQ,QAAQ,GAAGJ,cAAc;EACzC;EAEAK,aAAa,CAACC,QAAQ,EAAE;IACtB,OAAOA,QAAQ,CAACC,GAAG,CAACC,CAAC,IAAI;MACvB,IAAI,CAACA,CAAC,EAAE;QACN,OAAOA,CAAC;MACV;MAEA,IAAI,OAAOA,CAAC,KAAK,QAAQ,EAAE;QACzB,OAAOA,CAAC,CAACC,OAAO,CAAC,0BAA0B,EAAE,aAAa,CAAC;MAC7D;MACA;;MAEA;MACA,IAAID,CAAC,CAACE,GAAG,EAAE;QACT;QACA,IAAI,OAAOF,CAAC,CAACE,GAAG,KAAK,QAAQ,EAAE;UAC7BF,CAAC,CAACE,GAAG,GAAG,IAAI,CAACjB,gBAAgB,CAACe,CAAC,CAACE,GAAG,CAAC;QACtC,CAAC,MAAM,IAAIC,KAAK,CAACC,OAAO,CAACJ,CAAC,CAACE,GAAG,CAAC,EAAE;UAC/B;UACAF,CAAC,CAACE,GAAG,GAAGF,CAAC,CAACE,GAAG,CAACH,GAAG,CAACM,IAAI,IAAI;YACxB,IAAI,OAAOA,IAAI,KAAK,QAAQ,EAAE;cAC5B,OAAO,IAAI,CAACpB,gBAAgB,CAACoB,IAAI,CAAC;YACpC;YAEA,OAAOA,IAAI;UACb,CAAC,CAAC;QACJ;MACF;MAEA,IAAIL,CAAC,CAACM,IAAI,EAAE;QACV,KAAK,MAAMb,GAAG,IAAIc,MAAM,CAACC,IAAI,CAACR,CAAC,CAACM,IAAI,CAAC,EAAE;UACrC,IAAIb,GAAG,KAAK,UAAU,EAAE;YACtBO,CAAC,CAACM,IAAI,CAACb,GAAG,CAAC,GAAG,UAAU;YACxB;UACF;QACF;MACF;MAEA,IAAIO,CAAC,CAACS,MAAM,EAAE;QACZ,KAAK,MAAMhB,GAAG,IAAIc,MAAM,CAACC,IAAI,CAACR,CAAC,CAACS,MAAM,CAAC,EAAE;UACvC,IAAIhB,GAAG,KAAK,UAAU,EAAE;YACtBO,CAAC,CAACS,MAAM,CAAChB,GAAG,CAAC,GAAG,UAAU;YAC1B;UACF;QACF;MACF;MAEA,OAAOO,CAAC;IACV,CAAC,CAAC;EACJ;EAEAU,GAAG,CAAC/B,KAAK,EAAEgC,IAAI,EAAE;IACf;IACAA,IAAI,GAAG,IAAI,CAACd,aAAa,CAAC,CAAC,GAAGc,IAAI,CAAC,CAAC;IACpCA,IAAI,GAAG,EAAE,CAACC,MAAM,CACdjC,KAAK,EACLgC,IAAI,CAACZ,GAAG,CAACc,GAAG,IAAI;MACd,IAAI,OAAOA,GAAG,KAAK,UAAU,EAAE;QAC7B,OAAOA,GAAG,EAAE;MACd;MACA,OAAOA,GAAG;IACZ,CAAC,CAAC,CACH;IACD,IAAI,CAACtC,OAAO,CAACmC,GAAG,CAACI,KAAK,CAAC,IAAI,CAACvC,OAAO,EAAEoC,IAAI,CAAC;EAC5C;EAEAI,IAAI,GAAG;IACL,OAAO,IAAI,CAACL,GAAG,CAAC,MAAM,EAAEM,SAAS,CAAC;EACpC;EAEAC,KAAK,GAAG;IACN,OAAO,IAAI,CAACP,GAAG,CAAC,OAAO,EAAEM,SAAS,CAAC;EACrC;EAEAE,IAAI,GAAG;IACL,OAAO,IAAI,CAACR,GAAG,CAAC,MAAM,EAAEM,SAAS,CAAC;EACpC;EAEApC,OAAO,GAAG;IACR,OAAO,IAAI,CAAC8B,GAAG,CAAC,SAAS,EAAEM,SAAS,CAAC;EACvC;EAEAG,KAAK,GAAG;IACN,OAAO,IAAI,CAACT,GAAG,CAAC,OAAO,EAAEM,SAAS,CAAC;EACrC;EAEAI,KAAK,GAAG;IACN,OAAO,IAAI,CAACV,GAAG,CAAC,OAAO,EAAEM,SAAS,CAAC;EACrC;EAEAK,UAAU,CAAC;IAAEC,MAAM;IAAEpB,GAAG;IAAEqB,OAAO;IAAEjB;EAAK,CAAC,EAAE;IACzC,IAAI,CAAC1B,OAAO,CACV,MAAM;MACJ,MAAM4C,eAAe,GAAGC,IAAI,CAACC,SAAS,CAACpB,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;MACrD,OAAQ,gBAAegB,MAAO,KAAIpB,GAAI,KAAIsB,eAAgB,EAAC;IAC7D,CAAC,EACD;MACEF,MAAM;MACNpB,GAAG;MACHqB,OAAO;MACPjB;IACF,CAAC,CACF;EACH;EAEAqB,WAAW,CAAC;IAAEL,MAAM;IAAEpB,GAAG;IAAE0B;EAAO,CAAC,EAAE;IACnC,IAAI,CAAChD,OAAO,CACV,MAAM;MACJ,MAAMiD,mBAAmB,GAAGJ,IAAI,CAACC,SAAS,CAACE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;MAC3D,OAAQ,kBAAiBN,MAAO,KAAIpB,GAAI,KAAI2B,mBAAoB,EAAC;IACnE,CAAC,EACD;MAAED,MAAM,EAAEA;IAAO,CAAC,CACnB;EACH;EACA;EACA,OAAOE,aAAa,CAACC,IAAI,EAAE;IACzB,IAAI,CAACA,IAAI,EAAE;MACT,OAAO,IAAI;IACb;IACAA,IAAI,GAAG,IAAIC,IAAI,CAACD,IAAI,CAAC;IAErB,IAAI,CAACE,KAAK,CAACF,IAAI,CAACG,OAAO,EAAE,CAAC,EAAE;MAC1B,OAAOH,IAAI;IACb;IAEA,OAAO,IAAI;EACb;EAEAI,kBAAkB,CAACC,MAAM,EAAE;IACzB,IAAIA,MAAM,IAAIA,MAAM,CAACC,MAAM,GAAG1E,0BAA0B,EAAE;MACxD,MAAM2E,SAAS,GAAGF,MAAM,CAACG,SAAS,CAAC,CAAC,EAAE5E,0BAA0B,CAAC,GAAGC,gBAAgB;MACpF,OAAO0E,SAAS;IAClB;IAEA,OAAOF,MAAM;EACf;EAEA,OAAOI,YAAY,CAAC/D,OAAO,GAAG,CAAC,CAAC,EAAE;IAChC,MAAMgE,IAAI,GACRrE,gBAAgB,CAAC0D,aAAa,CAACrD,OAAO,CAACgE,IAAI,CAAC,IAC5C,IAAIT,IAAI,CAACA,IAAI,CAACU,GAAG,EAAE,GAAG,CAAC,GAAGhF,qBAAqB,CAAC;IAClD,MAAMiF,KAAK,GAAGvE,gBAAgB,CAAC0D,aAAa,CAACrD,OAAO,CAACkE,KAAK,CAAC,IAAI,IAAIX,IAAI,EAAE;IACzE,MAAMY,IAAI,GAAGC,MAAM,CAACpE,OAAO,CAACmE,IAAI,CAAC,IAAI,EAAE;IACvC,MAAME,KAAK,GAAGrE,OAAO,CAACqE,KAAK,IAAI9E,QAAQ,CAACC,UAAU;IAClD,MAAMU,KAAK,GAAGF,OAAO,CAACE,KAAK,IAAId,QAAQ,CAACC,IAAI;IAE5C,OAAO;MACL2E,IAAI;MACJE,KAAK;MACLC,IAAI;MACJE,KAAK;MACLnE;IACF,CAAC;EACH;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACAoE,OAAO,CAACtE,OAAO,GAAG,CAAC,CAAC,EAAE;IACpB,IAAI,CAAC,IAAI,CAACF,OAAO,EAAE;MACjB,MAAM,IAAIyE,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACC,kBAAkB,EAAE,iCAAiC,CAAC;IAC1F;IACA,IAAI,OAAO,IAAI,CAAC3E,OAAO,CAACe,KAAK,KAAK,UAAU,EAAE;MAC5C,MAAM,IAAI0D,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACC,kBAAkB,EAC9B,kDAAkD,CACnD;IACH;IACAzE,OAAO,GAAGL,gBAAgB,CAACoE,YAAY,CAAC/D,OAAO,CAAC;IAChD,OAAO,IAAI,CAACF,OAAO,CAACe,KAAK,CAACb,OAAO,CAAC;EACpC;EAEA0E,mBAAmB,GAAG;IACpB,OAAOC,4BAAa;EACtB;AACF;AAAC;AAAA,eAEchF,gBAAgB;AAAA"}
|