summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/i/regenerate-token.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2019-02-24 17:57:49 +0900
committersyuilo <syuilotan@yahoo.co.jp>2019-02-24 17:57:49 +0900
commitf4ae9391248d9ba366210be215681537ce9ecb49 (patch)
tree28de199e28cf57ea5254da4c1f300e16b3996a5f /src/server/api/endpoints/i/regenerate-token.ts
parentRefactor (diff)
downloadmisskey-f4ae9391248d9ba366210be215681537ce9ecb49.tar.gz
misskey-f4ae9391248d9ba366210be215681537ce9ecb49.tar.bz2
misskey-f4ae9391248d9ba366210be215681537ce9ecb49.zip
ハイフンに統一
Diffstat (limited to 'src/server/api/endpoints/i/regenerate-token.ts')
-rw-r--r--src/server/api/endpoints/i/regenerate-token.ts41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/server/api/endpoints/i/regenerate-token.ts b/src/server/api/endpoints/i/regenerate-token.ts
new file mode 100644
index 0000000000..ad10b99b36
--- /dev/null
+++ b/src/server/api/endpoints/i/regenerate-token.ts
@@ -0,0 +1,41 @@
+import $ from 'cafy';
+import * as bcrypt from 'bcryptjs';
+import User from '../../../../models/user';
+import { publishMainStream } from '../../../../services/stream';
+import generateUserToken from '../../common/generate-native-user-token';
+import define from '../../define';
+
+export const meta = {
+ requireCredential: true,
+
+ secure: true,
+
+ params: {
+ password: {
+ validator: $.str
+ }
+ }
+};
+
+export default define(meta, async (ps, user) => {
+ // Compare password
+ const same = await bcrypt.compare(ps.password, user.password);
+
+ if (!same) {
+ throw new Error('incorrect password');
+ }
+
+ // Generate secret
+ const secret = generateUserToken();
+
+ await User.update(user._id, {
+ $set: {
+ 'token': secret
+ }
+ });
+
+ // Publish event
+ publishMainStream(user._id, 'myTokenRegenerated');
+
+ return;
+});