no message
This commit is contained in:
35
src/_VisualDVM/Passes/Server/CloneServerObject.java
Normal file
35
src/_VisualDVM/Passes/Server/CloneServerObject.java
Normal file
@@ -0,0 +1,35 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import _VisualDVM.Current;
|
||||
import Common.Database.Objects.riDBObject;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
public abstract class CloneServerObject<S extends RepositoryServer, D extends riDBObject> extends PublishServerObject<S, D> {
|
||||
public D src;
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/MultiFiles.png";
|
||||
}
|
||||
public CloneServerObject(S server_in, Class<D> d_in) {
|
||||
super(server_in, d_in);
|
||||
}
|
||||
protected abstract Current currentName();
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
src=null;
|
||||
if (!Global.mainModule.Check(Log, currentName()))
|
||||
return false;
|
||||
|
||||
//---------
|
||||
pk = null;
|
||||
if (Global.mainModule.getAccount().CheckRegistered(Log)) {
|
||||
target = d.newInstance();
|
||||
target.SynchronizeFields(src=(D) Global.mainModule.get(currentName()));
|
||||
//единственное отличие клона - текущий автор
|
||||
target.description+=" копия";
|
||||
target.sender_name = Global.mainModule.getAccount().name;
|
||||
target.sender_address = Global.mainModule.getAccount().email;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Repository.Server.ComponentsServer;
|
||||
public abstract class ComponentsRepositoryPass<T> extends RepositoryPass<ComponentsServer, T> {
|
||||
public ComponentsRepositoryPass() {
|
||||
super(Global.componentsServer);
|
||||
}
|
||||
}
|
||||
42
src/_VisualDVM/Passes/Server/DeleteServerObject.java
Normal file
42
src/_VisualDVM/Passes/Server/DeleteServerObject.java
Normal file
@@ -0,0 +1,42 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import _VisualDVM.ServerObjectsCache.VisualCaches;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
public class DeleteServerObject<S extends RepositoryServer, D extends DBObject> extends ServerObjectPass<S, D> {
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/Delete.png";
|
||||
}
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
target = (D) getDb().tables.get(d).getCurrent();
|
||||
return getDb().tables.get(d).CheckCurrent(Log) && getDb().tables.get(d).ShowDeleteObjectDialog(target);
|
||||
}
|
||||
//Очищаем все связанные таблицы, чтобы не допустить перерисовки во время удаления объекта.
|
||||
@Override
|
||||
protected void showPreparation() throws Exception {
|
||||
getDb().tables.get(d).ClearUI();
|
||||
for (Class dep : getDb().tables.get(d).getFKDependencies().keySet()) {
|
||||
switch (getDb().tables.get(d).getFKDependencies().get(dep).data) {
|
||||
case NONE:
|
||||
case DROP:
|
||||
break;
|
||||
case DELETE:
|
||||
getDb().tables.get(dep).ClearUI();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
public DeleteServerObject(S server_in, Class<D> d_in) {
|
||||
super(server_in, d_in);
|
||||
}
|
||||
@Override
|
||||
protected void ServerAction() throws Exception {
|
||||
DeleteObject(target);
|
||||
VisualCaches.DeleteCache(target);
|
||||
}
|
||||
@Override
|
||||
protected void showDone() throws Exception {
|
||||
getDb().tables.get(d).ui_.Show();
|
||||
}
|
||||
}
|
||||
78
src/_VisualDVM/Passes/Server/DeleteServerObjects.java
Normal file
78
src/_VisualDVM/Passes/Server/DeleteServerObjects.java
Normal file
@@ -0,0 +1,78 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import Common.Database.Tables.DBTable;
|
||||
import Common.Database.Database;
|
||||
import Common.Visual.UI_;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.ServerObjectsCache.VisualCaches;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
import _VisualDVM.Repository.Server.ServerCode;
|
||||
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
|
||||
import javafx.util.Pair;
|
||||
|
||||
import java.util.Vector;
|
||||
public class DeleteServerObjects <S extends RepositoryServer, D extends DBObject> extends RepositoryPass<S, Vector<Object>> {
|
||||
protected Class<D> d; //класс объектов.
|
||||
//---
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/Delete.png";
|
||||
}
|
||||
@Override
|
||||
public String getButtonText() {
|
||||
return "";
|
||||
}
|
||||
//---
|
||||
protected Database getDb() {
|
||||
return server.db;
|
||||
}
|
||||
protected String getEmail(){return null;}
|
||||
//---
|
||||
public DeleteServerObjects(S server_in, Class<D> d_in) {
|
||||
super(server_in);
|
||||
d = d_in;
|
||||
}
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
DBTable table =getDb().tables.get(d);
|
||||
if (table.getCheckedCount()>0) {
|
||||
target = table.getCheckedKeys();
|
||||
return UI_.Warning(table.getCheckedCount()+" объектов будет удален(о).");
|
||||
}
|
||||
else {
|
||||
if (Global.mainModule.Check(Log, table.CurrentName())){
|
||||
target = new Vector<>();
|
||||
target.add(table.getCurrent().getPK());
|
||||
return getDb().tables.get(d).CheckCurrent(Log) && getDb().tables.get(d).ShowDeleteObjectDialog(table.getCurrent());
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
//Очищаем все связанные таблицы, чтобы не допустить перерисовки во время удаления объекта.
|
||||
@Override
|
||||
protected void showPreparation() throws Exception {
|
||||
getDb().tables.get(d).ClearUI();
|
||||
for (Class dep : getDb().tables.get(d).getFKDependencies().keySet()) {
|
||||
switch (getDb().tables.get(d).getFKDependencies().get(dep).data) {
|
||||
case NONE:
|
||||
case DROP:
|
||||
break;
|
||||
case DELETE:
|
||||
getDb().tables.get(dep).ClearUI();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
@Override
|
||||
protected void ServerAction() throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.DeleteObjectsByPK, getEmail(),new Pair<>(d, target)));
|
||||
}
|
||||
@Override
|
||||
protected void performFinish() throws Exception {
|
||||
super.performFinish();
|
||||
Global.mainModule.getPass(getDb().getSynchronizePassCode()).Do();
|
||||
for (Object key: target){
|
||||
VisualCaches.DeleteCache(d, key);
|
||||
}
|
||||
}
|
||||
}
|
||||
31
src/_VisualDVM/Passes/Server/EditServerObject.java
Normal file
31
src/_VisualDVM/Passes/Server/EditServerObject.java
Normal file
@@ -0,0 +1,31 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import _VisualDVM.ServerObjectsCache.VisualCaches;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
public class EditServerObject<S extends RepositoryServer, D extends DBObject> extends ServerObjectPass<S, D> {
|
||||
//--
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/Edit.png";
|
||||
}
|
||||
//--
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
target = (D) getDb().tables.get(d).getCurrent();
|
||||
return getDb().tables.get(d).CheckCurrent(Log) && getDb().tables.get(d).ShowEditObjectDialog(target);
|
||||
}
|
||||
//--
|
||||
public EditServerObject(S server_in, Class<D> d_in) {
|
||||
super(server_in, d_in);
|
||||
}
|
||||
//--
|
||||
@Override
|
||||
protected void ServerAction() throws Exception {
|
||||
EditObject(target);
|
||||
}
|
||||
@Override
|
||||
protected void showDone() throws Exception {
|
||||
VisualCaches.RefreshCache(target);
|
||||
getDb().tables.get(d).ui_.Show(target.getPK());
|
||||
}
|
||||
}
|
||||
44
src/_VisualDVM/Passes/Server/PublishServerObject.java
Normal file
44
src/_VisualDVM/Passes/Server/PublishServerObject.java
Normal file
@@ -0,0 +1,44 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import Common.Database.Objects.riDBObject;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
import _VisualDVM.Repository.Server.ServerCode;
|
||||
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
|
||||
public class PublishServerObject<S extends RepositoryServer, D extends DBObject> extends ServerObjectPass<S, D> {
|
||||
public Object pk = null;
|
||||
public PublishServerObject(S server_in, Class<D> d_in) {
|
||||
super(server_in, d_in);
|
||||
}
|
||||
@Override
|
||||
public String getIconPath() {
|
||||
return "/icons/RedAdd.png";
|
||||
}
|
||||
//--
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
pk = null;
|
||||
if (Global.mainModule.getAccount().CheckRegistered(Log)) {
|
||||
target = d.newInstance();
|
||||
if (target instanceof riDBObject) {
|
||||
riDBObject rTarget = (riDBObject) target;
|
||||
rTarget.sender_name = Global.mainModule.getAccount().name;
|
||||
rTarget.sender_address = Global.mainModule.getAccount().email;
|
||||
}
|
||||
return fillObjectFields();
|
||||
}
|
||||
return false;
|
||||
}
|
||||
protected String getEmail(){return null;}
|
||||
//--
|
||||
@Override
|
||||
protected void ServerAction() throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.PublishObject, getEmail(), target));
|
||||
pk = response.object;
|
||||
}
|
||||
@Override
|
||||
protected void showDone() throws Exception {
|
||||
super.showDone();
|
||||
getDb().tables.get(d).ui_.Show(pk);
|
||||
}
|
||||
}
|
||||
127
src/_VisualDVM/Passes/Server/RepositoryPass.java
Normal file
127
src/_VisualDVM/Passes/Server/RepositoryPass.java
Normal file
@@ -0,0 +1,127 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import Common.Utils.Utils_;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Utils;
|
||||
import _VisualDVM.Repository.RepositoryRefuseException;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
import _VisualDVM.Repository.Server.ServerCode;
|
||||
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
|
||||
import Common.Passes.PassException;
|
||||
import Common.Passes.Pass;
|
||||
import javafx.util.Pair;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.ObjectInputStream;
|
||||
import java.io.ObjectOutputStream;
|
||||
import java.net.*;
|
||||
public abstract class RepositoryPass<S extends RepositoryServer, T> extends Pass<T> {
|
||||
protected S server;
|
||||
public RepositoryPass(S server_in) {
|
||||
server = server_in;
|
||||
}
|
||||
protected ObjectInputStream in = null; // поток чтения из сокета
|
||||
protected ObjectOutputStream out = null; // поток записи в сокет
|
||||
//-
|
||||
protected ServerExchangeUnit_2021 request;
|
||||
protected ServerExchangeUnit_2021 response;
|
||||
//-
|
||||
protected Socket clientSocket = null; //сокет для общения
|
||||
protected ServerCode ExitCode = ServerCode.Undefined;
|
||||
@Override
|
||||
protected boolean needsAnimation() {
|
||||
return true;
|
||||
}
|
||||
protected int getTimeout() {
|
||||
return Global.properties.SocketTimeout;
|
||||
}
|
||||
//-
|
||||
protected void connect() throws Exception {
|
||||
clientSocket = Utils.createClientSocket(InetAddress.getByName(Global.properties.ServerAddress),
|
||||
server.getPort(),
|
||||
getTimeout()
|
||||
);
|
||||
out = new ObjectOutputStream(clientSocket.getOutputStream());
|
||||
in = new ObjectInputStream(clientSocket.getInputStream());
|
||||
}
|
||||
protected void disconnect() throws Exception {
|
||||
if (clientSocket != null)
|
||||
clientSocket.close();
|
||||
if (in != null)
|
||||
in.close();
|
||||
if (out != null)
|
||||
out.close();
|
||||
//-
|
||||
clientSocket = null;
|
||||
in = null;
|
||||
out = null;
|
||||
}
|
||||
protected abstract void ServerAction() throws Exception;
|
||||
protected void Command(ServerExchangeUnit_2021 request_in) throws Exception {
|
||||
ExitCode = ServerCode.Undefined;
|
||||
request = request_in;
|
||||
out.writeObject(request);
|
||||
response = (ServerExchangeUnit_2021) in.readObject();
|
||||
switch (ExitCode = response.getCode()) {
|
||||
case FAIL:
|
||||
throw (Exception) response.object;
|
||||
case OLD:
|
||||
throw new PassException("Сервер устарел.");
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
protected void SendFile(File src, String dst) throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.SendFile, dst, Utils_.fileToBytes(src)));
|
||||
}
|
||||
protected void ReceiveFile(String src, File dst) throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.ReceiveFile, src));
|
||||
if (response.object != null)
|
||||
response.Unpack(dst);
|
||||
}
|
||||
protected String ReadFile(String src) throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.ReadFile, src));
|
||||
return response.object.toString();
|
||||
}
|
||||
@Override
|
||||
protected void body() throws Exception {
|
||||
connect();
|
||||
ServerAction();
|
||||
}
|
||||
@Override
|
||||
protected void performFinish() throws Exception {
|
||||
disconnect();
|
||||
}
|
||||
@Override
|
||||
protected void CheckException(Exception ex) {
|
||||
if (ExitCode.equals(ServerCode.OLD)) {
|
||||
Log.Writeln_("Текущий сервер устарел. Доступны только обновления компонент!");
|
||||
return;
|
||||
}
|
||||
if (ex instanceof RepositoryRefuseException) {
|
||||
Log.Writeln_(ex.getMessage());
|
||||
return;
|
||||
}
|
||||
Throwable cause = getCauseRec(ex);
|
||||
if ((cause instanceof UnknownHostException)) {
|
||||
Log.Writeln_("Репозиторий не найден.\n" +
|
||||
"Проверьте наличие подключения к сети.");
|
||||
} else if ((cause instanceof SocketTimeoutException)) {
|
||||
Log.Writeln_("Время ожидания подключения к репозиторию истекло.\n" +
|
||||
"Проверьте наличие подключения к сети.");
|
||||
} else if ((cause instanceof ConnectException)) {
|
||||
if (cause.getMessage().contains("Connection refused: connect"))
|
||||
Log.Writeln_("Серверный компонент не активен. Обратитесь к администрации.");
|
||||
else Log.Writeln_("Ошибка соединения");
|
||||
} else
|
||||
super.CheckException(ex);
|
||||
}
|
||||
public void EditObject(DBObject object) throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.EditObject, "", object));
|
||||
}
|
||||
//-
|
||||
public void DeleteObject(DBObject object) throws Exception {
|
||||
Command(new ServerExchangeUnit_2021(ServerCode.DeleteObjectByPK, "",
|
||||
new Pair<>(object.getClass(), object.getPK())));
|
||||
}
|
||||
}
|
||||
31
src/_VisualDVM/Passes/Server/ServerObjectPass.java
Normal file
31
src/_VisualDVM/Passes/Server/ServerObjectPass.java
Normal file
@@ -0,0 +1,31 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import Common.Database.Database;
|
||||
import Common.Database.Objects.DBObject;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.Repository.RepositoryServer;
|
||||
public abstract class ServerObjectPass <S extends RepositoryServer, D extends DBObject> extends RepositoryPass<S,D>{
|
||||
protected Class<D> d; //класс объектов.
|
||||
//---
|
||||
public ServerObjectPass(S server_in, Class<D> d_in) {
|
||||
super(server_in);
|
||||
d = d_in;
|
||||
}
|
||||
//--
|
||||
@Override
|
||||
public String getButtonText() {
|
||||
return "";
|
||||
}
|
||||
//--
|
||||
protected Database getDb() {
|
||||
return server.db;
|
||||
}
|
||||
@Override
|
||||
protected void performFinish() throws Exception {
|
||||
super.performFinish();
|
||||
Global.mainModule.getPass(getDb().getSynchronizePassCode()).Do();
|
||||
}
|
||||
//-
|
||||
public boolean fillObjectFields() throws Exception {
|
||||
return getDb().tables.get(d).ShowAddObjectDialog(target);
|
||||
}
|
||||
}
|
||||
13
src/_VisualDVM/Passes/Server/TestingSystemPass.java
Normal file
13
src/_VisualDVM/Passes/Server/TestingSystemPass.java
Normal file
@@ -0,0 +1,13 @@
|
||||
package _VisualDVM.Passes.Server;
|
||||
import _VisualDVM.Global;
|
||||
import _VisualDVM.TestingSystem.Common.TestingServer;
|
||||
public abstract class TestingSystemPass<T> extends RepositoryPass<TestingServer, T> {
|
||||
public TestingSystemPass() {
|
||||
super(Global.testingServer);
|
||||
}
|
||||
@Override
|
||||
protected int getTimeout() {
|
||||
return 120000;
|
||||
}
|
||||
//----
|
||||
}
|
||||
Reference in New Issue
Block a user