alpic 0.0.0-dev.f2f58a6 → 0.0.0-dev.f330b89

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 (178) hide show
  1. package/dist/__tests__/auth.e2e.test.d.ts +1 -0
  2. package/dist/__tests__/auth.e2e.test.js +158 -0
  3. package/dist/__tests__/auth.e2e.test.js.map +1 -0
  4. package/dist/__tests__/deploy-flags.e2e.test.d.ts +1 -0
  5. package/dist/__tests__/deploy-flags.e2e.test.js +111 -0
  6. package/dist/__tests__/deploy-flags.e2e.test.js.map +1 -0
  7. package/dist/__tests__/deploy.e2e.test.js +51 -150
  8. package/dist/__tests__/deploy.e2e.test.js.map +1 -1
  9. package/dist/__tests__/deployment-inspect.e2e.test.d.ts +1 -0
  10. package/dist/__tests__/deployment-inspect.e2e.test.js +113 -0
  11. package/dist/__tests__/deployment-inspect.e2e.test.js.map +1 -0
  12. package/dist/__tests__/deployment-list.e2e.test.d.ts +1 -0
  13. package/dist/__tests__/deployment-list.e2e.test.js +116 -0
  14. package/dist/__tests__/deployment-list.e2e.test.js.map +1 -0
  15. package/dist/__tests__/deployment-logs.e2e.test.d.ts +1 -0
  16. package/dist/__tests__/deployment-logs.e2e.test.js +255 -0
  17. package/dist/__tests__/deployment-logs.e2e.test.js.map +1 -0
  18. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.d.ts +1 -0
  19. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +260 -0
  20. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -0
  21. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.d.ts +1 -0
  22. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +140 -0
  23. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -0
  24. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.d.ts +1 -0
  25. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +151 -0
  26. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -0
  27. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.d.ts +1 -0
  28. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +343 -0
  29. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -0
  30. package/dist/__tests__/environment-variable/environment-variable-validation.test.d.ts +1 -0
  31. package/dist/__tests__/environment-variable/environment-variable-validation.test.js +20 -0
  32. package/dist/__tests__/environment-variable/environment-variable-validation.test.js.map +1 -0
  33. package/dist/__tests__/fixtures/demo-project/index.js +1 -1
  34. package/dist/__tests__/fixtures/demo-project/index.js.map +1 -1
  35. package/dist/__tests__/git-flags.e2e.test.d.ts +1 -0
  36. package/dist/__tests__/git-flags.e2e.test.js +124 -0
  37. package/dist/__tests__/git-flags.e2e.test.js.map +1 -0
  38. package/dist/__tests__/git.e2e.test.d.ts +1 -0
  39. package/dist/__tests__/git.e2e.test.js +221 -0
  40. package/dist/__tests__/git.e2e.test.js.map +1 -0
  41. package/dist/__tests__/logs.e2e.test.d.ts +1 -0
  42. package/dist/__tests__/logs.e2e.test.js +227 -0
  43. package/dist/__tests__/logs.e2e.test.js.map +1 -0
  44. package/dist/__tests__/mock-server.d.ts +16 -0
  45. package/dist/__tests__/mock-server.js +440 -25
  46. package/dist/__tests__/mock-server.js.map +1 -1
  47. package/dist/__tests__/publish.e2e.test.d.ts +1 -0
  48. package/dist/__tests__/publish.e2e.test.js +505 -0
  49. package/dist/__tests__/publish.e2e.test.js.map +1 -0
  50. package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
  51. package/dist/__tests__/tunnel.e2e.test.js +64 -0
  52. package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
  53. package/dist/__tests__/utils.d.ts +44 -1
  54. package/dist/__tests__/utils.js +195 -11
  55. package/dist/__tests__/utils.js.map +1 -1
  56. package/dist/api.d.ts +1 -2
  57. package/dist/api.js +6 -10
  58. package/dist/api.js.map +1 -1
  59. package/dist/commands/deploy.d.ts +7 -4
  60. package/dist/commands/deploy.js +47 -28
  61. package/dist/commands/deploy.js.map +1 -1
  62. package/dist/commands/deployment/inspect.d.ts +11 -0
  63. package/dist/commands/deployment/inspect.js +91 -0
  64. package/dist/commands/deployment/inspect.js.map +1 -0
  65. package/dist/commands/deployment/list.d.ts +11 -0
  66. package/dist/commands/deployment/list.js +97 -0
  67. package/dist/commands/deployment/list.js.map +1 -0
  68. package/dist/commands/deployment/logs.d.ts +12 -0
  69. package/dist/commands/deployment/logs.js +50 -0
  70. package/dist/commands/deployment/logs.js.map +1 -0
  71. package/dist/commands/environment-variable/add.d.ts +14 -0
  72. package/dist/commands/environment-variable/add.js +46 -0
  73. package/dist/commands/environment-variable/add.js.map +1 -0
  74. package/dist/commands/environment-variable/list.d.ts +9 -0
  75. package/dist/commands/environment-variable/list.js +44 -0
  76. package/dist/commands/environment-variable/list.js.map +1 -0
  77. package/dist/commands/environment-variable/remove.d.ts +11 -0
  78. package/dist/commands/environment-variable/remove.js +32 -0
  79. package/dist/commands/environment-variable/remove.js.map +1 -0
  80. package/dist/commands/environment-variable/update.d.ts +13 -0
  81. package/dist/commands/environment-variable/update.js +40 -0
  82. package/dist/commands/environment-variable/update.js.map +1 -0
  83. package/dist/commands/git/connect.d.ts +10 -0
  84. package/dist/commands/git/connect.js +60 -0
  85. package/dist/commands/git/connect.js.map +1 -0
  86. package/dist/commands/git/disconnect.d.ts +9 -0
  87. package/dist/commands/git/disconnect.js +45 -0
  88. package/dist/commands/git/disconnect.js.map +1 -0
  89. package/dist/commands/git.d.ts +6 -0
  90. package/dist/commands/git.js +17 -0
  91. package/dist/commands/git.js.map +1 -0
  92. package/dist/commands/login.d.ts +6 -0
  93. package/dist/commands/login.js +34 -0
  94. package/dist/commands/login.js.map +1 -0
  95. package/dist/commands/logout.d.ts +6 -0
  96. package/dist/commands/logout.js +20 -0
  97. package/dist/commands/logout.js.map +1 -0
  98. package/dist/commands/logs.d.ts +16 -0
  99. package/dist/commands/logs.js +96 -0
  100. package/dist/commands/logs.js.map +1 -0
  101. package/dist/commands/publish.d.ts +15 -0
  102. package/dist/commands/publish.js +51 -0
  103. package/dist/commands/publish.js.map +1 -0
  104. package/dist/commands/tunnel.d.ts +9 -0
  105. package/dist/commands/tunnel.js +53 -0
  106. package/dist/commands/tunnel.js.map +1 -0
  107. package/dist/commands/whoami.d.ts +6 -0
  108. package/dist/commands/whoami.js +13 -0
  109. package/dist/commands/whoami.js.map +1 -0
  110. package/dist/env.d.ts +4 -0
  111. package/dist/env.js +10 -0
  112. package/dist/env.js.map +1 -0
  113. package/dist/lib/alpic-command.d.ts +6 -0
  114. package/dist/lib/alpic-command.js +27 -0
  115. package/dist/lib/alpic-command.js.map +1 -0
  116. package/dist/lib/archive.d.ts +3 -3
  117. package/dist/lib/archive.js +11 -15
  118. package/dist/lib/archive.js.map +1 -1
  119. package/dist/lib/auth/auth.d.ts +2 -0
  120. package/dist/lib/auth/auth.js +21 -0
  121. package/dist/lib/auth/auth.js.map +1 -0
  122. package/dist/lib/auth/oauth/client.d.ts +28 -0
  123. package/dist/lib/auth/oauth/client.js +110 -0
  124. package/dist/lib/auth/oauth/client.js.map +1 -0
  125. package/dist/lib/auth/oauth/constants.d.ts +2 -0
  126. package/dist/lib/auth/oauth/constants.js +3 -0
  127. package/dist/lib/auth/oauth/constants.js.map +1 -0
  128. package/dist/lib/auth/oauth/server/assets/alpic-mountain.png +0 -0
  129. package/dist/lib/auth/oauth/server/assets/authorize.html +195 -0
  130. package/dist/lib/auth/oauth/server/assets/callback.html +88 -0
  131. package/dist/lib/auth/oauth/server/index.d.ts +8 -0
  132. package/dist/lib/auth/oauth/server/index.js +105 -0
  133. package/dist/lib/auth/oauth/server/index.js.map +1 -0
  134. package/dist/lib/auth/whoami.d.ts +1 -0
  135. package/dist/lib/auth/whoami.js +41 -0
  136. package/dist/lib/auth/whoami.js.map +1 -0
  137. package/dist/lib/base-workflow.d.ts +10 -0
  138. package/dist/lib/base-workflow.js +22 -0
  139. package/dist/lib/base-workflow.js.map +1 -0
  140. package/dist/lib/config.d.ts +2 -2
  141. package/dist/lib/config.js +7 -7
  142. package/dist/lib/config.js.map +1 -1
  143. package/dist/lib/deployment.d.ts +70 -3
  144. package/dist/lib/deployment.js +121 -10
  145. package/dist/lib/deployment.js.map +1 -1
  146. package/dist/lib/environment-variable.d.ts +41 -0
  147. package/dist/lib/environment-variable.js +311 -0
  148. package/dist/lib/environment-variable.js.map +1 -0
  149. package/dist/lib/git.d.ts +22 -0
  150. package/dist/lib/git.js +131 -0
  151. package/dist/lib/git.js.map +1 -0
  152. package/dist/lib/global-store.d.ts +28 -0
  153. package/dist/lib/global-store.js +76 -0
  154. package/dist/lib/global-store.js.map +1 -0
  155. package/dist/lib/logs.d.ts +20 -0
  156. package/dist/lib/logs.js +86 -0
  157. package/dist/lib/logs.js.map +1 -0
  158. package/dist/lib/project.d.ts +68 -61
  159. package/dist/lib/project.js +275 -250
  160. package/dist/lib/project.js.map +1 -1
  161. package/dist/lib/publish.d.ts +22 -0
  162. package/dist/lib/publish.js +188 -0
  163. package/dist/lib/publish.js.map +1 -0
  164. package/dist/lib/table.d.ts +8 -0
  165. package/dist/lib/table.js +27 -0
  166. package/dist/lib/table.js.map +1 -0
  167. package/dist/lib/telemetry.js +7 -7
  168. package/dist/lib/telemetry.js.map +1 -1
  169. package/dist/lib/utils.d.ts +4 -0
  170. package/dist/lib/utils.js +45 -0
  171. package/dist/lib/utils.js.map +1 -0
  172. package/dist/lib/utils.test.d.ts +1 -0
  173. package/dist/lib/utils.test.js +27 -0
  174. package/dist/lib/utils.test.js.map +1 -0
  175. package/package.json +35 -31
  176. package/dist/lib/global-config.d.ts +0 -9
  177. package/dist/lib/global-config.js +0 -48
  178. package/dist/lib/global-config.js.map +0 -1
