// Next.js API route support: https://nextjs.org/docs/api-routes/introduction import axios from 'axios'; import { Cookies } from 'react-cookie'; import cookie from 'cookie'; import moment from 'moment'; import jwt from 'jsonwebtoken'; //import { cors } from '../../lib/cors'; import NextCors from 'nextjs-cors'; export default async function handler(req, res) { await NextCors(req, res, { methods: ['GET', 'HEAD', 'PUT', 'OPTIONS', 'PATCH', 'POST', 'DELETE'], origin: '*', optionsSuccessStatus: 200, // some legacy browsers (IE11, various SmartTVs) choke on 204 }); if(req.headers.cookie !== undefined) { const cookies = cookie.parse(req.headers?.cookie ? req.headers?.cookie : ""); if(cookies.jwt !== undefined && cookies.jwt !== null) { console.log("cookies.jwt"); console.log(cookies.jwt); var client_jwt_decoded = jwt.verify(cookies.jwt, process.env.JWT_SECRET_CLIENT); var crm_jwt = jwt.sign(client_jwt_decoded, process.env.JWT_SECRET_CRM, { noTimestamp: true }); console.log("client_jwt_decoded", client_jwt_decoded); console.log("crm_jwt", crm_jwt); console.log(`URL`); console.log(`${ process.env.CRM_API_HOST }/lk/Account/GetContracts/`); try { await axios.get(`${ process.env.CRM_API_HOST }/lk/Account/GetContracts/`, { params: client_jwt_decoded, headers: { "Authorization": `Bearer ${ crm_jwt }`, } }) .then((crm_response) => { console.log("crm_response"); //console.log(crm_response); res.status(200).json(crm_response.data); }) .catch((error) => { console.error(error); res.status(500).send(); }); } catch(e) { console.error(e); res.status(500).send(); } } else { res.status(403).send(); } } }