mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-23 00:00:31 +00:00
93 lines
2.0 KiB
TypeScript
93 lines
2.0 KiB
TypeScript
// @ts-nocheck
|
|
import { useMutation } from 'react-query';
|
|
import useApiRequest from '../useRequest';
|
|
import { setCookie } from '../../utils';
|
|
import { useRequestQuery } from '../useQueryRequest';
|
|
import t from './types';
|
|
|
|
/**
|
|
* Saves the response data to cookies.
|
|
*/
|
|
function setAuthLoginCookies(data) {
|
|
setCookie('token', data.token);
|
|
setCookie('authenticated_user_id', data.user.id);
|
|
setCookie('organization_id', data.tenant.organization_id);
|
|
setCookie('tenant_id', data.tenant.id);
|
|
|
|
if (data?.tenant?.metadata?.language)
|
|
setCookie('locale', data.tenant.metadata.language);
|
|
}
|
|
|
|
/**
|
|
* Authentication login.
|
|
*/
|
|
export const useAuthLogin = (props) => {
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation((values) => apiRequest.post('auth/login', values), {
|
|
select: (res) => res.data,
|
|
onSuccess: (data) => {
|
|
// Set authentication cookies.
|
|
setAuthLoginCookies(data.data);
|
|
|
|
// Reboot the application.
|
|
window.location.reload();
|
|
},
|
|
...props,
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Authentication register.
|
|
*/
|
|
export const useAuthRegister = (props) => {
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation(
|
|
(values) => apiRequest.post('auth/register', values),
|
|
props,
|
|
);
|
|
};
|
|
|
|
/**
|
|
* Authentication send reset password.
|
|
*/
|
|
export const useAuthSendResetPassword = (props) => {
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation(
|
|
(email) => apiRequest.post('auth/send_reset_password', email),
|
|
props,
|
|
);
|
|
};
|
|
|
|
/**
|
|
* Authentication reset password.
|
|
*/
|
|
export const useAuthResetPassword = (props) => {
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation(
|
|
([token, values]) => apiRequest.post(`auth/reset/${token}`, values),
|
|
props,
|
|
);
|
|
};
|
|
|
|
/**
|
|
* Fetches the authentication page metadata.
|
|
*/
|
|
export const useAuthMetadata = (props) => {
|
|
return useRequestQuery(
|
|
[t.AUTH_METADATA_PAGE,],
|
|
{
|
|
method: 'get',
|
|
url: `auth/meta`,
|
|
},
|
|
{
|
|
select: (res) => res.data,
|
|
defaultData: {},
|
|
...props,
|
|
},
|
|
);
|
|
}
|