mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
878707f444
* dev: remove default user * dev: initiate licensing * dev: remove migration file 0046 * feat: self hosted licensing initialize * dev: instance licenses * dev: change license response structure * dev: add default properties and issue mention migration * dev: reset migrations * dev: instance configuration * dev: instance configuration migration * dev: update instance configuration model to take null and empty values * dev: instance configuration variables * dev: set default values * dev: update instance configuration load * dev: email configuration settings moved to database * dev: instance configuration on instance bootup * dev: auto instance registration script * dev: instance admin * dev: enable instance configuration and instance admin roles * dev: instance owner fix * dev: instance configuration values * dev: fix instance permissions and serializer * dev: fix email senders * dev: remove deprecated variables * dev: fix current site domain registration * dev: update cors setup and local settings * dev: migrate instance registration and configuration to manage commands * dev: check email validity * dev: update script to use manage command * dev: default bucket creation script * dev: instance admin routes and initial set of screens * dev: admin api to check if the current user is admin * dev: instance admin unique constraints * dev: check magic link login * dev: fix email sending for ssl * dev: create instance activation route if the instance is not activated during startup * dev: removed DJANGO_SETTINGS_MODULE from environment files and deleted auto bucket create script * dev: environment configuration for backend * dev: fix access token variable error * feat: Instance Admin Panel: General Settings (#2792) --------- Co-authored-by: pablohashescobar <nikhilschacko@gmail.com> Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com>
202 lines
5.2 KiB
TypeScript
202 lines
5.2 KiB
TypeScript
// services
|
|
import { APIService } from "services/api.service";
|
|
import { TrackEventService } from "services/track_event.service";
|
|
// types
|
|
import type {
|
|
IIssue,
|
|
IUser,
|
|
IUserActivityResponse,
|
|
IInstanceAdminStatus,
|
|
IUserProfileData,
|
|
IUserProfileProjectSegregation,
|
|
IUserSettings,
|
|
IUserWorkspaceDashboard,
|
|
} from "types";
|
|
// helpers
|
|
import { API_BASE_URL } from "helpers/common.helper";
|
|
|
|
const trackEventService = new TrackEventService();
|
|
|
|
export class UserService extends APIService {
|
|
constructor() {
|
|
super(API_BASE_URL);
|
|
}
|
|
|
|
currentUserConfig() {
|
|
return {
|
|
url: `${this.baseURL}/api/users/me/`,
|
|
headers: this.getHeaders(),
|
|
};
|
|
}
|
|
|
|
async userIssues(
|
|
workspaceSlug: string,
|
|
params: any
|
|
): Promise<
|
|
| {
|
|
[key: string]: IIssue[];
|
|
}
|
|
| IIssue[]
|
|
> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/my-issues/`, {
|
|
params,
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async currentUser(): Promise<IUser> {
|
|
return this.get("/api/users/me/")
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response;
|
|
});
|
|
}
|
|
|
|
async currentUserInstanceAdminStatus(): Promise<IInstanceAdminStatus> {
|
|
return this.get("/api/users/me/instance-admin/")
|
|
.then((respone) => respone?.data)
|
|
.catch((error) => {
|
|
throw error?.response;
|
|
});
|
|
}
|
|
|
|
async currentUserSettings(): Promise<IUserSettings> {
|
|
return this.get("/api/users/me/settings/")
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response;
|
|
});
|
|
}
|
|
|
|
async updateUser(data: Partial<IUser>): Promise<any> {
|
|
return this.patch("/api/users/me/", data)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async updateUserOnBoard({ userRole }: any, user: IUser | undefined): Promise<any> {
|
|
return this.patch("/api/users/me/onboard/", {
|
|
is_onboarded: true,
|
|
})
|
|
.then((response) => {
|
|
trackEventService.trackUserOnboardingCompleteEvent(
|
|
{
|
|
user_role: userRole ?? "None",
|
|
},
|
|
user as IUser
|
|
);
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async updateUserTourCompleted(user: IUser): Promise<any> {
|
|
return this.patch("/api/users/me/tour-completed/", {
|
|
is_tour_completed: true,
|
|
})
|
|
.then((response) => {
|
|
trackEventService.trackUserTourCompleteEvent({ user_role: user.role ?? "None" }, user);
|
|
return response?.data;
|
|
})
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserWorkspaceActivity(workspaceSlug: string): Promise<IUserActivityResponse> {
|
|
return this.get(`/api/users/workspaces/${workspaceSlug}/activities/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async userWorkspaceDashboard(workspaceSlug: string, month: number): Promise<IUserWorkspaceDashboard> {
|
|
return this.get(`/api/users/me/workspaces/${workspaceSlug}/dashboard/`, {
|
|
params: {
|
|
month: month,
|
|
},
|
|
})
|
|
.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 resetPassword(
|
|
uidb64: string,
|
|
token: string,
|
|
data: {
|
|
new_password: string;
|
|
confirm_password: string;
|
|
}
|
|
): Promise<any> {
|
|
return this.post(`/api/reset-password/${uidb64}/${token}/`, data)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserProfileData(workspaceSlug: string, userId: string): Promise<IUserProfileData> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/user-stats/${userId}/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserProfileProjectsSegregation(
|
|
workspaceSlug: string,
|
|
userId: string
|
|
): Promise<IUserProfileProjectSegregation> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/user-profile/${userId}/`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserProfileActivity(workspaceSlug: string, userId: string): Promise<IUserActivityResponse> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/user-activity/${userId}/?per_page=15`)
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
|
|
async getUserProfileIssues(
|
|
workspaceSlug: string,
|
|
userId: string,
|
|
params: any
|
|
): Promise<
|
|
| {
|
|
[key: string]: IIssue[];
|
|
}
|
|
| IIssue[]
|
|
> {
|
|
return this.get(`/api/workspaces/${workspaceSlug}/user-issues/${userId}/`, {
|
|
params,
|
|
})
|
|
.then((response) => response?.data)
|
|
.catch((error) => {
|
|
throw error?.response?.data;
|
|
});
|
|
}
|
|
}
|