alpic 0.0.0-dev.f1a6945 → 0.0.0-dev.f1faa63

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 (144) hide show
  1. package/dist/__tests__/auth.e2e.test.js +27 -11
  2. package/dist/__tests__/auth.e2e.test.js.map +1 -1
  3. package/dist/__tests__/deploy-flags.e2e.test.d.ts +1 -0
  4. package/dist/__tests__/deploy-flags.e2e.test.js +111 -0
  5. package/dist/__tests__/deploy-flags.e2e.test.js.map +1 -0
  6. package/dist/__tests__/deploy.e2e.test.js +2 -51
  7. package/dist/__tests__/deploy.e2e.test.js.map +1 -1
  8. package/dist/__tests__/deployment-inspect.e2e.test.d.ts +1 -0
  9. package/dist/__tests__/deployment-inspect.e2e.test.js +113 -0
  10. package/dist/__tests__/deployment-inspect.e2e.test.js.map +1 -0
  11. package/dist/__tests__/deployment-list.e2e.test.d.ts +1 -0
  12. package/dist/__tests__/deployment-list.e2e.test.js +108 -0
  13. package/dist/__tests__/deployment-list.e2e.test.js.map +1 -0
  14. package/dist/__tests__/deployment-logs.e2e.test.d.ts +1 -0
  15. package/dist/__tests__/deployment-logs.e2e.test.js +180 -0
  16. package/dist/__tests__/deployment-logs.e2e.test.js.map +1 -0
  17. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.d.ts +1 -0
  18. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +250 -0
  19. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -0
  20. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.d.ts +1 -0
  21. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +122 -0
  22. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -0
  23. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.d.ts +1 -0
  24. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +139 -0
  25. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -0
  26. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.d.ts +1 -0
  27. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +319 -0
  28. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -0
  29. package/dist/__tests__/environment-variable/environment-variable-validation.test.d.ts +1 -0
  30. package/dist/__tests__/environment-variable/environment-variable-validation.test.js +20 -0
  31. package/dist/__tests__/environment-variable/environment-variable-validation.test.js.map +1 -0
  32. package/dist/__tests__/fixtures/demo-project/index.js +1 -1
  33. package/dist/__tests__/fixtures/demo-project/index.js.map +1 -1
  34. package/dist/__tests__/git-flags.e2e.test.d.ts +1 -0
  35. package/dist/__tests__/git-flags.e2e.test.js +124 -0
  36. package/dist/__tests__/git-flags.e2e.test.js.map +1 -0
  37. package/dist/__tests__/git.e2e.test.js +15 -12
  38. package/dist/__tests__/git.e2e.test.js.map +1 -1
  39. package/dist/__tests__/logs.e2e.test.d.ts +1 -0
  40. package/dist/__tests__/logs.e2e.test.js +197 -0
  41. package/dist/__tests__/logs.e2e.test.js.map +1 -0
  42. package/dist/__tests__/mock-server.d.ts +16 -0
  43. package/dist/__tests__/mock-server.js +206 -7
  44. package/dist/__tests__/mock-server.js.map +1 -1
  45. package/dist/__tests__/publish.e2e.test.d.ts +1 -0
  46. package/dist/__tests__/publish.e2e.test.js +485 -0
  47. package/dist/__tests__/publish.e2e.test.js.map +1 -0
  48. package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
  49. package/dist/__tests__/tunnel.e2e.test.js +64 -0
  50. package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
  51. package/dist/__tests__/utils.d.ts +15 -4
  52. package/dist/__tests__/utils.js +93 -18
  53. package/dist/__tests__/utils.js.map +1 -1
  54. package/dist/commands/deploy.d.ts +5 -2
  55. package/dist/commands/deploy.js +37 -19
  56. package/dist/commands/deploy.js.map +1 -1
  57. package/dist/commands/deployment/inspect.d.ts +11 -0
  58. package/dist/commands/deployment/inspect.js +68 -0
  59. package/dist/commands/deployment/inspect.js.map +1 -0
  60. package/dist/commands/deployment/list.d.ts +11 -0
  61. package/dist/commands/deployment/list.js +85 -0
  62. package/dist/commands/deployment/list.js.map +1 -0
  63. package/dist/commands/deployment/logs.d.ts +12 -0
  64. package/dist/commands/deployment/logs.js +48 -0
  65. package/dist/commands/deployment/logs.js.map +1 -0
  66. package/dist/commands/environment-variable/add.d.ts +14 -0
  67. package/dist/commands/environment-variable/add.js +46 -0
  68. package/dist/commands/environment-variable/add.js.map +1 -0
  69. package/dist/commands/environment-variable/list.d.ts +9 -0
  70. package/dist/commands/environment-variable/list.js +44 -0
  71. package/dist/commands/environment-variable/list.js.map +1 -0
  72. package/dist/commands/environment-variable/remove.d.ts +11 -0
  73. package/dist/commands/environment-variable/remove.js +32 -0
  74. package/dist/commands/environment-variable/remove.js.map +1 -0
  75. package/dist/commands/environment-variable/update.d.ts +13 -0
  76. package/dist/commands/environment-variable/update.js +40 -0
  77. package/dist/commands/environment-variable/update.js.map +1 -0
  78. package/dist/commands/git/connect.d.ts +3 -2
  79. package/dist/commands/git/connect.js +26 -27
  80. package/dist/commands/git/connect.js.map +1 -1
  81. package/dist/commands/git/disconnect.d.ts +2 -2
  82. package/dist/commands/git/disconnect.js +16 -26
  83. package/dist/commands/git/disconnect.js.map +1 -1
  84. package/dist/commands/git.js +2 -2
  85. package/dist/commands/git.js.map +1 -1
  86. package/dist/commands/login.js +5 -10
  87. package/dist/commands/login.js.map +1 -1
  88. package/dist/commands/logs.d.ts +16 -0
  89. package/dist/commands/logs.js +96 -0
  90. package/dist/commands/logs.js.map +1 -0
  91. package/dist/commands/publish.d.ts +15 -0
  92. package/dist/commands/publish.js +51 -0
  93. package/dist/commands/publish.js.map +1 -0
  94. package/dist/commands/tunnel.d.ts +9 -0
  95. package/dist/commands/tunnel.js +53 -0
  96. package/dist/commands/tunnel.js.map +1 -0
  97. package/dist/commands/whoami.js +2 -14
  98. package/dist/commands/whoami.js.map +1 -1
  99. package/dist/lib/alpic-command.d.ts +2 -0
  100. package/dist/lib/alpic-command.js +13 -3
  101. package/dist/lib/alpic-command.js.map +1 -1
  102. package/dist/lib/archive.d.ts +3 -3
  103. package/dist/lib/archive.js +11 -15
  104. package/dist/lib/archive.js.map +1 -1
  105. package/dist/lib/auth/whoami.d.ts +1 -28
  106. package/dist/lib/auth/whoami.js +24 -18
  107. package/dist/lib/auth/whoami.js.map +1 -1
  108. package/dist/lib/base-workflow.d.ts +10 -0
  109. package/dist/lib/base-workflow.js +22 -0
  110. package/dist/lib/base-workflow.js.map +1 -0
  111. package/dist/lib/config.d.ts +2 -2
  112. package/dist/lib/config.js +7 -7
  113. package/dist/lib/config.js.map +1 -1
  114. package/dist/lib/deployment.d.ts +68 -0
  115. package/dist/lib/deployment.js +102 -2
  116. package/dist/lib/deployment.js.map +1 -1
  117. package/dist/lib/environment-variable.d.ts +41 -0
  118. package/dist/lib/environment-variable.js +304 -0
  119. package/dist/lib/environment-variable.js.map +1 -0
  120. package/dist/lib/git.d.ts +12 -4
  121. package/dist/lib/git.js +51 -25
  122. package/dist/lib/git.js.map +1 -1
  123. package/dist/lib/global-store.d.ts +1 -1
  124. package/dist/lib/global-store.js +4 -3
  125. package/dist/lib/global-store.js.map +1 -1
  126. package/dist/lib/logs.d.ts +20 -0
  127. package/dist/lib/logs.js +86 -0
  128. package/dist/lib/logs.js.map +1 -0
  129. package/dist/lib/project.d.ts +68 -61
  130. package/dist/lib/project.js +273 -252
  131. package/dist/lib/project.js.map +1 -1
  132. package/dist/lib/publish.d.ts +22 -0
  133. package/dist/lib/publish.js +181 -0
  134. package/dist/lib/publish.js.map +1 -0
  135. package/dist/lib/table.d.ts +8 -0
  136. package/dist/lib/table.js +27 -0
  137. package/dist/lib/table.js.map +1 -0
  138. package/dist/lib/utils.d.ts +4 -0
  139. package/dist/lib/utils.js +21 -0
  140. package/dist/lib/utils.js.map +1 -0
  141. package/dist/lib/utils.test.d.ts +1 -0
  142. package/dist/lib/utils.test.js +21 -0
  143. package/dist/lib/utils.test.js.map +1 -0
  144. package/package.json +23 -17
