@opentabs-dev/opentabs-plugin-github 0.0.76 → 0.0.78
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 +75 -129
- package/dist/adapter.iife.js +1149 -663
- package/dist/adapter.iife.js.map +4 -4
- package/dist/github-api.d.ts +16 -10
- package/dist/github-api.d.ts.map +1 -1
- package/dist/github-api.js +314 -112
- package/dist/github-api.js.map +1 -1
- package/dist/tools/add-reaction.d.ts +5 -9
- package/dist/tools/add-reaction.d.ts.map +1 -1
- package/dist/tools/add-reaction.js +29 -31
- package/dist/tools/add-reaction.js.map +1 -1
- package/dist/tools/compare-commits.d.ts +2 -8
- package/dist/tools/compare-commits.d.ts.map +1 -1
- package/dist/tools/compare-commits.js +32 -34
- package/dist/tools/compare-commits.js.map +1 -1
- package/dist/tools/create-comment.d.ts +1 -8
- package/dist/tools/create-comment.d.ts.map +1 -1
- package/dist/tools/create-comment.js +21 -5
- package/dist/tools/create-comment.js.map +1 -1
- package/dist/tools/create-issue.d.ts +0 -2
- package/dist/tools/create-issue.d.ts.map +1 -1
- package/dist/tools/create-issue.js +32 -15
- package/dist/tools/create-issue.js.map +1 -1
- package/dist/tools/create-label.d.ts.map +1 -1
- package/dist/tools/create-label.js +20 -12
- package/dist/tools/create-label.js.map +1 -1
- package/dist/tools/create-or-update-file.d.ts +1 -4
- package/dist/tools/create-or-update-file.d.ts.map +1 -1
- package/dist/tools/create-or-update-file.js +23 -23
- package/dist/tools/create-or-update-file.js.map +1 -1
- package/dist/tools/create-pull-request.d.ts.map +1 -1
- package/dist/tools/create-pull-request.js +37 -16
- package/dist/tools/create-pull-request.js.map +1 -1
- package/dist/tools/create-release.d.ts.map +1 -1
- package/dist/tools/create-release.js +29 -19
- package/dist/tools/create-release.js.map +1 -1
- package/dist/tools/create-repo.d.ts.map +1 -1
- package/dist/tools/create-repo.js +33 -18
- package/dist/tools/create-repo.js.map +1 -1
- package/dist/tools/delete-file.d.ts +1 -6
- package/dist/tools/delete-file.d.ts.map +1 -1
- package/dist/tools/delete-file.js +8 -25
- package/dist/tools/delete-file.js.map +1 -1
- package/dist/tools/get-file-content.d.ts.map +1 -1
- package/dist/tools/get-file-content.js +5 -9
- package/dist/tools/get-file-content.js.map +1 -1
- package/dist/tools/get-issue.d.ts.map +1 -1
- package/dist/tools/get-issue.js +25 -4
- package/dist/tools/get-issue.js.map +1 -1
- package/dist/tools/get-pull-request-diff.d.ts.map +1 -1
- package/dist/tools/get-pull-request-diff.js +19 -5
- package/dist/tools/get-pull-request-diff.js.map +1 -1
- package/dist/tools/get-pull-request.d.ts.map +1 -1
- package/dist/tools/get-pull-request.js +32 -3
- package/dist/tools/get-pull-request.js.map +1 -1
- package/dist/tools/get-repo.d.ts.map +1 -1
- package/dist/tools/get-repo.js +21 -4
- package/dist/tools/get-repo.js.map +1 -1
- package/dist/tools/get-user-profile.d.ts.map +1 -1
- package/dist/tools/get-user-profile.js +15 -2
- package/dist/tools/get-user-profile.js.map +1 -1
- package/dist/tools/get-workflow-run.d.ts.map +1 -1
- package/dist/tools/get-workflow-run.js +28 -5
- package/dist/tools/get-workflow-run.js.map +1 -1
- package/dist/tools/list-branches.d.ts +0 -2
- package/dist/tools/list-branches.d.ts.map +1 -1
- package/dist/tools/list-branches.js +3 -9
- package/dist/tools/list-branches.js.map +1 -1
- package/dist/tools/list-comments.d.ts +0 -2
- package/dist/tools/list-comments.d.ts.map +1 -1
- package/dist/tools/list-comments.js +33 -10
- package/dist/tools/list-comments.js.map +1 -1
- package/dist/tools/list-commits.d.ts +0 -2
- package/dist/tools/list-commits.d.ts.map +1 -1
- package/dist/tools/list-commits.js +8 -13
- package/dist/tools/list-commits.js.map +1 -1
- package/dist/tools/list-issues.d.ts +2 -2
- package/dist/tools/list-issues.d.ts.map +1 -1
- package/dist/tools/list-issues.js +43 -16
- package/dist/tools/list-issues.js.map +1 -1
- package/dist/tools/list-labels.d.ts +0 -2
- package/dist/tools/list-labels.d.ts.map +1 -1
- package/dist/tools/list-labels.js +18 -10
- package/dist/tools/list-labels.js.map +1 -1
- package/dist/tools/list-notifications.d.ts +1 -6
- package/dist/tools/list-notifications.d.ts.map +1 -1
- package/dist/tools/list-notifications.js +30 -23
- package/dist/tools/list-notifications.js.map +1 -1
- package/dist/tools/list-org-members.d.ts +0 -3
- package/dist/tools/list-org-members.d.ts.map +1 -1
- package/dist/tools/list-org-members.js +24 -18
- package/dist/tools/list-org-members.js.map +1 -1
- package/dist/tools/list-pull-request-files.d.ts +0 -3
- package/dist/tools/list-pull-request-files.d.ts.map +1 -1
- package/dist/tools/list-pull-request-files.js +6 -28
- package/dist/tools/list-pull-request-files.js.map +1 -1
- package/dist/tools/list-pull-requests.d.ts +2 -4
- package/dist/tools/list-pull-requests.d.ts.map +1 -1
- package/dist/tools/list-pull-requests.js +34 -18
- package/dist/tools/list-pull-requests.js.map +1 -1
- package/dist/tools/list-releases.d.ts +0 -2
- package/dist/tools/list-releases.d.ts.map +1 -1
- package/dist/tools/list-releases.js +37 -10
- package/dist/tools/list-releases.js.map +1 -1
- package/dist/tools/list-repos.d.ts +0 -7
- package/dist/tools/list-repos.d.ts.map +1 -1
- package/dist/tools/list-repos.js +18 -23
- package/dist/tools/list-repos.js.map +1 -1
- package/dist/tools/list-workflow-runs.d.ts +0 -21
- package/dist/tools/list-workflow-runs.d.ts.map +1 -1
- package/dist/tools/list-workflow-runs.js +32 -43
- package/dist/tools/list-workflow-runs.js.map +1 -1
- package/dist/tools/merge-pull-request.d.ts +1 -3
- package/dist/tools/merge-pull-request.d.ts.map +1 -1
- package/dist/tools/merge-pull-request.js +11 -15
- package/dist/tools/merge-pull-request.js.map +1 -1
- package/dist/tools/request-pull-request-review.d.ts +1 -21
- package/dist/tools/request-pull-request-review.d.ts.map +1 -1
- package/dist/tools/request-pull-request-review.js +17 -10
- package/dist/tools/request-pull-request-review.js.map +1 -1
- package/dist/tools/schemas.d.ts +130 -38
- package/dist/tools/schemas.d.ts.map +1 -1
- package/dist/tools/schemas.js +140 -52
- package/dist/tools/schemas.js.map +1 -1
- package/dist/tools/search-issues.d.ts +0 -13
- package/dist/tools/search-issues.d.ts.map +1 -1
- package/dist/tools/search-issues.js +23 -17
- package/dist/tools/search-issues.js.map +1 -1
- package/dist/tools/search-repos.d.ts +0 -10
- package/dist/tools/search-repos.d.ts.map +1 -1
- package/dist/tools/search-repos.js +7 -12
- package/dist/tools/search-repos.js.map +1 -1
- package/dist/tools/update-issue.d.ts +2 -18
- package/dist/tools/update-issue.d.ts.map +1 -1
- package/dist/tools/update-issue.js +19 -16
- package/dist/tools/update-issue.js.map +1 -1
- package/dist/tools/update-pull-request.d.ts +2 -24
- package/dist/tools/update-pull-request.d.ts.map +1 -1
- package/dist/tools/update-pull-request.js +28 -20
- package/dist/tools/update-pull-request.js.map +1 -1
- package/dist/tools.json +70 -747
- package/package.json +10 -4
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { submitPageForm } from '../github-api.js';
|
|
4
|
+
import { pullRequestSchema } from './schemas.js';
|
|
5
5
|
export const createPullRequest = defineTool({
|
|
6
6
|
name: 'create_pull_request',
|
|
7
7
|
displayName: 'Create Pull Request',
|
|
@@ -13,7 +13,7 @@ export const createPullRequest = defineTool({
|
|
|
13
13
|
owner: z.string().min(1).describe('Repository owner (user or org)'),
|
|
14
14
|
repo: z.string().min(1).describe('Repository name'),
|
|
15
15
|
title: z.string().min(1).describe('Pull request title'),
|
|
16
|
-
head: z.string().min(1).describe('Source branch name
|
|
16
|
+
head: z.string().min(1).describe('Source branch name'),
|
|
17
17
|
base: z.string().min(1).describe('Target branch name to merge into'),
|
|
18
18
|
body: z.string().optional().describe('Pull request description in Markdown'),
|
|
19
19
|
draft: z.boolean().optional().describe('Create as a draft PR (default: false)'),
|
|
@@ -22,20 +22,41 @@ export const createPullRequest = defineTool({
|
|
|
22
22
|
pull_request: pullRequestSchema.describe('The created pull request'),
|
|
23
23
|
}),
|
|
24
24
|
handle: async (params) => {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
25
|
+
// GitHub's compare page has a form for creating PRs.
|
|
26
|
+
// POST to /:owner/:repo/compare with the head and base branches.
|
|
27
|
+
const fields = {
|
|
28
|
+
'pull_request[title]': params.title,
|
|
29
|
+
'pull_request[head]': params.head,
|
|
30
|
+
'pull_request[base]': params.base,
|
|
31
|
+
};
|
|
32
|
+
if (params.body)
|
|
33
|
+
fields['pull_request[body]'] = params.body;
|
|
34
|
+
if (params.draft)
|
|
35
|
+
fields['pull_request[draft]'] = '1';
|
|
36
|
+
await submitPageForm(`/${params.owner}/${params.repo}/compare/${params.base}...${params.head}`, 'form#new_pull_request, form[action*="pull"]', fields);
|
|
37
|
+
return {
|
|
38
|
+
pull_request: {
|
|
39
|
+
number: 0,
|
|
40
|
+
title: params.title,
|
|
41
|
+
state: 'open',
|
|
42
|
+
body: params.body ?? '',
|
|
43
|
+
html_url: `https://github.com/${params.owner}/${params.repo}/pulls`,
|
|
44
|
+
user_login: '',
|
|
45
|
+
head_ref: params.head,
|
|
46
|
+
base_ref: params.base,
|
|
47
|
+
labels: [],
|
|
48
|
+
draft: params.draft ?? false,
|
|
49
|
+
merged: false,
|
|
50
|
+
mergeable: false,
|
|
51
|
+
comments: 0,
|
|
52
|
+
commits: 0,
|
|
53
|
+
additions: 0,
|
|
54
|
+
deletions: 0,
|
|
55
|
+
changed_files: 0,
|
|
56
|
+
created_at: new Date().toISOString(),
|
|
57
|
+
updated_at: new Date().toISOString(),
|
|
58
|
+
},
|
|
29
59
|
};
|
|
30
|
-
if (params.body !== undefined)
|
|
31
|
-
body.body = params.body;
|
|
32
|
-
if (params.draft !== undefined)
|
|
33
|
-
body.draft = params.draft;
|
|
34
|
-
const data = await api(`/repos/${params.owner}/${params.repo}/pulls`, {
|
|
35
|
-
method: 'POST',
|
|
36
|
-
body,
|
|
37
|
-
});
|
|
38
|
-
return { pull_request: mapPullRequest(data) };
|
|
39
60
|
},
|
|
40
61
|
});
|
|
41
62
|
//# sourceMappingURL=create-pull-request.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-pull-request.js","sourceRoot":"","sources":["../../src/tools/create-pull-request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"create-pull-request.js","sourceRoot":"","sources":["../../src/tools/create-pull-request.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-release.d.ts","sourceRoot":"","sources":["../../src/tools/create-release.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAIxB,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"create-release.d.ts","sourceRoot":"","sources":["../../src/tools/create-release.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAIxB,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;kBA+CxB,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { submitPageForm } from '../github-api.js';
|
|
4
|
+
import { releaseSchema } from './schemas.js';
|
|
5
5
|
export const createRelease = defineTool({
|
|
6
6
|
name: 'create_release',
|
|
7
7
|
displayName: 'Create Release',
|
|
@@ -23,24 +23,34 @@ export const createRelease = defineTool({
|
|
|
23
23
|
release: releaseSchema.describe('The created release'),
|
|
24
24
|
}),
|
|
25
25
|
handle: async (params) => {
|
|
26
|
-
const
|
|
27
|
-
tag_name: params.tag_name,
|
|
26
|
+
const fields = {
|
|
27
|
+
'release[tag_name]': params.tag_name,
|
|
28
|
+
};
|
|
29
|
+
if (params.name)
|
|
30
|
+
fields['release[name]'] = params.name;
|
|
31
|
+
if (params.body)
|
|
32
|
+
fields['release[body]'] = params.body;
|
|
33
|
+
if (params.draft)
|
|
34
|
+
fields['release[draft]'] = '1';
|
|
35
|
+
if (params.prerelease)
|
|
36
|
+
fields['release[prerelease]'] = '1';
|
|
37
|
+
if (params.target_commitish)
|
|
38
|
+
fields['release[target_commitish]'] = params.target_commitish;
|
|
39
|
+
await submitPageForm(`/${params.owner}/${params.repo}/releases/new`, 'form[action*="releases"]', fields);
|
|
40
|
+
return {
|
|
41
|
+
release: {
|
|
42
|
+
id: 0,
|
|
43
|
+
tag_name: params.tag_name,
|
|
44
|
+
name: params.name ?? params.tag_name,
|
|
45
|
+
body: params.body ?? '',
|
|
46
|
+
draft: params.draft ?? false,
|
|
47
|
+
prerelease: params.prerelease ?? false,
|
|
48
|
+
created_at: new Date().toISOString(),
|
|
49
|
+
published_at: params.draft ? '' : new Date().toISOString(),
|
|
50
|
+
html_url: `https://github.com/${params.owner}/${params.repo}/releases/tag/${params.tag_name}`,
|
|
51
|
+
author_login: '',
|
|
52
|
+
},
|
|
28
53
|
};
|
|
29
|
-
if (params.name !== undefined)
|
|
30
|
-
body.name = params.name;
|
|
31
|
-
if (params.body !== undefined)
|
|
32
|
-
body.body = params.body;
|
|
33
|
-
if (params.draft !== undefined)
|
|
34
|
-
body.draft = params.draft;
|
|
35
|
-
if (params.prerelease !== undefined)
|
|
36
|
-
body.prerelease = params.prerelease;
|
|
37
|
-
if (params.target_commitish !== undefined)
|
|
38
|
-
body.target_commitish = params.target_commitish;
|
|
39
|
-
const data = await api(`/repos/${params.owner}/${params.repo}/releases`, {
|
|
40
|
-
method: 'POST',
|
|
41
|
-
body,
|
|
42
|
-
});
|
|
43
|
-
return { release: mapRelease(data) };
|
|
44
54
|
},
|
|
45
55
|
});
|
|
46
56
|
//# sourceMappingURL=create-release.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-release.js","sourceRoot":"","sources":["../../src/tools/create-release.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"create-release.js","sourceRoot":"","sources":["../../src/tools/create-release.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-repo.d.ts","sourceRoot":"","sources":["../../src/tools/create-repo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAIxB,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"create-repo.d.ts","sourceRoot":"","sources":["../../src/tools/create-repo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAIxB,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;kBAgDrB,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { submitPageForm } from '../github-api.js';
|
|
4
|
+
import { repositorySchema } from './schemas.js';
|
|
5
5
|
export const createRepo = defineTool({
|
|
6
6
|
name: 'create_repo',
|
|
7
7
|
displayName: 'Create Repository',
|
|
@@ -21,22 +21,37 @@ export const createRepo = defineTool({
|
|
|
21
21
|
repository: repositorySchema.describe('The created repository'),
|
|
22
22
|
}),
|
|
23
23
|
handle: async (params) => {
|
|
24
|
-
const
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
if (params.
|
|
28
|
-
|
|
29
|
-
if (params.
|
|
30
|
-
|
|
31
|
-
if (params.
|
|
32
|
-
|
|
33
|
-
if (params.
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
24
|
+
const fields = {
|
|
25
|
+
'repository[name]': params.name,
|
|
26
|
+
};
|
|
27
|
+
if (params.description)
|
|
28
|
+
fields['repository[description]'] = params.description;
|
|
29
|
+
if (params.private)
|
|
30
|
+
fields['repository[visibility]'] = 'private';
|
|
31
|
+
if (params.auto_init)
|
|
32
|
+
fields['repository[auto_init]'] = '1';
|
|
33
|
+
if (params.gitignore_template)
|
|
34
|
+
fields['repository[gitignore_template]'] = params.gitignore_template;
|
|
35
|
+
if (params.license_template)
|
|
36
|
+
fields['repository[license_template]'] = params.license_template;
|
|
37
|
+
await submitPageForm('/new', 'form[action="/repositories"]', fields);
|
|
38
|
+
return {
|
|
39
|
+
repository: {
|
|
40
|
+
id: 0,
|
|
41
|
+
name: params.name,
|
|
42
|
+
full_name: params.name,
|
|
43
|
+
description: params.description ?? '',
|
|
44
|
+
private: params.private ?? false,
|
|
45
|
+
html_url: `https://github.com/${params.name}`,
|
|
46
|
+
default_branch: 'main',
|
|
47
|
+
language: '',
|
|
48
|
+
stargazers_count: 0,
|
|
49
|
+
forks_count: 0,
|
|
50
|
+
open_issues_count: 0,
|
|
51
|
+
archived: false,
|
|
52
|
+
updated_at: new Date().toISOString(),
|
|
53
|
+
},
|
|
54
|
+
};
|
|
40
55
|
},
|
|
41
56
|
});
|
|
42
57
|
//# sourceMappingURL=create-repo.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-repo.js","sourceRoot":"","sources":["../../src/tools/create-repo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"create-repo.js","sourceRoot":"","sources":["../../src/tools/create-repo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEhD,MAAM,CAAC,MAAM,UAAU,GAAG,UAAU,CAAC;IACnC,IAAI,EAAE,aAAa;IACnB,WAAW,EAAE,mBAAmB;IAChC,WAAW,EAAE,qDAAqD;IAClE,OAAO,EAAE,yBAAyB;IAClC,IAAI,EAAE,aAAa;IACnB,KAAK,EAAE,cAAc;IACrB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,qCAAqC,CAAC;QAClF,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,oDAAoD,CAAC;QAC9F,SAAS,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,2CAA2C,CAAC;QACvF,kBAAkB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kDAAkD,CAAC;QACtG,gBAAgB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,8CAA8C,CAAC;KACjG,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,UAAU,EAAE,gBAAgB,CAAC,QAAQ,CAAC,wBAAwB,CAAC;KAChE,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,MAAM,MAAM,GAA2B;YACrC,kBAAkB,EAAE,MAAM,CAAC,IAAI;SAChC,CAAC;QACF,IAAI,MAAM,CAAC,WAAW;YAAE,MAAM,CAAC,yBAAyB,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;QAC/E,IAAI,MAAM,CAAC,OAAO;YAAE,MAAM,CAAC,wBAAwB,CAAC,GAAG,SAAS,CAAC;QACjE,IAAI,MAAM,CAAC,SAAS;YAAE,MAAM,CAAC,uBAAuB,CAAC,GAAG,GAAG,CAAC;QAC5D,IAAI,MAAM,CAAC,kBAAkB;YAAE,MAAM,CAAC,gCAAgC,CAAC,GAAG,MAAM,CAAC,kBAAkB,CAAC;QACpG,IAAI,MAAM,CAAC,gBAAgB;YAAE,MAAM,CAAC,8BAA8B,CAAC,GAAG,MAAM,CAAC,gBAAgB,CAAC;QAE9F,MAAM,cAAc,CAAC,MAAM,EAAE,8BAA8B,EAAE,MAAM,CAAC,CAAC;QAErE,OAAO;YACL,UAAU,EAAE;gBACV,EAAE,EAAE,CAAC;gBACL,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,SAAS,EAAE,MAAM,CAAC,IAAI;gBACtB,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,EAAE;gBACrC,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK;gBAChC,QAAQ,EAAE,sBAAsB,MAAM,CAAC,IAAI,EAAE;gBAC7C,cAAc,EAAE,MAAM;gBACtB,QAAQ,EAAE,EAAE;gBACZ,gBAAgB,EAAE,CAAC;gBACnB,WAAW,EAAE,CAAC;gBACd,iBAAiB,EAAE,CAAC;gBACpB,QAAQ,EAAE,KAAK;gBACf,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACrC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -4,13 +4,8 @@ export declare const deleteFile: import("@opentabs-dev/plugin-sdk").ToolDefiniti
|
|
|
4
4
|
repo: z.ZodString;
|
|
5
5
|
path: z.ZodString;
|
|
6
6
|
message: z.ZodString;
|
|
7
|
-
sha: z.ZodString;
|
|
8
7
|
branch: z.ZodOptional<z.ZodString>;
|
|
9
8
|
}, z.core.$strip>, z.ZodObject<{
|
|
10
|
-
|
|
11
|
-
sha: z.ZodString;
|
|
12
|
-
message: z.ZodString;
|
|
13
|
-
url: z.ZodString;
|
|
14
|
-
}, z.core.$strip>;
|
|
9
|
+
success: z.ZodBoolean;
|
|
15
10
|
}, z.core.$strip>>;
|
|
16
11
|
//# sourceMappingURL=delete-file.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-file.d.ts","sourceRoot":"","sources":["../../src/tools/delete-file.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"delete-file.d.ts","sourceRoot":"","sources":["../../src/tools/delete-file.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,eAAO,MAAM,UAAU;;;;;;;;kBA4BrB,CAAC"}
|
|
@@ -1,15 +1,10 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
const deleteCommitSchema = z.object({
|
|
5
|
-
sha: z.string().describe('Commit SHA'),
|
|
6
|
-
message: z.string().describe('Commit message'),
|
|
7
|
-
url: z.string().describe('URL to the commit on GitHub'),
|
|
8
|
-
});
|
|
3
|
+
import { submitPageForm } from '../github-api.js';
|
|
9
4
|
export const deleteFile = defineTool({
|
|
10
5
|
name: 'delete_file',
|
|
11
6
|
displayName: 'Delete File',
|
|
12
|
-
description: 'Delete a file from a repository.
|
|
7
|
+
description: 'Delete a file from a repository. Commits directly to the specified branch.',
|
|
13
8
|
summary: 'Delete a file from a repository',
|
|
14
9
|
icon: 'file-x',
|
|
15
10
|
group: 'Repositories',
|
|
@@ -18,31 +13,19 @@ export const deleteFile = defineTool({
|
|
|
18
13
|
repo: z.string().min(1).describe('Repository name'),
|
|
19
14
|
path: z.string().min(1).describe('File path relative to repository root'),
|
|
20
15
|
message: z.string().min(1).describe('Commit message for the deletion'),
|
|
21
|
-
sha: z.string().min(1).describe('SHA of the file being deleted — required to prevent accidental overwrites'),
|
|
22
16
|
branch: z.string().optional().describe('Branch to commit to (defaults to the default branch)'),
|
|
23
17
|
}),
|
|
24
18
|
output: z.object({
|
|
25
|
-
|
|
19
|
+
success: z.boolean().describe('Whether the file was deleted'),
|
|
26
20
|
}),
|
|
27
21
|
handle: async (params) => {
|
|
28
|
-
const
|
|
22
|
+
const branch = params.branch ?? 'main';
|
|
23
|
+
await submitPageForm(`/${params.owner}/${params.repo}/delete/${branch}/${params.path}`, 'form[action*="delete"]', {
|
|
29
24
|
message: params.message,
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
if (params.branch !== undefined)
|
|
33
|
-
body.branch = params.branch;
|
|
34
|
-
const encodedPath = params.path.split('/').map(encodeURIComponent).join('/');
|
|
35
|
-
const data = await api(`/repos/${params.owner}/${params.repo}/contents/${encodedPath}`, {
|
|
36
|
-
method: 'DELETE',
|
|
37
|
-
body,
|
|
25
|
+
commit_choice: 'direct',
|
|
26
|
+
target_branch: branch,
|
|
38
27
|
});
|
|
39
|
-
return {
|
|
40
|
-
commit: {
|
|
41
|
-
sha: data.commit?.sha ?? '',
|
|
42
|
-
message: data.commit?.message ?? '',
|
|
43
|
-
url: data.commit?.html_url ?? '',
|
|
44
|
-
},
|
|
45
|
-
};
|
|
28
|
+
return { success: true };
|
|
46
29
|
},
|
|
47
30
|
});
|
|
48
31
|
//# sourceMappingURL=delete-file.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-file.js","sourceRoot":"","sources":["../../src/tools/delete-file.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"delete-file.js","sourceRoot":"","sources":["../../src/tools/delete-file.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,MAAM,CAAC,MAAM,UAAU,GAAG,UAAU,CAAC;IACnC,IAAI,EAAE,aAAa;IACnB,WAAW,EAAE,aAAa;IAC1B,WAAW,EAAE,4EAA4E;IACzF,OAAO,EAAE,iCAAiC;IAC1C,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,cAAc;IACrB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACnE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,uCAAuC,CAAC;QACzE,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iCAAiC,CAAC;QACtE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,sDAAsD,CAAC;KAC/F,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,8BAA8B,CAAC;KAC9D,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC;QAEvC,MAAM,cAAc,CAAC,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,WAAW,MAAM,IAAI,MAAM,CAAC,IAAI,EAAE,EAAE,wBAAwB,EAAE;YAChH,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,aAAa,EAAE,QAAQ;YACvB,aAAa,EAAE,MAAM;SACtB,CAAC,CAAC;QAEH,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-file-content.d.ts","sourceRoot":"","sources":["../../src/tools/get-file-content.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"get-file-content.d.ts","sourceRoot":"","sources":["../../src/tools/get-file-content.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AASxB,eAAO,MAAM,cAAc;;;;;;;;kBA0BzB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
3
|
+
import { pageEmbeddedData } from '../github-api.js';
|
|
4
4
|
export const getFileContent = defineTool({
|
|
5
5
|
name: 'get_file_content',
|
|
6
6
|
displayName: 'Get File Content',
|
|
@@ -19,14 +19,10 @@ export const getFileContent = defineTool({
|
|
|
19
19
|
path: z.string().describe('File path'),
|
|
20
20
|
}),
|
|
21
21
|
handle: async (params) => {
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const
|
|
26
|
-
const content = await apiRaw(`/repos/${params.owner}/${params.repo}/contents/${encodedPath}`, {
|
|
27
|
-
query,
|
|
28
|
-
accept: 'application/vnd.github.raw+json',
|
|
29
|
-
});
|
|
22
|
+
const ref = params.ref ?? 'HEAD';
|
|
23
|
+
const data = await pageEmbeddedData(`/${params.owner}/${params.repo}/blob/${ref}/${params.path}`);
|
|
24
|
+
const rawLines = data['codeViewBlobLayoutRoute.StyledBlob']?.rawLines;
|
|
25
|
+
const content = rawLines ? rawLines.join('\n') : '';
|
|
30
26
|
return { content, path: params.path };
|
|
31
27
|
},
|
|
32
28
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-file-content.js","sourceRoot":"","sources":["../../src/tools/get-file-content.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"get-file-content.js","sourceRoot":"","sources":["../../src/tools/get-file-content.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAQpD,MAAM,CAAC,MAAM,cAAc,GAAG,UAAU,CAAC;IACvC,IAAI,EAAE,kBAAkB;IACxB,WAAW,EAAE,kBAAkB;IAC/B,WAAW,EACT,iIAAiI;IACnI,OAAO,EAAE,+BAA+B;IACxC,IAAI,EAAE,WAAW;IACjB,KAAK,EAAE,cAAc;IACrB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACnE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,8DAA8D,CAAC;QAChG,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,kEAAkE,CAAC;KACxG,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,0BAA0B,CAAC;QACxD,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC;KACvC,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,IAAI,MAAM,CAAC;QACjC,MAAM,IAAI,GAAG,MAAM,gBAAgB,CAAe,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,SAAS,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;QAEhH,MAAM,QAAQ,GAAG,IAAI,CAAC,oCAAoC,CAAC,EAAE,QAAQ,CAAC;QACtE,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;IACxC,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-issue.d.ts","sourceRoot":"","sources":["../../src/tools/get-issue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"get-issue.d.ts","sourceRoot":"","sources":["../../src/tools/get-issue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAsBxB,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;kBA0CnB,CAAC"}
|
package/dist/tools/get-issue.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
import { issueSchema
|
|
3
|
+
import { turboData } from '../github-api.js';
|
|
4
|
+
import { issueSchema } from './schemas.js';
|
|
5
5
|
export const getIssue = defineTool({
|
|
6
6
|
name: 'get_issue',
|
|
7
7
|
displayName: 'Get Issue',
|
|
@@ -18,8 +18,29 @@ export const getIssue = defineTool({
|
|
|
18
18
|
issue: issueSchema.describe('Issue details'),
|
|
19
19
|
}),
|
|
20
20
|
handle: async (params) => {
|
|
21
|
-
const
|
|
22
|
-
|
|
21
|
+
const result = await turboData(`/${params.owner}/${params.repo}/issues/${params.issue_number}`);
|
|
22
|
+
const issue = result.data?.repository?.issue;
|
|
23
|
+
const labels = (issue?.labels?.edges ?? []).map(e => e.node?.name ?? '').filter(Boolean);
|
|
24
|
+
const assignees = (issue?.assignedActors?.nodes ?? []).map(a => a.login ?? '').filter(Boolean);
|
|
25
|
+
const state = issue?.state?.toLowerCase() ?? '';
|
|
26
|
+
const isPR = false; // This is specifically the issues endpoint
|
|
27
|
+
return {
|
|
28
|
+
issue: {
|
|
29
|
+
number: issue?.number ?? params.issue_number,
|
|
30
|
+
title: issue?.title ?? '',
|
|
31
|
+
state,
|
|
32
|
+
body: issue?.body ?? '',
|
|
33
|
+
html_url: `https://github.com/${params.owner}/${params.repo}/issues/${params.issue_number}`,
|
|
34
|
+
user_login: issue?.author?.login ?? '',
|
|
35
|
+
labels,
|
|
36
|
+
assignees,
|
|
37
|
+
comments: 0, // Not available in this query
|
|
38
|
+
created_at: issue?.createdAt ?? '',
|
|
39
|
+
updated_at: issue?.updatedAt ?? '',
|
|
40
|
+
closed_at: issue?.closedAt ?? '',
|
|
41
|
+
is_pull_request: isPR,
|
|
42
|
+
},
|
|
43
|
+
};
|
|
23
44
|
},
|
|
24
45
|
});
|
|
25
46
|
//# sourceMappingURL=get-issue.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-issue.js","sourceRoot":"","sources":["../../src/tools/get-issue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"get-issue.js","sourceRoot":"","sources":["../../src/tools/get-issue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAoB3C,MAAM,CAAC,MAAM,QAAQ,GAAG,UAAU,CAAC;IACjC,IAAI,EAAE,WAAW;IACjB,WAAW,EAAE,WAAW;IACxB,WAAW,EAAE,2EAA2E;IACxF,OAAO,EAAE,iCAAiC;IAC1C,IAAI,EAAE,YAAY;IAClB,KAAK,EAAE,QAAQ;IACf,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACnE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC;KAC/D,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,KAAK,EAAE,WAAW,CAAC,QAAQ,CAAC,eAAe,CAAC;KAC7C,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,MAAM,MAAM,GAAG,MAAM,SAAS,CAAoB,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,WAAW,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QAEnH,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,CAAC;QAC7C,MAAM,MAAM,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACzF,MAAM,SAAS,GAAG,CAAC,KAAK,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/F,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QAChD,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,2CAA2C;QAE/D,OAAO;YACL,KAAK,EAAE;gBACL,MAAM,EAAE,KAAK,EAAE,MAAM,IAAI,MAAM,CAAC,YAAY;gBAC5C,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE;gBACzB,KAAK;gBACL,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,EAAE;gBACvB,QAAQ,EAAE,sBAAsB,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,WAAW,MAAM,CAAC,YAAY,EAAE;gBAC3F,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,EAAE;gBACtC,MAAM;gBACN,SAAS;gBACT,QAAQ,EAAE,CAAC,EAAE,8BAA8B;gBAC3C,UAAU,EAAE,KAAK,EAAE,SAAS,IAAI,EAAE;gBAClC,UAAU,EAAE,KAAK,EAAE,SAAS,IAAI,EAAE;gBAClC,SAAS,EAAE,KAAK,EAAE,QAAQ,IAAI,EAAE;gBAChC,eAAe,EAAE,IAAI;aACtB;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-pull-request-diff.d.ts","sourceRoot":"","sources":["../../src/tools/get-pull-request-diff.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"get-pull-request-diff.d.ts","sourceRoot":"","sources":["../../src/tools/get-pull-request-diff.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAoBxB,eAAO,MAAM,kBAAkB;;;;;;kBAyC7B,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
3
|
+
import { pageEmbeddedData } from '../github-api.js';
|
|
4
4
|
export const getPullRequestDiff = defineTool({
|
|
5
5
|
name: 'get_pull_request_diff',
|
|
6
6
|
displayName: 'Get Pull Request Diff',
|
|
@@ -17,10 +17,24 @@ export const getPullRequestDiff = defineTool({
|
|
|
17
17
|
diff: z.string().describe('Raw unified diff text'),
|
|
18
18
|
}),
|
|
19
19
|
handle: async (params) => {
|
|
20
|
-
const
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
const data = await pageEmbeddedData(`/${params.owner}/${params.repo}/pull/${params.pull_number}/files`);
|
|
21
|
+
const route = data.pullRequestsChangesRoute;
|
|
22
|
+
const summaries = route?.diffSummaries ?? [];
|
|
23
|
+
const contents = route?.diffContents ?? {};
|
|
24
|
+
// Reconstruct unified diff from the structured diff data.
|
|
25
|
+
// diffContents uses numeric string keys ("0", "1", ...) matching the order of diffSummaries.
|
|
26
|
+
const diffParts = [];
|
|
27
|
+
for (let i = 0; i < summaries.length; i++) {
|
|
28
|
+
const path = summaries[i]?.path ?? '';
|
|
29
|
+
const content = contents[String(i)];
|
|
30
|
+
if (!content?.diffLines)
|
|
31
|
+
continue;
|
|
32
|
+
diffParts.push(`diff --git a/${path} b/${path}`);
|
|
33
|
+
for (const line of content.diffLines) {
|
|
34
|
+
diffParts.push(line.text ?? '');
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return { diff: diffParts.join('\n') };
|
|
24
38
|
},
|
|
25
39
|
});
|
|
26
40
|
//# sourceMappingURL=get-pull-request-diff.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-pull-request-diff.js","sourceRoot":"","sources":["../../src/tools/get-pull-request-diff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"get-pull-request-diff.js","sourceRoot":"","sources":["../../src/tools/get-pull-request-diff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAmBpD,MAAM,CAAC,MAAM,kBAAkB,GAAG,UAAU,CAAC;IAC3C,IAAI,EAAE,uBAAuB;IAC7B,WAAW,EAAE,uBAAuB;IACpC,WAAW,EAAE,0FAA0F;IACvG,OAAO,EAAE,oCAAoC;IAC7C,IAAI,EAAE,WAAW;IACjB,KAAK,EAAE,eAAe;IACtB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACnE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,qBAAqB,CAAC;KACrE,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,uBAAuB,CAAC;KACnD,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,MAAM,IAAI,GAAG,MAAM,gBAAgB,CACjC,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,SAAS,MAAM,CAAC,WAAW,QAAQ,CACnE,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,CAAC,wBAAwB,CAAC;QAC5C,MAAM,SAAS,GAAG,KAAK,EAAE,aAAa,IAAI,EAAE,CAAC;QAC7C,MAAM,QAAQ,GAAG,KAAK,EAAE,YAAY,IAAI,EAAE,CAAC;QAE3C,0DAA0D;QAC1D,6FAA6F;QAC7F,MAAM,SAAS,GAAa,EAAE,CAAC;QAE/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1C,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC;YACtC,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,OAAO,EAAE,SAAS;gBAAE,SAAS;YAElC,SAAS,CAAC,IAAI,CAAC,gBAAgB,IAAI,MAAM,IAAI,EAAE,CAAC,CAAC;YACjD,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;gBACrC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;YAClC,CAAC;QACH,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;IACxC,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-pull-request.d.ts","sourceRoot":"","sources":["../../src/tools/get-pull-request.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"get-pull-request.d.ts","sourceRoot":"","sources":["../../src/tools/get-pull-request.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAsCxB,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;kBAqDzB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
3
|
+
import { pageEmbeddedData } from '../github-api.js';
|
|
4
4
|
import { mapPullRequest, pullRequestSchema } from './schemas.js';
|
|
5
5
|
export const getPullRequest = defineTool({
|
|
6
6
|
name: 'get_pull_request',
|
|
@@ -18,8 +18,37 @@ export const getPullRequest = defineTool({
|
|
|
18
18
|
pull_request: pullRequestSchema.describe('Pull request details'),
|
|
19
19
|
}),
|
|
20
20
|
handle: async (params) => {
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
// Fetch the PR page to get basic metadata from the layout route
|
|
22
|
+
const pageData = await pageEmbeddedData(`/${params.owner}/${params.repo}/pull/${params.pull_number}`);
|
|
23
|
+
const prLayout = pageData.pullRequestsLayoutRoute?.pullRequest;
|
|
24
|
+
// Also fetch the files page for diff stats
|
|
25
|
+
let diffSummaries;
|
|
26
|
+
try {
|
|
27
|
+
const filesData = await pageEmbeddedData(`/${params.owner}/${params.repo}/pull/${params.pull_number}/files`);
|
|
28
|
+
diffSummaries = filesData.pullRequestsChangesRoute;
|
|
29
|
+
}
|
|
30
|
+
catch {
|
|
31
|
+
// Files page may not be accessible; diff stats will be 0
|
|
32
|
+
}
|
|
33
|
+
const raw = {
|
|
34
|
+
number: prLayout?.number ?? params.pull_number,
|
|
35
|
+
title: prLayout?.title,
|
|
36
|
+
author: prLayout?.author,
|
|
37
|
+
baseBranch: prLayout?.baseBranch,
|
|
38
|
+
headBranch: prLayout?.headBranch,
|
|
39
|
+
commitsCount: prLayout?.commitsCount,
|
|
40
|
+
mergedBy: prLayout?.mergedBy,
|
|
41
|
+
mergedTime: prLayout?.mergedTime,
|
|
42
|
+
// Map state from page format (OPEN, CLOSED, MERGED) to lowercase
|
|
43
|
+
pullRequestState: prLayout?.state,
|
|
44
|
+
closed: prLayout?.state === 'CLOSED' || prLayout?.state === 'MERGED',
|
|
45
|
+
isDraft: false, // not available in layout route
|
|
46
|
+
__typename: 'PullRequest',
|
|
47
|
+
diffSummaries: diffSummaries?.diffSummaries,
|
|
48
|
+
};
|
|
49
|
+
return {
|
|
50
|
+
pull_request: mapPullRequest(raw, { owner: params.owner, repo: params.repo }),
|
|
51
|
+
};
|
|
23
52
|
},
|
|
24
53
|
});
|
|
25
54
|
//# sourceMappingURL=get-pull-request.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-pull-request.js","sourceRoot":"","sources":["../../src/tools/get-pull-request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"get-pull-request.js","sourceRoot":"","sources":["../../src/tools/get-pull-request.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAqB,cAAc,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAoCpF,MAAM,CAAC,MAAM,cAAc,GAAG,UAAU,CAAC;IACvC,IAAI,EAAE,kBAAkB;IACxB,WAAW,EAAE,kBAAkB;IAC/B,WAAW,EAAE,gGAAgG;IAC7G,OAAO,EAAE,wCAAwC;IACjD,IAAI,EAAE,kBAAkB;IACxB,KAAK,EAAE,eAAe;IACtB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACnE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QACnD,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,qBAAqB,CAAC;KACrE,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,YAAY,EAAE,iBAAiB,CAAC,QAAQ,CAAC,sBAAsB,CAAC;KACjE,CAAC;IACF,MAAM,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACrB,gEAAgE;QAChE,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAa,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,SAAS,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;QAElH,MAAM,QAAQ,GAAG,QAAQ,CAAC,uBAAuB,EAAE,WAAW,CAAC;QAE/D,2CAA2C;QAC3C,IAAI,aAAiE,CAAC;QACtE,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,MAAM,gBAAgB,CACtC,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,SAAS,MAAM,CAAC,WAAW,QAAQ,CACnE,CAAC;YACF,aAAa,GAAG,SAAS,CAAC,wBAAwB,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,yDAAyD;QAC3D,CAAC;QAED,MAAM,GAAG,GAAiB;YACxB,MAAM,EAAE,QAAQ,EAAE,MAAM,IAAI,MAAM,CAAC,WAAW;YAC9C,KAAK,EAAE,QAAQ,EAAE,KAAK;YACtB,MAAM,EAAE,QAAQ,EAAE,MAAM;YACxB,UAAU,EAAE,QAAQ,EAAE,UAAU;YAChC,UAAU,EAAE,QAAQ,EAAE,UAAU;YAChC,YAAY,EAAE,QAAQ,EAAE,YAAY;YACpC,QAAQ,EAAE,QAAQ,EAAE,QAAQ;YAC5B,UAAU,EAAE,QAAQ,EAAE,UAAU;YAChC,iEAAiE;YACjE,gBAAgB,EAAE,QAAQ,EAAE,KAAK;YACjC,MAAM,EAAE,QAAQ,EAAE,KAAK,KAAK,QAAQ,IAAI,QAAQ,EAAE,KAAK,KAAK,QAAQ;YACpE,OAAO,EAAE,KAAK,EAAE,gCAAgC;YAChD,UAAU,EAAE,aAAa;YACzB,aAAa,EAAE,aAAa,EAAE,aAAa;SAC5C,CAAC;QAEF,OAAO;YACL,YAAY,EAAE,cAAc,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;SAC9E,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-repo.d.ts","sourceRoot":"","sources":["../../src/tools/get-repo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"get-repo.d.ts","sourceRoot":"","sources":["../../src/tools/get-repo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAqCxB,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;kBAoClB,CAAC"}
|
package/dist/tools/get-repo.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { defineTool } from '@opentabs-dev/plugin-sdk';
|
|
2
2
|
import { z } from 'zod';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { pageJson } from '../github-api.js';
|
|
4
|
+
import { repositorySchema } from './schemas.js';
|
|
5
5
|
export const getRepo = defineTool({
|
|
6
6
|
name: 'get_repo',
|
|
7
7
|
displayName: 'Get Repository',
|
|
@@ -17,8 +17,25 @@ export const getRepo = defineTool({
|
|
|
17
17
|
repository: repositorySchema.describe('Repository details'),
|
|
18
18
|
}),
|
|
19
19
|
handle: async (params) => {
|
|
20
|
-
const data = await
|
|
21
|
-
|
|
20
|
+
const data = await pageJson(`/${params.owner}/${params.repo}`);
|
|
21
|
+
const route = data.codeViewRepoRoute;
|
|
22
|
+
return {
|
|
23
|
+
repository: {
|
|
24
|
+
id: data.repo?.id ?? 0,
|
|
25
|
+
name: params.repo,
|
|
26
|
+
full_name: `${params.owner}/${params.repo}`,
|
|
27
|
+
description: data.repo?.description ?? '',
|
|
28
|
+
private: data.repo?.isPrivate ?? false,
|
|
29
|
+
html_url: `https://github.com/${params.owner}/${params.repo}`,
|
|
30
|
+
default_branch: route?.refInfo?.name ?? data.repo?.defaultBranch ?? '',
|
|
31
|
+
language: data.repo?.language ?? '',
|
|
32
|
+
stargazers_count: data.repo?.stargazerCount ?? 0,
|
|
33
|
+
forks_count: data.repo?.forkCount ?? 0,
|
|
34
|
+
open_issues_count: data.repo?.openIssueCount ?? 0,
|
|
35
|
+
archived: data.repo?.isArchived ?? false,
|
|
36
|
+
updated_at: data.repo?.updatedAt ?? '',
|
|
37
|
+
},
|
|
38
|
+
};
|
|
22
39
|
},
|
|
23
40
|
});
|
|
24
41
|
//# sourceMappingURL=get-repo.js.map
|