Task.go 42 KB

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