@@ -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"}
@@ -1,25 +1,13 @@
1
1
  import * as p from "@clack/prompts";
2
- import chalk from "chalk";
3
2
  import { AlpicCommand } from "../lib/alpic-command.js";
4
- import { getWhoamiInfo } from "../lib/auth/whoami.js";
3
+ import { getWhoamiInfoMessage } from "../lib/auth/whoami.js";
5
4
  export class Whoami extends AlpicCommand {
6
5
  static description = "Show the current Alpic identity (API key or logged-in user)";
7
6
  static examples = ["<%= config.bin %> whoami"];
8
7
  async run() {
9
8
  await this.parse(Whoami);
10
9
  p.intro("Reading authentication status…");
11
- const info = await getWhoamiInfo();
12
- if (!info) {
13
- p.cancel("Not logged in. Run `alpic login` or set ALPIC_API_KEY.");
14
- return;
15
- }
16
- if (info.method === "api_key") {
17
- const msg = `Authenticated via API key — Team: ${chalk.green(info.team?.name ?? "unknown")}`;
18
- p.outro(msg);
19
- return;
20
- }
21
- const msg = `Authenticated as ${chalk.green(info.name)} (${chalk.cyan(info.email)})`;
22
- p.outro(msg);
10
+ p.outro(await getWhoamiInfoMessage());
23
11
  }
24
12
  }
