@apiclient.xyz/gitlab 2.0.2 → 2.1.0
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.
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
5
|
name: '@apiclient.xyz/gitlab',
|
|
6
|
-
version: '2.0
|
|
6
|
+
version: '2.1.0',
|
|
7
7
|
description: 'A TypeScript client for the GitLab API, providing easy access to projects, groups, CI/CD variables, and pipelines.'
|
|
8
8
|
};
|
|
9
9
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSx1QkFBdUI7SUFDN0IsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLG9IQUFvSDtDQUNsSSxDQUFBIn0=
|
|
@@ -6,6 +6,31 @@ export declare class GitLabClient {
|
|
|
6
6
|
private request;
|
|
7
7
|
private requestText;
|
|
8
8
|
testConnection(): Promise<ITestConnectionResult>;
|
|
9
|
+
/**
|
|
10
|
+
* Get a single group by its full path (e.g. "foss.global" or "foss.global/push.rocks")
|
|
11
|
+
*/
|
|
12
|
+
getGroupByPath(fullPath: string): Promise<IGitLabGroup>;
|
|
13
|
+
/**
|
|
14
|
+
* List projects within a group (includes subgroups when include_subgroups=true)
|
|
15
|
+
*/
|
|
16
|
+
getGroupProjects(groupId: number | string, opts?: IListOptions): Promise<IGitLabProject[]>;
|
|
17
|
+
/**
|
|
18
|
+
* List all descendant groups (recursive subgroups) within a group
|
|
19
|
+
*/
|
|
20
|
+
getDescendantGroups(groupId: number | string, opts?: IListOptions): Promise<IGitLabGroup[]>;
|
|
21
|
+
/**
|
|
22
|
+
* Create a new group. Optionally nested under a parent group.
|
|
23
|
+
*/
|
|
24
|
+
createGroup(name: string, path: string, parentId?: number): Promise<IGitLabGroup>;
|
|
25
|
+
/**
|
|
26
|
+
* Create a new project (repository).
|
|
27
|
+
*/
|
|
28
|
+
createProject(name: string, opts?: {
|
|
29
|
+
path?: string;
|
|
30
|
+
namespaceId?: number;
|
|
31
|
+
visibility?: string;
|
|
32
|
+
description?: string;
|
|
33
|
+
}): Promise<IGitLabProject>;
|
|
9
34
|
getProjects(opts?: IListOptions): Promise<IGitLabProject[]>;
|
|
10
35
|
getGroups(opts?: IListOptions): Promise<IGitLabGroup[]>;
|
|
11
36
|
getProjectVariables(projectId: number | string): Promise<IGitLabVariable[]>;
|
|
@@ -89,6 +89,60 @@ export class GitLabClient {
|
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
91
|
// ---------------------------------------------------------------------------
|
|
92
|
+
// Groups — scoped queries
|
|
93
|
+
// ---------------------------------------------------------------------------
|
|
94
|
+
/**
|
|
95
|
+
* Get a single group by its full path (e.g. "foss.global" or "foss.global/push.rocks")
|
|
96
|
+
*/
|
|
97
|
+
async getGroupByPath(fullPath) {
|
|
98
|
+
return this.request('GET', `/api/v4/groups/${encodeURIComponent(fullPath)}`);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* List projects within a group (includes subgroups when include_subgroups=true)
|
|
102
|
+
*/
|
|
103
|
+
async getGroupProjects(groupId, opts) {
|
|
104
|
+
const page = opts?.page || 1;
|
|
105
|
+
const perPage = opts?.perPage || 50;
|
|
106
|
+
let url = `/api/v4/groups/${encodeURIComponent(groupId)}/projects?include_subgroups=true&order_by=updated_at&sort=desc&page=${page}&per_page=${perPage}`;
|
|
107
|
+
if (opts?.search) {
|
|
108
|
+
url += `&search=${encodeURIComponent(opts.search)}`;
|
|
109
|
+
}
|
|
110
|
+
return this.request('GET', url);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* List all descendant groups (recursive subgroups) within a group
|
|
114
|
+
*/
|
|
115
|
+
async getDescendantGroups(groupId, opts) {
|
|
116
|
+
const page = opts?.page || 1;
|
|
117
|
+
const perPage = opts?.perPage || 50;
|
|
118
|
+
let url = `/api/v4/groups/${encodeURIComponent(groupId)}/descendant_groups?order_by=name&sort=asc&page=${page}&per_page=${perPage}`;
|
|
119
|
+
if (opts?.search) {
|
|
120
|
+
url += `&search=${encodeURIComponent(opts.search)}`;
|
|
121
|
+
}
|
|
122
|
+
return this.request('GET', url);
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Create a new group. Optionally nested under a parent group.
|
|
126
|
+
*/
|
|
127
|
+
async createGroup(name, path, parentId) {
|
|
128
|
+
const body = { name, path, visibility: 'private' };
|
|
129
|
+
if (parentId)
|
|
130
|
+
body.parent_id = parentId;
|
|
131
|
+
return this.request('POST', '/api/v4/groups', body);
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Create a new project (repository).
|
|
135
|
+
*/
|
|
136
|
+
async createProject(name, opts) {
|
|
137
|
+
return this.request('POST', '/api/v4/projects', {
|
|
138
|
+
name,
|
|
139
|
+
path: opts?.path || name,
|
|
140
|
+
namespace_id: opts?.namespaceId,
|
|
141
|
+
visibility: opts?.visibility || 'private',
|
|
142
|
+
description: opts?.description || '',
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
// ---------------------------------------------------------------------------
|
|
92
146
|
// Projects
|
|
93
147
|
// ---------------------------------------------------------------------------
|
|
94
148
|
async getProjects(opts) {
|
|
@@ -189,4 +243,4 @@ export class GitLabClient {
|
|
|
189
243
|
await this.request('POST', `/api/v4/projects/${encodeURIComponent(projectId)}/pipelines/${pipelineId}/cancel`);
|
|
190
244
|
}
|
|
191
245
|
}
|
|
192
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.classes.gitlabclient.js","sourceRoot":"","sources":["../ts/gitlab.classes.gitlabclient.ts"],"names":[],"mappings":"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"}
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.classes.gitlabclient.js","sourceRoot":"","sources":["../ts/gitlab.classes.gitlabclient.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/readme.md
CHANGED
|
@@ -4,25 +4,291 @@ A TypeScript client for the GitLab API, providing easy access to projects, group
|
|
|
4
4
|
|
|
5
5
|
## Install
|
|
6
6
|
|
|
7
|
-
```
|
|
7
|
+
```bash
|
|
8
8
|
npm install @apiclient.xyz/gitlab
|
|
9
9
|
```
|
|
10
10
|
|
|
11
11
|
## Usage
|
|
12
12
|
|
|
13
|
+
All examples below use ESM imports and async/await.
|
|
14
|
+
|
|
15
|
+
### Creating a Client
|
|
16
|
+
|
|
13
17
|
```typescript
|
|
14
18
|
import { GitLabClient } from '@apiclient.xyz/gitlab';
|
|
15
19
|
|
|
16
|
-
const client = new GitLabClient('https://gitlab.com', 'your-private-token');
|
|
20
|
+
const client = new GitLabClient('https://gitlab.example.com', 'your-private-token');
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
The constructor accepts the base URL of your GitLab instance and a personal access token (or project/group token) used for authentication via the `PRIVATE-TOKEN` header.
|
|
24
|
+
|
|
25
|
+
### Testing the Connection
|
|
17
26
|
|
|
18
|
-
|
|
27
|
+
```typescript
|
|
19
28
|
const result = await client.testConnection();
|
|
20
29
|
|
|
21
|
-
|
|
30
|
+
if (result.ok) {
|
|
31
|
+
console.log('Connected successfully.');
|
|
32
|
+
} else {
|
|
33
|
+
console.error('Connection failed:', result.error);
|
|
34
|
+
}
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### Listing Projects
|
|
38
|
+
|
|
39
|
+
Retrieve projects you are a member of, ordered by most recently updated.
|
|
40
|
+
|
|
41
|
+
```typescript
|
|
42
|
+
// First page, default 50 per page
|
|
22
43
|
const projects = await client.getProjects();
|
|
23
44
|
|
|
24
|
-
//
|
|
25
|
-
await client.
|
|
45
|
+
// Search with pagination
|
|
46
|
+
const filtered = await client.getProjects({
|
|
47
|
+
search: 'my-service',
|
|
48
|
+
page: 1,
|
|
49
|
+
perPage: 20,
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
for (const project of filtered) {
|
|
53
|
+
console.log(`${project.id} - ${project.path_with_namespace}`);
|
|
54
|
+
}
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
### Listing Groups
|
|
58
|
+
|
|
59
|
+
```typescript
|
|
60
|
+
const groups = await client.getGroups();
|
|
61
|
+
|
|
62
|
+
// Search groups by name
|
|
63
|
+
const matchingGroups = await client.getGroups({ search: 'platform' });
|
|
64
|
+
|
|
65
|
+
for (const group of matchingGroups) {
|
|
66
|
+
console.log(`${group.id} - ${group.full_path}`);
|
|
67
|
+
}
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### Managing Project Variables
|
|
71
|
+
|
|
72
|
+
```typescript
|
|
73
|
+
const projectId = 42;
|
|
74
|
+
|
|
75
|
+
// List all variables
|
|
76
|
+
const vars = await client.getProjectVariables(projectId);
|
|
77
|
+
|
|
78
|
+
// Create a variable
|
|
79
|
+
await client.createProjectVariable(projectId, 'DATABASE_URL', 'postgres://...', {
|
|
80
|
+
protected: true,
|
|
81
|
+
masked: true,
|
|
82
|
+
environment_scope: 'production',
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
// Update a variable
|
|
86
|
+
await client.updateProjectVariable(projectId, 'DATABASE_URL', 'postgres://new-host/...', {
|
|
87
|
+
protected: true,
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
// Delete a variable
|
|
91
|
+
await client.deleteProjectVariable(projectId, 'DATABASE_URL');
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
### Managing Group Variables
|
|
95
|
+
|
|
96
|
+
The group variable API mirrors the project variable API.
|
|
97
|
+
|
|
98
|
+
```typescript
|
|
99
|
+
const groupId = 7;
|
|
100
|
+
|
|
101
|
+
// List all variables
|
|
102
|
+
const groupVars = await client.getGroupVariables(groupId);
|
|
103
|
+
|
|
104
|
+
// Create a variable
|
|
105
|
+
await client.createGroupVariable(groupId, 'NPM_TOKEN', 'tok-xxx', {
|
|
106
|
+
protected: false,
|
|
107
|
+
masked: true,
|
|
108
|
+
environment_scope: '*',
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
// Update a variable
|
|
112
|
+
await client.updateGroupVariable(groupId, 'NPM_TOKEN', 'tok-yyy', {
|
|
113
|
+
masked: true,
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
// Delete a variable
|
|
117
|
+
await client.deleteGroupVariable(groupId, 'NPM_TOKEN');
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
### Working with Pipelines
|
|
121
|
+
|
|
122
|
+
```typescript
|
|
123
|
+
const projectId = 42;
|
|
124
|
+
|
|
125
|
+
// List recent pipelines
|
|
126
|
+
const pipelines = await client.getPipelines(projectId, { page: 1, perPage: 10 });
|
|
127
|
+
|
|
128
|
+
for (const pipeline of pipelines) {
|
|
129
|
+
console.log(`Pipeline #${pipeline.id} [${pipeline.status}] on ${pipeline.ref}`);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// Get jobs for a specific pipeline
|
|
133
|
+
const jobs = await client.getPipelineJobs(projectId, pipelines[0].id);
|
|
134
|
+
for (const job of jobs) {
|
|
135
|
+
console.log(` Job "${job.name}" (${job.stage}): ${job.status}`);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
// Read the raw log output of a job
|
|
139
|
+
const log = await client.getJobLog(projectId, jobs[0].id);
|
|
140
|
+
console.log(log);
|
|
141
|
+
|
|
142
|
+
// Retry a failed pipeline
|
|
143
|
+
await client.retryPipeline(projectId, pipelines[0].id);
|
|
144
|
+
|
|
145
|
+
// Cancel a running pipeline
|
|
146
|
+
await client.cancelPipeline(projectId, pipelines[0].id);
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
## API Reference
|
|
150
|
+
|
|
151
|
+
### `GitLabClient`
|
|
152
|
+
|
|
153
|
+
| Method | Signature | Returns | Description |
|
|
154
|
+
|---|---|---|---|
|
|
155
|
+
| `constructor` | `(baseUrl: string, token: string)` | `GitLabClient` | Create a new client instance. |
|
|
156
|
+
| `testConnection` | `()` | `Promise<ITestConnectionResult>` | Verify the token and connectivity. |
|
|
157
|
+
| `getProjects` | `(opts?: IListOptions)` | `Promise<IGitLabProject[]>` | List projects you are a member of. |
|
|
158
|
+
| `getGroups` | `(opts?: IListOptions)` | `Promise<IGitLabGroup[]>` | List accessible groups. |
|
|
159
|
+
| `getProjectVariables` | `(projectId: number \| string)` | `Promise<IGitLabVariable[]>` | List all CI/CD variables for a project. |
|
|
160
|
+
| `createProjectVariable` | `(projectId: number \| string, key: string, value: string, opts?: IVariableOptions)` | `Promise<IGitLabVariable>` | Create a CI/CD variable on a project. |
|
|
161
|
+
| `updateProjectVariable` | `(projectId: number \| string, key: string, value: string, opts?: IVariableOptions)` | `Promise<IGitLabVariable>` | Update an existing project variable. |
|
|
162
|
+
| `deleteProjectVariable` | `(projectId: number \| string, key: string)` | `Promise<void>` | Delete a project variable. |
|
|
163
|
+
| `getGroupVariables` | `(groupId: number \| string)` | `Promise<IGitLabVariable[]>` | List all CI/CD variables for a group. |
|
|
164
|
+
| `createGroupVariable` | `(groupId: number \| string, key: string, value: string, opts?: IVariableOptions)` | `Promise<IGitLabVariable>` | Create a CI/CD variable on a group. |
|
|
165
|
+
| `updateGroupVariable` | `(groupId: number \| string, key: string, value: string, opts?: IVariableOptions)` | `Promise<IGitLabVariable>` | Update an existing group variable. |
|
|
166
|
+
| `deleteGroupVariable` | `(groupId: number \| string, key: string)` | `Promise<void>` | Delete a group variable. |
|
|
167
|
+
| `getPipelines` | `(projectId: number \| string, opts?: IListOptions)` | `Promise<IGitLabPipeline[]>` | List pipelines for a project, newest first. |
|
|
168
|
+
| `getPipelineJobs` | `(projectId: number \| string, pipelineId: number)` | `Promise<IGitLabJob[]>` | Get all jobs for a pipeline. |
|
|
169
|
+
| `getJobLog` | `(projectId: number \| string, jobId: number)` | `Promise<string>` | Retrieve the raw trace/log of a job. |
|
|
170
|
+
| `retryPipeline` | `(projectId: number \| string, pipelineId: number)` | `Promise<void>` | Retry all failed jobs in a pipeline. |
|
|
171
|
+
| `cancelPipeline` | `(projectId: number \| string, pipelineId: number)` | `Promise<void>` | Cancel a running pipeline. |
|
|
172
|
+
|
|
173
|
+
## Types
|
|
174
|
+
|
|
175
|
+
### `IListOptions`
|
|
176
|
+
|
|
177
|
+
Pagination and search options used by `getProjects`, `getGroups`, and `getPipelines`.
|
|
178
|
+
|
|
179
|
+
```typescript
|
|
180
|
+
interface IListOptions {
|
|
181
|
+
search?: string; // Filter results by keyword
|
|
182
|
+
page?: number; // Page number (default: 1)
|
|
183
|
+
perPage?: number; // Items per page (default: 50 for projects/groups, 30 for pipelines)
|
|
184
|
+
}
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
### `IVariableOptions`
|
|
188
|
+
|
|
189
|
+
Options when creating or updating CI/CD variables.
|
|
190
|
+
|
|
191
|
+
```typescript
|
|
192
|
+
interface IVariableOptions {
|
|
193
|
+
protected?: boolean; // Only expose to protected branches/tags (default: false)
|
|
194
|
+
masked?: boolean; // Mask the value in job logs (default: false)
|
|
195
|
+
environment_scope?: string; // Environment scope (default: '*' for all environments)
|
|
196
|
+
}
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
### `ITestConnectionResult`
|
|
200
|
+
|
|
201
|
+
```typescript
|
|
202
|
+
interface ITestConnectionResult {
|
|
203
|
+
ok: boolean;
|
|
204
|
+
error?: string; // Present when ok is false
|
|
205
|
+
}
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
### `IGitLabProject`
|
|
209
|
+
|
|
210
|
+
```typescript
|
|
211
|
+
interface IGitLabProject {
|
|
212
|
+
id: number;
|
|
213
|
+
name: string;
|
|
214
|
+
path_with_namespace: string;
|
|
215
|
+
description: string;
|
|
216
|
+
default_branch: string;
|
|
217
|
+
web_url: string;
|
|
218
|
+
visibility: string;
|
|
219
|
+
topics: string[];
|
|
220
|
+
last_activity_at: string;
|
|
221
|
+
}
|
|
222
|
+
```
|
|
223
|
+
|
|
224
|
+
### `IGitLabGroup`
|
|
225
|
+
|
|
226
|
+
```typescript
|
|
227
|
+
interface IGitLabGroup {
|
|
228
|
+
id: number;
|
|
229
|
+
name: string;
|
|
230
|
+
full_path: string;
|
|
231
|
+
description: string;
|
|
232
|
+
web_url: string;
|
|
233
|
+
visibility: string;
|
|
234
|
+
}
|
|
235
|
+
```
|
|
236
|
+
|
|
237
|
+
### `IGitLabVariable`
|
|
238
|
+
|
|
239
|
+
```typescript
|
|
240
|
+
interface IGitLabVariable {
|
|
241
|
+
key: string;
|
|
242
|
+
value: string;
|
|
243
|
+
variable_type: string;
|
|
244
|
+
protected: boolean;
|
|
245
|
+
masked: boolean;
|
|
246
|
+
environment_scope: string;
|
|
247
|
+
}
|
|
248
|
+
```
|
|
249
|
+
|
|
250
|
+
### `IGitLabPipeline`
|
|
251
|
+
|
|
252
|
+
```typescript
|
|
253
|
+
interface IGitLabPipeline {
|
|
254
|
+
id: number;
|
|
255
|
+
project_id: number;
|
|
256
|
+
status: string;
|
|
257
|
+
ref: string;
|
|
258
|
+
sha: string;
|
|
259
|
+
web_url: string;
|
|
260
|
+
duration: number;
|
|
261
|
+
created_at: string;
|
|
262
|
+
source: string;
|
|
263
|
+
}
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
### `IGitLabJob`
|
|
267
|
+
|
|
268
|
+
```typescript
|
|
269
|
+
interface IGitLabJob {
|
|
270
|
+
id: number;
|
|
271
|
+
name: string;
|
|
272
|
+
stage: string;
|
|
273
|
+
status: string;
|
|
274
|
+
duration: number;
|
|
275
|
+
}
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
### `IGitLabUser`
|
|
279
|
+
|
|
280
|
+
Returned internally by `testConnection` to verify credentials.
|
|
281
|
+
|
|
282
|
+
```typescript
|
|
283
|
+
interface IGitLabUser {
|
|
284
|
+
id: number;
|
|
285
|
+
username: string;
|
|
286
|
+
name: string;
|
|
287
|
+
email: string;
|
|
288
|
+
avatar_url: string;
|
|
289
|
+
web_url: string;
|
|
290
|
+
state: string;
|
|
291
|
+
}
|
|
26
292
|
```
|
|
27
293
|
|
|
28
294
|
## License
|
package/ts/00_commitinfo_data.ts
CHANGED
|
@@ -125,6 +125,73 @@ export class GitLabClient {
|
|
|
125
125
|
}
|
|
126
126
|
}
|
|
127
127
|
|
|
128
|
+
// ---------------------------------------------------------------------------
|
|
129
|
+
// Groups — scoped queries
|
|
130
|
+
// ---------------------------------------------------------------------------
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Get a single group by its full path (e.g. "foss.global" or "foss.global/push.rocks")
|
|
134
|
+
*/
|
|
135
|
+
public async getGroupByPath(fullPath: string): Promise<IGitLabGroup> {
|
|
136
|
+
return this.request<IGitLabGroup>(
|
|
137
|
+
'GET',
|
|
138
|
+
`/api/v4/groups/${encodeURIComponent(fullPath)}`,
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* List projects within a group (includes subgroups when include_subgroups=true)
|
|
144
|
+
*/
|
|
145
|
+
public async getGroupProjects(groupId: number | string, opts?: IListOptions): Promise<IGitLabProject[]> {
|
|
146
|
+
const page = opts?.page || 1;
|
|
147
|
+
const perPage = opts?.perPage || 50;
|
|
148
|
+
let url = `/api/v4/groups/${encodeURIComponent(groupId)}/projects?include_subgroups=true&order_by=updated_at&sort=desc&page=${page}&per_page=${perPage}`;
|
|
149
|
+
if (opts?.search) {
|
|
150
|
+
url += `&search=${encodeURIComponent(opts.search)}`;
|
|
151
|
+
}
|
|
152
|
+
return this.request<IGitLabProject[]>('GET', url);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
* List all descendant groups (recursive subgroups) within a group
|
|
157
|
+
*/
|
|
158
|
+
public async getDescendantGroups(groupId: number | string, opts?: IListOptions): Promise<IGitLabGroup[]> {
|
|
159
|
+
const page = opts?.page || 1;
|
|
160
|
+
const perPage = opts?.perPage || 50;
|
|
161
|
+
let url = `/api/v4/groups/${encodeURIComponent(groupId)}/descendant_groups?order_by=name&sort=asc&page=${page}&per_page=${perPage}`;
|
|
162
|
+
if (opts?.search) {
|
|
163
|
+
url += `&search=${encodeURIComponent(opts.search)}`;
|
|
164
|
+
}
|
|
165
|
+
return this.request<IGitLabGroup[]>('GET', url);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Create a new group. Optionally nested under a parent group.
|
|
170
|
+
*/
|
|
171
|
+
public async createGroup(name: string, path: string, parentId?: number): Promise<IGitLabGroup> {
|
|
172
|
+
const body: any = { name, path, visibility: 'private' };
|
|
173
|
+
if (parentId) body.parent_id = parentId;
|
|
174
|
+
return this.request<IGitLabGroup>('POST', '/api/v4/groups', body);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* Create a new project (repository).
|
|
179
|
+
*/
|
|
180
|
+
public async createProject(name: string, opts?: {
|
|
181
|
+
path?: string;
|
|
182
|
+
namespaceId?: number;
|
|
183
|
+
visibility?: string;
|
|
184
|
+
description?: string;
|
|
185
|
+
}): Promise<IGitLabProject> {
|
|
186
|
+
return this.request<IGitLabProject>('POST', '/api/v4/projects', {
|
|
187
|
+
name,
|
|
188
|
+
path: opts?.path || name,
|
|
189
|
+
namespace_id: opts?.namespaceId,
|
|
190
|
+
visibility: opts?.visibility || 'private',
|
|
191
|
+
description: opts?.description || '',
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
|
|
128
195
|
// ---------------------------------------------------------------------------
|
|
129
196
|
// Projects
|
|
130
197
|
// ---------------------------------------------------------------------------
|