MyDaemonInstallationNodeContribution.java 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. package uraxis;
  2. import com.ur.urcap.api.contribution.DaemonContribution;
  3. import com.ur.urcap.api.contribution.InstallationNodeContribution;
  4. import com.ur.urcap.api.domain.data.DataModel;
  5. import com.ur.urcap.api.domain.script.ScriptWriter;
  6. import com.ur.urcap.api.ui.annotation.Div;
  7. import com.ur.urcap.api.ui.annotation.Input;
  8. import com.ur.urcap.api.ui.annotation.Label;
  9. import com.ur.urcap.api.ui.component.*;
  10. import org.apache.xmlrpc.XmlRpcException;
  11. import java.awt.EventQueue;
  12. import java.util.Timer;
  13. import java.util.TimerTask;
  14. public class MyDaemonInstallationNodeContribution implements InstallationNodeContribution {
  15. private static final String POPUPTITLE_KEY = "popuptitle";
  16. private static final String XMLRPC_VARIABLE = "my_daemon";
  17. private static final String ENABLED_KEY = "enabled";
  18. private static final String DEFAULT_VALUE = "HelloWorld";
  19. private static final String IP = "ip";
  20. private static final String PORT = "port";
  21. private DataModel model;
  22. // private final MyDaemonDaemonService daemonService;
  23. private MyDaemonInterface daemonInterface;
  24. private Timer uiTimer;
  25. private Timer statusTimer;
  26. public MyDaemonInstallationNodeContribution(MyDaemonDaemonService daemonService, DataModel model) {
  27. // this.daemonService = daemonService;
  28. this.model = model;
  29. daemonInterface = new MyDaemonInterface(getIP(), Integer.parseInt(getPort()));
  30. // applyDesiredDaemonStatus();
  31. Activator.daemonInterface=daemonInterface;
  32. }
  33. @Input(id = POPUPTITLE_KEY)
  34. private InputTextField popupTitleField;
  35. @Input(id = "btnEnableDaemon")
  36. private InputButton enableDaemonButton;
  37. @Input(id = "btnRef")
  38. private InputButton refButtonRef;
  39. @Input(id = "textIP")
  40. private InputTextField refTextIP;
  41. @Input(id = "textPort")
  42. private InputTextField refTextPort;
  43. @Label(id = "lblStatus")
  44. private LabelComponent refLblStatus;
  45. @Input(id = "numberPos")
  46. private InputTextField refNumberPos;
  47. @Input(id = "btnPos")
  48. private InputButton refButtonPos;
  49. @Input(id = "btnDisableDaemon")
  50. private InputButton disableDaemonButton;
  51. @Label(id = "lblDaemonStatus")
  52. private LabelComponent daemonStatusLabel;
  53. @Input(id = POPUPTITLE_KEY)
  54. public void onMessageChange(InputEvent event) {
  55. if (event.getEventType() == InputEvent.EventType.ON_CHANGE) {
  56. setPopupTitle(popupTitleField.getText());
  57. }
  58. }
  59. @Input(id = "btnRef")
  60. public void onBtnRef(InputEvent event) {
  61. if (event.getEventType() == InputEvent.EventType.ON_CHANGE) {
  62. try {
  63. getDaemonInterface().client.execute("ref", new String[]{"foo", "bar"});
  64. } catch (XmlRpcException e) {
  65. e.printStackTrace();
  66. }
  67. }
  68. }
  69. @Input(id = "btnPos")
  70. public void onBtnPos(InputEvent event) {
  71. if (event.getEventType() == InputEvent.EventType.ON_CHANGE) {
  72. try {
  73. String pos=refNumberPos.getText();
  74. getDaemonInterface().client.execute("pos", new String[]{pos});
  75. } catch (XmlRpcException e) {
  76. e.printStackTrace();
  77. }
  78. }
  79. }
  80. @Input(id = "btnEnableDaemon")
  81. public void onStartClick(InputEvent event) {
  82. if (event.getEventType() == InputEvent.EventType.ON_CHANGE) {
  83. setDaemonEnabled(true);
  84. // applyDesiredDaemonStatus();
  85. }
  86. }
  87. @Input(id = "btnDisableDaemon")
  88. public void onStopClick(InputEvent event) {
  89. if (event.getEventType() == InputEvent.EventType.ON_CHANGE) {
  90. setDaemonEnabled(false);
  91. // applyDesiredDaemonStatus();
  92. }
  93. }
  94. @Override
  95. public void openView() {
  96. enableDaemonButton.setText("Start Daemon");
  97. disableDaemonButton.setText("Stop daemon");
  98. popupTitleField.setText(getPopupTitle());
  99. refTextIP.setText(getIP());
  100. refTextPort.setText(getPort());
  101. //UI updates from non-GUI threads must use EventQueue.invokeLater (or SwingUtilities.invokeLater)
  102. uiTimer = new Timer(true);
  103. uiTimer.schedule(new TimerTask() {
  104. @Override
  105. public void run() {
  106. EventQueue.invokeLater(new Runnable() {
  107. @Override
  108. public void run() {
  109. updateUI();
  110. }
  111. });
  112. }
  113. }, 0, 1000);
  114. // statusTimer = new Timer(true);
  115. // statusTimer.schedule(new TimerTask() {
  116. // @Override
  117. // public void run() {
  118. // EventQueue.invokeLater(new Runnable() {
  119. // @Override
  120. // public void run() {
  121. // try {
  122. // Object res = getDaemonInterface().client.execute("status", new String[]{});
  123. // refLblStatus.setText("<html>"+res.toString()+"</html>");
  124. // System.out.println(res);
  125. // } catch (XmlRpcException e) {
  126. // e.printStackTrace();
  127. // }
  128. // }
  129. // });
  130. // }},0,1000);
  131. }
  132. private void updateUI() {
  133. DaemonContribution.State state = getDaemonState();
  134. if (state == DaemonContribution.State.RUNNING) {
  135. enableDaemonButton.setEnabled(false);
  136. disableDaemonButton.setEnabled(true);
  137. } else {
  138. enableDaemonButton.setEnabled(true);
  139. disableDaemonButton.setEnabled(false);
  140. }
  141. String text = "";
  142. switch (state) {
  143. case RUNNING:
  144. text = "My Daemon runs";
  145. break;
  146. case STOPPED:
  147. text = "My Daemon stopped";
  148. break;
  149. case ERROR:
  150. text = "My Daemon failed";
  151. break;
  152. }
  153. daemonStatusLabel.setText(text);
  154. }
  155. @Override
  156. public void closeView() {
  157. if (uiTimer != null) {
  158. uiTimer.cancel();
  159. }
  160. setIP(refTextIP.getText());
  161. setPort(refTextPort.getText());
  162. }
  163. @Override
  164. public void generateScript(ScriptWriter writer) {
  165. writer.assign(XMLRPC_VARIABLE, "rpc_factory(\"xmlrpc\", \"http://"+ getIP()+":"+ getPort()+"\")");
  166. }
  167. public String getPopupTitle() {
  168. if (!model.isSet(POPUPTITLE_KEY)) {
  169. resetToDefaultValue();
  170. }
  171. return model.get(POPUPTITLE_KEY, DEFAULT_VALUE);
  172. }
  173. private void setPopupTitle(String title) {
  174. if ("".equals(title)) {
  175. resetToDefaultValue();
  176. } else {
  177. model.set(POPUPTITLE_KEY, title);
  178. // Apply the new setting to the daemon for real-time preview purposes
  179. // Note this might influence a running program, since the actual state is stored in the daemon.
  180. setDaemonTitle(title);
  181. }
  182. }
  183. public String getIP() {
  184. return model.get(IP, "127.0.0.1");
  185. }
  186. public void setIP(String ip) {
  187. model.set(IP, ip);
  188. }
  189. public String getPort() {
  190. return model.get(PORT, "8080");
  191. }
  192. public void setPort(String ip) {
  193. model.set(PORT, ip);
  194. }
  195. private void resetToDefaultValue() {
  196. popupTitleField.setText(DEFAULT_VALUE);
  197. model.set(POPUPTITLE_KEY, DEFAULT_VALUE);
  198. setDaemonTitle(DEFAULT_VALUE);
  199. }
  200. private void setDaemonTitle(String title) {
  201. try {
  202. daemonInterface.setTitle(title);
  203. } catch(Exception e){
  204. System.err.println("Could not set the title in the daemon process.");
  205. }
  206. }
  207. // private void applyDesiredDaemonStatus() {
  208. // new Thread(new Runnable() {
  209. // @Override
  210. // public void run() {
  211. // if (isDaemonEnabled()) {
  212. // // Download the daemon settings to the daemon process on initial start for real-time preview purposes
  213. // try {
  214. // awaitDaemonRunning(5000);
  215. // daemonInterface.setTitle(getPopupTitle());
  216. // } catch (Exception e) {
  217. // System.err.println("Could not set the title in the daemon process.");
  218. // }
  219. // } else {
  220. // daemonService.getDaemon().stop();
  221. // }
  222. // }
  223. // }).start();
  224. // }
  225. // private void awaitDaemonRunning(long timeOutMilliSeconds) throws InterruptedException {
  226. // daemonService.getDaemon().start();
  227. // long endTime = System.nanoTime() + timeOutMilliSeconds * 1000L * 1000L;
  228. // while(System.nanoTime() < endTime && (daemonService.getDaemon().getState() != DaemonContribution.State.RUNNING || !daemonInterface.isReachable())) {
  229. // Thread.sleep(100);
  230. // }
  231. // }
  232. //
  233. private DaemonContribution.State getDaemonState(){
  234. return DaemonContribution.State.RUNNING;
  235. // return daemonService.getDaemon().getState();
  236. }
  237. private Boolean isDaemonEnabled() {
  238. return model.get(ENABLED_KEY, true); //This daemon is enabled by default
  239. }
  240. private void setDaemonEnabled(Boolean enable) {
  241. model.set(ENABLED_KEY, enable);
  242. }
  243. public String getXMLRPCVariable(){
  244. return XMLRPC_VARIABLE;
  245. }
  246. public MyDaemonInterface getDaemonInterface() {return daemonInterface; }
  247. public boolean isDefined() {
  248. return true;
  249. }
  250. }