25
13
  //# sourceMappingURL=whoami.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"whoami.js","sourceRoot":"","sources":["../../src/commands/whoami.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,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,MAAM,IAAI,GAAG,MAAM,aAAa,EAAE,CAAC;QAEnC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,CAAC,CAAC,MAAM,CAAC,wDAAwD,CAAC,CAAC;YACnE,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,qCAAqC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,IAAI,SAAS,CAAC,EAAE,CAAC;YAC7F,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACb,OAAO;QACT,CAAC;QAED,MAAM,GAAG,GAAG,oBAAoB,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;QACrF,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACf,CAAC"}
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"}
@@ -1,4 +1,6 @@
1
1
  import { Command } from "@oclif/core";
2
2
  export declare abstract class AlpicCommand extends Command {
3
3
  catch(error: unknown): Promise<void>;
4
+ ensureAuthenticated(): Promise<void>;
5
+ protected exitWithErrorMessage(message: string): void;
4
6
  }
@@ -1,17 +1,27 @@
1
1
  import * as p from "@clack/prompts";
2
2
  import { Command } from "@oclif/core";
3
3
  import { ORPCError } from "@orpc/client";
4
+ import { isAuthenticated } from "./auth/auth.js";
4
5
  export class AlpicCommand extends Command {
5
6
  async catch(error) {
6
7
  if (error instanceof ORPCError) {
7
- p.cancel(`An error occurred while connecting to Alpic: ${error.message}`);
8
+ this.exitWithErrorMessage(`An error occurred while connecting to Alpic: ${error.message}`);
8
9
  return;
9
10
  }
10
11
  if (error instanceof Error) {
11
- p.cancel(error.message);
12
+ this.exitWithErrorMessage(error.message);
12
13
  return;
13
14
  }
14
- p.cancel(String(error));
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);
15
25
  }
