Task.go 53 KB

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