parse-server 6.0.0-alpha.9 → 6.0.0-beta.1
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 +57 -33
- package/lib/AccountLockout.js +11 -26
- package/lib/Adapters/AdapterLoader.js +8 -14
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
- package/lib/Adapters/Auth/AuthAdapter.js +7 -16
- package/lib/Adapters/Auth/OAuth1Client.js +32 -57
- package/lib/Adapters/Auth/apple.js +6 -22
- package/lib/Adapters/Auth/facebook.js +7 -37
- package/lib/Adapters/Auth/gcenter.js +8 -37
- package/lib/Adapters/Auth/github.js +7 -10
- package/lib/Adapters/Auth/google.js +11 -34
- package/lib/Adapters/Auth/gpgames.js +5 -8
- package/lib/Adapters/Auth/httpsRequest.js +1 -7
- package/lib/Adapters/Auth/index.js +20 -65
- package/lib/Adapters/Auth/instagram.js +5 -9
- package/lib/Adapters/Auth/janraincapture.js +8 -12
- package/lib/Adapters/Auth/janrainengage.js +7 -11
- package/lib/Adapters/Auth/keycloak.js +5 -19
- package/lib/Adapters/Auth/ldap.js +1 -15
- package/lib/Adapters/Auth/line.js +7 -10
- package/lib/Adapters/Auth/linkedin.js +7 -12
- package/lib/Adapters/Auth/meetup.js +7 -10
- package/lib/Adapters/Auth/microsoft.js +7 -10
- package/lib/Adapters/Auth/oauth2.js +6 -18
- package/lib/Adapters/Auth/phantauth.js +8 -10
- package/lib/Adapters/Auth/qq.js +7 -13
- package/lib/Adapters/Auth/spotify.js +7 -14
- package/lib/Adapters/Auth/twitter.js +5 -15
- package/lib/Adapters/Auth/vkontakte.js +9 -15
- package/lib/Adapters/Auth/wechat.js +7 -10
- package/lib/Adapters/Auth/weibo.js +7 -11
- package/lib/Adapters/Cache/CacheAdapter.js +4 -12
- package/lib/Adapters/Cache/InMemoryCache.js +5 -19
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
- package/lib/Adapters/Cache/LRUCache.js +1 -11
- package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +3 -30
- package/lib/Adapters/Cache/SchemaCache.js +1 -6
- package/lib/Adapters/Email/MailAdapter.js +2 -7
- package/lib/Adapters/Files/FilesAdapter.js +7 -21
- package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
- package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
- package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
- package/lib/Adapters/Logger/WinstonLogger.js +3 -30
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
- package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
- package/lib/Adapters/PubSub/RedisPubSub.js +12 -7
- package/lib/Adapters/Push/PushAdapter.js +2 -8
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
- package/lib/Auth.js +68 -121
- package/lib/ClientSDK.js +3 -11
- package/lib/Config.js +73 -115
- package/lib/Controllers/AdaptableController.js +6 -18
- package/lib/Controllers/AnalyticsController.js +1 -9
- package/lib/Controllers/CacheController.js +3 -23
- package/lib/Controllers/DatabaseController.js +171 -364
- package/lib/Controllers/FilesController.js +5 -34
- package/lib/Controllers/HooksController.js +1 -51
- package/lib/Controllers/LiveQueryController.js +4 -23
- package/lib/Controllers/LoggerController.js +15 -54
- package/lib/Controllers/ParseGraphQLController.js +49 -104
- package/lib/Controllers/PushController.js +20 -59
- package/lib/Controllers/SchemaController.js +162 -348
- package/lib/Controllers/UserController.js +17 -78
- package/lib/Controllers/index.js +19 -68
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +1 -1
- package/lib/Deprecator/Deprecator.js +9 -18
- package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
- package/lib/GraphQL/ParseGraphQLServer.js +2 -29
- package/lib/GraphQL/helpers/objectsMutations.js +2 -12
- package/lib/GraphQL/helpers/objectsQueries.js +18 -76
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
- package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
- package/lib/GraphQL/loaders/filesMutations.js +2 -19
- package/lib/GraphQL/loaders/functionsMutations.js +6 -17
- package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
- package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
- package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
- package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
- package/lib/GraphQL/loaders/schemaMutations.js +1 -20
- package/lib/GraphQL/loaders/schemaQueries.js +1 -14
- package/lib/GraphQL/loaders/schemaTypes.js +2 -6
- package/lib/GraphQL/loaders/usersMutations.js +6 -28
- package/lib/GraphQL/loaders/usersQueries.js +4 -26
- package/lib/GraphQL/parseGraphQLUtils.js +6 -19
- package/lib/GraphQL/transformers/className.js +1 -4
- package/lib/GraphQL/transformers/constraintType.js +1 -20
- package/lib/GraphQL/transformers/inputType.js +1 -20
- package/lib/GraphQL/transformers/mutation.js +6 -51
- package/lib/GraphQL/transformers/outputType.js +1 -20
- package/lib/GraphQL/transformers/query.js +6 -42
- package/lib/GraphQL/transformers/schemaFields.js +7 -34
- package/lib/KeyPromiseQueue.js +1 -12
- package/lib/LiveQuery/Client.js +1 -25
- package/lib/LiveQuery/Id.js +1 -7
- package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
- package/lib/LiveQuery/ParseLiveQueryServer.js +111 -307
- package/lib/LiveQuery/ParsePubSub.js +1 -12
- package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
- package/lib/LiveQuery/QueryTools.js +14 -116
- package/lib/LiveQuery/RequestSchema.js +1 -1
- package/lib/LiveQuery/SessionTokenCache.js +1 -17
- package/lib/LiveQuery/Subscription.js +4 -18
- package/lib/LiveQuery/equalObjects.js +2 -14
- package/lib/Options/Definitions.js +88 -8
- package/lib/Options/docs.js +25 -3
- package/lib/Options/index.js +4 -12
- package/lib/Options/parsers.js +1 -18
- package/lib/Page.js +1 -9
- package/lib/ParseMessageQueue.js +1 -10
- package/lib/ParseServer.js +175 -207
- package/lib/ParseServerRESTController.js +6 -33
- package/lib/PromiseRouter.js +16 -50
- package/lib/Push/PushQueue.js +3 -15
- package/lib/Push/PushWorker.js +7 -32
- package/lib/Push/utils.js +9 -38
- package/lib/RestQuery.js +105 -242
- package/lib/RestWrite.js +224 -389
- package/lib/Routers/AggregateRouter.js +14 -51
- package/lib/Routers/AnalyticsRouter.js +2 -8
- package/lib/Routers/AudiencesRouter.js +1 -15
- package/lib/Routers/ClassesRouter.js +3 -53
- package/lib/Routers/CloudCodeRouter.js +1 -19
- package/lib/Routers/FeaturesRouter.js +1 -10
- package/lib/Routers/FilesRouter.js +29 -76
- package/lib/Routers/FunctionsRouter.js +5 -28
- package/lib/Routers/GlobalConfigRouter.js +4 -18
- package/lib/Routers/GraphQLRouter.js +1 -14
- package/lib/Routers/HooksRouter.js +1 -29
- package/lib/Routers/IAPValidationRouter.js +6 -29
- package/lib/Routers/InstallationsRouter.js +2 -12
- package/lib/Routers/LogsRouter.js +4 -16
- package/lib/Routers/PagesRouter.js +69 -129
- package/lib/Routers/PublicAPIRouter.js +3 -62
- package/lib/Routers/PurgeRouter.js +1 -15
- package/lib/Routers/PushRouter.js +2 -18
- package/lib/Routers/RolesRouter.js +1 -7
- package/lib/Routers/SchemasRouter.js +4 -34
- package/lib/Routers/SecurityRouter.js +1 -12
- package/lib/Routers/SessionsRouter.js +3 -19
- package/lib/Routers/UsersRouter.js +48 -135
- package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
- package/lib/SchemaMigrations/Migrations.js +2 -8
- package/lib/Security/Check.js +8 -16
- package/lib/Security/CheckGroup.js +4 -11
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
- package/lib/Security/CheckGroups/CheckGroups.js +1 -4
- package/lib/Security/CheckRunner.js +22 -41
- package/lib/StatusHandler.js +12 -69
- package/lib/TestUtils.js +1 -6
- package/lib/Utils.js +27 -66
- package/lib/batch.js +17 -28
- package/lib/cache.js +1 -3
- package/lib/cli/definitions/parse-live-query-server.js +1 -3
- package/lib/cli/definitions/parse-server.js +1 -3
- package/lib/cli/parse-live-query-server.js +1 -6
- package/lib/cli/parse-server.js +11 -21
- package/lib/cli/utils/commander.js +13 -51
- package/lib/cli/utils/runner.js +1 -14
- package/lib/cloud-code/Parse.Cloud.js +71 -81
- package/lib/cryptoUtils.js +11 -19
- package/lib/defaults.js +2 -14
- package/lib/deprecated.js +1 -2
- package/lib/index.js +16 -34
- package/lib/logger.js +6 -13
- package/lib/middlewares.js +166 -148
- package/lib/password.js +6 -10
- package/lib/request.js +8 -42
- package/lib/requiredParameter.js +1 -3
- package/lib/rest.js +25 -47
- package/lib/triggers.js +54 -252
- package/lib/vendor/mongodbUrl.js +129 -310
- package/package.json +13 -10
- package/PATENTS +0 -37
|
@@ -4,73 +4,52 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = exports.UserController = void 0;
|
|
7
|
-
|
|
8
7
|
var _cryptoUtils = require("../cryptoUtils");
|
|
9
|
-
|
|
10
8
|
var _triggers = require("../triggers");
|
|
11
|
-
|
|
12
9
|
var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
|
|
13
|
-
|
|
14
10
|
var _MailAdapter = _interopRequireDefault(require("../Adapters/Email/MailAdapter"));
|
|
15
|
-
|
|
16
11
|
var _rest = _interopRequireDefault(require("../rest"));
|
|
17
|
-
|
|
18
12
|
var _node = _interopRequireDefault(require("parse/node"));
|
|
19
|
-
|
|
20
13
|
var _AccountLockout = _interopRequireDefault(require("../AccountLockout"));
|
|
21
|
-
|
|
22
14
|
var _Config = _interopRequireDefault(require("../Config"));
|
|
23
|
-
|
|
24
15
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
25
|
-
|
|
26
16
|
var RestQuery = require('../RestQuery');
|
|
27
|
-
|
|
28
17
|
var Auth = require('../Auth');
|
|
29
|
-
|
|
30
18
|
class UserController extends _AdaptableController.default {
|
|
31
19
|
constructor(adapter, appId, options = {}) {
|
|
32
20
|
super(adapter, appId, options);
|
|
33
21
|
}
|
|
34
|
-
|
|
35
22
|
get config() {
|
|
36
23
|
return _Config.default.get(this.appId);
|
|
37
24
|
}
|
|
38
|
-
|
|
39
25
|
validateAdapter(adapter) {
|
|
40
26
|
// Allow no adapter
|
|
41
27
|
if (!adapter && !this.shouldVerifyEmails) {
|
|
42
28
|
return;
|
|
43
29
|
}
|
|
44
|
-
|
|
45
30
|
super.validateAdapter(adapter);
|
|
46
31
|
}
|
|
47
|
-
|
|
48
32
|
expectedAdapterType() {
|
|
49
33
|
return _MailAdapter.default;
|
|
50
34
|
}
|
|
51
|
-
|
|
52
35
|
get shouldVerifyEmails() {
|
|
53
36
|
return this.options.verifyUserEmails;
|
|
54
37
|
}
|
|
55
|
-
|
|
56
38
|
setEmailVerifyToken(user) {
|
|
57
39
|
if (this.shouldVerifyEmails) {
|
|
58
40
|
user._email_verify_token = (0, _cryptoUtils.randomString)(25);
|
|
59
41
|
user.emailVerified = false;
|
|
60
|
-
|
|
61
42
|
if (this.config.emailVerifyTokenValidityDuration) {
|
|
62
43
|
user._email_verify_token_expires_at = _node.default._encode(this.config.generateEmailVerifyTokenExpiresAt());
|
|
63
44
|
}
|
|
64
45
|
}
|
|
65
46
|
}
|
|
66
|
-
|
|
67
47
|
verifyEmail(username, token) {
|
|
68
48
|
if (!this.shouldVerifyEmails) {
|
|
69
49
|
// Trying to verify email when not enabled
|
|
70
50
|
// TODO: Better error here.
|
|
71
51
|
throw undefined;
|
|
72
52
|
}
|
|
73
|
-
|
|
74
53
|
const query = {
|
|
75
54
|
username: username,
|
|
76
55
|
_email_verify_token: token
|
|
@@ -80,9 +59,10 @@ class UserController extends _AdaptableController.default {
|
|
|
80
59
|
_email_verify_token: {
|
|
81
60
|
__op: 'Delete'
|
|
82
61
|
}
|
|
83
|
-
};
|
|
84
|
-
// add additional query params and additional fields that need to be updated
|
|
62
|
+
};
|
|
85
63
|
|
|
64
|
+
// if the email verify token needs to be validated then
|
|
65
|
+
// add additional query params and additional fields that need to be updated
|
|
86
66
|
if (this.config.emailVerifyTokenValidityDuration) {
|
|
87
67
|
query.emailVerified = false;
|
|
88
68
|
query._email_verify_token_expires_at = {
|
|
@@ -92,10 +72,9 @@ class UserController extends _AdaptableController.default {
|
|
|
92
72
|
__op: 'Delete'
|
|
93
73
|
};
|
|
94
74
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
username: username
|
|
75
|
+
const maintenanceAuth = Auth.maintenance(this.config);
|
|
76
|
+
var findUserForEmailVerification = new RestQuery(this.config, maintenanceAuth, '_User', {
|
|
77
|
+
username
|
|
99
78
|
});
|
|
100
79
|
return findUserForEmailVerification.execute().then(result => {
|
|
101
80
|
if (result.results.length && result.results[0].emailVerified) {
|
|
@@ -103,68 +82,54 @@ class UserController extends _AdaptableController.default {
|
|
|
103
82
|
} else if (result.results.length) {
|
|
104
83
|
query.objectId = result.results[0].objectId;
|
|
105
84
|
}
|
|
106
|
-
|
|
107
|
-
return _rest.default.update(this.config, masterAuth, '_User', query, updateFields);
|
|
85
|
+
return _rest.default.update(this.config, maintenanceAuth, '_User', query, updateFields);
|
|
108
86
|
});
|
|
109
87
|
}
|
|
110
|
-
|
|
111
88
|
checkResetTokenValidity(username, token) {
|
|
112
89
|
return this.config.database.find('_User', {
|
|
113
90
|
username: username,
|
|
114
91
|
_perishable_token: token
|
|
115
92
|
}, {
|
|
116
93
|
limit: 1
|
|
117
|
-
}).then(results => {
|
|
94
|
+
}, Auth.maintenance(this.config)).then(results => {
|
|
118
95
|
if (results.length != 1) {
|
|
119
96
|
throw 'Failed to reset password: username / email / token is invalid';
|
|
120
97
|
}
|
|
121
|
-
|
|
122
98
|
if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
|
|
123
99
|
let expiresDate = results[0]._perishable_token_expires_at;
|
|
124
|
-
|
|
125
100
|
if (expiresDate && expiresDate.__type == 'Date') {
|
|
126
101
|
expiresDate = new Date(expiresDate.iso);
|
|
127
102
|
}
|
|
128
|
-
|
|
129
103
|
if (expiresDate < new Date()) throw 'The password reset link has expired';
|
|
130
104
|
}
|
|
131
|
-
|
|
132
105
|
return results[0];
|
|
133
106
|
});
|
|
134
107
|
}
|
|
135
|
-
|
|
136
108
|
getUserIfNeeded(user) {
|
|
137
109
|
if (user.username && user.email) {
|
|
138
110
|
return Promise.resolve(user);
|
|
139
111
|
}
|
|
140
|
-
|
|
141
112
|
var where = {};
|
|
142
|
-
|
|
143
113
|
if (user.username) {
|
|
144
114
|
where.username = user.username;
|
|
145
115
|
}
|
|
146
|
-
|
|
147
116
|
if (user.email) {
|
|
148
117
|
where.email = user.email;
|
|
149
118
|
}
|
|
150
|
-
|
|
151
119
|
var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);
|
|
152
120
|
return query.execute().then(function (result) {
|
|
153
121
|
if (result.results.length != 1) {
|
|
154
122
|
throw undefined;
|
|
155
123
|
}
|
|
156
|
-
|
|
157
124
|
return result.results[0];
|
|
158
125
|
});
|
|
159
126
|
}
|
|
160
|
-
|
|
161
127
|
sendVerificationEmail(user) {
|
|
162
128
|
if (!this.shouldVerifyEmails) {
|
|
163
129
|
return;
|
|
164
130
|
}
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
131
|
+
const token = encodeURIComponent(user._email_verify_token);
|
|
132
|
+
// We may need to fetch the user in case of update email
|
|
168
133
|
this.getUserIfNeeded(user).then(user => {
|
|
169
134
|
const username = encodeURIComponent(user.username);
|
|
170
135
|
const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);
|
|
@@ -173,7 +138,6 @@ class UserController extends _AdaptableController.default {
|
|
|
173
138
|
link: link,
|
|
174
139
|
user: (0, _triggers.inflate)('_User', user)
|
|
175
140
|
};
|
|
176
|
-
|
|
177
141
|
if (this.adapter.sendVerificationEmail) {
|
|
178
142
|
this.adapter.sendVerificationEmail(options);
|
|
179
143
|
} else {
|
|
@@ -181,14 +145,13 @@ class UserController extends _AdaptableController.default {
|
|
|
181
145
|
}
|
|
182
146
|
});
|
|
183
147
|
}
|
|
148
|
+
|
|
184
149
|
/**
|
|
185
150
|
* Regenerates the given user's email verification token
|
|
186
151
|
*
|
|
187
152
|
* @param user
|
|
188
153
|
* @returns {*}
|
|
189
154
|
*/
|
|
190
|
-
|
|
191
|
-
|
|
192
155
|
regenerateEmailVerifyToken(user) {
|
|
193
156
|
const {
|
|
194
157
|
_email_verify_token
|
|
@@ -196,21 +159,17 @@ class UserController extends _AdaptableController.default {
|
|
|
196
159
|
let {
|
|
197
160
|
_email_verify_token_expires_at
|
|
198
161
|
} = user;
|
|
199
|
-
|
|
200
162
|
if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {
|
|
201
163
|
_email_verify_token_expires_at = _email_verify_token_expires_at.iso;
|
|
202
164
|
}
|
|
203
|
-
|
|
204
165
|
if (this.config.emailVerifyTokenReuseIfValid && this.config.emailVerifyTokenValidityDuration && _email_verify_token && new Date() < new Date(_email_verify_token_expires_at)) {
|
|
205
166
|
return Promise.resolve();
|
|
206
167
|
}
|
|
207
|
-
|
|
208
168
|
this.setEmailVerifyToken(user);
|
|
209
169
|
return this.config.database.update('_User', {
|
|
210
170
|
username: user.username
|
|
211
171
|
}, user);
|
|
212
172
|
}
|
|
213
|
-
|
|
214
173
|
resendVerificationEmail(username) {
|
|
215
174
|
return this.getUserIfNeeded({
|
|
216
175
|
username: username
|
|
@@ -218,22 +177,18 @@ class UserController extends _AdaptableController.default {
|
|
|
218
177
|
if (!aUser || aUser.emailVerified) {
|
|
219
178
|
throw undefined;
|
|
220
179
|
}
|
|
221
|
-
|
|
222
180
|
return this.regenerateEmailVerifyToken(aUser).then(() => {
|
|
223
181
|
this.sendVerificationEmail(aUser);
|
|
224
182
|
});
|
|
225
183
|
});
|
|
226
184
|
}
|
|
227
|
-
|
|
228
185
|
setPasswordResetToken(email) {
|
|
229
186
|
const token = {
|
|
230
187
|
_perishable_token: (0, _cryptoUtils.randomString)(25)
|
|
231
188
|
};
|
|
232
|
-
|
|
233
189
|
if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {
|
|
234
190
|
token._perishable_token_expires_at = _node.default._encode(this.config.generatePasswordResetTokenExpiresAt());
|
|
235
191
|
}
|
|
236
|
-
|
|
237
192
|
return this.config.database.update('_User', {
|
|
238
193
|
$or: [{
|
|
239
194
|
email
|
|
@@ -245,14 +200,13 @@ class UserController extends _AdaptableController.default {
|
|
|
245
200
|
}]
|
|
246
201
|
}, token, {}, true);
|
|
247
202
|
}
|
|
248
|
-
|
|
249
203
|
async sendPasswordResetEmail(email) {
|
|
250
204
|
if (!this.adapter) {
|
|
251
|
-
throw 'Trying to send a reset password but no adapter is set';
|
|
205
|
+
throw 'Trying to send a reset password but no adapter is set';
|
|
206
|
+
// TODO: No adapter?
|
|
252
207
|
}
|
|
253
208
|
|
|
254
209
|
let user;
|
|
255
|
-
|
|
256
210
|
if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenReuseIfValid && this.config.passwordPolicy.resetTokenValidityDuration) {
|
|
257
211
|
const results = await this.config.database.find('_User', {
|
|
258
212
|
$or: [{
|
|
@@ -271,25 +225,20 @@ class UserController extends _AdaptableController.default {
|
|
|
271
225
|
}]
|
|
272
226
|
}, {
|
|
273
227
|
limit: 1
|
|
274
|
-
});
|
|
275
|
-
|
|
228
|
+
}, Auth.maintenance(this.config));
|
|
276
229
|
if (results.length == 1) {
|
|
277
230
|
let expiresDate = results[0]._perishable_token_expires_at;
|
|
278
|
-
|
|
279
231
|
if (expiresDate && expiresDate.__type == 'Date') {
|
|
280
232
|
expiresDate = new Date(expiresDate.iso);
|
|
281
233
|
}
|
|
282
|
-
|
|
283
234
|
if (expiresDate > new Date()) {
|
|
284
235
|
user = results[0];
|
|
285
236
|
}
|
|
286
237
|
}
|
|
287
238
|
}
|
|
288
|
-
|
|
289
239
|
if (!user || !user._perishable_token) {
|
|
290
240
|
user = await this.setPasswordResetToken(email);
|
|
291
241
|
}
|
|
292
|
-
|
|
293
242
|
const token = encodeURIComponent(user._perishable_token);
|
|
294
243
|
const username = encodeURIComponent(user.username);
|
|
295
244
|
const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);
|
|
@@ -298,16 +247,13 @@ class UserController extends _AdaptableController.default {
|
|
|
298
247
|
link: link,
|
|
299
248
|
user: (0, _triggers.inflate)('_User', user)
|
|
300
249
|
};
|
|
301
|
-
|
|
302
250
|
if (this.adapter.sendPasswordResetEmail) {
|
|
303
251
|
this.adapter.sendPasswordResetEmail(options);
|
|
304
252
|
} else {
|
|
305
253
|
this.adapter.sendMail(this.defaultResetPasswordEmail(options));
|
|
306
254
|
}
|
|
307
|
-
|
|
308
255
|
return Promise.resolve(user);
|
|
309
256
|
}
|
|
310
|
-
|
|
311
257
|
updatePassword(username, token, password) {
|
|
312
258
|
return this.checkResetTokenValidity(username, token).then(user => updateUserPassword(user, password, this.config)).then(user => {
|
|
313
259
|
const accountLockoutPolicy = new _AccountLockout.default(user, this.config);
|
|
@@ -321,7 +267,6 @@ class UserController extends _AdaptableController.default {
|
|
|
321
267
|
}
|
|
322
268
|
});
|
|
323
269
|
}
|
|
324
|
-
|
|
325
270
|
defaultVerificationEmail({
|
|
326
271
|
link,
|
|
327
272
|
user,
|
|
@@ -336,7 +281,6 @@ class UserController extends _AdaptableController.default {
|
|
|
336
281
|
subject
|
|
337
282
|
};
|
|
338
283
|
}
|
|
339
|
-
|
|
340
284
|
defaultResetPasswordEmail({
|
|
341
285
|
link,
|
|
342
286
|
user,
|
|
@@ -351,12 +295,10 @@ class UserController extends _AdaptableController.default {
|
|
|
351
295
|
subject
|
|
352
296
|
};
|
|
353
297
|
}
|
|
298
|
+
}
|
|
354
299
|
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
300
|
+
// Mark this private
|
|
358
301
|
exports.UserController = UserController;
|
|
359
|
-
|
|
360
302
|
function updateUserPassword(user, password, config) {
|
|
361
303
|
return _rest.default.update(config, Auth.master(config), '_User', {
|
|
362
304
|
objectId: user.objectId
|
|
@@ -364,10 +306,8 @@ function updateUserPassword(user, password, config) {
|
|
|
364
306
|
password: password
|
|
365
307
|
}).then(() => user);
|
|
366
308
|
}
|
|
367
|
-
|
|
368
309
|
function buildEmailLink(destination, username, token, config) {
|
|
369
310
|
const usernameAndToken = `token=${token}&username=${username}`;
|
|
370
|
-
|
|
371
311
|
if (config.parseFrameURL) {
|
|
372
312
|
const destinationWithoutHost = destination.replace(config.publicServerURL, '');
|
|
373
313
|
return `${config.parseFrameURL}?link=${encodeURIComponent(destinationWithoutHost)}&${usernameAndToken}`;
|
|
@@ -375,7 +315,6 @@ function buildEmailLink(destination, username, token, config) {
|
|
|
375
315
|
return `${destination}?${usernameAndToken}`;
|
|
376
316
|
}
|
|
377
317
|
}
|
|
378
|
-
|
|
379
318
|
var _default = UserController;
|
|
380
319
|
exports.default = _default;
|
|
381
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/UserController.js"],"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","masterAuth","master","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"mappings":"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","sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return this.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const masterAuth = Auth.master(this.config);\n    var findUserForEmailVerification = new RestQuery(\n      this.config,\n      Auth.master(this.config),\n      '_User',\n      { username: username }\n    );\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, masterAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 }\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\n      };\n      if (this.adapter.sendVerificationEmail) {\n        this.adapter.sendVerificationEmail(options);\n      } else {\n        this.adapter.sendMail(this.defaultVerificationEmail(options));\n      }\n    });\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\n    });\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 }\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"]}
|
|
320
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","randomString","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","maintenanceAuth","maintenance","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","master","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","inflate","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"sources":["../../src/Controllers/UserController.js"],"sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return this.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const maintenanceAuth = Auth.maintenance(this.config);\n    var findUserForEmailVerification = new RestQuery(this.config, maintenanceAuth, '_User', {\n      username,\n    });\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, maintenanceAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\n      };\n      if (this.adapter.sendVerificationEmail) {\n        this.adapter.sendVerificationEmail(options);\n      } else {\n        this.adapter.sendMail(this.defaultVerificationEmail(options));\n      }\n    });\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\n    });\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 },\n        Auth.maintenance(this.config)\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"],"mappings":"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"}
|