@@ -0,0 +1,45 @@
1
+ import * as p from "@clack/prompts";
2
+ import { Flags } from "@oclif/core";
3
+ import chalk from "chalk";
4
+ import { api } from "../../api.js";
5
+ import { AlpicCommand } from "../../lib/alpic-command.js";
6
+ import { config } from "../../lib/config.js";
7
+ import { GitWorkflow } from "../../lib/git.js";
8
+ export default class GitDisconnect extends AlpicCommand {
9
+ static description = "Disconnect a linked Alpic project from its git remote source";
10
+ static examples = ["<%= config.bin %> git disconnect", "<%= config.bin %> git disconnect --non-interactive"];
11
+ static flags = {
12
+ "non-interactive": Flags.boolean({
13
+ description: "Skip the confirmation prompt",
14
+ default: false,
15
+ }),
16
+ };
17
+ async run() {
18
+ const { flags } = await this.parse(GitDisconnect);
19
+ p.intro("Disconnecting git repository from Alpic");
20
+ await this.ensureAuthenticated();
21
+ const linkedConfig = config.load();
22
+ if (!linkedConfig) {
23
+ throw new Error("This directory is not linked to an Alpic project. Link it first using `alpic deploy`.");
24
+ }
25
+ const project = await api.projects.get.v1({
26
+ projectId: linkedConfig.projectId,
27
+ });
28
+ if (!project.sourceRepository) {
29
+ throw new Error(`Project "${project.name}" is not connected to any repository.`);
30
+ }
31
+ const workflow = new GitWorkflow({
32
+ "non-interactive": flags["non-interactive"],
33
+ });
34
+ const confirmed = await workflow.confirmDisconnect(project.sourceRepository, project.name);
35
+ if (!confirmed) {
36
+ throw new Error("Git disconnect cancelled");
37
+ }
38
+ await api.projects.update.v1({
39
+ projectId: linkedConfig.projectId,
40
+ sourceRepository: null,
41
+ });
42
+ p.outro(`✅ Disconnected ${chalk.bold(project.sourceRepository)} from project ${chalk.bold(project.name)}.`);
43
+ }
44
+ }
45
+ //# sourceMappingURL=disconnect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"disconnect.js","sourceRoot":"","sources":["../../../src/commands/git/disconnect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,YAAY;IACrD,MAAM,CAAU,WAAW,GAAG,8DAA8D,CAAC;IAE7F,MAAM,CAAU,QAAQ,GAAG,CAAC,kCAAkC,EAAE,oDAAoD,CAAC,CAAC;IAEtH,MAAM,CAAU,KAAK,GAAG;QACtB,iBAAiB,EAAE,KAAK,CAAC,OAAO,CAAC;YAC/B,WAAW,EAAE,8BAA8B;YAC3C,OAAO,EAAE,KAAK;SACf,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAClD,CAAC,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAEnD,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAEjC,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAC;QAC3G,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACxC,SAAS,EAAE,YAAY,CAAC,SAAS;SAClC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,YAAY,OAAO,CAAC,IAAI,uCAAuC,CAAC,CAAC;QACnF,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,WAAW,CAAC;YAC/B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB,CAAC;SAC5C,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,iBAAiB,CAAC,OAAO,CAAC,gBAAgB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QAC3F,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;QAED,MAAM,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,SAAS,EAAE,YAAY,CAAC,SAAS;YACjC,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QAEH,CAAC,CAAC,KAAK,CAAC,kBAAkB,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,iBAAiB,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC9G,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { Command } from "@oclif/core";
2
+ export default class Git extends Command {
3
+ static description: string;
4
+ static examples: string[];
5
+ run(): Promise<void>;
6
+ }
@@ -0,0 +1,17 @@
1
+ import { Command } from "@oclif/core";
2
+ import chalk from "chalk";
3
+ export default class Git extends Command {
4
+ static description = "Manage git repository connection for a linked Alpic project";
5
+ static examples = ["<%= config.bin %> git connect", "<%= config.bin %> git disconnect"];
6
+ async run() {
7
+ await this.parse(Git);
8
+ this.log(chalk.bold("Usage:"));
9
+ this.log(" alpic git connect");
10
+ this.log(" alpic git disconnect");
11
+ this.log("");
12
+ this.log(chalk.bold("Commands:"));
13
+ this.log(" connect Connect the linked Alpic project to a git remote source");
14
+ this.log(" disconnect Disconnect the linked Alpic project from its git remote source");
15
+ }
16
+ }
17
+ //# sourceMappingURL=git.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git.js","sourceRoot":"","sources":["../../src/commands/git.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,OAAO,OAAO,GAAI,SAAQ,OAAO;IACtC,MAAM,CAAU,WAAW,GAAG,6DAA6D,CAAC;IAE5F,MAAM,CAAU,QAAQ,GAAG,CAAC,+BAA+B,EAAE,kCAAkC,CAAC,CAAC;IAEjG,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEtB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC/B,IAAI,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;QAChC,IAAI,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;QACnC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACb,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;QAClF,IAAI,CAAC,GAAG,CAAC,8EAA8E,CAAC,CAAC;IAC3F,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Login extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ run(): Promise<void>;
6
+ }
@@ -0,0 +1,34 @@
1
+ import * as p from "@clack/prompts";
2
+ import chalk from "chalk";
3
+ import open from "open";
4
+ import { AlpicCommand } from "../lib/alpic-command.js";
5
+ import { oAuthClient } from "../lib/auth/oauth/client.js";
6
+ import { getLoginPageUrl, listenToOAuthCallback } from "../lib/auth/oauth/server/index.js";
7
+ import { getWhoamiInfoMessage } from "../lib/auth/whoami.js";
8
+ import { globalStore } from "../lib/global-store.js";
9
+ export class Login extends AlpicCommand {
10
+ static description = "Log in to Alpic (opens browser, stores tokens)";
11
+ static examples = ["<%= config.bin %> login"];
12
+ async run() {
13
+ await this.parse(Login);
14
+ p.intro("Log in to Alpic");
15
+ const token = await oAuthClient.getValidAccessToken();
16
+ if (token) {
17
+ p.outro("Already logged in.");
18
+ return;
19
+ }
20
+ const { authorizeUrl, state, nonce, codeVerifier } = await oAuthClient.prepareOAuthConfig();
21
+ const loginUrl = getLoginPageUrl();
22
+ p.log.message(`Opening browser to log in…\n\nIf the browser does not open, copy this URL: ${chalk.cyan(loginUrl)}`);
23
+ await open(loginUrl);
24
+ const storedToken = await listenToOAuthCallback({
25
+ state,
26
+ nonce,
27
+ codeVerifier,
28
+ authorizeUrl: authorizeUrl.toString(),
29
+ });
30
+ globalStore.saveCredentials(storedToken);
31
+ p.outro(await getWhoamiInfoMessage());
32
+ }
33
+ }
34
+ //# sourceMappingURL=login.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC3F,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,OAAO,KAAM,SAAQ,YAAY;IACrC,MAAM,CAAU,WAAW,GAAG,gDAAgD,CAAC;IAE/E,MAAM,CAAU,QAAQ,GAAG,CAAC,yBAAyB,CAAC,CAAC;IAEvD,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAExB,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAE3B,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,mBAAmB,EAAE,CAAC;QACtD,IAAI,KAAK,EAAE,CAAC;YACV,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;YAC9B,OAAO;QACT,CAAC;QAED,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,GAAG,MAAM,WAAW,CAAC,kBAAkB,EAAE,CAAC;QAE5F,MAAM,QAAQ,GAAG,eAAe,EAAE,CAAC;QACnC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,8EAA8E,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpH,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;QAErB,MAAM,WAAW,GAAG,MAAM,qBAAqB,CAAC;YAC9C,KAAK;YACL,KAAK;YACL,YAAY;YACZ,YAAY,EAAE,YAAY,CAAC,QAAQ,EAAE;SACtC,CAAC,CAAC;QAEH,WAAW,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QAEzC,CAAC,CAAC,KAAK,CAAC,MAAM,oBAAoB,EAAE,CAAC,CAAC;IACxC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Logout extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ run(): Promise<void>;
6
+ }
@@ -0,0 +1,20 @@
1
+ import * as p from "@clack/prompts";
2
+ import { AlpicCommand } from "../lib/alpic-command.js";
3
+ import { globalStore } from "../lib/global-store.js";
4
+ export class Logout extends AlpicCommand {
5
+ static description = "Log out from Alpic (removes stored OAuth credentials)";
6
+ static examples = ["<%= config.bin %> logout"];
7
+ async run() {
8
+ await this.parse(Logout);
9
+ p.intro("Log out from Alpic");
10
+ const hasCredentials = globalStore.getCredentials() !== null;
11
+ if (!hasCredentials) {
12
+ p.outro("You are not logged in.");
13
+ return;
14
+ }
15
+ globalStore.clearCredentials();
16
+ p.log.success("✅ User authentication cleared.");
17
+ p.outro("You are logged out.");
18
+ }
19
+ }
20
+ //# sourceMappingURL=logout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logout.js","sourceRoot":"","sources":["../../src/commands/logout.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,OAAO,MAAO,SAAQ,YAAY;IACtC,MAAM,CAAU,WAAW,GAAG,uDAAuD,CAAC;IAEtF,MAAM,CAAU,QAAQ,GAAG,CAAC,0BAA0B,CAAC,CAAC;IAExD,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAEzB,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;QAE9B,MAAM,cAAc,GAAG,WAAW,CAAC,cAAc,EAAE,KAAK,IAAI,CAAC;QAE7D,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,CAAC,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;YAClC,OAAO;QACT,CAAC;QAED,WAAW,CAAC,gBAAgB,EAAE,CAAC;QAE/B,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,gCAAgC,CAAC,CAAC;QAEhD,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;IACjC,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Logs extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ "environment-id": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
7
+ since: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
8
+ until: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
9
+ limit: import("@oclif/core/interfaces").OptionFlag<number | undefined, import("@oclif/core/interfaces").CustomOptions>;
10
+ follow: import("@oclif/core/interfaces").BooleanFlag<boolean>;
11
+ level: import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
12
+ search: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
13
+ "no-color": import("@oclif/core/interfaces").BooleanFlag<boolean>;
14
+ };
15
+ run(): Promise<void>;
16
+ }
@@ -0,0 +1,96 @@
1
+ import { Flags } from "@oclif/core";
2
+ import { api } from "../api.js";
3
+ import { AlpicCommand } from "../lib/alpic-command.js";
4
+ import { resolveEnvironmentId } from "../lib/environment-variable.js";
5
+ import { followEnvironmentLogs, parseLevel, printLog } from "../lib/logs.js";
6
+ export class Logs extends AlpicCommand {
7
+ static description = "Stream runtime logs for an environment";
8
+ static examples = [
9
+ "<%= config.bin %> logs --environment-id <environmentId>",
10
+ "<%= config.bin %> logs --environment-id <environmentId> --since 1h",
11
+ "<%= config.bin %> logs --environment-id <environmentId> --follow",
12
+ "<%= config.bin %> logs --environment-id <environmentId> --level ERROR --level WARNING",
13
+ "<%= config.bin %> logs --environment-id <environmentId> --search 'timeout' --limit 50",
14
+ "<%= config.bin %> logs --environment-id <environmentId> --no-color",
15
+ ];
16
+ static flags = {
17
+ "environment-id": Flags.string({
18
+ description: "The ID of the environment",
19
+ required: false,
20
+ }),
21
+ since: Flags.string({
22
+ description: "Show logs after this time (e.g. 1h, 30m, 2024-01-01T00:00:00Z)",
23
+ required: false,
24
+ }),
25
+ until: Flags.string({
26
+ description: "Show logs before this time (e.g. 1h, 30m, 2024-01-01T00:00:00Z). Cannot be used with --follow",
27
+ required: false,
28
+ }),
29
+ limit: Flags.integer({
30
+ char: "n",
31
+ description: "Maximum number of log entries to fetch. Cannot be used with --follow",
32
+ required: false,
33
+ min: 1,
34
+ max: 1000,
35
+ }),
36
+ follow: Flags.boolean({
37
+ char: "f",
38
+ description: "Poll for new logs continuously",
39
+ required: false,
40
+ default: false,
41
+ }),
42
+ level: Flags.string({
43
+ description: "Filter by log level (INFO, ERROR, WARNING, DEBUG)",
44
+ required: false,
45
+ multiple: true,
46
+ }),
47
+ search: Flags.string({
48
+ description: "Filter logs. Accepts a regex-style pattern or plain text",
49
+ required: false,
50
+ }),
51
+ "no-color": Flags.boolean({
52
+ description: "Disable colorized output and show log levels as text",
53
+ required: false,
54
+ default: false,
55
+ }),
56
+ };
57
+ async run() {
58
+ const { flags } = await this.parse(Logs);
59
+ await this.ensureAuthenticated();
60
+ const environmentId = resolveEnvironmentId(flags);
61
+ const level = flags.level !== undefined ? parseLevel(flags.level) : undefined;
62
+ if (flags.follow && flags.until !== undefined) {
63
+ throw new Error("--until cannot be used with --follow");
64
+ }
65
+ if (flags.follow && flags.limit !== undefined) {
66
+ throw new Error("--limit cannot be used with --follow");
67
+ }
68
+ const options = {
69
+ environmentId,
70
+ since: flags.since ?? (flags.follow ? "10m" : undefined),
71
+ until: flags.until,
72
+ limit: flags.limit,
73
+ level,
74
+ search: flags.search,
75
+ };
76
+ const { logs, nextToken } = await api.environments.getLogs.v1(options);
77
+ const onLog = (log) => {
78
+ printLog(log, { noColor: flags["no-color"] });
79
+ };
80
+ for (const log of logs) {
81
+ onLog(log);
82
+ }
83
+ if (!flags.follow)
84
+ return;
85
+ await followEnvironmentLogs({
86
+ environmentId,
87
+ limit: flags.limit,
88
+ level,
89
+ search: flags.search,
90
+ nextToken,
91
+ initialLogs: logs,
92
+ onLog,
93
+ });
94
+ }
95
+ }
96
+ //# sourceMappingURL=logs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logs.js","sourceRoot":"","sources":["../../src/commands/logs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Publish extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ "non-interactive": import("@oclif/core/interfaces").BooleanFlag<boolean>;
7
+ domain: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
8
+ title: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
9
+ description: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
10
+ "website-url": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
11
+ "icon-src": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
12
+ "project-id": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
13
+ };
14
+ run(): Promise<void>;
15
+ }
@@ -0,0 +1,51 @@
1
+ import * as p from "@clack/prompts";
2
+ import { Flags } from "@oclif/core";
3
+ import { AlpicCommand } from "../lib/alpic-command.js";
4
+ import { resolveProjectId } from "../lib/project.js";
5
+ import { PublishWorkflow } from "../lib/publish.js";
6
+ export class Publish extends AlpicCommand {
7
+ static description = "Publish your MCP server to the MCP registry";
8
+ static examples = [
9
+ "<%= config.bin %> publish",
10
+ "<%= config.bin %> publish --non-interactive --domain my.domain.com --title 'My Server' --description 'Does things'",
11
+ ];
12
+ static flags = {
13
+ "non-interactive": Flags.boolean({
14
+ description: "Skip all prompts",
15
+ required: false,
16
+ }),
17
+ domain: Flags.string({
18
+ description: "Domain to publish for",
19
+ required: false,
20
+ }),
21
+ title: Flags.string({
22
+ description: "Server title (1-100 chars)",
23
+ required: false,
24
+ }),
25
+ description: Flags.string({
26
+ description: "Server description (1-100 chars)",
27
+ required: false,
28
+ }),
29
+ "website-url": Flags.string({
30
+ description: "Website URL",
31
+ required: false,
32
+ }),
33
+ "icon-src": Flags.string({
34
+ description: "Icon URL",
35
+ required: false,
36
+ }),
37
+ "project-id": Flags.string({
38
+ description: "Project ID",
39
+ required: false,
40
+ }),
41
+ };
42
+ async run() {
43
+ const { flags } = await this.parse(Publish);
44
+ p.intro("Publishing to MCP Registry");
45
+ await this.ensureAuthenticated();
46
+ const projectId = resolveProjectId(flags);
47
+ const workflow = new PublishWorkflow(flags);
48
+ await workflow.publish(projectId);
49
+ }
50
+ }
51
+ //# sourceMappingURL=publish.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"publish.js","sourceRoot":"","sources":["../../src/commands/publish.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD,MAAM,OAAO,OAAQ,SAAQ,YAAY;IACvC,MAAM,CAAU,WAAW,GAAG,6CAA6C,CAAC;IAE5E,MAAM,CAAU,QAAQ,GAAG;QACzB,2BAA2B;QAC3B,oHAAoH;KACrH,CAAC;IAEF,MAAM,CAAU,KAAK,GAAG;QACtB,iBAAiB,EAAE,KAAK,CAAC,OAAO,CAAC;YAC/B,WAAW,EAAE,kBAAkB;YAC/B,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC;YACnB,WAAW,EAAE,uBAAuB;YACpC,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC;YAClB,WAAW,EAAE,4BAA4B;YACzC,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC;YACxB,WAAW,EAAE,kCAAkC;YAC/C,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC;YAC1B,WAAW,EAAE,aAAa;YAC1B,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,UAAU,EAAE,KAAK,CAAC,MAAM,CAAC;YACvB,WAAW,EAAE,UAAU;YACvB,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC;YACzB,WAAW,EAAE,YAAY;YACzB,QAAQ,EAAE,KAAK;SAChB,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAE5C,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAEtC,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAEjC,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,QAAQ,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5C,MAAM,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Tunnel extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ static flags: {
6
+ port: import("@oclif/core/interfaces").OptionFlag<number, import("@oclif/core/interfaces").CustomOptions>;
7
+ };
8
+ run(): Promise<void>;
9
+ }
@@ -0,0 +1,53 @@
1
+ import * as p from "@clack/prompts";
2
+ import { Flags } from "@oclif/core";
3
+ import { pipenet } from "pipenet";
4
+ import { api } from "../api.js";
5
+ import { AlpicCommand } from "../lib/alpic-command.js";
6
+ export class Tunnel extends AlpicCommand {
7
+ static description = "Expose a local server to the internet through an Alpic tunnel";
8
+ static examples = ["<%= config.bin %> tunnel --port 3000"];
9
+ static flags = {
10
+ port: Flags.integer({
11
+ description: "Local port to tunnel",
12
+ required: true,
13
+ }),
14
+ };
15
+ async run() {
16
+ const { flags } = await this.parse(Tunnel);
17
+ await this.ensureAuthenticated();
18
+ const spinner = p.spinner();
19
+ spinner.start("Opening tunnel...");
20
+ const { ticket, tunnelHost, subdomain } = await api.tunnels.getTicket.v1();
21
+ // terrible ux but pipenet client retries forever on error
22
+ // I'll probably open an issue/pr on their repo once I'm sure about the fix
23
+ const tunnel = await Promise.race([
24
+ pipenet({
25
+ port: flags.port,
26
+ host: `https://${tunnelHost}`,
27
+ subdomain: subdomain,
28
+ headers: { Authorization: `Bearer ${ticket}` },
29
+ }),
30
+ new Promise((_, reject) => {
31
+ const id = setTimeout(() => reject(new Error("Failed to connect to tunnel server")), 10_000);
32
+ id.unref?.(); // don't keep the event loop alive just for this timer
33
+ }),
34
+ ]);
35
+ spinner.stop(`Forwarding: https://${subdomain}.${tunnelHost} -> http://localhost:${flags.port}`);
36
+ p.log.info("Press Ctrl+C to close the tunnel");
37
+ // Keep the process alive until Ctrl+C
38
+ await new Promise((resolve) => {
39
+ process.once("SIGINT", () => {
40
+ tunnel.close();
41
+ resolve();
42
+ });
43
+ process.once("SIGTERM", () => {
44
+ tunnel.close();
45
+ resolve();
46
+ });
47
+ tunnel.on("error", (err) => p.log.error(err.message));
48
+ tunnel.on("close", resolve);
49
+ });
50
+ p.outro("Tunnel closed");
51
+ }
52
+ }
53
+ //# sourceMappingURL=tunnel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tunnel.js","sourceRoot":"","sources":["../../src/commands/tunnel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChC,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,MAAM,OAAO,MAAO,SAAQ,YAAY;IACtC,MAAM,CAAU,WAAW,GAAG,+DAA+D,CAAC;IAE9F,MAAM,CAAU,QAAQ,GAAG,CAAC,sCAAsC,CAAC,CAAC;IAEpE,MAAM,CAAU,KAAK,GAAG;QACtB,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;YAClB,WAAW,EAAE,sBAAsB;YACnC,QAAQ,EAAE,IAAI;SACf,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAE3C,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAEjC,MAAM,OAAO,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;QAC5B,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAEnC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC;QAE3E,0DAA0D;QAC1D,2EAA2E;QAC3E,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC;YAChC,OAAO,CAAC;gBACN,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,IAAI,EAAE,WAAW,UAAU,EAAE;gBAC7B,SAAS,EAAE,SAAS;gBACpB,OAAO,EAAE,EAAE,aAAa,EAAE,UAAU,MAAM,EAAE,EAAE;aAC/C,CAAC;YACF,IAAI,OAAO,CAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;gBAC/B,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;gBAC7F,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,sDAAsD;YACtE,CAAC,CAAC;SACH,CAAC,CAAC;QAEH,OAAO,CAAC,IAAI,CAAC,uBAAuB,SAAS,IAAI,UAAU,wBAAwB,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAEjG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;QAE/C,sCAAsC;QACtC,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YAClC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;gBAC1B,MAAM,CAAC,KAAK,EAAE,CAAC;gBACf,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE;gBAC3B,MAAM,CAAC,KAAK,EAAE,CAAC;gBACf,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAU,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;YAC7D,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;IAC3B,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { AlpicCommand } from "../lib/alpic-command.js";
2
+ export declare class Whoami extends AlpicCommand {
3
+ static description: string;
4
+ static examples: string[];
5
+ run(): Promise<void>;
6
+ }
@@ -0,0 +1,13 @@
1
+ import * as p from "@clack/prompts";
2
+ import { AlpicCommand } from "../lib/alpic-command.js";
3
+ import { getWhoamiInfoMessage } from "../lib/auth/whoami.js";
4
+ export class Whoami extends AlpicCommand {
5
+ static description = "Show the current Alpic identity (API key or logged-in user)";
6
+ static examples = ["<%= config.bin %> whoami"];
7
+ async run() {
8
+ await this.parse(Whoami);
9
+ p.intro("Reading authentication status…");
10
+ p.outro(await getWhoamiInfoMessage());
11
+ }
12
+ }
13
+ //# sourceMappingURL=whoami.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whoami.js","sourceRoot":"","sources":["../../src/commands/whoami.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAE7D,MAAM,OAAO,MAAO,SAAQ,YAAY;IACtC,MAAM,CAAU,WAAW,GAAG,6DAA6D,CAAC;IAE5F,MAAM,CAAU,QAAQ,GAAG,CAAC,0BAA0B,CAAC,CAAC;IAExD,KAAK,CAAC,GAAG;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAEzB,CAAC,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;QAE1C,CAAC,CAAC,KAAK,CAAC,MAAM,oBAAoB,EAAE,CAAC,CAAC;IACxC,CAAC"}
package/dist/env.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ export declare const env: Readonly<{
2
+ ALPIC_API_BASE_URL: string;
3
+ ALPIC_COGNITO_CLIENT_ID: string;
4
+ }>;
package/dist/env.js ADDED
@@ -0,0 +1,10 @@
1
+ import { createEnv } from "@t3-oss/env-core";
2
+ import { z } from "zod";
3
+ export const env = createEnv({
4
+ server: {
5
+ ALPIC_API_BASE_URL: z.string().default("https://api.alpic.ai"),
6
+ ALPIC_COGNITO_CLIENT_ID: z.string().default("h9nqsttp8ddb40ddi1aoni91h"),
7
+ },
8
+ runtimeEnv: process.env,
9
+ });
10
+ //# sourceMappingURL=env.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.js","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,CAAC,MAAM,GAAG,GAAG,SAAS,CAAC;IAC3B,MAAM,EAAE;QACN,kBAAkB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,sBAAsB,CAAC;QAC9D,uBAAuB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,2BAA2B,CAAC;KACzE;IACD,UAAU,EAAE,OAAO,CAAC,GAAG;CACxB,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { Command } from "@oclif/core";
2
+ export declare abstract class AlpicCommand extends Command {
3
+ catch(error: unknown): Promise<void>;
4
+ ensureAuthenticated(): Promise<void>;
5
+ protected exitWithErrorMessage(message: string): void;
6
+ }
@@ -0,0 +1,27 @@
1
+ import * as p from "@clack/prompts";
2
+ import { Command } from "@oclif/core";
3
+ import { ORPCError } from "@orpc/client";
4
+ import { isAuthenticated } from "./auth/auth.js";
5
+ export class AlpicCommand extends Command {
6
+ async catch(error) {
7
+ if (error instanceof ORPCError) {
8
+ this.exitWithErrorMessage(`An error occurred while connecting to Alpic: ${error.message}`);
9
+ return;
10
+ }
11
+ if (error instanceof Error) {
12
+ this.exitWithErrorMessage(error.message);
13
+ return;
14
+ }
15
+ this.exitWithErrorMessage(String(error));
16
+ }
17
+ async ensureAuthenticated() {
18
+ if (!(await isAuthenticated())) {
19
+ this.exitWithErrorMessage("Not authenticated. Run `alpic login` or set ALPIC_API_KEY. Get an API key from Team settings in the Alpic dashboard.");
20
+ }
21
+ }
22
+ exitWithErrorMessage(message) {
23
+ p.cancel(message);
24
+ this.exit(1);
25
+ }
26
+ }
27
+ //# sourceMappingURL=alpic-command.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alpic-command.js","sourceRoot":"","sources":["../../src/lib/alpic-command.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,MAAM,OAAgB,YAAa,SAAQ,OAAO;IACvC,KAAK,CAAC,KAAK,CAAC,KAAc;QACjC,IAAI,KAAK,YAAY,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,oBAAoB,CAAC,gDAAgD,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YAC3F,OAAO;QACT,CAAC;QACD,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,mBAAmB;QACvB,IAAI,CAAC,CAAC,MAAM,eAAe,EAAE,CAAC,EAAE,CAAC;YAC/B,IAAI,CAAC,oBAAoB,CACvB,sHAAsH,CACvH,CAAC;QACJ,CAAC;IACH,CAAC;IAES,oBAAoB,CAAC,OAAe;QAC5C,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACf,CAAC;CACF"}
@@ -1,7 +1,7 @@
1
1
  export declare function ensureGitAvailable(): void;
