@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.
Files changed (272) hide show
  1. package/README.md +161 -0
  2. package/dist/api/client.d.ts +5 -0
  3. package/dist/api/client.js +47 -1
  4. package/dist/api/client.js.map +1 -1
  5. package/dist/api/collaborators.d.ts +32 -0
  6. package/dist/api/collaborators.js +23 -0
  7. package/dist/api/collaborators.js.map +1 -0
  8. package/dist/api/contents.d.ts +88 -0
  9. package/dist/api/contents.js +44 -0
  10. package/dist/api/contents.js.map +1 -0
  11. package/dist/api/enterprises.d.ts +55 -0
  12. package/dist/api/enterprises.js +16 -0
  13. package/dist/api/enterprises.js.map +1 -0
  14. package/dist/api/hooks.d.ts +35 -0
  15. package/dist/api/hooks.js +35 -0
  16. package/dist/api/hooks.js.map +1 -0
  17. package/dist/api/issues.d.ts +42 -0
  18. package/dist/api/issues.js +35 -0
  19. package/dist/api/issues.js.map +1 -1
  20. package/dist/api/labels.d.ts +27 -0
  21. package/dist/api/labels.js +35 -0
  22. package/dist/api/labels.js.map +1 -0
  23. package/dist/api/milestones.d.ts +34 -0
  24. package/dist/api/milestones.js +35 -0
  25. package/dist/api/milestones.js.map +1 -0
  26. package/dist/api/orgs.d.ts +43 -0
  27. package/dist/api/orgs.js +27 -0
  28. package/dist/api/orgs.js.map +1 -0
  29. package/dist/api/prs.d.ts +103 -0
  30. package/dist/api/prs.js +120 -0
  31. package/dist/api/prs.js.map +1 -1
  32. package/dist/api/repos.d.ts +170 -0
  33. package/dist/api/repos.js +68 -0
  34. package/dist/api/repos.js.map +1 -0
  35. package/dist/api/search.d.ts +49 -0
  36. package/dist/api/search.js +22 -0
  37. package/dist/api/search.js.map +1 -0
  38. package/dist/api/tags.d.ts +21 -0
  39. package/dist/api/tags.js +23 -0
  40. package/dist/api/tags.js.map +1 -0
  41. package/dist/api/user.d.ts +31 -0
  42. package/dist/api/user.js +21 -0
  43. package/dist/api/user.js.map +1 -1
  44. package/dist/commands/branch/get.d.ts +13 -0
  45. package/dist/commands/branch/get.js +50 -0
  46. package/dist/commands/branch/get.js.map +1 -0
  47. package/dist/commands/branch/list.d.ts +13 -0
  48. package/dist/commands/branch/list.js +55 -0
  49. package/dist/commands/branch/list.js.map +1 -0
  50. package/dist/commands/branch/protect.d.ts +17 -0
  51. package/dist/commands/branch/protect.js +81 -0
  52. package/dist/commands/branch/protect.js.map +1 -0
  53. package/dist/commands/collaborator/add.d.ts +14 -0
  54. package/dist/commands/collaborator/add.js +50 -0
  55. package/dist/commands/collaborator/add.js.map +1 -0
  56. package/dist/commands/collaborator/list.d.ts +13 -0
  57. package/dist/commands/collaborator/list.js +61 -0
  58. package/dist/commands/collaborator/list.js.map +1 -0
  59. package/dist/commands/collaborator/permission.d.ts +13 -0
  60. package/dist/commands/collaborator/permission.js +39 -0
  61. package/dist/commands/collaborator/permission.js.map +1 -0
  62. package/dist/commands/collaborator/remove.d.ts +13 -0
  63. package/dist/commands/collaborator/remove.js +37 -0
  64. package/dist/commands/collaborator/remove.js.map +1 -0
  65. package/dist/commands/commit/compare.d.ts +14 -0
  66. package/dist/commands/commit/compare.js +73 -0
  67. package/dist/commands/commit/compare.js.map +1 -0
  68. package/dist/commands/commit/diff.d.ts +13 -0
  69. package/dist/commands/commit/diff.js +56 -0
  70. package/dist/commands/commit/diff.js.map +1 -0
  71. package/dist/commands/commit/get.d.ts +13 -0
  72. package/dist/commands/commit/get.js +65 -0
  73. package/dist/commands/commit/get.js.map +1 -0
  74. package/dist/commands/commit/list.d.ts +17 -0
  75. package/dist/commands/commit/list.js +67 -0
  76. package/dist/commands/commit/list.js.map +1 -0
  77. package/dist/commands/file/get.d.ts +14 -0
  78. package/dist/commands/file/get.js +61 -0
  79. package/dist/commands/file/get.js.map +1 -0
  80. package/dist/commands/file/list.d.ts +14 -0
  81. package/dist/commands/file/list.js +58 -0
  82. package/dist/commands/file/list.js.map +1 -0
  83. package/dist/commands/file/raw.d.ts +14 -0
  84. package/dist/commands/file/raw.js +48 -0
  85. package/dist/commands/file/raw.js.map +1 -0
  86. package/dist/commands/hook/create.d.ts +17 -0
  87. package/dist/commands/hook/create.js +62 -0
  88. package/dist/commands/hook/create.js.map +1 -0
  89. package/dist/commands/hook/delete.d.ts +16 -0
  90. package/dist/commands/hook/delete.js +37 -0
  91. package/dist/commands/hook/delete.js.map +1 -0
  92. package/dist/commands/hook/get.d.ts +16 -0
  93. package/dist/commands/hook/get.js +46 -0
  94. package/dist/commands/hook/get.js.map +1 -0
  95. package/dist/commands/hook/list.d.ts +12 -0
  96. package/dist/commands/hook/list.js +47 -0
  97. package/dist/commands/hook/list.js.map +1 -0
  98. package/dist/commands/issue/close.d.ts +13 -0
  99. package/dist/commands/issue/close.js +34 -0
  100. package/dist/commands/issue/close.js.map +1 -0
  101. package/dist/commands/issue/comment.d.ts +3 -2
  102. package/dist/commands/issue/comment.js +6 -7
  103. package/dist/commands/issue/comment.js.map +1 -1
  104. package/dist/commands/issue/create.d.ts +2 -2
  105. package/dist/commands/issue/create.js +7 -15
  106. package/dist/commands/issue/create.js.map +1 -1
  107. package/dist/commands/issue/history.d.ts +13 -0
  108. package/dist/commands/issue/history.js +39 -0
  109. package/dist/commands/issue/history.js.map +1 -0
  110. package/dist/commands/issue/labels.d.ts +15 -0
  111. package/dist/commands/issue/labels.js +53 -0
  112. package/dist/commands/issue/labels.js.map +1 -0
  113. package/dist/commands/issue/list.d.ts +3 -2
  114. package/dist/commands/issue/list.js +8 -9
  115. package/dist/commands/issue/list.js.map +1 -1
  116. package/dist/commands/issue/reactions.d.ts +13 -0
  117. package/dist/commands/issue/reactions.js +34 -0
  118. package/dist/commands/issue/reactions.js.map +1 -0
  119. package/dist/commands/issue/reopen.d.ts +13 -0
  120. package/dist/commands/issue/reopen.js +34 -0
  121. package/dist/commands/issue/reopen.js.map +1 -0
  122. package/dist/commands/issue/update.d.ts +18 -0
  123. package/dist/commands/issue/update.js +54 -0
  124. package/dist/commands/issue/update.js.map +1 -0
  125. package/dist/commands/issue/view.d.ts +3 -2
  126. package/dist/commands/issue/view.js +8 -9
  127. package/dist/commands/issue/view.js.map +1 -1
  128. package/dist/commands/label/create.d.ts +15 -0
  129. package/dist/commands/label/create.js +56 -0
  130. package/dist/commands/label/create.js.map +1 -0
  131. package/dist/commands/label/delete.d.ts +13 -0
  132. package/dist/commands/label/delete.js +44 -0
  133. package/dist/commands/label/delete.js.map +1 -0
  134. package/dist/commands/label/list.d.ts +12 -0
  135. package/dist/commands/label/list.js +53 -0
  136. package/dist/commands/label/list.js.map +1 -0
  137. package/dist/commands/label/update.d.ts +16 -0
  138. package/dist/commands/label/update.js +63 -0
  139. package/dist/commands/label/update.js.map +1 -0
  140. package/dist/commands/milestone/create.d.ts +15 -0
  141. package/dist/commands/milestone/create.js +49 -0
  142. package/dist/commands/milestone/create.js.map +1 -0
  143. package/dist/commands/milestone/delete.d.ts +16 -0
  144. package/dist/commands/milestone/delete.js +37 -0
  145. package/dist/commands/milestone/delete.js.map +1 -0
  146. package/dist/commands/milestone/get.d.ts +16 -0
  147. package/dist/commands/milestone/get.js +48 -0
  148. package/dist/commands/milestone/get.js.map +1 -0
  149. package/dist/commands/milestone/list.d.ts +13 -0
  150. package/dist/commands/milestone/list.js +53 -0
  151. package/dist/commands/milestone/list.js.map +1 -0
  152. package/dist/commands/milestone/update.d.ts +20 -0
  153. package/dist/commands/milestone/update.js +62 -0
  154. package/dist/commands/milestone/update.js.map +1 -0
  155. package/dist/commands/org/list.d.ts +11 -0
  156. package/dist/commands/org/list.js +53 -0
  157. package/dist/commands/org/list.js.map +1 -0
  158. package/dist/commands/org/members.d.ts +14 -0
  159. package/dist/commands/org/members.js +48 -0
  160. package/dist/commands/org/members.js.map +1 -0
  161. package/dist/commands/org/view.d.ts +12 -0
  162. package/dist/commands/org/view.js +42 -0
  163. package/dist/commands/org/view.js.map +1 -0
  164. package/dist/commands/pr/close.d.ts +13 -0
  165. package/dist/commands/pr/close.js +34 -0
  166. package/dist/commands/pr/close.js.map +1 -0
  167. package/dist/commands/pr/comment.d.ts +3 -3
  168. package/dist/commands/pr/comment.js +7 -15
  169. package/dist/commands/pr/comment.js.map +1 -1
  170. package/dist/commands/pr/comments.d.ts +19 -0
  171. package/dist/commands/pr/comments.js +71 -0
  172. package/dist/commands/pr/comments.js.map +1 -0
  173. package/dist/commands/pr/commits.d.ts +17 -0
  174. package/dist/commands/pr/commits.js +58 -0
  175. package/dist/commands/pr/commits.js.map +1 -0
  176. package/dist/commands/pr/create.d.ts +2 -2
  177. package/dist/commands/pr/create.js +6 -13
  178. package/dist/commands/pr/create.js.map +1 -1
  179. package/dist/commands/pr/diff.d.ts +3 -2
  180. package/dist/commands/pr/diff.js +6 -7
  181. package/dist/commands/pr/diff.js.map +1 -1
  182. package/dist/commands/pr/labels.d.ts +18 -0
  183. package/dist/commands/pr/labels.js +70 -0
  184. package/dist/commands/pr/labels.js.map +1 -0
  185. package/dist/commands/pr/link.d.ts +18 -0
  186. package/dist/commands/pr/link.js +63 -0
  187. package/dist/commands/pr/link.js.map +1 -0
  188. package/dist/commands/pr/list.d.ts +3 -2
  189. package/dist/commands/pr/list.js +8 -9
  190. package/dist/commands/pr/list.js.map +1 -1
  191. package/dist/commands/pr/logs.d.ts +17 -0
  192. package/dist/commands/pr/logs.js +58 -0
  193. package/dist/commands/pr/logs.js.map +1 -0
  194. package/dist/commands/pr/merge.d.ts +3 -2
  195. package/dist/commands/pr/merge.js +6 -7
  196. package/dist/commands/pr/merge.js.map +1 -1
  197. package/dist/commands/pr/reactions.d.ts +13 -0
  198. package/dist/commands/pr/reactions.js +34 -0
  199. package/dist/commands/pr/reactions.js.map +1 -0
  200. package/dist/commands/pr/reopen.d.ts +13 -0
  201. package/dist/commands/pr/reopen.js +34 -0
  202. package/dist/commands/pr/reopen.js.map +1 -0
  203. package/dist/commands/pr/review.d.ts +17 -0
  204. package/dist/commands/pr/review.js +55 -0
  205. package/dist/commands/pr/review.js.map +1 -0
  206. package/dist/commands/pr/reviewers.d.ts +19 -0
  207. package/dist/commands/pr/reviewers.js +91 -0
  208. package/dist/commands/pr/reviewers.js.map +1 -0
  209. package/dist/commands/pr/test.d.ts +17 -0
  210. package/dist/commands/pr/test.js +55 -0
  211. package/dist/commands/pr/test.js.map +1 -0
  212. package/dist/commands/pr/testers.d.ts +19 -0
  213. package/dist/commands/pr/testers.js +91 -0
  214. package/dist/commands/pr/testers.js.map +1 -0
  215. package/dist/commands/pr/update.d.ts +21 -0
  216. package/dist/commands/pr/update.js +66 -0
  217. package/dist/commands/pr/update.js.map +1 -0
  218. package/dist/commands/pr/view.d.ts +3 -2
  219. package/dist/commands/pr/view.js +8 -9
  220. package/dist/commands/pr/view.js.map +1 -1
  221. package/dist/commands/release/create.d.ts +3 -2
  222. package/dist/commands/release/create.js +6 -14
  223. package/dist/commands/release/create.js.map +1 -1
  224. package/dist/commands/repo/get-remote.d.ts +3 -2
  225. package/dist/commands/repo/get-remote.js +3 -3
  226. package/dist/commands/repo/set-remote.d.ts +3 -2
  227. package/dist/commands/repo/set-remote.js +3 -3
  228. package/dist/commands/repo/transfer.d.ts +14 -0
  229. package/dist/commands/repo/transfer.js +59 -0
  230. package/dist/commands/repo/transfer.js.map +1 -0
  231. package/dist/commands/repo/update.d.ts +15 -0
  232. package/dist/commands/repo/update.js +66 -0
  233. package/dist/commands/repo/update.js.map +1 -0
  234. package/dist/commands/repo/view.d.ts +10 -0
  235. package/dist/commands/repo/view.js +50 -0
  236. package/dist/commands/repo/view.js.map +1 -0
  237. package/dist/commands/search/code.d.ts +16 -0
  238. package/dist/commands/search/code.js +75 -0
  239. package/dist/commands/search/code.js.map +1 -0
  240. package/dist/commands/search/issues.d.ts +16 -0
  241. package/dist/commands/search/issues.js +77 -0
  242. package/dist/commands/search/issues.js.map +1 -0
  243. package/dist/commands/search/repos.d.ts +16 -0
  244. package/dist/commands/search/repos.js +77 -0
  245. package/dist/commands/search/repos.js.map +1 -0
  246. package/dist/commands/tag/list.d.ts +12 -0
  247. package/dist/commands/tag/list.js +45 -0
  248. package/dist/commands/tag/list.js.map +1 -0
  249. package/dist/commands/tag/protect.d.ts +14 -0
  250. package/dist/commands/tag/protect.js +53 -0
  251. package/dist/commands/tag/protect.js.map +1 -0
  252. package/dist/commands/user/emails.d.ts +9 -0
  253. package/dist/commands/user/emails.js +33 -0
  254. package/dist/commands/user/emails.js.map +1 -0
  255. package/dist/commands/user/followers.d.ts +14 -0
  256. package/dist/commands/user/followers.js +92 -0
  257. package/dist/commands/user/followers.js.map +1 -0
  258. package/dist/commands/user/following.d.ts +14 -0
  259. package/dist/commands/user/following.js +57 -0
  260. package/dist/commands/user/following.js.map +1 -0
  261. package/dist/commands/user/view.d.ts +12 -0
  262. package/dist/commands/user/view.js +46 -0
  263. package/dist/commands/user/view.js.map +1 -0
  264. package/dist/git/index.js +1 -1
  265. package/dist/git/index.js.map +1 -1
  266. package/dist/repo-command.d.ts +19 -0
  267. package/dist/repo-command.js +29 -0
  268. package/dist/repo-command.js.map +1 -0
  269. package/dist/ui/index.d.ts +1 -1
  270. package/dist/ui/index.js +1 -0
  271. package/dist/ui/index.js.map +1 -1
  272. 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":"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"}