16
26
  }
17
27
  //# sourceMappingURL=alpic-command.js.map
@@ -1 +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,MAAM,OAAgB,YAAa,SAAQ,OAAO;IACvC,KAAK,CAAC,KAAK,CAAC,KAAc;QACjC,IAAI,KAAK,YAAY,SAAS,EAAE,CAAC;YAC/B,CAAC,CAAC,MAAM,CAAC,gDAAgD,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YAC1E,OAAO;QACT,CAAC;QACD,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACxB,OAAO;QACT,CAAC;QACD,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1B,CAAC;CACF"}
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"}
@@ -1,28 +1 @@
1
- export type WhoamiInfo = {
2
- method: "api_key";
3
- team: {
4
- id: string;
5
- name: string;
6
- };
7
- } | {
8
- method: "oauth";
9
- email: string;
10
- name: string;
11
- } | null;
12
- export declare function getWhoamiInfo(): Promise<{
13
- method: string;
14
- team: {
15
- id: string;
16
- name: string;
17
- createdAt: Date;
18
- hasStripeAccount: boolean;
19
- hasActiveSubscription: boolean;
20
- } | undefined;
21
- email?: undefined;
22
- name?: undefined;
23
- } | {
24
- method: string;
25
- email: string | undefined;
26
- name: string | undefined;
27
- team?: undefined;
28
- } | null>;
1
+ export declare function getWhoamiInfoMessage(): Promise<string>;
@@ -1,33 +1,39 @@
1
+ import chalk from "chalk";
1
2
  import { api } from "../../api.js";
2
3
  import { oAuthClient } from "./oauth/client.js";
