2024-10-14 12:14:01 +03:00
|
|
|
|
package _VisualDVM.Passes.All;
|
2024-10-24 23:40:24 +03:00
|
|
|
|
import Common.MainModule_;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import Common.Passes.Pass;
|
|
|
|
|
|
import Common.Passes.PassException;
|
2025-02-18 16:21:20 +03:00
|
|
|
|
import _VisualDVM.ComponentsServer.SubscriberWorkspace.SubscriberWorkspace;
|
2024-10-12 00:17:51 +03:00
|
|
|
|
import _VisualDVM.Global;
|
2024-10-24 23:40:24 +03:00
|
|
|
|
import _VisualDVM.GlobalData.Machine.Machine;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.GlobalData.RemoteFile.RemoteFile;
|
2024-10-24 23:40:24 +03:00
|
|
|
|
import _VisualDVM.GlobalData.User.User;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.GlobalData.User.UserState;
|
2024-10-14 12:14:01 +03:00
|
|
|
|
import _VisualDVM.Passes.PassCode;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
public class InitialiseUser extends Pass {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
@Override
|
|
|
|
|
|
public String getIconPath() {
|
|
|
|
|
|
return "/icons/InitializeUser.png";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getButtonText() {
|
|
|
|
|
|
return "";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected boolean canStart(Object... args) throws Exception {
|
2024-10-25 00:50:19 +03:00
|
|
|
|
return MainModule_.instance.getDb().CheckCurrent(Log, Machine.class, User.class);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void body() throws Exception {
|
2024-10-24 23:40:24 +03:00
|
|
|
|
Machine machine = MainModule_.instance.getDb().getTable(Machine.class).getUI().getCurrent();
|
|
|
|
|
|
User user = MainModule_.instance.getDb().getTable(User.class).getUI().getCurrent();
|
|
|
|
|
|
switch (machine.type) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
case Local:
|
2024-10-13 23:55:03 +03:00
|
|
|
|
Global.mainModule.getPass(PassCode.LocalInitaliseUser).Do();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
break;
|
|
|
|
|
|
case Server:
|
|
|
|
|
|
case MVS_cluster:
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (Global.mainModule.getPass(PassCode.CheckRemoteWorkspace).Do()) {
|
|
|
|
|
|
SubscriberWorkspace workspace = (SubscriberWorkspace) Global.mainModule.getPass(PassCode.CheckRemoteWorkspace).target;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
if (workspace == null) {
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (Global.mainModule.getPass(PassCode.RemoteInitialiseUser).Do()) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
workspace = new SubscriberWorkspace();
|
2024-10-14 15:19:13 +03:00
|
|
|
|
workspace.email = Global.mainModule.getAccount().email;
|
2024-10-24 23:40:24 +03:00
|
|
|
|
workspace.URL = machine.getURL();
|
|
|
|
|
|
workspace.login = user.login;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
workspace.path = ((RemoteFile) Global.mainModule.getPass(PassCode.RemoteInitialiseUser).target).full_name;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//---
|
2024-10-14 15:19:13 +03:00
|
|
|
|
if (Global.mainModule.getPass(PassCode.PublishRemoteWorkspace).Do(workspace)) {
|
2024-10-24 23:40:24 +03:00
|
|
|
|
user.workspace = workspace.path;
|
|
|
|
|
|
user.state = UserState.ready_to_work;
|
|
|
|
|
|
Global.mainModule.getDb().Update(user);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2024-10-14 15:19:13 +03:00
|
|
|
|
} else {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//рега была. просто заносим то что там пользователю
|
2024-10-24 23:40:24 +03:00
|
|
|
|
user.workspace = workspace.path;
|
|
|
|
|
|
user.state = UserState.ready_to_work;
|
|
|
|
|
|
Global.mainModule.getDb().Update(user);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
default:
|
|
|
|
|
|
throw new PassException("Неопределенный тип пользователя");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showFinish() throws Exception {
|
2024-10-24 23:40:24 +03:00
|
|
|
|
Global.mainModule.getDb().users.getUI().RedrawControl();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|