mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-15 20:25:23 +02:00
* refactor: improve restore logging for database backups - Updated restore functions across various database types (Postgres, MySQL, MongoDB, MariaDB, LibSQL, and Compose) to provide clearer logging messages. - Replaced generic command execution logs with specific messages indicating the database being restored and the source backup file. - This change enhances the clarity of restore operations and aids in troubleshooting by providing more context in the logs. * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
59 lines
1.5 KiB
TypeScript
59 lines
1.5 KiB
TypeScript
import type { apiRestoreBackup } from "@dokploy/server/db/schema";
|
|
import type { Destination } from "@dokploy/server/services/destination";
|
|
import type { Postgres } from "@dokploy/server/services/postgres";
|
|
import type { z } from "zod";
|
|
import { getS3Credentials } from "../backups/utils";
|
|
import { execAsync, execAsyncRemote } from "../process/execAsync";
|
|
import { getRestoreCommand } from "./utils";
|
|
|
|
export const restorePostgresBackup = async (
|
|
postgres: Postgres,
|
|
destination: Destination,
|
|
backupInput: z.infer<typeof apiRestoreBackup>,
|
|
emit: (log: string) => void,
|
|
) => {
|
|
try {
|
|
const { appName, databaseUser, serverId } = postgres;
|
|
|
|
const rcloneFlags = getS3Credentials(destination);
|
|
const bucketPath = `:s3:${destination.bucket}`;
|
|
|
|
const backupPath = `${bucketPath}/${backupInput.backupFile}`;
|
|
|
|
const rcloneCommand = `rclone cat ${rcloneFlags.join(" ")} "${backupPath}" | gunzip`;
|
|
|
|
const command = getRestoreCommand({
|
|
appName,
|
|
credentials: {
|
|
database: backupInput.databaseName,
|
|
databaseUser,
|
|
},
|
|
type: "postgres",
|
|
rcloneCommand,
|
|
restoreType: "database",
|
|
});
|
|
|
|
emit("Starting restore...");
|
|
emit(
|
|
`Restoring database: ${backupInput.databaseName} from ${backupInput.backupFile}`,
|
|
);
|
|
|
|
if (serverId) {
|
|
await execAsyncRemote(serverId, command);
|
|
} else {
|
|
await execAsync(command);
|
|
}
|
|
|
|
emit("Restore completed successfully!");
|
|
} catch (error) {
|
|
emit(
|
|
`Error: ${
|
|
error instanceof Error
|
|
? error.message
|
|
: "Error restoring postgres backup"
|
|
}`,
|
|
);
|
|
throw error;
|
|
}
|
|
};
|