Task.go 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222
  1. package Task
  2. import (
  3. "ColdVerify_server/conf"
  4. "ColdVerify_server/lib"
  5. "ColdVerify_server/logs"
  6. "ColdVerify_server/models/InfoCollection"
  7. "encoding/json"
  8. "errors"
  9. "fmt"
  10. "github.com/astaxie/beego/cache"
  11. "github.com/beego/beego/v2/adapter/orm"
  12. orm2 "github.com/beego/beego/v2/client/orm"
  13. _ "github.com/go-sql-driver/mysql"
  14. "log"
  15. "strconv"
  16. "strings"
  17. "time"
  18. )
  19. var (
  20. TaskSchemeStateWaitSubmit = 0 // 待提交
  21. TaskSchemeStateSubmitted = 5 // 已提交
  22. TaskSchemeStateClientPass = 1 // 已通过(客户)
  23. TaskSchemeStateClientReturn = 2 // 已退回(客户)
  24. TaskSchemeStatePass = 3 // 已通过(负责人)
  25. TaskSchemeStateReturn = 4 // 已退回(负责人)
  26. TaskSchemeStateMap = map[int]string{
  27. TaskSchemeStateWaitSubmit: "待提交",
  28. TaskSchemeStateSubmitted: "已提交",
  29. TaskSchemeStateClientPass: "已通过(客户)",
  30. TaskSchemeStateClientReturn: "已驳回(客户)",
  31. TaskSchemeStatePass: "已通过",
  32. TaskSchemeStateReturn: "已退回",
  33. }
  34. // 0 未完成 1 数据来源已完成 2 处理中 3 已采集-无数据 4-数据编辑已完成(已提交) 5已通过(报告负责人) 6已退回(报告负责人)
  35. TaskCollectionStateWaitSubmit = 0 // 待提交
  36. TaskCollectionStateFinish = 1 // 已完成
  37. TaskCollectionStateInProgress = 2 // 处理中
  38. TaskCollectionStateNoData = 3 // 已采集-无数据
  39. TaskCollectionStateSubmitted = 4 // 已提交
  40. TaskCollectionStatePass = 5 // 已通过(负责人)
  41. TaskCollectionStateReturn = 6 // 已退回(负责人)
  42. TaskCollectionStateMap = map[int]string{
  43. TaskCollectionStateWaitSubmit: "待提交",
  44. TaskCollectionStateFinish: "已完成",
  45. TaskCollectionStateInProgress: "处理中",
  46. TaskCollectionStateNoData: "已采集-无数据",
  47. TaskCollectionStateSubmitted: "数据编辑已完成",
  48. TaskCollectionStatePass: "已通过",
  49. TaskCollectionStateReturn: "已退回",
  50. }
  51. TaskReportingStateWaitSubmit = 0 // 待提交
  52. TaskReportingStateSubmitted = 5 // 已提交
  53. TaskReportingStateClientPass = 1 // 已通过(客户)
  54. TaskReportingStateClientReturn = 2 // 已退回(客户)
  55. TaskReportingStatePass = 3 // 已通过
  56. TaskReportingStateReturn = 4 // 已退回
  57. TaskReportingStateMap = map[int]string{
  58. TaskReportingStateWaitSubmit: "待提交",
  59. TaskReportingStateSubmitted: "已提交",
  60. TaskReportingStateClientPass: "已通过(客户)",
  61. TaskReportingStateClientReturn: "已驳回(客户)",
  62. TaskReportingStatePass: "已通过",
  63. TaskReportingStateReturn: "已退回",
  64. }
  65. TaskDeliveryStateUnfinished = 0 // 未完成
  66. TaskDeliveryStateFinished = 1 // 已完成
  67. TaskDeliveryStateGoing = 2 // 进行中
  68. TaskDeliveryStateMap = map[int]string{
  69. TaskDeliveryStateUnfinished: "未完成",
  70. TaskDeliveryStateFinished: "已完成",
  71. TaskDeliveryStateGoing: "处理中",
  72. }
  73. TaskMarkingStateUnfinished = 0 // 未完成
  74. TaskMarkingStateFinished = 1 // 已完成
  75. TaskMarkingStateMap = map[int]string{
  76. TaskMarkingStateUnfinished: "未完成",
  77. TaskMarkingStateFinished: "已完成",
  78. }
  79. )
  80. var (
  81. TaskSchemeTimeLimit = map[string]float64{
  82. "BWX": 30, // 保温箱
  83. "LDX": 30, // 冷冻箱
  84. "LCG": 30, // 冷藏柜
  85. "LDG": 30, // 冷冻柜
  86. "YLG": 30, // 阴凉柜
  87. "LDC": 60, // 冷藏车
  88. "LK": 60, // 冷库
  89. "BG": 60, // 冰柜
  90. "DWBWX": 60, // 低温保存箱
  91. "XT": 30, // 系统验证
  92. "WZ": 80, // 位置
  93. "XJ": 0, // 巡检
  94. "PX": 0, // 培训
  95. "QT": 0, // 其他
  96. }
  97. TaskReportingTimeLimit = map[string]float64{
  98. "BWX": 180, // 保温箱
  99. "LDX": 180, // 冷冻箱
  100. "LCG": 210, // 冷藏柜
  101. "LDG": 210, // 冷冻柜
  102. "YLG": 210, // 阴凉柜
  103. "LDC": 300, // 冷藏车
  104. "LK": 390, // 冷库
  105. "BG": 210, // 冰柜
  106. "DWBWX": 180, // 低温保存箱
  107. "XT": 300, // 系统验证
  108. "WZ": 240, // 位置
  109. "XJ": 0, // 巡检
  110. "PX": 0, // 培训
  111. "QT": 0, // 其他
  112. }
  113. TaskCollectionTimeLimit float64 = 7 * 24 * 60
  114. )
  115. type AuditRecord struct {
  116. T_uuid string `orm:"size(256);null"` // 提交人(客户)UUID
  117. T_uuid_name string `orm:"size(256);null"` // 提交人名称
  118. T_admin string `orm:"size(256);null"` // 提交人(报告负责人)UUID
  119. T_admin_name string `orm:"size(256);null"` // 提交人名称
  120. T_state int `orm:"size(2);default(0)"` // 状态 1 已完成(客户通过) 2已退回(客户) 3已通过(报告负责人) 4已退回(报告负责人) 5已提交
  121. T_reason string `orm:"type(text)"` // 原因
  122. T_time string `orm:"type(256)"` // 时间
  123. T_type string `orm:"type(256)"` // 退回类型 scheme方案 reporting报告
  124. }
  125. // 模版
  126. type Task struct {
  127. Id int `orm:"column(ID);size(11);auto;pk"`
  128. T_Distributor_id string `orm:"size(256);null"` // 分销商id
  129. T_class int `orm:"size(200);default(0)"` // 分类id
  130. T_InfoCollection_id string `orm:"size(256);null"` // 信息采集ID
  131. T_InfoTemplate_id string `orm:"size(256);null"` // 信息采集模版ID
  132. T_task_id string `orm:"size(256);null"` // 任务ID
  133. T_uuid string `orm:"size(256);null"` // 用户 UUID
  134. T_name string `orm:"size(256);null"` // 标题
  135. T_VerifyTemplate_class string `orm:"size(256);null"` // 模版id
  136. T_VerifyTemplate_id string `orm:"size(256);null"` // 模版id
  137. T_deadline string `orm:"size(256);null"` // 截止时间
  138. T_scheme string `orm:"size(256);null"` // 实施方案 负责人UUID
  139. T_collection string `orm:"size(256);null"` // 数据采集 负责人UUID
  140. T_reporting string `orm:"size(256);null"` // 报告编写 负责人UUID
  141. T_delivery string `orm:"size(256);null"` // 交付审核 负责人UUID
  142. T_scheme_state int `orm:"size(2);default(0)"` // 实施方案 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  143. T_collection_state int `orm:"size(2);default(0)"` // 数据采集 状态 0 未完成 1 数据来源已完成 2 处理中 3 已采集-无数据 4-数据编辑已完成(已提交) 5已通过(负责人) 6已退回(负责人)
  144. T_reporting_state int `orm:"size(2);default(0)"` // 报告编写 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  145. T_delivery_state int `orm:"size(2);default(0)"` // 交付审核 状态 0 未完成 1 已完成 2 处理中
  146. T_marking_state int `orm:"size(2);default(0)"` // 验证标识 状态 0 未完成 1 已完成
  147. T_record string `orm:"type(text)"` // 领导备注
  148. T_VerifyDeviceDataStartTime string `orm:"size(256);null"` // 验证设备数据开始时间
  149. T_VerifyDeviceDataEndTime string `orm:"size(256);null"` // 验证设备数据开始时间
  150. T_BindDeviceDataStartTime string `orm:"size(256);null"` // 绑定设备数据开始时间
  151. T_BindDeviceDataEndTime string `orm:"size(256);null"` // 绑定设备数据结束时间
  152. T_doc1 string `orm:"type(text);null"` // 封面
  153. T_pdf1 string `orm:"type(text);null"` // 验证方案
  154. T_pdf1_watermark string `orm:"type(text);null"` // 验证方案 带水印
  155. T_doc2 string `orm:"type(text);null"` // 报告
  156. T_pdf2 string `orm:"type(text);null"` // 验证报告
  157. T_pdf2_watermark string `orm:"type(text);null"` // 验证报告 带水印
  158. T_doc3 string `orm:"type(text);null"` // 证书
  159. T_pdf3 string `orm:"type(text);null"` // 证书
  160. T_pdf4 string `orm:"type(text);null"` // 验证标识
  161. T_Show int `orm:"size(2);default(1)"` // 0 隐藏 1 公开
  162. T_Visit int `orm:"size(200);default(0)"` // 浏览量
  163. T_State int `orm:"size(2);default(1)"` // 0 删除 1 正常
  164. T_step int `orm:"size(2);default(-1)"` // 验证步骤
  165. T_sn string `orm:"size(256);null"` // sn
  166. T_CalibrationExpirationTime string `orm:"size(256);null"` // 校准到期时间
  167. T_project string `orm:"size(256);null"` // 项目 负责人UUID
  168. T_province string `orm:"size(256);null"` // 省
  169. T_city string `orm:"size(256);null"` // 市
  170. T_district string `orm:"size(256);null"` // 区
  171. T_province_code string `orm:"size(256);null"` // 省 code
  172. T_city_code string `orm:"size(256);null"` // 市 code
  173. T_district_code string `orm:"size(256);null"` // 区 code
  174. T_category string `orm:"size(256);null"` // 类别
  175. T_device_type string `orm:"size(256);null"` // 设备类型
  176. T_volume string `orm:"size(256);null"` // 规格/容积
  177. T_verify_type string `orm:"size(256);null"` // 验证类型
  178. T_subject_matter string `orm:"size(256);null"` // 标的物名称
  179. T_temp_range string `orm:"size(256);null"` // 验证温度范围
  180. T_report_number string `orm:"size(256);null"` // 报告编号
  181. T_report_type string `orm:"size(256);null"` // 报告类型
  182. T_start_time string `orm:"size(256);null"` // 项目开始时间
  183. T_end_time string `orm:"size(256);null"` // 结束时间 报告审核通过时间
  184. T_time_interval float64 `orm:"size(256);null"` // 时间间隔 单位分钟
  185. T_reject_times int `orm:"size(256);null"` // 驳回次数 客户退回方案和报告时
  186. T_reject_record string `orm:"type(text)"` // 驳回记录
  187. // 方案
  188. T_scheme_start_time string `orm:"size(256);null"` // 验证方案开始时间 接收信息采集表的时间
  189. T_scheme_end_time string `orm:"size(256);null"` // 验证方案结束时间 负责人审核通过后最后一次上传时间
  190. T_scheme_time_interval float64 `orm:"size(256);null"` // 时间间隔 单位分钟
  191. T_scheme_overtime float64 `orm:"size(256);null"` // 验证方案超时时间 单位分钟
  192. T_scheme_signature string `orm:"type(text)"` // 验证方案客户签字确认图片
  193. T_scheme_return_times int `orm:"size(256);null"` // 验证方案退回次数
  194. T_scheme_audit_record string `orm:"type(text)"` // 验证方案审核记录
  195. // 实施
  196. T_enter_area_time string `orm:"size(256);null"` // 进场时间
  197. T_collection_start_time string `orm:"size(256);null"` // 实施开始时间(app开始验证时间)
  198. T_collection_end_time string `orm:"size(256);null"` // 实施结束时间 (审核通过后签字确认提交时间)
  199. T_collection_time_interval float64 `orm:"size(256);null"` // 时间间隔 单位分钟
  200. T_collection_overtime float64 `orm:"size(256);null"` // 实施超时时间 单位分钟
  201. T_collection_signature string `orm:"type(text)"` // 实施人员签字确认图片
  202. T_collection_return_times int `orm:"size(256);null"` // 实施方案退回次数
  203. T_collection_audit_record string `orm:"type(text);null"` // 实施方案审核记录
  204. // 报告
  205. T_reporting_start_time string `orm:"size(256);null"` // 验证报告开始时间 接收信息采集表的时间
  206. T_reporting_end_time string `orm:"size(256);null"` // 验证报告结束时间 负责人审核通过前最后一次上传时间
  207. T_reporting_time_interval float64 `orm:"size(256);null"` // 时间间隔 单位分钟
  208. T_reporting_overtime float64 `orm:"size(256);null"` // 验证报告超时时间 单位分钟
  209. T_reporting_signature string `orm:"type(text)"` // 验证报告客户签字确认图片
  210. T_reporting_return_times int `orm:"size(256);null"` // 验证报告退回次数
  211. T_reporting_audit_record string `orm:"type(text);null"` // 验证报告审核记录
  212. T_reporting_pass_time string `orm:"size(256);null"` // 验证报告负责人通过时间
  213. CreateTime time.Time `orm:"column(create_time);type(timestamp);null;auto_now_add"` //auto_now_add 第一次保存时才设置时间
  214. UpdateTime time.Time `orm:"column(update_time);type(timestamp);null;auto_now"` //auto_now 每次 model 保存时都会对时间自动更新
  215. }
  216. type Task_ struct {
  217. Id int
  218. T_Distributor_id string // 信息采集ID
  219. T_class int // 分类ID
  220. T_InfoCollection_id string // 信息采集ID
  221. T_task_id string // 任务ID
  222. T_uuid string // 用户 UUID
  223. T_user_name string // 用户 UUID
  224. T_name string // 标题
  225. T_VerifyTemplate_class string // 任务模版id
  226. T_VerifyTemplate_id string // 任务模版id
  227. T_deadline string // 截止时间
  228. T_scheme string // 实施方案 负责人UUID
  229. T_collection string // 数据采集 负责人UUID
  230. T_reporting string // 报告编写 负责人UUID
  231. T_delivery string // 交付审核 负责人UUID
  232. T_scheme_state int // 实施方案 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  233. T_collection_state int // 数据采集 状态 0 未完成 1 数据来源已完成 2 处理中 3 已采集-无数据 4-数据编辑已完成(已提交) 5已通过(负责人) 6已退回(负责人)
  234. T_reporting_state int // 报告编写 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  235. T_delivery_state int // 交付审核 状态 0 未完成 1 已完成 2 处理中
  236. T_marking_state int // 验证标识 状态 0 未完成 1 已完成
  237. T_scheme_state_str string // 实施方案 状态 字符串
  238. T_collection_state_str string // 数据采集 状态 字符串
  239. T_reporting_state_str string // 报告编写 状态 字符串
  240. T_delivery_state_str string // 交付审核 状态 字符串
  241. T_marking_state_str string // 验证标识 状态 字符串
  242. T_scheme_name string // 实施方案 负责人姓名
  243. T_collection_name string // 数据采集 负责人姓名
  244. T_reporting_name string // 报告编写 负责人姓名
  245. T_delivery_name string // 交付审核 负责人姓名
  246. T_VerifyDeviceDataTime [2]string // 验证设备数据开始-结束时间
  247. T_BindDeviceDataTime [2]string // 绑定设备数据开始-结束时间
  248. T_doc1 string // 封面
  249. T_pdf1 string // 验证方案
  250. T_doc2 string // 报告
  251. T_pdf2 string // 报告
  252. T_doc3 string // 证书
  253. T_pdf3 string // 证书
  254. T_pdf4 string // 验证标识
  255. T_Show int // 0 公开 1 隐藏
  256. T_Visit int // 浏览量
  257. T_State int // 0 删除 1 正常
  258. T_sn string // sn
  259. T_CalibrationExpirationTime string // 校准到期时间
  260. T_province string // 省
  261. T_city string // 市
  262. T_district string // 区
  263. T_area []string // 省市区
  264. T_province_code string // 省 code
  265. T_city_code string // 市 code
  266. T_district_code string // 区 code
  267. T_area_code []string // 省市区
  268. InfoCollection InfoCollection.InfoCollection //信息采集
  269. T_record string //
  270. T_device_type string
  271. T_verify_type string
  272. T_reporting_pass_time string
  273. }
  274. type Task_Stat struct {
  275. Id int
  276. T_Distributor_id string // 信息采集ID
  277. T_class int // 分类ID
  278. T_InfoCollection_id string // 信息采集ID
  279. T_InfoTemplate_id string // 信息采集模版ID
  280. T_task_id string // 任务ID
  281. T_uuid string // 用户 UUID
  282. T_user_name string // 用户 UUID
  283. T_name string // 标题
  284. T_VerifyTemplate_class string // 任务模版id
  285. T_VerifyTemplate_id string // 任务模版id
  286. T_deadline string // 截止时间
  287. T_scheme string // 实施方案 负责人UUID
  288. T_collection string // 数据采集 负责人UUID
  289. T_reporting string // 报告编写 负责人UUID
  290. T_delivery string // 交付审核 负责人UUID
  291. T_scheme_state int // 实施方案 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  292. T_collection_state int // 数据采集 状态 0 未完成 1 数据来源已完成 2 处理中 3 已采集-无数据 4-数据编辑已完成(已提交) 5已通过(负责人) 6已退回(负责人)
  293. T_reporting_state int // 报告编写 状态 0 未完成 1 已完成(客户通过) 2已退回(客户) 3已通过(负责人) 4已退回(负责人) 5已提交
  294. T_delivery_state int // 交付审核 状态 0 未完成 1 已完成 2 处理中
  295. T_marking_state int // 验证标识 状态 0 未完成 1 已完成
  296. T_scheme_state_str string // 实施方案 状态 字符串
  297. T_collection_state_str string // 数据采集 状态 字符串
  298. T_reporting_state_str string // 报告编写 状态 字符串
  299. T_delivery_state_str string // 交付审核 状态 字符串
  300. T_marking_state_str string // 验证标识 状态 字符串
  301. T_scheme_name string // 实施方案 负责人姓名
  302. T_collection_name string // 数据采集 负责人姓名
  303. T_reporting_name string // 报告编写 负责人姓名
  304. T_delivery_name string // 交付审核 负责人姓名
  305. T_VerifyDeviceDataTime [2]string // 验证设备数据开始-结束时间
  306. T_BindDeviceDataTime [2]string // 绑定设备数据开始-结束时间
  307. T_doc1 string // 封面
  308. T_pdf1 string // 验证方案
  309. T_doc2 string // 报告
  310. T_pdf2 string // 报告
  311. T_doc3 string // 证书
  312. T_pdf3 string // 证书
  313. T_pdf4 string // 验证标识
  314. T_Show int // 0 公开 1 隐藏
  315. T_Visit int // 浏览量
  316. T_State int // 0 删除 1 正常
  317. T_sn string // sn
  318. T_CalibrationExpirationTime string // 校准到期时间
  319. T_project string // 项目 负责人UUID
  320. T_project_name string // 项目 负责人姓名
  321. T_province string // 省
  322. T_city string // 市
  323. T_district string // 区
  324. T_area []string // 省市区
  325. T_province_code string // 省 code
  326. T_city_code string // 市 code
  327. T_district_code string // 区 code
  328. T_area_code []string // 省市区
  329. T_category string // 类别
  330. T_device_type string // 设备类型
  331. T_volume string // 规格/容积
  332. T_verify_type string // 验证类型
  333. T_subject_matter string // 标的物名称
  334. T_temp_range string // 验证温度范围
  335. T_report_number string // 报告编号
  336. T_report_type string // 报告类型
  337. T_start_time string // 项目开始时间
  338. T_end_time string // 结束时间 报告审核通过时间
  339. T_time_interval string // 时间间隔 单位分钟
  340. T_reject_times int // 驳回次数 客户退回方案和报告时
  341. T_reject_record string // 驳回记录
  342. // 方案
  343. T_scheme_start_time string // 验证方案开始时间 接收信息采集表的时间
  344. T_scheme_end_time string // 验证方案结束时间
  345. T_scheme_time_interval string // 时间间隔 单位分钟
  346. T_scheme_overtime string // 验证方案超时时间 单位分钟
  347. T_scheme_signature string // 验证方案客户签字确认图片
  348. T_scheme_return_times int // 验证方案退回次数
  349. T_scheme_audit_record string // 验证方案审核记录
  350. // 实施
  351. T_enter_area_time string // 进场时间
  352. T_collection_start_time string // 实施开始时间(app开始验证时间)
  353. T_collection_end_time string // 实施结束时间 (签字确认提交时间)
  354. T_collection_time_interval string // 时间间隔 单位分钟
  355. T_collection_overtime string // 实施超时时间 单位分钟
  356. T_collection_signature string // 实施人员签字确认图片
  357. T_collection_return_times int // 实施方案退回次数
  358. T_collection_audit_record string // 实施方案审核记录
  359. // 报告
  360. T_reporting_start_time string // 验证报告开始时间 接收信息采集表的时间
  361. T_reporting_end_time string // 验证报告结束时间
  362. T_reporting_time_interval string // 时间间隔 单位分钟
  363. T_reporting_overtime string // 验证报告超时时间 单位分钟
  364. T_reporting_signature string // 验证报告客户签字确认图片
  365. T_reporting_return_times int // 验证报告退回次数
  366. T_reporting_audit_record string // 验证报告审核记录
  367. InfoCollection InfoCollection.InfoCollection_R //信息菜鸡
  368. T_record string //
  369. }
  370. func (t *Task) TableName() string {
  371. return "task" // 数据库名称 // ************** 替换 FormulaList **************
  372. }
  373. var redisCache_Task cache.Cache
  374. func init() {
  375. //注册模型
  376. orm.RegisterModel(new(Task))
  377. config := fmt.Sprintf(`{"key":"%s","conn":"%s","dbNum":"%s","password":"%s"}`,
  378. "redis_"+"Task", conf.Redis_address, conf.Redis_dbNum, conf.Redis_password)
  379. logs.Println(config)
  380. var err error
  381. redisCache_Task, err = cache.NewCache("redis", config)
  382. if err != nil || redisCache_Task == nil {
  383. errMsg := "failed to init redis"
  384. logs.Println(errMsg, err)
  385. }
  386. }
  387. // -------------------------------------------------------------
  388. func TaskToTask_(T Task, userMap, adminMap map[string]string) (T_ Task_) {
  389. T_.Id = T.Id
  390. T_.T_Distributor_id = T.T_Distributor_id
  391. T_.T_class = T.T_class
  392. T_.T_InfoCollection_id = T.T_InfoCollection_id
  393. if len(T.T_InfoCollection_id) > 0 {
  394. T_.InfoCollection, _ = InfoCollection.Read_InfoCollection(T.T_InfoCollection_id)
  395. }
  396. T_.T_task_id = T.T_task_id
  397. T_.T_uuid = T.T_uuid
  398. T_.T_user_name = userMap[T.T_uuid]
  399. T_.T_name = T.T_name
  400. T_.T_VerifyTemplate_class = T.T_VerifyTemplate_class
  401. T_.T_VerifyTemplate_id = T.T_VerifyTemplate_id
  402. T_.T_deadline = T.T_deadline
  403. T_.T_scheme = T.T_scheme
  404. T_.T_collection = T.T_collection
  405. T_.T_reporting = T.T_reporting
  406. T_.T_delivery = T.T_delivery
  407. T_.T_scheme_state = T.T_scheme_state
  408. T_.T_collection_state = T.T_collection_state
  409. T_.T_reporting_state = T.T_reporting_state
  410. T_.T_delivery_state = T.T_delivery_state
  411. T_.T_marking_state = T.T_marking_state
  412. T_.T_scheme_state_str = TaskSchemeStateMap[T.T_scheme_state]
  413. T_.T_collection_state_str = TaskCollectionStateMap[T.T_collection_state]
  414. T_.T_reporting_state_str = TaskReportingStateMap[T.T_reporting_state]
  415. T_.T_delivery_state_str = TaskDeliveryStateMap[T.T_delivery_state]
  416. T_.T_marking_state_str = TaskMarkingStateMap[T.T_marking_state]
  417. T_.T_scheme_name = adminMap[T.T_scheme]
  418. T_.T_collection_name = adminMap[T.T_collection]
  419. T_.T_reporting_name = adminMap[T.T_reporting]
  420. T_.T_delivery_name = adminMap[T.T_delivery]
  421. T_.T_VerifyDeviceDataTime = [2]string{T.T_VerifyDeviceDataStartTime, T.T_VerifyDeviceDataEndTime}
  422. T_.T_BindDeviceDataTime = [2]string{T.T_BindDeviceDataStartTime, T.T_BindDeviceDataEndTime}
  423. T_.T_doc1 = T.T_doc1
  424. T_.T_doc2 = T.T_doc2
  425. T_.T_doc3 = T.T_doc3
  426. T_.T_pdf1 = T.T_pdf1_watermark
  427. if T_.InfoCollection.T_status == InfoCollection.InfoCollectionStatusReturnedMoney || len(T.T_InfoCollection_id) == 0 || len(T.T_pdf1_watermark) == 0 {
  428. T_.T_pdf1 = T.T_pdf1
  429. }
  430. T_.T_pdf2 = T.T_pdf2_watermark
  431. if T_.InfoCollection.T_status == InfoCollection.InfoCollectionStatusReturnedMoney || len(T.T_InfoCollection_id) == 0 || len(T.T_pdf2_watermark) == 0 {
  432. T_.T_pdf2 = T.T_pdf2
  433. }
  434. T_.T_pdf3 = T.T_pdf3
  435. T_.T_pdf4 = T.T_pdf4
  436. T_.T_Show = T.T_Show
  437. T_.T_Visit = T.T_Visit
  438. T_.T_State = T.T_State
  439. T_.T_sn = T.T_sn
  440. T_.T_CalibrationExpirationTime = T.T_CalibrationExpirationTime
  441. T_.T_record = T.T_record
  442. T_.T_device_type = T.T_device_type
  443. T_.T_verify_type = T.T_verify_type
  444. T_.T_reporting_pass_time = T.T_reporting_pass_time
  445. return T_
  446. }
  447. func TaskToTask_Stat(T Task, userMap, adminMap map[string]string) (T_ Task_Stat) {
  448. T_.Id = T.Id
  449. T_.T_Distributor_id = T.T_Distributor_id
  450. T_.T_class = T.T_class
  451. T_.T_InfoCollection_id = T.T_InfoCollection_id
  452. if len(T.T_InfoCollection_id) > 0 {
  453. infoCollection, _ := InfoCollection.Read_InfoCollection(T.T_InfoCollection_id)
  454. T_.InfoCollection = InfoCollection.InfoCollectionToInfoCollection_R(infoCollection, userMap, adminMap, map[string]string{}, map[string]string{})
  455. }
  456. T_.T_task_id = T.T_task_id
  457. T_.T_uuid = T.T_uuid
  458. T_.T_user_name = userMap[T.T_uuid]
  459. T_.T_name = T.T_name
  460. T_.T_VerifyTemplate_class = T.T_VerifyTemplate_class
  461. T_.T_VerifyTemplate_id = T.T_VerifyTemplate_id
  462. T_.T_deadline = T.T_deadline
  463. T_.T_scheme = T.T_scheme
  464. T_.T_collection = T.T_collection
  465. T_.T_reporting = T.T_reporting
  466. T_.T_delivery = T.T_delivery
  467. T_.T_scheme_state = T.T_scheme_state
  468. T_.T_collection_state = T.T_collection_state
  469. T_.T_reporting_state = T.T_reporting_state
  470. T_.T_delivery_state = T.T_delivery_state
  471. T_.T_marking_state = T.T_marking_state
  472. T_.T_scheme_state_str = TaskSchemeStateMap[T.T_scheme_state]
  473. T_.T_collection_state_str = TaskCollectionStateMap[T.T_collection_state]
  474. T_.T_reporting_state_str = TaskReportingStateMap[T.T_reporting_state]
  475. T_.T_delivery_state_str = TaskDeliveryStateMap[T.T_delivery_state]
  476. T_.T_marking_state_str = TaskMarkingStateMap[T.T_marking_state]
  477. T_.T_project_name = adminMap[T.T_project]
  478. T_.T_scheme_name = adminMap[T.T_scheme]
  479. T_.T_collection_name = adminMap[T.T_collection]
  480. T_.T_reporting_name = adminMap[T.T_reporting]
  481. T_.T_delivery_name = adminMap[T.T_delivery]
  482. T_.T_VerifyDeviceDataTime = [2]string{T.T_VerifyDeviceDataStartTime, T.T_VerifyDeviceDataEndTime}
  483. T_.T_BindDeviceDataTime = [2]string{T.T_BindDeviceDataStartTime, T.T_BindDeviceDataEndTime}
  484. T_.T_doc1 = T.T_doc1
  485. T_.T_doc2 = T.T_doc2
  486. T_.T_doc3 = T.T_doc3
  487. T_.T_pdf1 = T.T_pdf1_watermark
  488. if T_.InfoCollection.T_status == InfoCollection.InfoCollectionStatusReturnedMoney || len(T.T_InfoCollection_id) == 0 || len(T.T_pdf1_watermark) == 0 {
  489. T_.T_pdf1 = T.T_pdf1
  490. }
  491. T_.T_pdf2 = T.T_pdf2_watermark
  492. if T_.InfoCollection.T_status == InfoCollection.InfoCollectionStatusReturnedMoney || len(T.T_InfoCollection_id) == 0 || len(T.T_pdf2_watermark) == 0 {
  493. T_.T_pdf2 = T.T_pdf2
  494. }
  495. T_.T_pdf3 = T.T_pdf3
  496. T_.T_pdf4 = T.T_pdf4
  497. T_.T_Show = T.T_Show
  498. T_.T_Visit = T.T_Visit
  499. T_.T_State = T.T_State
  500. T_.T_sn = T.T_sn
  501. T_.T_CalibrationExpirationTime = T.T_CalibrationExpirationTime
  502. T_.T_project = T.T_project
  503. T_.T_province = T.T_province
  504. T_.T_city = T.T_city
  505. T_.T_district = T.T_district
  506. T_.T_area = []string{T.T_province, T.T_city, T.T_district}
  507. T_.T_province_code = T.T_province_code
  508. T_.T_city_code = T.T_city_code
  509. T_.T_district_code = T.T_district_code
  510. T_.T_area_code = []string{T.T_province_code, T.T_city_code, T.T_district_code}
  511. T_.T_category = T.T_category
  512. T_.T_device_type = T.T_device_type
  513. T_.T_volume = T.T_volume
  514. T_.T_verify_type = T.T_verify_type
  515. T_.T_subject_matter = T.T_subject_matter
  516. T_.T_temp_range = T.T_temp_range
  517. T_.T_report_number = T.T_report_number
  518. T_.T_report_type = T.T_report_type
  519. T_.T_start_time = T.T_start_time
  520. T_.T_end_time = T.T_end_time
  521. T_.T_time_interval = lib.ConvertMinutesToDHM(int(T.T_time_interval))
  522. T_.T_reject_times = T.T_reject_times
  523. T_.T_reject_record = T.T_reject_record
  524. // 方案
  525. T_.T_scheme_start_time = T.T_scheme_start_time
  526. T_.T_scheme_end_time = T.T_scheme_end_time
  527. if T.T_scheme_state == TaskSchemeStateSubmitted ||
  528. T.T_scheme_state == TaskSchemeStateClientPass ||
  529. T.T_scheme_state == TaskSchemeStatePass {
  530. T_.T_scheme_time_interval = lib.ConvertMinutesToDHM(int(T.T_scheme_time_interval))
  531. T_.T_scheme_overtime = lib.ConvertMinutesToDHM(int(T.T_scheme_overtime))
  532. }
  533. T_.T_scheme_signature = T.T_scheme_signature
  534. T_.T_scheme_return_times = T.T_scheme_return_times
  535. T_.T_scheme_audit_record = T.T_scheme_audit_record
  536. // 实施
  537. T_.T_enter_area_time = T.T_enter_area_time
  538. T_.T_collection_start_time = T.T_collection_start_time
  539. T_.T_collection_end_time = T.T_collection_end_time
  540. if T.T_collection_state == TaskCollectionStatePass ||
  541. T.T_collection_state == TaskCollectionStateSubmitted {
  542. T_.T_collection_time_interval = lib.ConvertMinutesToDHM(int(T.T_collection_time_interval))
  543. T_.T_collection_overtime = lib.ConvertMinutesToDHM(int(T.T_collection_overtime))
  544. }
  545. T_.T_collection_signature = T.T_collection_signature
  546. T_.T_collection_return_times = T.T_collection_return_times
  547. T_.T_collection_audit_record = T.T_collection_audit_record
  548. // 报告
  549. T_.T_reporting_start_time = T.T_reporting_start_time
  550. T_.T_reporting_end_time = T.T_reporting_end_time
  551. if T.T_reporting_state == TaskReportingStateClientPass ||
  552. T.T_reporting_state == TaskReportingStateSubmitted ||
  553. T.T_reporting_state == TaskReportingStateClientReturn ||
  554. T.T_reporting_state == TaskReportingStatePass {
  555. T_.T_reporting_time_interval = lib.ConvertMinutesToDHM(int(T.T_reporting_time_interval))
  556. T_.T_reporting_overtime = lib.ConvertMinutesToDHM(int(T.T_reporting_overtime))
  557. }
  558. T_.T_reporting_signature = T.T_reporting_signature
  559. T_.T_reporting_return_times = T.T_reporting_return_times
  560. T_.T_reporting_audit_record = T.T_reporting_audit_record
  561. T_.T_record = T.T_record
  562. return T_
  563. }
  564. // ---------------- Redis -------------------
  565. func Redis_Task_Set(key string, r Task) (err error) {
  566. //json序列化
  567. str, err := json.Marshal(r)
  568. if err != nil {
  569. logs.Error(lib.FuncName(), err)
  570. return
  571. }
  572. err = redisCache_Task.Put(key, str, 24*time.Hour)
  573. if err != nil {
  574. logs.Println("set key:", key, ",value:", str, err)
  575. }
  576. return
  577. }
  578. func Redis_Task_Get(key string) (r Task, is bool) {
  579. if redisCache_Task.IsExist(key) {
  580. logs.Println("找到key:", key)
  581. v := redisCache_Task.Get(key)
  582. json.Unmarshal(v.([]byte), &r)
  583. return r, true
  584. }
  585. logs.Println("没有 找到key:", key)
  586. return Task{}, false
  587. }
  588. func Redis_Task_DelK(key string) (err error) {
  589. err = redisCache_Task.Delete(key)
  590. return
  591. }
  592. func Redis_Task_T_report_number_Set(key string) (err error) {
  593. err = redisCache_Task.Put(key, "", 24*time.Hour)
  594. if err != nil {
  595. logs.Println("set key:", key)
  596. }
  597. return
  598. }
  599. func Redis_Task_T_report_number_Get(key string) (is bool) {
  600. if redisCache_Task.IsExist(key) {
  601. return true
  602. }
  603. logs.Println("没有 找到key:", key)
  604. return false
  605. }
  606. func Redis_Task_T_report_number_DelK(key string) (err error) {
  607. err = redisCache_Task.Delete(key)
  608. return
  609. }
  610. // ---------------- 特殊方法 -------------------
  611. // 获取 ById
  612. func Read_Task_ById(id int) (r Task, is bool) {
  613. o := orm.NewOrm()
  614. r = Task{Id: id}
  615. err := o.Read(&r) // o.Read(&r,"Tokey") 如果不是 主键 就得指定字段名
  616. if err != nil {
  617. logs.Error(lib.FuncName(), err)
  618. return r, false
  619. }
  620. return r, true
  621. }
  622. // 获取 By
  623. func Read_Task(T_task_id string) (r Task, is bool) {
  624. if r, is = Redis_Task_Get(T_task_id); is == true {
  625. return r, true
  626. }
  627. o := orm.NewOrm()
  628. qs := o.QueryTable(new(Task))
  629. //err := qs.Filter("T_task_id", T_task_id).Filter("T_State", 1).One(&r)
  630. err := qs.Filter("T_task_id", T_task_id).Filter("T_State", 1).One(&r)
  631. if err != nil {
  632. return r, false
  633. }
  634. Redis_Task_Set(T_task_id, r)
  635. return r, true
  636. }
  637. // 添加
  638. func Add_Task(r Task) (string, bool) {
  639. o := orm.NewOrm()
  640. // 生成编号
  641. rand_x := 0
  642. for true {
  643. r.T_task_id = lib.GetRandstring(12, "abcdefghijklmnopqrstuvwxyz0123456789", int64(rand_x)) // 1,336,336
  644. err := o.Read(&r, "T_task_id") // o.Read(&r,"Tokey") 如果不是 主键 就得指定字段名
  645. if err != nil {
  646. break
  647. }
  648. rand_x += 1
  649. }
  650. _, err := o.Insert(&r)
  651. if err != nil {
  652. logs.Error(lib.FuncName(), err)
  653. return "", false
  654. }
  655. if !CREATE_TaskData(r.T_task_id) {
  656. return "", false
  657. }
  658. Redis_Task_Set(r.T_task_id, r)
  659. return r.T_task_id, true
  660. }
  661. func Add_Task_Tool(r Task) (string, bool) {
  662. o := orm.NewOrm()
  663. _, err := o.Insert(&r)
  664. if err != nil {
  665. logs.Error(lib.FuncName(), err)
  666. return "", false
  667. }
  668. return r.T_task_id, true
  669. }
  670. // 删除
  671. func Delete_Task(v Task) bool {
  672. o := orm.NewOrm()
  673. if num, err := o.Delete(&v); err == nil {
  674. logs.Println("Number of records deleted in database:", num)
  675. } else {
  676. logs.Error(lib.FuncName(), err)
  677. return false
  678. }
  679. Redis_Task_DelK(v.T_task_id)
  680. return true
  681. }
  682. // 删除
  683. func Delete_Task_(v Task) bool {
  684. o := orm.NewOrm()
  685. v.T_State = 0
  686. if num, err := o.Update(&v, "T_State"); err == nil {
  687. logs.Println("Number of records updated in database:", num)
  688. } else {
  689. logs.Error(lib.FuncName(), err)
  690. return false
  691. }
  692. Redis_Task_DelK(v.T_task_id)
  693. return true
  694. }
  695. // 修改
  696. func Update_Task(m Task, cols ...string) bool {
  697. o := orm.NewOrm()
  698. if num, err := o.Update(&m, cols...); err == nil {
  699. logs.Println("Number of records updated in database:", num)
  700. Redis_Task_Set(m.T_task_id, m)
  701. return true
  702. } else {
  703. logs.Error(lib.FuncName(), err)
  704. }
  705. return false
  706. }
  707. // 添加浏览量
  708. func Add_Task_Visit(m Task) bool {
  709. o := orm.NewOrm()
  710. m.T_Visit += 1
  711. if num, err := o.Update(&m, "T_Visit"); err == nil {
  712. logs.Println("Number of records updated in database:", num)
  713. Redis_Task_Set(m.T_task_id, m)
  714. return true
  715. } else {
  716. logs.Error(lib.FuncName(), err)
  717. }
  718. return false
  719. }
  720. // 获取用户任务列表
  721. func Read_Task_List_All() ([]Task, int) {
  722. o := orm.NewOrm()
  723. qs := o.QueryTable(new(Task))
  724. var r []Task
  725. cond := orm.NewCondition()
  726. //cond1 := cond.And("T_name__icontains", T_name).And("T_State", 1)
  727. cond1 := cond.And("T_State", 1)
  728. qs.Limit(10, 0).SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  729. cnt, _ := qs.SetCond((*orm2.Condition)(cond1)).Count()
  730. return r, int(cnt)
  731. }
  732. // 获取用户任务列表
  733. func Read_UserTask_List(T_uuid string, T_name string, userMap, adminMap map[string]string, page int, page_z int) ([]Task_, int) {
  734. o := orm.NewOrm()
  735. qs := o.QueryTable(new(Task))
  736. var r []Task
  737. var offset int64
  738. if page <= 1 {
  739. offset = 0
  740. } else {
  741. offset = int64((page - 1) * page_z)
  742. }
  743. cond := orm.NewCondition()
  744. cond1 := cond.And("T_name__icontains", T_name).And("T_Show", 1).And("T_State", 1)
  745. if len(T_uuid) > 0 {
  746. cond1 = cond1.And("T_uuid", T_uuid)
  747. }
  748. qs.Limit(page_z, offset).SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  749. cnt, _ := qs.SetCond((*orm2.Condition)(cond1)).Count()
  750. // 转换
  751. var TaskList []Task_
  752. for _, v := range r {
  753. TaskList = append(TaskList, TaskToTask_(v, userMap, adminMap))
  754. }
  755. return TaskList, int(cnt)
  756. }
  757. // 获取任务列表
  758. func Read_Task_List(T_Distributor_id, T_uuid, T_admin, T_name, T_InfoCollection_id string, T_scheme, T_collection, T_reporting, T_delivery,
  759. T_scheme_state, T_collection_state, T_reporting_state, T_delivery_state, T_marking_state string,
  760. T_company_list []string, userMap, adminMap map[string]string, CreateTime string, page int, page_z int) ([]Task_, int) {
  761. o := orm.NewOrm()
  762. qs := o.QueryTable(new(Task))
  763. var r []Task
  764. var offset int64
  765. if page <= 1 {
  766. offset = 0
  767. } else {
  768. offset = int64((page - 1) * page_z)
  769. }
  770. cond := orm.NewCondition()
  771. cond1 := cond.AndCond(cond.Or("T_name__icontains", T_name).Or("T_task_id__icontains", T_name)).And("T_State", 1)
  772. if len(T_uuid) > 0 {
  773. cond1 = cond1.And("T_uuid", T_uuid)
  774. }
  775. if len(T_Distributor_id) > 0 {
  776. cond1 = cond1.And("T_Distributor_id", T_Distributor_id)
  777. }
  778. if len(T_InfoCollection_id) > 0 {
  779. cond1 = cond1.And("T_InfoCollection_id", T_InfoCollection_id)
  780. }
  781. if len(T_admin) > 0 {
  782. cond1 = cond1.AndCond(cond.Or("T_scheme", T_admin).Or("T_collection", T_admin).
  783. Or("T_reporting", T_admin).Or("T_delivery", T_admin))
  784. }
  785. if len(T_company_list) > 0 {
  786. cond1 = cond1.And("T_uuid__in", T_company_list)
  787. }
  788. if len(T_scheme) > 0 {
  789. cond1 = cond1.And("T_scheme", T_scheme)
  790. }
  791. if len(T_collection) > 0 {
  792. cond1 = cond1.And("T_collection", T_collection)
  793. }
  794. if len(T_reporting) > 0 {
  795. cond1 = cond1.And("T_reporting", T_reporting)
  796. }
  797. if len(T_delivery) > 0 {
  798. cond1 = cond1.And("T_delivery", T_delivery)
  799. }
  800. if len(T_scheme_state) > 0 {
  801. cond1 = cond1.And("T_scheme_state", T_scheme_state)
  802. }
  803. if len(T_collection_state) > 0 {
  804. cond1 = cond1.And("T_collection_state", T_collection_state)
  805. }
  806. if len(T_reporting_state) > 0 {
  807. cond1 = cond1.And("T_reporting_state", T_reporting_state)
  808. }
  809. if len(T_delivery_state) > 0 {
  810. cond1 = cond1.And("T_delivery_state", T_delivery_state)
  811. }
  812. if len(T_marking_state) > 0 {
  813. cond1 = cond1.And("T_marking_state", T_marking_state)
  814. }
  815. if len(CreateTime) > 0 {
  816. CreateTime_s := strings.Split(CreateTime, "-")
  817. if len(CreateTime_s) == 2 {
  818. // 定义开始和结束时间
  819. start := time.Date(lib.To_int(CreateTime_s[0]), time.Month(lib.To_int(CreateTime_s[1])), 1, 0, 0, 0, 0, time.UTC)
  820. end := start.AddDate(0, 1, 0) // 下个月的第一天
  821. logs.Println("CreateTime_s:", start.Format("2006-01-02 15:04:05"), end.Format("2006-01-02 15:04:05"))
  822. cond1 = cond1.And("CreateTime__gte", start).And("CreateTime__lt", end)
  823. }
  824. }
  825. qs.Limit(page_z, offset).SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  826. cnt, _ := qs.SetCond((*orm2.Condition)(cond1)).Count()
  827. // 转换
  828. var TaskList []Task_
  829. for _, v := range r {
  830. TaskList = append(TaskList, TaskToTask_(v, userMap, adminMap))
  831. }
  832. return TaskList, int(cnt)
  833. }
  834. func Read_Task_BySN(sn string) (r Task, err error) {
  835. if task, is := Redis_Task_Get(sn); is == true {
  836. return task, nil
  837. }
  838. o := orm.NewOrm()
  839. qs := o.QueryTable(new(Task))
  840. err = qs.Filter("T_sn", sn).Filter("T_State", 1).One(&r)
  841. if err != nil {
  842. return r, err
  843. }
  844. Redis_Task_Set(sn, r)
  845. return r, nil
  846. }
  847. // 修改
  848. func Update_Task_T_InfoTemplate_id(T_InfoCollection_id, T_InfoTemplate_id string) error {
  849. o := orm.NewOrm()
  850. qs := o.QueryTable(new(Task))
  851. var r []Task
  852. o.Begin()
  853. qs.Filter("T_InfoCollection_id", T_InfoCollection_id).All(&r)
  854. for _, task := range r {
  855. task.T_InfoTemplate_id = T_InfoTemplate_id
  856. if _, err := o.Update(&task, "T_InfoTemplate_id"); err == nil {
  857. Redis_Task_Set(task.T_task_id, task)
  858. } else {
  859. o.Rollback()
  860. logs.Error(lib.FuncName(), err)
  861. return err
  862. }
  863. }
  864. o.Commit()
  865. return nil
  866. }
  867. func Add_AuditRecord(T_audit_record string, T_uuid, T_admin string, T_scheme_state int, T_reason string, T_type string) (string, error) {
  868. auditRecord := AuditRecord{
  869. T_uuid: T_uuid,
  870. T_admin: T_admin,
  871. T_state: T_scheme_state,
  872. T_reason: T_reason,
  873. T_type: T_type,
  874. T_time: time.Now().Format("2006-01-02 15:04:05"),
  875. }
  876. var returnRecordList []AuditRecord
  877. if len(T_audit_record) > 0 {
  878. err := json.Unmarshal([]byte(T_audit_record), &returnRecordList)
  879. if err != nil {
  880. logs.Error("JSON 反序列化失败:", err)
  881. return "", errors.New("JSON 反序列化失败")
  882. }
  883. }
  884. returnRecordList = append(returnRecordList, auditRecord)
  885. returnRecordJson, err := json.Marshal(returnRecordList)
  886. if err != nil {
  887. logs.Error("JSON 反序列化失败:", err)
  888. return "", errors.New("JSON 反序列化失败")
  889. }
  890. return string(returnRecordJson), nil
  891. }
  892. // 获取项目负责人列表
  893. func Get_Task_UserList(T_type string) []string {
  894. o := orm.NewOrm()
  895. var err error
  896. var pl_lists []string
  897. switch T_type {
  898. case "T_project":
  899. _, err = o.Raw("SELECT DISTINCT t_project FROM task LIMIT 0,1000").QueryRows(&pl_lists)
  900. case "T_scheme":
  901. _, err = o.Raw("SELECT DISTINCT t_scheme FROM task LIMIT 0,1000").QueryRows(&pl_lists)
  902. case "T_collection":
  903. _, err = o.Raw("SELECT DISTINCT t_collection FROM task LIMIT 0,1000").QueryRows(&pl_lists)
  904. case "T_reporting":
  905. _, err = o.Raw("SELECT DISTINCT t_reporting FROM task LIMIT 0,1000").QueryRows(&pl_lists)
  906. }
  907. if err != nil {
  908. logs.Error("获取项目负责人列表失败:", err)
  909. }
  910. return pl_lists
  911. }
  912. func Read_Task_Stat(T_Distributor_id, T_uuid, T_admin, T_name, T_InfoCollection_id string, T_project, T_scheme, T_collection, T_reporting, T_delivery,
  913. T_scheme_state, T_collection_state, T_reporting_state, T_delivery_state, T_marking_state string,
  914. T_company_list []string, userMap, adminMap map[string]string, CreateTime string, page int, page_z int) ([]Task_Stat, int) {
  915. o := orm.NewOrm()
  916. qs := o.QueryTable(new(Task))
  917. var r []Task
  918. var offset int64
  919. if page <= 1 {
  920. offset = 0
  921. } else {
  922. offset = int64((page - 1) * page_z)
  923. }
  924. cond := orm.NewCondition()
  925. cond1 := cond.AndCond(cond.Or("T_name__icontains", T_name).Or("T_task_id__icontains", T_name)).And("T_State", 1)
  926. if len(T_uuid) > 0 {
  927. cond1 = cond1.And("T_uuid", T_uuid)
  928. }
  929. if len(T_Distributor_id) > 0 {
  930. cond1 = cond1.And("T_Distributor_id", T_Distributor_id)
  931. }
  932. if len(T_InfoCollection_id) > 0 {
  933. cond1 = cond1.And("T_InfoCollection_id", T_InfoCollection_id)
  934. }
  935. if len(T_admin) > 0 {
  936. cond1 = cond1.AndCond(cond.Or("T_scheme", T_admin).Or("T_collection", T_admin).
  937. Or("T_reporting", T_admin).Or("T_delivery", T_admin))
  938. }
  939. if len(T_company_list) > 0 {
  940. cond1 = cond1.And("T_uuid__in", T_company_list)
  941. }
  942. if len(T_project) > 0 {
  943. cond1 = cond1.And("T_project", T_project)
  944. }
  945. if len(T_scheme) > 0 {
  946. cond1 = cond1.And("T_scheme", T_scheme)
  947. }
  948. if len(T_collection) > 0 {
  949. cond1 = cond1.And("T_collection", T_collection)
  950. }
  951. if len(T_reporting) > 0 {
  952. cond1 = cond1.And("T_reporting", T_reporting)
  953. }
  954. if len(T_delivery) > 0 {
  955. cond1 = cond1.And("T_delivery", T_delivery)
  956. }
  957. if len(T_scheme_state) > 0 {
  958. cond1 = cond1.And("T_scheme_state", T_scheme_state)
  959. }
  960. if len(T_collection_state) > 0 {
  961. cond1 = cond1.And("T_collection_state", T_collection_state)
  962. }
  963. if len(T_reporting_state) > 0 {
  964. cond1 = cond1.And("T_reporting_state", T_reporting_state)
  965. }
  966. if len(T_delivery_state) > 0 {
  967. cond1 = cond1.And("T_delivery_state", T_delivery_state)
  968. }
  969. if len(T_marking_state) > 0 {
  970. cond1 = cond1.And("T_marking_state", T_marking_state)
  971. }
  972. if len(CreateTime) > 0 {
  973. CreateTime_s := strings.Split(CreateTime, "-")
  974. if len(CreateTime_s) == 2 {
  975. // 定义开始和结束时间
  976. start := time.Date(lib.To_int(CreateTime_s[0]), time.Month(lib.To_int(CreateTime_s[1])), 1, 0, 0, 0, 0, time.UTC)
  977. end := start.AddDate(0, 1, 0) // 下个月的第一天
  978. logs.Println("CreateTime_s:", start.Format("2006-01-02 15:04:05"), end.Format("2006-01-02 15:04:05"))
  979. cond1 = cond1.And("CreateTime__gte", start).And("CreateTime__lt", end)
  980. }
  981. }
  982. if page_z == 9999 {
  983. qs.SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  984. } else {
  985. qs.Limit(page_z, offset).SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  986. }
  987. cnt, _ := qs.SetCond((*orm2.Condition)(cond1)).Count()
  988. // 转换
  989. var TaskList []Task_Stat
  990. for _, v := range r {
  991. TaskList = append(TaskList, TaskToTask_Stat(v, userMap, adminMap))
  992. }
  993. return TaskList, int(cnt)
  994. }
  995. // 获取用户任务列表
  996. func Read_UserTask_StatisticalRanking(T_uuid, T_scheme string) []Task {
  997. o := orm.NewOrm()
  998. qs := o.QueryTable(new(Task))
  999. var r []Task
  1000. cond := orm.NewCondition()
  1001. //cond_T_uuid := orm.NewCondition().Or("T_scheme", T_uuid).Or("T_collection", T_uuid).Or("T_reporting", T_uuid)
  1002. //cond1 := cond.And("T_name__icontains", T_name).And("T_State", 1)
  1003. cond1 := cond.And("T_State", 1).And(T_scheme, T_uuid)
  1004. qs.Limit(500, 0).SetCond((*orm2.Condition)(cond1)).OrderBy("-UpdateTime").All(&r)
  1005. qs.SetCond((*orm2.Condition)(cond1)).Count()
  1006. return r
  1007. }
  1008. // 获取任务列表
  1009. func Read_Task_List_For_ERP(T_reporting_pass_time string) ([]Task_, int) {
  1010. o := orm.NewOrm()
  1011. qs := o.QueryTable(new(Task))
  1012. var r []Task
  1013. cond := orm.NewCondition()
  1014. cond1 := cond.And("T_State", 1).And("T_reporting_state", TaskReportingStatePass)
  1015. if len(T_reporting_pass_time) > 0 {
  1016. start := T_reporting_pass_time + " 00:00:00"
  1017. end := T_reporting_pass_time + " 23:59:59"
  1018. log.Println("CreateTime_s:", start, end)
  1019. cond1 = cond1.And("T_reporting_pass_time__gte", start).And("T_reporting_pass_time__lte", end)
  1020. }
  1021. qs.SetCond((*orm2.Condition)(cond1)).OrderBy("-Id").All(&r)
  1022. cnt, _ := qs.SetCond((*orm2.Condition)(cond1)).Count()
  1023. // 转换
  1024. var TaskList []Task_
  1025. for _, v := range r {
  1026. TaskList = append(TaskList, TaskToTask_(v, map[string]string{}, map[string]string{}))
  1027. }
  1028. return TaskList, int(cnt)
  1029. }
  1030. // GenerateNextT_report_number 生成下一个编号
  1031. func GenerateNextT_report_number(T_device_type string) (string, error) {
  1032. o := orm.NewOrm()
  1033. // 获取当前年份和季度
  1034. currentYear := time.Now().Year()
  1035. currentQuarter := int(time.Now().Month()-1)/3 + 1 // 1,2,3,4 对应 A,B,C,D
  1036. quarterChar := string(rune('A' + currentQuarter - 1))
  1037. yearQuarter := fmt.Sprintf("%s%d%s", T_device_type, currentYear, quarterChar)
  1038. var lastRecord Task
  1039. err := o.QueryTable(new(Task)).
  1040. Filter("T_report_number__startswith", yearQuarter).
  1041. OrderBy("-T_report_number").
  1042. Limit(1).
  1043. One(&lastRecord)
  1044. if err != nil && err.Error() != orm.ErrNoRows.Error() {
  1045. return "", fmt.Errorf("报告编号-查询当前年季度最后编号失败: %v", err)
  1046. }
  1047. // 初始化新编号
  1048. var newSeq = 1
  1049. if lastRecord.T_report_number != "" {
  1050. // 提取序号部分,例如 "2025A00001" -> "00001"
  1051. lastSeqStr := lastRecord.T_report_number[len(lastRecord.T_report_number)-5:]
  1052. lastSeq, _ := strconv.Atoi(lastSeqStr)
  1053. newSeq = lastSeq + 1
  1054. }
  1055. var newCode string
  1056. for {
  1057. // 格式化新编号
  1058. newCode = fmt.Sprintf("%s%05d", yearQuarter, newSeq)
  1059. if Redis_Task_T_report_number_Get(newCode) {
  1060. newSeq += 1
  1061. } else {
  1062. err = Redis_Task_T_report_number_Set(newCode)
  1063. if err != nil {
  1064. return "", fmt.Errorf("报告编号-存入redis失败: %v", err)
  1065. }
  1066. break
  1067. }
  1068. }
  1069. return newCode, nil
  1070. }
  1071. // 获取 By
  1072. func Read_TaskbyT_report_number(T_report_number string) (r Task, is bool) {
  1073. o := orm.NewOrm()
  1074. qs := o.QueryTable(new(Task))
  1075. //err := qs.Filter("T_task_id", T_task_id).Filter("T_State", 1).One(&r)
  1076. err := qs.Filter("T_report_number", T_report_number).Filter("T_State", 1).One(&r)
  1077. if err != nil {
  1078. return r, false
  1079. }
  1080. return r, true
  1081. }