2024-10-14 12:14:01 +03:00
|
|
|
|
package _VisualDVM.Passes.All;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import Common.Passes.Pass;
|
|
|
|
|
|
import Common.Passes.PassException;
|
2024-10-09 22:01:19 +03:00
|
|
|
|
import _VisualDVM.Current;
|
2024-10-12 00:17:51 +03:00
|
|
|
|
import _VisualDVM.Global;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.GlobalData.RemoteFile.RemoteFile;
|
|
|
|
|
|
import _VisualDVM.GlobalData.User.UserState;
|
2024-10-14 12:14:01 +03:00
|
|
|
|
import _VisualDVM.Passes.PassCode;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Repository.SubscriberWorkspace.SubscriberWorkspace;
|
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-13 22:08:13 +03:00
|
|
|
|
return Global.mainModule.Check(Log, Current.Machine, Current.User);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void body() throws Exception {
|
2024-10-13 22:08:13 +03:00
|
|
|
|
switch (Global.mainModule.getMachine().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;
|
|
|
|
|
|
workspace.URL = Global.mainModule.getMachine().getURL();
|
|
|
|
|
|
workspace.login = Global.mainModule.getUser().login;
|
|
|
|
|
|
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-13 22:08:13 +03:00
|
|
|
|
Global.mainModule.getUser().workspace = workspace.path;
|
|
|
|
|
|
Global.mainModule.getUser().state = UserState.ready_to_work;
|
|
|
|
|
|
Global.mainModule.getDb().Update(Global.mainModule.getUser());
|
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-13 22:08:13 +03:00
|
|
|
|
Global.mainModule.getUser().workspace = workspace.path;
|
|
|
|
|
|
Global.mainModule.getUser().state = UserState.ready_to_work;
|
|
|
|
|
|
Global.mainModule.getDb().Update(Global.mainModule.getUser());
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
default:
|
|
|
|
|
|
throw new PassException("Неопределенный тип пользователя");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showFinish() throws Exception {
|
2024-10-22 17:27:41 +03:00
|
|
|
|
Global.mainModule.getDb().users.getUI().Refresh();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|