IOTNetworkCard.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  1. package controllers
  2. import (
  3. "ERP_storage/Nats/NatsServer"
  4. "ERP_storage/conf"
  5. "ERP_storage/logs"
  6. "ERP_storage/models/Account"
  7. "ERP_storage/models/IOTNetworkCard"
  8. "encoding/json"
  9. "github.com/beego/beego/v2/adapter/orm"
  10. beego "github.com/beego/beego/v2/server/web"
  11. "github.com/xuri/excelize/v2"
  12. userlibs "gogs.baozhida.cn/zoie/ERP_libs/User"
  13. "gogs.baozhida.cn/zoie/ERP_libs/lib"
  14. "math"
  15. "strconv"
  16. "time"
  17. )
  18. type IOTNetworkCardController struct {
  19. beego.Controller
  20. User userlibs.User
  21. }
  22. func (c *IOTNetworkCardController) Prepare() {
  23. c.User = *Account.User_r
  24. }
  25. // 财务管理列表
  26. func (c *IOTNetworkCardController) IOTNetworkCard_List() {
  27. // 分页参数 初始化
  28. page, _ := c.GetInt("page")
  29. if page < 1 {
  30. page = 1
  31. }
  32. page_z, _ := c.GetInt("page_z")
  33. if page_z < 1 {
  34. page_z = conf.Page_size
  35. }
  36. // 查询
  37. T_name := c.GetString("T_name")
  38. T_company_name := c.GetString("T_company_name")
  39. T_state, _ := c.GetInt("T_state")
  40. userList, _ := NatsServer.Read_User_List_All()
  41. Account.Read_User_All_Map(userList)
  42. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(orm.NewOrm())
  43. R_List, R_cnt := IOTNetworkCardDao.Read_IOTNetworkCard_List(T_name, T_company_name, T_state, page, page_z)
  44. var r_jsons lib.R_JSONS
  45. r_jsons.Num = R_cnt
  46. r_jsons.Data = R_List
  47. r_jsons.Page = page
  48. r_jsons.Page_size = int(math.Ceil(float64(R_cnt) / float64(page_z)))
  49. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  50. c.ServeJSON()
  51. return
  52. }
  53. func (c *IOTNetworkCardController) IOTNetworkCard_Get() {
  54. // 查询
  55. T_id, _ := c.GetInt("T_id")
  56. IOTNetworkCard_r, err := IOTNetworkCard.Read_IOTNetworkCard_ById(T_id)
  57. if err != nil {
  58. c.Data["json"] = lib.JSONS{Code: 203, Msg: "T_id Err!"}
  59. c.ServeJSON()
  60. return
  61. }
  62. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: IOTNetworkCard.IOTNetworkCardToIOTNetworkCard_R(IOTNetworkCard_r)}
  63. c.ServeJSON()
  64. return
  65. }
  66. func (c *IOTNetworkCardController) IOTNetworkCard_Add() {
  67. T_company_name := c.GetString("T_company_name")
  68. T_in_date := c.GetString("T_in_date")
  69. T_meal_type := c.GetString("T_meal_type")
  70. T_meal := c.GetString("T_meal")
  71. T_expire := c.GetString("T_expire")
  72. T_iccid := c.GetString("T_iccid")
  73. T_MSISDN := c.GetString("T_MSISDN")
  74. T_remark := c.GetString("T_remark")
  75. T_State, _ := c.GetInt("T_State")
  76. var_ := IOTNetworkCard.IOTNetworkCard{
  77. T_company_name: T_company_name,
  78. T_in_date: T_in_date,
  79. T_meal_type: T_meal_type,
  80. T_meal: T_meal,
  81. T_expire: T_expire,
  82. T_iccid: T_iccid,
  83. T_MSISDN: T_MSISDN,
  84. T_State: T_State,
  85. T_remark: T_remark,
  86. }
  87. // 添加入库记录
  88. var record []IOTNetworkCard.IOTNetworkCardRecord
  89. record = append(record, IOTNetworkCard.IOTNetworkCardRecord{
  90. T_data: time.Now().Format("2006-01-02"),
  91. T_State: T_State,
  92. })
  93. recordB, _ := json.Marshal(&record)
  94. var_.T_record = string(recordB)
  95. card, err := IOTNetworkCard.Read_IOTNetworkCard_ByT_MSISDN(T_MSISDN)
  96. if err != nil && err.Error() != orm.ErrNoRows.Error() {
  97. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败"}
  98. c.ServeJSON()
  99. return
  100. }
  101. if card.Id > 0 {
  102. c.Data["json"] = lib.JSONS{Code: 202, Msg: "此卡已入库"}
  103. c.ServeJSON()
  104. return
  105. }
  106. o := orm.NewOrm()
  107. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(o)
  108. Id, err := IOTNetworkCardDao.Add_IOTNetworkCard(var_)
  109. if err != nil {
  110. c.Data["json"] = lib.JSONS{Code: 203, Msg: "添加失败"}
  111. c.ServeJSON()
  112. return
  113. }
  114. NatsServer.AddUserLogs(c.User.T_uuid, "物联网卡", "添加", var_)
  115. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
  116. c.ServeJSON()
  117. return
  118. }
  119. func (c *IOTNetworkCardController) IOTNetworkCard_Edit() {
  120. T_id, _ := c.GetInt("T_id")
  121. T_in_date := c.GetString("T_in_date")
  122. T_company_name := c.GetString("T_company_name")
  123. T_meal_type := c.GetString("T_meal_type")
  124. T_meal := c.GetString("T_meal")
  125. T_expire := c.GetString("T_expire")
  126. T_iccid := c.GetString("T_iccid")
  127. T_MSISDN := c.GetString("T_MSISDN")
  128. T_out_date := c.GetString("T_out_date") // 出库日期
  129. T_out_project := c.GetString("T_out_project") // 出库项目
  130. T_receive := c.GetString("T_receive") // 领用人
  131. T_State, _ := c.GetInt("T_State") // 状态
  132. T_remark := c.GetString("T_remark") // 状态
  133. IOTNetworkCard_r, err := IOTNetworkCard.Read_IOTNetworkCard_ById(T_id)
  134. if err != nil {
  135. c.Data["json"] = lib.JSONS{Code: 203, Msg: "T_id Err!"}
  136. c.ServeJSON()
  137. return
  138. }
  139. if len(T_in_date) > 0 {
  140. IOTNetworkCard_r.T_in_date = T_in_date
  141. }
  142. if len(T_company_name) > 0 {
  143. IOTNetworkCard_r.T_company_name = T_company_name
  144. }
  145. if len(T_meal_type) > 0 {
  146. IOTNetworkCard_r.T_meal_type = T_meal_type
  147. }
  148. if len(T_meal) > 0 {
  149. IOTNetworkCard_r.T_meal = T_meal
  150. }
  151. if len(T_expire) > 0 {
  152. IOTNetworkCard_r.T_expire = T_expire
  153. }
  154. if len(T_iccid) > 0 {
  155. IOTNetworkCard_r.T_iccid = T_iccid
  156. }
  157. if len(T_MSISDN) > 0 {
  158. IOTNetworkCard_r.T_MSISDN = T_MSISDN
  159. }
  160. if len(T_out_date) > 0 {
  161. IOTNetworkCard_r.T_out_date = T_out_date
  162. }
  163. if len(T_out_project) > 0 {
  164. IOTNetworkCard_r.T_out_project = T_out_project
  165. }
  166. if len(T_receive) > 0 {
  167. IOTNetworkCard_r.T_receive = T_receive
  168. }
  169. if len(T_remark) > 0 {
  170. IOTNetworkCard_r.T_remark = T_remark
  171. }
  172. if T_State > 0 && T_State != IOTNetworkCard_r.T_State {
  173. IOTNetworkCard_r.T_State = T_State
  174. // 添加入库记录
  175. var record []IOTNetworkCard.IOTNetworkCardRecord
  176. err = json.Unmarshal([]byte(IOTNetworkCard_r.T_record), &record)
  177. if err != nil {
  178. logs.Error("JSON 反序列化失败:", err)
  179. return
  180. }
  181. record = append(record, IOTNetworkCard.IOTNetworkCardRecord{
  182. T_data: time.Now().Format("2006-01-02"),
  183. T_State: T_State,
  184. T_out_project: T_out_project,
  185. T_remark: T_remark,
  186. })
  187. recordB, _ := json.Marshal(&record)
  188. IOTNetworkCard_r.T_record = string(recordB)
  189. }
  190. if T_State == IOTNetworkCard.IOTNetworkCardReturnIn {
  191. IOTNetworkCard_r.T_out_date = ""
  192. }
  193. o := orm.NewOrm()
  194. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(o)
  195. if err = IOTNetworkCardDao.Update_IOTNetworkCard(IOTNetworkCard_r,
  196. "T_in_date", "T_meal_type", "T_meal", "T_expire", "T_iccid", "T_MSISDN", "T_out_date", "T_out_project", "T_receive", "T_State", "T_record", "T_remark"); err != nil {
  197. c.Data["json"] = lib.JSONS{Code: 203, Msg: "修改失败"}
  198. c.ServeJSON()
  199. return
  200. }
  201. NatsServer.AddUserLogs(c.User.T_uuid, "物联网卡", "修改", IOTNetworkCard_r)
  202. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  203. c.ServeJSON()
  204. return
  205. }
  206. func (c *IOTNetworkCardController) IOTNetworkCard_Del() {
  207. T_id, _ := c.GetInt("T_id")
  208. IOTNetworkCard_r, err := IOTNetworkCard.Read_IOTNetworkCard_ById(T_id)
  209. if err != nil {
  210. c.Data["json"] = lib.JSONS{Code: 203, Msg: "T_id Err!"}
  211. c.ServeJSON()
  212. return
  213. }
  214. o := orm.NewOrm()
  215. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(o)
  216. err = IOTNetworkCardDao.Delete_IOTNetworkCard(IOTNetworkCard_r)
  217. if err != nil {
  218. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  219. c.ServeJSON()
  220. return
  221. }
  222. NatsServer.AddUserLogs(c.User.T_uuid, "物联网卡", "删除", strconv.Itoa(T_id))
  223. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: T_id}
  224. c.ServeJSON()
  225. return
  226. }
  227. // 导入
  228. func (c *IOTNetworkCardController) IOTNetworkCard_Import() {
  229. // 获取上传的文件
  230. f, _, err := c.GetFile("file")
  231. if err != nil {
  232. c.Data["json"] = lib.JSONS{Code: 1201, Msg: "读取文件失败!", Data: nil}
  233. c.ServeJSON()
  234. return
  235. }
  236. defer f.Close()
  237. // 读取 Excel 文件
  238. reader, err := excelize.OpenReader(f)
  239. if err != nil {
  240. c.Data["json"] = lib.JSONS{Code: 1201, Msg: "打开文件失败!", Data: nil}
  241. c.ServeJSON()
  242. return
  243. }
  244. defer func() {
  245. if err = reader.Close(); err != nil {
  246. c.Data["json"] = lib.JSONS{Code: 1201, Msg: "关闭文件失败!", Data: nil}
  247. c.ServeJSON()
  248. return
  249. }
  250. }()
  251. var IOTNetworkCardList []IOTNetworkCard.IOTNetworkCard
  252. sheetMap := reader.GetSheetMap()
  253. for _, sheetName := range sheetMap {
  254. //读取工作表中的数据
  255. rows, errs := reader.GetRows(sheetName)
  256. if errs != nil {
  257. c.Data["json"] = lib.JSONS{Code: 1201, Msg: "读取工作表失败!", Data: nil}
  258. c.ServeJSON()
  259. return
  260. }
  261. for i, row := range rows {
  262. if i < 2 {
  263. continue // 忽略第一行和第二行
  264. }
  265. if len(row) >= 6 {
  266. // 解析时间
  267. t, errT := time.Parse("01-02-06", row[1])
  268. if errT != nil {
  269. c.Data["json"] = lib.JSONS{Code: 203, Msg: "解析入库时间失败"}
  270. c.ServeJSON()
  271. return
  272. }
  273. T_MSISDN := row[6]
  274. //_, errGet := IOTNetworkCard.Read_IOTNetworkCard_ByT_MSISDN(T_MSISDN)
  275. //if errGet != nil && errGet.Error() != orm.ErrNoRows.Error() {
  276. // continue
  277. //}
  278. var_ := IOTNetworkCard.IOTNetworkCard{
  279. T_in_date: t.Format("2006-01-02"),
  280. T_company_name: row[0],
  281. T_meal_type: row[2],
  282. T_meal: row[3],
  283. T_expire: row[4],
  284. T_iccid: row[5],
  285. T_MSISDN: T_MSISDN,
  286. T_State: IOTNetworkCard.IOTNetworkCardNewCardIn,
  287. }
  288. // 添加入库记录
  289. var record []IOTNetworkCard.IOTNetworkCardRecord
  290. record = append(record, IOTNetworkCard.IOTNetworkCardRecord{
  291. T_data: time.Now().Format("2006-01-02"),
  292. T_State: IOTNetworkCard.IOTNetworkCardNewCardIn,
  293. })
  294. if len(row) >= 8 && len(row[7]) > 0 {
  295. var outTime string
  296. outT, errOutT := time.Parse("01-02-06", row[7])
  297. if errOutT != nil {
  298. c.Data["json"] = lib.JSONS{Code: 203, Msg: "解析出库时间失败"}
  299. c.ServeJSON()
  300. return
  301. }
  302. outTime = outT.Format("2006-01-02")
  303. var_.T_State = IOTNetworkCard.IOTNetworkCardOut
  304. var_.T_out_date = outTime
  305. var_.T_out_project = row[8]
  306. record = append(record, IOTNetworkCard.IOTNetworkCardRecord{
  307. T_data: time.Now().Format("2006-01-02"),
  308. T_State: IOTNetworkCard.IOTNetworkCardOut,
  309. T_out_project: row[8],
  310. })
  311. }
  312. recordB, _ := json.Marshal(&record)
  313. var_.T_record = string(recordB)
  314. IOTNetworkCardList = append(IOTNetworkCardList, var_)
  315. }
  316. }
  317. }
  318. o := orm.NewOrm()
  319. o.Begin()
  320. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(o)
  321. // 定义批次大小
  322. batchSize := 1000
  323. total := len(IOTNetworkCardList)
  324. for i := 0; i < total; i += batchSize {
  325. end := i + batchSize
  326. if end > total {
  327. end = total
  328. }
  329. batch := IOTNetworkCardList[i:end]
  330. // 执行数据库批量插入
  331. if _, err := IOTNetworkCardDao.Add_IOTNetworkCardMulti(batch); err != nil {
  332. o.Rollback()
  333. c.Data["json"] = lib.JSONS{Code: 203, Msg: "导入失败"}
  334. c.ServeJSON()
  335. return // 中断处理流程
  336. }
  337. }
  338. o.Commit()
  339. // 去重 保留最小值
  340. IOTNetworkCardDao.DeleteDeduplicate()
  341. c.Data["json"] = lib.JSONS{Code: 200, Msg: "成功!", Data: nil}
  342. c.ServeJSON()
  343. }
  344. // 修改移动端设备编号
  345. func (c *IOTNetworkCardController) IOTNetworkCard_Edit_Device_Number() {
  346. T_id, _ := c.GetInt("T_id")
  347. T_device_number := c.GetString("T_device_number")
  348. IOTNetworkCard_r, err := IOTNetworkCard.Read_IOTNetworkCard_ById(T_id)
  349. if err != nil {
  350. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  351. c.ServeJSON()
  352. return
  353. }
  354. IOTNetworkCard_r.T_device_number = T_device_number
  355. o := orm.NewOrm()
  356. IOTNetworkCardDao := IOTNetworkCard.NewIOTNetworkCard(o)
  357. if err = IOTNetworkCardDao.Update_IOTNetworkCard(IOTNetworkCard_r, "T_device_number"); err != nil {
  358. c.Data["json"] = lib.JSONS{Code: 203, Msg: "修改失败"}
  359. c.ServeJSON()
  360. return
  361. }
  362. NatsServer.AddUserLogs(c.User.T_uuid, "物联网卡", "修改移动端设备编号", IOTNetworkCard_r)
  363. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  364. c.ServeJSON()
  365. return
  366. }