2023-11-19 02:12:44 +03:00
|
|
|
|
package Visual_DVM_2021.Passes.All;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
import Common.Current_;
|
2024-10-11 00:00:30 +03:00
|
|
|
|
import Common.Utils.Utils_;
|
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.GlobalDatabase;
|
|
|
|
|
|
import _VisualDVM.GlobalData.RemoteFile.RemoteFile;
|
|
|
|
|
|
import _VisualDVM.GlobalData.User.UserState;
|
|
|
|
|
|
import _VisualDVM.Repository.SubscriberWorkspace.SubscriberWorkspace;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
import Visual_DVM_2021.Passes.PassCode;
|
2024-10-10 23:57:36 +03:00
|
|
|
|
import Common.Passes.PassException;
|
|
|
|
|
|
import Common.Passes.Pass;
|
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-09 23:37:58 +03:00
|
|
|
|
passes.get(PassCode.LocalInitaliseUser).Do();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
break;
|
|
|
|
|
|
case Server:
|
|
|
|
|
|
case MVS_cluster:
|
2024-10-09 23:37:58 +03:00
|
|
|
|
if (passes.get(PassCode.CheckRemoteWorkspace).Do()) {
|
|
|
|
|
|
SubscriberWorkspace workspace = (SubscriberWorkspace) passes.get(PassCode.CheckRemoteWorkspace).target;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
if (workspace == null) {
|
2024-10-09 23:37:58 +03:00
|
|
|
|
if (passes.get(PassCode.RemoteInitialiseUser).Do()){
|
2023-09-17 22:13:42 +03:00
|
|
|
|
workspace = new SubscriberWorkspace();
|
2024-10-13 22:08:13 +03:00
|
|
|
|
workspace.email=Global.mainModule.getAccount().email;
|
|
|
|
|
|
workspace.URL=Global.mainModule.getMachine().getURL();
|
|
|
|
|
|
workspace.login=Global.mainModule.getUser().login;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
workspace.path=((RemoteFile) passes.get(PassCode.RemoteInitialiseUser).target).full_name;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//---
|
2024-10-09 23:37:58 +03:00
|
|
|
|
if (passes.get(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
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
else {
|
|
|
|
|
|
//рега была. просто заносим то что там пользователю
|
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-12 00:17:51 +03:00
|
|
|
|
Global.mainModule.getDb().users.RefreshUI();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|