@oh-gc/cli 0.4.5 → 0.6.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.
- package/README.md +161 -0
- package/dist/api/client.d.ts +5 -0
- package/dist/api/client.js +47 -1
- package/dist/api/client.js.map +1 -1
- package/dist/api/collaborators.d.ts +32 -0
- package/dist/api/collaborators.js +23 -0
- package/dist/api/collaborators.js.map +1 -0
- package/dist/api/contents.d.ts +88 -0
- package/dist/api/contents.js +44 -0
- package/dist/api/contents.js.map +1 -0
- package/dist/api/enterprises.d.ts +55 -0
- package/dist/api/enterprises.js +16 -0
- package/dist/api/enterprises.js.map +1 -0
- package/dist/api/hooks.d.ts +35 -0
- package/dist/api/hooks.js +35 -0
- package/dist/api/hooks.js.map +1 -0
- package/dist/api/issues.d.ts +42 -0
- package/dist/api/issues.js +35 -0
- package/dist/api/issues.js.map +1 -1
- package/dist/api/labels.d.ts +27 -0
- package/dist/api/labels.js +35 -0
- package/dist/api/labels.js.map +1 -0
- package/dist/api/milestones.d.ts +34 -0
- package/dist/api/milestones.js +35 -0
- package/dist/api/milestones.js.map +1 -0
- package/dist/api/orgs.d.ts +43 -0
- package/dist/api/orgs.js +27 -0
- package/dist/api/orgs.js.map +1 -0
- package/dist/api/prs.d.ts +103 -0
- package/dist/api/prs.js +120 -0
- package/dist/api/prs.js.map +1 -1
- package/dist/api/repos.d.ts +170 -0
- package/dist/api/repos.js +68 -0
- package/dist/api/repos.js.map +1 -0
- package/dist/api/search.d.ts +49 -0
- package/dist/api/search.js +22 -0
- package/dist/api/search.js.map +1 -0
- package/dist/api/tags.d.ts +21 -0
- package/dist/api/tags.js +23 -0
- package/dist/api/tags.js.map +1 -0
- package/dist/api/user.d.ts +31 -0
- package/dist/api/user.js +21 -0
- package/dist/api/user.js.map +1 -1
- package/dist/commands/branch/get.d.ts +13 -0
- package/dist/commands/branch/get.js +50 -0
- package/dist/commands/branch/get.js.map +1 -0
- package/dist/commands/branch/list.d.ts +13 -0
- package/dist/commands/branch/list.js +55 -0
- package/dist/commands/branch/list.js.map +1 -0
- package/dist/commands/branch/protect.d.ts +17 -0
- package/dist/commands/branch/protect.js +81 -0
- package/dist/commands/branch/protect.js.map +1 -0
- package/dist/commands/collaborator/add.d.ts +14 -0
- package/dist/commands/collaborator/add.js +50 -0
- package/dist/commands/collaborator/add.js.map +1 -0
- package/dist/commands/collaborator/list.d.ts +13 -0
- package/dist/commands/collaborator/list.js +61 -0
- package/dist/commands/collaborator/list.js.map +1 -0
- package/dist/commands/collaborator/permission.d.ts +13 -0
- package/dist/commands/collaborator/permission.js +39 -0
- package/dist/commands/collaborator/permission.js.map +1 -0
- package/dist/commands/collaborator/remove.d.ts +13 -0
- package/dist/commands/collaborator/remove.js +37 -0
- package/dist/commands/collaborator/remove.js.map +1 -0
- package/dist/commands/commit/compare.d.ts +14 -0
- package/dist/commands/commit/compare.js +73 -0
- package/dist/commands/commit/compare.js.map +1 -0
- package/dist/commands/commit/diff.d.ts +13 -0
- package/dist/commands/commit/diff.js +56 -0
- package/dist/commands/commit/diff.js.map +1 -0
- package/dist/commands/commit/get.d.ts +13 -0
- package/dist/commands/commit/get.js +65 -0
- package/dist/commands/commit/get.js.map +1 -0
- package/dist/commands/commit/list.d.ts +17 -0
- package/dist/commands/commit/list.js +67 -0
- package/dist/commands/commit/list.js.map +1 -0
- package/dist/commands/file/get.d.ts +14 -0
- package/dist/commands/file/get.js +61 -0
- package/dist/commands/file/get.js.map +1 -0
- package/dist/commands/file/list.d.ts +14 -0
- package/dist/commands/file/list.js +58 -0
- package/dist/commands/file/list.js.map +1 -0
- package/dist/commands/file/raw.d.ts +14 -0
- package/dist/commands/file/raw.js +48 -0
- package/dist/commands/file/raw.js.map +1 -0
- package/dist/commands/hook/create.d.ts +17 -0
- package/dist/commands/hook/create.js +62 -0
- package/dist/commands/hook/create.js.map +1 -0
- package/dist/commands/hook/delete.d.ts +16 -0
- package/dist/commands/hook/delete.js +37 -0
- package/dist/commands/hook/delete.js.map +1 -0
- package/dist/commands/hook/get.d.ts +16 -0
- package/dist/commands/hook/get.js +46 -0
- package/dist/commands/hook/get.js.map +1 -0
- package/dist/commands/hook/list.d.ts +12 -0
- package/dist/commands/hook/list.js +47 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/issue/close.d.ts +13 -0
- package/dist/commands/issue/close.js +34 -0
- package/dist/commands/issue/close.js.map +1 -0
- package/dist/commands/issue/comment.d.ts +3 -2
- package/dist/commands/issue/comment.js +6 -7
- package/dist/commands/issue/comment.js.map +1 -1
- package/dist/commands/issue/create.d.ts +2 -2
- package/dist/commands/issue/create.js +7 -15
- package/dist/commands/issue/create.js.map +1 -1
- package/dist/commands/issue/history.d.ts +13 -0
- package/dist/commands/issue/history.js +39 -0
- package/dist/commands/issue/history.js.map +1 -0
- package/dist/commands/issue/labels.d.ts +15 -0
- package/dist/commands/issue/labels.js +53 -0
- package/dist/commands/issue/labels.js.map +1 -0
- package/dist/commands/issue/list.d.ts +3 -2
- package/dist/commands/issue/list.js +8 -9
- package/dist/commands/issue/list.js.map +1 -1
- package/dist/commands/issue/reactions.d.ts +13 -0
- package/dist/commands/issue/reactions.js +34 -0
- package/dist/commands/issue/reactions.js.map +1 -0
- package/dist/commands/issue/reopen.d.ts +13 -0
- package/dist/commands/issue/reopen.js +34 -0
- package/dist/commands/issue/reopen.js.map +1 -0
- package/dist/commands/issue/update.d.ts +18 -0
- package/dist/commands/issue/update.js +54 -0
- package/dist/commands/issue/update.js.map +1 -0
- package/dist/commands/issue/view.d.ts +3 -2
- package/dist/commands/issue/view.js +8 -9
- package/dist/commands/issue/view.js.map +1 -1
- package/dist/commands/label/create.d.ts +15 -0
- package/dist/commands/label/create.js +56 -0
- package/dist/commands/label/create.js.map +1 -0
- package/dist/commands/label/delete.d.ts +13 -0
- package/dist/commands/label/delete.js +44 -0
- package/dist/commands/label/delete.js.map +1 -0
- package/dist/commands/label/list.d.ts +12 -0
- package/dist/commands/label/list.js +53 -0
- package/dist/commands/label/list.js.map +1 -0
- package/dist/commands/label/update.d.ts +16 -0
- package/dist/commands/label/update.js +63 -0
- package/dist/commands/label/update.js.map +1 -0
- package/dist/commands/milestone/create.d.ts +15 -0
- package/dist/commands/milestone/create.js +49 -0
- package/dist/commands/milestone/create.js.map +1 -0
- package/dist/commands/milestone/delete.d.ts +16 -0
- package/dist/commands/milestone/delete.js +37 -0
- package/dist/commands/milestone/delete.js.map +1 -0
- package/dist/commands/milestone/get.d.ts +16 -0
- package/dist/commands/milestone/get.js +48 -0
- package/dist/commands/milestone/get.js.map +1 -0
- package/dist/commands/milestone/list.d.ts +13 -0
- package/dist/commands/milestone/list.js +53 -0
- package/dist/commands/milestone/list.js.map +1 -0
- package/dist/commands/milestone/update.d.ts +20 -0
- package/dist/commands/milestone/update.js +62 -0
- package/dist/commands/milestone/update.js.map +1 -0
- package/dist/commands/org/list.d.ts +11 -0
- package/dist/commands/org/list.js +53 -0
- package/dist/commands/org/list.js.map +1 -0
- package/dist/commands/org/members.d.ts +14 -0
- package/dist/commands/org/members.js +48 -0
- package/dist/commands/org/members.js.map +1 -0
- package/dist/commands/org/view.d.ts +12 -0
- package/dist/commands/org/view.js +42 -0
- package/dist/commands/org/view.js.map +1 -0
- package/dist/commands/pr/close.d.ts +13 -0
- package/dist/commands/pr/close.js +34 -0
- package/dist/commands/pr/close.js.map +1 -0
- package/dist/commands/pr/comment.d.ts +3 -3
- package/dist/commands/pr/comment.js +7 -15
- package/dist/commands/pr/comment.js.map +1 -1
- package/dist/commands/pr/comments.d.ts +19 -0
- package/dist/commands/pr/comments.js +71 -0
- package/dist/commands/pr/comments.js.map +1 -0
- package/dist/commands/pr/commits.d.ts +17 -0
- package/dist/commands/pr/commits.js +58 -0
- package/dist/commands/pr/commits.js.map +1 -0
- package/dist/commands/pr/create.d.ts +2 -2
- package/dist/commands/pr/create.js +6 -13
- package/dist/commands/pr/create.js.map +1 -1
- package/dist/commands/pr/diff.d.ts +3 -2
- package/dist/commands/pr/diff.js +6 -7
- package/dist/commands/pr/diff.js.map +1 -1
- package/dist/commands/pr/labels.d.ts +18 -0
- package/dist/commands/pr/labels.js +70 -0
- package/dist/commands/pr/labels.js.map +1 -0
- package/dist/commands/pr/link.d.ts +18 -0
- package/dist/commands/pr/link.js +63 -0
- package/dist/commands/pr/link.js.map +1 -0
- package/dist/commands/pr/list.d.ts +3 -2
- package/dist/commands/pr/list.js +8 -9
- package/dist/commands/pr/list.js.map +1 -1
- package/dist/commands/pr/logs.d.ts +17 -0
- package/dist/commands/pr/logs.js +58 -0
- package/dist/commands/pr/logs.js.map +1 -0
- package/dist/commands/pr/merge.d.ts +3 -2
- package/dist/commands/pr/merge.js +6 -7
- package/dist/commands/pr/merge.js.map +1 -1
- package/dist/commands/pr/reactions.d.ts +13 -0
- package/dist/commands/pr/reactions.js +34 -0
- package/dist/commands/pr/reactions.js.map +1 -0
- package/dist/commands/pr/reopen.d.ts +13 -0
- package/dist/commands/pr/reopen.js +34 -0
- package/dist/commands/pr/reopen.js.map +1 -0
- package/dist/commands/pr/review.d.ts +17 -0
- package/dist/commands/pr/review.js +55 -0
- package/dist/commands/pr/review.js.map +1 -0
- package/dist/commands/pr/reviewers.d.ts +19 -0
- package/dist/commands/pr/reviewers.js +91 -0
- package/dist/commands/pr/reviewers.js.map +1 -0
- package/dist/commands/pr/test.d.ts +17 -0
- package/dist/commands/pr/test.js +55 -0
- package/dist/commands/pr/test.js.map +1 -0
- package/dist/commands/pr/testers.d.ts +19 -0
- package/dist/commands/pr/testers.js +91 -0
- package/dist/commands/pr/testers.js.map +1 -0
- package/dist/commands/pr/update.d.ts +21 -0
- package/dist/commands/pr/update.js +66 -0
- package/dist/commands/pr/update.js.map +1 -0
- package/dist/commands/pr/view.d.ts +3 -2
- package/dist/commands/pr/view.js +8 -9
- package/dist/commands/pr/view.js.map +1 -1
- package/dist/commands/release/create.d.ts +3 -2
- package/dist/commands/release/create.js +6 -14
- package/dist/commands/release/create.js.map +1 -1
- package/dist/commands/repo/get-remote.d.ts +3 -2
- package/dist/commands/repo/get-remote.js +3 -3
- package/dist/commands/repo/set-remote.d.ts +3 -2
- package/dist/commands/repo/set-remote.js +3 -3
- package/dist/commands/repo/transfer.d.ts +14 -0
- package/dist/commands/repo/transfer.js +59 -0
- package/dist/commands/repo/transfer.js.map +1 -0
- package/dist/commands/repo/update.d.ts +15 -0
- package/dist/commands/repo/update.js +66 -0
- package/dist/commands/repo/update.js.map +1 -0
- package/dist/commands/repo/view.d.ts +10 -0
- package/dist/commands/repo/view.js +50 -0
- package/dist/commands/repo/view.js.map +1 -0
- package/dist/commands/search/code.d.ts +16 -0
- package/dist/commands/search/code.js +75 -0
- package/dist/commands/search/code.js.map +1 -0
- package/dist/commands/search/issues.d.ts +16 -0
- package/dist/commands/search/issues.js +77 -0
- package/dist/commands/search/issues.js.map +1 -0
- package/dist/commands/search/repos.d.ts +16 -0
- package/dist/commands/search/repos.js +77 -0
- package/dist/commands/search/repos.js.map +1 -0
- package/dist/commands/tag/list.d.ts +12 -0
- package/dist/commands/tag/list.js +45 -0
- package/dist/commands/tag/list.js.map +1 -0
- package/dist/commands/tag/protect.d.ts +14 -0
- package/dist/commands/tag/protect.js +53 -0
- package/dist/commands/tag/protect.js.map +1 -0
- package/dist/commands/user/emails.d.ts +9 -0
- package/dist/commands/user/emails.js +33 -0
- package/dist/commands/user/emails.js.map +1 -0
- package/dist/commands/user/followers.d.ts +14 -0
- package/dist/commands/user/followers.js +92 -0
- package/dist/commands/user/followers.js.map +1 -0
- package/dist/commands/user/following.d.ts +14 -0
- package/dist/commands/user/following.js +57 -0
- package/dist/commands/user/following.js.map +1 -0
- package/dist/commands/user/view.d.ts +12 -0
- package/dist/commands/user/view.js +46 -0
- package/dist/commands/user/view.js.map +1 -0
- package/dist/git/index.js +1 -1
- package/dist/git/index.js.map +1 -1
- package/dist/repo-command.d.ts +19 -0
- package/dist/repo-command.js +29 -0
- package/dist/repo-command.js.map +1 -0
- package/dist/ui/index.d.ts +1 -1
- package/dist/ui/index.js +1 -0
- package/dist/ui/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const core_1 = require("@oclif/core");
|
|
4
|
-
const
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
5
|
const index_1 = require("../../config/index");
|
|
6
|
-
const index_2 = require("../../git/index");
|
|
7
6
|
const prs_1 = require("../../api/prs");
|
|
8
7
|
const client_1 = require("../../api/client");
|
|
9
|
-
const
|
|
10
|
-
class PRMerge extends
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRMerge extends repo_command_1.RepoCommand {
|
|
11
10
|
async run() {
|
|
12
11
|
const { args, flags } = await this.parse(PRMerge);
|
|
13
12
|
const token = (0, index_1.getToken)();
|
|
@@ -16,7 +15,7 @@ class PRMerge extends base_command_1.BaseCommand {
|
|
|
16
15
|
let owner, repo;
|
|
17
16
|
try {
|
|
18
17
|
;
|
|
19
|
-
({ owner, repo } =
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
20
19
|
}
|
|
21
20
|
catch (err) {
|
|
22
21
|
this.error(err.message);
|
|
@@ -26,7 +25,7 @@ class PRMerge extends base_command_1.BaseCommand {
|
|
|
26
25
|
merge_method: flags.method,
|
|
27
26
|
});
|
|
28
27
|
if (flags.json) {
|
|
29
|
-
(0,
|
|
28
|
+
(0, index_2.printJson)(result);
|
|
30
29
|
}
|
|
31
30
|
else {
|
|
32
31
|
this.log(`Merged PR #${args.number} (${result.sha.slice(0, 8)})`);
|
|
@@ -48,7 +47,7 @@ PRMerge.args = {
|
|
|
48
47
|
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
49
48
|
};
|
|
50
49
|
PRMerge.flags = {
|
|
51
|
-
...
|
|
50
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
52
51
|
method: core_1.Flags.string({
|
|
53
52
|
description: 'Merge method: merge, squash, rebase',
|
|
54
53
|
default: 'merge',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"merge.js","sourceRoot":"","sources":["../../../src/commands/pr/merge.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,
|
|
1
|
+
{"version":3,"file":"merge.js","sourceRoot":"","sources":["../../../src/commands/pr/merge.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,uCAAuC;AACvC,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,OAAQ,SAAQ,0BAAW;IAkB9C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAEjD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,CAAC;YAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAA,aAAO,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE;gBAC5D,YAAY,EAAE,KAAK,CAAC,MAAM;aAC3B,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;YACnB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAA;YACnE,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY;gBAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACxD,IAAI,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC;;AA5CM,mBAAW,GAAG,sBAAsB,CAAA;AACpC,gBAAQ,GAAG;IAChB,8BAA8B;IAC9B,8CAA8C;CAC/C,CAAA;AACM,YAAI,GAAG;IACZ,MAAM,EAAE,WAAI,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnE,CAAA;AACM,aAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,MAAM,EAAE,YAAK,CAAC,MAAM,CAAC;QACnB,WAAW,EAAE,qCAAqC;QAClD,OAAO,EAAE,OAAO;QAChB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC;KACvC,CAAC;CACH,CAAA;kBAhBkB,OAAO"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRReactions extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
static args: {
|
|
10
|
+
number: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const repo_command_1 = require("../../repo-command");
|
|
4
|
+
const prs_1 = require("../../api/prs");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class PRReactions extends repo_command_1.RepoCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(PRReactions);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
14
|
+
}
|
|
15
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
16
|
+
const reactions = await (0, prs_1.listPRReactions)(token, owner, repo, parseInt(args.number));
|
|
17
|
+
if (flags.json) {
|
|
18
|
+
(0, ui_1.printJson)(reactions);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
(0, ui_1.printTable)(reactions, ['content', 'user']);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
PRReactions.description = 'List reactions on a pull request';
|
|
26
|
+
PRReactions.examples = ['<%= config.bin %> pr:reactions 123'];
|
|
27
|
+
PRReactions.flags = {
|
|
28
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
29
|
+
};
|
|
30
|
+
PRReactions.args = {
|
|
31
|
+
number: core_1.Args.string({ description: 'PR number', required: true }),
|
|
32
|
+
};
|
|
33
|
+
exports.default = PRReactions;
|
|
34
|
+
//# sourceMappingURL=reactions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reactions.js","sourceRoot":"","sources":["../../../src/commands/pr/reactions.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,uCAA+C;AAC/C,yCAAuC;AACvC,iCAAgD;AAChD,sCAAkC;AAElC,MAAqB,WAAY,SAAQ,0BAAW;IAalD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QACrD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QACxD,MAAM,SAAS,GAAG,MAAM,IAAA,qBAAe,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAA;QAElF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,SAAS,CAAC,CAAA;QACtB,CAAC;aAAM,CAAC;YACN,IAAA,eAAU,EAAC,SAAS,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAA;QAC5C,CAAC;IACH,CAAC;;AA3BM,uBAAW,GAAG,kCAAkC,CAAA;AAEhD,oBAAQ,GAAG,CAAC,oCAAoC,CAAC,CAAA;AAEjD,iBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;CACzB,CAAA;AAEM,gBAAI,GAAG;IACZ,MAAM,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAClE,CAAA;kBAXkB,WAAW"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRReopen extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
};
|
|
9
|
+
static args: {
|
|
10
|
+
number: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const repo_command_1 = require("../../repo-command");
|
|
4
|
+
const prs_1 = require("../../api/prs");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class PRReopen extends repo_command_1.RepoCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(PRReopen);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
14
|
+
}
|
|
15
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
16
|
+
const pr = await (0, prs_1.reopenPR)(token, owner, repo, parseInt(args.number));
|
|
17
|
+
if (flags.json) {
|
|
18
|
+
(0, ui_1.printJson)(pr);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this.log(`Reopened pull request #${pr.number}`);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
PRReopen.description = 'Reopen a closed pull request';
|
|
26
|
+
PRReopen.examples = ['<%= config.bin %> pr:reopen 123'];
|
|
27
|
+
PRReopen.flags = {
|
|
28
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
29
|
+
};
|
|
30
|
+
PRReopen.args = {
|
|
31
|
+
number: core_1.Args.string({ description: 'PR number', required: true }),
|
|
32
|
+
};
|
|
33
|
+
exports.default = PRReopen;
|
|
34
|
+
//# sourceMappingURL=reopen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reopen.js","sourceRoot":"","sources":["../../../src/commands/pr/reopen.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,uCAAwC;AACxC,yCAAuC;AACvC,iCAAoC;AACpC,sCAAkC;AAElC,MAAqB,QAAS,SAAQ,0BAAW;IAa/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAClD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QACxD,MAAM,EAAE,GAAG,MAAM,IAAA,cAAQ,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAA;QAEpE,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,EAAE,CAAC,CAAA;QACf,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,CAAC,0BAA0B,EAAE,CAAC,MAAM,EAAE,CAAC,CAAA;QACjD,CAAC;IACH,CAAC;;AA3BM,oBAAW,GAAG,8BAA8B,CAAA;AAE5C,iBAAQ,GAAG,CAAC,iCAAiC,CAAC,CAAA;AAE9C,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;CACzB,CAAA;AAEM,aAAI,GAAG;IACZ,MAAM,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAClE,CAAA;kBAXkB,QAAQ"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRReview extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
number: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
min?: number | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
static flags: {
|
|
12
|
+
force: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
};
|
|
16
|
+
run(): Promise<void>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const prs_1 = require("../../api/prs");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRReview extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(PRReview);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
let owner, repo;
|
|
16
|
+
try {
|
|
17
|
+
;
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
this.error(err.message);
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const result = await (0, prs_1.submitReview)(token, owner, repo, args.number, flags.force);
|
|
25
|
+
if (flags.json) {
|
|
26
|
+
(0, index_2.printJson)(result);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.log(`Approved PR #${args.number}`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
if (err instanceof client_1.GitCodeError)
|
|
34
|
+
this.error(err.message);
|
|
35
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
PRReview.description = 'Approve a pull request review';
|
|
40
|
+
PRReview.examples = [
|
|
41
|
+
'<%= config.bin %> pr:review 5',
|
|
42
|
+
'<%= config.bin %> pr:review 5 --force',
|
|
43
|
+
];
|
|
44
|
+
PRReview.args = {
|
|
45
|
+
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
46
|
+
};
|
|
47
|
+
PRReview.flags = {
|
|
48
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
49
|
+
force: core_1.Flags.boolean({
|
|
50
|
+
description: 'Force the review approval',
|
|
51
|
+
default: false,
|
|
52
|
+
}),
|
|
53
|
+
};
|
|
54
|
+
exports.default = PRReview;
|
|
55
|
+
//# sourceMappingURL=review.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"review.js","sourceRoot":"","sources":["../../../src/commands/pr/review.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,uCAA4C;AAC5C,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,QAAS,SAAQ,0BAAW;IAiB/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAElD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,CAAC;YAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAA,kBAAY,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAA;YAE/E,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;YACnB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,MAAM,EAAE,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY;gBAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACxD,IAAI,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC;;AAzCM,oBAAW,GAAG,+BAA+B,CAAA;AAC7C,iBAAQ,GAAG;IAChB,+BAA+B;IAC/B,uCAAuC;CACxC,CAAA;AACM,aAAI,GAAG;IACZ,MAAM,EAAE,WAAI,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnE,CAAA;AACM,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,KAAK,EAAE,YAAK,CAAC,OAAO,CAAC;QACnB,WAAW,EAAE,2BAA2B;QACxC,OAAO,EAAE,KAAK;KACf,CAAC;CACH,CAAA;kBAfkB,QAAQ"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRReviewers extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
number: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
min?: number | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
usernames: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
11
|
+
};
|
|
12
|
+
static flags: {
|
|
13
|
+
remove: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
append: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
16
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
17
|
+
};
|
|
18
|
+
run(): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const prs_1 = require("../../api/prs");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRReviewers extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(PRReviewers);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
let owner, repo;
|
|
16
|
+
try {
|
|
17
|
+
;
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
this.error(err.message);
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
if (!args.usernames) {
|
|
25
|
+
// List mode — get reviewers from PR detail
|
|
26
|
+
const pr = await (0, prs_1.getPR)(token, owner, repo, args.number);
|
|
27
|
+
const reviewers = pr.approval_reviewers || [];
|
|
28
|
+
if (flags.json) {
|
|
29
|
+
(0, index_2.printJson)(reviewers);
|
|
30
|
+
}
|
|
31
|
+
else if (reviewers.length === 0) {
|
|
32
|
+
this.log('No reviewers assigned.');
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
(0, index_2.printTable)(reviewers.map((u) => ({
|
|
36
|
+
login: u.login,
|
|
37
|
+
name: u.name,
|
|
38
|
+
accepted: u.accept ? 'yes' : 'no',
|
|
39
|
+
})), ['login', 'name', 'accepted']);
|
|
40
|
+
}
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
let result;
|
|
44
|
+
if (flags.remove) {
|
|
45
|
+
result = await (0, prs_1.removeReviewers)(token, owner, repo, args.number, args.usernames);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
result = await (0, prs_1.assignReviewers)(token, owner, repo, args.number, args.usernames, flags.append);
|
|
49
|
+
}
|
|
50
|
+
if (flags.json) {
|
|
51
|
+
(0, index_2.printJson)(result);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
(0, index_2.printTable)(result.map((u) => ({
|
|
55
|
+
login: u.login,
|
|
56
|
+
name: u.name,
|
|
57
|
+
})), ['login', 'name']);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (err) {
|
|
61
|
+
if (err instanceof client_1.GitCodeError)
|
|
62
|
+
this.error(err.message);
|
|
63
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
PRReviewers.description = 'List, assign, or remove reviewers on a pull request';
|
|
68
|
+
PRReviewers.examples = [
|
|
69
|
+
'<%= config.bin %> pr:reviewers 5',
|
|
70
|
+
'<%= config.bin %> pr:reviewers 5 --repo openharmony/arkui_ace_engine',
|
|
71
|
+
'<%= config.bin %> pr:reviewers 5 alice,bob',
|
|
72
|
+
'<%= config.bin %> pr:reviewers 5 alice,bob --remove',
|
|
73
|
+
'<%= config.bin %> pr:reviewers 5 alice --append',
|
|
74
|
+
];
|
|
75
|
+
PRReviewers.args = {
|
|
76
|
+
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
77
|
+
usernames: core_1.Args.string({ description: 'Comma-separated reviewer logins (omit to list)', required: false }),
|
|
78
|
+
};
|
|
79
|
+
PRReviewers.flags = {
|
|
80
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
81
|
+
remove: core_1.Flags.boolean({
|
|
82
|
+
description: 'Remove reviewers instead of adding',
|
|
83
|
+
default: false,
|
|
84
|
+
}),
|
|
85
|
+
append: core_1.Flags.boolean({
|
|
86
|
+
description: 'Append to existing reviewers (only when adding)',
|
|
87
|
+
default: false,
|
|
88
|
+
}),
|
|
89
|
+
};
|
|
90
|
+
exports.default = PRReviewers;
|
|
91
|
+
//# sourceMappingURL=reviewers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewers.js","sourceRoot":"","sources":["../../../src/commands/pr/reviewers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRTest extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
number: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
min?: number | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
static flags: {
|
|
12
|
+
force: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
};
|
|
16
|
+
run(): Promise<void>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const prs_1 = require("../../api/prs");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRTest extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(PRTest);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
let owner, repo;
|
|
16
|
+
try {
|
|
17
|
+
;
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
this.error(err.message);
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const result = await (0, prs_1.submitTest)(token, owner, repo, args.number, flags.force);
|
|
25
|
+
if (flags.json) {
|
|
26
|
+
(0, index_2.printJson)(result);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.log(`Marked PR #${args.number} as test passed`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
if (err instanceof client_1.GitCodeError)
|
|
34
|
+
this.error(err.message);
|
|
35
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
PRTest.description = 'Mark a pull request as test passed';
|
|
40
|
+
PRTest.examples = [
|
|
41
|
+
'<%= config.bin %> pr:test 5',
|
|
42
|
+
'<%= config.bin %> pr:test 5 --force',
|
|
43
|
+
];
|
|
44
|
+
PRTest.args = {
|
|
45
|
+
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
46
|
+
};
|
|
47
|
+
PRTest.flags = {
|
|
48
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
49
|
+
force: core_1.Flags.boolean({
|
|
50
|
+
description: 'Force the test pass',
|
|
51
|
+
default: false,
|
|
52
|
+
}),
|
|
53
|
+
};
|
|
54
|
+
exports.default = PRTest;
|
|
55
|
+
//# sourceMappingURL=test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../../src/commands/pr/test.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,uCAA0C;AAC1C,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,MAAO,SAAQ,0BAAW;IAiB7C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAEhD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,CAAC;YAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAA,gBAAU,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAA;YAE7E,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;YACnB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,MAAM,iBAAiB,CAAC,CAAA;YACtD,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY;gBAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACxD,IAAI,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC;;AAzCM,kBAAW,GAAG,oCAAoC,CAAA;AAClD,eAAQ,GAAG;IAChB,6BAA6B;IAC7B,qCAAqC;CACtC,CAAA;AACM,WAAI,GAAG;IACZ,MAAM,EAAE,WAAI,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnE,CAAA;AACM,YAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,KAAK,EAAE,YAAK,CAAC,OAAO,CAAC;QACnB,WAAW,EAAE,qBAAqB;QAClC,OAAO,EAAE,KAAK;KACf,CAAC;CACH,CAAA;kBAfkB,MAAM"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRTesters extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
number: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
min?: number | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
usernames: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
11
|
+
};
|
|
12
|
+
static flags: {
|
|
13
|
+
remove: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
append: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
16
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
17
|
+
};
|
|
18
|
+
run(): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const prs_1 = require("../../api/prs");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRTesters extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(PRTesters);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
let owner, repo;
|
|
16
|
+
try {
|
|
17
|
+
;
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
this.error(err.message);
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
if (!args.usernames) {
|
|
25
|
+
// List mode — get testers from PR detail
|
|
26
|
+
const pr = await (0, prs_1.getPR)(token, owner, repo, args.number);
|
|
27
|
+
const testers = pr.testers || [];
|
|
28
|
+
if (flags.json) {
|
|
29
|
+
(0, index_2.printJson)(testers);
|
|
30
|
+
}
|
|
31
|
+
else if (testers.length === 0) {
|
|
32
|
+
this.log('No testers assigned.');
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
(0, index_2.printTable)(testers.map((u) => ({
|
|
36
|
+
login: u.login,
|
|
37
|
+
name: u.name,
|
|
38
|
+
accepted: u.accept ? 'yes' : 'no',
|
|
39
|
+
})), ['login', 'name', 'accepted']);
|
|
40
|
+
}
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
let result;
|
|
44
|
+
if (flags.remove) {
|
|
45
|
+
result = await (0, prs_1.removeTesters)(token, owner, repo, args.number, args.usernames);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
result = await (0, prs_1.assignTesters)(token, owner, repo, args.number, args.usernames, flags.append);
|
|
49
|
+
}
|
|
50
|
+
if (flags.json) {
|
|
51
|
+
(0, index_2.printJson)(result);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
(0, index_2.printTable)(result.map((u) => ({
|
|
55
|
+
login: u.login,
|
|
56
|
+
name: u.name,
|
|
57
|
+
})), ['login', 'name']);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (err) {
|
|
61
|
+
if (err instanceof client_1.GitCodeError)
|
|
62
|
+
this.error(err.message);
|
|
63
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
PRTesters.description = 'List, assign, or remove testers on a pull request';
|
|
68
|
+
PRTesters.examples = [
|
|
69
|
+
'<%= config.bin %> pr:testers 5',
|
|
70
|
+
'<%= config.bin %> pr:testers 5 --repo openharmony/arkui_ace_engine',
|
|
71
|
+
'<%= config.bin %> pr:testers 5 alice,bob',
|
|
72
|
+
'<%= config.bin %> pr:testers 5 alice,bob --remove',
|
|
73
|
+
'<%= config.bin %> pr:testers 5 alice --append',
|
|
74
|
+
];
|
|
75
|
+
PRTesters.args = {
|
|
76
|
+
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
77
|
+
usernames: core_1.Args.string({ description: 'Comma-separated tester logins (omit to list)', required: false }),
|
|
78
|
+
};
|
|
79
|
+
PRTesters.flags = {
|
|
80
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
81
|
+
remove: core_1.Flags.boolean({
|
|
82
|
+
description: 'Remove testers instead of adding',
|
|
83
|
+
default: false,
|
|
84
|
+
}),
|
|
85
|
+
append: core_1.Flags.boolean({
|
|
86
|
+
description: 'Append to existing testers (only when adding)',
|
|
87
|
+
default: false,
|
|
88
|
+
}),
|
|
89
|
+
};
|
|
90
|
+
exports.default = PRTesters;
|
|
91
|
+
//# sourceMappingURL=testers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testers.js","sourceRoot":"","sources":["../../../src/commands/pr/testers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class PRUpdate extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
number: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
min?: number | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
static flags: {
|
|
12
|
+
title: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
body: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
state: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
15
|
+
labels: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
16
|
+
draft: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
17
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
18
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
19
|
+
};
|
|
20
|
+
run(): Promise<void>;
|
|
21
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const repo_command_1 = require("../../repo-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const prs_1 = require("../../api/prs");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class PRUpdate extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(PRUpdate);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
let owner, repo;
|
|
16
|
+
try {
|
|
17
|
+
;
|
|
18
|
+
({ owner, repo } = this.resolveRepoFromFlags(flags));
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
this.error(err.message);
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const pr = await (0, prs_1.updatePR)(token, owner, repo, args.number, {
|
|
25
|
+
title: flags.title,
|
|
26
|
+
body: flags.body,
|
|
27
|
+
state: flags.state,
|
|
28
|
+
labels: flags.labels,
|
|
29
|
+
draft: flags.draft || undefined,
|
|
30
|
+
});
|
|
31
|
+
if (flags.json) {
|
|
32
|
+
(0, index_2.printJson)(pr);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
this.log(`Updated PR #${pr.number}: ${pr.title}`);
|
|
36
|
+
this.log(pr.html_url);
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
if (err instanceof client_1.GitCodeError)
|
|
40
|
+
this.error(err.message);
|
|
41
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
PRUpdate.description = 'Update a pull request';
|
|
46
|
+
PRUpdate.examples = [
|
|
47
|
+
'<%= config.bin %> pr update 5 --title "New title"',
|
|
48
|
+
'<%= config.bin %> pr update 5 --state closed',
|
|
49
|
+
'<%= config.bin %> pr update 5 --draft',
|
|
50
|
+
];
|
|
51
|
+
PRUpdate.args = {
|
|
52
|
+
number: core_1.Args.integer({ description: 'PR number', required: true }),
|
|
53
|
+
};
|
|
54
|
+
PRUpdate.flags = {
|
|
55
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
56
|
+
title: core_1.Flags.string({ description: 'New title for the PR' }),
|
|
57
|
+
body: core_1.Flags.string({ description: 'New body for the PR' }),
|
|
58
|
+
state: core_1.Flags.string({
|
|
59
|
+
description: 'Set PR state',
|
|
60
|
+
options: ['open', 'closed'],
|
|
61
|
+
}),
|
|
62
|
+
labels: core_1.Flags.string({ description: 'Comma-separated list of labels' }),
|
|
63
|
+
draft: core_1.Flags.boolean({ description: 'Mark PR as draft', default: false }),
|
|
64
|
+
};
|
|
65
|
+
exports.default = PRUpdate;
|
|
66
|
+
//# sourceMappingURL=update.js.map
|