@oh-gc/cli 0.6.1 → 0.7.2

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.
Files changed (181) hide show
  1. package/README.md +139 -89
  2. package/dist/api/issues.d.ts +43 -0
  3. package/dist/api/issues.js +33 -0
  4. package/dist/api/issues.js.map +1 -1
  5. package/dist/api/prs.d.ts +52 -0
  6. package/dist/api/prs.js +63 -0
  7. package/dist/api/prs.js.map +1 -1
  8. package/dist/api/repos.d.ts +186 -0
  9. package/dist/api/repos.js +155 -0
  10. package/dist/api/repos.js.map +1 -1
  11. package/dist/api/tags.d.ts +25 -0
  12. package/dist/api/tags.js +34 -0
  13. package/dist/api/tags.js.map +1 -1
  14. package/dist/commands/branch/create.d.ts +14 -0
  15. package/dist/commands/branch/create.js +48 -0
  16. package/dist/commands/branch/create.js.map +1 -0
  17. package/dist/commands/branch/delete.d.ts +13 -0
  18. package/dist/commands/branch/delete.js +42 -0
  19. package/dist/commands/branch/delete.js.map +1 -0
  20. package/dist/commands/branch/protect-rule-create.d.ts +15 -0
  21. package/dist/commands/branch/protect-rule-create.js +53 -0
  22. package/dist/commands/branch/protect-rule-create.js.map +1 -0
  23. package/dist/commands/branch/protect-rule-delete.d.ts +13 -0
  24. package/dist/commands/branch/protect-rule-delete.js +42 -0
  25. package/dist/commands/branch/protect-rule-delete.js.map +1 -0
  26. package/dist/commands/branch/protect-rule-update.d.ts +15 -0
  27. package/dist/commands/branch/protect-rule-update.js +57 -0
  28. package/dist/commands/branch/protect-rule-update.js.map +1 -0
  29. package/dist/commands/branch/protect-rules.d.ts +12 -0
  30. package/dist/commands/branch/protect-rules.js +53 -0
  31. package/dist/commands/branch/protect-rules.js.map +1 -0
  32. package/dist/commands/commit/comment.d.ts +14 -0
  33. package/dist/commands/commit/comment.js +48 -0
  34. package/dist/commands/commit/comment.js.map +1 -0
  35. package/dist/commands/commit/comments.d.ts +15 -0
  36. package/dist/commands/commit/comments.js +57 -0
  37. package/dist/commands/commit/comments.js.map +1 -0
  38. package/dist/commands/file/create.d.ts +18 -0
  39. package/dist/commands/file/create.js +64 -0
  40. package/dist/commands/file/create.js.map +1 -0
  41. package/dist/commands/file/delete.d.ts +16 -0
  42. package/dist/commands/file/delete.js +56 -0
  43. package/dist/commands/file/delete.js.map +1 -0
  44. package/dist/commands/file/update.d.ts +19 -0
  45. package/dist/commands/file/update.js +69 -0
  46. package/dist/commands/file/update.js.map +1 -0
  47. package/dist/commands/issue/branches.d.ts +14 -0
  48. package/dist/commands/issue/branches.js +69 -0
  49. package/dist/commands/issue/branches.js.map +1 -0
  50. package/dist/commands/issue/close.js +1 -1
  51. package/dist/commands/issue/comment-delete.d.ts +16 -0
  52. package/dist/commands/issue/comment-delete.js +42 -0
  53. package/dist/commands/issue/comment-delete.js.map +1 -0
  54. package/dist/commands/issue/comment-edit.d.ts +17 -0
  55. package/dist/commands/issue/comment-edit.js +48 -0
  56. package/dist/commands/issue/comment-edit.js.map +1 -0
  57. package/dist/commands/issue/comment-get.d.ts +16 -0
  58. package/dist/commands/issue/comment-get.js +50 -0
  59. package/dist/commands/issue/comment-get.js.map +1 -0
  60. package/dist/commands/issue/comment-history.d.ts +16 -0
  61. package/dist/commands/issue/comment-history.js +51 -0
  62. package/dist/commands/issue/comment-history.js.map +1 -0
  63. package/dist/commands/issue/comment-reactions.d.ts +19 -0
  64. package/dist/commands/issue/comment-reactions.js +58 -0
  65. package/dist/commands/issue/comment-reactions.js.map +1 -0
  66. package/dist/commands/issue/history.js +1 -1
  67. package/dist/commands/issue/labels.js +1 -1
  68. package/dist/commands/issue/prs.d.ts +14 -0
  69. package/dist/commands/issue/prs.js +56 -0
  70. package/dist/commands/issue/prs.js.map +1 -0
  71. package/dist/commands/issue/reactions.js +1 -1
  72. package/dist/commands/issue/reopen.js +1 -1
  73. package/dist/commands/issue/update.js +1 -1
  74. package/dist/commands/pr/assignees.d.ts +20 -0
  75. package/dist/commands/pr/assignees.js +76 -0
  76. package/dist/commands/pr/assignees.js.map +1 -0
  77. package/dist/commands/pr/close.js +1 -1
  78. package/dist/commands/pr/comment-delete.d.ts +16 -0
  79. package/dist/commands/pr/comment-delete.js +42 -0
  80. package/dist/commands/pr/comment-delete.js.map +1 -0
  81. package/dist/commands/pr/comment-edit.d.ts +17 -0
  82. package/dist/commands/pr/comment-edit.js +48 -0
  83. package/dist/commands/pr/comment-edit.js.map +1 -0
  84. package/dist/commands/pr/comment-get.d.ts +16 -0
  85. package/dist/commands/pr/comment-get.js +49 -0
  86. package/dist/commands/pr/comment-get.js.map +1 -0
  87. package/dist/commands/pr/comment-history.d.ts +16 -0
  88. package/dist/commands/pr/comment-history.js +51 -0
  89. package/dist/commands/pr/comment-history.js.map +1 -0
  90. package/dist/commands/pr/comment-reactions.d.ts +19 -0
  91. package/dist/commands/pr/comment-reactions.js +58 -0
  92. package/dist/commands/pr/comment-reactions.js.map +1 -0
  93. package/dist/commands/pr/comment.js +1 -1
  94. package/dist/commands/pr/files.d.ts +16 -0
  95. package/dist/commands/pr/files.js +52 -0
  96. package/dist/commands/pr/files.js.map +1 -0
  97. package/dist/commands/pr/history.d.ts +16 -0
  98. package/dist/commands/pr/history.js +51 -0
  99. package/dist/commands/pr/history.js.map +1 -0
  100. package/dist/commands/pr/labels.d.ts +1 -0
  101. package/dist/commands/pr/labels.js +18 -0
  102. package/dist/commands/pr/labels.js.map +1 -1
  103. package/dist/commands/pr/linked-issues.d.ts +18 -0
  104. package/dist/commands/pr/linked-issues.js +56 -0
  105. package/dist/commands/pr/linked-issues.js.map +1 -0
  106. package/dist/commands/pr/option-reviewers.d.ts +16 -0
  107. package/dist/commands/pr/option-reviewers.js +50 -0
  108. package/dist/commands/pr/option-reviewers.js.map +1 -0
  109. package/dist/commands/pr/reactions.js +1 -1
  110. package/dist/commands/pr/reopen.js +1 -1
  111. package/dist/commands/pr/settings-update.d.ts +18 -0
  112. package/dist/commands/pr/settings-update.js +74 -0
  113. package/dist/commands/pr/settings-update.js.map +1 -0
  114. package/dist/commands/pr/settings.d.ts +10 -0
  115. package/dist/commands/pr/settings.js +45 -0
  116. package/dist/commands/pr/settings.js.map +1 -0
  117. package/dist/commands/repo/archive.d.ts +12 -0
  118. package/dist/commands/repo/archive.js +46 -0
  119. package/dist/commands/repo/archive.js.map +1 -0
  120. package/dist/commands/repo/contributors.d.ts +15 -0
  121. package/dist/commands/repo/contributors.js +91 -0
  122. package/dist/commands/repo/contributors.js.map +1 -0
  123. package/dist/commands/repo/create.d.ts +24 -0
  124. package/dist/commands/repo/create.js +74 -0
  125. package/dist/commands/repo/create.js.map +1 -0
  126. package/dist/commands/repo/delete.d.ts +11 -0
  127. package/dist/commands/repo/delete.js +46 -0
  128. package/dist/commands/repo/delete.js.map +1 -0
  129. package/dist/commands/repo/events.d.ts +16 -0
  130. package/dist/commands/repo/events.js +72 -0
  131. package/dist/commands/repo/events.js.map +1 -0
  132. package/dist/commands/repo/fork.d.ts +13 -0
  133. package/dist/commands/repo/fork.js +56 -0
  134. package/dist/commands/repo/fork.js.map +1 -0
  135. package/dist/commands/repo/forks.d.ts +13 -0
  136. package/dist/commands/repo/forks.js +66 -0
  137. package/dist/commands/repo/forks.js.map +1 -0
  138. package/dist/commands/repo/languages.d.ts +10 -0
  139. package/dist/commands/repo/languages.js +56 -0
  140. package/dist/commands/repo/languages.js.map +1 -0
  141. package/dist/commands/repo/list.d.ts +18 -0
  142. package/dist/commands/repo/list.js +89 -0
  143. package/dist/commands/repo/list.js.map +1 -0
  144. package/dist/commands/repo/module.d.ts +17 -0
  145. package/dist/commands/repo/module.js +69 -0
  146. package/dist/commands/repo/module.js.map +1 -0
  147. package/dist/commands/repo/roles.d.ts +10 -0
  148. package/dist/commands/repo/roles.js +53 -0
  149. package/dist/commands/repo/roles.js.map +1 -0
  150. package/dist/commands/repo/settings.d.ts +17 -0
  151. package/dist/commands/repo/settings.js +82 -0
  152. package/dist/commands/repo/settings.js.map +1 -0
  153. package/dist/commands/repo/stats.d.ts +16 -0
  154. package/dist/commands/repo/stats.js +92 -0
  155. package/dist/commands/repo/stats.js.map +1 -0
  156. package/dist/commands/repo/transition.d.ts +11 -0
  157. package/dist/commands/repo/transition.js +67 -0
  158. package/dist/commands/repo/transition.js.map +1 -0
  159. package/dist/commands/tag/create.d.ts +15 -0
  160. package/dist/commands/tag/create.js +58 -0
  161. package/dist/commands/tag/create.js.map +1 -0
  162. package/dist/commands/tag/delete.d.ts +13 -0
  163. package/dist/commands/tag/delete.js +42 -0
  164. package/dist/commands/tag/delete.js.map +1 -0
  165. package/dist/commands/tag/protect-create.d.ts +14 -0
  166. package/dist/commands/tag/protect-create.js +57 -0
  167. package/dist/commands/tag/protect-create.js.map +1 -0
  168. package/dist/commands/tag/protect-delete.d.ts +13 -0
  169. package/dist/commands/tag/protect-delete.js +42 -0
  170. package/dist/commands/tag/protect-delete.js.map +1 -0
  171. package/dist/commands/tag/protect-get.d.ts +13 -0
  172. package/dist/commands/tag/protect-get.js +48 -0
  173. package/dist/commands/tag/protect-get.js.map +1 -0
  174. package/dist/commands/tag/protect-update.d.ts +14 -0
  175. package/dist/commands/tag/protect-update.js +54 -0
  176. package/dist/commands/tag/protect-update.js.map +1 -0
  177. package/dist/commands/user/emails.js +1 -1
  178. package/dist/commands/user/followers.js +1 -1
  179. package/dist/commands/user/following.js +1 -1
  180. package/dist/commands/user/view.js +1 -1
  181. package/package.json +3 -2
