chore: common services package (#6255)

* fix: initial services package setup

* fix: services packages updates

* fix: services changes

* fix: merge conflicts

* chore: file structuring

* fix: import fixes
This commit is contained in:
sriram veeraghanta 2024-12-23 01:51:30 +05:30 committed by GitHub
parent 1ee0661ac1
commit 043f4eaa5e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
47 changed files with 2345 additions and 10 deletions

View file

@ -0,0 +1,68 @@
import { API_BASE_URL } from "@plane/constants";
import { IApiToken } from "@plane/types";
import { APIService } from "@/api.service";
export class APITokenService extends APIService {
constructor(BASE_URL?: string) {
super(BASE_URL || API_BASE_URL);
}
/**
* Retrieves all API tokens for a specific workspace
* @param {string} workspaceSlug - The unique identifier for the workspace
* @returns {Promise<IApiToken[]>} Array of API tokens associated with the workspace
* @throws {Error} Throws response data if the request fails
*/
async list(workspaceSlug: string): Promise<IApiToken[]> {
return this.get(`/api/workspaces/${workspaceSlug}/api-tokens/`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Retrieves a specific API token by its ID
* @param {string} workspaceSlug - The unique identifier for the workspace
* @param {string} tokenId - The unique identifier of the API token
* @returns {Promise<IApiToken>} The requested API token's details
* @throws {Error} Throws response data if the request fails
*/
async retrieve(workspaceSlug: string, tokenId: string): Promise<IApiToken> {
return this.get(`/api/workspaces/${workspaceSlug}/api-tokens/${tokenId}`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Creates a new API token for a workspace
* @param {string} workspaceSlug - The unique identifier for the workspace
* @param {Partial<IApiToken>} data - The data for creating the new API token
* @returns {Promise<IApiToken>} The newly created API token
* @throws {Error} Throws response data if the request fails
*/
async create(workspaceSlug: string, data: Partial<IApiToken>): Promise<IApiToken> {
return this.post(`/api/workspaces/${workspaceSlug}/api-tokens/`, data)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Deletes a specific API token from the workspace
* @param {string} workspaceSlug - The unique identifier for the workspace
* @param {string} tokenId - The unique identifier of the API token to delete
* @returns {Promise<IApiToken>} The deleted API token's details
* @throws {Error} Throws response data if the request fails
*/
async destroy(workspaceSlug: string, tokenId: string): Promise<IApiToken> {
return this.delete(`/api/workspaces/${workspaceSlug}/api-tokens/${tokenId}`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
}

View file

@ -0,0 +1,2 @@
export * from "./api-token.service";
export * from "./webhook.service";

View file

@ -0,0 +1,104 @@
import { API_BASE_URL } from "@plane/constants";
import { IWebhook } from "@plane/types";
import { APIService } from "../api.service";
/**
* Service class for managing webhooks
* Handles CRUD operations for webhooks and secret key management
* @extends {APIService}
*/
export default class WebhookService extends APIService {
constructor(BASE_URL?: string) {
super(BASE_URL || API_BASE_URL);
}
/**
* Retrieves all webhooks for a workspace
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @returns {Promise<IWebhook[]>} Promise resolving to array of webhooks
* @throws {Error} If the API request fails
*/
async list(workspaceSlug: string): Promise<IWebhook[]> {
return this.get(`/api/workspaces/${workspaceSlug}/webhooks/`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Retrieves details of a specific webhook
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @param {string} webhookId - The unique identifier for the webhook
* @returns {Promise<IWebhook>} Promise resolving to webhook details
* @throws {Error} If the API request fails
*/
async retrieve(workspaceSlug: string, webhookId: string): Promise<IWebhook> {
return this.get(`/api/workspaces/${workspaceSlug}/webhooks/${webhookId}/`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Creates a new webhook in the workspace
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @param {Object} [data={}] - Webhook configuration data
* @returns {Promise<IWebhook>} Promise resolving to the created webhook
* @throws {Error} If the API request fails
*/
async create(workspaceSlug: string, data = {}): Promise<IWebhook> {
return this.post(`/api/workspaces/${workspaceSlug}/webhooks/`, data)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Updates an existing webhook
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @param {string} webhookId - The unique identifier for the webhook
* @param {Object} [data={}] - Updated webhook configuration data
* @returns {Promise<IWebhook>} Promise resolving to the updated webhook
* @throws {Error} If the API request fails
*/
async update(workspaceSlug: string, webhookId: string, data = {}): Promise<IWebhook> {
return this.patch(`/api/workspaces/${workspaceSlug}/webhooks/${webhookId}/`, data)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Deletes a webhook from the workspace
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @param {string} webhookId - The unique identifier for the webhook
* @returns {Promise<void>} Promise resolving when webhook is deleted
* @throws {Error} If the API request fails
*/
async destroy(workspaceSlug: string, webhookId: string): Promise<void> {
return this.delete(`/api/workspaces/${workspaceSlug}/webhooks/${webhookId}/`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
/**
* Regenerates the secret key for a webhook
* @param {string} workspaceSlug - The unique slug identifier for the workspace
* @param {string} webhookId - The unique identifier for the webhook
* @returns {Promise<IWebhook>} Promise resolving to the webhook with new secret key
* @throws {Error} If the API request fails
*/
async regenerateSecretKey(workspaceSlug: string, webhookId: string): Promise<IWebhook> {
return this.post(`/api/workspaces/${workspaceSlug}/webhooks/${webhookId}/regenerate/`)
.then((response) => response?.data)
.catch((error) => {
throw error?.response?.data;
});
}
}