2024-10-14 12:14:01 +03:00
|
|
|
|
package _VisualDVM.Passes.All;
|
2024-10-10 23:57:36 +03:00
|
|
|
|
import Common.Passes.Pass;
|
|
|
|
|
|
import Common.Passes.PassException;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import Common.Visual.Controls.PassMenuItem;
|
2024-10-09 20:35:18 +03:00
|
|
|
|
import Common.Visual.Trees.DataTree;
|
2024-10-08 22:33:49 +03:00
|
|
|
|
import Common.Visual.Windows.Dialog.Dialog;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Current;
|
|
|
|
|
|
import _VisualDVM.Global;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.GlobalData.RemoteFile.RemoteFile;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Passes.CurrentComponentPass;
|
|
|
|
|
|
import _VisualDVM.Passes.PassCode;
|
|
|
|
|
|
import _VisualDVM.Passes.Server.ComponentsRepositoryPass;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.Repository.Server.ServerCode;
|
|
|
|
|
|
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Utils;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
|
|
|
|
|
|
import javax.swing.*;
|
|
|
|
|
|
import javax.swing.tree.DefaultMutableTreeNode;
|
|
|
|
|
|
import javax.swing.tree.DefaultTreeCellRenderer;
|
|
|
|
|
|
import java.awt.*;
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
|
import java.nio.file.Files;
|
|
|
|
|
|
import java.nio.file.StandardCopyOption;
|
|
|
|
|
|
import java.util.Vector;
|
|
|
|
|
|
public class ResurrectComponentFromServer extends CurrentComponentPass {
|
2024-10-14 15:19:13 +03:00
|
|
|
|
Vector<RemoteFile> backups; //не забывать что файлы на СЕРВЕРЕ.
|
|
|
|
|
|
RemoteFile remoteFile;
|
|
|
|
|
|
File localFile;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
@Override
|
|
|
|
|
|
public JMenuItem createMenuItem() {
|
|
|
|
|
|
if (menuItem == null)
|
|
|
|
|
|
menuItem = new PassMenuItem(this);
|
|
|
|
|
|
return menuItem;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected boolean canStart(Object... args) throws Exception {
|
|
|
|
|
|
remoteFile = null;
|
|
|
|
|
|
localFile = null;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (super.canStart() && Global.mainModule.getPass(PassCode.GetComponentsBackupsFromServer).Do()) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//1. Получить список бекапов.
|
2024-10-14 15:19:13 +03:00
|
|
|
|
backups = (Vector<RemoteFile>) Global.mainModule.getPass(PassCode.GetComponentsBackupsFromServer).target;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
backups.sort((o1, o2) -> o2.name.compareTo(o1.name));
|
|
|
|
|
|
Dialog d = new Dialog(null) {
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public int getDefaultWidth() {
|
|
|
|
|
|
return 300;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public int getDefaultHeight() {
|
|
|
|
|
|
return 400;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public void CreateContent() {
|
|
|
|
|
|
DefaultMutableTreeNode root = new DefaultMutableTreeNode("(скрыть)");
|
|
|
|
|
|
for (RemoteFile file : backups) {
|
|
|
|
|
|
root.add(new DefaultMutableTreeNode(file));
|
|
|
|
|
|
}
|
|
|
|
|
|
DataTree tree = new DataTree(root) {
|
|
|
|
|
|
{
|
|
|
|
|
|
setRootVisible(false);
|
|
|
|
|
|
setCellRenderer(new DefaultTreeCellRenderer() {
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public Component getTreeCellRendererComponent(JTree tree, Object value, boolean sel, boolean expanded, boolean leaf, int row, boolean hasFocus) {
|
|
|
|
|
|
super.getTreeCellRendererComponent(tree, value, sel, expanded, leaf, row, hasFocus);
|
|
|
|
|
|
Object o = ((DefaultMutableTreeNode) value).getUserObject();
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (o instanceof RemoteFile) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
RemoteFile file = (RemoteFile) o;
|
|
|
|
|
|
setText(file.name);
|
|
|
|
|
|
}
|
|
|
|
|
|
return this;
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
2024-10-17 20:31:06 +03:00
|
|
|
|
public Current currentName() {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
return Current.ComponentServerBackup;
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
content = tree;
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (d.ShowDialog("Выбор версии для восстановления") && Global.mainModule.Check(Log, Current.ComponentServerBackup)) {
|
2024-10-13 22:08:13 +03:00
|
|
|
|
remoteFile = Global.mainModule.getComponentServerBackup();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
return true;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
}
|
|
|
|
|
|
;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void body() throws Exception {
|
2024-10-14 15:19:13 +03:00
|
|
|
|
//1. Скачать файл.
|
2024-10-09 23:37:58 +03:00
|
|
|
|
Pass receivePass = new ComponentsRepositoryPass() {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
@Override
|
|
|
|
|
|
public String getDescription() {
|
|
|
|
|
|
return "Скачивание файла с сервера";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void ServerAction() throws Exception {
|
|
|
|
|
|
Command(new ServerExchangeUnit_2021(ServerCode.ReceiveFile, remoteFile.full_name));
|
|
|
|
|
|
localFile = Utils.getTempFileName(remoteFile.name);
|
|
|
|
|
|
response.Unpack(localFile);
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
if (!receivePass.Do())
|
2024-10-14 15:19:13 +03:00
|
|
|
|
throw new PassException("Не удалось скачать файл!");
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//------------>>
|
|
|
|
|
|
Files.copy(localFile.toPath(), target.getNewFile().toPath(), StandardCopyOption.REPLACE_EXISTING);
|
|
|
|
|
|
target.Update();
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void performDone() throws Exception {
|
|
|
|
|
|
target.InitialVersionCheck();
|
|
|
|
|
|
if (target.CanBeUpdated())
|
|
|
|
|
|
target.CheckIfNeedsUpdateOrPublish();
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showDone() throws Exception {
|
2024-10-22 20:16:57 +03:00
|
|
|
|
Global.components.RefreshUpdatesStatus();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|