summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/i/2fa/done.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2019-04-14 20:38:55 +0900
committersyuilo <syuilotan@yahoo.co.jp>2019-04-14 20:38:55 +0900
commitd66e4b7ff97d512e2a2523815e2eef170456b37f (patch)
tree59ae1a102d88b5c2c2236b734ea4a584b4f9ba46 /src/server/api/endpoints/i/2fa/done.ts
parent10.100.0 (diff)
parent11.0.0 (diff)
downloadmisskey-d66e4b7ff97d512e2a2523815e2eef170456b37f.tar.gz
misskey-d66e4b7ff97d512e2a2523815e2eef170456b37f.tar.bz2
misskey-d66e4b7ff97d512e2a2523815e2eef170456b37f.zip
Merge branch 'develop'
Diffstat (limited to 'src/server/api/endpoints/i/2fa/done.ts')
-rw-r--r--src/server/api/endpoints/i/2fa/done.ts23
1 files changed, 11 insertions, 12 deletions
diff --git a/src/server/api/endpoints/i/2fa/done.ts b/src/server/api/endpoints/i/2fa/done.ts
index 556354c386..e23678dcbb 100644
--- a/src/server/api/endpoints/i/2fa/done.ts
+++ b/src/server/api/endpoints/i/2fa/done.ts
@@ -1,7 +1,8 @@
import $ from 'cafy';
import * as speakeasy from 'speakeasy';
-import User from '../../../../../models/user';
import define from '../../../define';
+import { UserProfiles } from '../../../../../models';
+import { ensure } from '../../../../../prelude/ensure';
export const meta = {
requireCredential: true,
@@ -16,28 +17,26 @@ export const meta = {
};
export default define(meta, async (ps, user) => {
- const _token = ps.token.replace(/\s/g, '');
+ const token = ps.token.replace(/\s/g, '');
- if (user.twoFactorTempSecret == null) {
+ const profile = await UserProfiles.findOne({ userId: user.id }).then(ensure);
+
+ if (profile.twoFactorTempSecret == null) {
throw new Error('二段階認証の設定が開始されていません');
}
const verified = (speakeasy as any).totp.verify({
- secret: user.twoFactorTempSecret,
+ secret: profile.twoFactorTempSecret,
encoding: 'base32',
- token: _token
+ token: token
});
if (!verified) {
throw new Error('not verified');
}
- await User.update(user._id, {
- $set: {
- 'twoFactorSecret': user.twoFactorTempSecret,
- 'twoFactorEnabled': true
- }
+ await UserProfiles.update({ userId: user.id }, {
+ twoFactorSecret: profile.twoFactorTempSecret,
+ twoFactorEnabled: true
});
-
- return;
});