icynet-admin/pages/api/login.ts

39 lines
939 B
TypeScript
Raw Normal View History

2022-08-29 18:34:46 +00:00
import Cookies from 'cookies';
2022-08-29 18:09:28 +00:00
import { NextApiRequest, NextApiResponse } from 'next';
2022-08-29 18:34:46 +00:00
import {
CLIENT_ID,
COOKIE_KEYS,
OAUTH_URL,
PUBLIC_URL,
} from '../../lib/constants';
import { encrypt, generateString } from '../../lib/utils/crypto';
const redirect = `${PUBLIC_URL}/api/callback`;
2022-08-29 18:09:28 +00:00
export default function handler(req: NextApiRequest, res: NextApiResponse) {
2022-08-29 18:34:46 +00:00
const stateToken = generateString(16);
const state = encrypt(
JSON.stringify({
redirect_uri: redirect,
state: stateToken,
})
);
2022-08-30 18:08:54 +00:00
2022-08-29 18:09:28 +00:00
const params = new URLSearchParams({
client_id: CLIENT_ID,
response_type: 'code',
2022-08-29 18:34:46 +00:00
redirect_uri: redirect,
2022-08-29 18:09:28 +00:00
scope: 'management',
2022-08-29 18:34:46 +00:00
state,
2022-08-29 18:09:28 +00:00
});
2022-08-29 18:34:46 +00:00
const cookies = new Cookies(req, res, { keys: COOKIE_KEYS });
cookies.set('validation', stateToken, {
secure: process.env.NODE_ENV === 'production',
signed: true,
});
2022-08-29 18:09:28 +00:00
res.redirect(`${OAUTH_URL}/authorize?${params.toString()}`);
}