@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
|
@@ -0,0 +1,81 @@
|
|
|
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 repos_1 = require("../../api/repos");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class BranchProtect extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(BranchProtect);
|
|
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 (flags.unprotect) {
|
|
25
|
+
await (0, repos_1.unprotectBranch)(token, owner, repo, args.branch);
|
|
26
|
+
if (flags.json) {
|
|
27
|
+
(0, index_2.printJson)({ protected: false });
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
this.log(`Branch '${args.branch}' is no longer protected`);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const params = {};
|
|
34
|
+
if (flags['enforce-admins'])
|
|
35
|
+
params.enforce_admins = true;
|
|
36
|
+
if (flags['require-status-checks']) {
|
|
37
|
+
params.required_status_checks = {
|
|
38
|
+
strict: true,
|
|
39
|
+
contexts: flags['require-status-checks'].split(',').map((c) => c.trim()),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
if (flags['dismiss-stale-reviews']) {
|
|
43
|
+
params.required_pull_request_reviews = {
|
|
44
|
+
dismiss_stale_reviews: true,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
const protection = await (0, repos_1.protectBranch)(token, owner, repo, args.branch, params);
|
|
48
|
+
if (flags.json) {
|
|
49
|
+
(0, index_2.printJson)(protection);
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
this.log(`Branch '${args.branch}' is now protected`);
|
|
53
|
+
}
|
|
54
|
+
catch (err) {
|
|
55
|
+
if (err instanceof client_1.GitCodeError)
|
|
56
|
+
this.error(err.message);
|
|
57
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
BranchProtect.description = 'Protect or unprotect a branch';
|
|
62
|
+
BranchProtect.examples = [
|
|
63
|
+
'<%= config.bin %> branch protect main',
|
|
64
|
+
'<%= config.bin %> branch protect main --unprotect',
|
|
65
|
+
];
|
|
66
|
+
BranchProtect.args = {
|
|
67
|
+
branch: core_1.Args.string({ description: 'Branch name', required: true }),
|
|
68
|
+
};
|
|
69
|
+
BranchProtect.flags = {
|
|
70
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
71
|
+
unprotect: core_1.Flags.boolean({ description: 'Remove branch protection' }),
|
|
72
|
+
'enforce-admins': core_1.Flags.boolean({ description: 'Enforce protection for admins' }),
|
|
73
|
+
'require-status-checks': core_1.Flags.string({
|
|
74
|
+
description: 'Comma-separated required status check contexts',
|
|
75
|
+
}),
|
|
76
|
+
'dismiss-stale-reviews': core_1.Flags.boolean({
|
|
77
|
+
description: 'Dismiss stale pull request reviews',
|
|
78
|
+
}),
|
|
79
|
+
};
|
|
80
|
+
exports.default = BranchProtect;
|
|
81
|
+
//# sourceMappingURL=protect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protect.js","sourceRoot":"","sources":["../../../src/commands/branch/protect.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CollaboratorAdd extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
username: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
permission: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
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 collaborators_1 = require("../../api/collaborators");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CollaboratorAdd extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(CollaboratorAdd);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
16
|
+
try {
|
|
17
|
+
const collaborator = await (0, collaborators_1.addCollaborator)(token, owner, repo, args.username, {
|
|
18
|
+
permission: flags.permission,
|
|
19
|
+
});
|
|
20
|
+
if (flags.json) {
|
|
21
|
+
(0, index_2.printJson)(collaborator);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
this.log(`Added ${args.username} as a collaborator with ${flags.permission} permission`);
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
if (err instanceof client_1.GitCodeError)
|
|
28
|
+
this.error(err.message);
|
|
29
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
CollaboratorAdd.description = 'Add a collaborator to the repository';
|
|
34
|
+
CollaboratorAdd.examples = [
|
|
35
|
+
'<%= config.bin %> collaborator add bob',
|
|
36
|
+
'<%= config.bin %> collaborator add bob --permission admin',
|
|
37
|
+
];
|
|
38
|
+
CollaboratorAdd.args = {
|
|
39
|
+
username: core_1.Args.string({ description: 'Username to add', required: true }),
|
|
40
|
+
};
|
|
41
|
+
CollaboratorAdd.flags = {
|
|
42
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
43
|
+
permission: core_1.Flags.string({
|
|
44
|
+
description: 'Permission level',
|
|
45
|
+
options: ['pull', 'triage', 'push', 'maintain', 'admin'],
|
|
46
|
+
default: 'push',
|
|
47
|
+
}),
|
|
48
|
+
};
|
|
49
|
+
exports.default = CollaboratorAdd;
|
|
50
|
+
//# sourceMappingURL=add.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/commands/collaborator/add.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,2DAAyD;AACzD,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,eAAgB,SAAQ,0BAAW;IAoBtD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAA;QAEzD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QAExD,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,MAAM,IAAA,+BAAe,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE;gBAC5E,UAAU,EAAE,KAAK,CAAC,UAA+D;aAClF,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,YAAY,CAAC,CAAA;gBACvB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,QAAQ,2BAA2B,KAAK,CAAC,UAAU,aAAa,CAAC,CAAA;QAC1F,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;;AA1CM,2BAAW,GAAG,sCAAsC,CAAA;AACpD,wBAAQ,GAAG;IAChB,wCAAwC;IACxC,2DAA2D;CAC5D,CAAA;AAEM,oBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,iBAAiB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAC1E,CAAA;AAEM,qBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,UAAU,EAAE,YAAK,CAAC,MAAM,CAAC;QACvB,WAAW,EAAE,kBAAkB;QAC/B,OAAO,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC;QACxD,OAAO,EAAE,MAAM;KAChB,CAAC;CACH,CAAA;kBAlBkB,eAAe"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CollaboratorList extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
7
|
+
'per-page': import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
8
|
+
affiliation: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
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 collaborators_1 = require("../../api/collaborators");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CollaboratorList extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { flags } = await this.parse(CollaboratorList);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
16
|
+
try {
|
|
17
|
+
const collaborators = await (0, collaborators_1.listCollaborators)(token, owner, repo, {
|
|
18
|
+
page: flags.page,
|
|
19
|
+
per_page: flags['per-page'],
|
|
20
|
+
affiliation: flags.affiliation,
|
|
21
|
+
});
|
|
22
|
+
if (flags.json) {
|
|
23
|
+
(0, index_2.printJson)(collaborators);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
(0, index_2.printTable)(collaborators.map((c) => {
|
|
27
|
+
let perm = 'none';
|
|
28
|
+
if (c.permissions?.admin)
|
|
29
|
+
perm = 'admin';
|
|
30
|
+
else if (c.permissions?.maintain)
|
|
31
|
+
perm = 'maintain';
|
|
32
|
+
else if (c.permissions?.push)
|
|
33
|
+
perm = 'write';
|
|
34
|
+
else if (c.permissions?.triage)
|
|
35
|
+
perm = 'triage';
|
|
36
|
+
else if (c.permissions?.pull)
|
|
37
|
+
perm = 'read';
|
|
38
|
+
return { login: c.login, permission: perm };
|
|
39
|
+
}), ['login', 'permission']);
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
if (err instanceof client_1.GitCodeError)
|
|
43
|
+
this.error(err.message);
|
|
44
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
CollaboratorList.description = 'List repository collaborators';
|
|
49
|
+
CollaboratorList.examples = ['<%= config.bin %> collaborator list'];
|
|
50
|
+
CollaboratorList.flags = {
|
|
51
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
52
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
53
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page', default: 30 }),
|
|
54
|
+
affiliation: core_1.Flags.string({
|
|
55
|
+
description: 'Filter by affiliation',
|
|
56
|
+
options: ['outside', 'direct', 'all'],
|
|
57
|
+
default: 'all',
|
|
58
|
+
}),
|
|
59
|
+
};
|
|
60
|
+
exports.default = CollaboratorList;
|
|
61
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/collaborator/list.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAgD;AAChD,8CAA6C;AAC7C,2DAA2D;AAC3D,6CAA+C;AAC/C,0CAAsD;AAEtD,MAAqB,gBAAiB,SAAQ,0BAAW;IAevD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAA;QAEpD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QAExD,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,MAAM,IAAA,iCAAiB,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE;gBAChE,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;gBAC3B,WAAW,EAAE,KAAK,CAAC,WAA2C;aAC/D,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,aAAa,CAAC,CAAA;gBACxB,OAAM;YACR,CAAC;YAED,IAAA,kBAAU,EACR,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACtB,IAAI,IAAI,GAAG,MAAM,CAAA;gBACjB,IAAI,CAAC,CAAC,WAAW,EAAE,KAAK;oBAAE,IAAI,GAAG,OAAO,CAAA;qBACnC,IAAI,CAAC,CAAC,WAAW,EAAE,QAAQ;oBAAE,IAAI,GAAG,UAAU,CAAA;qBAC9C,IAAI,CAAC,CAAC,WAAW,EAAE,IAAI;oBAAE,IAAI,GAAG,OAAO,CAAA;qBACvC,IAAI,CAAC,CAAC,WAAW,EAAE,MAAM;oBAAE,IAAI,GAAG,QAAQ,CAAA;qBAC1C,IAAI,CAAC,CAAC,WAAW,EAAE,IAAI;oBAAE,IAAI,GAAG,MAAM,CAAA;gBAC3C,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,CAAA;YAC7C,CAAC,CAAC,EACF,CAAC,OAAO,EAAE,YAAY,CAAC,CACxB,CAAA;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;;AAlDM,4BAAW,GAAG,+BAA+B,CAAA;AAC7C,yBAAQ,GAAG,CAAC,qCAAqC,CAAC,CAAA;AAElD,sBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IAC/D,UAAU,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,kBAAkB,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC3E,WAAW,EAAE,YAAK,CAAC,MAAM,CAAC;QACxB,WAAW,EAAE,uBAAuB;QACpC,OAAO,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,KAAK,CAAC;QACrC,OAAO,EAAE,KAAK;KACf,CAAC;CACH,CAAA;kBAbkB,gBAAgB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CollaboratorPermission extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
username: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
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 collaborators_1 = require("../../api/collaborators");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CollaboratorPermission extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(CollaboratorPermission);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
16
|
+
try {
|
|
17
|
+
const result = await (0, collaborators_1.getCollaboratorPermission)(token, owner, repo, args.username);
|
|
18
|
+
if (flags.json) {
|
|
19
|
+
(0, index_2.printJson)(result);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.log(`User: ${result.user.login}`);
|
|
23
|
+
this.log(`Permission: ${result.permission}`);
|
|
24
|
+
}
|
|
25
|
+
catch (err) {
|
|
26
|
+
if (err instanceof client_1.GitCodeError)
|
|
27
|
+
this.error(err.message);
|
|
28
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
CollaboratorPermission.description = 'Get collaborator permission level';
|
|
33
|
+
CollaboratorPermission.examples = ['<%= config.bin %> collaborator permission bob'];
|
|
34
|
+
CollaboratorPermission.args = {
|
|
35
|
+
username: core_1.Args.string({ description: 'Username to check', required: true }),
|
|
36
|
+
};
|
|
37
|
+
CollaboratorPermission.flags = { ...repo_command_1.RepoCommand.repoFlags };
|
|
38
|
+
exports.default = CollaboratorPermission;
|
|
39
|
+
//# sourceMappingURL=permission.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.js","sourceRoot":"","sources":["../../../src/commands/collaborator/permission.ts"],"names":[],"mappings":";;AAAA,sCAAkC;AAClC,qDAAgD;AAChD,8CAA6C;AAC7C,2DAAmE;AACnE,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,sBAAuB,SAAQ,0BAAW;IAU7D,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAA;QAEhE,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QAExD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAA,yCAAyB,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;YAEjF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;gBACjB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;YAC5C,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,UAAU,EAAE,CAAC,CAAA;QAC9C,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;;AA/BM,kCAAW,GAAG,mCAAmC,CAAA;AACjD,+BAAQ,GAAG,CAAC,+CAA+C,CAAC,CAAA;AAE5D,2BAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAC5E,CAAA;AAEM,4BAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBARxB,sBAAsB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CollaboratorRemove extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
username: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
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 collaborators_1 = require("../../api/collaborators");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
class CollaboratorRemove extends repo_command_1.RepoCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { args, flags } = await this.parse(CollaboratorRemove);
|
|
11
|
+
const token = (0, index_1.getToken)();
|
|
12
|
+
if (!token)
|
|
13
|
+
this.error('Not logged in. Run: gc auth login');
|
|
14
|
+
const { owner, repo } = this.resolveRepoFromFlags(flags);
|
|
15
|
+
try {
|
|
16
|
+
await (0, collaborators_1.removeCollaborator)(token, owner, repo, args.username);
|
|
17
|
+
if (flags.json) {
|
|
18
|
+
process.stdout.write(JSON.stringify({ removed: true }) + '\n');
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
this.log(`Removed ${args.username} from collaborators`);
|
|
22
|
+
}
|
|
23
|
+
catch (err) {
|
|
24
|
+
if (err instanceof client_1.GitCodeError)
|
|
25
|
+
this.error(err.message);
|
|
26
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
CollaboratorRemove.description = 'Remove a collaborator from the repository';
|
|
31
|
+
CollaboratorRemove.examples = ['<%= config.bin %> collaborator remove bob'];
|
|
32
|
+
CollaboratorRemove.args = {
|
|
33
|
+
username: core_1.Args.string({ description: 'Username to remove', required: true }),
|
|
34
|
+
};
|
|
35
|
+
CollaboratorRemove.flags = { ...repo_command_1.RepoCommand.repoFlags };
|
|
36
|
+
exports.default = CollaboratorRemove;
|
|
37
|
+
//# sourceMappingURL=remove.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove.js","sourceRoot":"","sources":["../../../src/commands/collaborator/remove.ts"],"names":[],"mappings":";;AAAA,sCAAkC;AAClC,qDAAgD;AAChD,8CAA6C;AAC7C,2DAA4D;AAC5D,6CAA+C;AAE/C,MAAqB,kBAAmB,SAAQ,0BAAW;IAUzD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAA;QAE5D,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QAExD,IAAI,CAAC;YACH,MAAM,IAAA,kCAAkB,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;YAE3D,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC,CAAA;gBAC9D,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,QAAQ,qBAAqB,CAAC,CAAA;QACzD,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;;AA9BM,8BAAW,GAAG,2CAA2C,CAAA;AACzD,2BAAQ,GAAG,CAAC,2CAA2C,CAAC,CAAA;AAExD,uBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,oBAAoB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAC7E,CAAA;AAEM,wBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBARxB,kBAAkB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CommitCompare extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
base: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
head: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
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 repos_1 = require("../../api/repos");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CommitCompare extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(CommitCompare);
|
|
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, repos_1.compareCommits)(token, owner, repo, args.base, args.head);
|
|
25
|
+
if (flags.json) {
|
|
26
|
+
(0, index_2.printJson)(result);
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
this.log(`Comparing ${args.base}...${args.head}`);
|
|
30
|
+
this.log(`Status: ${result.status}`);
|
|
31
|
+
this.log(`Ahead by: ${result.ahead_by} commits`);
|
|
32
|
+
this.log(`Behind by: ${result.behind_by} commits`);
|
|
33
|
+
this.log(`URL: ${result.html_url}`);
|
|
34
|
+
this.log('');
|
|
35
|
+
if (result.commits.length > 0) {
|
|
36
|
+
this.log('Commits:');
|
|
37
|
+
(0, index_2.printTable)(result.commits.map((c) => ({
|
|
38
|
+
sha: c.sha.substring(0, 7),
|
|
39
|
+
author: c.author?.login || c.commit.author.name,
|
|
40
|
+
date: (0, index_2.formatDate)(c.commit.author.date),
|
|
41
|
+
message: c.commit.message.split('\n')[0].substring(0, 40),
|
|
42
|
+
})), ['sha', 'author', 'date', 'message']);
|
|
43
|
+
}
|
|
44
|
+
if (result.files && result.files.length > 0) {
|
|
45
|
+
this.log('');
|
|
46
|
+
this.log(`Files changed (${result.files.length}):`);
|
|
47
|
+
for (const file of result.files.slice(0, 20)) {
|
|
48
|
+
this.log(` ${file.status} ${file.filename}`);
|
|
49
|
+
}
|
|
50
|
+
if (result.files.length > 20) {
|
|
51
|
+
this.log(` ... and ${result.files.length - 20} more`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
catch (err) {
|
|
56
|
+
if (err instanceof client_1.GitCodeError)
|
|
57
|
+
this.error(err.message);
|
|
58
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
CommitCompare.description = 'Compare two commits or branches';
|
|
63
|
+
CommitCompare.examples = [
|
|
64
|
+
'<%= config.bin %> commit compare main feature',
|
|
65
|
+
'<%= config.bin %> commit compare abc123 def456',
|
|
66
|
+
];
|
|
67
|
+
CommitCompare.args = {
|
|
68
|
+
base: core_1.Args.string({ description: 'Base branch or commit SHA', required: true }),
|
|
69
|
+
head: core_1.Args.string({ description: 'Head branch or commit SHA', required: true }),
|
|
70
|
+
};
|
|
71
|
+
CommitCompare.flags = { ...repo_command_1.RepoCommand.repoFlags };
|
|
72
|
+
exports.default = CommitCompare;
|
|
73
|
+
//# sourceMappingURL=compare.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compare.js","sourceRoot":"","sources":["../../../src/commands/commit/compare.ts"],"names":[],"mappings":";;AAAA,sCAAkC;AAClC,qDAAgD;AAChD,8CAA6C;AAC7C,2CAAgD;AAChD,6CAA+C;AAC/C,0CAAkE;AAElE,MAAqB,aAAc,SAAQ,0BAAW;IAcpD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QAEvD,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,sBAAc,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;YAE7E,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;gBACjB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,aAAa,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAA;YACjD,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,MAAM,EAAE,CAAC,CAAA;YACxC,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,QAAQ,UAAU,CAAC,CAAA;YAClD,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,SAAS,UAAU,CAAC,CAAA;YACnD,IAAI,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAA;YAC1C,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;YAEZ,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC9B,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;gBACpB,IAAA,kBAAU,EACR,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;oBACzB,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;oBAC1B,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI;oBAC/C,IAAI,EAAE,IAAA,kBAAU,EAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC;oBACtC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;iBAC1D,CAAC,CAAC,EACH,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,CACrC,CAAA;YACH,CAAC;YAED,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBACZ,IAAI,CAAC,GAAG,CAAC,kBAAkB,MAAM,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,CAAA;gBACnD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;oBAC7C,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;gBAC/C,CAAC;gBACD,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC;oBAC7B,IAAI,CAAC,GAAG,CAAC,aAAa,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,OAAO,CAAC,CAAA;gBACxD,CAAC;YACH,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;;AApEM,yBAAW,GAAG,iCAAiC,CAAA;AAC/C,sBAAQ,GAAG;IAChB,+CAA+C;IAC/C,gDAAgD;CACjD,CAAA;AAEM,kBAAI,GAAG;IACZ,IAAI,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,2BAA2B,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/E,IAAI,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,2BAA2B,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChF,CAAA;AAEM,mBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBAZxB,aAAa"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CommitDiff extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
sha: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
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 repos_1 = require("../../api/repos");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CommitDiff extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(CommitDiff);
|
|
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 commit = await (0, repos_1.getCommit)(token, owner, repo, args.sha);
|
|
25
|
+
if (flags.json) {
|
|
26
|
+
(0, index_2.printJson)(commit.files);
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
if (!commit.files || commit.files.length === 0) {
|
|
30
|
+
this.log('No diff available for this commit');
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
for (const file of commit.files) {
|
|
34
|
+
this.log(`diff --git a/${file.filename} b/${file.filename}`);
|
|
35
|
+
this.log(`status: ${file.status} +${file.additions} -${file.deletions}`);
|
|
36
|
+
if (file.patch) {
|
|
37
|
+
this.log(file.patch);
|
|
38
|
+
}
|
|
39
|
+
this.log('');
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
catch (err) {
|
|
43
|
+
if (err instanceof client_1.GitCodeError)
|
|
44
|
+
this.error(err.message);
|
|
45
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
CommitDiff.description = 'Show commit diff';
|
|
50
|
+
CommitDiff.examples = ['<%= config.bin %> commit diff abc123'];
|
|
51
|
+
CommitDiff.args = {
|
|
52
|
+
sha: core_1.Args.string({ description: 'Commit SHA', required: true }),
|
|
53
|
+
};
|
|
54
|
+
CommitDiff.flags = { ...repo_command_1.RepoCommand.repoFlags };
|
|
55
|
+
exports.default = CommitDiff;
|
|
56
|
+
//# sourceMappingURL=diff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../../src/commands/commit/diff.ts"],"names":[],"mappings":";;AAAA,sCAAkC;AAClC,qDAAgD;AAChD,8CAA6C;AAC7C,2CAA2C;AAC3C,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,UAAW,SAAQ,0BAAW;IAUjD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAEpD,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,iBAAS,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAA;YAE5D,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBACvB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC/C,IAAI,CAAC,GAAG,CAAC,mCAAmC,CAAC,CAAA;gBAC7C,OAAM;YACR,CAAC;YAED,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBAChC,IAAI,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,QAAQ,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;gBAC5D,IAAI,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,MAAM,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;gBACzE,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;gBACtB,CAAC;gBACD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;YACd,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;;AA/CM,sBAAW,GAAG,kBAAkB,CAAA;AAChC,mBAAQ,GAAG,CAAC,sCAAsC,CAAC,CAAA;AAEnD,eAAI,GAAG;IACZ,GAAG,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChE,CAAA;AAEM,gBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBARxB,UAAU"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class CommitGet extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
sha: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
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 repos_1 = require("../../api/repos");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class CommitGet extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(CommitGet);
|
|
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 commit = await (0, repos_1.getCommit)(token, owner, repo, args.sha);
|
|
25
|
+
if (flags.json) {
|
|
26
|
+
(0, index_2.printJson)(commit);
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
this.log(`SHA: ${commit.sha}`);
|
|
30
|
+
this.log(`Author: ${commit.commit.author.name} <${commit.commit.author.email}>`);
|
|
31
|
+
this.log(`Date: ${(0, index_2.formatDate)(commit.commit.author.date)}`);
|
|
32
|
+
this.log(`Committer: ${commit.commit.committer.name}`);
|
|
33
|
+
this.log(`URL: ${commit.html_url}`);
|
|
34
|
+
this.log('');
|
|
35
|
+
this.log(commit.commit.message);
|
|
36
|
+
if (commit.stats) {
|
|
37
|
+
this.log('');
|
|
38
|
+
this.log(`Stats: ${commit.stats.additions} additions, ${commit.stats.deletions} deletions`);
|
|
39
|
+
}
|
|
40
|
+
if (commit.files && commit.files.length > 0) {
|
|
41
|
+
this.log('');
|
|
42
|
+
this.log(`Files (${commit.files.length}):`);
|
|
43
|
+
for (const file of commit.files.slice(0, 10)) {
|
|
44
|
+
this.log(` ${file.status.padEnd(1)} ${file.filename}`);
|
|
45
|
+
}
|
|
46
|
+
if (commit.files.length > 10) {
|
|
47
|
+
this.log(` ... and ${commit.files.length - 10} more`);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (err) {
|
|
52
|
+
if (err instanceof client_1.GitCodeError)
|
|
53
|
+
this.error(err.message);
|
|
54
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
CommitGet.description = 'Show commit details';
|
|
59
|
+
CommitGet.examples = ['<%= config.bin %> commit get abc123'];
|
|
60
|
+
CommitGet.args = {
|
|
61
|
+
sha: core_1.Args.string({ description: 'Commit SHA', required: true }),
|
|
62
|
+
};
|
|
63
|
+
CommitGet.flags = { ...repo_command_1.RepoCommand.repoFlags };
|
|
64
|
+
exports.default = CommitGet;
|
|
65
|
+
//# sourceMappingURL=get.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get.js","sourceRoot":"","sources":["../../../src/commands/commit/get.ts"],"names":[],"mappings":"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"}
|