@@ -0,0 +1,89 @@
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 repos_1 = require("../../api/repos");
7
+ const client_1 = require("../../api/client");
8
+ const index_2 = require("../../ui/index");
9
+ class RepoList extends base_command_1.BaseCommand {
10
+ async run() {
11
+ const { flags } = await this.parse(RepoList);
12
+ const token = (0, index_1.getToken)();
13
+ if (!token)
14
+ this.error('Not logged in. Run: gc auth login');
15
+ try {
16
+ const params = {
17
+ visibility: flags.visibility,
18
+ type: flags.type,
19
+ sort: flags.sort,
20
+ direction: flags.direction,
21
+ per_page: flags.limit,
22
+ page: flags.page,
23
+ repo_type: flags['repo-type'],
24
+ };
25
+ let repos;
26
+ if (flags.org) {
27
+ repos = await (0, repos_1.listOrgRepos)(token, flags.org, params);
28
+ }
29
+ else if (flags.user) {
30
+ repos = await (0, repos_1.listUserPublicRepos)(token, flags.user, params);
31
+ }
32
+ else {
33
+ repos = await (0, repos_1.listUserRepos)(token, params);
34
+ }
35
+ if (flags.json) {
36
+ (0, index_2.printJson)(repos);
37
+ return;
38
+ }
39
+ if (repos.length === 0) {
40
+ this.log('No repositories found.');
41
+ return;
42
+ }
43
+ (0, index_2.printTable)(repos.map((r) => ({
44
+ name: r.full_name,
45
+ visibility: r.private ? 'private' : 'public',
46
+ default_branch: r.default_branch,
47
+ updated: (0, index_2.formatDate)(r.updated_at),
48
+ })), ['name', 'visibility', 'default_branch', 'updated']);
49
+ }
50
+ catch (err) {
51
+ if (err instanceof client_1.GitCodeError)
52
+ this.error(err.message);
53
+ this.error('Could not connect to GitCode. Check your internet connection.');
54
+ }
55
+ }
56
+ }
57
+ RepoList.description = 'List repositories';
58
+ RepoList.examples = [
59
+ '<%= config.bin %> repo list',
60
+ '<%= config.bin %> repo list --org myorg',
61
+ '<%= config.bin %> repo list --user alice',
62
+ '<%= config.bin %> repo list --visibility private --sort updated',
63
+ ];
64
+ RepoList.flags = {
65
+ ...base_command_1.BaseCommand.baseFlags,
66
+ org: core_1.Flags.string({ description: 'List repositories for an organization' }),
67
+ user: core_1.Flags.string({ description: "List a user's public repositories" }),
68
+ visibility: core_1.Flags.string({
69
+ description: 'Filter by visibility',
70
+ options: ['public', 'private', 'all'],
71
+ }),
72
+ type: core_1.Flags.string({ description: 'Filter by repository type' }),
73
+ sort: core_1.Flags.string({
74
+ description: 'Sort repositories by field',
75
+ options: ['created', 'updated', 'pushed', 'full_name'],
76
+ }),
77
+ direction: core_1.Flags.string({
78
+ description: 'Sort direction',
79
+ options: ['asc', 'desc'],
80
+ }),
81
+ limit: core_1.Flags.integer({ description: 'Max number of repositories to show', default: 30 }),
82
+ page: core_1.Flags.integer({ description: 'Page number', default: 1 }),
83
+ 'repo-type': core_1.Flags.string({
84
+ description: 'Filter by repository type',
85
+ options: ['code', 'model', 'dataset', 'space', 'all'],
86
+ }),
87
+ };
88
+ exports.default = RepoList;
89
+ //# sourceMappingURL=list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/repo/list.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class RepoModule extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ wiki: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
7
+ issues: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
8
+ security: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
9
+ 'merge-request': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
10
+ fork: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
11
+ analysis: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
12
+ discussion: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
13
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
14
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
15
+ };
16
+ run(): Promise<void>;
17
+ }
@@ -0,0 +1,69 @@
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
+ class RepoModule extends repo_command_1.RepoCommand {
9
+ async run() {
10
+ const { flags } = await this.parse(RepoModule);
11
+ const token = (0, index_1.getToken)();
12
+ if (!token)
13
+ this.error('Not logged in. Run: gc auth login');
14
+ let owner, repo;
15
+ try {
16
+ ;
17
+ ({ owner, repo } = this.resolveRepoFromFlags(flags));
18
+ }
19
+ catch (err) {
20
+ this.error(err.message);
21
+ }
22
+ const moduleFlags = ['wiki', 'issues', 'security', 'merge-request', 'fork', 'analysis', 'discussion'];
23
+ const hasAny = moduleFlags.some((f) => flags[f] !== undefined);
24
+ if (!hasAny) {
25
+ this.error('At least one module flag is required (e.g. --wiki, --no-issues).');
26
+ }
27
+ const params = {};
28
+ if (flags.wiki !== undefined)
29
+ params.has_wiki = flags.wiki;
30
+ if (flags.issues !== undefined)
31
+ params.has_issue = flags.issues;
32
+ if (flags.security !== undefined)
33
+ params.has_security = flags.security;
34
+ if (flags['merge-request'] !== undefined)
35
+ params.has_merge_request = flags['merge-request'];
36
+ if (flags.fork !== undefined)
37
+ params.has_fork = flags.fork;
38
+ if (flags.analysis !== undefined)
39
+ params.has_analysis = flags.analysis;
40
+ if (flags.discussion !== undefined)
41
+ params.has_discussion = flags.discussion;
42
+ try {
43
+ await (0, repos_1.updateModuleSetting)(token, owner, repo, params);
44
+ this.log(`Updated module settings for ${owner}/${repo}`);
45
+ }
46
+ catch (err) {
47
+ if (err instanceof client_1.GitCodeError)
48
+ this.error(err.message);
49
+ this.error('Could not connect to GitCode. Check your internet connection.');
50
+ }
51
+ }
52
+ }
53
+ RepoModule.description = 'Enable or disable repository modules (wiki, issues, etc.)';
54
+ RepoModule.examples = [
55
+ '<%= config.bin %> repo module --wiki --issues',
56
+ '<%= config.bin %> repo module --no-fork --no-discussion',
57
+ ];
58
+ RepoModule.flags = {
59
+ ...repo_command_1.RepoCommand.repoFlags,
60
+ wiki: core_1.Flags.boolean({ description: 'Enable or disable wiki', allowNo: true }),
61
+ issues: core_1.Flags.boolean({ description: 'Enable or disable issues', allowNo: true }),
62
+ security: core_1.Flags.boolean({ description: 'Enable or disable security', allowNo: true }),
63
+ 'merge-request': core_1.Flags.boolean({ description: 'Enable or disable merge requests', allowNo: true }),
64
+ fork: core_1.Flags.boolean({ description: 'Enable or disable fork', allowNo: true }),
65
+ analysis: core_1.Flags.boolean({ description: 'Enable or disable analysis', allowNo: true }),
66
+ discussion: core_1.Flags.boolean({ description: 'Enable or disable discussion', allowNo: true }),
67
+ };
68
+ exports.default = RepoModule;
69
+ //# sourceMappingURL=module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.js","sourceRoot":"","sources":["../../../src/commands/repo/module.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class RepoRoles extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
7
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
8
+ };
9
+ run(): Promise<void>;
10
+ }
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const repo_command_1 = require("../../repo-command");
4
+ const index_1 = require("../../config/index");
5
+ const repos_1 = require("../../api/repos");
6
+ const client_1 = require("../../api/client");
7
+ const index_2 = require("../../ui/index");
8
+ class RepoRoles extends repo_command_1.RepoCommand {
9
+ async run() {
10
+ const { flags } = await this.parse(RepoRoles);
11
+ const token = (0, index_1.getToken)();
12
+ if (!token)
13
+ this.error('Not logged in. Run: gc auth login');
14
+ let owner, repo;
15
+ try {
16
+ ;
17
+ ({ owner, repo } = this.resolveRepoFromFlags(flags));
18
+ }
19
+ catch (err) {
20
+ this.error(err.message);
21
+ }
22
+ try {
23
+ const roles = await (0, repos_1.getCustomizedRoles)(token, owner, repo);
24
+ if (flags.json) {
25
+ (0, index_2.printJson)(roles);
26
+ return;
27
+ }
28
+ if (roles.length === 0) {
29
+ this.log('No customized roles found.');
30
+ return;
31
+ }
32
+ (0, index_2.printTable)(roles.map((r) => ({
33
+ name: r.role_name,
34
+ 'access level': r.access_level,
35
+ members: r.member_count,
36
+ description: r.role_description || '-',
37
+ })), ['name', 'access level', 'members', 'description']);
38
+ }
39
+ catch (err) {
40
+ if (err instanceof client_1.GitCodeError)
41
+ this.error(err.message);
42
+ this.error('Could not connect to GitCode. Check your internet connection.');
43
+ }
44
+ }
45
+ }
46
+ RepoRoles.description = 'List customized roles for a repository';
47
+ RepoRoles.examples = [
48
+ '<%= config.bin %> repo roles',
49
+ '<%= config.bin %> repo roles --repo alice/myrepo --json',
50
+ ];
51
+ RepoRoles.flags = { ...repo_command_1.RepoCommand.repoFlags };
52
+ exports.default = RepoRoles;
53
+ //# sourceMappingURL=roles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"roles.js","sourceRoot":"","sources":["../../../src/commands/repo/roles.ts"],"names":[],"mappings":";;AAAA,qDAAgD;AAChD,8CAA6C;AAC7C,2CAAoD;AACpD,6CAA+C;AAC/C,0CAAsD;AAEtD,MAAqB,SAAU,SAAQ,0BAAW;IAShD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;QAE7C,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,KAAK,GAAG,MAAM,IAAA,0BAAkB,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;YAE1D,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,KAAK,CAAC,CAAA;gBAChB,OAAM;YACR,CAAC;YAED,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,IAAI,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAA;gBACtC,OAAM;YACR,CAAC;YAED,IAAA,kBAAU,EACR,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAChB,IAAI,EAAE,CAAC,CAAC,SAAS;gBACjB,cAAc,EAAE,CAAC,CAAC,YAAY;gBAC9B,OAAO,EAAE,CAAC,CAAC,YAAY;gBACvB,WAAW,EAAE,CAAC,CAAC,gBAAgB,IAAI,GAAG;aACvC,CAAC,CAAC,EACH,CAAC,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,aAAa,CAAC,CACnD,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;;AA/CM,qBAAW,GAAG,wCAAwC,CAAA;AACtD,kBAAQ,GAAG;IAChB,8BAA8B;IAC9B,yDAAyD;CAC1D,CAAA;AAEM,eAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBAPxB,SAAS"}
@@ -0,0 +1,17 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class RepoSettings extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ 'disable-fork': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
7
+ 'developer-branch': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
8
+ 'developer-tag': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
9
+ 'committer-branch': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
10
+ 'pre-merge-ref': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
11
+ 'open-gpg': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
12
+ lfs: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
13
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
14
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
15
+ };
16
+ run(): Promise<void>;
17
+ }
@@ -0,0 +1,82 @@
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 RepoSettings extends repo_command_1.RepoCommand {
10
+ async run() {
11
+ const { flags } = await this.parse(RepoSettings);
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
+ const updateFlags = ['disable-fork', 'developer-branch', 'developer-tag', 'committer-branch', 'pre-merge-ref', 'open-gpg', 'lfs'];
24
+ const hasUpdates = updateFlags.some((f) => flags[f] !== undefined);
25
+ try {
26
+ if (hasUpdates) {
27
+ const params = {};
28
+ if (flags['disable-fork'] !== undefined)
29
+ params.disable_fork = flags['disable-fork'];
30
+ if (flags['developer-branch'] !== undefined)
31
+ params.forbidden_developer_create_branch = flags['developer-branch'];
32
+ if (flags['developer-tag'] !== undefined)
33
+ params.forbidden_developer_create_tag = flags['developer-tag'];
34
+ if (flags['committer-branch'] !== undefined)
35
+ params.forbidden_committer_create_branch = flags['committer-branch'];
36
+ if (flags['pre-merge-ref'] !== undefined)
37
+ params.generate_pre_merge_ref = flags['pre-merge-ref'];
38
+ if (flags['open-gpg'] !== undefined)
39
+ params.open_gpg_verified = flags['open-gpg'];
40
+ if (flags.lfs !== undefined)
41
+ params.include_lfs_objects = flags.lfs;
42
+ const result = await (0, repos_1.updateRepoSettings)(token, owner, repo, params);
43
+ if (flags.json) {
44
+ (0, index_2.printJson)(result);
45
+ return;
46
+ }
47
+ this.log(`Updated settings for ${owner}/${repo}`);
48
+ }
49
+ else {
50
+ const settings = await (0, repos_1.getRepoSettings)(token, owner, repo);
51
+ if (flags.json) {
52
+ (0, index_2.printJson)(settings);
53
+ return;
54
+ }
55
+ (0, index_2.printTable)(Object.entries(settings).map(([key, value]) => ({ setting: key, value: String(value) })), ['setting', 'value']);
56
+ }
57
+ }
58
+ catch (err) {
59
+ if (err instanceof client_1.GitCodeError)
60
+ this.error(err.message);
61
+ this.error('Could not connect to GitCode. Check your internet connection.');
62
+ }
63
+ }
64
+ }
65
+ RepoSettings.description = 'View or update repository settings';
66
+ RepoSettings.examples = [
67
+ '<%= config.bin %> repo settings',
68
+ '<%= config.bin %> repo settings --disable-fork',
69
+ '<%= config.bin %> repo settings --pre-merge-ref --lfs',
70
+ ];
71
+ RepoSettings.flags = {
72
+ ...repo_command_1.RepoCommand.repoFlags,
73
+ 'disable-fork': core_1.Flags.boolean({ description: 'Disable forking', allowNo: true }),
74
+ 'developer-branch': core_1.Flags.boolean({ description: 'Forbid developer from creating branches', allowNo: true }),
75
+ 'developer-tag': core_1.Flags.boolean({ description: 'Forbid developer from creating tags', allowNo: true }),
76
+ 'committer-branch': core_1.Flags.boolean({ description: 'Forbid committer from creating branches', allowNo: true }),
77
+ 'pre-merge-ref': core_1.Flags.boolean({ description: 'Generate pre-merge ref', allowNo: true }),
78
+ 'open-gpg': core_1.Flags.boolean({ description: 'Enable GPG verification', allowNo: true }),
79
+ lfs: core_1.Flags.boolean({ description: 'Include LFS objects', allowNo: true }),
80
+ };
81
+ exports.default = RepoSettings;
82
+ //# sourceMappingURL=settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../src/commands/repo/settings.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class RepoStats extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ branch: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
7
+ author: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
8
+ since: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
9
+ until: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
10
+ downloads: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
11
+ direction: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
12
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
13
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
14
+ };
15
+ run(): Promise<void>;
16
+ }
@@ -0,0 +1,92 @@
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 RepoStats extends repo_command_1.RepoCommand {
10
+ async run() {
11
+ const { flags } = await this.parse(RepoStats);
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.downloads) {
25
+ const stats = await (0, repos_1.getDownloadStatistics)(token, owner, repo, {
26
+ start_date: flags.since,
27
+ end_date: flags.until,
28
+ direction: flags.direction,
29
+ });
30
+ if (flags.json) {
31
+ (0, index_2.printJson)(stats);
32
+ return;
33
+ }
34
+ if (stats.length === 0) {
35
+ this.log('No download statistics found.');
36
+ return;
37
+ }
38
+ (0, index_2.printTable)(stats.map((s) => ({ date: s.date, downloads: s.downloads })), ['date', 'downloads']);
39
+ }
40
+ else {
41
+ if (!flags.branch) {
42
+ this.error('--branch is required for commit statistics. Use --downloads for download stats.');
43
+ }
44
+ const stats = await (0, repos_1.getCommitStatistics)(token, owner, repo, {
45
+ branch_name: flags.branch,
46
+ author: flags.author,
47
+ since: flags.since,
48
+ until: flags.until,
49
+ });
50
+ if (flags.json) {
51
+ (0, index_2.printJson)(stats);
52
+ return;
53
+ }
54
+ if (stats.length === 0) {
55
+ this.log('No commit statistics found.');
56
+ return;
57
+ }
58
+ (0, index_2.printTable)(stats.map((s) => ({
59
+ author: s.name,
60
+ additions: s.additions,
61
+ deletions: s.deletions,
62
+ commits: s.commit_count,
63
+ })), ['author', 'additions', 'deletions', 'commits']);
64
+ }
65
+ }
66
+ catch (err) {
67
+ if (err instanceof client_1.GitCodeError)
68
+ this.error(err.message);
69
+ this.error('Could not connect to GitCode. Check your internet connection.');
70
+ }
71
+ }
72
+ }
73
+ RepoStats.description = 'Show commit or download statistics for a repository';
74
+ RepoStats.examples = [
75
+ '<%= config.bin %> repo stats --branch main',
76
+ '<%= config.bin %> repo stats --branch main --author alice --since 2026-01-01',
77
+ '<%= config.bin %> repo stats --downloads',
78
+ ];
79
+ RepoStats.flags = {
80
+ ...repo_command_1.RepoCommand.repoFlags,
81
+ branch: core_1.Flags.string({ description: 'Branch name (required for commit stats)' }),
82
+ author: core_1.Flags.string({ description: 'Filter by author' }),
83
+ since: core_1.Flags.string({ description: 'Start date (YYYY-MM-DD)' }),
84
+ until: core_1.Flags.string({ description: 'End date (YYYY-MM-DD)' }),
85
+ downloads: core_1.Flags.boolean({ description: 'Show download statistics instead of commit stats' }),
86
+ direction: core_1.Flags.string({
87
+ description: 'Sort direction for download stats',
88
+ options: ['asc', 'desc'],
89
+ }),
90
+ };
91
+ exports.default = RepoStats;
92
+ //# sourceMappingURL=stats.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stats.js","sourceRoot":"","sources":["../../../src/commands/repo/stats.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class RepoTransition extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ mode: import("@oclif/core/lib/interfaces").OptionFlag<number | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
7
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
8
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
9
+ };
10
+ run(): Promise<void>;
11
+ }
@@ -0,0 +1,67 @@
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
+ const MODE_LABELS = {
10
+ 1: 'inherit (inherits permissions from parent)',
11
+ 2: 'independent (manages its own permissions)',
12
+ };
13
+ class RepoTransition extends repo_command_1.RepoCommand {
14
+ async run() {
15
+ const { flags } = await this.parse(RepoTransition);
16
+ const token = (0, index_1.getToken)();
17
+ if (!token)
18
+ this.error('Not logged in. Run: gc auth login');
19
+ let owner, repo;
20
+ try {
21
+ ;
22
+ ({ owner, repo } = this.resolveRepoFromFlags(flags));
23
+ }
24
+ catch (err) {
25
+ this.error(err.message);
26
+ }
27
+ try {
28
+ if (flags.mode !== undefined) {
29
+ const result = await (0, repos_1.updateTransition)(token, owner, repo, {
30
+ mode: flags.mode,
31
+ });
32
+ if (flags.json) {
33
+ (0, index_2.printJson)(result);
34
+ return;
35
+ }
36
+ this.log(`Updated permission mode to: ${MODE_LABELS[result.mode] ?? result.mode}`);
37
+ }
38
+ else {
39
+ const result = await (0, repos_1.getTransition)(token, owner, repo);
40
+ if (flags.json) {
41
+ (0, index_2.printJson)(result);
42
+ return;
43
+ }
44
+ this.log(`Permission mode: ${MODE_LABELS[result.mode] ?? result.mode}`);
45
+ }
46
+ }
47
+ catch (err) {
48
+ if (err instanceof client_1.GitCodeError)
49
+ this.error(err.message);
50
+ this.error('Could not connect to GitCode. Check your internet connection.');
51
+ }
52
+ }
53
+ }
54
+ RepoTransition.description = 'View or update repository permission inheritance mode';
55
+ RepoTransition.examples = [
56
+ '<%= config.bin %> repo transition',
57
+ '<%= config.bin %> repo transition --mode 2',
58
+ ];
59
+ RepoTransition.flags = {
60
+ ...repo_command_1.RepoCommand.repoFlags,
61
+ mode: core_1.Flags.integer({
62
+ description: 'Permission mode: 1=inherit, 2=independent',
63
+ options: ['1', '2'],
64
+ }),
65
+ };
66
+ exports.default = RepoTransition;
67
+ //# sourceMappingURL=transition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transition.js","sourceRoot":"","sources":["../../../src/commands/repo/transition.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAgD;AAChD,8CAA6C;AAC7C,2CAAiE;AACjE,6CAA+C;AAC/C,0CAA0C;AAE1C,MAAM,WAAW,GAA2B;IAC1C,CAAC,EAAE,4CAA4C;IAC/C,CAAC,EAAE,2CAA2C;CAC/C,CAAA;AAED,MAAqB,cAAe,SAAQ,0BAAW;IAerD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAA;QAElD,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAE3D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,CAAC;YAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAA;QACvD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,IAAI,CAAC;YACH,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBAC7B,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAgB,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE;oBACxD,IAAI,EAAE,KAAK,CAAC,IAAa;iBAC1B,CAAC,CAAA;gBAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;oBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;oBACjB,OAAM;gBACR,CAAC;gBAED,IAAI,CAAC,GAAG,CAAC,+BAA+B,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;YACpF,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAa,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;gBAEtD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;oBACf,IAAA,iBAAS,EAAC,MAAM,CAAC,CAAA;oBACjB,OAAM;gBACR,CAAC;gBAED,IAAI,CAAC,GAAG,CAAC,oBAAoB,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;YACzE,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;;AArDM,0BAAW,GAAG,uDAAuD,CAAA;AACrE,uBAAQ,GAAG;IAChB,mCAAmC;IACnC,4CAA4C;CAC7C,CAAA;AAEM,oBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,IAAI,EAAE,YAAK,CAAC,OAAO,CAAC;QAClB,WAAW,EAAE,2CAA2C;QACxD,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;KACpB,CAAC;CACH,CAAA;kBAbkB,cAAc"}
@@ -0,0 +1,15 @@
1
+ import { RepoCommand } from '../../repo-command';
2
+ export default class TagCreate extends RepoCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static args: {
6
+ name: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
7
+ };
8
+ static flags: {
9
+ ref: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces").CustomOptions>;
10
+ message: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
11
+ repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
12
+ json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
13
+ };
14
+ run(): Promise<void>;
15
+ }