| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- 'use strict'
-
- const Joi = require('joi')
-
- const pluginConfig = {
- handlerType: 'authentication',
- docs: {
- get: {
- description: 'creates session token for authentication',
- notes: 'Creates session token for authentication',
- },
- },
- }
-
- const validators = {
- payload: Joi.object({
- payload: Joi.object({
- email: Joi.string(),
- name: Joi.string(),
- seeking: Joi.string(),
- }),
- }),
- }
-
- module.exports = {
- method: 'POST',
- path: '/token',
- options: {
- ...pluginConfig.docs.get,
- tags: ['api'],
- auth: false,
- cors: {
- headers: ['Authorization', 'Content-Type'],
- exposedHeaders: ['Authorization', 'Access-Control-Expose-Headers'],
- },
- handler: async function (request, h) {
- const { userService } = request.server.services()
- const res = request.payload
- // NOTE: Session Token set for 5 minutes expiration (default)
- const sessionToken = await userService.createToken(res, 600)
- try {
- const response = h.response({
- ok: true,
- handler: pluginConfig.handlerType,
- data: sessionToken,
- })
- response.header('Authorization', sessionToken)
- return response
- } catch (err) {
- return {
- ok: false,
- handler: pluginConfig.handlerType,
- data: {
- error: err,
- },
- }
- }
- },
- validate: {
- ...validators,
- failAction: 'log',
- },
- response: {
- // TODO: change back to accommodate new h.response return values
- schema: Joi.any().label('get_session_res'),
- failAction: 'log',
- },
- },
- }
|