3
- export async function getWhoamiInfo() {
4
- if (process.env.ALPIC_API_KEY !== undefined) {
5
- const team = await getApiKeyTeam();
6
- return {
7
- method: "api_key",
8
- team,
9
- };
4
+ export async function getWhoamiInfoMessage() {
5
+ const info = (await getWhoamiInfoFromApiKey()) ?? (await getWhoamiInfoFromOAuth());
6
+ if (info === null) {
7
+ return "Not logged in. Run `alpic login` or set ALPIC_API_KEY.";
10
8
  }
9
+ if (info.method === "api_key") {
10
+ return `Authenticated via API key — Team: ${chalk.green(info.team?.name ?? "unknown")}`;
11
+ }
12
+ return `Authenticated as ${chalk.green(info.name)} (${chalk.cyan(info.email)})`;
13
+ }
14
+ async function getWhoamiInfoFromApiKey() {
15
+ if (process.env.ALPIC_API_KEY === undefined) {
16
+ return null;
17
+ }
18
+ const team = await getApiKeyTeam();
19
+ return {
20
+ method: "api_key",
21
+ team,
22
+ };
23
+ }
24
+ async function getWhoamiInfoFromOAuth() {
11
25
  const token = await oAuthClient.getValidAccessToken();
12
26
  if (!token)
13
27
  return null;
14
- const userInfo = await fetchOAuthUserInfo(token);
28
+ const userInfo = await oAuthClient.fetchUserInfo(token);
15
29
  if (!userInfo)
16
30
  return null;
17
31
  return {
18
32
  method: "oauth",
19
- email: userInfo.email,
20
- name: userInfo.name,
33
+ email: userInfo.email ?? "unknown",
34
+ name: userInfo.name ?? "unknown",
21
35
  };
22
36
  }
23
- async function fetchOAuthUserInfo(credentials) {
24
- try {
25
- return await oAuthClient.fetchUserInfo(credentials);
26
- }
27
- catch {
28
- return null;
29
- }
30
- }
31
37
  async function getApiKeyTeam() {
32
38
  const teams = await api.teams.list.v1();
33
39
  return teams[0];
@@ -1 +1 @@
1
- {"version":3,"file":"whoami.js","sourceRoot":"","sources":["../../../src/lib/auth/whoami.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AAEnC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAOhD,MAAM,CAAC,KAAK,UAAU,aAAa;IACjC,IAAI,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;QAC5C,MAAM,IAAI,GAAG,MAAM,aAAa,EAAE,CAAC;QACnC,OAAO;YACL,MAAM,EAAE,SAAS;YACjB,IAAI;SACL,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,mBAAmB,EAAE,CAAC;IACtD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IAExB,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACjD,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO;QACL,MAAM,EAAE,OAAO;QACf,KAAK,EAAE,QAAQ,CAAC,KAAK;QACrB,IAAI,EAAE,QAAQ,CAAC,IAAI;KACpB,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,kBAAkB,CAAC,WAAwB;IACxD,IAAI,CAAC;QACH,OAAO,MAAM,WAAW,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;IACtD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,KAAK,UAAU,aAAa;IAC1B,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;IACxC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
1
+ {"version":3,"file":"whoami.js","sourceRoot":"","sources":["../../../src/lib/auth/whoami.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAahD,MAAM,CAAC,KAAK,UAAU,oBAAoB;IACxC,MAAM,IAAI,GAAG,CAAC,MAAM,uBAAuB,EAAE,CAAC,IAAI,CAAC,MAAM,sBAAsB,EAAE,CAAC,CAAC;IAEnF,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC;QAClB,OAAO,wDAAwD,CAAC;IAClE,CAAC;IAED,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC9B,OAAO,qCAAqC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,IAAI,SAAS,CAAC,EAAE,CAAC;IAC1F,CAAC;IAED,OAAO,oBAAoB,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;AAClF,CAAC;AAED,KAAK,UAAU,uBAAuB;IACpC,IAAI,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;IACD,MAAM,IAAI,GAAG,MAAM,aAAa,EAAE,CAAC;IACnC,OAAO;QACL,MAAM,EAAE,SAAS;QACjB,IAAI;KACL,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,sBAAsB;IACnC,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,mBAAmB,EAAE,CAAC;IACtD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACxD,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO;QACL,MAAM,EAAE,OAAO;QACf,KAAK,EAAE,QAAQ,CAAC,KAAK,IAAI,SAAS;QAClC,IAAI,EAAE,QAAQ,CAAC,IAAI,IAAI,SAAS;KACjC,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,aAAa;IAC1B,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;IACxC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
@@ -0,0 +1,10 @@
1
+ import * as p from "@clack/prompts";
2
+ export type Flags = {
3
+ "non-interactive"?: boolean;
4
+ };
5
+ export declare abstract class BaseWorkflow<F extends Flags = Flags> {
6
+ readonly flags: F;
7
+ constructor(flags: F);
8
+ protected confirm(options: p.ConfirmOptions, defaultValue?: boolean): Promise<boolean | symbol>;
9
+ protected isNonInteractive(): boolean;
10
+ }
@@ -0,0 +1,22 @@
1
+ import * as p from "@clack/prompts";
2
+ import * as ci from "ci-info";
3
+ export class BaseWorkflow {
4
+ flags;
5
+ constructor(flags) {
6
+ this.flags = flags;
7
+ }
8
+ confirm(options, defaultValue = true) {
9
+ if (this.isNonInteractive()) {
10
+ return Promise.resolve(defaultValue);
11
+ }
12
+ return p.confirm(options);
13
+ }
14
+ isNonInteractive() {
15
+ if (this.flags["non-interactive"])
16
+ return true;
17
+ if (process.env.VITEST)
18
+ return false;
19
+ return ci.isCI ?? false;
20
+ }
21
+ }
22
+ //# sourceMappingURL=base-workflow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base-workflow.js","sourceRoot":"","sources":["../../src/lib/base-workflow.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAM9B,MAAM,OAAgB,YAAY;IACJ;IAA5B,YAA4B,KAAQ;QAAR,UAAK,GAAL,KAAK,CAAG;IAAG,CAAC;IAE9B,OAAO,CAAC,OAAyB,EAAE,eAAwB,IAAI;QACvE,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC5B,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACvC,CAAC;QACD,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAC5B,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC;YAAE,OAAO,IAAI,CAAC;QAC/C,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAErC,OAAO,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC;IAC1B,CAAC;CACF"}
@@ -1,11 +1,11 @@
1
1
  import type { ProjectConfig } from "../types.js";
2
2
  export declare const config: {
3
- load: (deployDir: string) => {
3
+ load: () => {
4
4
  projectId: string;
5
5
  teamId: string;
6
6
  projectName: string;
7
7
  environmentId: string | undefined;
8
8
  environmentName: string | undefined;
9
9
  } | null;
10
- save: (config: ProjectConfig, deployDir: string) => void;
10
+ save: (projectConfig: ProjectConfig) => void;
11
11
  };
@@ -1,9 +1,9 @@
1
1
  import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
2
2
  import { join } from "node:path";
3
- const getProjectJsonPath = (deployDir) => join(deployDir, ".alpic", "project.json");
3
+ const getProjectJsonPath = () => join(process.cwd(), ".alpic", "project.json");
4
4
  export const config = {
5
- load: (deployDir) => {
6
- const path = getProjectJsonPath(deployDir);
5
+ load: () => {
6
+ const path = getProjectJsonPath();
7
7
  if (!existsSync(path)) {
8
8
  return null;
9
9
  }
@@ -22,10 +22,10 @@ export const config = {
22
22
  environmentName: raw.environmentName,
23
23
  };
24
24
  },
25
- save: (config, deployDir) => {
26
- const path = getProjectJsonPath(deployDir);
27
- mkdirSync(join(deployDir, ".alpic"), { recursive: true });
28
- writeFileSync(path, JSON.stringify(config, null, 2));
25
+ save: (projectConfig) => {
26
+ const path = getProjectJsonPath();
27
+ mkdirSync(join(process.cwd(), ".alpic"), { recursive: true });
28
+ writeFileSync(path, JSON.stringify(projectConfig, null, 2));
29
29
  },
30
30
  };
31
31
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/lib/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,MAAM,kBAAkB,GAAG,CAAC,SAAiB,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;AAE5F,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,IAAI,EAAE,CAAC,SAAiB,EAAE,EAAE;QAC1B,MAAM,IAAI,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAmE,CAAC;QACxE,IAAI,CAAC;YACH,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAG1C,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,kCAAmC,KAAe,CAAC,OAAO,EAAE,CAAC,CAAC;QAChF,CAAC;QACD,OAAO;YACL,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,SAAS;YAC7C,aAAa,EAAE,GAAG,CAAC,aAAa;YAChC,eAAe,EAAE,GAAG,CAAC,eAAe;SACrC,CAAC;IACJ,CAAC;IACD,IAAI,EAAE,CAAC,MAAqB,EAAE,SAAiB,EAAE,EAAE;QACjD,MAAM,IAAI,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAC3C,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC1D,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC;CACF,CAAC"}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/lib/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,MAAM,kBAAkB,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;AAE/E,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,IAAI,EAAE,GAAG,EAAE;QACT,MAAM,IAAI,GAAG,kBAAkB,EAAE,CAAC;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAmE,CAAC;QACxE,IAAI,CAAC;YACH,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAG1C,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,kCAAmC,KAAe,CAAC,OAAO,EAAE,CAAC,CAAC;QAChF,CAAC;QACD,OAAO;YACL,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,SAAS;YAC7C,aAAa,EAAE,GAAG,CAAC,aAAa;YAChC,eAAe,EAAE,GAAG,CAAC,eAAe;SACrC,CAAC;IACJ,CAAC;IACD,IAAI,EAAE,CAAC,aAA4B,EAAE,EAAE;QACrC,MAAM,IAAI,GAAG,kBAAkB,EAAE,CAAC;QAClC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC9D,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC;CACF,CAAC"}
@@ -1,5 +1,69 @@
1
1
  import type { RouterOutput } from "@alpic-ai/api";
2
+ export declare const colorizeDeploymentStatus: (text: string) => import("chalk").ChalkInstance | ((value: string) => string);
2
3
  export declare function formatElapsed(ms: number): string;
4
+ export declare function calculateDeploymentDuration(deployment: {
5
+ startedAt?: Date | null;
6
+ completedAt?: Date | null;
7
+ }): number | null;
8
+ export declare function fetchDeployment(deploymentId: string): Promise<{
9
+ id: string;
10
+ status: "ongoing" | "deployed" | "failed" | "canceled";
11
+ sourceRef: string | null;
12
+ sourceCommitId: string | null;
13
+ sourceCommitMessage: string | null;
14
+ authorUsername: string | null;
15
+ authorAvatarUrl: string | null;
16
+ startedAt: Date | null;
17
+ completedAt: Date | null;
18
+ environmentId: string;
19
+ environmentName: string;
20
+ isCurrent: boolean;
21
+ deploymentPageUrl: string | null;
22
+ }>;
23
+ export declare function fetchLatestDeploymentForEnvironment(environmentId: string): Promise<{
24
+ id: string;
25
+ status: "ongoing" | "deployed" | "failed" | "canceled";
26
+ sourceRef: string | null;
27
+ sourceCommitId: string | null;
28
+ sourceCommitMessage: string | null;
29
+ authorUsername: string | null;
30
+ authorAvatarUrl: string | null;
31
+ startedAt: Date | null;
32
+ completedAt: Date | null;
33
+ environmentId: string;
34
+ environmentName: string;
35
+ isCurrent: boolean;
36
+ deploymentPageUrl: string | null;
37
+ }>;
38
+ export declare function resolveDeploymentId(flags: {
39
+ "deployment-id"?: string;
40
+ "environment-id"?: string;
41
+ }): Promise<string>;
42
+ export declare function waitForDeployment(deployment: RouterOutput["deployments"]["get"]["v1"]): Promise<{
43
+ id: string;
44
+ status: "ongoing" | "deployed" | "failed" | "canceled";
45
+ sourceRef: string | null;
46
+ sourceCommitId: string | null;
47
+ sourceCommitMessage: string | null;
48
+ authorUsername: string | null;
49
+ authorAvatarUrl: string | null;
50
+ startedAt: Date | null;
51
+ completedAt: Date | null;
52
+ environmentId: string;
53
+ environmentName: string;
54
+ isCurrent: boolean;
55
+ deploymentPageUrl: string | null;
56
+ }>;
57
+ type DeploymentLogEntry = {
58
+ timestamp?: Date;
59
+ content?: string;
60
+ };
61
+ export declare function printDeploymentLog(log: DeploymentLogEntry, { noColor }?: {
62
+ noColor?: boolean;
63
+ }): void;
64
+ export declare function followDeploymentLogs(deploymentId: string, initialLogs: DeploymentLogEntry[], { noColor }?: {
65
+ noColor?: boolean;
66
+ }): Promise<void>;
3
67
  export declare function deployAndWait({ initial, startedAt, }: {
4
68
  initial: RouterOutput["deployments"]["get"]["v1"];
5
69
  startedAt: number;
@@ -14,7 +78,11 @@ export declare function deployAndWait({ initial, startedAt, }: {
14
78
  authorAvatarUrl: string | null;
15
79
  startedAt: Date | null;
16
80
  completedAt: Date | null;
81
+ environmentId: string;
82
+ environmentName: string;
83
+ isCurrent: boolean;
17
84
  deploymentPageUrl: string | null;
18
85
  };
19
86
  elapsedMs: number;
20
87
  }>;
88
+ export {};