forked from github/plane
9013497a5a
* dev: update email check endpoint * fix: auth magic login check * chore: updated the error code handler and handled authentication workflow * dev: add magic link login --------- Co-authored-by: pablohashescobar <nikhilschacko@gmail.com> Co-authored-by: guru_sainath <gurusainath007@gmail.com>
79 lines
2.1 KiB
TypeScript
79 lines
2.1 KiB
TypeScript
// types
|
|
import { ICsrfTokenData, IEmailCheckData, IEmailCheckResponse } from "@plane/types";
|
|
// helpers
|
|
import { API_BASE_URL } from "@/helpers/common.helper";
|
|
// services
|
|
import { APIService } from "@/services/api.service";
|
|
|
|
export class AuthService extends APIService {
|
|
constructor() {
|
|
super(API_BASE_URL);
|
|
}
|
|
|
|
async requestCSRFToken(): Promise<ICsrfTokenData> {
|
|
return this.get("/auth/get-csrf-token/")
|
|
.then((response) => response.data)
|
|
.catch((error) => {
|
|
throw error;
|
|
});
|
|
}
|
|
|
|
emailCheck = async (data: IEmailCheckData): Promise<IEmailCheckResponse> =>
|
|
this.post("/auth/email-check/", data, { headers: {} })
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
|
|
async sendResetPasswordLink(data: { email: string }): Promise<any> {
|
|
return this.post(`/auth/forgot-password/`, data)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response;
|
|
});
|
|
}
|
|
|
|
async setPassword(token: string, data: { password: string }): Promise<any> {
|
|
return this.post(`/auth/set-password/`, data, {
|
|
headers: {
|
|
"X-CSRFTOKEN": token,
|
|
},
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async generateUniqueCode(data: { email: string }): Promise<any> {
|
|
return this.post("/auth/magic-generate/", data, { headers: {} })
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async signOut(baseUrl: string): Promise<any> {
|
|
await this.requestCSRFToken().then((data) => {
|
|
const csrfToken = data?.csrf_token;
|
|
|
|
if (!csrfToken) throw Error("CSRF token not found");
|
|
|
|
const form = document.createElement("form");
|
|
const element1 = document.createElement("input");
|
|
|
|
form.method = "POST";
|
|
form.action = `${baseUrl}/auth/sign-out/`;
|
|
|
|
element1.value = csrfToken;
|
|
element1.name = "csrfmiddlewaretoken";
|
|
element1.type = "hidden";
|
|
form.appendChild(element1);
|
|
|
|
document.body.appendChild(form);
|
|
|
|
form.submit();
|
|
});
|
|
}
|
|
}
|