diff options
| author | ha-dai <contact@haradai.net> | 2018-05-04 02:49:46 +0900 |
|---|---|---|
| committer | ha-dai <contact@haradai.net> | 2018-05-04 02:49:46 +0900 |
| commit | f850283147072c681df1b39c57f8bd0b14f18016 (patch) | |
| tree | 63ff533c91097da2d8ca2070fc67a28f67ee33da /src/server/api/authenticate.ts | |
| parent | Merge branch 'master' of github.com:syuilo/misskey (diff) | |
| parent | 1.7.0 (diff) | |
| download | misskey-f850283147072c681df1b39c57f8bd0b14f18016.tar.gz misskey-f850283147072c681df1b39c57f8bd0b14f18016.tar.bz2 misskey-f850283147072c681df1b39c57f8bd0b14f18016.zip | |
Merge branch 'master' of github.com:syuilo/misskey
Diffstat (limited to 'src/server/api/authenticate.ts')
| -rw-r--r-- | src/server/api/authenticate.ts | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/server/api/authenticate.ts b/src/server/api/authenticate.ts new file mode 100644 index 0000000000..836fb7cfe8 --- /dev/null +++ b/src/server/api/authenticate.ts @@ -0,0 +1,39 @@ +import App, { IApp } from '../../models/app'; +import { default as User, IUser } from '../../models/user'; +import AccessToken from '../../models/access-token'; +import isNativeToken from './common/is-native-token'; + +export default (token: string) => new Promise<[IUser, IApp]>(async (resolve, reject) => { + if (token == null) { + resolve([null, null]); + return; + } + + if (isNativeToken(token)) { + // Fetch user + const user: IUser = await User + .findOne({ token }); + + if (user === null) { + return reject('user not found'); + } + + resolve([user, null]); + } else { + const accessToken = await AccessToken.findOne({ + hash: token.toLowerCase() + }); + + if (accessToken === null) { + return reject('invalid signature'); + } + + const app = await App + .findOne({ _id: accessToken.appId }); + + const user = await User + .findOne({ _id: accessToken.userId }); + + resolve([user, app]); + } +}); |