import { zodResolver } from '@hookform/resolvers/zod' import { data } from 'react-router' import { getValidatedFormData } from 'remix-hook-form' import { XiorError } from 'xior' import { getUser } from '~/apis/news/get-user' import { userLoginRequest } from '~/apis/news/login-user' import { loginSchema, type TLoginSchema } from '~/layouts/news/form-login' import { generateUserTokenCookie } from '~/utils/token' import type { Route } from './+types/actions.login' export const action = async ({ request }: Route.ActionArgs) => { try { const { errors, data: payload, receivedValues: defaultValues, } = await getValidatedFormData( request, zodResolver(loginSchema), false, ) if (errors) { return data({ success: false, errors, defaultValues }, { status: 400 }) } const { data: loginData } = await userLoginRequest(payload) const { token: accessToken } = loginData const { data: userData } = await getUser({ accessToken }) const tokenCookie = generateUserTokenCookie({ accessToken }) const headers = new Headers() headers.append('Set-Cookie', await tokenCookie) return data( { success: true, user: userData, }, { headers, status: 200, statusText: 'OK', }, ) } catch (error) { if (error instanceof XiorError) { return data( { success: false, message: error?.response?.data?.error?.message || error.message, }, { status: error?.response?.status || 500, }, ) } return data( { success: false, message: 'Internal server error', }, { status: 500 }, ) } }