forked from github/plane
1e152c666c
* chore: moved app & space from apps to root * chore: modified workspace configuration * chore: modified dockerfiles for space and web * chore: modified icons for space * feat: updated files for new svg icons supported by next-images * chore: added /spaces base path for next * chore: added compose config for space * chore: updated husky configuration * chore: updated workflows for new configuration * chore: changed app name to web * fix: resolved build errors with web * chore: reset file tracing root for both projects * chore: added nginx config for deploy * fix: eslint and tsconfig settings for space app * husky setup fixes based on new dir * eslint fixes * prettier formatting --------- Co-authored-by: Henit Chobisa <chobisa.henit@gmail.com>
93 lines
2.6 KiB
TypeScript
93 lines
2.6 KiB
TypeScript
// services
|
|
import APIService from "services/api.service";
|
|
|
|
class AuthService extends APIService {
|
|
constructor() {
|
|
super(process.env.NEXT_PUBLIC_API_BASE_URL || "http://localhost:8000");
|
|
}
|
|
|
|
async emailLogin(data: any) {
|
|
return this.post("/api/sign-in/", data, { headers: {} })
|
|
.then((response) => {
|
|
this.setAccessToken(response?.data?.access_token);
|
|
this.setRefreshToken(response?.data?.refresh_token);
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async emailSignUp(data: { email: string; password: string }) {
|
|
return this.post("/api/sign-up/", data, { headers: {} })
|
|
.then((response) => {
|
|
this.setAccessToken(response?.data?.access_token);
|
|
this.setRefreshToken(response?.data?.refresh_token);
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async socialAuth(data: any): Promise<{
|
|
access_token: string;
|
|
refresh_toke: string;
|
|
user: any;
|
|
}> {
|
|
return this.post("/api/social-auth/", data, { headers: {} })
|
|
.then((response) => {
|
|
this.setAccessToken(response?.data?.access_token);
|
|
this.setRefreshToken(response?.data?.refresh_token);
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async emailCode(data: any) {
|
|
return this.post("/api/magic-generate/", data, { headers: {} })
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async forgotPassword(data: { email: string }): Promise<any> {
|
|
return this.post(`/api/forgot-password/`, data)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response;
|
|
});
|
|
}
|
|
|
|
async magicSignIn(data: any) {
|
|
const response = await this.post("/api/magic-sign-in/", data, { headers: {} });
|
|
if (response?.status === 200) {
|
|
this.setAccessToken(response?.data?.access_token);
|
|
this.setRefreshToken(response?.data?.refresh_token);
|
|
return response?.data;
|
|
}
|
|
throw response.response.data;
|
|
}
|
|
|
|
async signOut() {
|
|
return this.post("/api/sign-out/", { refresh_token: this.getRefreshToken() })
|
|
.then((response) => {
|
|
this.purgeAccessToken();
|
|
this.purgeRefreshToken();
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
this.purgeAccessToken();
|
|
this.purgeRefreshToken();
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
}
|
|
|
|
const authService = new AuthService();
|
|
|
|
export default authService;
|