'use strict' const { plugin } = require('@hapi/inert') const Joi = require('joi') const pluginConfig = { handlerType: 'jwt', docs: { get: { description: 'validates session token for each step of survey', notes: 'validates session token for each step of survey', }, }, } module.exports = { method: 'GET', path: '/validatesession', options: { ...pluginConfig.docs.get, tags: ['api'], auth: 'default_jwt', cors: true, handler: async function (request, h) { const sessionToken = request.headers.authorization const { userService } = request.server.services() try { const validatedSessionToken = userService.validateToken(sessionToken) return { ok: true, handler: pluginConfig.handlerType, data: validatedSessionToken, } } catch (err) { return { ok: false, handler: pluginConfig.handlerType, data: { error: err.message }, } } }, validate: { failAction: 'log', }, response: { schema: Joi.object({ ok: Joi.bool(), handler: Joi.string(), data: Joi.object(), }).label('validate_session_res'), failAction: 'log', }, }, }