diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2019-02-24 17:57:49 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2019-02-24 17:57:49 +0900 |
| commit | f4ae9391248d9ba366210be215681537ce9ecb49 (patch) | |
| tree | 28de199e28cf57ea5254da4c1f300e16b3996a5f /src/server/api/endpoints/i/regenerate-token.ts | |
| parent | Refactor (diff) | |
| download | misskey-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.ts | 41 |
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; +}); |