alpic 0.0.0-dev.fdd9dcb → 0.0.0-dev.fe18813

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 (156) hide show
  1. package/dist/__tests__/auth.e2e.test.d.ts +1 -0
  2. package/dist/__tests__/auth.e2e.test.js +142 -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.d.ts +1 -0
  8. package/dist/__tests__/deploy.e2e.test.js +168 -0
  9. package/dist/__tests__/deploy.e2e.test.js.map +1 -0
  10. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.d.ts +1 -0
  11. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +250 -0
  12. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -0
  13. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.d.ts +1 -0
  14. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +121 -0
  15. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -0
  16. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.d.ts +1 -0
  17. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +139 -0
  18. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -0
  19. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.d.ts +1 -0
  20. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +294 -0
  21. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -0
  22. package/dist/__tests__/environment-variable/environment-variable-validation.test.d.ts +1 -0
  23. package/dist/__tests__/environment-variable/environment-variable-validation.test.js +19 -0
  24. package/dist/__tests__/environment-variable/environment-variable-validation.test.js.map +1 -0
  25. package/dist/__tests__/fixtures/demo-project/index.d.ts +1 -0
  26. package/dist/__tests__/fixtures/demo-project/index.js +4 -0
  27. package/dist/__tests__/fixtures/demo-project/index.js.map +1 -0
  28. package/dist/__tests__/git-flags.e2e.test.d.ts +1 -0
  29. package/dist/__tests__/git-flags.e2e.test.js +124 -0
  30. package/dist/__tests__/git-flags.e2e.test.js.map +1 -0
  31. package/dist/__tests__/git.e2e.test.d.ts +1 -0
  32. package/dist/__tests__/git.e2e.test.js +221 -0
  33. package/dist/__tests__/git.e2e.test.js.map +1 -0
  34. package/dist/__tests__/mock-server.d.ts +23 -0
  35. package/dist/__tests__/mock-server.js +573 -0
  36. package/dist/__tests__/mock-server.js.map +1 -0
  37. package/dist/__tests__/utils.d.ts +67 -0
  38. package/dist/__tests__/utils.js +255 -0
  39. package/dist/__tests__/utils.js.map +1 -0
  40. package/dist/api.d.ts +3 -0
  41. package/dist/api.js +15 -0
  42. package/dist/api.js.map +1 -0
  43. package/dist/commands/deploy.d.ts +12 -0
  44. package/dist/commands/deploy.js +100 -0
  45. package/dist/commands/deploy.js.map +1 -0
  46. package/dist/commands/environment-variable/add.d.ts +14 -0
  47. package/dist/commands/environment-variable/add.js +46 -0
  48. package/dist/commands/environment-variable/add.js.map +1 -0
  49. package/dist/commands/environment-variable/list.d.ts +9 -0
  50. package/dist/commands/environment-variable/list.js +48 -0
  51. package/dist/commands/environment-variable/list.js.map +1 -0
  52. package/dist/commands/environment-variable/remove.d.ts +11 -0
  53. package/dist/commands/environment-variable/remove.js +32 -0
  54. package/dist/commands/environment-variable/remove.js.map +1 -0
  55. package/dist/commands/environment-variable/update.d.ts +13 -0
  56. package/dist/commands/environment-variable/update.js +40 -0
  57. package/dist/commands/environment-variable/update.js.map +1 -0
  58. package/dist/commands/git/connect.d.ts +10 -0
  59. package/dist/commands/git/connect.js +58 -0
  60. package/dist/commands/git/connect.js.map +1 -0
  61. package/dist/commands/git/disconnect.d.ts +9 -0
  62. package/dist/commands/git/disconnect.js +41 -0
  63. package/dist/commands/git/disconnect.js.map +1 -0
  64. package/dist/commands/{hello.d.ts → git.d.ts} +1 -1
  65. package/dist/commands/git.js +17 -0
  66. package/dist/commands/git.js.map +1 -0
  67. package/dist/commands/login.d.ts +6 -0
  68. package/dist/commands/login.js +32 -0
  69. package/dist/commands/login.js.map +1 -0
  70. package/dist/commands/logout.d.ts +6 -0
  71. package/dist/commands/logout.js +20 -0
  72. package/dist/commands/logout.js.map +1 -0
  73. package/dist/commands/telemetry/disable.d.ts +5 -0
  74. package/dist/commands/telemetry/disable.js +14 -0
  75. package/dist/commands/telemetry/disable.js.map +1 -0
  76. package/dist/commands/telemetry/enable.d.ts +5 -0
  77. package/dist/commands/telemetry/enable.js +13 -0
  78. package/dist/commands/telemetry/enable.js.map +1 -0
  79. package/dist/commands/telemetry/status.d.ts +5 -0
  80. package/dist/commands/telemetry/status.js +19 -0
  81. package/dist/commands/telemetry/status.js.map +1 -0
  82. package/dist/commands/whoami.d.ts +6 -0
  83. package/dist/commands/whoami.js +13 -0
  84. package/dist/commands/whoami.js.map +1 -0
  85. package/dist/env.d.ts +4 -0
  86. package/dist/env.js +10 -0
  87. package/dist/env.js.map +1 -0
  88. package/dist/lib/alpic-command.d.ts +6 -0
  89. package/dist/lib/alpic-command.js +27 -0
  90. package/dist/lib/alpic-command.js.map +1 -0
  91. package/dist/lib/archive.d.ts +7 -0
  92. package/dist/lib/archive.js +51 -0
  93. package/dist/lib/archive.js.map +1 -0
  94. package/dist/lib/auth/auth.d.ts +2 -0
  95. package/dist/lib/auth/auth.js +21 -0
  96. package/dist/lib/auth/auth.js.map +1 -0
  97. package/dist/lib/auth/oauth/client.d.ts +28 -0
  98. package/dist/lib/auth/oauth/client.js +110 -0
  99. package/dist/lib/auth/oauth/client.js.map +1 -0
  100. package/dist/lib/auth/oauth/constants.d.ts +2 -0
  101. package/dist/lib/auth/oauth/constants.js +3 -0
  102. package/dist/lib/auth/oauth/constants.js.map +1 -0
  103. package/dist/lib/auth/oauth/server/assets/alpic-mountain.png +0 -0
  104. package/dist/lib/auth/oauth/server/assets/authorize.html +195 -0
  105. package/dist/lib/auth/oauth/server/assets/callback.html +88 -0
  106. package/dist/lib/auth/oauth/server/index.d.ts +8 -0
  107. package/dist/lib/auth/oauth/server/index.js +102 -0
  108. package/dist/lib/auth/oauth/server/index.js.map +1 -0
  109. package/dist/lib/auth/whoami.d.ts +1 -0
  110. package/dist/lib/auth/whoami.js +41 -0
  111. package/dist/lib/auth/whoami.js.map +1 -0
  112. package/dist/lib/base-workflow.d.ts +10 -0
  113. package/dist/lib/base-workflow.js +22 -0
  114. package/dist/lib/base-workflow.js.map +1 -0
  115. package/dist/lib/config.d.ts +11 -0
  116. package/dist/lib/config.js +31 -0
  117. package/dist/lib/config.js.map +1 -0
  118. package/dist/lib/deployment.d.ts +20 -0
  119. package/dist/lib/deployment.js +42 -0
  120. package/dist/lib/deployment.js.map +1 -0
  121. package/dist/lib/environment-variable.d.ts +35 -0
  122. package/dist/lib/environment-variable.js +277 -0
  123. package/dist/lib/environment-variable.js.map +1 -0
  124. package/dist/lib/git.d.ts +22 -0
  125. package/dist/lib/git.js +131 -0
  126. package/dist/lib/git.js.map +1 -0
  127. package/dist/lib/global-store.d.ts +28 -0
  128. package/dist/lib/global-store.js +76 -0
  129. package/dist/lib/global-store.js.map +1 -0
  130. package/dist/lib/project.d.ts +71 -0
  131. package/dist/lib/project.js +295 -0
  132. package/dist/lib/project.js.map +1 -0
  133. package/dist/lib/table.d.ts +8 -0
  134. package/dist/lib/table.js +27 -0
  135. package/dist/lib/table.js.map +1 -0
  136. package/dist/lib/telemetry.d.ts +7 -0
  137. package/dist/lib/telemetry.js +66 -0
  138. package/dist/lib/telemetry.js.map +1 -0
  139. package/dist/lib/upload.d.ts +1 -0
  140. package/dist/lib/upload.js +14 -0
  141. package/dist/lib/upload.js.map +1 -0
  142. package/dist/lib/utils.d.ts +1 -0
  143. package/dist/lib/utils.js +17 -0
  144. package/dist/lib/utils.js.map +1 -0
  145. package/dist/lib/utils.test.d.ts +1 -0
  146. package/dist/lib/utils.test.js +14 -0
  147. package/dist/lib/utils.test.js.map +1 -0
  148. package/dist/posthog.d.ts +3 -0
  149. package/dist/posthog.js +10 -0
  150. package/dist/posthog.js.map +1 -0
  151. package/dist/types.d.ts +7 -0
  152. package/dist/types.js +2 -0
  153. package/dist/types.js.map +1 -0
  154. package/package.json +38 -9
  155. package/dist/commands/hello.js +0 -10
  156. package/dist/commands/hello.js.map +0 -1
