mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-20 06:35:22 +02:00
- Modified the database URL assignment logic to differentiate between production and development environments. - Ensured that the correct database URL is used based on the NODE_ENV variable, improving deployment flexibility.
46 lines
1.3 KiB
TypeScript
46 lines
1.3 KiB
TypeScript
import fs from "node:fs";
|
|
|
|
export const {
|
|
DATABASE_URL,
|
|
POSTGRES_PASSWORD_FILE,
|
|
POSTGRES_USER = "dokploy",
|
|
POSTGRES_DB = "dokploy",
|
|
POSTGRES_HOST = "dokploy-postgres",
|
|
POSTGRES_PORT = "5432",
|
|
} = process.env;
|
|
|
|
function readSecret(path: string): string {
|
|
try {
|
|
return fs.readFileSync(path, "utf8").trim();
|
|
} catch {
|
|
throw new Error(`Cannot read secret at ${path}`);
|
|
}
|
|
}
|
|
export let dbUrl: string;
|
|
if (DATABASE_URL) {
|
|
// Compatibilidad legacy / overrides
|
|
dbUrl = DATABASE_URL;
|
|
} else if (POSTGRES_PASSWORD_FILE) {
|
|
const password = readSecret(POSTGRES_PASSWORD_FILE);
|
|
dbUrl = `postgres://${POSTGRES_USER}:${encodeURIComponent(
|
|
password,
|
|
)}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB}`;
|
|
} else {
|
|
console.warn(`
|
|
⚠️ [DEPRECATED DATABASE CONFIG]
|
|
You are using the legacy hardcoded database credentials.
|
|
This mode WILL BE REMOVED in a future release.
|
|
|
|
Please migrate to Docker Secrets using POSTGRES_PASSWORD_FILE.
|
|
Please execute this command in your server: curl -sSL https://dokploy.com/security/0.26.6.sh | bash
|
|
`);
|
|
|
|
if (process.env.NODE_ENV === "production") {
|
|
dbUrl =
|
|
"postgres://dokploy:amukds4wi9001583845717ad2@dokploy-postgres:5432/dokploy";
|
|
} else {
|
|
dbUrl =
|
|
"postgres://dokploy:amukds4wi9001583845717ad2@localhost:5432/dokploy";
|
|
}
|
|
}
|