CMoveTask.java 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package com.zskk.task;
  2. import java.text.SimpleDateFormat;
  3. import java.util.Date;
  4. import com.alibaba.fastjson.JSON;
  5. import com.alibaba.fastjson.JSONArray;
  6. import com.alibaba.fastjson.JSONObject;
  7. import com.jfinal.plugin.activerecord.Db;
  8. import com.jfinal.plugin.activerecord.Record;
  9. import com.jfinal.plugin.cron4j.ITask;
  10. import com.zskk.service.DataService;
  11. import com.zskk.service.ServiceFactory;
  12. import com.zskk.tools.ExecUtil;
  13. public class CMoveTask implements ITask {
  14. @Override
  15. public void run() {
  16. // TODO Auto-generated method stub
  17. //0wait1match2break
  18. int flag = 0;
  19. DataService dService = ServiceFactory.getService(DataService.class);
  20. JSONArray jsonArray = dService.getExamList(50);
  21. Record studyidfind = null;
  22. while (flag != 2) {
  23. studyidfind = Db.use("local").findFirst("select * from study where status =1 or status =2 order by createAt desc");
  24. if (studyidfind == null) {
  25. return;
  26. }
  27. // for (Object object : jsonArray) {
  28. // JSONObject jsonObject = JSON.parseObject(object.toString());
  29. // if (jsonObject.getString("studyuid").equals(studyidfind.getStr("STUDYUID"))) {
  30. // flag = 1;
  31. // }
  32. // }
  33. if (studyidfind.getStr("device")==null) {
  34. Record dRecord = Db.use("connected").findFirst("select * from reportinfo where STUDYUID = ?",
  35. studyidfind.getStr("STUDYUID"));
  36. String deviceString = "";
  37. if (dRecord != null && dRecord.getStr("DEVICE") != null) {
  38. deviceString = dRecord.getStr("DEVICE");
  39. }
  40. studyidfind.set("device", deviceString);
  41. studyidfind.set("updateAt", parseStringToDateTime());
  42. Db.use("local").update("study", studyidfind);
  43. }
  44. if (!studyidfind.getStr("device").equals("联影 40排CT") && !studyidfind.getStr("device").equals("Achieva 3.0T")) {
  45. studyidfind.set("status", 5);
  46. studyidfind.set("updateAt", parseStringToDateTime());
  47. Db.use("local").update("study", studyidfind);
  48. }else if(studyidfind.getStr("device").equals("联影 40排CT") || studyidfind.getStr("device").equals("Achieva 3.0T")){
  49. studyidfind.set("status", 4);
  50. studyidfind.set("updateAt", parseStringToDateTime());
  51. Db.use("local").update("study", studyidfind);
  52. String execCmd = ExecUtil.execCmd("/zskk_system/other/cmove.sh " + studyidfind.getStr("studyuid"));
  53. if (execCmd.contains("Connection refused") || execCmd.contains("Socket closed")) {
  54. studyidfind.set("status", 2);
  55. studyidfind.set("updateAt", parseStringToDateTime());
  56. Db.use("local").update("study", studyidfind);
  57. return;
  58. }
  59. studyidfind.set("status", 3);
  60. studyidfind.set("updateAt", parseStringToDateTime());
  61. Db.use("local").update("study", studyidfind);
  62. flag = 2;
  63. }
  64. }
  65. }
  66. @Override
  67. public void stop() {
  68. // TODO Auto-generated method stub
  69. }
  70. /**
  71. * 日期字符串格式转换年月日时分秒
  72. *
  73. * @param dateStr
  74. * @return
  75. */
  76. private String parseStringToDateTime() {
  77. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  78. Date date = new Date();
  79. String daString = sdf.format(date);
  80. return daString;
  81. }
  82. }