summaryrefslogtreecommitdiff
path: root/src/server/api/authenticate.ts
diff options
context:
space:
mode:
authorha-dai <contact@haradai.net>2018-05-04 02:49:46 +0900
committerha-dai <contact@haradai.net>2018-05-04 02:49:46 +0900
commitf850283147072c681df1b39c57f8bd0b14f18016 (patch)
tree63ff533c91097da2d8ca2070fc67a28f67ee33da /src/server/api/authenticate.ts
parentMerge branch 'master' of github.com:syuilo/misskey (diff)
parent1.7.0 (diff)
downloadmisskey-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.ts39
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]);
+ }
+});