2023-03-15 09:17:51 -04:00
|
|
|
import { inject as service } from "@ember/service";
|
2015-11-20 20:27:06 -05:00
|
|
|
import Backup from "admin/models/backup";
|
|
|
|
import BackupStatus from "admin/models/backup-status";
|
2019-10-22 09:46:10 -04:00
|
|
|
import DiscourseRoute from "discourse/routes/discourse";
|
2023-03-15 09:17:51 -04:00
|
|
|
import EmberObject, { action } from "@ember/object";
|
2020-05-13 16:23:41 -04:00
|
|
|
import I18n from "I18n";
|
2020-05-06 15:28:06 -04:00
|
|
|
import PreloadStore from "discourse/lib/preload-store";
|
2019-11-12 11:38:51 -05:00
|
|
|
import User from "discourse/models/user";
|
2016-06-30 13:55:44 -04:00
|
|
|
import { ajax } from "discourse/lib/ajax";
|
2021-01-20 00:04:21 -05:00
|
|
|
import { extractError } from "discourse/lib/ajax-error";
|
2020-06-03 12:45:26 -04:00
|
|
|
import getURL from "discourse-common/lib/get-url";
|
2022-12-12 10:32:25 -05:00
|
|
|
import { bind } from "discourse-common/utils/decorators";
|
2023-08-01 09:40:25 -04:00
|
|
|
import StartBackupModal from "admin/components/modal/start-backup";
|
2022-12-12 10:32:25 -05:00
|
|
|
|
2015-03-12 12:12:23 -04:00
|
|
|
const LOG_CHANNEL = "/admin/backups/logs";
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
export default class AdminBackupsRoute extends DiscourseRoute {
|
|
|
|
@service dialog;
|
2023-07-18 15:52:55 -04:00
|
|
|
@service router;
|
2023-08-01 09:40:25 -04:00
|
|
|
@service messageBus;
|
|
|
|
@service modal;
|
2022-09-14 11:06:56 -04:00
|
|
|
|
2015-03-10 15:01:15 -04:00
|
|
|
activate() {
|
2022-12-12 10:32:25 -05:00
|
|
|
this.messageBus.subscribe(LOG_CHANNEL, this.onMessage);
|
2023-03-15 09:17:51 -04:00
|
|
|
}
|
2022-12-12 10:32:25 -05:00
|
|
|
|
|
|
|
deactivate() {
|
|
|
|
this.messageBus.unsubscribe(LOG_CHANNEL, this.onMessage);
|
2023-03-15 09:17:51 -04:00
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2015-03-10 15:01:15 -04:00
|
|
|
model() {
|
2019-01-23 11:40:24 -05:00
|
|
|
return PreloadStore.getAndRemove("operations_status", () =>
|
|
|
|
ajax("/admin/backups/status.json")
|
|
|
|
).then((status) =>
|
|
|
|
BackupStatus.create({
|
2014-02-12 23:35:46 -05:00
|
|
|
isOperationRunning: status.is_operation_running,
|
2014-08-28 17:02:26 -04:00
|
|
|
canRollback: status.can_rollback,
|
|
|
|
allowRestore: status.allow_restore,
|
2019-01-23 11:40:24 -05:00
|
|
|
})
|
|
|
|
);
|
2023-03-15 09:17:51 -04:00
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2022-12-12 10:32:25 -05:00
|
|
|
@bind
|
|
|
|
onMessage(log) {
|
|
|
|
if (log.message === "[STARTED]") {
|
|
|
|
User.currentProp("hideReadOnlyAlert", true);
|
|
|
|
this.controllerFor("adminBackups").set("model.isOperationRunning", true);
|
|
|
|
this.controllerFor("adminBackupsLogs").get("logs").clear();
|
|
|
|
} else if (log.message === "[FAILED]") {
|
|
|
|
this.controllerFor("adminBackups").set("model.isOperationRunning", false);
|
|
|
|
this.dialog.alert(
|
|
|
|
I18n.t("admin.backups.operations.failed", {
|
|
|
|
operation: log.operation,
|
|
|
|
})
|
|
|
|
);
|
|
|
|
} else if (log.message === "[SUCCESS]") {
|
|
|
|
User.currentProp("hideReadOnlyAlert", false);
|
|
|
|
this.controllerFor("adminBackups").set("model.isOperationRunning", false);
|
|
|
|
if (log.operation === "restore") {
|
|
|
|
// redirect to homepage when the restore is done (session might be lost)
|
|
|
|
window.location = getURL("/");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
this.controllerFor("adminBackupsLogs")
|
|
|
|
.get("logs")
|
|
|
|
.pushObject(EmberObject.create(log));
|
|
|
|
}
|
2023-03-15 09:17:51 -04:00
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
showStartBackupModal() {
|
2023-08-01 09:40:25 -04:00
|
|
|
this.modal.show(StartBackupModal, {
|
|
|
|
model: { startBackup: this.startBackup },
|
|
|
|
});
|
2023-03-15 09:17:51 -04:00
|
|
|
}
|
2014-08-20 12:48:56 -04:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
startBackup(withUploads) {
|
2023-07-18 15:52:55 -04:00
|
|
|
this.router.transitionTo("admin.backups.logs");
|
2023-03-15 09:17:51 -04:00
|
|
|
Backup.start(withUploads).then((result) => {
|
|
|
|
if (!result.success) {
|
|
|
|
this.dialog.alert(result.message);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
destroyBackup(backup) {
|
|
|
|
return this.dialog.yesNoConfirm({
|
|
|
|
message: I18n.t("admin.backups.operations.destroy.confirm"),
|
|
|
|
didConfirm: () => {
|
|
|
|
backup
|
|
|
|
.destroy()
|
|
|
|
.then(() =>
|
|
|
|
this.controllerFor("adminBackupsIndex")
|
|
|
|
.get("model")
|
|
|
|
.removeObject(backup)
|
|
|
|
);
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
startRestore(backup) {
|
|
|
|
this.dialog.yesNoConfirm({
|
|
|
|
message: I18n.t("admin.backups.operations.restore.confirm"),
|
|
|
|
didConfirm: () => {
|
2023-07-18 15:52:55 -04:00
|
|
|
this.router.transitionTo("admin.backups.logs");
|
2023-03-15 09:17:51 -04:00
|
|
|
backup.restore();
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
cancelOperation() {
|
|
|
|
this.dialog.yesNoConfirm({
|
|
|
|
message: I18n.t("admin.backups.operations.cancel.confirm"),
|
|
|
|
didConfirm: () => {
|
|
|
|
Backup.cancel().then(() => {
|
|
|
|
this.controllerFor("adminBackups").set(
|
|
|
|
"model.isOperationRunning",
|
|
|
|
false
|
|
|
|
);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2014-02-12 23:35:46 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
rollback() {
|
|
|
|
return this.dialog.yesNoConfirm({
|
|
|
|
message: I18n.t("admin.backups.operations.rollback.confirm"),
|
|
|
|
didConfirm: () => {
|
|
|
|
Backup.rollback().then((result) => {
|
|
|
|
if (!result.success) {
|
|
|
|
this.dialog.alert(result.message);
|
|
|
|
} else {
|
|
|
|
// redirect to homepage (session might be lost)
|
|
|
|
window.location = getURL("/");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2014-02-21 19:41:01 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
uploadSuccess(filename) {
|
|
|
|
this.dialog.alert(I18n.t("admin.backups.upload.success", { filename }));
|
|
|
|
}
|
2014-02-21 19:41:01 -05:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
uploadError(filename, message) {
|
|
|
|
this.dialog.alert(
|
|
|
|
I18n.t("admin.backups.upload.error", { filename, message })
|
|
|
|
);
|
|
|
|
}
|
2018-10-14 21:43:31 -04:00
|
|
|
|
2023-03-15 09:17:51 -04:00
|
|
|
@action
|
|
|
|
remoteUploadSuccess() {
|
|
|
|
Backup.find()
|
|
|
|
.then((backups) => backups.map((backup) => Backup.create(backup)))
|
|
|
|
.then((backups) => {
|
|
|
|
this.controllerFor("adminBackupsIndex").set(
|
|
|
|
"model",
|
|
|
|
backups.map((backup) => Backup.create(backup))
|
|
|
|
);
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
this.dialog.alert(
|
|
|
|
I18n.t("admin.backups.backup_storage_error", {
|
|
|
|
error_message: extractError(error),
|
|
|
|
})
|
|
|
|
);
|
|
|
|
return [];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|