* feat(auth): add OAuth2 login with GitHub and Google * chore(translations): add files for Japanese * fix(auth): fix link function for GitHub * feat(oauth): basic oidc implementation * feat(oauth): oauth guard * fix: disable image optimizations for logo to prevent caching issues with custom logos * fix: memory leak while downloading large files * chore(translations): update translations via Crowdin (#278) * New translations en-us.ts (Japanese) * New translations en-us.ts (Japanese) * New translations en-us.ts (Japanese) * release: 0.18.2 * doc(translations): Add Japanese README (#279) * Added Japanese README. * Added JAPANESE README link to README.md. * Updated Japanese README. * Updated Environment Variable Table. * updated zh-cn README. * feat(oauth): unlink account * refactor(oauth): make providers extensible * fix(oauth): fix discoveryUri error when toggle google-enabled * feat(oauth): add microsoft and discord as oauth provider * docs(oauth): update README.md * docs(oauth): update oauth2-guide.md * set password to null for new oauth users * New translations en-us.ts (Japanese) (#281) * chore(translations): add Polish files * fix(oauth): fix random username and password * feat(oauth): add totp * fix(oauth): fix totp throttle * fix(oauth): fix qrcode and remove comment * feat(oauth): add error page * fix(oauth): i18n of error page * feat(auth): add OAuth2 login * fix(auth): fix link function for GitHub * feat(oauth): basic oidc implementation * feat(oauth): oauth guard * feat(oauth): unlink account * refactor(oauth): make providers extensible * fix(oauth): fix discoveryUri error when toggle google-enabled * feat(oauth): add microsoft and discord as oauth provider * docs(oauth): update README.md * docs(oauth): update oauth2-guide.md * set password to null for new oauth users * fix(oauth): fix random username and password * feat(oauth): add totp * fix(oauth): fix totp throttle * fix(oauth): fix qrcode and remove comment * feat(oauth): add error page * fix(oauth): i18n of error page * refactor: return null instead of `false` in `getIdOfCurrentUser` functiom * feat: show original oauth error if available * refactor: run formatter * refactor(oauth): error message i18n * refactor(oauth): make OAuth token available someone may use it (to revoke token or get other info etc.) also improved the i18n message * chore(oauth): remove unused import * chore: add database migration * fix: missing python installation for nanoid --------- Co-authored-by: Elias Schneider <login@eliasschneider.com> Co-authored-by: ふうせん <10260662+fusengum@users.noreply.github.com>
109 lines
2.4 KiB
TypeScript
109 lines
2.4 KiB
TypeScript
import { getCookie } from "cookies-next";
|
|
import * as jose from "jose";
|
|
import api from "./api.service";
|
|
|
|
const signIn = async (emailOrUsername: string, password: string) => {
|
|
const emailOrUsernameBody = emailOrUsername.includes("@")
|
|
? { email: emailOrUsername }
|
|
: { username: emailOrUsername };
|
|
|
|
const response = await api.post("auth/signIn", {
|
|
...emailOrUsernameBody,
|
|
password,
|
|
});
|
|
|
|
return response;
|
|
};
|
|
|
|
const signInTotp = (totp: string, loginToken: string) => {
|
|
return api.post("auth/signIn/totp", {
|
|
totp,
|
|
loginToken,
|
|
});
|
|
};
|
|
|
|
const signUp = async (email: string, username: string, password: string) => {
|
|
const response = await api.post("auth/signUp", { email, username, password });
|
|
|
|
return response;
|
|
};
|
|
|
|
const signOut = async () => {
|
|
await api.post("/auth/signOut");
|
|
window.location.reload();
|
|
};
|
|
|
|
const refreshAccessToken = async () => {
|
|
try {
|
|
const accessToken = getCookie("access_token") as string;
|
|
if (
|
|
!accessToken ||
|
|
(jose.decodeJwt(accessToken).exp ?? 0) * 1000 < Date.now() + 2 * 60 * 1000
|
|
) {
|
|
await api.post("/auth/token");
|
|
}
|
|
} catch (e) {
|
|
console.info("Refresh token invalid or expired");
|
|
}
|
|
};
|
|
|
|
const requestResetPassword = async (email: string) => {
|
|
await api.post(`/auth/resetPassword/${email}`);
|
|
};
|
|
|
|
const resetPassword = async (token: string, password: string) => {
|
|
await api.post("/auth/resetPassword", { token, password });
|
|
};
|
|
|
|
const updatePassword = async (oldPassword: string, password: string) => {
|
|
await api.patch("/auth/password", { oldPassword, password });
|
|
};
|
|
|
|
const enableTOTP = async (password: string) => {
|
|
const { data } = await api.post("/auth/totp/enable", { password });
|
|
|
|
return {
|
|
totpAuthUrl: data.totpAuthUrl,
|
|
totpSecret: data.totpSecret,
|
|
qrCode: data.qrCode,
|
|
};
|
|
};
|
|
|
|
const verifyTOTP = async (totpCode: string, password: string) => {
|
|
await api.post("/auth/totp/verify", {
|
|
code: totpCode,
|
|
password,
|
|
});
|
|
};
|
|
|
|
const disableTOTP = async (totpCode: string, password: string) => {
|
|
await api.post("/auth/totp/disable", {
|
|
code: totpCode,
|
|
password,
|
|
});
|
|
};
|
|
|
|
const getAvailableOAuth = async () => {
|
|
return api.get("/oauth/available");
|
|
};
|
|
|
|
const getOAuthStatus = () => {
|
|
return api.get("/oauth/status");
|
|
};
|
|
|
|
export default {
|
|
signIn,
|
|
signInTotp,
|
|
signUp,
|
|
signOut,
|
|
refreshAccessToken,
|
|
updatePassword,
|
|
requestResetPassword,
|
|
resetPassword,
|
|
enableTOTP,
|
|
verifyTOTP,
|
|
disableTOTP,
|
|
getAvailableOAuth,
|
|
getOAuthStatus,
|
|
};
|