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
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
const https = require('https');
|
|
4
|
-
|
|
5
4
|
function makeCallback(resolve, reject, noJSON) {
|
|
6
5
|
return function (res) {
|
|
7
6
|
let data = '';
|
|
@@ -22,13 +21,11 @@ function makeCallback(resolve, reject, noJSON) {
|
|
|
22
21
|
res.on('error', reject);
|
|
23
22
|
};
|
|
24
23
|
}
|
|
25
|
-
|
|
26
24
|
function get(options, noJSON = false) {
|
|
27
25
|
return new Promise((resolve, reject) => {
|
|
28
26
|
https.get(options, makeCallback(resolve, reject, noJSON)).on('error', reject);
|
|
29
27
|
});
|
|
30
28
|
}
|
|
31
|
-
|
|
32
29
|
function request(options, postData) {
|
|
33
30
|
return new Promise((resolve, reject) => {
|
|
34
31
|
const req = https.request(options, makeCallback(resolve, reject));
|
|
@@ -37,6 +34,8 @@ function request(options, postData) {
|
|
|
37
34
|
req.end();
|
|
38
35
|
});
|
|
39
36
|
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
37
|
+
module.exports = {
|
|
38
|
+
get,
|
|
39
|
+
request
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJodHRwcyIsInJlcXVpcmUiLCJtYWtlQ2FsbGJhY2siLCJyZXNvbHZlIiwicmVqZWN0Iiwibm9KU09OIiwicmVzIiwiZGF0YSIsIm9uIiwiY2h1bmsiLCJKU09OIiwicGFyc2UiLCJlIiwiZ2V0Iiwib3B0aW9ucyIsIlByb21pc2UiLCJyZXF1ZXN0IiwicG9zdERhdGEiLCJyZXEiLCJ3cml0ZSIsImVuZCIsIm1vZHVsZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQWRhcHRlcnMvQXV0aC9odHRwc1JlcXVlc3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgaHR0cHMgPSByZXF1aXJlKCdodHRwcycpO1xuXG5mdW5jdGlvbiBtYWtlQ2FsbGJhY2socmVzb2x2ZSwgcmVqZWN0LCBub0pTT04pIHtcbiAgcmV0dXJuIGZ1bmN0aW9uIChyZXMpIHtcbiAgICBsZXQgZGF0YSA9ICcnO1xuICAgIHJlcy5vbignZGF0YScsIGNodW5rID0+IHtcbiAgICAgIGRhdGEgKz0gY2h1bms7XG4gICAgfSk7XG4gICAgcmVzLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICBpZiAobm9KU09OKSB7XG4gICAgICAgIHJldHVybiByZXNvbHZlKGRhdGEpO1xuICAgICAgfVxuICAgICAgdHJ5IHtcbiAgICAgICAgZGF0YSA9IEpTT04ucGFyc2UoZGF0YSk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIHJldHVybiByZWplY3QoZSk7XG4gICAgICB9XG4gICAgICByZXNvbHZlKGRhdGEpO1xuICAgIH0pO1xuICAgIHJlcy5vbignZXJyb3InLCByZWplY3QpO1xuICB9O1xufVxuXG5mdW5jdGlvbiBnZXQob3B0aW9ucywgbm9KU09OID0gZmFsc2UpIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBodHRwcy5nZXQob3B0aW9ucywgbWFrZUNhbGxiYWNrKHJlc29sdmUsIHJlamVjdCwgbm9KU09OKSkub24oJ2Vycm9yJywgcmVqZWN0KTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIHJlcXVlc3Qob3B0aW9ucywgcG9zdERhdGEpIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCByZXEgPSBodHRwcy5yZXF1ZXN0KG9wdGlvbnMsIG1ha2VDYWxsYmFjayhyZXNvbHZlLCByZWplY3QpKTtcbiAgICByZXEub24oJ2Vycm9yJywgcmVqZWN0KTtcbiAgICByZXEud3JpdGUocG9zdERhdGEpO1xuICAgIHJlcS5lbmQoKTtcbiAgfSk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0geyBnZXQsIHJlcXVlc3QgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxNQUFNQSxLQUFLLEdBQUdDLE9BQU8sQ0FBQyxPQUFPLENBQUM7QUFFOUIsU0FBU0MsWUFBWUEsQ0FBQ0MsT0FBTyxFQUFFQyxNQUFNLEVBQUVDLE1BQU0sRUFBRTtFQUM3QyxPQUFPLFVBQVVDLEdBQUcsRUFBRTtJQUNwQixJQUFJQyxJQUFJLEdBQUcsRUFBRTtJQUNiRCxHQUFHLENBQUNFLEVBQUUsQ0FBQyxNQUFNLEVBQUVDLEtBQUssSUFBSTtNQUN0QkYsSUFBSSxJQUFJRSxLQUFLO0lBQ2YsQ0FBQyxDQUFDO0lBQ0ZILEdBQUcsQ0FBQ0UsRUFBRSxDQUFDLEtBQUssRUFBRSxNQUFNO01BQ2xCLElBQUlILE1BQU0sRUFBRTtRQUNWLE9BQU9GLE9BQU8sQ0FBQ0ksSUFBSSxDQUFDO01BQ3RCO01BQ0EsSUFBSTtRQUNGQSxJQUFJLEdBQUdHLElBQUksQ0FBQ0MsS0FBSyxDQUFDSixJQUFJLENBQUM7TUFDekIsQ0FBQyxDQUFDLE9BQU9LLENBQUMsRUFBRTtRQUNWLE9BQU9SLE1BQU0sQ0FBQ1EsQ0FBQyxDQUFDO01BQ2xCO01BQ0FULE9BQU8sQ0FBQ0ksSUFBSSxDQUFDO0lBQ2YsQ0FBQyxDQUFDO0lBQ0ZELEdBQUcsQ0FBQ0UsRUFBRSxDQUFDLE9BQU8sRUFBRUosTUFBTSxDQUFDO0VBQ3pCLENBQUM7QUFDSDtBQUVBLFNBQVNTLEdBQUdBLENBQUNDLE9BQU8sRUFBRVQsTUFBTSxHQUFHLEtBQUssRUFBRTtFQUNwQyxPQUFPLElBQUlVLE9BQU8sQ0FBQyxDQUFDWixPQUFPLEVBQUVDLE1BQU0sS0FBSztJQUN0Q0osS0FBSyxDQUFDYSxHQUFHLENBQUNDLE9BQU8sRUFBRVosWUFBWSxDQUFDQyxPQUFPLEVBQUVDLE1BQU0sRUFBRUMsTUFBTSxDQUFDLENBQUMsQ0FBQ0csRUFBRSxDQUFDLE9BQU8sRUFBRUosTUFBTSxDQUFDO0VBQy9FLENBQUMsQ0FBQztBQUNKO0FBRUEsU0FBU1ksT0FBT0EsQ0FBQ0YsT0FBTyxFQUFFRyxRQUFRLEVBQUU7RUFDbEMsT0FBTyxJQUFJRixPQUFPLENBQUMsQ0FBQ1osT0FBTyxFQUFFQyxNQUFNLEtBQUs7SUFDdEMsTUFBTWMsR0FBRyxHQUFHbEIsS0FBSyxDQUFDZ0IsT0FBTyxDQUFDRixPQUFPLEVBQUVaLFlBQVksQ0FBQ0MsT0FBTyxFQUFFQyxNQUFNLENBQUMsQ0FBQztJQUNqRWMsR0FBRyxDQUFDVixFQUFFLENBQUMsT0FBTyxFQUFFSixNQUFNLENBQUM7SUFDdkJjLEdBQUcsQ0FBQ0MsS0FBSyxDQUFDRixRQUFRLENBQUM7SUFDbkJDLEdBQUcsQ0FBQ0UsR0FBRyxDQUFDLENBQUM7RUFDWCxDQUFDLENBQUM7QUFDSjtBQUVBQyxNQUFNLENBQUNDLE9BQU8sR0FBRztFQUFFVCxHQUFHO0VBQUVHO0FBQVEsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,28 +1,34 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var _AdapterLoader = require(
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _AdapterLoader = _interopRequireDefault(require("../AdapterLoader"));
|
|
4
|
+
var _node = _interopRequireDefault(require("parse/node"));
|
|
5
|
+
var _AuthAdapter = _interopRequireDefault(require("./AuthAdapter"));
|
|
6
|
+
var _gcenter = _interopRequireDefault(require("./gcenter"));
|
|
7
|
+
var _github = _interopRequireDefault(require("./github"));
|
|
8
|
+
var _gpgames = _interopRequireDefault(require("./gpgames"));
|
|
9
|
+
var _instagram = _interopRequireDefault(require("./instagram"));
|
|
10
|
+
var _line = _interopRequireDefault(require("./line"));
|
|
11
|
+
var _linkedin = _interopRequireDefault(require("./linkedin"));
|
|
12
|
+
var _mfa = _interopRequireDefault(require("./mfa"));
|
|
13
|
+
var _microsoft = _interopRequireDefault(require("./microsoft"));
|
|
14
|
+
var _oauth = _interopRequireDefault(require("./oauth2"));
|
|
15
|
+
var _qq = _interopRequireDefault(require("./qq"));
|
|
16
|
+
var _spotify = _interopRequireDefault(require("./spotify"));
|
|
17
|
+
var _twitter = _interopRequireDefault(require("./twitter"));
|
|
18
|
+
var _wechat = _interopRequireDefault(require("./wechat"));
|
|
19
|
+
var _weibo = _interopRequireDefault(require("./weibo"));
|
|
20
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
21
|
+
const apple = require('./apple');
|
|
22
|
+
const digits = require('./twitter'); // digits tokens are validated by twitter
|
|
9
23
|
const facebook = require('./facebook');
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
const digits = require("./twitter"); // digits tokens are validated by twitter
|
|
19
|
-
const janrainengage = require("./janrainengage");
|
|
20
|
-
const janraincapture = require("./janraincapture");
|
|
21
|
-
const vkontakte = require("./vkontakte");
|
|
22
|
-
const qq = require("./qq");
|
|
23
|
-
const wechat = require("./wechat");
|
|
24
|
-
const weibo = require("./weibo");
|
|
25
|
-
|
|
24
|
+
const google = require('./google');
|
|
25
|
+
const janraincapture = require('./janraincapture');
|
|
26
|
+
const janrainengage = require('./janrainengage');
|
|
27
|
+
const keycloak = require('./keycloak');
|
|
28
|
+
const ldap = require('./ldap');
|
|
29
|
+
const meetup = require('./meetup');
|
|
30
|
+
const phantauth = require('./phantauth');
|
|
31
|
+
const vkontakte = require('./vkontakte');
|
|
26
32
|
const anonymous = {
|
|
27
33
|
validateAuthData: () => {
|
|
28
34
|
return Promise.resolve();
|
|
@@ -31,67 +37,136 @@ const anonymous = {
|
|
|
31
37
|
return Promise.resolve();
|
|
32
38
|
}
|
|
33
39
|
};
|
|
34
|
-
|
|
35
40
|
const providers = {
|
|
41
|
+
apple,
|
|
42
|
+
gcenter: _gcenter.default,
|
|
43
|
+
gpgames: _gpgames.default,
|
|
36
44
|
facebook,
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
linkedin,
|
|
45
|
+
instagram: _instagram.default,
|
|
46
|
+
linkedin: _linkedin.default,
|
|
40
47
|
meetup,
|
|
48
|
+
mfa: _mfa.default,
|
|
41
49
|
google,
|
|
42
|
-
github,
|
|
43
|
-
twitter,
|
|
44
|
-
spotify,
|
|
50
|
+
github: _github.default,
|
|
51
|
+
twitter: _twitter.default,
|
|
52
|
+
spotify: _spotify.default,
|
|
45
53
|
anonymous,
|
|
46
54
|
digits,
|
|
47
55
|
janrainengage,
|
|
48
56
|
janraincapture,
|
|
57
|
+
line: _line.default,
|
|
49
58
|
vkontakte,
|
|
50
|
-
qq,
|
|
51
|
-
wechat,
|
|
52
|
-
weibo
|
|
59
|
+
qq: _qq.default,
|
|
60
|
+
wechat: _wechat.default,
|
|
61
|
+
weibo: _weibo.default,
|
|
62
|
+
phantauth,
|
|
63
|
+
microsoft: _microsoft.default,
|
|
64
|
+
keycloak,
|
|
65
|
+
ldap
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
// Indexed auth policies
|
|
69
|
+
const authAdapterPolicies = {
|
|
70
|
+
default: true,
|
|
71
|
+
solo: true,
|
|
72
|
+
additional: true
|
|
53
73
|
};
|
|
54
|
-
function authDataValidator(adapter, appIds, options) {
|
|
55
|
-
return function (authData) {
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
74
|
+
function authDataValidator(provider, adapter, appIds, options) {
|
|
75
|
+
return async function (authData, req, user, requestObject) {
|
|
76
|
+
if (appIds && typeof adapter.validateAppId === 'function') {
|
|
77
|
+
await Promise.resolve(adapter.validateAppId(appIds, authData, options, requestObject));
|
|
78
|
+
}
|
|
79
|
+
if (adapter.policy && !authAdapterPolicies[adapter.policy] && typeof adapter.policy !== 'function') {
|
|
80
|
+
throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'AuthAdapter policy is not configured correctly. The value must be either "solo", "additional", "default" or undefined (will be handled as "default")');
|
|
81
|
+
}
|
|
82
|
+
if (typeof adapter.validateAuthData === 'function') {
|
|
83
|
+
return adapter.validateAuthData(authData, options, requestObject);
|
|
84
|
+
}
|
|
85
|
+
if (typeof adapter.validateSetUp !== 'function' || typeof adapter.validateLogin !== 'function' || typeof adapter.validateUpdate !== 'function') {
|
|
86
|
+
throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'Adapter is not configured. Implement either validateAuthData or all of the following: validateSetUp, validateLogin and validateUpdate');
|
|
87
|
+
}
|
|
88
|
+
// When masterKey is detected, we should trigger a logged in user
|
|
89
|
+
const isLoggedIn = req.auth.user && user && req.auth.user.id === user.id || user && req.auth.isMaster;
|
|
90
|
+
let hasAuthDataConfigured = false;
|
|
91
|
+
if (user && user.get('authData') && user.get('authData')[provider]) {
|
|
92
|
+
hasAuthDataConfigured = true;
|
|
93
|
+
}
|
|
94
|
+
if (isLoggedIn) {
|
|
95
|
+
// User is updating their authData
|
|
96
|
+
if (hasAuthDataConfigured) {
|
|
97
|
+
return {
|
|
98
|
+
method: 'validateUpdate',
|
|
99
|
+
validator: () => adapter.validateUpdate(authData, options, requestObject)
|
|
100
|
+
};
|
|
59
101
|
}
|
|
60
|
-
|
|
61
|
-
|
|
102
|
+
// Set up if the user does not have the provider configured
|
|
103
|
+
return {
|
|
104
|
+
method: 'validateSetUp',
|
|
105
|
+
validator: () => adapter.validateSetUp(authData, options, requestObject)
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Not logged in and authData is configured on the user
|
|
110
|
+
if (hasAuthDataConfigured) {
|
|
111
|
+
return {
|
|
112
|
+
method: 'validateLogin',
|
|
113
|
+
validator: () => adapter.validateLogin(authData, options, requestObject)
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// User not logged in and the provider is not set up, for example when a new user
|
|
118
|
+
// signs up or an existing user uses a new auth provider
|
|
119
|
+
return {
|
|
120
|
+
method: 'validateSetUp',
|
|
121
|
+
validator: () => adapter.validateSetUp(authData, options, requestObject)
|
|
122
|
+
};
|
|
62
123
|
};
|
|
63
124
|
}
|
|
64
|
-
|
|
65
125
|
function loadAuthAdapter(provider, authOptions) {
|
|
66
|
-
|
|
67
|
-
|
|
126
|
+
// providers are auth providers implemented by default
|
|
127
|
+
let defaultAdapter = providers[provider];
|
|
128
|
+
// authOptions can contain complete custom auth adapters or
|
|
129
|
+
// a default auth adapter like Facebook
|
|
68
130
|
const providerOptions = authOptions[provider];
|
|
131
|
+
if (providerOptions && Object.prototype.hasOwnProperty.call(providerOptions, 'oauth2') && providerOptions['oauth2'] === true) {
|
|
132
|
+
defaultAdapter = _oauth.default;
|
|
133
|
+
}
|
|
69
134
|
|
|
135
|
+
// Default provider not found and a custom auth provider was not provided
|
|
70
136
|
if (!defaultAdapter && !providerOptions) {
|
|
71
137
|
return;
|
|
72
138
|
}
|
|
73
|
-
|
|
139
|
+
const adapter = defaultAdapter instanceof _AuthAdapter.default ? defaultAdapter : Object.assign({}, defaultAdapter);
|
|
140
|
+
const keys = ['validateAuthData', 'validateAppId', 'validateSetUp', 'validateLogin', 'validateUpdate', 'challenge', 'validateOptions', 'policy', 'afterFind'];
|
|
141
|
+
const defaultAuthAdapter = new _AuthAdapter.default();
|
|
142
|
+
keys.forEach(key => {
|
|
143
|
+
const existing = adapter?.[key];
|
|
144
|
+
if (existing && typeof existing === 'function' && existing.toString() === defaultAuthAdapter[key].toString()) {
|
|
145
|
+
adapter[key] = null;
|
|
146
|
+
}
|
|
147
|
+
});
|
|
74
148
|
const appIds = providerOptions ? providerOptions.appIds : undefined;
|
|
75
149
|
|
|
76
150
|
// Try the configuration methods
|
|
77
151
|
if (providerOptions) {
|
|
78
|
-
const optionalAdapter = (0,
|
|
152
|
+
const optionalAdapter = (0, _AdapterLoader.default)(providerOptions, undefined, providerOptions);
|
|
79
153
|
if (optionalAdapter) {
|
|
80
|
-
|
|
154
|
+
keys.forEach(key => {
|
|
81
155
|
if (optionalAdapter[key]) {
|
|
82
156
|
adapter[key] = optionalAdapter[key];
|
|
83
157
|
}
|
|
84
158
|
});
|
|
85
159
|
}
|
|
86
160
|
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
return;
|
|
161
|
+
if (adapter.validateOptions) {
|
|
162
|
+
adapter.validateOptions(providerOptions);
|
|
90
163
|
}
|
|
91
|
-
|
|
92
|
-
|
|
164
|
+
return {
|
|
165
|
+
adapter,
|
|
166
|
+
appIds,
|
|
167
|
+
providerOptions
|
|
168
|
+
};
|
|
93
169
|
}
|
|
94
|
-
|
|
95
170
|
module.exports = function (authOptions = {}, enableAnonymousUsers = true) {
|
|
96
171
|
let _enableAnonymousUsers = enableAnonymousUsers;
|
|
97
172
|
const setEnableAnonymousUsers = function (enable) {
|
|
@@ -99,25 +174,58 @@ module.exports = function (authOptions = {}, enableAnonymousUsers = true) {
|
|
|
99
174
|
};
|
|
100
175
|
// To handle the test cases on configuration
|
|
101
176
|
const getValidatorForProvider = function (provider) {
|
|
102
|
-
|
|
103
177
|
if (provider === 'anonymous' && !_enableAnonymousUsers) {
|
|
178
|
+
return {
|
|
179
|
+
validator: undefined
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
const authAdapter = loadAuthAdapter(provider, authOptions);
|
|
183
|
+
if (!authAdapter) {
|
|
104
184
|
return;
|
|
105
185
|
}
|
|
106
|
-
|
|
107
186
|
const {
|
|
108
187
|
adapter,
|
|
109
188
|
appIds,
|
|
110
189
|
providerOptions
|
|
111
|
-
} =
|
|
112
|
-
|
|
113
|
-
|
|
190
|
+
} = authAdapter;
|
|
191
|
+
return {
|
|
192
|
+
validator: authDataValidator(provider, adapter, appIds, providerOptions),
|
|
193
|
+
adapter
|
|
194
|
+
};
|
|
195
|
+
};
|
|
196
|
+
const runAfterFind = async (req, authData) => {
|
|
197
|
+
if (!authData) {
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
const adapters = Object.keys(authData);
|
|
201
|
+
await Promise.all(adapters.map(async provider => {
|
|
202
|
+
const authAdapter = getValidatorForProvider(provider);
|
|
203
|
+
if (!authAdapter) {
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
const {
|
|
207
|
+
adapter,
|
|
208
|
+
providerOptions
|
|
209
|
+
} = authAdapter;
|
|
210
|
+
const afterFind = adapter.afterFind;
|
|
211
|
+
if (afterFind && typeof afterFind === 'function') {
|
|
212
|
+
const requestObject = {
|
|
213
|
+
ip: req.config.ip,
|
|
214
|
+
user: req.auth.user,
|
|
215
|
+
master: req.auth.isMaster
|
|
216
|
+
};
|
|
217
|
+
const result = afterFind.call(adapter, authData[provider], providerOptions, requestObject);
|
|
218
|
+
if (result) {
|
|
219
|
+
authData[provider] = result;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}));
|
|
114
223
|
};
|
|
115
|
-
|
|
116
224
|
return Object.freeze({
|
|
117
225
|
getValidatorForProvider,
|
|
118
|
-
setEnableAnonymousUsers
|
|
226
|
+
setEnableAnonymousUsers,
|
|
227
|
+
runAfterFind
|
|
119
228
|
});
|
|
120
229
|
};
|
|
121
|
-
|
|
122
230
|
module.exports.loadAuthAdapter = loadAuthAdapter;
|
|
123
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Adapters/Auth/index.js"],"names":["facebook","require","facebookaccountkit","instagram","linkedin","meetup","google","github","twitter","spotify","digits","janrainengage","janraincapture","vkontakte","qq","wechat","weibo","anonymous","validateAuthData","Promise","resolve","validateAppId","providers","authDataValidator","adapter","appIds","options","authData","then","loadAuthAdapter","provider","authOptions","defaultAdapter","Object","assign","providerOptions","undefined","optionalAdapter","forEach","key","module","exports","enableAnonymousUsers","_enableAnonymousUsers","setEnableAnonymousUsers","enable","getValidatorForProvider","freeze"],"mappings":"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","file":"index.js","sourcesContent":["import loadAdapter from '../AdapterLoader';\n\nconst facebook = require('./facebook');\nconst facebookaccountkit = require('./facebookaccountkit');\nconst instagram = require(\"./instagram\");\nconst linkedin = require(\"./linkedin\");\nconst meetup = require(\"./meetup\");\nconst google = require(\"./google\");\nconst github = require(\"./github\");\nconst twitter = require(\"./twitter\");\nconst spotify = require(\"./spotify\");\nconst digits = require(\"./twitter\"); // digits tokens are validated by twitter\nconst janrainengage = require(\"./janrainengage\");\nconst janraincapture = require(\"./janraincapture\");\nconst vkontakte = require(\"./vkontakte\");\nconst qq = require(\"./qq\");\nconst wechat = require(\"./wechat\");\nconst weibo = require(\"./weibo\");\n\nconst anonymous = {\n  validateAuthData: () => {\n    return Promise.resolve();\n  },\n  validateAppId: () => {\n    return Promise.resolve();\n  }\n}\n\nconst providers = {\n  facebook,\n  facebookaccountkit,\n  instagram,\n  linkedin,\n  meetup,\n  google,\n  github,\n  twitter,\n  spotify,\n  anonymous,\n  digits,\n  janrainengage,\n  janraincapture,\n  vkontakte,\n  qq,\n  wechat,\n  weibo\n}\nfunction authDataValidator(adapter, appIds, options) {\n  return function(authData) {\n    return adapter.validateAuthData(authData, options).then(() => {\n      if (appIds) {\n        return adapter.validateAppId(appIds, authData, options);\n      }\n      return Promise.resolve();\n    });\n  }\n}\n\nfunction loadAuthAdapter(provider, authOptions) {\n  const defaultAdapter = providers[provider];\n  const adapter = Object.assign({}, defaultAdapter);\n  const providerOptions = authOptions[provider];\n\n  if (!defaultAdapter && !providerOptions) {\n    return;\n  }\n\n  const appIds = providerOptions ? providerOptions.appIds : undefined;\n\n  // Try the configuration methods\n  if (providerOptions) {\n    const optionalAdapter = loadAdapter(providerOptions, undefined, providerOptions);\n    if (optionalAdapter) {\n      ['validateAuthData', 'validateAppId'].forEach((key) => {\n        if (optionalAdapter[key]) {\n          adapter[key] = optionalAdapter[key];\n        }\n      });\n    }\n  }\n\n  if (!adapter.validateAuthData || !adapter.validateAppId) {\n    return;\n  }\n\n  return {adapter, appIds, providerOptions};\n}\n\nmodule.exports = function(authOptions = {}, enableAnonymousUsers = true) {\n  let _enableAnonymousUsers = enableAnonymousUsers;\n  const setEnableAnonymousUsers = function(enable) {\n    _enableAnonymousUsers = enable;\n  }\n  // To handle the test cases on configuration\n  const getValidatorForProvider = function(provider) {\n\n    if (provider === 'anonymous' && !_enableAnonymousUsers) {\n      return;\n    }\n\n    const {\n      adapter,\n      appIds,\n      providerOptions\n    } = loadAuthAdapter(provider, authOptions);\n\n    return authDataValidator(adapter, appIds, providerOptions);\n  }\n\n  return Object.freeze({\n    getValidatorForProvider,\n    setEnableAnonymousUsers\n  })\n}\n\nmodule.exports.loadAuthAdapter = loadAuthAdapter;\n"]}
|
|
231
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_AdapterLoader","_interopRequireDefault","require","_node","_AuthAdapter","_gcenter","_github","_gpgames","_instagram","_line","_linkedin","_mfa","_microsoft","_oauth","_qq","_spotify","_twitter","_wechat","_weibo","e","__esModule","default","apple","digits","facebook","google","janraincapture","janrainengage","keycloak","ldap","meetup","phantauth","vkontakte","anonymous","validateAuthData","Promise","resolve","validateAppId","providers","gcenter","gpgames","instagram","linkedin","mfa","github","twitter","spotify","line","qq","wechat","weibo","microsoft","authAdapterPolicies","solo","additional","authDataValidator","provider","adapter","appIds","options","authData","req","user","requestObject","policy","Parse","Error","OTHER_CAUSE","validateSetUp","validateLogin","validateUpdate","isLoggedIn","auth","id","isMaster","hasAuthDataConfigured","get","method","validator","loadAuthAdapter","authOptions","defaultAdapter","providerOptions","Object","prototype","hasOwnProperty","call","oauth2","AuthAdapter","assign","keys","defaultAuthAdapter","forEach","key","existing","toString","undefined","optionalAdapter","loadAdapter","validateOptions","module","exports","enableAnonymousUsers","_enableAnonymousUsers","setEnableAnonymousUsers","enable","getValidatorForProvider","authAdapter","runAfterFind","adapters","all","map","afterFind","ip","config","master","result","freeze"],"sources":["../../../src/Adapters/Auth/index.js"],"sourcesContent":["import loadAdapter from '../AdapterLoader';\nimport Parse from 'parse/node';\nimport AuthAdapter from './AuthAdapter';\n\nconst apple = require('./apple');\nconst digits = require('./twitter'); // digits tokens are validated by twitter\nconst facebook = require('./facebook');\nimport gcenter from './gcenter';\nimport github from './github';\nconst google = require('./google');\nimport gpgames from './gpgames';\nimport instagram from './instagram';\nconst janraincapture = require('./janraincapture');\nconst janrainengage = require('./janrainengage');\nconst keycloak = require('./keycloak');\nconst ldap = require('./ldap');\nimport line from './line';\nimport linkedin from './linkedin';\nconst meetup = require('./meetup');\nimport mfa from './mfa';\nimport microsoft from './microsoft';\nimport oauth2 from './oauth2';\nconst phantauth = require('./phantauth');\nimport qq from './qq';\nimport spotify from './spotify';\nimport twitter from './twitter';\nconst vkontakte = require('./vkontakte');\nimport wechat from './wechat';\nimport weibo from './weibo';\n\n\nconst anonymous = {\n  validateAuthData: () => {\n    return Promise.resolve();\n  },\n  validateAppId: () => {\n    return Promise.resolve();\n  },\n};\n\nconst providers = {\n  apple,\n  gcenter,\n  gpgames,\n  facebook,\n  instagram,\n  linkedin,\n  meetup,\n  mfa,\n  google,\n  github,\n  twitter,\n  spotify,\n  anonymous,\n  digits,\n  janrainengage,\n  janraincapture,\n  line,\n  vkontakte,\n  qq,\n  wechat,\n  weibo,\n  phantauth,\n  microsoft,\n  keycloak,\n  ldap,\n};\n\n// Indexed auth policies\nconst authAdapterPolicies = {\n  default: true,\n  solo: true,\n  additional: true,\n};\n\nfunction authDataValidator(provider, adapter, appIds, options) {\n  return async function (authData, req, user, requestObject) {\n    if (appIds && typeof adapter.validateAppId === 'function') {\n      await Promise.resolve(adapter.validateAppId(appIds, authData, options, requestObject));\n    }\n    if (\n      adapter.policy &&\n      !authAdapterPolicies[adapter.policy] &&\n      typeof adapter.policy !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'AuthAdapter policy is not configured correctly. The value must be either \"solo\", \"additional\", \"default\" or undefined (will be handled as \"default\")'\n      );\n    }\n    if (typeof adapter.validateAuthData === 'function') {\n      return adapter.validateAuthData(authData, options, requestObject);\n    }\n    if (\n      typeof adapter.validateSetUp !== 'function' ||\n      typeof adapter.validateLogin !== 'function' ||\n      typeof adapter.validateUpdate !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'Adapter is not configured. Implement either validateAuthData or all of the following: validateSetUp, validateLogin and validateUpdate'\n      );\n    }\n    // When masterKey is detected, we should trigger a logged in user\n    const isLoggedIn =\n      (req.auth.user && user && req.auth.user.id === user.id) || (user && req.auth.isMaster);\n    let hasAuthDataConfigured = false;\n\n    if (user && user.get('authData') && user.get('authData')[provider]) {\n      hasAuthDataConfigured = true;\n    }\n\n    if (isLoggedIn) {\n      // User is updating their authData\n      if (hasAuthDataConfigured) {\n        return {\n          method: 'validateUpdate',\n          validator: () => adapter.validateUpdate(authData, options, requestObject),\n        };\n      }\n      // Set up if the user does not have the provider configured\n      return {\n        method: 'validateSetUp',\n        validator: () => adapter.validateSetUp(authData, options, requestObject),\n      };\n    }\n\n    // Not logged in and authData is configured on the user\n    if (hasAuthDataConfigured) {\n      return {\n        method: 'validateLogin',\n        validator: () => adapter.validateLogin(authData, options, requestObject),\n      };\n    }\n\n    // User not logged in and the provider is not set up, for example when a new user\n    // signs up or an existing user uses a new auth provider\n    return {\n      method: 'validateSetUp',\n      validator: () => adapter.validateSetUp(authData, options, requestObject),\n    };\n  };\n}\n\nfunction loadAuthAdapter(provider, authOptions) {\n  // providers are auth providers implemented by default\n  let defaultAdapter = providers[provider];\n  // authOptions can contain complete custom auth adapters or\n  // a default auth adapter like Facebook\n  const providerOptions = authOptions[provider];\n  if (\n    providerOptions &&\n    Object.prototype.hasOwnProperty.call(providerOptions, 'oauth2') &&\n    providerOptions['oauth2'] === true\n  ) {\n    defaultAdapter = oauth2;\n  }\n\n  // Default provider not found and a custom auth provider was not provided\n  if (!defaultAdapter && !providerOptions) {\n    return;\n  }\n\n  const adapter =\n    defaultAdapter instanceof AuthAdapter ? defaultAdapter : Object.assign({}, defaultAdapter);\n  const keys = [\n    'validateAuthData',\n    'validateAppId',\n    'validateSetUp',\n    'validateLogin',\n    'validateUpdate',\n    'challenge',\n    'validateOptions',\n    'policy',\n    'afterFind',\n  ];\n  const defaultAuthAdapter = new AuthAdapter();\n  keys.forEach(key => {\n    const existing = adapter?.[key];\n    if (\n      existing &&\n      typeof existing === 'function' &&\n      existing.toString() === defaultAuthAdapter[key].toString()\n    ) {\n      adapter[key] = null;\n    }\n  });\n  const appIds = providerOptions ? providerOptions.appIds : undefined;\n\n  // Try the configuration methods\n  if (providerOptions) {\n    const optionalAdapter = loadAdapter(providerOptions, undefined, providerOptions);\n    if (optionalAdapter) {\n      keys.forEach(key => {\n        if (optionalAdapter[key]) {\n          adapter[key] = optionalAdapter[key];\n        }\n      });\n    }\n  }\n  if (adapter.validateOptions) {\n    adapter.validateOptions(providerOptions);\n  }\n\n  return { adapter, appIds, providerOptions };\n}\n\nmodule.exports = function (authOptions = {}, enableAnonymousUsers = true) {\n  let _enableAnonymousUsers = enableAnonymousUsers;\n  const setEnableAnonymousUsers = function (enable) {\n    _enableAnonymousUsers = enable;\n  };\n  // To handle the test cases on configuration\n  const getValidatorForProvider = function (provider) {\n    if (provider === 'anonymous' && !_enableAnonymousUsers) {\n      return { validator: undefined };\n    }\n    const authAdapter = loadAuthAdapter(provider, authOptions);\n    if (!authAdapter) { return; }\n    const { adapter, appIds, providerOptions } = authAdapter;\n    return { validator: authDataValidator(provider, adapter, appIds, providerOptions), adapter };\n  };\n\n  const runAfterFind = async (req, authData) => {\n    if (!authData) {\n      return;\n    }\n    const adapters = Object.keys(authData);\n    await Promise.all(\n      adapters.map(async provider => {\n        const authAdapter = getValidatorForProvider(provider);\n        if (!authAdapter) {\n          return;\n        }\n        const { adapter, providerOptions } = authAdapter;\n        const afterFind = adapter.afterFind;\n        if (afterFind && typeof afterFind === 'function') {\n          const requestObject = {\n            ip: req.config.ip,\n            user: req.auth.user,\n            master: req.auth.isMaster,\n          };\n          const result = afterFind.call(\n            adapter,\n            authData[provider],\n            providerOptions,\n            requestObject,\n          );\n          if (result) {\n            authData[provider] = result;\n          }\n        }\n      })\n    );\n  };\n\n  return Object.freeze({\n    getValidatorForProvider,\n    setEnableAnonymousUsers,\n    runAfterFind,\n  });\n};\n\nmodule.exports.loadAuthAdapter = loadAuthAdapter;\n"],"mappings":";;AAAA,IAAAA,cAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,KAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,YAAA,GAAAH,sBAAA,CAAAC,OAAA;AAKA,IAAAG,QAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,OAAA,GAAAL,sBAAA,CAAAC,OAAA;AAEA,IAAAK,QAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,UAAA,GAAAP,sBAAA,CAAAC,OAAA;AAKA,IAAAO,KAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,SAAA,GAAAT,sBAAA,CAAAC,OAAA;AAEA,IAAAS,IAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,UAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,MAAA,GAAAZ,sBAAA,CAAAC,OAAA;AAEA,IAAAY,GAAA,GAAAb,sBAAA,CAAAC,OAAA;AACA,IAAAa,QAAA,GAAAd,sBAAA,CAAAC,OAAA;AACA,IAAAc,QAAA,GAAAf,sBAAA,CAAAC,OAAA;AAEA,IAAAe,OAAA,GAAAhB,sBAAA,CAAAC,OAAA;AACA,IAAAgB,MAAA,GAAAjB,sBAAA,CAAAC,OAAA;AAA4B,SAAAD,uBAAAkB,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAxB5B,MAAMG,KAAK,GAAGpB,OAAO,CAAC,SAAS,CAAC;AAChC,MAAMqB,MAAM,GAAGrB,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;AACrC,MAAMsB,QAAQ,GAAGtB,OAAO,CAAC,YAAY,CAAC;AAGtC,MAAMuB,MAAM,GAAGvB,OAAO,CAAC,UAAU,CAAC;AAGlC,MAAMwB,cAAc,GAAGxB,OAAO,CAAC,kBAAkB,CAAC;AAClD,MAAMyB,aAAa,GAAGzB,OAAO,CAAC,iBAAiB,CAAC;AAChD,MAAM0B,QAAQ,GAAG1B,OAAO,CAAC,YAAY,CAAC;AACtC,MAAM2B,IAAI,GAAG3B,OAAO,CAAC,QAAQ,CAAC;AAG9B,MAAM4B,MAAM,GAAG5B,OAAO,CAAC,UAAU,CAAC;AAIlC,MAAM6B,SAAS,GAAG7B,OAAO,CAAC,aAAa,CAAC;AAIxC,MAAM8B,SAAS,GAAG9B,OAAO,CAAC,aAAa,CAAC;AAKxC,MAAM+B,SAAS,GAAG;EAChBC,gBAAgB,EAAEA,CAAA,KAAM;IACtB,OAAOC,OAAO,CAACC,OAAO,CAAC,CAAC;EAC1B,CAAC;EACDC,aAAa,EAAEA,CAAA,KAAM;IACnB,OAAOF,OAAO,CAACC,OAAO,CAAC,CAAC;EAC1B;AACF,CAAC;AAED,MAAME,SAAS,GAAG;EAChBhB,KAAK;EACLiB,OAAO,EAAPA,gBAAO;EACPC,OAAO,EAAPA,gBAAO;EACPhB,QAAQ;EACRiB,SAAS,EAATA,kBAAS;EACTC,QAAQ,EAARA,iBAAQ;EACRZ,MAAM;EACNa,GAAG,EAAHA,YAAG;EACHlB,MAAM;EACNmB,MAAM,EAANA,eAAM;EACNC,OAAO,EAAPA,gBAAO;EACPC,OAAO,EAAPA,gBAAO;EACPb,SAAS;EACTV,MAAM;EACNI,aAAa;EACbD,cAAc;EACdqB,IAAI,EAAJA,aAAI;EACJf,SAAS;EACTgB,EAAE,EAAFA,WAAE;EACFC,MAAM,EAANA,eAAM;EACNC,KAAK,EAALA,cAAK;EACLnB,SAAS;EACToB,SAAS,EAATA,kBAAS;EACTvB,QAAQ;EACRC;AACF,CAAC;;AAED;AACA,MAAMuB,mBAAmB,GAAG;EAC1B/B,OAAO,EAAE,IAAI;EACbgC,IAAI,EAAE,IAAI;EACVC,UAAU,EAAE;AACd,CAAC;AAED,SAASC,iBAAiBA,CAACC,QAAQ,EAAEC,OAAO,EAAEC,MAAM,EAAEC,OAAO,EAAE;EAC7D,OAAO,gBAAgBC,QAAQ,EAAEC,GAAG,EAAEC,IAAI,EAAEC,aAAa,EAAE;IACzD,IAAIL,MAAM,IAAI,OAAOD,OAAO,CAACpB,aAAa,KAAK,UAAU,EAAE;MACzD,MAAMF,OAAO,CAACC,OAAO,CAACqB,OAAO,CAACpB,aAAa,CAACqB,MAAM,EAAEE,QAAQ,EAAED,OAAO,EAAEI,aAAa,CAAC,CAAC;IACxF;IACA,IACEN,OAAO,CAACO,MAAM,IACd,CAACZ,mBAAmB,CAACK,OAAO,CAACO,MAAM,CAAC,IACpC,OAAOP,OAAO,CAACO,MAAM,KAAK,UAAU,EACpC;MACA,MAAM,IAAIC,aAAK,CAACC,KAAK,CACnBD,aAAK,CAACC,KAAK,CAACC,WAAW,EACvB,sJACF,CAAC;IACH;IACA,IAAI,OAAOV,OAAO,CAACvB,gBAAgB,KAAK,UAAU,EAAE;MAClD,OAAOuB,OAAO,CAACvB,gBAAgB,CAAC0B,QAAQ,EAAED,OAAO,EAAEI,aAAa,CAAC;IACnE;IACA,IACE,OAAON,OAAO,CAACW,aAAa,KAAK,UAAU,IAC3C,OAAOX,OAAO,CAACY,aAAa,KAAK,UAAU,IAC3C,OAAOZ,OAAO,CAACa,cAAc,KAAK,UAAU,EAC5C;MACA,MAAM,IAAIL,aAAK,CAACC,KAAK,CACnBD,aAAK,CAACC,KAAK,CAACC,WAAW,EACvB,uIACF,CAAC;IACH;IACA;IACA,MAAMI,UAAU,GACbV,GAAG,CAACW,IAAI,CAACV,IAAI,IAAIA,IAAI,IAAID,GAAG,CAACW,IAAI,CAACV,IAAI,CAACW,EAAE,KAAKX,IAAI,CAACW,EAAE,IAAMX,IAAI,IAAID,GAAG,CAACW,IAAI,CAACE,QAAS;IACxF,IAAIC,qBAAqB,GAAG,KAAK;IAEjC,IAAIb,IAAI,IAAIA,IAAI,CAACc,GAAG,CAAC,UAAU,CAAC,IAAId,IAAI,CAACc,GAAG,CAAC,UAAU,CAAC,CAACpB,QAAQ,CAAC,EAAE;MAClEmB,qBAAqB,GAAG,IAAI;IAC9B;IAEA,IAAIJ,UAAU,EAAE;MACd;MACA,IAAII,qBAAqB,EAAE;QACzB,OAAO;UACLE,MAAM,EAAE,gBAAgB;UACxBC,SAAS,EAAEA,CAAA,KAAMrB,OAAO,CAACa,cAAc,CAACV,QAAQ,EAAED,OAAO,EAAEI,aAAa;QAC1E,CAAC;MACH;MACA;MACA,OAAO;QACLc,MAAM,EAAE,eAAe;QACvBC,SAAS,EAAEA,CAAA,KAAMrB,OAAO,CAACW,aAAa,CAACR,QAAQ,EAAED,OAAO,EAAEI,aAAa;MACzE,CAAC;IACH;;IAEA;IACA,IAAIY,qBAAqB,EAAE;MACzB,OAAO;QACLE,MAAM,EAAE,eAAe;QACvBC,SAAS,EAAEA,CAAA,KAAMrB,OAAO,CAACY,aAAa,CAACT,QAAQ,EAAED,OAAO,EAAEI,aAAa;MACzE,CAAC;IACH;;IAEA;IACA;IACA,OAAO;MACLc,MAAM,EAAE,eAAe;MACvBC,SAAS,EAAEA,CAAA,KAAMrB,OAAO,CAACW,aAAa,CAACR,QAAQ,EAAED,OAAO,EAAEI,aAAa;IACzE,CAAC;EACH,CAAC;AACH;AAEA,SAASgB,eAAeA,CAACvB,QAAQ,EAAEwB,WAAW,EAAE;EAC9C;EACA,IAAIC,cAAc,GAAG3C,SAAS,CAACkB,QAAQ,CAAC;EACxC;EACA;EACA,MAAM0B,eAAe,GAAGF,WAAW,CAACxB,QAAQ,CAAC;EAC7C,IACE0B,eAAe,IACfC,MAAM,CAACC,SAAS,CAACC,cAAc,CAACC,IAAI,CAACJ,eAAe,EAAE,QAAQ,CAAC,IAC/DA,eAAe,CAAC,QAAQ,CAAC,KAAK,IAAI,EAClC;IACAD,cAAc,GAAGM,cAAM;EACzB;;EAEA;EACA,IAAI,CAACN,cAAc,IAAI,CAACC,eAAe,EAAE;IACvC;EACF;EAEA,MAAMzB,OAAO,GACXwB,cAAc,YAAYO,oBAAW,GAAGP,cAAc,GAAGE,MAAM,CAACM,MAAM,CAAC,CAAC,CAAC,EAAER,cAAc,CAAC;EAC5F,MAAMS,IAAI,GAAG,CACX,kBAAkB,EAClB,eAAe,EACf,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,iBAAiB,EACjB,QAAQ,EACR,WAAW,CACZ;EACD,MAAMC,kBAAkB,GAAG,IAAIH,oBAAW,CAAC,CAAC;EAC5CE,IAAI,CAACE,OAAO,CAACC,GAAG,IAAI;IAClB,MAAMC,QAAQ,GAAGrC,OAAO,GAAGoC,GAAG,CAAC;IAC/B,IACEC,QAAQ,IACR,OAAOA,QAAQ,KAAK,UAAU,IAC9BA,QAAQ,CAACC,QAAQ,CAAC,CAAC,KAAKJ,kBAAkB,CAACE,GAAG,CAAC,CAACE,QAAQ,CAAC,CAAC,EAC1D;MACAtC,OAAO,CAACoC,GAAG,CAAC,GAAG,IAAI;IACrB;EACF,CAAC,CAAC;EACF,MAAMnC,MAAM,GAAGwB,eAAe,GAAGA,eAAe,CAACxB,MAAM,GAAGsC,SAAS;;EAEnE;EACA,IAAId,eAAe,EAAE;IACnB,MAAMe,eAAe,GAAG,IAAAC,sBAAW,EAAChB,eAAe,EAAEc,SAAS,EAAEd,eAAe,CAAC;IAChF,IAAIe,eAAe,EAAE;MACnBP,IAAI,CAACE,OAAO,CAACC,GAAG,IAAI;QAClB,IAAII,eAAe,CAACJ,GAAG,CAAC,EAAE;UACxBpC,OAAO,CAACoC,GAAG,CAAC,GAAGI,eAAe,CAACJ,GAAG,CAAC;QACrC;MACF,CAAC,CAAC;IACJ;EACF;EACA,IAAIpC,OAAO,CAAC0C,eAAe,EAAE;IAC3B1C,OAAO,CAAC0C,eAAe,CAACjB,eAAe,CAAC;EAC1C;EAEA,OAAO;IAAEzB,OAAO;IAAEC,MAAM;IAAEwB;EAAgB,CAAC;AAC7C;AAEAkB,MAAM,CAACC,OAAO,GAAG,UAAUrB,WAAW,GAAG,CAAC,CAAC,EAAEsB,oBAAoB,GAAG,IAAI,EAAE;EACxE,IAAIC,qBAAqB,GAAGD,oBAAoB;EAChD,MAAME,uBAAuB,GAAG,SAAAA,CAAUC,MAAM,EAAE;IAChDF,qBAAqB,GAAGE,MAAM;EAChC,CAAC;EACD;EACA,MAAMC,uBAAuB,GAAG,SAAAA,CAAUlD,QAAQ,EAAE;IAClD,IAAIA,QAAQ,KAAK,WAAW,IAAI,CAAC+C,qBAAqB,EAAE;MACtD,OAAO;QAAEzB,SAAS,EAAEkB;MAAU,CAAC;IACjC;IACA,MAAMW,WAAW,GAAG5B,eAAe,CAACvB,QAAQ,EAAEwB,WAAW,CAAC;IAC1D,IAAI,CAAC2B,WAAW,EAAE;MAAE;IAAQ;IAC5B,MAAM;MAAElD,OAAO;MAAEC,MAAM;MAAEwB;IAAgB,CAAC,GAAGyB,WAAW;IACxD,OAAO;MAAE7B,SAAS,EAAEvB,iBAAiB,CAACC,QAAQ,EAAEC,OAAO,EAAEC,MAAM,EAAEwB,eAAe,CAAC;MAAEzB;IAAQ,CAAC;EAC9F,CAAC;EAED,MAAMmD,YAAY,GAAG,MAAAA,CAAO/C,GAAG,EAAED,QAAQ,KAAK;IAC5C,IAAI,CAACA,QAAQ,EAAE;MACb;IACF;IACA,MAAMiD,QAAQ,GAAG1B,MAAM,CAACO,IAAI,CAAC9B,QAAQ,CAAC;IACtC,MAAMzB,OAAO,CAAC2E,GAAG,CACfD,QAAQ,CAACE,GAAG,CAAC,MAAMvD,QAAQ,IAAI;MAC7B,MAAMmD,WAAW,GAAGD,uBAAuB,CAAClD,QAAQ,CAAC;MACrD,IAAI,CAACmD,WAAW,EAAE;QAChB;MACF;MACA,MAAM;QAAElD,OAAO;QAAEyB;MAAgB,CAAC,GAAGyB,WAAW;MAChD,MAAMK,SAAS,GAAGvD,OAAO,CAACuD,SAAS;MACnC,IAAIA,SAAS,IAAI,OAAOA,SAAS,KAAK,UAAU,EAAE;QAChD,MAAMjD,aAAa,GAAG;UACpBkD,EAAE,EAAEpD,GAAG,CAACqD,MAAM,CAACD,EAAE;UACjBnD,IAAI,EAAED,GAAG,CAACW,IAAI,CAACV,IAAI;UACnBqD,MAAM,EAAEtD,GAAG,CAACW,IAAI,CAACE;QACnB,CAAC;QACD,MAAM0C,MAAM,GAAGJ,SAAS,CAAC1B,IAAI,CAC3B7B,OAAO,EACPG,QAAQ,CAACJ,QAAQ,CAAC,EAClB0B,eAAe,EACfnB,aACF,CAAC;QACD,IAAIqD,MAAM,EAAE;UACVxD,QAAQ,CAACJ,QAAQ,CAAC,GAAG4D,MAAM;QAC7B;MACF;IACF,CAAC,CACH,CAAC;EACH,CAAC;EAED,OAAOjC,MAAM,CAACkC,MAAM,CAAC;IACnBX,uBAAuB;IACvBF,uBAAuB;IACvBI;EACF,CAAC,CAAC;AACJ,CAAC;AAEDR,MAAM,CAACC,OAAO,CAACtB,eAAe,GAAGA,eAAe","ignoreList":[]}
|
|
@@ -1,44 +1,118 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _BaseCodeAuthAdapter = _interopRequireDefault(require("./BaseCodeAuthAdapter"));
|
|
8
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
+
/**
|
|
10
|
+
* Parse Server authentication adapter for Instagram.
|
|
11
|
+
*
|
|
12
|
+
* @class InstagramAdapter
|
|
13
|
+
* @param {Object} options - The adapter configuration options.
|
|
14
|
+
* @param {string} options.clientId - Your Instagram App Client ID. Required for secure authentication.
|
|
15
|
+
* @param {string} options.clientSecret - Your Instagram App Client Secret. Required for secure authentication.
|
|
16
|
+
* @param {boolean} [options.enableInsecureAuth=false] - **[DEPRECATED]** Enable insecure authentication (not recommended).
|
|
17
|
+
*
|
|
18
|
+
* @description
|
|
19
|
+
* ## Parse Server Configuration
|
|
20
|
+
* To configure Parse Server for Instagram authentication, use the following structure:
|
|
21
|
+
* ```json
|
|
22
|
+
* {
|
|
23
|
+
* "auth": {
|
|
24
|
+
* "instagram": {
|
|
25
|
+
* "clientId": "your-client-id",
|
|
26
|
+
* "clientSecret": "your-client-secret"
|
|
27
|
+
* }
|
|
28
|
+
* }
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
* ### Insecure Configuration (Not Recommended)
|
|
32
|
+
* ```json
|
|
33
|
+
* {
|
|
34
|
+
* "auth": {
|
|
35
|
+
* "instagram": {
|
|
36
|
+
* "enableInsecureAuth": true
|
|
37
|
+
* }
|
|
38
|
+
* }
|
|
39
|
+
* }
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* The adapter requires the following `authData` fields:
|
|
43
|
+
* - **Secure Authentication**: `code`, `redirect_uri`.
|
|
44
|
+
* - **Insecure Authentication (Deprecated)**: `id`, `access_token`.
|
|
45
|
+
*
|
|
46
|
+
* ## Auth Payloads
|
|
47
|
+
* ### Secure Authentication Payload
|
|
48
|
+
* ```json
|
|
49
|
+
* {
|
|
50
|
+
* "instagram": {
|
|
51
|
+
* "code": "lmn789opq012rst345uvw",
|
|
52
|
+
* "redirect_uri": "https://example.com/callback"
|
|
53
|
+
* }
|
|
54
|
+
* }
|
|
55
|
+
* ```
|
|
56
|
+
*
|
|
57
|
+
* ### Insecure Authentication Payload (Deprecated)
|
|
58
|
+
* ```json
|
|
59
|
+
* {
|
|
60
|
+
* "instagram": {
|
|
61
|
+
* "id": "1234567",
|
|
62
|
+
* "access_token": "AQXNnd2hIT6z9bHFzZz2Kp1ghiMz_RtyuvwXYZ123abc"
|
|
63
|
+
* }
|
|
64
|
+
* }
|
|
65
|
+
* ```
|
|
66
|
+
*
|
|
67
|
+
* ## Notes
|
|
68
|
+
* - `enableInsecureAuth` is **deprecated** and will be removed in future versions. Use secure authentication with `code` and `redirect_uri`.
|
|
69
|
+
* - Secure authentication exchanges the `code` and `redirect_uri` provided by the client for an access token using Instagram's OAuth flow.
|
|
70
|
+
*
|
|
71
|
+
* @see {@link https://developers.facebook.com/docs/instagram-basic-display-api/getting-started Instagram Basic Display API - Getting Started}
|
|
72
|
+
*/
|
|
6
73
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return new Promise(function (resolve, reject) {
|
|
25
|
-
https.get("https://api.instagram.com/v1/" + path, function (res) {
|
|
26
|
-
var data = '';
|
|
27
|
-
res.on('data', function (chunk) {
|
|
28
|
-
data += chunk;
|
|
29
|
-
});
|
|
30
|
-
res.on('end', function () {
|
|
31
|
-
data = JSON.parse(data);
|
|
32
|
-
resolve(data);
|
|
33
|
-
});
|
|
34
|
-
}).on('error', function () {
|
|
35
|
-
reject('Failed to validate this access token with Instagram.');
|
|
74
|
+
class InstagramAdapter extends _BaseCodeAuthAdapter.default {
|
|
75
|
+
constructor() {
|
|
76
|
+
super('Instagram');
|
|
77
|
+
}
|
|
78
|
+
async getAccessTokenFromCode(authData) {
|
|
79
|
+
const response = await fetch('https://api.instagram.com/oauth/access_token', {
|
|
80
|
+
method: 'POST',
|
|
81
|
+
headers: {
|
|
82
|
+
'Content-Type': 'application/x-www-form-urlencoded'
|
|
83
|
+
},
|
|
84
|
+
body: new URLSearchParams({
|
|
85
|
+
client_id: this.clientId,
|
|
86
|
+
client_secret: this.clientSecret,
|
|
87
|
+
grant_type: 'authorization_code',
|
|
88
|
+
redirect_uri: this.redirectUri,
|
|
89
|
+
code: authData.code
|
|
90
|
+
})
|
|
36
91
|
});
|
|
37
|
-
|
|
92
|
+
if (!response.ok) {
|
|
93
|
+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram API request failed.');
|
|
94
|
+
}
|
|
95
|
+
const data = await response.json();
|
|
96
|
+
if (data.error) {
|
|
97
|
+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, data.error_description || data.error);
|
|
98
|
+
}
|
|
99
|
+
return data.access_token;
|
|
100
|
+
}
|
|
101
|
+
async getUserFromAccessToken(accessToken, authData) {
|
|
102
|
+
const apiURL = 'https://graph.instagram.com/';
|
|
103
|
+
const path = `${apiURL}me?fields=id&access_token=${accessToken}`;
|
|
104
|
+
const response = await fetch(path);
|
|
105
|
+
if (!response.ok) {
|
|
106
|
+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram API request failed.');
|
|
107
|
+
}
|
|
108
|
+
const user = await response.json();
|
|
109
|
+
if (user?.id !== authData.id) {
|
|
110
|
+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram auth is invalid for this user.');
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
id: user.id
|
|
114
|
+
};
|
|
115
|
+
}
|
|
38
116
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
validateAppId: validateAppId,
|
|
42
|
-
validateAuthData: validateAuthData
|
|
43
|
-
};
|
|
44
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BZGFwdGVycy9BdXRoL2luc3RhZ3JhbS5qcyJdLCJuYW1lcyI6WyJodHRwcyIsInJlcXVpcmUiLCJQYXJzZSIsInZhbGlkYXRlQXV0aERhdGEiLCJhdXRoRGF0YSIsInJlcXVlc3QiLCJhY2Nlc3NfdG9rZW4iLCJ0aGVuIiwicmVzcG9uc2UiLCJkYXRhIiwiaWQiLCJFcnJvciIsIk9CSkVDVF9OT1RfRk9VTkQiLCJ2YWxpZGF0ZUFwcElkIiwiUHJvbWlzZSIsInJlc29sdmUiLCJwYXRoIiwicmVqZWN0IiwiZ2V0IiwicmVzIiwib24iLCJjaHVuayIsIkpTT04iLCJwYXJzZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiI7O0FBQUE7QUFDQSxJQUFJQSxRQUFRQyxRQUFRLE9BQVIsQ0FBWjtBQUNBLElBQUlDLFFBQVFELFFBQVEsWUFBUixFQUFzQkMsS0FBbEM7O0FBRUE7QUFDQSxTQUFTQyxnQkFBVCxDQUEwQkMsUUFBMUIsRUFBb0M7QUFDbEMsU0FBT0MsUUFBUSw4QkFBOEJELFNBQVNFLFlBQS9DLEVBQ0pDLElBREksQ0FDRUMsUUFBRCxJQUFjO0FBQ2xCLFFBQUlBLFlBQVlBLFNBQVNDLElBQXJCLElBQTZCRCxTQUFTQyxJQUFULENBQWNDLEVBQWQsSUFBb0JOLFNBQVNNLEVBQTlELEVBQWtFO0FBQ2hFO0FBQ0Q7QUFDRCxVQUFNLElBQUlSLE1BQU1TLEtBQVYsQ0FDSlQsTUFBTVMsS0FBTixDQUFZQyxnQkFEUixFQUVKLDBDQUZJLENBQU47QUFHRCxHQVJJLENBQVA7QUFTRDs7QUFFRDtBQUNBLFNBQVNDLGFBQVQsR0FBeUI7QUFDdkIsU0FBT0MsUUFBUUMsT0FBUixFQUFQO0FBQ0Q7O0FBRUQ7QUFDQSxTQUFTVixPQUFULENBQWlCVyxJQUFqQixFQUF1QjtBQUNyQixTQUFPLElBQUlGLE9BQUosQ0FBWSxVQUFTQyxPQUFULEVBQWtCRSxNQUFsQixFQUEwQjtBQUMzQ2pCLFVBQU1rQixHQUFOLENBQVUsa0NBQWtDRixJQUE1QyxFQUFrRCxVQUFTRyxHQUFULEVBQWM7QUFDOUQsVUFBSVYsT0FBTyxFQUFYO0FBQ0FVLFVBQUlDLEVBQUosQ0FBTyxNQUFQLEVBQWUsVUFBU0MsS0FBVCxFQUFnQjtBQUM3QlosZ0JBQVFZLEtBQVI7QUFDRCxPQUZEO0FBR0FGLFVBQUlDLEVBQUosQ0FBTyxLQUFQLEVBQWMsWUFBVztBQUN2QlgsZUFBT2EsS0FBS0MsS0FBTCxDQUFXZCxJQUFYLENBQVA7QUFDQU0sZ0JBQVFOLElBQVI7QUFDRCxPQUhEO0FBSUQsS0FURCxFQVNHVyxFQVRILENBU00sT0FUTixFQVNlLFlBQVc7QUFDeEJILGFBQU8sc0RBQVA7QUFDRCxLQVhEO0FBWUQsR0FiTSxDQUFQO0FBY0Q7O0FBRURPLE9BQU9DLE9BQVAsR0FBaUI7QUFDZlosaUJBQWVBLGFBREE7QUFFZlYsb0JBQWtCQTtBQUZILENBQWpCIiwiZmlsZSI6Imluc3RhZ3JhbS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEhlbHBlciBmdW5jdGlvbnMgZm9yIGFjY2Vzc2luZyB0aGUgaW5zdGFncmFtIEFQSS5cbnZhciBodHRwcyA9IHJlcXVpcmUoJ2h0dHBzJyk7XG52YXIgUGFyc2UgPSByZXF1aXJlKCdwYXJzZS9ub2RlJykuUGFyc2U7XG5cbi8vIFJldHVybnMgYSBwcm9taXNlIHRoYXQgZnVsZmlsbHMgaWZmIHRoaXMgdXNlciBpZCBpcyB2YWxpZC5cbmZ1bmN0aW9uIHZhbGlkYXRlQXV0aERhdGEoYXV0aERhdGEpIHtcbiAgcmV0dXJuIHJlcXVlc3QoXCJ1c2Vycy9zZWxmLz9hY2Nlc3NfdG9rZW49XCIgKyBhdXRoRGF0YS5hY2Nlc3NfdG9rZW4pXG4gICAgLnRoZW4oKHJlc3BvbnNlKSA9PiB7XG4gICAgICBpZiAocmVzcG9uc2UgJiYgcmVzcG9uc2UuZGF0YSAmJiByZXNwb25zZS5kYXRhLmlkID09IGF1dGhEYXRhLmlkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuT0JKRUNUX05PVF9GT1VORCxcbiAgICAgICAgJ0luc3RhZ3JhbSBhdXRoIGlzIGludmFsaWQgZm9yIHRoaXMgdXNlci4nKTtcbiAgICB9KTtcbn1cblxuLy8gUmV0dXJucyBhIHByb21pc2UgdGhhdCBmdWxmaWxscyBpZmYgdGhpcyBhcHAgaWQgaXMgdmFsaWQuXG5mdW5jdGlvbiB2YWxpZGF0ZUFwcElkKCkge1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG59XG5cbi8vIEEgcHJvbWlzZXkgd3JhcHBlciBmb3IgYXBpIHJlcXVlc3RzXG5mdW5jdGlvbiByZXF1ZXN0KHBhdGgpIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkge1xuICAgIGh0dHBzLmdldChcImh0dHBzOi8vYXBpLmluc3RhZ3JhbS5jb20vdjEvXCIgKyBwYXRoLCBmdW5jdGlvbihyZXMpIHtcbiAgICAgIHZhciBkYXRhID0gJyc7XG4gICAgICByZXMub24oJ2RhdGEnLCBmdW5jdGlvbihjaHVuaykge1xuICAgICAgICBkYXRhICs9IGNodW5rO1xuICAgICAgfSk7XG4gICAgICByZXMub24oJ2VuZCcsIGZ1bmN0aW9uKCkge1xuICAgICAgICBkYXRhID0gSlNPTi5wYXJzZShkYXRhKTtcbiAgICAgICAgcmVzb2x2ZShkYXRhKTtcbiAgICAgIH0pO1xuICAgIH0pLm9uKCdlcnJvcicsIGZ1bmN0aW9uKCkge1xuICAgICAgcmVqZWN0KCdGYWlsZWQgdG8gdmFsaWRhdGUgdGhpcyBhY2Nlc3MgdG9rZW4gd2l0aCBJbnN0YWdyYW0uJyk7XG4gICAgfSk7XG4gIH0pO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgdmFsaWRhdGVBcHBJZDogdmFsaWRhdGVBcHBJZCxcbiAgdmFsaWRhdGVBdXRoRGF0YTogdmFsaWRhdGVBdXRoRGF0YVxufTtcbiJdfQ==
|
|
117
|
+
var _default = exports.default = new InstagramAdapter();
|
|
118
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_BaseCodeAuthAdapter","_interopRequireDefault","require","e","__esModule","default","InstagramAdapter","BaseAuthCodeAdapter","constructor","getAccessTokenFromCode","authData","response","fetch","method","headers","body","URLSearchParams","client_id","clientId","client_secret","clientSecret","grant_type","redirect_uri","redirectUri","code","ok","Parse","Error","OBJECT_NOT_FOUND","data","json","error","error_description","access_token","getUserFromAccessToken","accessToken","apiURL","path","user","id","_default","exports"],"sources":["../../../src/Adapters/Auth/instagram.js"],"sourcesContent":["/**\n * Parse Server authentication adapter for Instagram.\n *\n * @class InstagramAdapter\n * @param {Object} options - The adapter configuration options.\n * @param {string} options.clientId - Your Instagram App Client ID. Required for secure authentication.\n * @param {string} options.clientSecret - Your Instagram App Client Secret. Required for secure authentication.\n * @param {boolean} [options.enableInsecureAuth=false] - **[DEPRECATED]** Enable insecure authentication (not recommended).\n *\n * @description\n * ## Parse Server Configuration\n * To configure Parse Server for Instagram authentication, use the following structure:\n * ```json\n * {\n *   \"auth\": {\n *     \"instagram\": {\n *       \"clientId\": \"your-client-id\",\n *       \"clientSecret\": \"your-client-secret\"\n *     }\n *   }\n * }\n * ```\n * ### Insecure Configuration (Not Recommended)\n * ```json\n * {\n *   \"auth\": {\n *     \"instagram\": {\n *       \"enableInsecureAuth\": true\n *     }\n *   }\n * }\n * ```\n *\n * The adapter requires the following `authData` fields:\n * - **Secure Authentication**: `code`, `redirect_uri`.\n * - **Insecure Authentication (Deprecated)**: `id`, `access_token`.\n *\n * ## Auth Payloads\n * ### Secure Authentication Payload\n * ```json\n * {\n *   \"instagram\": {\n *     \"code\": \"lmn789opq012rst345uvw\",\n *     \"redirect_uri\": \"https://example.com/callback\"\n *   }\n * }\n * ```\n *\n * ### Insecure Authentication Payload (Deprecated)\n * ```json\n * {\n *   \"instagram\": {\n *     \"id\": \"1234567\",\n *     \"access_token\": \"AQXNnd2hIT6z9bHFzZz2Kp1ghiMz_RtyuvwXYZ123abc\"\n *   }\n * }\n * ```\n *\n * ## Notes\n * - `enableInsecureAuth` is **deprecated** and will be removed in future versions. Use secure authentication with `code` and `redirect_uri`.\n * - Secure authentication exchanges the `code` and `redirect_uri` provided by the client for an access token using Instagram's OAuth flow.\n *\n * @see {@link https://developers.facebook.com/docs/instagram-basic-display-api/getting-started Instagram Basic Display API - Getting Started}\n */\n\n\nimport BaseAuthCodeAdapter from './BaseCodeAuthAdapter';\nclass InstagramAdapter extends BaseAuthCodeAdapter {\n  constructor() {\n    super('Instagram');\n  }\n\n  async getAccessTokenFromCode(authData) {\n    const response = await fetch('https://api.instagram.com/oauth/access_token', {\n      method: 'POST',\n      headers: { 'Content-Type': 'application/x-www-form-urlencoded' },\n      body: new URLSearchParams({\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'authorization_code',\n        redirect_uri: this.redirectUri,\n        code: authData.code\n      })\n    });\n\n    if (!response.ok) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram API request failed.');\n    }\n\n    const data = await response.json();\n    if (data.error) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, data.error_description || data.error);\n    }\n\n    return data.access_token;\n  }\n\n  async getUserFromAccessToken(accessToken, authData) {\n    const apiURL = 'https://graph.instagram.com/';\n    const path = `${apiURL}me?fields=id&access_token=${accessToken}`;\n\n    const response = await fetch(path);\n\n    if (!response.ok) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram API request failed.');\n    }\n\n    const user = await response.json();\n    if (user?.id !== authData.id) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Instagram auth is invalid for this user.');\n    }\n\n    return {\n      id: user.id,\n    }\n\n  }\n}\n\nexport default new InstagramAdapter();\n"],"mappings":";;;;;;AAkEA,IAAAA,oBAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAwD,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAlExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA,MAAMG,gBAAgB,SAASC,4BAAmB,CAAC;EACjDC,WAAWA,CAAA,EAAG;IACZ,KAAK,CAAC,WAAW,CAAC;EACpB;EAEA,MAAMC,sBAAsBA,CAACC,QAAQ,EAAE;IACrC,MAAMC,QAAQ,GAAG,MAAMC,KAAK,CAAC,8CAA8C,EAAE;MAC3EC,MAAM,EAAE,MAAM;MACdC,OAAO,EAAE;QAAE,cAAc,EAAE;MAAoC,CAAC;MAChEC,IAAI,EAAE,IAAIC,eAAe,CAAC;QACxBC,SAAS,EAAE,IAAI,CAACC,QAAQ;QACxBC,aAAa,EAAE,IAAI,CAACC,YAAY;QAChCC,UAAU,EAAE,oBAAoB;QAChCC,YAAY,EAAE,IAAI,CAACC,WAAW;QAC9BC,IAAI,EAAEd,QAAQ,CAACc;MACjB,CAAC;IACH,CAAC,CAAC;IAEF,IAAI,CAACb,QAAQ,CAACc,EAAE,EAAE;MAChB,MAAM,IAAIC,KAAK,CAACC,KAAK,CAACD,KAAK,CAACC,KAAK,CAACC,gBAAgB,EAAE,+BAA+B,CAAC;IACtF;IAEA,MAAMC,IAAI,GAAG,MAAMlB,QAAQ,CAACmB,IAAI,CAAC,CAAC;IAClC,IAAID,IAAI,CAACE,KAAK,EAAE;MACd,MAAM,IAAIL,KAAK,CAACC,KAAK,CAACD,KAAK,CAACC,KAAK,CAACC,gBAAgB,EAAEC,IAAI,CAACG,iBAAiB,IAAIH,IAAI,CAACE,KAAK,CAAC;IAC3F;IAEA,OAAOF,IAAI,CAACI,YAAY;EAC1B;EAEA,MAAMC,sBAAsBA,CAACC,WAAW,EAAEzB,QAAQ,EAAE;IAClD,MAAM0B,MAAM,GAAG,8BAA8B;IAC7C,MAAMC,IAAI,GAAG,GAAGD,MAAM,6BAA6BD,WAAW,EAAE;IAEhE,MAAMxB,QAAQ,GAAG,MAAMC,KAAK,CAACyB,IAAI,CAAC;IAElC,IAAI,CAAC1B,QAAQ,CAACc,EAAE,EAAE;MAChB,MAAM,IAAIC,KAAK,CAACC,KAAK,CAACD,KAAK,CAACC,KAAK,CAACC,gBAAgB,EAAE,+BAA+B,CAAC;IACtF;IAEA,MAAMU,IAAI,GAAG,MAAM3B,QAAQ,CAACmB,IAAI,CAAC,CAAC;IAClC,IAAIQ,IAAI,EAAEC,EAAE,KAAK7B,QAAQ,CAAC6B,EAAE,EAAE;MAC5B,MAAM,IAAIb,KAAK,CAACC,KAAK,CAACD,KAAK,CAACC,KAAK,CAACC,gBAAgB,EAAE,0CAA0C,CAAC;IACjG;IAEA,OAAO;MACLW,EAAE,EAAED,IAAI,CAACC;IACX,CAAC;EAEH;AACF;AAAC,IAAAC,QAAA,GAAAC,OAAA,CAAApC,OAAA,GAEc,IAAIC,gBAAgB,CAAC,CAAC","ignoreList":[]}
|