@symbo.ls/sdk 3.2.3 → 3.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +141 -0
- package/dist/cjs/config/environment.js +94 -10
- package/dist/cjs/index.js +152 -12
- package/dist/cjs/services/AdminService.js +351 -0
- package/dist/cjs/services/AuthService.js +738 -305
- package/dist/cjs/services/BaseService.js +158 -6
- package/dist/cjs/services/BranchService.js +484 -0
- package/dist/cjs/services/CollabService.js +439 -116
- package/dist/cjs/services/DnsService.js +340 -0
- package/dist/cjs/services/FeatureFlagService.js +175 -0
- package/dist/cjs/services/FileService.js +201 -0
- package/dist/cjs/services/IntegrationService.js +538 -0
- package/dist/cjs/services/MetricsService.js +62 -0
- package/dist/cjs/services/PaymentService.js +271 -0
- package/dist/cjs/services/PlanService.js +426 -0
- package/dist/cjs/services/ProjectService.js +1207 -0
- package/dist/cjs/services/PullRequestService.js +503 -0
- package/dist/cjs/services/ScreenshotService.js +304 -0
- package/dist/cjs/services/SubscriptionService.js +396 -0
- package/dist/cjs/services/TrackingService.js +661 -0
- package/dist/cjs/services/WaitlistService.js +148 -0
- package/dist/cjs/services/index.js +60 -4
- package/dist/cjs/state/RootStateManager.js +2 -23
- package/dist/cjs/state/rootEventBus.js +9 -0
- package/dist/cjs/utils/CollabClient.js +78 -12
- package/dist/cjs/utils/TokenManager.js +16 -3
- package/dist/cjs/utils/changePreprocessor.js +199 -0
- package/dist/cjs/utils/jsonDiff.js +46 -4
- package/dist/cjs/utils/ordering.js +309 -0
- package/dist/cjs/utils/services.js +285 -128
- package/dist/cjs/utils/validation.js +0 -3
- package/dist/esm/config/environment.js +94 -10
- package/dist/esm/index.js +47862 -18248
- package/dist/esm/services/AdminService.js +1132 -0
- package/dist/esm/services/AuthService.js +1493 -386
- package/dist/esm/services/BaseService.js +757 -6
- package/dist/esm/services/BranchService.js +1265 -0
- package/dist/esm/services/CollabService.js +24956 -16089
- package/dist/esm/services/DnsService.js +1121 -0
- package/dist/esm/services/FeatureFlagService.js +956 -0
- package/dist/esm/services/FileService.js +982 -0
- package/dist/esm/services/IntegrationService.js +1319 -0
- package/dist/esm/services/MetricsService.js +843 -0
- package/dist/esm/services/PaymentService.js +1052 -0
- package/dist/esm/services/PlanService.js +1207 -0
- package/dist/esm/services/ProjectService.js +2526 -0
- package/dist/esm/services/PullRequestService.js +1284 -0
- package/dist/esm/services/ScreenshotService.js +1085 -0
- package/dist/esm/services/SubscriptionService.js +1177 -0
- package/dist/esm/services/TrackingService.js +18454 -0
- package/dist/esm/services/WaitlistService.js +929 -0
- package/dist/esm/services/index.js +47373 -18027
- package/dist/esm/state/RootStateManager.js +11 -23
- package/dist/esm/state/rootEventBus.js +9 -0
- package/dist/esm/utils/CollabClient.js +17526 -16120
- package/dist/esm/utils/TokenManager.js +16 -3
- package/dist/esm/utils/changePreprocessor.js +542 -0
- package/dist/esm/utils/jsonDiff.js +958 -43
- package/dist/esm/utils/ordering.js +291 -0
- package/dist/esm/utils/services.js +285 -128
- package/dist/esm/utils/validation.js +116 -50
- package/dist/node/config/environment.js +94 -10
- package/dist/node/index.js +183 -16
- package/dist/node/services/AdminService.js +332 -0
- package/dist/node/services/AuthService.js +742 -310
- package/dist/node/services/BaseService.js +148 -6
- package/dist/node/services/BranchService.js +465 -0
- package/dist/node/services/CollabService.js +439 -116
- package/dist/node/services/DnsService.js +321 -0
- package/dist/node/services/FeatureFlagService.js +156 -0
- package/dist/node/services/FileService.js +182 -0
- package/dist/node/services/IntegrationService.js +519 -0
- package/dist/node/services/MetricsService.js +43 -0
- package/dist/node/services/PaymentService.js +252 -0
- package/dist/node/services/PlanService.js +407 -0
- package/dist/node/services/ProjectService.js +1188 -0
- package/dist/node/services/PullRequestService.js +484 -0
- package/dist/node/services/ScreenshotService.js +285 -0
- package/dist/node/services/SubscriptionService.js +377 -0
- package/dist/node/services/TrackingService.js +632 -0
- package/dist/node/services/WaitlistService.js +129 -0
- package/dist/node/services/index.js +60 -4
- package/dist/node/state/RootStateManager.js +2 -23
- package/dist/node/state/rootEventBus.js +9 -0
- package/dist/node/utils/CollabClient.js +77 -11
- package/dist/node/utils/TokenManager.js +16 -3
- package/dist/node/utils/changePreprocessor.js +180 -0
- package/dist/node/utils/jsonDiff.js +46 -4
- package/dist/node/utils/ordering.js +290 -0
- package/dist/node/utils/services.js +285 -128
- package/dist/node/utils/validation.js +0 -3
- package/package.json +30 -18
- package/src/config/environment.js +95 -10
- package/src/index.js +190 -23
- package/src/services/AdminService.js +374 -0
- package/src/services/AuthService.js +874 -328
- package/src/services/BaseService.js +166 -6
- package/src/services/BranchService.js +536 -0
- package/src/services/CollabService.js +557 -148
- package/src/services/DnsService.js +366 -0
- package/src/services/FeatureFlagService.js +174 -0
- package/src/services/FileService.js +213 -0
- package/src/services/IntegrationService.js +548 -0
- package/src/services/MetricsService.js +40 -0
- package/src/services/PaymentService.js +287 -0
- package/src/services/PlanService.js +468 -0
- package/src/services/ProjectService.js +1366 -0
- package/src/services/PullRequestService.js +537 -0
- package/src/services/ScreenshotService.js +258 -0
- package/src/services/SubscriptionService.js +425 -0
- package/src/services/TrackingService.js +853 -0
- package/src/services/WaitlistService.js +130 -0
- package/src/services/index.js +79 -5
- package/src/services/tests/BranchService/createBranch.test.js +153 -0
- package/src/services/tests/BranchService/deleteBranch.test.js +173 -0
- package/src/services/tests/BranchService/getBranchChanges.test.js +146 -0
- package/src/services/tests/BranchService/listBranches.test.js +87 -0
- package/src/services/tests/BranchService/mergeBranch.test.js +210 -0
- package/src/services/tests/BranchService/publishVersion.test.js +183 -0
- package/src/services/tests/BranchService/renameBranch.test.js +240 -0
- package/src/services/tests/BranchService/resetBranch.test.js +152 -0
- package/src/services/tests/FeatureFlagService/adminFeatureFlags.test.js +67 -0
- package/src/services/tests/FeatureFlagService/getFeatureFlags.test.js +75 -0
- package/src/services/tests/FileService/createFileFormData.test.js +74 -0
- package/src/services/tests/FileService/getFileUrl.test.js +69 -0
- package/src/services/tests/FileService/updateProjectIcon.test.js +109 -0
- package/src/services/tests/FileService/uploadDocument.test.js +36 -0
- package/src/services/tests/FileService/uploadFile.test.js +78 -0
- package/src/services/tests/FileService/uploadFileWithValidation.test.js +114 -0
- package/src/services/tests/FileService/uploadImage.test.js +36 -0
- package/src/services/tests/FileService/uploadMultipleFiles.test.js +111 -0
- package/src/services/tests/FileService/validateFile.test.js +63 -0
- package/src/services/tests/PlanService/createPlan.test.js +104 -0
- package/src/services/tests/PlanService/createPlanWithValidation.test.js +523 -0
- package/src/services/tests/PlanService/deletePlan.test.js +92 -0
- package/src/services/tests/PlanService/getActivePlans.test.js +123 -0
- package/src/services/tests/PlanService/getAdminPlans.test.js +84 -0
- package/src/services/tests/PlanService/getPlan.test.js +50 -0
- package/src/services/tests/PlanService/getPlanByKey.test.js +109 -0
- package/src/services/tests/PlanService/getPlanWithValidation.test.js +85 -0
- package/src/services/tests/PlanService/getPlans.test.js +53 -0
- package/src/services/tests/PlanService/getPlansByPriceRange.test.js +109 -0
- package/src/services/tests/PlanService/getPlansWithValidation.test.js +48 -0
- package/src/services/tests/PlanService/initializePlans.test.js +75 -0
- package/src/services/tests/PlanService/updatePlan.test.js +111 -0
- package/src/services/tests/PlanService/updatePlanWithValidation.test.js +556 -0
- package/src/state/RootStateManager.js +37 -32
- package/src/state/rootEventBus.js +19 -0
- package/src/utils/CollabClient.js +99 -12
- package/src/utils/TokenManager.js +20 -3
- package/src/utils/changePreprocessor.js +239 -0
- package/src/utils/jsonDiff.js +40 -5
- package/src/utils/ordering.js +271 -0
- package/src/utils/services.js +306 -139
- package/src/utils/validation.js +0 -3
- package/dist/cjs/services/AIService.js +0 -155
- package/dist/cjs/services/BasedService.js +0 -1185
- package/dist/cjs/services/CoreService.js +0 -2295
- package/dist/cjs/services/SocketService.js +0 -309
- package/dist/cjs/services/SymstoryService.js +0 -571
- package/dist/cjs/utils/basedQuerys.js +0 -181
- package/dist/cjs/utils/symstoryClient.js +0 -259
- package/dist/esm/services/AIService.js +0 -185
- package/dist/esm/services/BasedService.js +0 -5262
- package/dist/esm/services/CoreService.js +0 -2827
- package/dist/esm/services/SocketService.js +0 -456
- package/dist/esm/services/SymstoryService.js +0 -7025
- package/dist/esm/utils/basedQuerys.js +0 -163
- package/dist/esm/utils/symstoryClient.js +0 -354
- package/dist/node/services/AIService.js +0 -136
- package/dist/node/services/BasedService.js +0 -1156
- package/dist/node/services/CoreService.js +0 -2266
- package/dist/node/services/SocketService.js +0 -280
- package/dist/node/services/SymstoryService.js +0 -542
- package/dist/node/utils/basedQuerys.js +0 -162
- package/dist/node/utils/symstoryClient.js +0 -230
- package/src/services/AIService.js +0 -150
- package/src/services/BasedService.js +0 -1302
- package/src/services/CoreService.js +0 -2548
- package/src/services/SocketService.js +0 -336
- package/src/services/SymstoryService.js +0 -649
- package/src/utils/basedQuerys.js +0 -164
- package/src/utils/symstoryClient.js +0 -252
|
@@ -0,0 +1,538 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var IntegrationService_exports = {};
|
|
19
|
+
__export(IntegrationService_exports, {
|
|
20
|
+
IntegrationService: () => IntegrationService
|
|
21
|
+
});
|
|
22
|
+
module.exports = __toCommonJS(IntegrationService_exports);
|
|
23
|
+
var import_BaseService = require("./BaseService.js");
|
|
24
|
+
class IntegrationService extends import_BaseService.BaseService {
|
|
25
|
+
// ==================== INTEGRATION METHODS ====================
|
|
26
|
+
/**
|
|
27
|
+
* Programmatic auth sanity check (API key based).
|
|
28
|
+
*
|
|
29
|
+
* Mirrors: GET /integrations/whoami (requireApiKey)
|
|
30
|
+
*
|
|
31
|
+
* Assumption: backend reads API key from `x-api-key` header.
|
|
32
|
+
* You can override via `options.headers`.
|
|
33
|
+
*/
|
|
34
|
+
async integrationWhoami(apiKey, options = {}) {
|
|
35
|
+
this._requireReady("integrationWhoami");
|
|
36
|
+
if (!apiKey) {
|
|
37
|
+
throw new Error("API key is required");
|
|
38
|
+
}
|
|
39
|
+
const headers = {
|
|
40
|
+
"x-api-key": apiKey,
|
|
41
|
+
...options.headers || {}
|
|
42
|
+
};
|
|
43
|
+
try {
|
|
44
|
+
const response = await this._request("/integrations/whoami", {
|
|
45
|
+
method: "GET",
|
|
46
|
+
headers,
|
|
47
|
+
methodName: "integrationWhoami"
|
|
48
|
+
});
|
|
49
|
+
if (response.success) {
|
|
50
|
+
return response.data;
|
|
51
|
+
}
|
|
52
|
+
throw new Error(response.message);
|
|
53
|
+
} catch (error) {
|
|
54
|
+
throw new Error(`Failed to validate integration API key: ${error.message}`, { cause: error });
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* List integrations visible to the user.
|
|
59
|
+
*
|
|
60
|
+
* Mirrors: GET /integrations?orgId=&projectId=
|
|
61
|
+
*/
|
|
62
|
+
async listIntegrations(options = {}) {
|
|
63
|
+
this._requireReady("listIntegrations");
|
|
64
|
+
const { orgId, projectId } = options || {};
|
|
65
|
+
const queryParams = new URLSearchParams();
|
|
66
|
+
if (orgId != null) {
|
|
67
|
+
queryParams.append("orgId", String(orgId));
|
|
68
|
+
}
|
|
69
|
+
if (projectId != null) {
|
|
70
|
+
queryParams.append("projectId", String(projectId));
|
|
71
|
+
}
|
|
72
|
+
const queryString = queryParams.toString();
|
|
73
|
+
const url = `/integrations${queryString ? `?${queryString}` : ""}`;
|
|
74
|
+
try {
|
|
75
|
+
const response = await this._request(url, {
|
|
76
|
+
method: "GET",
|
|
77
|
+
methodName: "listIntegrations"
|
|
78
|
+
});
|
|
79
|
+
if (response.success) {
|
|
80
|
+
return response.data;
|
|
81
|
+
}
|
|
82
|
+
throw new Error(response.message);
|
|
83
|
+
} catch (error) {
|
|
84
|
+
throw new Error(`Failed to list integrations: ${error.message}`, { cause: error });
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Create an integration.
|
|
89
|
+
*
|
|
90
|
+
* Mirrors: POST /integrations
|
|
91
|
+
*/
|
|
92
|
+
async createIntegration(data = {}) {
|
|
93
|
+
this._requireReady("createIntegration");
|
|
94
|
+
if (!data || typeof data !== "object") {
|
|
95
|
+
throw new Error("Integration payload is required");
|
|
96
|
+
}
|
|
97
|
+
if (!data.name) {
|
|
98
|
+
throw new Error("Integration name is required");
|
|
99
|
+
}
|
|
100
|
+
if (!data.ownerType) {
|
|
101
|
+
throw new Error("ownerType is required");
|
|
102
|
+
}
|
|
103
|
+
try {
|
|
104
|
+
const response = await this._request("/integrations", {
|
|
105
|
+
method: "POST",
|
|
106
|
+
body: JSON.stringify(data),
|
|
107
|
+
methodName: "createIntegration"
|
|
108
|
+
});
|
|
109
|
+
if (response.success) {
|
|
110
|
+
return response.data;
|
|
111
|
+
}
|
|
112
|
+
throw new Error(response.message);
|
|
113
|
+
} catch (error) {
|
|
114
|
+
throw new Error(`Failed to create integration: ${error.message}`, { cause: error });
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Update an integration.
|
|
119
|
+
*
|
|
120
|
+
* Mirrors: PATCH /integrations/:integrationId
|
|
121
|
+
*/
|
|
122
|
+
async updateIntegration(integrationId, update = {}) {
|
|
123
|
+
this._requireReady("updateIntegration");
|
|
124
|
+
if (!integrationId) {
|
|
125
|
+
throw new Error("Integration ID is required");
|
|
126
|
+
}
|
|
127
|
+
if (!update || typeof update !== "object") {
|
|
128
|
+
throw new Error("Update payload is required");
|
|
129
|
+
}
|
|
130
|
+
try {
|
|
131
|
+
const response = await this._request(`/integrations/${integrationId}`, {
|
|
132
|
+
method: "PATCH",
|
|
133
|
+
body: JSON.stringify(update),
|
|
134
|
+
methodName: "updateIntegration"
|
|
135
|
+
});
|
|
136
|
+
if (response.success) {
|
|
137
|
+
return response.data;
|
|
138
|
+
}
|
|
139
|
+
throw new Error(response.message);
|
|
140
|
+
} catch (error) {
|
|
141
|
+
throw new Error(`Failed to update integration: ${error.message}`, { cause: error });
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
// ==================== INTEGRATION API KEY METHODS ====================
|
|
145
|
+
/**
|
|
146
|
+
* Create a new API key for an integration.
|
|
147
|
+
*
|
|
148
|
+
* Mirrors: POST /integrations/:integrationId/api-keys
|
|
149
|
+
*/
|
|
150
|
+
async createIntegrationApiKey(integrationId, data = {}) {
|
|
151
|
+
this._requireReady("createIntegrationApiKey");
|
|
152
|
+
if (!integrationId) {
|
|
153
|
+
throw new Error("Integration ID is required");
|
|
154
|
+
}
|
|
155
|
+
if (!data || typeof data !== "object") {
|
|
156
|
+
throw new Error("API key payload is required");
|
|
157
|
+
}
|
|
158
|
+
try {
|
|
159
|
+
const response = await this._request(`/integrations/${integrationId}/api-keys`, {
|
|
160
|
+
method: "POST",
|
|
161
|
+
body: JSON.stringify(data),
|
|
162
|
+
methodName: "createIntegrationApiKey"
|
|
163
|
+
});
|
|
164
|
+
if (response.success) {
|
|
165
|
+
return response.data;
|
|
166
|
+
}
|
|
167
|
+
throw new Error(response.message);
|
|
168
|
+
} catch (error) {
|
|
169
|
+
throw new Error(`Failed to create integration API key: ${error.message}`, { cause: error });
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* List API keys for an integration.
|
|
174
|
+
*
|
|
175
|
+
* Mirrors: GET /integrations/:integrationId/api-keys
|
|
176
|
+
*/
|
|
177
|
+
async listIntegrationApiKeys(integrationId) {
|
|
178
|
+
this._requireReady("listIntegrationApiKeys");
|
|
179
|
+
if (!integrationId) {
|
|
180
|
+
throw new Error("Integration ID is required");
|
|
181
|
+
}
|
|
182
|
+
try {
|
|
183
|
+
const response = await this._request(`/integrations/${integrationId}/api-keys`, {
|
|
184
|
+
method: "GET",
|
|
185
|
+
methodName: "listIntegrationApiKeys"
|
|
186
|
+
});
|
|
187
|
+
if (response.success) {
|
|
188
|
+
return response.data;
|
|
189
|
+
}
|
|
190
|
+
throw new Error(response.message);
|
|
191
|
+
} catch (error) {
|
|
192
|
+
throw new Error(`Failed to list integration API keys: ${error.message}`, { cause: error });
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Revoke an API key for an integration.
|
|
197
|
+
*
|
|
198
|
+
* Mirrors: POST /integrations/:integrationId/api-keys/:keyId/revoke
|
|
199
|
+
*/
|
|
200
|
+
async revokeIntegrationApiKey(integrationId, keyId) {
|
|
201
|
+
this._requireReady("revokeIntegrationApiKey");
|
|
202
|
+
if (!integrationId) {
|
|
203
|
+
throw new Error("Integration ID is required");
|
|
204
|
+
}
|
|
205
|
+
if (!keyId) {
|
|
206
|
+
throw new Error("API key ID is required");
|
|
207
|
+
}
|
|
208
|
+
try {
|
|
209
|
+
const response = await this._request(
|
|
210
|
+
`/integrations/${integrationId}/api-keys/${keyId}/revoke`,
|
|
211
|
+
{
|
|
212
|
+
method: "POST",
|
|
213
|
+
methodName: "revokeIntegrationApiKey"
|
|
214
|
+
}
|
|
215
|
+
);
|
|
216
|
+
if (response.success) {
|
|
217
|
+
return response.data;
|
|
218
|
+
}
|
|
219
|
+
throw new Error(response.message);
|
|
220
|
+
} catch (error) {
|
|
221
|
+
throw new Error(`Failed to revoke integration API key: ${error.message}`, { cause: error });
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
// ==================== WEBHOOK METHODS ====================
|
|
225
|
+
/**
|
|
226
|
+
* Create a webhook endpoint for an integration.
|
|
227
|
+
*
|
|
228
|
+
* Mirrors: POST /integrations/:integrationId/webhooks
|
|
229
|
+
*/
|
|
230
|
+
async createIntegrationWebhook(integrationId, data = {}) {
|
|
231
|
+
this._requireReady("createIntegrationWebhook");
|
|
232
|
+
if (!integrationId) {
|
|
233
|
+
throw new Error("Integration ID is required");
|
|
234
|
+
}
|
|
235
|
+
if (!data || typeof data !== "object") {
|
|
236
|
+
throw new Error("Webhook payload is required");
|
|
237
|
+
}
|
|
238
|
+
try {
|
|
239
|
+
const response = await this._request(`/integrations/${integrationId}/webhooks`, {
|
|
240
|
+
method: "POST",
|
|
241
|
+
body: JSON.stringify(data),
|
|
242
|
+
methodName: "createIntegrationWebhook"
|
|
243
|
+
});
|
|
244
|
+
if (response.success) {
|
|
245
|
+
return response.data;
|
|
246
|
+
}
|
|
247
|
+
throw new Error(response.message);
|
|
248
|
+
} catch (error) {
|
|
249
|
+
throw new Error(`Failed to create integration webhook: ${error.message}`, { cause: error });
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* List webhook endpoints for an integration.
|
|
254
|
+
*
|
|
255
|
+
* Mirrors: GET /integrations/:integrationId/webhooks
|
|
256
|
+
*/
|
|
257
|
+
async listIntegrationWebhooks(integrationId) {
|
|
258
|
+
this._requireReady("listIntegrationWebhooks");
|
|
259
|
+
if (!integrationId) {
|
|
260
|
+
throw new Error("Integration ID is required");
|
|
261
|
+
}
|
|
262
|
+
try {
|
|
263
|
+
const response = await this._request(`/integrations/${integrationId}/webhooks`, {
|
|
264
|
+
method: "GET",
|
|
265
|
+
methodName: "listIntegrationWebhooks"
|
|
266
|
+
});
|
|
267
|
+
if (response.success) {
|
|
268
|
+
return response.data;
|
|
269
|
+
}
|
|
270
|
+
throw new Error(response.message);
|
|
271
|
+
} catch (error) {
|
|
272
|
+
throw new Error(`Failed to list integration webhooks: ${error.message}`, { cause: error });
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
/**
|
|
276
|
+
* Update a webhook endpoint for an integration.
|
|
277
|
+
*
|
|
278
|
+
* Mirrors: PATCH /integrations/:integrationId/webhooks/:webhookId
|
|
279
|
+
*/
|
|
280
|
+
async updateIntegrationWebhook(integrationId, webhookId, update = {}) {
|
|
281
|
+
this._requireReady("updateIntegrationWebhook");
|
|
282
|
+
if (!integrationId) {
|
|
283
|
+
throw new Error("Integration ID is required");
|
|
284
|
+
}
|
|
285
|
+
if (!webhookId) {
|
|
286
|
+
throw new Error("Webhook ID is required");
|
|
287
|
+
}
|
|
288
|
+
if (!update || typeof update !== "object") {
|
|
289
|
+
throw new Error("Update payload is required");
|
|
290
|
+
}
|
|
291
|
+
try {
|
|
292
|
+
const response = await this._request(
|
|
293
|
+
`/integrations/${integrationId}/webhooks/${webhookId}`,
|
|
294
|
+
{
|
|
295
|
+
method: "PATCH",
|
|
296
|
+
body: JSON.stringify(update),
|
|
297
|
+
methodName: "updateIntegrationWebhook"
|
|
298
|
+
}
|
|
299
|
+
);
|
|
300
|
+
if (response.success) {
|
|
301
|
+
return response.data;
|
|
302
|
+
}
|
|
303
|
+
throw new Error(response.message);
|
|
304
|
+
} catch (error) {
|
|
305
|
+
throw new Error(`Failed to update integration webhook: ${error.message}`, { cause: error });
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Delete a webhook endpoint for an integration.
|
|
310
|
+
*
|
|
311
|
+
* Mirrors: DELETE /integrations/:integrationId/webhooks/:webhookId
|
|
312
|
+
*/
|
|
313
|
+
async deleteIntegrationWebhook(integrationId, webhookId) {
|
|
314
|
+
this._requireReady("deleteIntegrationWebhook");
|
|
315
|
+
if (!integrationId) {
|
|
316
|
+
throw new Error("Integration ID is required");
|
|
317
|
+
}
|
|
318
|
+
if (!webhookId) {
|
|
319
|
+
throw new Error("Webhook ID is required");
|
|
320
|
+
}
|
|
321
|
+
try {
|
|
322
|
+
const response = await this._request(
|
|
323
|
+
`/integrations/${integrationId}/webhooks/${webhookId}`,
|
|
324
|
+
{
|
|
325
|
+
method: "DELETE",
|
|
326
|
+
methodName: "deleteIntegrationWebhook"
|
|
327
|
+
}
|
|
328
|
+
);
|
|
329
|
+
if (response && response.success) {
|
|
330
|
+
return response.data;
|
|
331
|
+
}
|
|
332
|
+
if (response == null) {
|
|
333
|
+
return null;
|
|
334
|
+
}
|
|
335
|
+
throw new Error(response.message);
|
|
336
|
+
} catch (error) {
|
|
337
|
+
throw new Error(`Failed to delete integration webhook: ${error.message}`, { cause: error });
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* List webhook deliveries for an integration webhook.
|
|
342
|
+
*
|
|
343
|
+
* Mirrors: GET /integrations/:integrationId/webhooks/:webhookId/deliveries
|
|
344
|
+
*/
|
|
345
|
+
async listIntegrationWebhookDeliveries(integrationId, webhookId, options = {}) {
|
|
346
|
+
this._requireReady("listIntegrationWebhookDeliveries");
|
|
347
|
+
if (!integrationId) {
|
|
348
|
+
throw new Error("Integration ID is required");
|
|
349
|
+
}
|
|
350
|
+
if (!webhookId) {
|
|
351
|
+
throw new Error("Webhook ID is required");
|
|
352
|
+
}
|
|
353
|
+
const { page, limit, status, includePayload } = options || {};
|
|
354
|
+
const queryParams = new URLSearchParams();
|
|
355
|
+
if (page != null) {
|
|
356
|
+
queryParams.append("page", String(page));
|
|
357
|
+
}
|
|
358
|
+
if (limit != null) {
|
|
359
|
+
queryParams.append("limit", String(limit));
|
|
360
|
+
}
|
|
361
|
+
if (status != null) {
|
|
362
|
+
queryParams.append("status", String(status));
|
|
363
|
+
}
|
|
364
|
+
if (includePayload != null) {
|
|
365
|
+
queryParams.append("includePayload", String(includePayload));
|
|
366
|
+
}
|
|
367
|
+
const queryString = queryParams.toString();
|
|
368
|
+
const url = `/integrations/${integrationId}/webhooks/${webhookId}/deliveries${queryString ? `?${queryString}` : ""}`;
|
|
369
|
+
try {
|
|
370
|
+
const response = await this._request(url, {
|
|
371
|
+
method: "GET",
|
|
372
|
+
methodName: "listIntegrationWebhookDeliveries"
|
|
373
|
+
});
|
|
374
|
+
if (response.success) {
|
|
375
|
+
return response.data;
|
|
376
|
+
}
|
|
377
|
+
throw new Error(response.message);
|
|
378
|
+
} catch (error) {
|
|
379
|
+
throw new Error(`Failed to list webhook deliveries: ${error.message}`, { cause: error });
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
/**
|
|
383
|
+
* Replay a webhook delivery.
|
|
384
|
+
*
|
|
385
|
+
* Mirrors: POST /integrations/:integrationId/webhooks/:webhookId/replay
|
|
386
|
+
* Body: { deliveryId }
|
|
387
|
+
*/
|
|
388
|
+
async replayIntegrationWebhookDelivery(integrationId, webhookId, deliveryId) {
|
|
389
|
+
this._requireReady("replayIntegrationWebhookDelivery");
|
|
390
|
+
if (!integrationId) {
|
|
391
|
+
throw new Error("Integration ID is required");
|
|
392
|
+
}
|
|
393
|
+
if (!webhookId) {
|
|
394
|
+
throw new Error("Webhook ID is required");
|
|
395
|
+
}
|
|
396
|
+
if (!deliveryId) {
|
|
397
|
+
throw new Error("deliveryId is required");
|
|
398
|
+
}
|
|
399
|
+
try {
|
|
400
|
+
const response = await this._request(
|
|
401
|
+
`/integrations/${integrationId}/webhooks/${webhookId}/replay`,
|
|
402
|
+
{
|
|
403
|
+
method: "POST",
|
|
404
|
+
body: JSON.stringify({ deliveryId }),
|
|
405
|
+
methodName: "replayIntegrationWebhookDelivery"
|
|
406
|
+
}
|
|
407
|
+
);
|
|
408
|
+
if (response.success) {
|
|
409
|
+
return response.data;
|
|
410
|
+
}
|
|
411
|
+
throw new Error(response.message);
|
|
412
|
+
} catch (error) {
|
|
413
|
+
throw new Error(`Failed to replay webhook delivery: ${error.message}`, { cause: error });
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
// ==================== CONNECTOR METHODS (GITHUB) ====================
|
|
417
|
+
/**
|
|
418
|
+
* List GitHub connectors for an integration.
|
|
419
|
+
*
|
|
420
|
+
* Mirrors: GET /integrations/:integrationId/connectors/github
|
|
421
|
+
*/
|
|
422
|
+
async listGitHubConnectors(integrationId) {
|
|
423
|
+
this._requireReady("listGitHubConnectors");
|
|
424
|
+
if (!integrationId) {
|
|
425
|
+
throw new Error("Integration ID is required");
|
|
426
|
+
}
|
|
427
|
+
try {
|
|
428
|
+
const response = await this._request(`/integrations/${integrationId}/connectors/github`, {
|
|
429
|
+
method: "GET",
|
|
430
|
+
methodName: "listGitHubConnectors"
|
|
431
|
+
});
|
|
432
|
+
if (response.success) {
|
|
433
|
+
return response.data;
|
|
434
|
+
}
|
|
435
|
+
throw new Error(response.message);
|
|
436
|
+
} catch (error) {
|
|
437
|
+
throw new Error(`Failed to list GitHub connectors: ${error.message}`, { cause: error });
|
|
438
|
+
}
|
|
439
|
+
}
|
|
440
|
+
/**
|
|
441
|
+
* Create a GitHub connector for an integration.
|
|
442
|
+
*
|
|
443
|
+
* Mirrors: POST /integrations/:integrationId/connectors/github
|
|
444
|
+
*/
|
|
445
|
+
async createGitHubConnector(integrationId, data = {}) {
|
|
446
|
+
this._requireReady("createGitHubConnector");
|
|
447
|
+
if (!integrationId) {
|
|
448
|
+
throw new Error("Integration ID is required");
|
|
449
|
+
}
|
|
450
|
+
if (!data || typeof data !== "object") {
|
|
451
|
+
throw new Error("Connector payload is required");
|
|
452
|
+
}
|
|
453
|
+
if (!data.projectId) {
|
|
454
|
+
throw new Error("projectId is required");
|
|
455
|
+
}
|
|
456
|
+
if (!data.repository) {
|
|
457
|
+
throw new Error("repository is required");
|
|
458
|
+
}
|
|
459
|
+
try {
|
|
460
|
+
const response = await this._request(`/integrations/${integrationId}/connectors/github`, {
|
|
461
|
+
method: "POST",
|
|
462
|
+
body: JSON.stringify(data),
|
|
463
|
+
methodName: "createGitHubConnector"
|
|
464
|
+
});
|
|
465
|
+
if (response.success) {
|
|
466
|
+
return response.data;
|
|
467
|
+
}
|
|
468
|
+
throw new Error(response.message);
|
|
469
|
+
} catch (error) {
|
|
470
|
+
throw new Error(`Failed to create GitHub connector: ${error.message}`, { cause: error });
|
|
471
|
+
}
|
|
472
|
+
}
|
|
473
|
+
/**
|
|
474
|
+
* Update a GitHub connector.
|
|
475
|
+
*
|
|
476
|
+
* Mirrors: PATCH /integrations/:integrationId/connectors/github/:connectorId
|
|
477
|
+
*/
|
|
478
|
+
async updateGitHubConnector(integrationId, connectorId, update = {}) {
|
|
479
|
+
this._requireReady("updateGitHubConnector");
|
|
480
|
+
if (!integrationId) {
|
|
481
|
+
throw new Error("Integration ID is required");
|
|
482
|
+
}
|
|
483
|
+
if (!connectorId) {
|
|
484
|
+
throw new Error("Connector ID is required");
|
|
485
|
+
}
|
|
486
|
+
if (!update || typeof update !== "object") {
|
|
487
|
+
throw new Error("Update payload is required");
|
|
488
|
+
}
|
|
489
|
+
try {
|
|
490
|
+
const response = await this._request(
|
|
491
|
+
`/integrations/${integrationId}/connectors/github/${connectorId}`,
|
|
492
|
+
{
|
|
493
|
+
method: "PATCH",
|
|
494
|
+
body: JSON.stringify(update),
|
|
495
|
+
methodName: "updateGitHubConnector"
|
|
496
|
+
}
|
|
497
|
+
);
|
|
498
|
+
if (response.success) {
|
|
499
|
+
return response.data;
|
|
500
|
+
}
|
|
501
|
+
throw new Error(response.message);
|
|
502
|
+
} catch (error) {
|
|
503
|
+
throw new Error(`Failed to update GitHub connector: ${error.message}`, { cause: error });
|
|
504
|
+
}
|
|
505
|
+
}
|
|
506
|
+
/**
|
|
507
|
+
* Delete a GitHub connector.
|
|
508
|
+
*
|
|
509
|
+
* Mirrors: DELETE /integrations/:integrationId/connectors/github/:connectorId
|
|
510
|
+
*/
|
|
511
|
+
async deleteGitHubConnector(integrationId, connectorId) {
|
|
512
|
+
this._requireReady("deleteGitHubConnector");
|
|
513
|
+
if (!integrationId) {
|
|
514
|
+
throw new Error("Integration ID is required");
|
|
515
|
+
}
|
|
516
|
+
if (!connectorId) {
|
|
517
|
+
throw new Error("Connector ID is required");
|
|
518
|
+
}
|
|
519
|
+
try {
|
|
520
|
+
const response = await this._request(
|
|
521
|
+
`/integrations/${integrationId}/connectors/github/${connectorId}`,
|
|
522
|
+
{
|
|
523
|
+
method: "DELETE",
|
|
524
|
+
methodName: "deleteGitHubConnector"
|
|
525
|
+
}
|
|
526
|
+
);
|
|
527
|
+
if (response && response.success) {
|
|
528
|
+
return response.data;
|
|
529
|
+
}
|
|
530
|
+
if (response == null) {
|
|
531
|
+
return null;
|
|
532
|
+
}
|
|
533
|
+
throw new Error(response.message);
|
|
534
|
+
} catch (error) {
|
|
535
|
+
throw new Error(`Failed to delete GitHub connector: ${error.message}`, { cause: error });
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var MetricsService_exports = {};
|
|
19
|
+
__export(MetricsService_exports, {
|
|
20
|
+
MetricsService: () => MetricsService
|
|
21
|
+
});
|
|
22
|
+
module.exports = __toCommonJS(MetricsService_exports);
|
|
23
|
+
var import_BaseService = require("./BaseService.js");
|
|
24
|
+
class MetricsService extends import_BaseService.BaseService {
|
|
25
|
+
// ==================== METRICS METHODS ====================
|
|
26
|
+
/**
|
|
27
|
+
* Contribution heat-map stats.
|
|
28
|
+
*
|
|
29
|
+
* Mirrors: GET /metrics/contributions (MetricsController.getContributions)
|
|
30
|
+
*/
|
|
31
|
+
async getContributions(options = {}) {
|
|
32
|
+
this._requireReady("getContributions");
|
|
33
|
+
const { projectId, userId, from, to } = options || {};
|
|
34
|
+
const queryParams = new URLSearchParams();
|
|
35
|
+
if (projectId != null) {
|
|
36
|
+
queryParams.append("projectId", String(projectId));
|
|
37
|
+
}
|
|
38
|
+
if (userId != null) {
|
|
39
|
+
queryParams.append("userId", String(userId));
|
|
40
|
+
}
|
|
41
|
+
if (from != null) {
|
|
42
|
+
queryParams.append("from", String(from));
|
|
43
|
+
}
|
|
44
|
+
if (to != null) {
|
|
45
|
+
queryParams.append("to", String(to));
|
|
46
|
+
}
|
|
47
|
+
const queryString = queryParams.toString();
|
|
48
|
+
const url = `/metrics/contributions${queryString ? `?${queryString}` : ""}`;
|
|
49
|
+
try {
|
|
50
|
+
const response = await this._request(url, {
|
|
51
|
+
method: "GET",
|
|
52
|
+
methodName: "getContributions"
|
|
53
|
+
});
|
|
54
|
+
if (response.success) {
|
|
55
|
+
return response.data;
|
|
56
|
+
}
|
|
57
|
+
throw new Error(response.message);
|
|
58
|
+
} catch (error) {
|
|
59
|
+
throw new Error(`Failed to get contribution stats: ${error.message}`, { cause: error });
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|