@@ -0,0 +1,76 @@
1
+ import envPaths from "env-paths";
2
+ import crypto from "node:crypto";
3
+ import { existsSync, mkdirSync, readFileSync, unlinkSync, writeFileSync } from "node:fs";
4
+ import { join } from "node:path";
5
+ export class GlobalStore {
6
+ configDir;
7
+ constructor() {
8
+ const configDirOverride = process.env["ALPIC_GLOBAL_CONFIG_DIR"];
9
+ this.configDir = configDirOverride ?? envPaths("alpic", { suffix: "" }).config;
10
+ }
11
+ getCredentials() {
12
+ const token = this.parseJsonFile(this.getCredentialsFilePath());
13
+ if (!token) {
14
+ return null;
15
+ }
16
+ return token;
17
+ }
18
+ saveCredentials(credentials) {
19
+ this.saveJsonFile(this.getCredentialsFilePath(), credentials);
20
+ }
21
+ clearCredentials() {
22
+ this.clear(this.getCredentialsFilePath());
23
+ }
24
+ getConfig() {
25
+ const existing = this.parseJsonFile(this.getConfigFilePath());
26
+ if (existing?.machineId && existing?.telemetry !== undefined) {
27
+ return existing;
28
+ }
29
+ const config = {
30
+ machineId: existing?.machineId ?? crypto.randomUUID(),
31
+ telemetry: {
32
+ enabled: existing?.telemetry?.enabled ?? true,
33
+ },
34
+ };
35
+ this.saveConfig(config);
36
+ return config;
37
+ }
38
+ saveConfig(config) {
39
+ this.saveJsonFile(this.getConfigFilePath(), config);
40
+ }
41
+ clearConfig() {
42
+ this.clear(this.getConfigFilePath());
43
+ }
44
+ getCredentialsFilePath() {
45
+ return join(this.configDir, "credentials.json");
46
+ }
47
+ getConfigFilePath() {
48
+ return join(this.configDir, "config.json");
49
+ }
50
+ parseJsonFile(filePath) {
51
+ if (!existsSync(filePath)) {
52
+ return null;
53
+ }
54
+ try {
55
+ return JSON.parse(readFileSync(filePath, "utf-8"));
56
+ }
57
+ catch {
58
+ this.clear(filePath);
59
+ return null;
60
+ }
61
+ }
62
+ saveJsonFile(filePath, data) {
63
+ mkdirSync(this.configDir, { recursive: true });
64
+ writeFileSync(filePath, JSON.stringify(data, null, 2), {
65
+ encoding: "utf-8",
66
+ mode: 0o600,
67
+ });
68
+ }
69
+ clear(filePath) {
70
+ if (existsSync(filePath)) {
71
+ unlinkSync(filePath);
72
+ }
73
+ }
74
+ }
75
+ export const globalStore = new GlobalStore();
76
+ //# sourceMappingURL=global-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"global-store.js","sourceRoot":"","sources":["../../src/lib/global-store.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,WAAW,CAAC;AACjC,OAAO,MAAM,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACzF,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAejC,MAAM,OAAO,WAAW;IACL,SAAS,CAAS;IAEnC;QACE,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;QACjE,IAAI,CAAC,SAAS,GAAG,iBAAiB,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC;IACjF,CAAC;IAED,cAAc;QACZ,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAc,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;QAE7E,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,eAAe,CAAC,WAAwB;QACtC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,sBAAsB,EAAE,EAAE,WAAW,CAAC,CAAC;IAChE,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,SAAS;QACP,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAS,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QACtE,IAAI,QAAQ,EAAE,SAAS,IAAI,QAAQ,EAAE,SAAS,KAAK,SAAS,EAAE,CAAC;YAC7D,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,MAAM,MAAM,GAAW;YACrB,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,MAAM,CAAC,UAAU,EAAE;YACrD,SAAS,EAAE;gBACT,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,IAAI,IAAI;aAC9C;SACF,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,UAAU,CAAC,MAAc;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,MAAM,CAAC,CAAC;IACtD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACvC,CAAC;IAEO,sBAAsB;QAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAC;IAClD,CAAC;IAEO,iBAAiB;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;IAC7C,CAAC;IAEO,aAAa,CAAI,QAAgB;QACvC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAM,CAAC;QAC1D,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACrB,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,QAAgB,EAAE,IAAa;QAClD,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/C,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE;YACrD,QAAQ,EAAE,OAAO;YACjB,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,QAAgB;QAC5B,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzB,UAAU,CAAC,QAAQ,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;CACF;AAED,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC"}
@@ -0,0 +1,71 @@
1
+ import type { RouterOutput, Runtime } from "@alpic-ai/api";
2
+ import type { ProjectConfig } from "../types.js";
3
+ import { BaseWorkflow } from "./base-workflow.js";
4
+ export type ProjectFlags = {
5
+ "non-interactive"?: boolean;
6
+ projectName?: string;
7
+ runtime?: Runtime;
8
+ rootDir?: string;
9
+ };
10
+ export declare class ProjectWorkflow extends BaseWorkflow<ProjectFlags> {
11
+ selectEnvironmentFromList(environments: RouterOutput["projects"]["get"]["v1"]["environments"]): Promise<(typeof environments)[number] | null>;
12
+ selectProjectFromList(projects: RouterOutput["projects"]["list"]["v1"]): Promise<{
13
+ id: string;
14
+ name: string;
15
+ teamId: string;
16
+ sourceRepository: string | null;
17
+ runtime: "python3.13" | "python3.14" | "node22" | "node24";
18
+ transport: "stdio" | "sse" | "streamablehttp" | null;
19
+ rootDirectory: string | null;
20
+ buildCommand: string | null;
21
+ buildOutputDir: string | null;
22
+ installCommand: string | null;
23
+ startCommand: string | null;
24
+ createdAt: Date;
25
+ productionEnvironment: {
26
+ id: string;
27
+ name: string;
28
+ mcpServerUrl: string;
29
+ domains: {
30
+ domain: string;
31
+ status: "ongoing" | "deployed" | "failed";
32
+ createdAt: Date;
33
+ }[];
34
+ latestDeployment: {
35
+ id: string;
36
+ status: "ongoing" | "deployed" | "failed" | "canceled";
37
+ sourceCommitId: string | null;
38
+ sourceCommitMessage: string | null;
39
+ completedAt: Date | null;
40
+ } | null;
41
+ } | null;
42
+ environments: {
43
+ id: string;
44
+ name: string;
45
+ sourceBranch: string | null;
46
+ mcpServerUrl: string;
47
+ createdAt: Date;
48
+ projectId: string;
49
+ latestDeployment: {
50
+ id: string;
51
+ status: "ongoing" | "deployed" | "failed" | "canceled";
52
+ sourceCommitId: string | null;
53
+ sourceCommitMessage: string | null;
54
+ completedAt: Date | null;
55
+ } | null;
56
+ }[];
57
+ } | null>;
58
+ promptRootDirectory(): Promise<string | null>;
59
+ private directoryExists;
60
+ private detectRuntime;
61
+ confirmDeployWithExistingConfig(existingConfig: ProjectConfig): Promise<boolean | null>;
62
+ confirmDeployDirectory(): Promise<boolean>;
63
+ confirmLinkExisting(): Promise<boolean>;
64
+ confirmLinkToAnotherProject(): Promise<boolean>;
65
+ resolveProjectForDeploy(): Promise<(ProjectConfig & {
66
+ environmentId: string;
67
+ }) | null>;
68
+ private resolveEnvironmentForProject;
69
+ private runCreateProjectFlow;
70
+ private runLinkingFlow;
71
+ }
@@ -0,0 +1,295 @@
1
+ import * as p from "@clack/prompts";
2
+ import chalk from "chalk";
3
+ import { existsSync, readFileSync, statSync } from "node:fs";
4
+ import { resolve } from "node:path";
5
+ import { api } from "../api.js";
6
+ import { BaseWorkflow } from "./base-workflow.js";
7
+ import { config } from "./config.js";
8
+ export class ProjectWorkflow extends BaseWorkflow {
9
+ async selectEnvironmentFromList(environments) {
10
+ if (environments.length === 0) {
11
+ return null;
12
+ }
13
+ const choice = await p.select({
14
+ message: chalk.bold("Choose an environment to deploy to"),
15
+ options: environments.map((env) => ({
16
+ value: env.id,
17
+ label: env.sourceBranch ? `${env.name} (${env.sourceBranch})` : env.name,
18
+ })),
19
+ });
20
+ if (p.isCancel(choice))
21
+ return null;
22
+ const environment = environments.find((e) => e.id === choice);
23
+ return environment ?? null;
24
+ }
25
+ async selectProjectFromList(projects) {
26
+ if (projects.length === 0) {
27
+ return null;
28
+ }
29
+ const choice = await p.select({
30
+ message: chalk.bold("Choose a project"),
31
+ options: projects.map((proj) => ({ value: proj.id, label: proj.name })),
32
+ });
33
+ if (p.isCancel(choice))
34
+ return null;
35
+ const project = projects.find((proj) => proj.id === choice);
36
+ return project ?? null;
37
+ }
38
+ async promptRootDirectory() {
39
+ if (this.isNonInteractive()) {
40
+ if (this.flags.rootDir) {
41
+ const trimmed = this.flags.rootDir.trim();
42
+ if (trimmed === "" || trimmed === ".")
43
+ return null;
44
+ if (!this.directoryExists(trimmed)) {
45
+ throw new Error(`Directory does not exist: ${resolve(trimmed)}`);
46
+ }
47
+ return trimmed;
48
+ }
49
+ return null;
50
+ }
51
+ while (true) {
52
+ const rootDir = await p.text({
53
+ message: chalk.bold("Root directory"),
54
+ placeholder: ".",
55
+ initialValue: ".",
56
+ validate: (value) => {
57
+ if (value != null && value.length > 512)
58
+ return "Path must be at most 512 characters.";
59
+ return undefined;
60
+ },
61
+ });
62
+ if (p.isCancel(rootDir))
63
+ return null;
64
+ const trimmed = rootDir.trim();
65
+ if (trimmed === "" || trimmed === ".")
66
+ return null;
67
+ if (!this.directoryExists(trimmed)) {
68
+ p.log.error(`Directory does not exist: ${trimmed}`);
69
+ continue;
70
+ }
71
+ return trimmed;
72
+ }
73
+ }
74
+ directoryExists(dir) {
75
+ return existsSync(dir) && statSync(dir).isDirectory();
76
+ }
77
+ detectRuntime() {
78
+ const has = (file) => existsSync(file);
79
+ const read = (file) => {
80
+ try {
81
+ return readFileSync(file, "utf8");
82
+ }
83
+ catch {
84
+ return "";
85
+ }
86
+ };
87
+ if (has("pyproject.toml") || has("requirements.txt") || has("setup.py") || has(".python-version")) {
88
+ return "python3.13";
89
+ }
90
+ if (has("package.json")) {
91
+ const nvmrc = has(".nvmrc") ? (read(".nvmrc").trim().split(/\s/)[0] ?? "") : "";
92
+ const major = nvmrc.replace(/^v/i, "").match(/^(\d+)/)?.[1];
93
+ if (major === "22")
94
+ return "node22";
95
+ return "node24";
96
+ }
97
+ return null;
98
+ }
99
+ async confirmDeployWithExistingConfig(existingConfig) {
100
+ const envLabel = existingConfig.environmentName ? ` to environment "${existingConfig.environmentName}"` : "";
101
+ const confirmed = await this.confirm({
102
+ message: chalk.bold(`Deploy project "${existingConfig.projectName}"${envLabel}?`),
103
+ initialValue: true,
104
+ });
105
+ if (p.isCancel(confirmed))
106
+ return null;
107
+ return confirmed === true;
108
+ }
109
+ async confirmDeployDirectory() {
110
+ const confirmed = await this.confirm({
111
+ message: chalk.bold(`Deploy the directory? `) + chalk.cyan(process.cwd()),
112
+ initialValue: true,
113
+ });
114
+ if (p.isCancel(confirmed))
115
+ return false;
116
+ return confirmed === true;
117
+ }
118
+ async confirmLinkExisting() {
119
+ const link = await this.confirm({
120
+ message: chalk.bold("Link to existing project?"),
121
+ initialValue: true,
122
+ }, false);
123
+ if (p.isCancel(link))
124
+ return false;
125
+ return link === true;
126
+ }
127
+ async confirmLinkToAnotherProject() {
128
+ const link = await this.confirm({
129
+ message: chalk.bold("Link to another project?"),
130
+ initialValue: true,
131
+ }, false);
132
+ if (p.isCancel(link))
133
+ return false;
134
+ return link === true;
135
+ }
136
+ async resolveProjectForDeploy() {
137
+ const ok = await this.confirmDeployDirectory();
138
+ if (!ok)
139
+ return null;
140
+ const existingConfig = config.load();
141
+ if (existingConfig) {
142
+ let confirmed;
143
+ while (true) {
144
+ confirmed = await this.confirmDeployWithExistingConfig(existingConfig);
145
+ if (confirmed === null)
146
+ return null;
147
+ if (confirmed)
148
+ break;
149
+ const linkAnother = await this.confirmLinkToAnotherProject();
150
+ if (p.isCancel(linkAnother))
151
+ return null;
152
+ if (linkAnother) {
153
+ const linkExisting = await this.confirmLinkExisting();
154
+ if (!linkExisting) {
155
+ return this.runCreateProjectFlow();
156
+ }
157
+ return this.runLinkingFlow();
158
+ }
159
+ }
160
+ if (existingConfig.environmentId) {
161
+ return {
162
+ projectId: existingConfig.projectId,
163
+ teamId: existingConfig.teamId,
164
+ projectName: existingConfig.projectName,
165
+ environmentId: existingConfig.environmentId,
166
+ environmentName: existingConfig.environmentName,
167
+ };
168
+ }
169
+ const env = await this.resolveEnvironmentForProject(existingConfig.projectId);
170
+ if (!env)
171
+ return null;
172
+ const updatedConfig = {
173
+ ...existingConfig,
174
+ environmentId: env.environmentId,
175
+ environmentName: env.environmentName,
176
+ };
177
+ config.save(updatedConfig);
178
+ p.note(`Environment "${env.environmentName}" will be used for future deploys.`, undefined, {
179
+ format: (line) => line,
180
+ });
181
+ return updatedConfig;
182
+ }
183
+ const linkExisting = await this.confirmLinkExisting();
184
+ if (!linkExisting) {
185
+ return this.runCreateProjectFlow();
186
+ }
187
+ return this.runLinkingFlow();
188
+ }
189
+ async resolveEnvironmentForProject(projectId) {
190
+ const project = await api.projects.get.v1({ projectId });
191
+ const environments = project.environments ?? [];
192
+ if (environments.length === 0) {
193
+ throw new Error("No environments found for this project.");
194
+ }
195
+ const environment = await this.selectEnvironmentFromList(environments);
196
+ if (!environment)
197
+ return null;
198
+ return { environmentId: environment.id, environmentName: environment.name };
199
+ }
200
+ async runCreateProjectFlow() {
201
+ if (this.isNonInteractive() && !this.flags.projectName) {
202
+ throw new Error("--project-name is required when using --non-interactive");
203
+ }
204
+ const name = this.flags.projectName ??
205
+ (await p.text({
206
+ message: chalk.bold("Project name"),
207
+ placeholder: "my-app",
208
+ validate: (value) => {
209
+ if (!value?.trim())
210
+ return "Project name is required.";
211
+ if (value.length > 100)
212
+ return "Project name must be at most 100 characters.";
213
+ return undefined;
214
+ },
215
+ }));
216
+ if (p.isCancel(name)) {
217
+ throw new Error("Project name is required.");
218
+ }
219
+ const detectedRuntime = this.detectRuntime();
220
+ const defaultRuntime = detectedRuntime ?? "node24";
221
+ const runtime = this.isNonInteractive()
222
+ ? (this.flags.runtime ?? defaultRuntime)
223
+ : await p.select({
224
+ message: chalk.bold("Runtime"),
225
+ options: [
226
+ { value: "node24", label: "Node.js 24" },
227
+ { value: "node22", label: "Node.js 22" },
228
+ { value: "python3.14", label: "Python 3.14" },
229
+ { value: "python3.13", label: "Python 3.13" },
230
+ ],
231
+ initialValue: defaultRuntime,
232
+ });
233
+ if (p.isCancel(runtime)) {
234
+ throw new Error("Runtime is required.");
235
+ }
236
+ const rootDirectory = await this.promptRootDirectory();
237
+ const spin = p.spinner();
238
+ spin.start("Creating project...");
239
+ try {
240
+ const projectInput = {
241
+ name,
242
+ runtime,
243
+ };
244
+ projectInput.rootDirectory = rootDirectory ?? undefined;
245
+ const created = await api.projects.create.v1(projectInput);
246
+ spin.stop("Project created.");
247
+ const productionEnv = created.productionEnvironment;
248
+ if (!productionEnv) {
249
+ throw new Error("Project was created but has no Production environment.");
250
+ }
251
+ const newConfig = {
252
+ projectId: created.id,
253
+ teamId: created.teamId,
254
+ projectName: created.name,
255
+ environmentId: productionEnv.id,
256
+ environmentName: productionEnv.name,
257
+ };
258
+ config.save(newConfig);
259
+ return newConfig;
260
+ }
261
+ catch (error) {
262
+ spin.stop();
263
+ throw error;
264
+ }
265
+ }
266
+ async runLinkingFlow() {
267
+ const projects = await api.projects.list.v1();
268
+ if (projects.length === 0) {
269
+ throw new Error("No projects found. Create a project in the Alpic dashboard first.");
270
+ }
271
+ const project = await this.selectProjectFromList(projects);
272
+ if (!project)
273
+ return null;
274
+ const environments = project.environments ?? [];
275
+ if (environments.length === 0) {
276
+ throw new Error("No environments found for this project.");
277
+ }
278
+ const environment = await this.selectEnvironmentFromList(environments);
279
+ if (!environment)
280
+ return null;
281
+ const newConfig = {
282
+ projectId: project.id,
283
+ teamId: project.teamId,
284
+ projectName: project.name,
285
+ environmentId: environment.id,
286
+ environmentName: environment.name,
287
+ };
288
+ config.save(newConfig);
289
+ p.note(`Linked to project "${project.name}", environment "${environment.name}".`, undefined, {
290
+ format: (line) => line,
291
+ });
292
+ return newConfig;
293
+ }
294
+ }
295
+ //# sourceMappingURL=project.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/lib/project.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ type TableColumn<Row extends Record<string, unknown>> = {
2
+ key: keyof Row;
3
+ header: string;
4
+ minWidth?: number;
5
+ format?: (value: string, row: Row) => string;
6
+ };
7
+ export declare const formatTable: <Row extends Record<string, unknown>>(rows: Row[], columns: TableColumn<Row>[]) => string;
8
+ export {};
@@ -0,0 +1,27 @@
1
+ import chalk from "chalk";
2
+ import { stripVTControlCharacters } from "node:util";
3
+ const visibleLength = (value) => stripVTControlCharacters(value).length;
4
+ const COLUMN_GAP = 4;
5
+ export const formatTable = (rows, columns) => {
6
+ const gap = " ".repeat(COLUMN_GAP);
7
+ const widths = columns.map((column) => {
8
+ const formattedLengths = rows.map((row) => {
9
+ const rawValue = String(row[column.key] ?? "");
10
+ const formattedValue = column.format ? column.format(rawValue, row) : rawValue;
11
+ return visibleLength(formattedValue);
12
+ });
13
+ return Math.max(column.minWidth ?? 0, column.header.length, ...formattedLengths);
14
+ });
15
+ const header = columns.map((column, index) => chalk.gray(column.header.padEnd(widths[index] ?? 0))).join(gap);
16
+ const body = rows.map((row) => columns
17
+ .map((column, index) => {
18
+ const rawValue = String(row[column.key] ?? "");
19
+ const formattedValue = column.format ? column.format(rawValue, row) : rawValue;
20
+ const padSize = Math.max(0, (widths[index] ?? 0) - visibleLength(formattedValue));
21
+ return `${formattedValue}${" ".repeat(padSize)}`;
22
+ })
23
+ .join(gap));
24
+ const content = [header, ...body].join("\n");
25
+ return `\n${content}\n`;
26
+ };
27
+ //# sourceMappingURL=table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table.js","sourceRoot":"","sources":["../../src/lib/table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AASrD,MAAM,aAAa,GAAG,CAAC,KAAa,EAAU,EAAE,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;AAExF,MAAM,UAAU,GAAG,CAAC,CAAC;AAErB,MAAM,CAAC,MAAM,WAAW,GAAG,CAAsC,IAAW,EAAE,OAA2B,EAAE,EAAE;IAC3G,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACnC,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QACpC,MAAM,gBAAgB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACxC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;YAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;YAC/E,OAAO,aAAa,CAAC,cAAc,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,gBAAgB,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAE9G,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAC5B,OAAO;SACJ,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;QACrB,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC/E,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC;QAClF,OAAO,GAAG,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;IACnD,CAAC,CAAC;SACD,IAAI,CAAC,GAAG,CAAC,CACb,CAAC;IAEF,MAAM,OAAO,GAAG,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAE7C,OAAO,KAAK,OAAO,IAAI,CAAC;AAC1B,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { Hook } from "@oclif/core";
2
+ export declare function isEnabled(): boolean;
3
+ export declare function isDebugMode(): boolean;
4
+ export declare function setEnabled(enabled: boolean): void;
5
+ export declare function getMachineId(): string;
6
+ declare const hook: Hook<"finally">;
7
+ export default hook;
@@ -0,0 +1,66 @@
1
+ import ci from "ci-info";
2
+ import crypto from "node:crypto";
3
+ import posthog from "../posthog.js";
4
+ import { globalStore } from "./global-store.js";
5
+ const ENV_TELEMETRY_DISABLED = "ALPIC_TELEMETRY_DISABLED";
6
+ const ENV_TELEMETRY_DEBUG = "ALPIC_TELEMETRY_DEBUG";
7
+ const ENV_DO_NOT_TRACK = "DO_NOT_TRACK";
8
+ export function isEnabled() {
9
+ if (process.env[ENV_TELEMETRY_DISABLED] === "1" || process.env[ENV_TELEMETRY_DISABLED]?.toLowerCase() === "true") {
10
+ return false;
11
+ }
12
+ if (process.env[ENV_DO_NOT_TRACK] === "1" || process.env[ENV_DO_NOT_TRACK]?.toLowerCase() === "true") {
13
+ return false;
14
+ }
15
+ if (ci.isCI) {
16
+ return true;
17
+ }
18
+ const config = globalStore.getConfig();
19
+ return config.telemetry.enabled;
20
+ }
21
+ export function isDebugMode() {
22
+ return process.env[ENV_TELEMETRY_DEBUG] === "1" || process.env[ENV_TELEMETRY_DEBUG]?.toLowerCase() === "true";
23
+ }
24
+ export function setEnabled(enabled) {
25
+ const config = globalStore.getConfig();
26
+ config.telemetry.enabled = enabled;
27
+ globalStore.saveConfig(config);
28
+ }
29
+ export function getMachineId() {
30
+ if (ci.isCI) {
31
+ return ci.name ?? "unknown-ci";
32
+ }
33
+ return globalStore.getConfig().machineId;
34
+ }
35
+ const hook = async ({ id: command, config: { version }, error, }) => {
36
+ if (!isEnabled()) {
37
+ return;
38
+ }
39
+ const event = {
40
+ command,
41
+ version,
42
+ machineId: getMachineId(),
43
+ sessionId: crypto.randomUUID(),
44
+ isCI: ci.isCI,
45
+ nodeVersion: process.version,
46
+ platform: process.platform,
47
+ outcome: error ? "failure" : "success",
48
+ error: error?.message,
49
+ };
50
+ if (isDebugMode()) {
51
+ console.error("[Telemetry Debug] Would send event:", JSON.stringify(event, null, 2));
52
+ return;
53
+ }
54
+ try {
55
+ posthog.capture({
56
+ distinctId: event.machineId,
57
+ event: command,
58
+ properties: event,
59
+ });
60
+ }
61
+ catch {
62
+ // Silently ignore telemetry errors - never block CLI operation
63
+ }
64
+ };
65
+ export default hook;
66
+ //# sourceMappingURL=telemetry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telemetry.js","sourceRoot":"","sources":["../../src/lib/telemetry.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function uploadToPresignedUrl(uploadUrl: string, buffer: Buffer): Promise<void>;
@@ -0,0 +1,14 @@
1
+ export async function uploadToPresignedUrl(uploadUrl, buffer) {
2
+ const res = await fetch(uploadUrl, {
3
+ method: "PUT",
4
+ headers: {
5
+ "Content-Type": "application/gzip",
6
+ "Content-Length": String(buffer.byteLength),
7
+ },
8
+ body: new Uint8Array(buffer),
9
+ });
10
+ if (!res.ok) {
11
+ throw new Error(`Upload failed: ${res.status} ${res.statusText}`);
12
+ }
13
+ }
14
+ //# sourceMappingURL=upload.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload.js","sourceRoot":"","sources":["../../src/lib/upload.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,SAAiB,EAAE,MAAc;IAC1E,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,SAAS,EAAE;QACjC,MAAM,EAAE,KAAK;QACb,OAAO,EAAE;YACP,cAAc,EAAE,kBAAkB;YAClC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC;SAC5C;QACD,IAAI,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC;KAC7B,CAAC,CAAC;IACH,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,kBAAkB,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC;IACpE,CAAC;AACH,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const formatAgo: (date: Date, now?: Date) => string;
@@ -0,0 +1,17 @@
1
+ export const formatAgo = (date, now = new Date()) => {
2
+ const rtf = new Intl.RelativeTimeFormat("en", { numeric: "auto" });
3
+ const diffInSeconds = Math.round((date.getTime() - now.getTime()) / 1000);
4
+ const absSeconds = Math.abs(diffInSeconds);
5
+ if (absSeconds < 60)
6
+ return rtf.format(diffInSeconds, "second");
7
+ if (absSeconds < 3600)
8
+ return rtf.format(Math.round(diffInSeconds / 60), "minute");
9
+ if (absSeconds < 86400)
10
+ return rtf.format(Math.round(diffInSeconds / 3600), "hour");
11
+ if (absSeconds < 2592000)
12
+ return rtf.format(Math.round(diffInSeconds / 86400), "day");
13
+ if (absSeconds < 31536000)
14
+ return rtf.format(Math.round(diffInSeconds / 2592000), "month");
15
+ return rtf.format(Math.round(diffInSeconds / 31536000), "year");
16
+ };
17
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,IAAU,EAAE,GAAG,GAAG,IAAI,IAAI,EAAE,EAAE,EAAE;IACxD,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IACnE,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,GAAG,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;IAC1E,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAE3C,IAAI,UAAU,GAAG,EAAE;QAAE,OAAO,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IAChE,IAAI,UAAU,GAAG,IAAI;QAAE,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;IACnF,IAAI,UAAU,GAAG,KAAK;QAAE,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;IACpF,IAAI,UAAU,GAAG,OAAO;QAAE,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC;IACtF,IAAI,UAAU,GAAG,QAAQ;QAAE,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC;IAC3F,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC;AAClE,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export {};