@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,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const search_1 = require("../../api/search");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class SearchIssues extends base_command_1.BaseCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { flags, args } = await this.parse(SearchIssues);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
try {
|
|
16
|
+
const result = await (0, search_1.searchIssues)(token, {
|
|
17
|
+
q: args.query,
|
|
18
|
+
sort: flags.sort,
|
|
19
|
+
order: flags.order,
|
|
20
|
+
page: flags.page,
|
|
21
|
+
per_page: flags.limit,
|
|
22
|
+
});
|
|
23
|
+
if (flags.json) {
|
|
24
|
+
(0, index_2.printJson)(result);
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (result.items.length === 0) {
|
|
28
|
+
this.log('No issues found.');
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
this.log(`Found ${result.total_count} issues\n`);
|
|
32
|
+
(0, index_2.printTable)(result.items.map((i) => ({
|
|
33
|
+
number: i.number,
|
|
34
|
+
title: i.title.substring(0, 50),
|
|
35
|
+
state: i.state,
|
|
36
|
+
author: i.user.login,
|
|
37
|
+
repo: i.repository?.full_name || '-',
|
|
38
|
+
})), ['number', 'title', 'state', 'author', 'repo']);
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 404) {
|
|
42
|
+
this.log('Search API not available (endpoint may not be enabled).');
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 0) {
|
|
46
|
+
this.log('Search API not available (endpoint may not be enabled).');
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
if (err instanceof client_1.GitCodeError)
|
|
50
|
+
this.error(err.message);
|
|
51
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
SearchIssues.description = 'Search issues and pull requests';
|
|
56
|
+
SearchIssues.examples = [
|
|
57
|
+
'<%= config.bin %> search issues "memory leak"',
|
|
58
|
+
'<%= config.bin %> search issues "bug label:enhancement" --limit 10',
|
|
59
|
+
];
|
|
60
|
+
SearchIssues.args = {
|
|
61
|
+
query: core_1.Args.string({ description: 'Search query', required: true }),
|
|
62
|
+
};
|
|
63
|
+
SearchIssues.flags = {
|
|
64
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
65
|
+
sort: core_1.Flags.string({
|
|
66
|
+
description: 'Sort field',
|
|
67
|
+
options: ['created', 'updated', 'comments'],
|
|
68
|
+
}),
|
|
69
|
+
order: core_1.Flags.string({
|
|
70
|
+
description: 'Sort order',
|
|
71
|
+
options: ['asc', 'desc'],
|
|
72
|
+
}),
|
|
73
|
+
limit: core_1.Flags.integer({ description: 'Max results', default: 30 }),
|
|
74
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
75
|
+
};
|
|
76
|
+
exports.default = SearchIssues;
|
|
77
|
+
//# sourceMappingURL=issues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"issues.js","sourceRoot":"","sources":["../../../src/commands/search/issues.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class SearchRepos extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
query: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
sort: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
order: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
limit: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
page: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const index_1 = require("../../config/index");
|
|
6
|
+
const search_1 = require("../../api/search");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class SearchRepos extends base_command_1.BaseCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { flags, args } = await this.parse(SearchRepos);
|
|
12
|
+
const token = (0, index_1.getToken)();
|
|
13
|
+
if (!token)
|
|
14
|
+
this.error('Not logged in. Run: gc auth login');
|
|
15
|
+
try {
|
|
16
|
+
const result = await (0, search_1.searchRepos)(token, {
|
|
17
|
+
q: args.query,
|
|
18
|
+
sort: flags.sort,
|
|
19
|
+
order: flags.order,
|
|
20
|
+
page: flags.page,
|
|
21
|
+
per_page: flags.limit,
|
|
22
|
+
});
|
|
23
|
+
if (flags.json) {
|
|
24
|
+
(0, index_2.printJson)(result);
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (result.items.length === 0) {
|
|
28
|
+
this.log('No repositories found.');
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
this.log(`Found ${result.total_count} repositories\n`);
|
|
32
|
+
(0, index_2.printTable)(result.items.map((r) => ({
|
|
33
|
+
name: r.full_name,
|
|
34
|
+
stars: r.stargazers_count,
|
|
35
|
+
forks: r.forks_count,
|
|
36
|
+
language: r.language || '-',
|
|
37
|
+
description: (r.description || '').substring(0, 40),
|
|
38
|
+
})), ['name', 'stars', 'forks', 'language', 'description']);
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 404) {
|
|
42
|
+
this.log('Search API not available (endpoint may not be enabled).');
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 0) {
|
|
46
|
+
this.log('Search API not available (endpoint may not be enabled).');
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
if (err instanceof client_1.GitCodeError)
|
|
50
|
+
this.error(err.message);
|
|
51
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
SearchRepos.description = 'Search repositories';
|
|
56
|
+
SearchRepos.examples = [
|
|
57
|
+
'<%= config.bin %> search repos window',
|
|
58
|
+
'<%= config.bin %> search repos "window manager" --limit 10',
|
|
59
|
+
];
|
|
60
|
+
SearchRepos.args = {
|
|
61
|
+
query: core_1.Args.string({ description: 'Search query', required: true }),
|
|
62
|
+
};
|
|
63
|
+
SearchRepos.flags = {
|
|
64
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
65
|
+
sort: core_1.Flags.string({
|
|
66
|
+
description: 'Sort field',
|
|
67
|
+
options: ['stars', 'forks', 'updated'],
|
|
68
|
+
}),
|
|
69
|
+
order: core_1.Flags.string({
|
|
70
|
+
description: 'Sort order',
|
|
71
|
+
options: ['asc', 'desc'],
|
|
72
|
+
}),
|
|
73
|
+
limit: core_1.Flags.integer({ description: 'Max results', default: 30 }),
|
|
74
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
75
|
+
};
|
|
76
|
+
exports.default = SearchRepos;
|
|
77
|
+
//# sourceMappingURL=repos.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repos.js","sourceRoot":"","sources":["../../../src/commands/search/repos.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class TagList 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
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
10
|
+
};
|
|
11
|
+
run(): Promise<void>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
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 tags_1 = require("../../api/tags");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class TagList extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { flags } = await this.parse(TagList);
|
|
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 tags = await (0, tags_1.listTags)(token, owner, repo, {
|
|
18
|
+
page: flags.page,
|
|
19
|
+
per_page: flags['per-page'],
|
|
20
|
+
});
|
|
21
|
+
if (flags.json) {
|
|
22
|
+
(0, index_2.printJson)(tags);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
(0, index_2.printTable)(tags.map((t) => ({
|
|
26
|
+
name: t.name,
|
|
27
|
+
sha: t.commit.sha.substring(0, 7),
|
|
28
|
+
})), ['name', 'sha']);
|
|
29
|
+
}
|
|
30
|
+
catch (err) {
|
|
31
|
+
if (err instanceof client_1.GitCodeError)
|
|
32
|
+
this.error(err.message);
|
|
33
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
TagList.description = 'List repository tags';
|
|
38
|
+
TagList.examples = ['<%= config.bin %> tag list'];
|
|
39
|
+
TagList.flags = {
|
|
40
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
41
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
42
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page', default: 30 }),
|
|
43
|
+
};
|
|
44
|
+
exports.default = TagList;
|
|
45
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/tag/list.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAgD;AAChD,8CAA6C;AAC7C,yCAAyC;AACzC,6CAA+C;AAC/C,0CAAsD;AAEtD,MAAqB,OAAQ,SAAQ,0BAAW;IAU9C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAE3C,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,IAAI,GAAG,MAAM,IAAA,eAAQ,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE;gBAC9C,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;aAC5B,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,IAAI,CAAC,CAAA;gBACf,OAAM;YACR,CAAC;YAED,IAAA,kBAAU,EACR,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACf,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;aAClC,CAAC,CAAC,EACH,CAAC,MAAM,EAAE,KAAK,CAAC,CAChB,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;;AAvCM,mBAAW,GAAG,sBAAsB,CAAA;AACpC,gBAAQ,GAAG,CAAC,4BAA4B,CAAC,CAAA;AAEzC,aAAK,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;CAC5E,CAAA;kBARkB,OAAO"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { RepoCommand } from '../../repo-command';
|
|
2
|
+
export default class TagProtect extends RepoCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
tag: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
unprotect: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
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,53 @@
|
|
|
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 tags_1 = require("../../api/tags");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const index_2 = require("../../ui/index");
|
|
9
|
+
class TagProtect extends repo_command_1.RepoCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { args, flags } = await this.parse(TagProtect);
|
|
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
|
+
if (flags.unprotect) {
|
|
18
|
+
await (0, tags_1.unprotectTag)(token, owner, repo, args.tag);
|
|
19
|
+
if (flags.json) {
|
|
20
|
+
(0, index_2.printJson)({ protected: false });
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
this.log(`Tag '${args.tag}' is no longer protected`);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const result = await (0, tags_1.protectTag)(token, owner, repo, args.tag);
|
|
27
|
+
if (flags.json) {
|
|
28
|
+
(0, index_2.printJson)(result);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
this.log(`Tag '${args.tag}' is now protected`);
|
|
32
|
+
}
|
|
33
|
+
catch (err) {
|
|
34
|
+
if (err instanceof client_1.GitCodeError)
|
|
35
|
+
this.error(err.message);
|
|
36
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
TagProtect.description = 'Protect or unprotect a tag';
|
|
41
|
+
TagProtect.examples = [
|
|
42
|
+
'<%= config.bin %> tag protect v1.0',
|
|
43
|
+
'<%= config.bin %> tag protect v1.0 --unprotect',
|
|
44
|
+
];
|
|
45
|
+
TagProtect.args = {
|
|
46
|
+
tag: core_1.Args.string({ description: 'Tag name', required: true }),
|
|
47
|
+
};
|
|
48
|
+
TagProtect.flags = {
|
|
49
|
+
...repo_command_1.RepoCommand.repoFlags,
|
|
50
|
+
unprotect: core_1.Flags.boolean({ description: 'Remove tag protection' }),
|
|
51
|
+
};
|
|
52
|
+
exports.default = TagProtect;
|
|
53
|
+
//# sourceMappingURL=protect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protect.js","sourceRoot":"","sources":["../../../src/commands/tag/protect.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,yCAAyD;AACzD,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAqB,UAAW,SAAQ,0BAAW;IAgBjD,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,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QAExD,IAAI,CAAC;YACH,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBACpB,MAAM,IAAA,mBAAY,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAA;gBAChD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;oBACf,IAAA,iBAAS,EAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;oBAC/B,OAAM;gBACR,CAAC;gBACD,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,GAAG,0BAA0B,CAAC,CAAA;gBACpD,OAAM;YACR,CAAC;YAED,MAAM,MAAM,GAAG,MAAM,IAAA,iBAAU,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAA;YAE7D,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;gBACjB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,GAAG,oBAAoB,CAAC,CAAA;QAChD,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;;AA9CM,sBAAW,GAAG,4BAA4B,CAAA;AAC1C,mBAAQ,GAAG;IAChB,oCAAoC;IACpC,gDAAgD;CACjD,CAAA;AAEM,eAAI,GAAG;IACZ,GAAG,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAC9D,CAAA;AAEM,gBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,SAAS,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,CAAC;CACnE,CAAA;kBAdkB,UAAU"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserEmails extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
};
|
|
8
|
+
run(): Promise<void>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
class UserEmails extends base_command_1.BaseCommand {
|
|
8
|
+
async run() {
|
|
9
|
+
const { flags } = await this.parse(UserEmails);
|
|
10
|
+
const token = (0, config_1.getToken)();
|
|
11
|
+
if (!token) {
|
|
12
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
13
|
+
}
|
|
14
|
+
const emails = await (0, user_1.getUserEmails)(token);
|
|
15
|
+
if (flags.json) {
|
|
16
|
+
(0, ui_1.printJson)(emails);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
(0, ui_1.printTable)(emails.map((e) => ({
|
|
20
|
+
email: e.email,
|
|
21
|
+
primary: e.primary ? '✓' : '',
|
|
22
|
+
verified: e.verified ? '✓' : '',
|
|
23
|
+
})), ['email', 'primary', 'verified']);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
UserEmails.description = 'List authenticated user emails';
|
|
28
|
+
UserEmails.examples = ['<%= config.bin %> user:emails'];
|
|
29
|
+
UserEmails.flags = {
|
|
30
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
31
|
+
};
|
|
32
|
+
exports.default = UserEmails;
|
|
33
|
+
//# sourceMappingURL=emails.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"emails.js","sourceRoot":"","sources":["../../../src/commands/user/emails.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAA8C;AAC9C,yCAAuC;AACvC,iCAAgD;AAEhD,MAAqB,UAAW,SAAQ,0BAAW;IASjD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAC9C,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,MAAM,GAAG,MAAM,IAAA,oBAAa,EAAC,KAAK,CAAC,CAAA;QAEzC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,MAAM,CAAC,CAAA;QACnB,CAAC;aAAM,CAAC;YACN,IAAA,eAAU,EACR,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACjB,KAAK,EAAE,CAAC,CAAC,KAAK;gBACd,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAC7B,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;aAChC,CAAC,CAAC,EACH,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,CACjC,CAAA;QACH,CAAC;IACH,CAAC;;AA7BM,sBAAW,GAAG,gCAAgC,CAAA;AAE9C,mBAAQ,GAAG,CAAC,+BAA+B,CAAC,CAAA;AAE5C,gBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;CACzB,CAAA;kBAPkB,UAAU"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserFollowers extends BaseCommand {
|
|
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
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
username: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const base_command_1 = require("../../base-command");
|
|
37
|
+
const user_1 = require("../../api/user");
|
|
38
|
+
const config_1 = require("../../config");
|
|
39
|
+
const ui_1 = require("../../ui");
|
|
40
|
+
const client_1 = require("../../api/client");
|
|
41
|
+
const core_1 = require("@oclif/core");
|
|
42
|
+
class UserFollowers extends base_command_1.BaseCommand {
|
|
43
|
+
async run() {
|
|
44
|
+
const { flags, args } = await this.parse(UserFollowers);
|
|
45
|
+
const token = (0, config_1.getToken)();
|
|
46
|
+
if (!token) {
|
|
47
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
// If no username provided, get current user first
|
|
51
|
+
const { getCurrentUser } = await Promise.resolve().then(() => __importStar(require('../../api/user')));
|
|
52
|
+
const username = args.username || (await getCurrentUser(token)).login;
|
|
53
|
+
const followers = await (0, user_1.getUserFollowers)(token, username, {
|
|
54
|
+
page: flags.page,
|
|
55
|
+
per_page: flags['per-page'],
|
|
56
|
+
});
|
|
57
|
+
if (flags.json) {
|
|
58
|
+
(0, ui_1.printJson)(followers);
|
|
59
|
+
}
|
|
60
|
+
else if (followers.length === 0) {
|
|
61
|
+
this.log('No followers found.');
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
(0, ui_1.printTable)(followers, ['login', 'name']);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 404) {
|
|
69
|
+
this.log('No followers found (API endpoint may not be available).');
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (err instanceof client_1.GitCodeError)
|
|
73
|
+
this.error(err.message);
|
|
74
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
UserFollowers.description = 'List user followers';
|
|
79
|
+
UserFollowers.examples = [
|
|
80
|
+
'<%= config.bin %> user:followers',
|
|
81
|
+
'<%= config.bin %> user:followers alice',
|
|
82
|
+
];
|
|
83
|
+
UserFollowers.flags = {
|
|
84
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
85
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
86
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page', default: 30 }),
|
|
87
|
+
};
|
|
88
|
+
UserFollowers.args = {
|
|
89
|
+
username: core_1.Args.string({ description: 'Username (defaults to current user)' }),
|
|
90
|
+
};
|
|
91
|
+
exports.default = UserFollowers;
|
|
92
|
+
//# sourceMappingURL=followers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"followers.js","sourceRoot":"","sources":["../../../src/commands/user/followers.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAgD;AAChD,yCAAiD;AACjD,yCAAuC;AACvC,iCAAgD;AAChD,6CAA+C;AAC/C,sCAAyC;AAEzC,MAAqB,aAAc,SAAQ,0BAAW;IAkBpD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACvD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,IAAI,CAAC;YACH,kDAAkD;YAClD,MAAM,EAAE,cAAc,EAAE,GAAG,wDAAa,gBAAgB,GAAC,CAAA;YACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAA;YAErE,MAAM,SAAS,GAAG,MAAM,IAAA,uBAAgB,EAAC,KAAK,EAAE,QAAQ,EAAE;gBACxD,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;aAC5B,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,cAAS,EAAC,SAAS,CAAC,CAAA;YACtB,CAAC;iBAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;YACjC,CAAC;iBAAM,CAAC;gBACN,IAAA,eAAU,EAAC,SAAS,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;YAC1C,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;gBAC1D,IAAI,CAAC,GAAG,CAAC,yDAAyD,CAAC,CAAA;gBACnE,OAAM;YACR,CAAC;YACD,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;;AAjDM,yBAAW,GAAG,qBAAqB,CAAA;AAEnC,sBAAQ,GAAG;IAChB,kCAAkC;IAClC,wCAAwC;CACzC,CAAA;AAEM,mBAAK,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;CAC5E,CAAA;AAEM,kBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;CAC9E,CAAA;kBAhBkB,aAAa"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserFollowing extends BaseCommand {
|
|
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
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
username: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const client_1 = require("../../api/client");
|
|
8
|
+
const core_1 = require("@oclif/core");
|
|
9
|
+
class UserFollowing extends base_command_1.BaseCommand {
|
|
10
|
+
async run() {
|
|
11
|
+
const { flags, args } = await this.parse(UserFollowing);
|
|
12
|
+
const token = (0, config_1.getToken)();
|
|
13
|
+
if (!token) {
|
|
14
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
const username = args.username || (await (0, user_1.getCurrentUser)(token)).login;
|
|
18
|
+
const following = await (0, user_1.getUserFollowing)(token, username, {
|
|
19
|
+
page: flags.page,
|
|
20
|
+
per_page: flags['per-page'],
|
|
21
|
+
});
|
|
22
|
+
if (flags.json) {
|
|
23
|
+
(0, ui_1.printJson)(following);
|
|
24
|
+
}
|
|
25
|
+
else if (following.length === 0) {
|
|
26
|
+
this.log('Not following anyone.');
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
(0, ui_1.printTable)(following, ['login', 'name']);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
if (err instanceof client_1.GitCodeError && err.statusCode === 404) {
|
|
34
|
+
this.log('Not following anyone (API endpoint may not be available).');
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
if (err instanceof client_1.GitCodeError)
|
|
38
|
+
this.error(err.message);
|
|
39
|
+
this.error('Could not connect to GitCode. Check your internet connection.');
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
UserFollowing.description = 'List users that a user is following';
|
|
44
|
+
UserFollowing.examples = [
|
|
45
|
+
'<%= config.bin %> user:following',
|
|
46
|
+
'<%= config.bin %> user:following alice',
|
|
47
|
+
];
|
|
48
|
+
UserFollowing.flags = {
|
|
49
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
50
|
+
page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
|
|
51
|
+
'per-page': core_1.Flags.integer({ description: 'Results per page', default: 30 }),
|
|
52
|
+
};
|
|
53
|
+
UserFollowing.args = {
|
|
54
|
+
username: core_1.Args.string({ description: 'Username (defaults to current user)' }),
|
|
55
|
+
};
|
|
56
|
+
exports.default = UserFollowing;
|
|
57
|
+
//# sourceMappingURL=following.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"following.js","sourceRoot":"","sources":["../../../src/commands/user/following.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAAiE;AACjE,yCAAuC;AACvC,iCAAgD;AAChD,6CAA+C;AAC/C,sCAAyC;AAEzC,MAAqB,aAAc,SAAQ,0BAAW;IAkBpD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACvD,MAAM,KAAK,GAAG,IAAA,iBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAA;QACxD,CAAC;QAED,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM,IAAA,qBAAc,EAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAA;YAErE,MAAM,SAAS,GAAG,MAAM,IAAA,uBAAgB,EAAC,KAAK,EAAE,QAAQ,EAAE;gBACxD,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;aAC5B,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,cAAS,EAAC,SAAS,CAAC,CAAA;YACtB,CAAC;iBAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAA;YACnC,CAAC;iBAAM,CAAC;gBACN,IAAA,eAAU,EAAC,SAAS,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;YAC1C,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;gBAC1D,IAAI,CAAC,GAAG,CAAC,2DAA2D,CAAC,CAAA;gBACrE,OAAM;YACR,CAAC;YACD,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,yBAAW,GAAG,qCAAqC,CAAA;AAEnD,sBAAQ,GAAG;IAChB,kCAAkC;IAClC,wCAAwC;CACzC,CAAA;AAEM,mBAAK,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;CAC5E,CAAA;AAEM,kBAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;CAC9E,CAAA;kBAhBkB,aAAa"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class UserView extends BaseCommand {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
};
|
|
8
|
+
static args: {
|
|
9
|
+
username: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
10
|
+
};
|
|
11
|
+
run(): Promise<void>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_command_1 = require("../../base-command");
|
|
4
|
+
const user_1 = require("../../api/user");
|
|
5
|
+
const config_1 = require("../../config");
|
|
6
|
+
const ui_1 = require("../../ui");
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
class UserView extends base_command_1.BaseCommand {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(UserView);
|
|
11
|
+
const token = (0, config_1.getToken)();
|
|
12
|
+
if (!token) {
|
|
13
|
+
this.error('Not authenticated. Run: oh-gc auth:login');
|
|
14
|
+
}
|
|
15
|
+
const user = args.username
|
|
16
|
+
? await (0, user_1.getUser)(token, args.username)
|
|
17
|
+
: await (0, user_1.getCurrentUser)(token);
|
|
18
|
+
if (flags.json) {
|
|
19
|
+
(0, ui_1.printJson)(user);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
this.log(`Login: ${user.login}`);
|
|
23
|
+
this.log(`Name: ${user.name || 'N/A'}`);
|
|
24
|
+
this.log(`Bio: ${user.bio || 'N/A'}`);
|
|
25
|
+
this.log(`Location: ${user.location || 'N/A'}`);
|
|
26
|
+
this.log(`Company: ${user.company || 'N/A'}`);
|
|
27
|
+
this.log(`Blog: ${user.blog || 'N/A'}`);
|
|
28
|
+
this.log(`Public repos: ${user.public_repos || 0}`);
|
|
29
|
+
this.log(`Followers: ${user.followers || 0}`);
|
|
30
|
+
this.log(`Following: ${user.following || 0}`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
UserView.description = 'View user profile';
|
|
35
|
+
UserView.examples = [
|
|
36
|
+
'<%= config.bin %> user:view',
|
|
37
|
+
'<%= config.bin %> user:view alice',
|
|
38
|
+
];
|
|
39
|
+
UserView.flags = {
|
|
40
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
41
|
+
};
|
|
42
|
+
UserView.args = {
|
|
43
|
+
username: core_1.Args.string({ description: 'Username (defaults to current user)' }),
|
|
44
|
+
};
|
|
45
|
+
exports.default = UserView;
|
|
46
|
+
//# sourceMappingURL=view.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"view.js","sourceRoot":"","sources":["../../../src/commands/user/view.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,yCAAwD;AACxD,yCAAuC;AACvC,iCAAoC;AACpC,sCAAkC;AAElC,MAAqB,QAAS,SAAQ,0BAAW;IAgB/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,IAAI,GAAG,IAAI,CAAC,QAAQ;YACxB,CAAC,CAAC,MAAM,IAAA,cAAO,EAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC;YACrC,CAAC,CAAC,MAAM,IAAA,qBAAc,EAAC,KAAK,CAAC,CAAA;QAE/B,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,IAAA,cAAS,EAAC,IAAI,CAAC,CAAA;QACjB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,CAAC,UAAU,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;YAChC,IAAI,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,KAAK,EAAE,CAAC,CAAA;YACvC,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,GAAG,IAAI,KAAK,EAAE,CAAC,CAAA;YACrC,IAAI,CAAC,GAAG,CAAC,aAAa,IAAI,CAAC,QAAQ,IAAI,KAAK,EAAE,CAAC,CAAA;YAC/C,IAAI,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,OAAO,IAAI,KAAK,EAAE,CAAC,CAAA;YAC7C,IAAI,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,KAAK,EAAE,CAAC,CAAA;YACvC,IAAI,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,YAAY,IAAI,CAAC,EAAE,CAAC,CAAA;YACnD,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE,CAAC,CAAA;YAC7C,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE,CAAC,CAAA;QAC/C,CAAC;IACH,CAAC;;AAvCM,oBAAW,GAAG,mBAAmB,CAAA;AAEjC,iBAAQ,GAAG;IAChB,6BAA6B;IAC7B,mCAAmC;CACpC,CAAA;AAEM,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;CACzB,CAAA;AAEM,aAAI,GAAG;IACZ,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;CAC9E,CAAA;kBAdkB,QAAQ"}
|
package/dist/git/index.js
CHANGED
|
@@ -39,7 +39,7 @@ function setConfiguredRemote(remote) {
|
|
|
39
39
|
}
|
|
40
40
|
function getRemoteUrl(remote) {
|
|
41
41
|
try {
|
|
42
|
-
return (0, node_child_process_1.execSync)(`git remote get-url ${remote}`, { encoding: 'utf8' }).trim();
|
|
42
|
+
return (0, node_child_process_1.execSync)(`git remote get-url ${remote} 2>/dev/null`, { encoding: 'utf8' }).trim();
|
|
43
43
|
}
|
|
44
44
|
catch {
|
|
45
45
|
throw new Error(`Remote "${remote}" not found. Are you in a git repository?`);
|