mirror of
https://github.com/stack-auth/stack.git
synced 2026-06-13 21:01:21 +08:00
# Conflicts: # apps/backend/package.json # apps/dashboard/package.json # apps/dev-launchpad/package.json # apps/e2e/package.json # apps/hosted-components/package.json # apps/internal-tool/package.json # apps/mcp/package.json # apps/mock-oauth-server/package.json # apps/skills/package.json # docs-mintlify/package.json # docs/package.json # examples/cjs-test/package.json # examples/convex/package.json # examples/demo/package.json # examples/docs-examples/package.json # examples/e-commerce/package.json # examples/js-example/package.json # examples/lovable-react-18-example/package.json # examples/middleware/package.json # examples/react-example/package.json # examples/supabase/package.json # examples/tanstack-start-demo/package.json # packages/dashboard-ui-components/package.json # packages/init-stack/package.json # packages/js/package.json # packages/react/package.json # packages/stack-cli/package.json # packages/stack-sc/package.json # packages/stack-shared/package.json # packages/stack-ui/package.json # packages/stack/package.json # packages/tanstack-start/package.json # packages/template/package-template.json # packages/template/package.json # sdks/implementations/swift/package.json # sdks/spec/package.json
116 lines
4.4 KiB
JavaScript
116 lines
4.4 KiB
JavaScript
#!/usr/bin/env node
|
|
import { execFileSync } from "child_process";
|
|
import { chmodSync, cpSync, existsSync, mkdirSync, readlinkSync, readdirSync, rmSync } from "fs";
|
|
import { dirname, join, relative, resolve } from "path";
|
|
import { fileURLToPath } from "url";
|
|
|
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
const packageRoot = resolve(__dirname, "..");
|
|
const repoRoot = resolve(packageRoot, "../..");
|
|
const qemuSrc = resolve(repoRoot, "docker/local-emulator/qemu");
|
|
const envGenScript = resolve(repoRoot, "docker/local-emulator/generate-env-development.mjs");
|
|
const envSrc = resolve(repoRoot, "docker/local-emulator/.env.development");
|
|
const dashboardRoot = resolve(repoRoot, "apps/dashboard");
|
|
const dashboardStandaloneSrc = join(dashboardRoot, ".next/standalone");
|
|
const dashboardStaticSrc = join(dashboardRoot, ".next/static");
|
|
const dashboardPublicSrc = join(dashboardRoot, "public");
|
|
const distDir = join(packageRoot, "dist");
|
|
const emulatorDist = join(distDir, "emulator");
|
|
const dashboardDist = join(distDir, "dashboard");
|
|
|
|
function assertExists(path, message) {
|
|
if (!existsSync(path)) {
|
|
throw new Error(message);
|
|
}
|
|
}
|
|
|
|
function copyEmulatorAssets() {
|
|
execFileSync(process.execPath, [envGenScript], { stdio: "inherit" });
|
|
|
|
mkdirSync(emulatorDist, { recursive: true });
|
|
|
|
for (const name of ["run-emulator.sh", "common.sh", "cloud-init"]) {
|
|
cpSync(join(qemuSrc, name), join(emulatorDist, name), { recursive: true });
|
|
}
|
|
|
|
chmodSync(join(emulatorDist, "run-emulator.sh"), 0o755);
|
|
cpSync(envSrc, join(distDir, ".env.development"));
|
|
|
|
console.log(`Copied emulator assets into ${emulatorDist} (+ .env.development into ${distDir}).`);
|
|
}
|
|
|
|
function shouldCopyDashboardFile(path) {
|
|
return existsSync(path);
|
|
}
|
|
|
|
function copyDashboardSymlinkTarget(src, dest) {
|
|
rmSync(dest, { recursive: true, force: true });
|
|
cpSync(src, dest, { recursive: true, dereference: true, filter: shouldCopyDashboardFile });
|
|
}
|
|
|
|
function splitDashboardPath(root, path) {
|
|
return relative(root, path).split(/[\\/]+/);
|
|
}
|
|
|
|
function getDashboardDependencyName(pnpmRoot, path) {
|
|
const parts = splitDashboardPath(pnpmRoot, path);
|
|
const nodeModulesIndex = parts.lastIndexOf("node_modules");
|
|
if (nodeModulesIndex < 0) {
|
|
return undefined;
|
|
}
|
|
const dependencyParts = parts.slice(nodeModulesIndex + 1);
|
|
if (dependencyParts.length === 1) {
|
|
return dependencyParts[0];
|
|
}
|
|
if (dependencyParts.length === 2 && dependencyParts[0].startsWith("@")) {
|
|
return join(dependencyParts[0], dependencyParts[1]);
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
function copyDashboardHoistedDependencies(pnpmRoot, current = pnpmRoot) {
|
|
for (const entry of readdirSync(current, { withFileTypes: true })) {
|
|
const path = join(current, entry.name);
|
|
if (entry.isDirectory()) {
|
|
copyDashboardHoistedDependencies(pnpmRoot, path);
|
|
continue;
|
|
}
|
|
if (!entry.isSymbolicLink() || !existsSync(path)) {
|
|
continue;
|
|
}
|
|
const dependencyName = getDashboardDependencyName(pnpmRoot, path);
|
|
if (dependencyName == null) {
|
|
continue;
|
|
}
|
|
const target = resolve(current, readlinkSync(path));
|
|
const parts = splitDashboardPath(pnpmRoot, path);
|
|
if (parts[0] !== "node_modules" && existsSync(join(target, "package.json"))) {
|
|
copyDashboardSymlinkTarget(target, join(dashboardDist, "node_modules", dependencyName));
|
|
}
|
|
}
|
|
}
|
|
|
|
function copyDashboardAssets() {
|
|
assertExists(
|
|
join(dashboardStandaloneSrc, "apps/dashboard/server.js"),
|
|
"Dashboard standalone build is missing. Run `pnpm exec turbo run build:rde-standalone --filter=@hexclave/dashboard` before building @hexclave/cli.",
|
|
);
|
|
assertExists(
|
|
dashboardStaticSrc,
|
|
"Dashboard static assets are missing. Run `pnpm exec turbo run build:rde-standalone --filter=@hexclave/dashboard` before building @hexclave/cli.",
|
|
);
|
|
|
|
rmSync(dashboardDist, { recursive: true, force: true });
|
|
cpSync(dashboardStandaloneSrc, dashboardDist, { recursive: true, dereference: true, filter: shouldCopyDashboardFile });
|
|
cpSync(dashboardStaticSrc, join(dashboardDist, "apps/dashboard/.next/static"), { recursive: true });
|
|
if (existsSync(dashboardPublicSrc)) {
|
|
cpSync(dashboardPublicSrc, join(dashboardDist, "apps/dashboard/public"), { recursive: true });
|
|
}
|
|
copyDashboardHoistedDependencies(join(dashboardStandaloneSrc, "node_modules/.pnpm"));
|
|
|
|
console.log(`Copied dashboard standalone runtime into ${dashboardDist}.`);
|
|
}
|
|
|
|
copyEmulatorAssets();
|
|
copyDashboardAssets();
|