parse-server 2.8.4 → 8.6.2
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/LICENSE +167 -25
- package/NOTICE +10 -0
- package/README.md +929 -278
- package/lib/AccountLockout.js +47 -30
- package/lib/Adapters/AdapterLoader.js +21 -6
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
- package/lib/Adapters/Auth/AuthAdapter.js +116 -13
- package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
- package/lib/Adapters/Auth/OAuth1Client.js +27 -46
- package/lib/Adapters/Auth/apple.js +123 -0
- package/lib/Adapters/Auth/facebook.js +162 -35
- package/lib/Adapters/Auth/gcenter.js +217 -0
- package/lib/Adapters/Auth/github.js +118 -48
- package/lib/Adapters/Auth/google.js +160 -51
- package/lib/Adapters/Auth/gpgames.js +125 -0
- package/lib/Adapters/Auth/httpsRequest.js +6 -7
- package/lib/Adapters/Auth/index.js +170 -62
- package/lib/Adapters/Auth/instagram.js +114 -40
- package/lib/Adapters/Auth/janraincapture.js +52 -23
- package/lib/Adapters/Auth/janrainengage.js +19 -36
- package/lib/Adapters/Auth/keycloak.js +148 -0
- package/lib/Adapters/Auth/ldap.js +167 -0
- package/lib/Adapters/Auth/line.js +125 -0
- package/lib/Adapters/Auth/linkedin.js +111 -55
- package/lib/Adapters/Auth/meetup.js +24 -34
- package/lib/Adapters/Auth/mfa.js +324 -0
- package/lib/Adapters/Auth/microsoft.js +111 -0
- package/lib/Adapters/Auth/oauth2.js +97 -162
- package/lib/Adapters/Auth/phantauth.js +53 -0
- package/lib/Adapters/Auth/qq.js +108 -49
- package/lib/Adapters/Auth/spotify.js +107 -55
- package/lib/Adapters/Auth/twitter.js +188 -48
- package/lib/Adapters/Auth/utils.js +28 -0
- package/lib/Adapters/Auth/vkontakte.js +26 -39
- package/lib/Adapters/Auth/wechat.js +106 -44
- package/lib/Adapters/Auth/weibo.js +132 -58
- package/lib/Adapters/Cache/CacheAdapter.js +13 -8
- package/lib/Adapters/Cache/InMemoryCache.js +3 -13
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
- package/lib/Adapters/Cache/LRUCache.js +13 -27
- package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
- package/lib/Adapters/Cache/SchemaCache.js +25 -0
- package/lib/Adapters/Email/MailAdapter.js +10 -8
- package/lib/Adapters/Files/FilesAdapter.js +83 -25
- package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
- package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
- package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
- package/lib/Adapters/Logger/WinstonLogger.js +69 -88
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
- package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
- package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
- package/lib/Adapters/Push/PushAdapter.js +14 -7
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
- package/lib/Auth.js +488 -125
- package/lib/ClientSDK.js +2 -6
- package/lib/Config.js +525 -94
- package/lib/Controllers/AdaptableController.js +5 -25
- package/lib/Controllers/AnalyticsController.js +22 -23
- package/lib/Controllers/CacheController.js +10 -31
- package/lib/Controllers/DatabaseController.js +767 -313
- package/lib/Controllers/FilesController.js +49 -54
- package/lib/Controllers/HooksController.js +80 -84
- package/lib/Controllers/LiveQueryController.js +35 -22
- package/lib/Controllers/LoggerController.js +22 -58
- package/lib/Controllers/ParseGraphQLController.js +293 -0
- package/lib/Controllers/PushController.js +58 -49
- package/lib/Controllers/SchemaController.js +916 -422
- package/lib/Controllers/UserController.js +265 -180
- package/lib/Controllers/index.js +90 -125
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +30 -0
- package/lib/Deprecator/Deprecator.js +127 -0
- package/lib/Error.js +48 -0
- package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
- package/lib/GraphQL/ParseGraphQLServer.js +214 -0
- package/lib/GraphQL/helpers/objectsMutations.js +30 -0
- package/lib/GraphQL/helpers/objectsQueries.js +246 -0
- package/lib/GraphQL/loaders/configMutations.js +87 -0
- package/lib/GraphQL/loaders/configQueries.js +79 -0
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
- package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
- package/lib/GraphQL/loaders/filesMutations.js +107 -0
- package/lib/GraphQL/loaders/functionsMutations.js +78 -0
- package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
- package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
- package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
- package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
- package/lib/GraphQL/loaders/schemaMutations.js +162 -0
- package/lib/GraphQL/loaders/schemaQueries.js +81 -0
- package/lib/GraphQL/loaders/schemaTypes.js +341 -0
- package/lib/GraphQL/loaders/usersMutations.js +433 -0
- package/lib/GraphQL/loaders/usersQueries.js +90 -0
- package/lib/GraphQL/parseGraphQLUtils.js +63 -0
- package/lib/GraphQL/transformers/className.js +14 -0
- package/lib/GraphQL/transformers/constraintType.js +53 -0
- package/lib/GraphQL/transformers/inputType.js +51 -0
- package/lib/GraphQL/transformers/mutation.js +274 -0
- package/lib/GraphQL/transformers/outputType.js +51 -0
- package/lib/GraphQL/transformers/query.js +237 -0
- package/lib/GraphQL/transformers/schemaFields.js +99 -0
- package/lib/KeyPromiseQueue.js +48 -0
- package/lib/LiveQuery/Client.js +25 -33
- package/lib/LiveQuery/Id.js +2 -5
- package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
- package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
- package/lib/LiveQuery/ParsePubSub.js +7 -16
- package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
- package/lib/LiveQuery/QueryTools.js +76 -15
- package/lib/LiveQuery/RequestSchema.js +111 -97
- package/lib/LiveQuery/SessionTokenCache.js +23 -36
- package/lib/LiveQuery/Subscription.js +8 -17
- package/lib/LiveQuery/equalObjects.js +2 -3
- package/lib/Options/Definitions.js +1355 -382
- package/lib/Options/docs.js +301 -62
- package/lib/Options/index.js +11 -1
- package/lib/Options/parsers.js +14 -10
- package/lib/Page.js +44 -0
- package/lib/ParseMessageQueue.js +6 -13
- package/lib/ParseServer.js +474 -235
- package/lib/ParseServerRESTController.js +102 -40
- package/lib/PromiseRouter.js +39 -50
- package/lib/Push/PushQueue.js +24 -30
- package/lib/Push/PushWorker.js +32 -56
- package/lib/Push/utils.js +22 -35
- package/lib/RestQuery.js +361 -139
- package/lib/RestWrite.js +713 -344
- package/lib/Routers/AggregateRouter.js +97 -71
- package/lib/Routers/AnalyticsRouter.js +8 -14
- package/lib/Routers/AudiencesRouter.js +16 -35
- package/lib/Routers/ClassesRouter.js +86 -72
- package/lib/Routers/CloudCodeRouter.js +28 -37
- package/lib/Routers/FeaturesRouter.js +22 -25
- package/lib/Routers/FilesRouter.js +266 -171
- package/lib/Routers/FunctionsRouter.js +87 -103
- package/lib/Routers/GlobalConfigRouter.js +94 -33
- package/lib/Routers/GraphQLRouter.js +41 -0
- package/lib/Routers/HooksRouter.js +43 -47
- package/lib/Routers/IAPValidationRouter.js +57 -70
- package/lib/Routers/InstallationsRouter.js +17 -25
- package/lib/Routers/LogsRouter.js +10 -25
- package/lib/Routers/PagesRouter.js +647 -0
- package/lib/Routers/PublicAPIRouter.js +104 -112
- package/lib/Routers/PurgeRouter.js +19 -29
- package/lib/Routers/PushRouter.js +14 -28
- package/lib/Routers/RolesRouter.js +7 -14
- package/lib/Routers/SchemasRouter.js +63 -42
- package/lib/Routers/SecurityRouter.js +34 -0
- package/lib/Routers/SessionsRouter.js +25 -38
- package/lib/Routers/UsersRouter.js +463 -190
- package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
- package/lib/SchemaMigrations/Migrations.js +30 -0
- package/lib/Security/Check.js +109 -0
- package/lib/Security/CheckGroup.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
- package/lib/Security/CheckGroups/CheckGroups.js +21 -0
- package/lib/Security/CheckRunner.js +213 -0
- package/lib/SharedRest.js +29 -0
- package/lib/StatusHandler.js +96 -93
- package/lib/TestUtils.js +70 -14
- package/lib/Utils.js +468 -0
- package/lib/batch.js +74 -40
- package/lib/cache.js +8 -8
- package/lib/cli/definitions/parse-live-query-server.js +4 -3
- package/lib/cli/definitions/parse-server.js +4 -3
- package/lib/cli/parse-live-query-server.js +9 -17
- package/lib/cli/parse-server.js +49 -47
- package/lib/cli/utils/commander.js +20 -29
- package/lib/cli/utils/runner.js +31 -32
- package/lib/cloud-code/Parse.Cloud.js +711 -36
- package/lib/cloud-code/Parse.Server.js +21 -0
- package/lib/cryptoUtils.js +6 -11
- package/lib/defaults.js +21 -15
- package/lib/deprecated.js +1 -1
- package/lib/index.js +78 -67
- package/lib/logger.js +12 -20
- package/lib/middlewares.js +484 -160
- package/lib/password.js +10 -6
- package/lib/request.js +175 -0
- package/lib/requiredParameter.js +4 -3
- package/lib/rest.js +157 -82
- package/lib/triggers.js +627 -185
- package/lib/vendor/README.md +3 -3
- package/lib/vendor/mongodbUrl.js +224 -137
- package/package.json +135 -57
- package/postinstall.js +38 -50
- package/public_html/invalid_verification_link.html +3 -3
- package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
- package/types/@types/deepcopy/index.d.ts +5 -0
- package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
- package/types/Options/index.d.ts +301 -0
- package/types/ParseServer.d.ts +65 -0
- package/types/eslint.config.mjs +30 -0
- package/types/index.d.ts +21 -0
- package/types/logger.d.ts +2 -0
- package/types/tests.ts +44 -0
- package/types/tsconfig.json +24 -0
- package/CHANGELOG.md +0 -1246
- package/PATENTS +0 -37
- package/bin/dev +0 -37
- package/lib/.DS_Store +0 -0
- package/lib/Adapters/Auth/common.js +0 -2
- package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
- package/lib/Controllers/SchemaCache.js +0 -97
- package/lib/LiveQuery/.DS_Store +0 -0
- package/lib/cli/utils/parsers.js +0 -77
- package/lib/cloud-code/.DS_Store +0 -0
- package/lib/cloud-code/HTTPResponse.js +0 -57
- package/lib/cloud-code/Untitled-1 +0 -123
- package/lib/cloud-code/httpRequest.js +0 -102
- package/lib/cloud-code/team.html +0 -123
- package/lib/graphql/ParseClass.js +0 -234
- package/lib/graphql/Schema.js +0 -197
- package/lib/graphql/index.js +0 -1
- package/lib/graphql/types/ACL.js +0 -35
- package/lib/graphql/types/Date.js +0 -25
- package/lib/graphql/types/File.js +0 -24
- package/lib/graphql/types/GeoPoint.js +0 -35
- package/lib/graphql/types/JSONObject.js +0 -30
- package/lib/graphql/types/NumberInput.js +0 -43
- package/lib/graphql/types/NumberQuery.js +0 -42
- package/lib/graphql/types/Pointer.js +0 -35
- package/lib/graphql/types/QueryConstraint.js +0 -61
- package/lib/graphql/types/StringQuery.js +0 -39
- package/lib/graphql/types/index.js +0 -110
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.transformQueryInputToParse = exports.transformQueryConstraintInputToParse = void 0;
|
|
7
|
+
var _graphqlRelay = require("graphql-relay");
|
|
8
|
+
const parseQueryMap = {
|
|
9
|
+
OR: '$or',
|
|
10
|
+
AND: '$and',
|
|
11
|
+
NOR: '$nor'
|
|
12
|
+
};
|
|
13
|
+
const parseConstraintMap = {
|
|
14
|
+
equalTo: '$eq',
|
|
15
|
+
notEqualTo: '$ne',
|
|
16
|
+
lessThan: '$lt',
|
|
17
|
+
lessThanOrEqualTo: '$lte',
|
|
18
|
+
greaterThan: '$gt',
|
|
19
|
+
greaterThanOrEqualTo: '$gte',
|
|
20
|
+
in: '$in',
|
|
21
|
+
notIn: '$nin',
|
|
22
|
+
exists: '$exists',
|
|
23
|
+
inQueryKey: '$select',
|
|
24
|
+
notInQueryKey: '$dontSelect',
|
|
25
|
+
inQuery: '$inQuery',
|
|
26
|
+
notInQuery: '$notInQuery',
|
|
27
|
+
containedBy: '$containedBy',
|
|
28
|
+
contains: '$all',
|
|
29
|
+
matchesRegex: '$regex',
|
|
30
|
+
options: '$options',
|
|
31
|
+
text: '$text',
|
|
32
|
+
search: '$search',
|
|
33
|
+
term: '$term',
|
|
34
|
+
language: '$language',
|
|
35
|
+
caseSensitive: '$caseSensitive',
|
|
36
|
+
diacriticSensitive: '$diacriticSensitive',
|
|
37
|
+
nearSphere: '$nearSphere',
|
|
38
|
+
maxDistance: '$maxDistance',
|
|
39
|
+
maxDistanceInRadians: '$maxDistanceInRadians',
|
|
40
|
+
maxDistanceInMiles: '$maxDistanceInMiles',
|
|
41
|
+
maxDistanceInKilometers: '$maxDistanceInKilometers',
|
|
42
|
+
within: '$within',
|
|
43
|
+
box: '$box',
|
|
44
|
+
geoWithin: '$geoWithin',
|
|
45
|
+
polygon: '$polygon',
|
|
46
|
+
centerSphere: '$centerSphere',
|
|
47
|
+
geoIntersects: '$geoIntersects',
|
|
48
|
+
point: '$point'
|
|
49
|
+
};
|
|
50
|
+
const transformQueryConstraintInputToParse = (constraints, parentFieldName, className, parentConstraints, parseClasses) => {
|
|
51
|
+
const fields = parseClasses[className].fields;
|
|
52
|
+
if (parentFieldName === 'id' && className) {
|
|
53
|
+
Object.keys(constraints).forEach(constraintName => {
|
|
54
|
+
const constraintValue = constraints[constraintName];
|
|
55
|
+
if (typeof constraintValue === 'string') {
|
|
56
|
+
const globalIdObject = (0, _graphqlRelay.fromGlobalId)(constraintValue);
|
|
57
|
+
if (globalIdObject.type === className) {
|
|
58
|
+
constraints[constraintName] = globalIdObject.id;
|
|
59
|
+
}
|
|
60
|
+
} else if (Array.isArray(constraintValue)) {
|
|
61
|
+
constraints[constraintName] = constraintValue.map(value => {
|
|
62
|
+
const globalIdObject = (0, _graphqlRelay.fromGlobalId)(value);
|
|
63
|
+
if (globalIdObject.type === className) {
|
|
64
|
+
return globalIdObject.id;
|
|
65
|
+
}
|
|
66
|
+
return value;
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
parentConstraints.objectId = constraints;
|
|
71
|
+
delete parentConstraints.id;
|
|
72
|
+
}
|
|
73
|
+
Object.keys(constraints).forEach(fieldName => {
|
|
74
|
+
let fieldValue = constraints[fieldName];
|
|
75
|
+
if (parseConstraintMap[fieldName]) {
|
|
76
|
+
constraints[parseConstraintMap[fieldName]] = constraints[fieldName];
|
|
77
|
+
delete constraints[fieldName];
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* If we have a key-value pair, we need to change the way the constraint is structured.
|
|
81
|
+
*
|
|
82
|
+
* Example:
|
|
83
|
+
* From:
|
|
84
|
+
* {
|
|
85
|
+
* "someField": {
|
|
86
|
+
* "lessThan": {
|
|
87
|
+
* "key":"foo.bar",
|
|
88
|
+
* "value": 100
|
|
89
|
+
* },
|
|
90
|
+
* "greaterThan": {
|
|
91
|
+
* "key":"foo.bar",
|
|
92
|
+
* "value": 10
|
|
93
|
+
* }
|
|
94
|
+
* }
|
|
95
|
+
* }
|
|
96
|
+
*
|
|
97
|
+
* To:
|
|
98
|
+
* {
|
|
99
|
+
* "someField.foo.bar": {
|
|
100
|
+
* "$lt": 100,
|
|
101
|
+
* "$gt": 10
|
|
102
|
+
* }
|
|
103
|
+
* }
|
|
104
|
+
*/
|
|
105
|
+
if (fieldValue.key && fieldValue.value !== undefined && parentConstraints && parentFieldName) {
|
|
106
|
+
delete parentConstraints[parentFieldName];
|
|
107
|
+
parentConstraints[`${parentFieldName}.${fieldValue.key}`] = {
|
|
108
|
+
...parentConstraints[`${parentFieldName}.${fieldValue.key}`],
|
|
109
|
+
[parseConstraintMap[fieldName]]: fieldValue.value
|
|
110
|
+
};
|
|
111
|
+
} else if (fields[parentFieldName] && (fields[parentFieldName].type === 'Pointer' || fields[parentFieldName].type === 'Relation')) {
|
|
112
|
+
const {
|
|
113
|
+
targetClass
|
|
114
|
+
} = fields[parentFieldName];
|
|
115
|
+
if (fieldName === 'exists') {
|
|
116
|
+
if (fields[parentFieldName].type === 'Relation') {
|
|
117
|
+
const whereTarget = fieldValue ? 'where' : 'notWhere';
|
|
118
|
+
if (constraints[whereTarget]) {
|
|
119
|
+
if (constraints[whereTarget].objectId) {
|
|
120
|
+
constraints[whereTarget].objectId = {
|
|
121
|
+
...constraints[whereTarget].objectId,
|
|
122
|
+
$exists: fieldValue
|
|
123
|
+
};
|
|
124
|
+
} else {
|
|
125
|
+
constraints[whereTarget].objectId = {
|
|
126
|
+
$exists: fieldValue
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
} else {
|
|
130
|
+
const parseWhereTarget = fieldValue ? '$inQuery' : '$notInQuery';
|
|
131
|
+
parentConstraints[parentFieldName][parseWhereTarget] = {
|
|
132
|
+
where: {
|
|
133
|
+
objectId: {
|
|
134
|
+
$exists: true
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
className: targetClass
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
delete constraints.$exists;
|
|
141
|
+
} else {
|
|
142
|
+
parentConstraints[parentFieldName].$exists = fieldValue;
|
|
143
|
+
}
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
switch (fieldName) {
|
|
147
|
+
case 'have':
|
|
148
|
+
parentConstraints[parentFieldName].$inQuery = {
|
|
149
|
+
where: fieldValue,
|
|
150
|
+
className: targetClass
|
|
151
|
+
};
|
|
152
|
+
transformQueryInputToParse(parentConstraints[parentFieldName].$inQuery.where, targetClass, parseClasses);
|
|
153
|
+
break;
|
|
154
|
+
case 'haveNot':
|
|
155
|
+
parentConstraints[parentFieldName].$notInQuery = {
|
|
156
|
+
where: fieldValue,
|
|
157
|
+
className: targetClass
|
|
158
|
+
};
|
|
159
|
+
transformQueryInputToParse(parentConstraints[parentFieldName].$notInQuery.where, targetClass, parseClasses);
|
|
160
|
+
break;
|
|
161
|
+
}
|
|
162
|
+
delete constraints[fieldName];
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
switch (fieldName) {
|
|
166
|
+
case 'point':
|
|
167
|
+
if (typeof fieldValue === 'object' && !fieldValue.__type) {
|
|
168
|
+
fieldValue.__type = 'GeoPoint';
|
|
169
|
+
}
|
|
170
|
+
break;
|
|
171
|
+
case 'nearSphere':
|
|
172
|
+
if (typeof fieldValue === 'object' && !fieldValue.__type) {
|
|
173
|
+
fieldValue.__type = 'GeoPoint';
|
|
174
|
+
}
|
|
175
|
+
break;
|
|
176
|
+
case 'box':
|
|
177
|
+
if (typeof fieldValue === 'object' && fieldValue.bottomLeft && fieldValue.upperRight) {
|
|
178
|
+
fieldValue = [{
|
|
179
|
+
__type: 'GeoPoint',
|
|
180
|
+
...fieldValue.bottomLeft
|
|
181
|
+
}, {
|
|
182
|
+
__type: 'GeoPoint',
|
|
183
|
+
...fieldValue.upperRight
|
|
184
|
+
}];
|
|
185
|
+
constraints[parseConstraintMap[fieldName]] = fieldValue;
|
|
186
|
+
}
|
|
187
|
+
break;
|
|
188
|
+
case 'polygon':
|
|
189
|
+
if (fieldValue instanceof Array) {
|
|
190
|
+
fieldValue.forEach(geoPoint => {
|
|
191
|
+
if (typeof geoPoint === 'object' && !geoPoint.__type) {
|
|
192
|
+
geoPoint.__type = 'GeoPoint';
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
break;
|
|
197
|
+
case 'centerSphere':
|
|
198
|
+
if (typeof fieldValue === 'object' && fieldValue.center && fieldValue.distance) {
|
|
199
|
+
fieldValue = [{
|
|
200
|
+
__type: 'GeoPoint',
|
|
201
|
+
...fieldValue.center
|
|
202
|
+
}, fieldValue.distance];
|
|
203
|
+
constraints[parseConstraintMap[fieldName]] = fieldValue;
|
|
204
|
+
}
|
|
205
|
+
break;
|
|
206
|
+
}
|
|
207
|
+
if (typeof fieldValue === 'object') {
|
|
208
|
+
if (fieldName === 'where') {
|
|
209
|
+
transformQueryInputToParse(fieldValue, className, parseClasses);
|
|
210
|
+
} else {
|
|
211
|
+
transformQueryConstraintInputToParse(fieldValue, fieldName, className, constraints, parseClasses);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
};
|
|
216
|
+
exports.transformQueryConstraintInputToParse = transformQueryConstraintInputToParse;
|
|
217
|
+
const transformQueryInputToParse = (constraints, className, parseClasses) => {
|
|
218
|
+
if (!constraints || typeof constraints !== 'object') {
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
Object.keys(constraints).forEach(fieldName => {
|
|
222
|
+
const fieldValue = constraints[fieldName];
|
|
223
|
+
if (parseQueryMap[fieldName]) {
|
|
224
|
+
delete constraints[fieldName];
|
|
225
|
+
fieldName = parseQueryMap[fieldName];
|
|
226
|
+
constraints[fieldName] = fieldValue;
|
|
227
|
+
fieldValue.forEach(fieldValueItem => {
|
|
228
|
+
transformQueryInputToParse(fieldValueItem, className, parseClasses);
|
|
229
|
+
});
|
|
230
|
+
return;
|
|
231
|
+
} else {
|
|
232
|
+
transformQueryConstraintInputToParse(fieldValue, fieldName, className, constraints, parseClasses);
|
|
233
|
+
}
|
|
234
|
+
});
|
|
235
|
+
};
|
|
236
|
+
exports.transformQueryInputToParse = transformQueryInputToParse;
|
|
237
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphqlRelay","require","parseQueryMap","OR","AND","NOR","parseConstraintMap","equalTo","notEqualTo","lessThan","lessThanOrEqualTo","greaterThan","greaterThanOrEqualTo","in","notIn","exists","inQueryKey","notInQueryKey","inQuery","notInQuery","containedBy","contains","matchesRegex","options","text","search","term","language","caseSensitive","diacriticSensitive","nearSphere","maxDistance","maxDistanceInRadians","maxDistanceInMiles","maxDistanceInKilometers","within","box","geoWithin","polygon","centerSphere","geoIntersects","point","transformQueryConstraintInputToParse","constraints","parentFieldName","className","parentConstraints","parseClasses","fields","Object","keys","forEach","constraintName","constraintValue","globalIdObject","fromGlobalId","type","id","Array","isArray","map","value","objectId","fieldName","fieldValue","key","undefined","targetClass","whereTarget","$exists","parseWhereTarget","where","$inQuery","transformQueryInputToParse","$notInQuery","__type","bottomLeft","upperRight","geoPoint","center","distance","exports","fieldValueItem"],"sources":["../../../src/GraphQL/transformers/query.js"],"sourcesContent":["import { fromGlobalId } from 'graphql-relay';\n\nconst parseQueryMap = {\n  OR: '$or',\n  AND: '$and',\n  NOR: '$nor',\n};\n\nconst parseConstraintMap = {\n  equalTo: '$eq',\n  notEqualTo: '$ne',\n  lessThan: '$lt',\n  lessThanOrEqualTo: '$lte',\n  greaterThan: '$gt',\n  greaterThanOrEqualTo: '$gte',\n  in: '$in',\n  notIn: '$nin',\n  exists: '$exists',\n  inQueryKey: '$select',\n  notInQueryKey: '$dontSelect',\n  inQuery: '$inQuery',\n  notInQuery: '$notInQuery',\n  containedBy: '$containedBy',\n  contains: '$all',\n  matchesRegex: '$regex',\n  options: '$options',\n  text: '$text',\n  search: '$search',\n  term: '$term',\n  language: '$language',\n  caseSensitive: '$caseSensitive',\n  diacriticSensitive: '$diacriticSensitive',\n  nearSphere: '$nearSphere',\n  maxDistance: '$maxDistance',\n  maxDistanceInRadians: '$maxDistanceInRadians',\n  maxDistanceInMiles: '$maxDistanceInMiles',\n  maxDistanceInKilometers: '$maxDistanceInKilometers',\n  within: '$within',\n  box: '$box',\n  geoWithin: '$geoWithin',\n  polygon: '$polygon',\n  centerSphere: '$centerSphere',\n  geoIntersects: '$geoIntersects',\n  point: '$point',\n};\n\nconst transformQueryConstraintInputToParse = (\n  constraints,\n  parentFieldName,\n  className,\n  parentConstraints,\n  parseClasses\n) => {\n  const fields = parseClasses[className].fields;\n  if (parentFieldName === 'id' && className) {\n    Object.keys(constraints).forEach(constraintName => {\n      const constraintValue = constraints[constraintName];\n      if (typeof constraintValue === 'string') {\n        const globalIdObject = fromGlobalId(constraintValue);\n\n        if (globalIdObject.type === className) {\n          constraints[constraintName] = globalIdObject.id;\n        }\n      } else if (Array.isArray(constraintValue)) {\n        constraints[constraintName] = constraintValue.map(value => {\n          const globalIdObject = fromGlobalId(value);\n\n          if (globalIdObject.type === className) {\n            return globalIdObject.id;\n          }\n\n          return value;\n        });\n      }\n    });\n    parentConstraints.objectId = constraints;\n    delete parentConstraints.id;\n  }\n  Object.keys(constraints).forEach(fieldName => {\n    let fieldValue = constraints[fieldName];\n    if (parseConstraintMap[fieldName]) {\n      constraints[parseConstraintMap[fieldName]] = constraints[fieldName];\n      delete constraints[fieldName];\n    }\n    /**\n     * If we have a key-value pair, we need to change the way the constraint is structured.\n     *\n     * Example:\n     *   From:\n     *   {\n     *     \"someField\": {\n     *       \"lessThan\": {\n     *         \"key\":\"foo.bar\",\n     *         \"value\": 100\n     *       },\n     *       \"greaterThan\": {\n     *         \"key\":\"foo.bar\",\n     *         \"value\": 10\n     *       }\n     *     }\n     *   }\n     *\n     *   To:\n     *   {\n     *     \"someField.foo.bar\": {\n     *       \"$lt\": 100,\n     *       \"$gt\": 10\n     *      }\n     *   }\n     */\n    if (fieldValue.key && fieldValue.value !== undefined && parentConstraints && parentFieldName) {\n      delete parentConstraints[parentFieldName];\n      parentConstraints[`${parentFieldName}.${fieldValue.key}`] = {\n        ...parentConstraints[`${parentFieldName}.${fieldValue.key}`],\n        [parseConstraintMap[fieldName]]: fieldValue.value,\n      };\n    } else if (\n      fields[parentFieldName] &&\n      (fields[parentFieldName].type === 'Pointer' || fields[parentFieldName].type === 'Relation')\n    ) {\n      const { targetClass } = fields[parentFieldName];\n      if (fieldName === 'exists') {\n        if (fields[parentFieldName].type === 'Relation') {\n          const whereTarget = fieldValue ? 'where' : 'notWhere';\n          if (constraints[whereTarget]) {\n            if (constraints[whereTarget].objectId) {\n              constraints[whereTarget].objectId = {\n                ...constraints[whereTarget].objectId,\n                $exists: fieldValue,\n              };\n            } else {\n              constraints[whereTarget].objectId = {\n                $exists: fieldValue,\n              };\n            }\n          } else {\n            const parseWhereTarget = fieldValue ? '$inQuery' : '$notInQuery';\n            parentConstraints[parentFieldName][parseWhereTarget] = {\n              where: { objectId: { $exists: true } },\n              className: targetClass,\n            };\n          }\n          delete constraints.$exists;\n        } else {\n          parentConstraints[parentFieldName].$exists = fieldValue;\n        }\n        return;\n      }\n      switch (fieldName) {\n        case 'have':\n          parentConstraints[parentFieldName].$inQuery = {\n            where: fieldValue,\n            className: targetClass,\n          };\n          transformQueryInputToParse(\n            parentConstraints[parentFieldName].$inQuery.where,\n            targetClass,\n            parseClasses\n          );\n          break;\n        case 'haveNot':\n          parentConstraints[parentFieldName].$notInQuery = {\n            where: fieldValue,\n            className: targetClass,\n          };\n          transformQueryInputToParse(\n            parentConstraints[parentFieldName].$notInQuery.where,\n            targetClass,\n            parseClasses\n          );\n          break;\n      }\n      delete constraints[fieldName];\n      return;\n    }\n    switch (fieldName) {\n      case 'point':\n        if (typeof fieldValue === 'object' && !fieldValue.__type) {\n          fieldValue.__type = 'GeoPoint';\n        }\n        break;\n      case 'nearSphere':\n        if (typeof fieldValue === 'object' && !fieldValue.__type) {\n          fieldValue.__type = 'GeoPoint';\n        }\n        break;\n      case 'box':\n        if (typeof fieldValue === 'object' && fieldValue.bottomLeft && fieldValue.upperRight) {\n          fieldValue = [\n            {\n              __type: 'GeoPoint',\n              ...fieldValue.bottomLeft,\n            },\n            {\n              __type: 'GeoPoint',\n              ...fieldValue.upperRight,\n            },\n          ];\n          constraints[parseConstraintMap[fieldName]] = fieldValue;\n        }\n        break;\n      case 'polygon':\n        if (fieldValue instanceof Array) {\n          fieldValue.forEach(geoPoint => {\n            if (typeof geoPoint === 'object' && !geoPoint.__type) {\n              geoPoint.__type = 'GeoPoint';\n            }\n          });\n        }\n        break;\n      case 'centerSphere':\n        if (typeof fieldValue === 'object' && fieldValue.center && fieldValue.distance) {\n          fieldValue = [\n            {\n              __type: 'GeoPoint',\n              ...fieldValue.center,\n            },\n            fieldValue.distance,\n          ];\n          constraints[parseConstraintMap[fieldName]] = fieldValue;\n        }\n        break;\n    }\n    if (typeof fieldValue === 'object') {\n      if (fieldName === 'where') {\n        transformQueryInputToParse(fieldValue, className, parseClasses);\n      } else {\n        transformQueryConstraintInputToParse(\n          fieldValue,\n          fieldName,\n          className,\n          constraints,\n          parseClasses\n        );\n      }\n    }\n  });\n};\n\nconst transformQueryInputToParse = (constraints, className, parseClasses) => {\n  if (!constraints || typeof constraints !== 'object') {\n    return;\n  }\n\n  Object.keys(constraints).forEach(fieldName => {\n    const fieldValue = constraints[fieldName];\n\n    if (parseQueryMap[fieldName]) {\n      delete constraints[fieldName];\n      fieldName = parseQueryMap[fieldName];\n      constraints[fieldName] = fieldValue;\n      fieldValue.forEach(fieldValueItem => {\n        transformQueryInputToParse(fieldValueItem, className, parseClasses);\n      });\n      return;\n    } else {\n      transformQueryConstraintInputToParse(\n        fieldValue,\n        fieldName,\n        className,\n        constraints,\n        parseClasses\n      );\n    }\n  });\n};\n\nexport { transformQueryConstraintInputToParse, transformQueryInputToParse };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.transformToParse = exports.transformToGraphQL = void 0;
|
|
7
|
+
var _node = _interopRequireDefault(require("parse/node"));
|
|
8
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
+
const transformToParse = (graphQLSchemaFields, existingFields) => {
|
|
10
|
+
if (!graphQLSchemaFields) {
|
|
11
|
+
return {};
|
|
12
|
+
}
|
|
13
|
+
let parseSchemaFields = {};
|
|
14
|
+
const reducerGenerator = type => (parseSchemaFields, field) => {
|
|
15
|
+
if (type === 'Remove') {
|
|
16
|
+
if (existingFields[field.name]) {
|
|
17
|
+
return {
|
|
18
|
+
...parseSchemaFields,
|
|
19
|
+
[field.name]: {
|
|
20
|
+
__op: 'Delete'
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
} else {
|
|
24
|
+
return parseSchemaFields;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (graphQLSchemaFields.remove && graphQLSchemaFields.remove.find(removeField => removeField.name === field.name)) {
|
|
28
|
+
return parseSchemaFields;
|
|
29
|
+
}
|
|
30
|
+
if (parseSchemaFields[field.name] || existingFields && existingFields[field.name]) {
|
|
31
|
+
throw new _node.default.Error(_node.default.Error.INVALID_KEY_NAME, `Duplicated field name: ${field.name}`);
|
|
32
|
+
}
|
|
33
|
+
if (type === 'Relation' || type === 'Pointer') {
|
|
34
|
+
return {
|
|
35
|
+
...parseSchemaFields,
|
|
36
|
+
[field.name]: {
|
|
37
|
+
type,
|
|
38
|
+
targetClass: field.targetClassName
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
return {
|
|
43
|
+
...parseSchemaFields,
|
|
44
|
+
[field.name]: {
|
|
45
|
+
type
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
if (graphQLSchemaFields.addStrings) {
|
|
50
|
+
parseSchemaFields = graphQLSchemaFields.addStrings.reduce(reducerGenerator('String'), parseSchemaFields);
|
|
51
|
+
}
|
|
52
|
+
if (graphQLSchemaFields.addNumbers) {
|
|
53
|
+
parseSchemaFields = graphQLSchemaFields.addNumbers.reduce(reducerGenerator('Number'), parseSchemaFields);
|
|
54
|
+
}
|
|
55
|
+
if (graphQLSchemaFields.addBooleans) {
|
|
56
|
+
parseSchemaFields = graphQLSchemaFields.addBooleans.reduce(reducerGenerator('Boolean'), parseSchemaFields);
|
|
57
|
+
}
|
|
58
|
+
if (graphQLSchemaFields.addArrays) {
|
|
59
|
+
parseSchemaFields = graphQLSchemaFields.addArrays.reduce(reducerGenerator('Array'), parseSchemaFields);
|
|
60
|
+
}
|
|
61
|
+
if (graphQLSchemaFields.addObjects) {
|
|
62
|
+
parseSchemaFields = graphQLSchemaFields.addObjects.reduce(reducerGenerator('Object'), parseSchemaFields);
|
|
63
|
+
}
|
|
64
|
+
if (graphQLSchemaFields.addDates) {
|
|
65
|
+
parseSchemaFields = graphQLSchemaFields.addDates.reduce(reducerGenerator('Date'), parseSchemaFields);
|
|
66
|
+
}
|
|
67
|
+
if (graphQLSchemaFields.addFiles) {
|
|
68
|
+
parseSchemaFields = graphQLSchemaFields.addFiles.reduce(reducerGenerator('File'), parseSchemaFields);
|
|
69
|
+
}
|
|
70
|
+
if (graphQLSchemaFields.addGeoPoint) {
|
|
71
|
+
parseSchemaFields = [graphQLSchemaFields.addGeoPoint].reduce(reducerGenerator('GeoPoint'), parseSchemaFields);
|
|
72
|
+
}
|
|
73
|
+
if (graphQLSchemaFields.addPolygons) {
|
|
74
|
+
parseSchemaFields = graphQLSchemaFields.addPolygons.reduce(reducerGenerator('Polygon'), parseSchemaFields);
|
|
75
|
+
}
|
|
76
|
+
if (graphQLSchemaFields.addBytes) {
|
|
77
|
+
parseSchemaFields = graphQLSchemaFields.addBytes.reduce(reducerGenerator('Bytes'), parseSchemaFields);
|
|
78
|
+
}
|
|
79
|
+
if (graphQLSchemaFields.addPointers) {
|
|
80
|
+
parseSchemaFields = graphQLSchemaFields.addPointers.reduce(reducerGenerator('Pointer'), parseSchemaFields);
|
|
81
|
+
}
|
|
82
|
+
if (graphQLSchemaFields.addRelations) {
|
|
83
|
+
parseSchemaFields = graphQLSchemaFields.addRelations.reduce(reducerGenerator('Relation'), parseSchemaFields);
|
|
84
|
+
}
|
|
85
|
+
if (existingFields && graphQLSchemaFields.remove) {
|
|
86
|
+
parseSchemaFields = graphQLSchemaFields.remove.reduce(reducerGenerator('Remove'), parseSchemaFields);
|
|
87
|
+
}
|
|
88
|
+
return parseSchemaFields;
|
|
89
|
+
};
|
|
90
|
+
exports.transformToParse = transformToParse;
|
|
91
|
+
const transformToGraphQL = parseSchemaFields => {
|
|
92
|
+
return Object.keys(parseSchemaFields).map(name => ({
|
|
93
|
+
name,
|
|
94
|
+
type: parseSchemaFields[name].type,
|
|
95
|
+
targetClassName: parseSchemaFields[name].targetClass
|
|
96
|
+
}));
|
|
97
|
+
};
|
|
98
|
+
exports.transformToGraphQL = transformToGraphQL;
|
|
99
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","e","__esModule","default","transformToParse","graphQLSchemaFields","existingFields","parseSchemaFields","reducerGenerator","type","field","name","__op","remove","find","removeField","Parse","Error","INVALID_KEY_NAME","targetClass","targetClassName","addStrings","reduce","addNumbers","addBooleans","addArrays","addObjects","addDates","addFiles","addGeoPoint","addPolygons","addBytes","addPointers","addRelations","exports","transformToGraphQL","Object","keys","map"],"sources":["../../../src/GraphQL/transformers/schemaFields.js"],"sourcesContent":["import Parse from 'parse/node';\n\nconst transformToParse = (graphQLSchemaFields, existingFields) => {\n  if (!graphQLSchemaFields) {\n    return {};\n  }\n\n  let parseSchemaFields = {};\n\n  const reducerGenerator = type => (parseSchemaFields, field) => {\n    if (type === 'Remove') {\n      if (existingFields[field.name]) {\n        return {\n          ...parseSchemaFields,\n          [field.name]: {\n            __op: 'Delete',\n          },\n        };\n      } else {\n        return parseSchemaFields;\n      }\n    }\n    if (\n      graphQLSchemaFields.remove &&\n      graphQLSchemaFields.remove.find(removeField => removeField.name === field.name)\n    ) {\n      return parseSchemaFields;\n    }\n    if (parseSchemaFields[field.name] || (existingFields && existingFields[field.name])) {\n      throw new Parse.Error(Parse.Error.INVALID_KEY_NAME, `Duplicated field name: ${field.name}`);\n    }\n    if (type === 'Relation' || type === 'Pointer') {\n      return {\n        ...parseSchemaFields,\n        [field.name]: {\n          type,\n          targetClass: field.targetClassName,\n        },\n      };\n    }\n    return {\n      ...parseSchemaFields,\n      [field.name]: {\n        type,\n      },\n    };\n  };\n\n  if (graphQLSchemaFields.addStrings) {\n    parseSchemaFields = graphQLSchemaFields.addStrings.reduce(\n      reducerGenerator('String'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addNumbers) {\n    parseSchemaFields = graphQLSchemaFields.addNumbers.reduce(\n      reducerGenerator('Number'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addBooleans) {\n    parseSchemaFields = graphQLSchemaFields.addBooleans.reduce(\n      reducerGenerator('Boolean'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addArrays) {\n    parseSchemaFields = graphQLSchemaFields.addArrays.reduce(\n      reducerGenerator('Array'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addObjects) {\n    parseSchemaFields = graphQLSchemaFields.addObjects.reduce(\n      reducerGenerator('Object'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addDates) {\n    parseSchemaFields = graphQLSchemaFields.addDates.reduce(\n      reducerGenerator('Date'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addFiles) {\n    parseSchemaFields = graphQLSchemaFields.addFiles.reduce(\n      reducerGenerator('File'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addGeoPoint) {\n    parseSchemaFields = [graphQLSchemaFields.addGeoPoint].reduce(\n      reducerGenerator('GeoPoint'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addPolygons) {\n    parseSchemaFields = graphQLSchemaFields.addPolygons.reduce(\n      reducerGenerator('Polygon'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addBytes) {\n    parseSchemaFields = graphQLSchemaFields.addBytes.reduce(\n      reducerGenerator('Bytes'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addPointers) {\n    parseSchemaFields = graphQLSchemaFields.addPointers.reduce(\n      reducerGenerator('Pointer'),\n      parseSchemaFields\n    );\n  }\n  if (graphQLSchemaFields.addRelations) {\n    parseSchemaFields = graphQLSchemaFields.addRelations.reduce(\n      reducerGenerator('Relation'),\n      parseSchemaFields\n    );\n  }\n  if (existingFields && graphQLSchemaFields.remove) {\n    parseSchemaFields = graphQLSchemaFields.remove.reduce(\n      reducerGenerator('Remove'),\n      parseSchemaFields\n    );\n  }\n\n  return parseSchemaFields;\n};\n\nconst transformToGraphQL = parseSchemaFields => {\n  return Object.keys(parseSchemaFields).map(name => ({\n    name,\n    type: parseSchemaFields[name].type,\n    targetClassName: parseSchemaFields[name].targetClass,\n  }));\n};\n\nexport { transformToParse, transformToGraphQL };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.KeyPromiseQueue = void 0;
|
|
7
|
+
// KeyPromiseQueue is a simple promise queue
|
|
8
|
+
// used to queue operations per key basis.
|
|
9
|
+
// Once the tail promise in the key-queue fulfills,
|
|
10
|
+
// the chain on that key will be cleared.
|
|
11
|
+
class KeyPromiseQueue {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.queue = {};
|
|
14
|
+
}
|
|
15
|
+
enqueue(key, operation) {
|
|
16
|
+
const tuple = this.beforeOp(key);
|
|
17
|
+
const toAwait = tuple[1];
|
|
18
|
+
const nextOperation = toAwait.then(operation);
|
|
19
|
+
const wrappedOperation = nextOperation.then(result => {
|
|
20
|
+
this.afterOp(key);
|
|
21
|
+
return result;
|
|
22
|
+
});
|
|
23
|
+
tuple[1] = wrappedOperation;
|
|
24
|
+
return wrappedOperation;
|
|
25
|
+
}
|
|
26
|
+
beforeOp(key) {
|
|
27
|
+
let tuple = this.queue[key];
|
|
28
|
+
if (!tuple) {
|
|
29
|
+
tuple = [0, Promise.resolve()];
|
|
30
|
+
this.queue[key] = tuple;
|
|
31
|
+
}
|
|
32
|
+
tuple[0]++;
|
|
33
|
+
return tuple;
|
|
34
|
+
}
|
|
35
|
+
afterOp(key) {
|
|
36
|
+
const tuple = this.queue[key];
|
|
37
|
+
if (!tuple) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
tuple[0]--;
|
|
41
|
+
if (tuple[0] <= 0) {
|
|
42
|
+
delete this.queue[key];
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
exports.KeyPromiseQueue = KeyPromiseQueue;
|
|
48
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJLZXlQcm9taXNlUXVldWUiLCJjb25zdHJ1Y3RvciIsInF1ZXVlIiwiZW5xdWV1ZSIsImtleSIsIm9wZXJhdGlvbiIsInR1cGxlIiwiYmVmb3JlT3AiLCJ0b0F3YWl0IiwibmV4dE9wZXJhdGlvbiIsInRoZW4iLCJ3cmFwcGVkT3BlcmF0aW9uIiwicmVzdWx0IiwiYWZ0ZXJPcCIsIlByb21pc2UiLCJyZXNvbHZlIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uL3NyYy9LZXlQcm9taXNlUXVldWUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gS2V5UHJvbWlzZVF1ZXVlIGlzIGEgc2ltcGxlIHByb21pc2UgcXVldWVcbi8vIHVzZWQgdG8gcXVldWUgb3BlcmF0aW9ucyBwZXIga2V5IGJhc2lzLlxuLy8gT25jZSB0aGUgdGFpbCBwcm9taXNlIGluIHRoZSBrZXktcXVldWUgZnVsZmlsbHMsXG4vLyB0aGUgY2hhaW4gb24gdGhhdCBrZXkgd2lsbCBiZSBjbGVhcmVkLlxuZXhwb3J0IGNsYXNzIEtleVByb21pc2VRdWV1ZSB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMucXVldWUgPSB7fTtcbiAgfVxuXG4gIGVucXVldWUoa2V5LCBvcGVyYXRpb24pIHtcbiAgICBjb25zdCB0dXBsZSA9IHRoaXMuYmVmb3JlT3Aoa2V5KTtcbiAgICBjb25zdCB0b0F3YWl0ID0gdHVwbGVbMV07XG4gICAgY29uc3QgbmV4dE9wZXJhdGlvbiA9IHRvQXdhaXQudGhlbihvcGVyYXRpb24pO1xuICAgIGNvbnN0IHdyYXBwZWRPcGVyYXRpb24gPSBuZXh0T3BlcmF0aW9uLnRoZW4ocmVzdWx0ID0+IHtcbiAgICAgIHRoaXMuYWZ0ZXJPcChrZXkpO1xuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9KTtcbiAgICB0dXBsZVsxXSA9IHdyYXBwZWRPcGVyYXRpb247XG4gICAgcmV0dXJuIHdyYXBwZWRPcGVyYXRpb247XG4gIH1cblxuICBiZWZvcmVPcChrZXkpIHtcbiAgICBsZXQgdHVwbGUgPSB0aGlzLnF1ZXVlW2tleV07XG4gICAgaWYgKCF0dXBsZSkge1xuICAgICAgdHVwbGUgPSBbMCwgUHJvbWlzZS5yZXNvbHZlKCldO1xuICAgICAgdGhpcy5xdWV1ZVtrZXldID0gdHVwbGU7XG4gICAgfVxuICAgIHR1cGxlWzBdKys7XG4gICAgcmV0dXJuIHR1cGxlO1xuICB9XG5cbiAgYWZ0ZXJPcChrZXkpIHtcbiAgICBjb25zdCB0dXBsZSA9IHRoaXMucXVldWVba2V5XTtcbiAgICBpZiAoIXR1cGxlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHR1cGxlWzBdLS07XG4gICAgaWYgKHR1cGxlWzBdIDw9IDApIHtcbiAgICAgIGRlbGV0ZSB0aGlzLnF1ZXVlW2tleV07XG4gICAgICByZXR1cm47XG4gICAgfVxuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ08sTUFBTUEsZUFBZSxDQUFDO0VBQzNCQyxXQUFXQSxDQUFBLEVBQUc7SUFDWixJQUFJLENBQUNDLEtBQUssR0FBRyxDQUFDLENBQUM7RUFDakI7RUFFQUMsT0FBT0EsQ0FBQ0MsR0FBRyxFQUFFQyxTQUFTLEVBQUU7SUFDdEIsTUFBTUMsS0FBSyxHQUFHLElBQUksQ0FBQ0MsUUFBUSxDQUFDSCxHQUFHLENBQUM7SUFDaEMsTUFBTUksT0FBTyxHQUFHRixLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3hCLE1BQU1HLGFBQWEsR0FBR0QsT0FBTyxDQUFDRSxJQUFJLENBQUNMLFNBQVMsQ0FBQztJQUM3QyxNQUFNTSxnQkFBZ0IsR0FBR0YsYUFBYSxDQUFDQyxJQUFJLENBQUNFLE1BQU0sSUFBSTtNQUNwRCxJQUFJLENBQUNDLE9BQU8sQ0FBQ1QsR0FBRyxDQUFDO01BQ2pCLE9BQU9RLE1BQU07SUFDZixDQUFDLENBQUM7SUFDRk4sS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHSyxnQkFBZ0I7SUFDM0IsT0FBT0EsZ0JBQWdCO0VBQ3pCO0VBRUFKLFFBQVFBLENBQUNILEdBQUcsRUFBRTtJQUNaLElBQUlFLEtBQUssR0FBRyxJQUFJLENBQUNKLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO0lBQzNCLElBQUksQ0FBQ0UsS0FBSyxFQUFFO01BQ1ZBLEtBQUssR0FBRyxDQUFDLENBQUMsRUFBRVEsT0FBTyxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDO01BQzlCLElBQUksQ0FBQ2IsS0FBSyxDQUFDRSxHQUFHLENBQUMsR0FBR0UsS0FBSztJQUN6QjtJQUNBQSxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUU7SUFDVixPQUFPQSxLQUFLO0VBQ2Q7RUFFQU8sT0FBT0EsQ0FBQ1QsR0FBRyxFQUFFO0lBQ1gsTUFBTUUsS0FBSyxHQUFHLElBQUksQ0FBQ0osS0FBSyxDQUFDRSxHQUFHLENBQUM7SUFDN0IsSUFBSSxDQUFDRSxLQUFLLEVBQUU7TUFDVjtJQUNGO0lBQ0FBLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRTtJQUNWLElBQUlBLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUU7TUFDakIsT0FBTyxJQUFJLENBQUNKLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO01BQ3RCO0lBQ0Y7RUFDRjtBQUNGO0FBQUNZLE9BQUEsQ0FBQWhCLGVBQUEsR0FBQUEsZUFBQSIsImlnbm9yZUxpc3QiOltdfQ==
|
package/lib/LiveQuery/Client.js
CHANGED
|
@@ -1,24 +1,19 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.Client =
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
var _logger2 = _interopRequireDefault(_logger);
|
|
11
|
-
|
|
12
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
6
|
+
exports.Client = void 0;
|
|
7
|
+
var _logger = _interopRequireDefault(require("../logger"));
|
|
8
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
9
|
const dafaultFields = ['className', 'objectId', 'updatedAt', 'createdAt', 'ACL'];
|
|
15
|
-
|
|
16
10
|
class Client {
|
|
17
|
-
|
|
18
|
-
constructor(id, parseWebSocket, hasMasterKey) {
|
|
11
|
+
constructor(id, parseWebSocket, hasMasterKey = false, sessionToken, installationId) {
|
|
19
12
|
this.id = id;
|
|
20
13
|
this.parseWebSocket = parseWebSocket;
|
|
21
14
|
this.hasMasterKey = hasMasterKey;
|
|
15
|
+
this.sessionToken = sessionToken;
|
|
16
|
+
this.installationId = installationId;
|
|
22
17
|
this.roles = [];
|
|
23
18
|
this.subscriptionInfos = new Map();
|
|
24
19
|
this.pushConnect = this._pushEvent('connected');
|
|
@@ -30,53 +25,51 @@ class Client {
|
|
|
30
25
|
this.pushDelete = this._pushEvent('delete');
|
|
31
26
|
this.pushLeave = this._pushEvent('leave');
|
|
32
27
|
}
|
|
33
|
-
|
|
34
28
|
static pushResponse(parseWebSocket, message) {
|
|
35
|
-
|
|
29
|
+
_logger.default.verbose('Push Response : %j', message);
|
|
36
30
|
parseWebSocket.send(message);
|
|
37
31
|
}
|
|
38
|
-
|
|
39
|
-
static pushError(parseWebSocket, code, error, reconnect = true) {
|
|
32
|
+
static pushError(parseWebSocket, code, error, reconnect = true, requestId = null) {
|
|
40
33
|
Client.pushResponse(parseWebSocket, JSON.stringify({
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
34
|
+
op: 'error',
|
|
35
|
+
error,
|
|
36
|
+
code,
|
|
37
|
+
reconnect,
|
|
38
|
+
requestId
|
|
45
39
|
}));
|
|
46
40
|
}
|
|
47
|
-
|
|
48
41
|
addSubscriptionInfo(requestId, subscriptionInfo) {
|
|
49
42
|
this.subscriptionInfos.set(requestId, subscriptionInfo);
|
|
50
43
|
}
|
|
51
|
-
|
|
52
44
|
getSubscriptionInfo(requestId) {
|
|
53
45
|
return this.subscriptionInfos.get(requestId);
|
|
54
46
|
}
|
|
55
|
-
|
|
56
47
|
deleteSubscriptionInfo(requestId) {
|
|
57
48
|
return this.subscriptionInfos.delete(requestId);
|
|
58
49
|
}
|
|
59
|
-
|
|
60
50
|
_pushEvent(type) {
|
|
61
|
-
return function (subscriptionId, parseObjectJSON) {
|
|
51
|
+
return function (subscriptionId, parseObjectJSON, parseOriginalObjectJSON) {
|
|
62
52
|
const response = {
|
|
63
|
-
|
|
64
|
-
|
|
53
|
+
op: type,
|
|
54
|
+
clientId: this.id,
|
|
55
|
+
installationId: this.installationId
|
|
65
56
|
};
|
|
66
57
|
if (typeof subscriptionId !== 'undefined') {
|
|
67
58
|
response['requestId'] = subscriptionId;
|
|
68
59
|
}
|
|
69
60
|
if (typeof parseObjectJSON !== 'undefined') {
|
|
70
|
-
let
|
|
61
|
+
let keys;
|
|
71
62
|
if (this.subscriptionInfos.has(subscriptionId)) {
|
|
72
|
-
|
|
63
|
+
keys = this.subscriptionInfos.get(subscriptionId).keys;
|
|
64
|
+
}
|
|
65
|
+
response['object'] = this._toJSONWithFields(parseObjectJSON, keys);
|
|
66
|
+
if (parseOriginalObjectJSON) {
|
|
67
|
+
response['original'] = this._toJSONWithFields(parseOriginalObjectJSON, keys);
|
|
73
68
|
}
|
|
74
|
-
response['object'] = this._toJSONWithFields(parseObjectJSON, fields);
|
|
75
69
|
}
|
|
76
70
|
Client.pushResponse(this.parseWebSocket, JSON.stringify(response));
|
|
77
71
|
};
|
|
78
72
|
}
|
|
79
|
-
|
|
80
73
|
_toJSONWithFields(parseObjectJSON, fields) {
|
|
81
74
|
if (!fields) {
|
|
82
75
|
return parseObjectJSON;
|
|
@@ -93,6 +86,5 @@ class Client {
|
|
|
93
86
|
return limitedParseObject;
|
|
94
87
|
}
|
|
95
88
|
}
|
|
96
|
-
|
|
97
89
|
exports.Client = Client;
|
|
98
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/LiveQuery/Client.js"],"names":["dafaultFields","Client","constructor","id","parseWebSocket","hasMasterKey","roles","subscriptionInfos","Map","pushConnect","_pushEvent","pushSubscribe","pushUnsubscribe","pushCreate","pushEnter","pushUpdate","pushDelete","pushLeave","pushResponse","message","logger","verbose","send","pushError","code","error","reconnect","JSON","stringify","addSubscriptionInfo","requestId","subscriptionInfo","set","getSubscriptionInfo","get","deleteSubscriptionInfo","delete","type","subscriptionId","parseObjectJSON","response","fields","has","_toJSONWithFields","limitedParseObject","field"],"mappings":"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","file":"Client.js","sourcesContent":["import logger from '../logger';\n\nimport type { FlattenedObjectData } from './Subscription';\nexport type Message = { [attr: string]: any };\n\nconst dafaultFields = ['className', 'objectId', 'updatedAt', 'createdAt', 'ACL'];\n\nclass Client {\n  id: number;\n  parseWebSocket: any;\n  hasMasterKey: boolean;\n  userId: string;\n  roles: Array<string>;\n  subscriptionInfos: Object;\n  pushConnect: Function;\n  pushSubscribe: Function;\n  pushUnsubscribe: Function;\n  pushCreate: Function;\n  pushEnter: Function;\n  pushUpdate: Function;\n  pushDelete: Function;\n  pushLeave: Function;\n\n  constructor(id: number, parseWebSocket: any, hasMasterKey: boolean) {\n    this.id = id;\n    this.parseWebSocket = parseWebSocket;\n    this.hasMasterKey = hasMasterKey;\n    this.roles = [];\n    this.subscriptionInfos = new Map();\n    this.pushConnect = this._pushEvent('connected');\n    this.pushSubscribe = this._pushEvent('subscribed');\n    this.pushUnsubscribe = this._pushEvent('unsubscribed');\n    this.pushCreate = this._pushEvent('create');\n    this.pushEnter = this._pushEvent('enter');\n    this.pushUpdate = this._pushEvent('update');\n    this.pushDelete = this._pushEvent('delete');\n    this.pushLeave = this._pushEvent('leave');\n  }\n\n  static pushResponse(parseWebSocket: any, message: Message): void {\n    logger.verbose('Push Response : %j', message);\n    parseWebSocket.send(message);\n  }\n\n  static pushError(parseWebSocket: any, code: number, error: string, reconnect: boolean = true): void {\n    Client.pushResponse(parseWebSocket, JSON.stringify({\n      'op': 'error',\n      'error': error,\n      'code': code,\n      'reconnect': reconnect\n    }));\n  }\n\n  addSubscriptionInfo(requestId: number, subscriptionInfo: any): void {\n    this.subscriptionInfos.set(requestId, subscriptionInfo);\n  }\n\n  getSubscriptionInfo(requestId: number): any {\n    return this.subscriptionInfos.get(requestId);\n  }\n\n  deleteSubscriptionInfo(requestId: number): void {\n    return this.subscriptionInfos.delete(requestId);\n  }\n\n  _pushEvent(type: string): Function {\n    return function(subscriptionId: number, parseObjectJSON: any): void {\n      const response: Message = {\n        'op' : type,\n        'clientId' : this.id\n      };\n      if (typeof subscriptionId !== 'undefined') {\n        response['requestId'] = subscriptionId;\n      }\n      if (typeof parseObjectJSON !== 'undefined') {\n        let fields;\n        if (this.subscriptionInfos.has(subscriptionId)) {\n          fields = this.subscriptionInfos.get(subscriptionId).fields;\n        }\n        response['object'] = this._toJSONWithFields(parseObjectJSON, fields);\n      }\n      Client.pushResponse(this.parseWebSocket, JSON.stringify(response));\n    }\n  }\n\n  _toJSONWithFields(parseObjectJSON: any, fields: any): FlattenedObjectData {\n    if (!fields) {\n      return parseObjectJSON;\n    }\n    const limitedParseObject = {};\n    for (const field of dafaultFields) {\n      limitedParseObject[field] = parseObjectJSON[field];\n    }\n    for (const field of fields) {\n      if (field in parseObjectJSON) {\n        limitedParseObject[field] = parseObjectJSON[field];\n      }\n    }\n    return limitedParseObject;\n  }\n}\n\nexport {\n  Client\n}\n"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","_interopRequireDefault","require","e","__esModule","default","dafaultFields","Client","constructor","id","parseWebSocket","hasMasterKey","sessionToken","installationId","roles","subscriptionInfos","Map","pushConnect","_pushEvent","pushSubscribe","pushUnsubscribe","pushCreate","pushEnter","pushUpdate","pushDelete","pushLeave","pushResponse","message","logger","verbose","send","pushError","code","error","reconnect","requestId","JSON","stringify","op","addSubscriptionInfo","subscriptionInfo","set","getSubscriptionInfo","get","deleteSubscriptionInfo","delete","type","subscriptionId","parseObjectJSON","parseOriginalObjectJSON","response","clientId","keys","has","_toJSONWithFields","fields","limitedParseObject","field","exports"],"sources":["../../src/LiveQuery/Client.js"],"sourcesContent":["import logger from '../logger';\n\nimport type { FlattenedObjectData } from './Subscription';\nexport type Message = { [attr: string]: any };\n\nconst dafaultFields = ['className', 'objectId', 'updatedAt', 'createdAt', 'ACL'];\n\nclass Client {\n  id: number;\n  parseWebSocket: any;\n  hasMasterKey: boolean;\n  sessionToken: string;\n  installationId: string;\n  userId: string;\n  roles: Array<string>;\n  subscriptionInfos: Object;\n  pushConnect: Function;\n  pushSubscribe: Function;\n  pushUnsubscribe: Function;\n  pushCreate: Function;\n  pushEnter: Function;\n  pushUpdate: Function;\n  pushDelete: Function;\n  pushLeave: Function;\n\n  constructor(\n    id: number,\n    parseWebSocket: any,\n    hasMasterKey: boolean = false,\n    sessionToken: string,\n    installationId: string\n  ) {\n    this.id = id;\n    this.parseWebSocket = parseWebSocket;\n    this.hasMasterKey = hasMasterKey;\n    this.sessionToken = sessionToken;\n    this.installationId = installationId;\n    this.roles = [];\n    this.subscriptionInfos = new Map();\n    this.pushConnect = this._pushEvent('connected');\n    this.pushSubscribe = this._pushEvent('subscribed');\n    this.pushUnsubscribe = this._pushEvent('unsubscribed');\n    this.pushCreate = this._pushEvent('create');\n    this.pushEnter = this._pushEvent('enter');\n    this.pushUpdate = this._pushEvent('update');\n    this.pushDelete = this._pushEvent('delete');\n    this.pushLeave = this._pushEvent('leave');\n  }\n\n  static pushResponse(parseWebSocket: any, message: Message): void {\n    logger.verbose('Push Response : %j', message);\n    parseWebSocket.send(message);\n  }\n\n  static pushError(\n    parseWebSocket: any,\n    code: number,\n    error: string,\n    reconnect: boolean = true,\n    requestId: number | void = null\n  ): void {\n    Client.pushResponse(\n      parseWebSocket,\n      JSON.stringify({\n        op: 'error',\n        error,\n        code,\n        reconnect,\n        requestId,\n      })\n    );\n  }\n\n  addSubscriptionInfo(requestId: number, subscriptionInfo: any): void {\n    this.subscriptionInfos.set(requestId, subscriptionInfo);\n  }\n\n  getSubscriptionInfo(requestId: number): any {\n    return this.subscriptionInfos.get(requestId);\n  }\n\n  deleteSubscriptionInfo(requestId: number): void {\n    return this.subscriptionInfos.delete(requestId);\n  }\n\n  _pushEvent(type: string): Function {\n    return function (\n      subscriptionId: number,\n      parseObjectJSON: any,\n      parseOriginalObjectJSON: any\n    ): void {\n      const response: Message = {\n        op: type,\n        clientId: this.id,\n        installationId: this.installationId,\n      };\n      if (typeof subscriptionId !== 'undefined') {\n        response['requestId'] = subscriptionId;\n      }\n      if (typeof parseObjectJSON !== 'undefined') {\n        let keys;\n        if (this.subscriptionInfos.has(subscriptionId)) {\n          keys = this.subscriptionInfos.get(subscriptionId).keys;\n        }\n        response['object'] = this._toJSONWithFields(parseObjectJSON, keys);\n        if (parseOriginalObjectJSON) {\n          response['original'] = this._toJSONWithFields(parseOriginalObjectJSON, keys);\n        }\n      }\n      Client.pushResponse(this.parseWebSocket, JSON.stringify(response));\n    };\n  }\n\n  _toJSONWithFields(parseObjectJSON: any, fields: any): FlattenedObjectData {\n    if (!fields) {\n      return parseObjectJSON;\n    }\n    const limitedParseObject = {};\n    for (const field of dafaultFields) {\n      limitedParseObject[field] = parseObjectJSON[field];\n    }\n    for (const field of fields) {\n      if (field in parseObjectJSON) {\n        limitedParseObject[field] = parseObjectJSON[field];\n      }\n    }\n    return limitedParseObject;\n  }\n}\n\nexport { Client };\n"],"mappings":"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","ignoreList":[]}
|
package/lib/LiveQuery/Id.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
class Id {
|
|
4
|
-
|
|
5
4
|
constructor(className, objectId) {
|
|
6
5
|
this.className = className;
|
|
7
6
|
this.objectId = objectId;
|
|
@@ -9,7 +8,6 @@ class Id {
|
|
|
9
8
|
toString() {
|
|
10
9
|
return this.className + ':' + this.objectId;
|
|
11
10
|
}
|
|
12
|
-
|
|
13
11
|
static fromString(str) {
|
|
14
12
|
var split = str.split(':');
|
|
15
13
|
if (split.length !== 2) {
|
|
@@ -18,6 +16,5 @@ class Id {
|
|
|
18
16
|
return new Id(split[0], split[1]);
|
|
19
17
|
}
|
|
20
18
|
}
|
|
21
|
-
|
|
22
19
|
module.exports = Id;
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJJZCIsImNvbnN0cnVjdG9yIiwiY2xhc3NOYW1lIiwib2JqZWN0SWQiLCJ0b1N0cmluZyIsImZyb21TdHJpbmciLCJzdHIiLCJzcGxpdCIsImxlbmd0aCIsIlR5cGVFcnJvciIsIm1vZHVsZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvTGl2ZVF1ZXJ5L0lkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImNsYXNzIElkIHtcbiAgY2xhc3NOYW1lOiBzdHJpbmc7XG4gIG9iamVjdElkOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoY2xhc3NOYW1lOiBzdHJpbmcsIG9iamVjdElkOiBzdHJpbmcpIHtcbiAgICB0aGlzLmNsYXNzTmFtZSA9IGNsYXNzTmFtZTtcbiAgICB0aGlzLm9iamVjdElkID0gb2JqZWN0SWQ7XG4gIH1cbiAgdG9TdHJpbmcoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5jbGFzc05hbWUgKyAnOicgKyB0aGlzLm9iamVjdElkO1xuICB9XG5cbiAgc3RhdGljIGZyb21TdHJpbmcoc3RyOiBzdHJpbmcpIHtcbiAgICB2YXIgc3BsaXQgPSBzdHIuc3BsaXQoJzonKTtcbiAgICBpZiAoc3BsaXQubGVuZ3RoICE9PSAyKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdDYW5ub3QgY3JlYXRlIElkIG9iamVjdCBmcm9tIHRoaXMgc3RyaW5nJyk7XG4gICAgfVxuICAgIHJldHVybiBuZXcgSWQoc3BsaXRbMF0sIHNwbGl0WzFdKTtcbiAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IElkO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLE1BQU1BLEVBQUUsQ0FBQztFQUlQQyxXQUFXQSxDQUFDQyxTQUFpQixFQUFFQyxRQUFnQixFQUFFO0lBQy9DLElBQUksQ0FBQ0QsU0FBUyxHQUFHQSxTQUFTO0lBQzFCLElBQUksQ0FBQ0MsUUFBUSxHQUFHQSxRQUFRO0VBQzFCO0VBQ0FDLFFBQVFBLENBQUEsRUFBVztJQUNqQixPQUFPLElBQUksQ0FBQ0YsU0FBUyxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUNDLFFBQVE7RUFDN0M7RUFFQSxPQUFPRSxVQUFVQSxDQUFDQyxHQUFXLEVBQUU7SUFDN0IsSUFBSUMsS0FBSyxHQUFHRCxHQUFHLENBQUNDLEtBQUssQ0FBQyxHQUFHLENBQUM7SUFDMUIsSUFBSUEsS0FBSyxDQUFDQyxNQUFNLEtBQUssQ0FBQyxFQUFFO01BQ3RCLE1BQU0sSUFBSUMsU0FBUyxDQUFDLDBDQUEwQyxDQUFDO0lBQ2pFO0lBQ0EsT0FBTyxJQUFJVCxFQUFFLENBQUNPLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRUEsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO0VBQ25DO0FBQ0Y7QUFFQUcsTUFBTSxDQUFDQyxPQUFPLEdBQUdYLEVBQUUiLCJpZ25vcmVMaXN0IjpbXX0=
|