alpic 0.0.0-dev.6b89b07 → 0.0.0-dev.6eac3b6
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.
- package/dist/api.d.ts +1 -9
- package/dist/api.js +0 -36
- package/dist/api.js.map +1 -1
- package/dist/commands/deploy.js +9 -27
- package/dist/commands/deploy.js.map +1 -1
- package/dist/lib/project.d.ts +2 -4
- package/dist/lib/project.js +11 -147
- package/dist/lib/project.js.map +1 -1
- package/dist/types.d.ts +1 -21
- package/package.json +3 -3
- package/dist/lib/deployment.d.ts +0 -11
- package/dist/lib/deployment.js +0 -38
- package/dist/lib/deployment.js.map +0 -1
package/dist/api.d.ts
CHANGED
|
@@ -1,17 +1,9 @@
|
|
|
1
|
-
import { type
|
|
2
|
-
export declare class ApiError extends Error {
|
|
3
|
-
readonly statusCode: number;
|
|
4
|
-
constructor(message: string, statusCode: number);
|
|
5
|
-
}
|
|
6
|
-
export declare function getFrontendBaseUrl(): string;
|
|
1
|
+
import { type ApiDeployment, type ApiProject, type PresignedUploadResponse } from "./types.js";
|
|
7
2
|
export declare const api: {
|
|
8
3
|
listProjects: () => Promise<ApiProject[]>;
|
|
9
4
|
getProject: (projectId: string) => Promise<ApiProject>;
|
|
10
|
-
createProject: (input: CreateProjectInput) => Promise<ApiCreateProjectOutput>;
|
|
11
5
|
getPresignedUploadUrl: () => Promise<PresignedUploadResponse>;
|
|
12
6
|
deployEnvironment: (environmentId: string, body?: {
|
|
13
7
|
token?: string;
|
|
14
8
|
}) => Promise<ApiDeployment>;
|
|
15
|
-
getDeployment: (deploymentId: string) => Promise<ApiDeployment>;
|
|
16
|
-
getEnvironment: (environmentId: string) => Promise<ApiEnvironment>;
|
|
17
9
|
};
|
package/dist/api.js
CHANGED
|
@@ -1,19 +1,7 @@
|
|
|
1
1
|
import {} from "./types.js";
|
|
2
|
-
export class ApiError extends Error {
|
|
3
|
-
statusCode;
|
|
4
|
-
constructor(message, statusCode) {
|
|
5
|
-
super(message);
|
|
6
|
-
this.statusCode = statusCode;
|
|
7
|
-
this.name = "ApiError";
|
|
8
|
-
Object.setPrototypeOf(this, ApiError.prototype);
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
2
|
function getApiBaseUrl() {
|
|
12
3
|
return process.env.ALPIC_API_BASE_URL ?? "https://api.alpic.ai";
|
|
13
4
|
}
|
|
14
|
-
export function getFrontendBaseUrl() {
|
|
15
|
-
return process.env.ALPIC_FRONTEND_BASE_URL ?? "https://app.alpic.ai";
|
|
16
|
-
}
|
|
17
5
|
const doFetch = async (path, options = {}) => {
|
|
18
6
|
const res = await fetch(`${getApiBaseUrl()}${path}`, {
|
|
19
7
|
...options,
|
|
@@ -22,17 +10,6 @@ const doFetch = async (path, options = {}) => {
|
|
|
22
10
|
...options.headers,
|
|
23
11
|
},
|
|
24
12
|
});
|
|
25
|
-
if (!res.ok) {
|
|
26
|
-
try {
|
|
27
|
-
const body = await res.json();
|
|
28
|
-
throw new ApiError(`${res.status} ${res.statusText}: ${body.message}`, res.status);
|
|
29
|
-
}
|
|
30
|
-
catch (error) {
|
|
31
|
-
if (error instanceof ApiError)
|
|
32
|
-
throw error;
|
|
33
|
-
throw new ApiError(res.statusText, res.status);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
13
|
return res.json();
|
|
37
14
|
};
|
|
38
15
|
export const api = {
|
|
@@ -42,13 +19,6 @@ export const api = {
|
|
|
42
19
|
getProject: async (projectId) => {
|
|
43
20
|
return doFetch(`/v1/projects/${projectId}`, { method: "GET" });
|
|
44
21
|
},
|
|
45
|
-
createProject: async (input) => {
|
|
46
|
-
return doFetch("/v1/projects", {
|
|
47
|
-
method: "POST",
|
|
48
|
-
body: JSON.stringify(input),
|
|
49
|
-
headers: { "Content-Type": "application/json" },
|
|
50
|
-
});
|
|
51
|
-
},
|
|
52
22
|
getPresignedUploadUrl: async () => {
|
|
53
23
|
return doFetch("/v1/deployments/upload", { method: "POST" });
|
|
54
24
|
},
|
|
@@ -59,11 +29,5 @@ export const api = {
|
|
|
59
29
|
headers: { "Content-Type": "application/json" },
|
|
60
30
|
});
|
|
61
31
|
},
|
|
62
|
-
getDeployment: async (deploymentId) => {
|
|
63
|
-
return doFetch(`/v1/deployments/${deploymentId}`, { method: "GET" });
|
|
64
|
-
},
|
|
65
|
-
getEnvironment: async (environmentId) => {
|
|
66
|
-
return doFetch(`/v1/environments/${environmentId}`, { method: "GET" });
|
|
67
|
-
},
|
|
68
32
|
};
|
|
69
33
|
//# sourceMappingURL=api.js.map
|
package/dist/api.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqE,MAAM,YAAY,CAAC;AAE/F,SAAS,aAAa;IACpB,OAAO,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,sBAAsB,CAAC;AAClE,CAAC;AAED,MAAM,OAAO,GAAG,KAAK,EAAK,IAAY,EAAE,UAAuB,EAAE,EAAc,EAAE;IAC/E,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,aAAa,EAAE,GAAG,IAAI,EAAE,EAAE;QACnD,GAAG,OAAO;QACV,OAAO,EAAE;YACP,aAAa,EAAE,UAAU,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE;YACpD,GAAI,OAAO,CAAC,OAAkC;SAC/C;KACF,CAAC,CAAC;IACH,OAAO,GAAG,CAAC,IAAI,EAAgB,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,GAAG,GAAG;IACjB,YAAY,EAAE,KAAK,IAAI,EAAE;QACvB,OAAO,OAAO,CAAe,cAAc,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAClE,CAAC;IACD,UAAU,EAAE,KAAK,EAAE,SAAiB,EAAE,EAAE;QACtC,OAAO,OAAO,CAAa,gBAAgB,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC7E,CAAC;IACD,qBAAqB,EAAE,KAAK,IAAI,EAAE;QAChC,OAAO,OAAO,CAA0B,wBAAwB,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IACxF,CAAC;IACD,iBAAiB,EAAE,KAAK,EAAE,aAAqB,EAAE,IAAyB,EAA0B,EAAE;QACpG,OAAO,OAAO,CAAgB,oBAAoB,aAAa,SAAS,EAAE;YACxE,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC;YAChC,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;SAChD,CAAC,CAAC;IACL,CAAC;CACF,CAAC"}
|
package/dist/commands/deploy.js
CHANGED
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import * as p from "@clack/prompts";
|
|
2
2
|
import { Args, Command } from "@oclif/core";
|
|
3
|
-
import chalk from "chalk";
|
|
4
3
|
import { readFileSync, rmSync } from "node:fs";
|
|
5
|
-
import { api
|
|
4
|
+
import { api } from "../api.js";
|
|
6
5
|
import { createTarArchive, getFilesToPack } from "../lib/archive.js";
|
|
7
|
-
import { deployAndWait, formatElapsed } from "../lib/deployment.js";
|
|
8
6
|
import { resolveDeployDir, resolveProjectForDeploy } from "../lib/project.js";
|
|
9
7
|
import { uploadToPresignedUrl } from "../lib/upload.js";
|
|
10
8
|
export class Deploy extends Command {
|
|
@@ -21,7 +19,7 @@ export class Deploy extends Command {
|
|
|
21
19
|
p.intro("Deploying to Alpic");
|
|
22
20
|
const apiKey = process.env.ALPIC_API_KEY;
|
|
23
21
|
if (!apiKey) {
|
|
24
|
-
p.cancel("ALPIC_API_KEY environment variable is required
|
|
22
|
+
p.cancel("ALPIC_API_KEY environment variable is required");
|
|
25
23
|
this.exit(1);
|
|
26
24
|
return;
|
|
27
25
|
}
|
|
@@ -38,42 +36,26 @@ export class Deploy extends Command {
|
|
|
38
36
|
spinner.start("Collecting source files...");
|
|
39
37
|
const files = getFilesToPack(deployDir);
|
|
40
38
|
spinner.stop(`Collected ${files.length} file${files.length === 1 ? "" : "s"}`);
|
|
39
|
+
spinner.start("Creating archive...");
|
|
41
40
|
const result = await createTarArchive(files, deployDir);
|
|
42
41
|
tmpDir = result.tmpDir;
|
|
43
42
|
const archivePath = result.archivePath;
|
|
43
|
+
spinner.stop("Archive created");
|
|
44
|
+
spinner.start("Getting upload URL...");
|
|
44
45
|
const { uploadUrl, token } = await api.getPresignedUploadUrl();
|
|
46
|
+
spinner.stop("Upload URL received");
|
|
45
47
|
spinner.start("Uploading source...");
|
|
46
48
|
const buffer = readFileSync(archivePath);
|
|
47
49
|
await uploadToPresignedUrl(uploadUrl, buffer);
|
|
48
50
|
spinner.stop("Upload complete");
|
|
49
51
|
spinner.start("Triggering deployment...");
|
|
50
|
-
const
|
|
51
|
-
const initialDeployment = await api.deployEnvironment(config.environmentId, { token });
|
|
52
|
+
const deployment = await api.deployEnvironment(config.environmentId, { token });
|
|
52
53
|
spinner.stop("Deployment started");
|
|
53
|
-
|
|
54
|
-
initial: initialDeployment,
|
|
55
|
-
startedAt: deployStartedAt,
|
|
56
|
-
teamId: config.teamId,
|
|
57
|
-
projectId: config.projectId,
|
|
58
|
-
});
|
|
59
|
-
const elapsedStr = formatElapsed(elapsedMs);
|
|
60
|
-
if (deployment.status !== "deployed") {
|
|
61
|
-
throw new Error("Deployment failed");
|
|
62
|
-
}
|
|
63
|
-
const environment = await api.getEnvironment(config.environmentId);
|
|
64
|
-
const urls = environment.mcpServerUrl ? [environment.mcpServerUrl] : environment.domains;
|
|
65
|
-
p.box([...urls.map((url) => chalk.bold(`🔗 ${url}`)), "", `Completed in ${elapsedStr}`].join("\n"), "Deployment summary:", {
|
|
66
|
-
contentAlign: "center",
|
|
67
|
-
titleAlign: "center",
|
|
68
|
-
width: "auto",
|
|
69
|
-
rounded: true,
|
|
70
|
-
contentPadding: 3,
|
|
71
|
-
});
|
|
54
|
+
p.outro(`Deployment ${deployment.id} is ${deployment.status}`);
|
|
72
55
|
}
|
|
73
56
|
catch (error) {
|
|
74
57
|
spinner.stop();
|
|
75
|
-
|
|
76
|
-
p.cancel(`Error: ${message}`);
|
|
58
|
+
p.cancel(`Error: ${error instanceof Error ? error.message : String(error)}`);
|
|
77
59
|
this.exit(1);
|
|
78
60
|
}
|
|
79
61
|
finally {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../src/commands/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../src/commands/deploy.ts"],"names":[],"mappings":"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"}
|
package/dist/lib/project.d.ts
CHANGED
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
import type { ApiEnvironment, ApiProject, ProjectConfig } from "../types.js";
|
|
2
2
|
export declare function resolveDeployDir(raw: string | undefined): string;
|
|
3
|
-
export declare function confirmDeployWithExistingConfig(existingConfig: ProjectConfig): Promise<boolean
|
|
3
|
+
export declare function confirmDeployWithExistingConfig(existingConfig: ProjectConfig): Promise<boolean>;
|
|
4
4
|
export declare function selectEnvironmentFromList(environments: ApiEnvironment[]): Promise<ApiEnvironment | null>;
|
|
5
|
-
export declare function
|
|
5
|
+
export declare function confirmDeployWithoutConfig(deployDir: string): Promise<boolean>;
|
|
6
6
|
export declare function confirmLinkExisting(): Promise<boolean>;
|
|
7
|
-
export declare function confirmLinkToAnotherProject(): Promise<boolean>;
|
|
8
7
|
export declare function selectProjectFromList(projects: ApiProject[]): Promise<ApiProject | null>;
|
|
9
|
-
export declare function promptRootDirectory(deployDir: string): Promise<string | null | undefined>;
|
|
10
8
|
export declare function resolveProjectForDeploy(deployDir: string): Promise<(ProjectConfig & {
|
|
11
9
|
environmentId: string;
|
|
12
10
|
}) | null>;
|
package/dist/lib/project.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import * as p from "@clack/prompts";
|
|
2
2
|
import chalk from "chalk";
|
|
3
|
-
import { existsSync,
|
|
3
|
+
import { existsSync, statSync } from "node:fs";
|
|
4
4
|
import { resolve } from "node:path";
|
|
5
5
|
import { api } from "../api.js";
|
|
6
6
|
import { config } from "./config.js";
|
|
@@ -21,7 +21,7 @@ export async function confirmDeployWithExistingConfig(existingConfig) {
|
|
|
21
21
|
initialValue: true,
|
|
22
22
|
});
|
|
23
23
|
if (p.isCancel(confirm))
|
|
24
|
-
return
|
|
24
|
+
return false;
|
|
25
25
|
return confirm === true;
|
|
26
26
|
}
|
|
27
27
|
export async function selectEnvironmentFromList(environments) {
|
|
@@ -32,7 +32,7 @@ export async function selectEnvironmentFromList(environments) {
|
|
|
32
32
|
message: chalk.bold("Choose an environment to deploy to"),
|
|
33
33
|
options: environments.map((env) => ({
|
|
34
34
|
value: env.id,
|
|
35
|
-
label:
|
|
35
|
+
label: `${env.name} (${env.sourceBranch})`,
|
|
36
36
|
})),
|
|
37
37
|
});
|
|
38
38
|
if (p.isCancel(choice))
|
|
@@ -40,7 +40,7 @@ export async function selectEnvironmentFromList(environments) {
|
|
|
40
40
|
const environment = environments.find((e) => e.id === choice);
|
|
41
41
|
return environment ?? null;
|
|
42
42
|
}
|
|
43
|
-
export async function
|
|
43
|
+
export async function confirmDeployWithoutConfig(deployDir) {
|
|
44
44
|
const confirm = await p.confirm({
|
|
45
45
|
message: chalk.bold(`Deploy the directory? `) + chalk.cyan(deployDir),
|
|
46
46
|
initialValue: true,
|
|
@@ -58,15 +58,6 @@ export async function confirmLinkExisting() {
|
|
|
58
58
|
return false;
|
|
59
59
|
return link === true;
|
|
60
60
|
}
|
|
61
|
-
export async function confirmLinkToAnotherProject() {
|
|
62
|
-
const link = await p.confirm({
|
|
63
|
-
message: chalk.bold("Link to another project?"),
|
|
64
|
-
initialValue: true,
|
|
65
|
-
});
|
|
66
|
-
if (p.isCancel(link))
|
|
67
|
-
return false;
|
|
68
|
-
return link === true;
|
|
69
|
-
}
|
|
70
61
|
export async function selectProjectFromList(projects) {
|
|
71
62
|
if (projects.length === 0) {
|
|
72
63
|
return null;
|
|
@@ -80,35 +71,6 @@ export async function selectProjectFromList(projects) {
|
|
|
80
71
|
const project = projects.find((proj) => proj.id === choice);
|
|
81
72
|
return project ?? null;
|
|
82
73
|
}
|
|
83
|
-
export async function promptRootDirectory(deployDir) {
|
|
84
|
-
while (true) {
|
|
85
|
-
const rootDir = await p.text({
|
|
86
|
-
message: chalk.bold("Root directory"),
|
|
87
|
-
placeholder: ".",
|
|
88
|
-
initialValue: ".",
|
|
89
|
-
validate: (value) => {
|
|
90
|
-
if (value != null && value.length > 512)
|
|
91
|
-
return "Path must be at most 512 characters.";
|
|
92
|
-
return undefined;
|
|
93
|
-
},
|
|
94
|
-
});
|
|
95
|
-
if (p.isCancel(rootDir))
|
|
96
|
-
return null;
|
|
97
|
-
const trimmed = rootDir.trim();
|
|
98
|
-
if (trimmed === "" || trimmed === ".")
|
|
99
|
-
return undefined;
|
|
100
|
-
const resolved = resolve(deployDir, trimmed);
|
|
101
|
-
if (!existsSync(resolved)) {
|
|
102
|
-
p.log.error(`Path does not exist: ${resolved}`);
|
|
103
|
-
continue;
|
|
104
|
-
}
|
|
105
|
-
if (!statSync(resolved).isDirectory()) {
|
|
106
|
-
p.log.error(`Path is not a directory: ${resolved}`);
|
|
107
|
-
continue;
|
|
108
|
-
}
|
|
109
|
-
return trimmed;
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
74
|
async function resolveEnvironmentForProject(projectId) {
|
|
113
75
|
const project = await api.getProject(projectId);
|
|
114
76
|
const environments = project.environments ?? [];
|
|
@@ -121,29 +83,11 @@ async function resolveEnvironmentForProject(projectId) {
|
|
|
121
83
|
return { environmentId: environment.id, environmentName: environment.name };
|
|
122
84
|
}
|
|
123
85
|
export async function resolveProjectForDeploy(deployDir) {
|
|
124
|
-
const ok = await confirmDeployDirectory(deployDir);
|
|
125
|
-
if (!ok)
|
|
126
|
-
return null;
|
|
127
86
|
const existingConfig = config.load(deployDir);
|
|
128
87
|
if (existingConfig) {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
if (confirm === null)
|
|
133
|
-
return null;
|
|
134
|
-
if (confirm)
|
|
135
|
-
break;
|
|
136
|
-
const linkAnother = await confirmLinkToAnotherProject();
|
|
137
|
-
if (p.isCancel(linkAnother))
|
|
138
|
-
return null;
|
|
139
|
-
if (linkAnother) {
|
|
140
|
-
const linkExisting = await confirmLinkExisting();
|
|
141
|
-
if (!linkExisting) {
|
|
142
|
-
return runCreateProjectFlow(deployDir);
|
|
143
|
-
}
|
|
144
|
-
return runLinkingFlow(deployDir);
|
|
145
|
-
}
|
|
146
|
-
}
|
|
88
|
+
const ok = await confirmDeployWithExistingConfig(existingConfig);
|
|
89
|
+
if (!ok)
|
|
90
|
+
return null;
|
|
147
91
|
if (existingConfig.environmentId) {
|
|
148
92
|
return {
|
|
149
93
|
projectId: existingConfig.projectId,
|
|
@@ -165,72 +109,14 @@ export async function resolveProjectForDeploy(deployDir) {
|
|
|
165
109
|
p.note(`Environment "${env.environmentName}" will be used for future deploys.`);
|
|
166
110
|
return updatedConfig;
|
|
167
111
|
}
|
|
112
|
+
const ok = await confirmDeployWithoutConfig(deployDir);
|
|
113
|
+
if (!ok)
|
|
114
|
+
return null;
|
|
168
115
|
const linkExisting = await confirmLinkExisting();
|
|
169
116
|
if (!linkExisting) {
|
|
170
|
-
|
|
171
|
-
}
|
|
172
|
-
return runLinkingFlow(deployDir);
|
|
173
|
-
}
|
|
174
|
-
async function runCreateProjectFlow(deployDir) {
|
|
175
|
-
const name = await p.text({
|
|
176
|
-
message: chalk.bold("Project name"),
|
|
177
|
-
placeholder: "my-app",
|
|
178
|
-
validate: (value) => {
|
|
179
|
-
if (!value?.trim())
|
|
180
|
-
return "Project name is required.";
|
|
181
|
-
if (value.length > 100)
|
|
182
|
-
return "Project name must be at most 100 characters.";
|
|
183
|
-
return undefined;
|
|
184
|
-
},
|
|
185
|
-
});
|
|
186
|
-
if (p.isCancel(name))
|
|
117
|
+
p.note("Creating a new project is not implemented yet.", "Not yet implemented");
|
|
187
118
|
return null;
|
|
188
|
-
const detectedRuntime = detectRuntime(deployDir);
|
|
189
|
-
const runtime = await p.select({
|
|
190
|
-
message: chalk.bold("Runtime"),
|
|
191
|
-
options: [
|
|
192
|
-
{ value: "node24", label: "Node.js 24" },
|
|
193
|
-
{ value: "node22", label: "Node.js 22" },
|
|
194
|
-
{ value: "python3.14", label: "Python 3.14" },
|
|
195
|
-
{ value: "python3.13", label: "Python 3.13" },
|
|
196
|
-
],
|
|
197
|
-
initialValue: detectedRuntime ?? "node24",
|
|
198
|
-
});
|
|
199
|
-
if (p.isCancel(runtime))
|
|
200
|
-
return null;
|
|
201
|
-
const rootDirectory = await promptRootDirectory(deployDir);
|
|
202
|
-
const spin = p.spinner();
|
|
203
|
-
spin.start("Creating project...");
|
|
204
|
-
try {
|
|
205
|
-
const projectInput = {
|
|
206
|
-
name: name.trim(),
|
|
207
|
-
runtime,
|
|
208
|
-
};
|
|
209
|
-
if (rootDirectory) {
|
|
210
|
-
projectInput.rootDirectory = rootDirectory;
|
|
211
|
-
}
|
|
212
|
-
const created = await api.createProject(projectInput);
|
|
213
|
-
spin.stop("Project created.");
|
|
214
|
-
const productionEnv = created.productionEnvironment;
|
|
215
|
-
if (!productionEnv) {
|
|
216
|
-
throw new Error("Project was created but has no Production environment.");
|
|
217
|
-
}
|
|
218
|
-
const newConfig = {
|
|
219
|
-
projectId: created.id,
|
|
220
|
-
teamId: created.teamId,
|
|
221
|
-
projectName: created.name,
|
|
222
|
-
environmentId: productionEnv.id,
|
|
223
|
-
environmentName: productionEnv.name,
|
|
224
|
-
};
|
|
225
|
-
config.save(newConfig, deployDir);
|
|
226
|
-
return newConfig;
|
|
227
|
-
}
|
|
228
|
-
catch (error) {
|
|
229
|
-
spin.stop();
|
|
230
|
-
throw error;
|
|
231
119
|
}
|
|
232
|
-
}
|
|
233
|
-
async function runLinkingFlow(deployDir) {
|
|
234
120
|
const projects = await api.listProjects();
|
|
235
121
|
if (projects.length === 0) {
|
|
236
122
|
throw new Error("No projects found. Create a project in the Alpic dashboard first.");
|
|
@@ -256,26 +142,4 @@ async function runLinkingFlow(deployDir) {
|
|
|
256
142
|
p.note(`Linked to project "${project.name}", environment "${environment.name}".`);
|
|
257
143
|
return newConfig;
|
|
258
144
|
}
|
|
259
|
-
function detectRuntime(dir) {
|
|
260
|
-
const has = (file) => existsSync(resolve(dir, file));
|
|
261
|
-
const read = (file) => {
|
|
262
|
-
try {
|
|
263
|
-
return readFileSync(resolve(dir, file), "utf8");
|
|
264
|
-
}
|
|
265
|
-
catch {
|
|
266
|
-
return "";
|
|
267
|
-
}
|
|
268
|
-
};
|
|
269
|
-
if (has("pyproject.toml") || has("requirements.txt") || has("setup.py") || has(".python-version")) {
|
|
270
|
-
return "python3.13";
|
|
271
|
-
}
|
|
272
|
-
if (has("package.json")) {
|
|
273
|
-
const nvmrc = has(".nvmrc") ? (read(".nvmrc").trim().split(/\s/)[0] ?? "") : "";
|
|
274
|
-
const major = nvmrc.replace(/^v/i, "").match(/^(\d+)/)?.[1];
|
|
275
|
-
if (major === "22")
|
|
276
|
-
return "node22";
|
|
277
|
-
return "node24";
|
|
278
|
-
}
|
|
279
|
-
return null;
|
|
280
|
-
}
|
|
281
145
|
//# sourceMappingURL=project.js.map
|
package/dist/lib/project.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/lib/project.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,
|
|
1
|
+
{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/lib/project.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
CHANGED
|
@@ -20,7 +20,6 @@ export type ApiEnvironment = {
|
|
|
20
20
|
sourceBranch: string;
|
|
21
21
|
mcpServerUrl: string;
|
|
22
22
|
projectId: string;
|
|
23
|
-
domains: string[];
|
|
24
23
|
};
|
|
25
24
|
export type ProjectConfig = {
|
|
26
25
|
projectId: string;
|
|
@@ -31,7 +30,7 @@ export type ProjectConfig = {
|
|
|
31
30
|
};
|
|
32
31
|
export type ApiDeployment = {
|
|
33
32
|
id: string;
|
|
34
|
-
status:
|
|
33
|
+
status: string;
|
|
35
34
|
sourceRef: string;
|
|
36
35
|
sourceCommitId?: string;
|
|
37
36
|
sourceCommitMessage?: string;
|
|
@@ -40,22 +39,3 @@ export type ApiDeployment = {
|
|
|
40
39
|
startedAt: string | null;
|
|
41
40
|
completedAt: string | null;
|
|
42
41
|
};
|
|
43
|
-
export type Runtime = "node22" | "node24" | "python3.13" | "python3.14";
|
|
44
|
-
export type CreateProjectInput = {
|
|
45
|
-
name: string;
|
|
46
|
-
runtime: Runtime;
|
|
47
|
-
rootDirectory?: string;
|
|
48
|
-
};
|
|
49
|
-
export type ApiCreateProjectOutput = {
|
|
50
|
-
id: string;
|
|
51
|
-
name: string;
|
|
52
|
-
teamId: string;
|
|
53
|
-
productionEnvironment: {
|
|
54
|
-
id: string;
|
|
55
|
-
name: string;
|
|
56
|
-
} | null;
|
|
57
|
-
environments: {
|
|
58
|
-
id: string;
|
|
59
|
-
name: string;
|
|
60
|
-
}[];
|
|
61
|
-
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "alpic",
|
|
3
|
-
"version": "0.0.0-dev.
|
|
3
|
+
"version": "0.0.0-dev.6eac3b6",
|
|
4
4
|
"description": "The command-line interface for Alpic",
|
|
5
5
|
"homepage": "https://alpic.ai",
|
|
6
6
|
"preferGlobal": true,
|
|
@@ -25,12 +25,12 @@
|
|
|
25
25
|
"author": "Alpic",
|
|
26
26
|
"license": "ISC",
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"@clack/prompts": "^
|
|
29
|
-
"@oclif/core": "^4.8.0",
|
|
28
|
+
"@clack/prompts": "^0.8.2",
|
|
30
29
|
"chalk": "^5.6.2",
|
|
31
30
|
"tar": "^7.4.0"
|
|
32
31
|
},
|
|
33
32
|
"devDependencies": {
|
|
33
|
+
"@oclif/core": "^4.8.0",
|
|
34
34
|
"@total-typescript/tsconfig": "^1.0.4",
|
|
35
35
|
"@types/node": "^25.1.0",
|
|
36
36
|
"biome": "^0.3.3",
|
package/dist/lib/deployment.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { ApiDeployment } from "../types.js";
|
|
2
|
-
export declare function formatElapsed(ms: number): string;
|
|
3
|
-
export declare function deployAndWait({ initial, startedAt, teamId, projectId, }: {
|
|
4
|
-
initial: ApiDeployment;
|
|
5
|
-
startedAt: number;
|
|
6
|
-
teamId: string;
|
|
7
|
-
projectId: string;
|
|
8
|
-
}): Promise<{
|
|
9
|
-
deployment: ApiDeployment;
|
|
10
|
-
elapsedMs: number;
|
|
11
|
-
}>;
|
package/dist/lib/deployment.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import * as p from "@clack/prompts";
|
|
2
|
-
import chalk from "chalk";
|
|
3
|
-
import { api, getFrontendBaseUrl } from "../api.js";
|
|
4
|
-
export function formatElapsed(ms) {
|
|
5
|
-
const totalSeconds = Math.floor(ms / 1000);
|
|
6
|
-
const minutes = Math.floor(totalSeconds / 60);
|
|
7
|
-
const seconds = totalSeconds % 60;
|
|
8
|
-
return minutes > 0 ? `${minutes}m ${seconds}s` : `${seconds}s`;
|
|
9
|
-
}
|
|
10
|
-
export async function deployAndWait({ initial, startedAt, teamId, projectId, }) {
|
|
11
|
-
const spinner = p.spinner();
|
|
12
|
-
spinner.start("Deployment in progress");
|
|
13
|
-
const deploymentPageUrl = `${getFrontendBaseUrl()}/team/${teamId}/project/${projectId}/deployments/${initial.id}`;
|
|
14
|
-
p.note(deploymentPageUrl, "View deployment details:");
|
|
15
|
-
const elapsedInterval = setInterval(() => {
|
|
16
|
-
const elapsed = formatElapsed(Date.now() - startedAt);
|
|
17
|
-
spinner.message(`Deployment in progress — ${elapsed}`);
|
|
18
|
-
}, 1000);
|
|
19
|
-
const timeoutMs = 15 * 60 * 1000; // 15 minutes
|
|
20
|
-
let deployment = initial;
|
|
21
|
-
try {
|
|
22
|
-
while (deployment.status === "ongoing") {
|
|
23
|
-
const elapsedMs = Date.now() - startedAt;
|
|
24
|
-
if (elapsedMs >= timeoutMs) {
|
|
25
|
-
throw new Error(`Deployment aborted after 15 minutes. View status: ${deploymentPageUrl}`);
|
|
26
|
-
}
|
|
27
|
-
await new Promise((resolve) => setTimeout(resolve, 10_000));
|
|
28
|
-
deployment = await api.getDeployment(deployment.id);
|
|
29
|
-
}
|
|
30
|
-
return { deployment, elapsedMs: Date.now() - startedAt };
|
|
31
|
-
}
|
|
32
|
-
finally {
|
|
33
|
-
const message = deployment.status === "deployed" ? chalk.green("Deployment completed") : chalk.red("Deployment failed");
|
|
34
|
-
spinner.stop(message);
|
|
35
|
-
clearInterval(elapsedInterval);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
//# sourceMappingURL=deployment.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"deployment.js","sourceRoot":"","sources":["../../src/lib/deployment.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,GAAG,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAGpD,MAAM,UAAU,aAAa,CAAC,EAAU;IACtC,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;IAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG,YAAY,GAAG,EAAE,CAAC;IAClC,OAAO,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,KAAK,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,OAAO,GAAG,CAAC;AACjE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAClC,OAAO,EACP,SAAS,EACT,MAAM,EACN,SAAS,GAMV;IACC,MAAM,OAAO,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;IAE5B,OAAO,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;IAExC,MAAM,iBAAiB,GAAG,GAAG,kBAAkB,EAAE,SAAS,MAAM,YAAY,SAAS,gBAAgB,OAAO,CAAC,EAAE,EAAE,CAAC;IAClH,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,0BAA0B,CAAC,CAAC;IAEtD,MAAM,eAAe,GAAG,WAAW,CAAC,GAAG,EAAE;QACvC,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC,CAAC;QACtD,OAAO,CAAC,OAAO,CAAC,4BAA4B,OAAO,EAAE,CAAC,CAAC;IACzD,CAAC,EAAE,IAAI,CAAC,CAAC;IAET,MAAM,SAAS,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,aAAa;IAC/C,IAAI,UAAU,GAAG,OAAO,CAAC;IACzB,IAAI,CAAC;QACH,OAAO,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YACzC,IAAI,SAAS,IAAI,SAAS,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CAAC,qDAAqD,iBAAiB,EAAE,CAAC,CAAC;YAC5F,CAAC;YACD,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;YAC5D,UAAU,GAAG,MAAM,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;IAC3D,CAAC;YAAS,CAAC;QACT,MAAM,OAAO,GACX,UAAU,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QAC1G,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtB,aAAa,CAAC,eAAe,CAAC,CAAC;IACjC,CAAC;AACH,CAAC"}
|