@@ -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":";;AAAA,sCAAkC;AAClC,qDAAgD;AAChD,8CAA6C;AAC7C,2CAA2C;AAC3C,6CAA+C;AAC/C,0CAAsD;AAEtD,MAAqB,SAAU,SAAQ,0BAAW;IAUhD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;QAEnD,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,CAAA;gBACjB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,GAAG,CAAC,cAAc,MAAM,CAAC,GAAG,EAAE,CAAC,CAAA;YACpC,IAAI,CAAC,GAAG,CAAC,cAAc,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAA;YACnF,IAAI,CAAC,GAAG,CAAC,cAAc,IAAA,kBAAU,EAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAC/D,IAAI,CAAC,GAAG,CAAC,cAAc,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAA;YACtD,IAAI,CAAC,GAAG,CAAC,cAAc,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAA;YACzC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;YACZ,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;YAE/B,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBACjB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBACZ,IAAI,CAAC,GAAG,CAAC,UAAU,MAAM,CAAC,KAAK,CAAC,SAAS,eAAe,MAAM,CAAC,KAAK,CAAC,SAAS,YAAY,CAAC,CAAA;YAC7F,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,UAAU,MAAM,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,CAAA;gBAC3C,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,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;gBACzD,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;;AAzDM,qBAAW,GAAG,qBAAqB,CAAA;AACnC,kBAAQ,GAAG,CAAC,qCAAqC,CAAC,CAAA;AAElD,cAAI,GAAG;IACZ,GAAG,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChE,CAAA;AAEM,eAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAA;kBARxB,SAAS"}