diff options
Diffstat (limited to 'src/server/api/endpoints/auth/session')
| -rw-r--r-- | src/server/api/endpoints/auth/session/generate.ts | 27 | ||||
| -rw-r--r-- | src/server/api/endpoints/auth/session/show.ts | 21 | ||||
| -rw-r--r-- | src/server/api/endpoints/auth/session/userkey.ts | 37 |
3 files changed, 47 insertions, 38 deletions
diff --git a/src/server/api/endpoints/auth/session/generate.ts b/src/server/api/endpoints/auth/session/generate.ts index bd1face9e3..79eb34d96a 100644 --- a/src/server/api/endpoints/auth/session/generate.ts +++ b/src/server/api/endpoints/auth/session/generate.ts @@ -1,26 +1,27 @@ -/** - * Module dependencies - */ import * as uuid from 'uuid'; import $ from 'cafy'; import App from '../../../../../models/app'; import AuthSess from '../../../../../models/auth-session'; import config from '../../../../../config'; +import getParams from '../../../get-params'; + +export const meta = { + requireCredential: false, + + params: { + appSecret: { + validator: $.str + } + } +}; -/** - * Generate a session - * - * @param {any} params - * @return {Promise<any>} - */ export default (params: any) => new Promise(async (res, rej) => { - // Get 'appSecret' parameter - const [appSecret, appSecretErr] = $.str.get(params.appSecret); - if (appSecretErr) return rej('invalid appSecret param'); + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); // Lookup app const app = await App.findOne({ - secret: appSecret + secret: ps.appSecret }); if (app == null) { diff --git a/src/server/api/endpoints/auth/session/show.ts b/src/server/api/endpoints/auth/session/show.ts index f2cbfe388e..9e7f4f52d4 100644 --- a/src/server/api/endpoints/auth/session/show.ts +++ b/src/server/api/endpoints/auth/session/show.ts @@ -1,18 +1,25 @@ import $ from 'cafy'; import AuthSess, { pack } from '../../../../../models/auth-session'; import { ILocalUser } from '../../../../../models/user'; +import getParams from '../../../get-params'; + +export const meta = { + requireCredential: false, + + params: { + token: { + validator: $.str + } + } +}; -/** - * Show a session - */ export default (params: any, user: ILocalUser) => new Promise(async (res, rej) => { - // Get 'token' parameter - const [token, tokenErr] = $.str.get(params.token); - if (tokenErr) return rej('invalid token param'); + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); // Lookup session const session = await AuthSess.findOne({ - token: token + token: ps.token }); if (session == null) { diff --git a/src/server/api/endpoints/auth/session/userkey.ts b/src/server/api/endpoints/auth/session/userkey.ts index 97f28464a5..50edf12abc 100644 --- a/src/server/api/endpoints/auth/session/userkey.ts +++ b/src/server/api/endpoints/auth/session/userkey.ts @@ -1,40 +1,41 @@ -/** - * Module dependencies - */ import $ from 'cafy'; import App from '../../../../../models/app'; import AuthSess from '../../../../../models/auth-session'; import AccessToken from '../../../../../models/access-token'; import { pack } from '../../../../../models/user'; +import getParams from '../../../get-params'; + +export const meta = { + requireCredential: false, + + params: { + appSecret: { + validator: $.str + }, + + token: { + validator: $.str + } + } +}; -/** - * Generate a session - * - * @param {any} params - * @return {Promise<any>} - */ export default (params: any) => new Promise(async (res, rej) => { - // Get 'appSecret' parameter - const [appSecret, appSecretErr] = $.str.get(params.appSecret); - if (appSecretErr) return rej('invalid appSecret param'); + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); // Lookup app const app = await App.findOne({ - secret: appSecret + secret: ps.appSecret }); if (app == null) { return rej('app not found'); } - // Get 'token' parameter - const [token, tokenErr] = $.str.get(params.token); - if (tokenErr) return rej('invalid token param'); - // Fetch token const session = await AuthSess .findOne({ - token: token, + token: ps.token, appId: app._id }); |