2
- export declare function getGitFiles(deployDir: string): string[];
3
- export declare function getFilesToPack(deployDir: string): string[];
4
- export declare function createTarArchive(files: string[], deployDir: string): Promise<{
2
+ export declare function getGitFiles(): string[];
3
+ export declare function getFilesToPack(): string[];
4
+ export declare function createTarArchive(files: string[]): Promise<{
5
5
  tmpDir: string;
6
6
  archivePath: string;
7
7
  }>;
@@ -1,11 +1,11 @@
1
1
  import { execSync } from "node:child_process";
2
2
  import { existsSync, mkdtempSync, rmSync } from "node:fs";
3
3
  import { tmpdir } from "node:os";
4
- import { join, resolve } from "node:path";
4
+ import { join } from "node:path";
5
5
  import { create as tarCreate } from "tar";
6
6
  const GIT_FILES_MAX_BUFFER = 10 * 1024 * 1024;
7
- function isGitRepository(dir) {
8
- return existsSync(join(resolve(dir), ".git"));
7
+ function isGitRepository() {
8
+ return existsSync(join(process.cwd(), ".git"));
9
9
  }
10
10
  export function ensureGitAvailable() {
11
11
  try {
@@ -15,10 +15,8 @@ export function ensureGitAvailable() {
15
15
  throw new Error("Git is required to deploy. Please install git and ensure it is available in your PATH.");
16
16
  }
17
17
  }
18
- export function getGitFiles(deployDir) {
19
- const dir = resolve(deployDir);
18
+ export function getGitFiles() {
20
19
  const output = execSync("git ls-files -z --cached --others --exclude-standard -- .", {
21
- cwd: dir,
22
20
  encoding: "utf8",
23
21
  maxBuffer: GIT_FILES_MAX_BUFFER,
24
22
  });
@@ -28,27 +26,25 @@ export function getGitFiles(deployDir) {
28
26
  }
29
27
  return files;
30
28
  }
31
- export function getFilesToPack(deployDir) {
32
- const dir = resolve(deployDir);
33
- if (isGitRepository(dir)) {
34
- return getGitFiles(deployDir);
29
+ export function getFilesToPack() {
30
+ if (isGitRepository()) {
31
+ return getGitFiles();
35
32
  }
36
33
  ensureGitAvailable();
37
- execSync("git init", { cwd: dir });
34
+ execSync("git init", { stdio: "ignore" });
38
35
  try {
39
- return getGitFiles(deployDir);
36
+ return getGitFiles();
40
37
  }
41
38
  finally {
42
- rmSync(join(dir, ".git"), { recursive: true });
39
+ rmSync(join(process.cwd(), ".git"), { recursive: true, force: true });
43
40
  }
44
41
  }
45
- export async function createTarArchive(files, deployDir) {
42
+ export async function createTarArchive(files) {
46
43
  const tmpDir = mkdtempSync(join(tmpdir(), "alpic-deploy-"));
47
44
  const archivePath = join(tmpDir, "source.tar.gz");
48
45
  await tarCreate({
49
46
  gzip: true,
50
47
  file: archivePath,
51
- cwd: deployDir,
52
48
  }, files);
53
49
  return { tmpDir, archivePath };
54
50
  }
@@ -1 +1 @@
1
- {"version":3,"file":"archive.js","sourceRoot":"","sources":["../../src/lib/archive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,MAAM,IAAI,SAAS,EAAE,MAAM,KAAK,CAAC;AAE1C,MAAM,oBAAoB,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC;AAE9C,SAAS,eAAe,CAAC,GAAW;IAClC,OAAO,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;AAChD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,IAAI,CAAC;QACH,QAAQ,CAAC,eAAe,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;IAC5G,CAAC;AACH,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,SAAiB;IAC3C,MAAM,GAAG,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;IAC/B,MAAM,MAAM,GAAG,QAAQ,CAAC,2DAA2D,EAAE;QACnF,GAAG,EAAE,GAAG;QACR,QAAQ,EAAE,MAAM;QAChB,SAAS,EAAE,oBAAoB;KAChC,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACjD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;IACnH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,SAAiB;IAC9C,MAAM,GAAG,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;IAC/B,IAAI,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;QACzB,OAAO,WAAW,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IACD,kBAAkB,EAAE,CAAC;IACrB,QAAQ,CAAC,UAAU,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,IAAI,CAAC;QACH,OAAO,WAAW,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;YAAS,CAAC;QACT,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACjD,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,KAAe,EAAE,SAAiB;IACvE,MAAM,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC;IAC5D,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IAClD,MAAM,SAAS,CACb;QACE,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,WAAW;QACjB,GAAG,EAAE,SAAS;KACf,EACD,KAAK,CACN,CAAC;IACF,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;AACjC,CAAC"}
1
+ {"version":3,"file":"archive.js","sourceRoot":"","sources":["../../src/lib/archive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,MAAM,IAAI,SAAS,EAAE,MAAM,KAAK,CAAC;AAE1C,MAAM,oBAAoB,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC;AAE9C,SAAS,eAAe;IACtB,OAAO,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,IAAI,CAAC;QACH,QAAQ,CAAC,eAAe,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;IAC5G,CAAC;AACH,CAAC;AAED,MAAM,UAAU,WAAW;IACzB,MAAM,MAAM,GAAG,QAAQ,CAAC,2DAA2D,EAAE;QACnF,QAAQ,EAAE,MAAM;QAChB,SAAS,EAAE,oBAAoB;KAChC,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACjD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;IACnH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,IAAI,eAAe,EAAE,EAAE,CAAC;QACtB,OAAO,WAAW,EAAE,CAAC;IACvB,CAAC;IACD,kBAAkB,EAAE,CAAC;IACrB,QAAQ,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC1C,IAAI,CAAC;QACH,OAAO,WAAW,EAAE,CAAC;IACvB,CAAC;YAAS,CAAC;QACT,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACxE,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,KAAe;IACpD,MAAM,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC;IAC5D,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IAClD,MAAM,SAAS,CACb;QACE,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,WAAW;KAClB,EACD,KAAK,CACN,CAAC;IACF,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;AACjC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function getApiToken(): Promise<string | undefined>;
2
+ export declare function isAuthenticated(): Promise<boolean>;
@@ -0,0 +1,21 @@
1
+ import { oAuthClient } from "./oauth/client.js";
2
+ export async function getApiToken() {
3
+ const token = process.env.ALPIC_API_KEY ?? (await oAuthClient.getValidAccessToken())?.access_token;
4
+ return token;
5
+ }
6
+ export async function isAuthenticated() {
7
+ const isAuthenticatedViaApiKey = hasApiKey();
8
+ if (isAuthenticatedViaApiKey)
9
+ return true;
10
+ const isAuthenticatedViaOAuth = await hasValidAccessToken();
11
+ if (isAuthenticatedViaOAuth)
12
+ return true;
13
+ return false;
14
+ }
15
+ function hasApiKey() {
16
+ return process.env.ALPIC_API_KEY !== undefined;
17
+ }
18
+ async function hasValidAccessToken() {
19
+ return (await oAuthClient.getValidAccessToken()) !== null;
20
+ }
21
+ //# sourceMappingURL=auth.js.map