Device.go 71 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666
  1. package controllers
  2. import (
  3. "Cold_Api/Nats/NatsServer"
  4. "Cold_Api/conf"
  5. "Cold_Api/controllers/lib"
  6. "Cold_Api/models/Account"
  7. "Cold_Api/models/Company"
  8. "Cold_Api/models/Device"
  9. "Cold_Api/models/System"
  10. "Cold_Api/models/Warning"
  11. "fmt"
  12. "math"
  13. "os"
  14. "strconv"
  15. "strings"
  16. "time"
  17. "github.com/beego/beego/v2/core/logs"
  18. beego "github.com/beego/beego/v2/server/web"
  19. "github.com/shopspring/decimal"
  20. "github.com/xuri/excelize/v2"
  21. )
  22. // Handle
  23. type DeviceController struct {
  24. beego.Controller
  25. Admin_r *Account.Admin // 登陆的用户
  26. T_pid int // 公司id
  27. }
  28. func (c *DeviceController) Prepare() {
  29. GetCookie := c.Ctx.GetCookie("User_tokey")
  30. GetString := c.GetString("User_tokey")
  31. User_tokey := GetString
  32. if len(User_tokey) == 0 {
  33. User_tokey = GetCookie
  34. }
  35. if Account.Admin_r == nil {
  36. return
  37. }
  38. c.Admin_r = Account.Admin_r
  39. T_pid := c.Admin_r.T_pid
  40. EntryPid, _ := Account.Redis_Tokey_T_pid_Get(User_tokey)
  41. if EntryPid > 0 {
  42. T_pid = EntryPid
  43. }
  44. c.T_pid = T_pid
  45. }
  46. // 设备 ------------------------------------------
  47. func (c *DeviceController) Device_List() {
  48. type R_JSONS struct {
  49. //必须的大写开头
  50. Device_lite []Device.Device_R
  51. Num int64
  52. Page int
  53. Page_size int
  54. }
  55. var r_jsons R_JSONS
  56. page, _ := c.GetInt("page")
  57. if page < 1 {
  58. page = 1
  59. }
  60. page_z, _ := c.GetInt("page_z")
  61. if page_z < 1 {
  62. page_z = conf.Page_size
  63. }
  64. Name := c.GetString("T_name")
  65. T_abandon, _ := c.GetInt("T_abandon")
  66. T_online := c.GetString("T_online")
  67. T_monitor := c.GetString("T_monitor")
  68. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  69. if err != nil {
  70. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  71. c.ServeJSON()
  72. return
  73. }
  74. r_jsons.Device_lite, r_jsons.Num = Device.Read_Device_List(c.Admin_r, bindSN, c.T_pid, Name, T_monitor, T_online, T_abandon, page, page_z)
  75. r_jsons.Page = page
  76. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  77. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  78. c.ServeJSON()
  79. return
  80. }
  81. func (c *DeviceController) Device_Get() {
  82. var r_jsons lib.R_JSONS
  83. T_sn := c.GetString("T_sn")
  84. Device_r, err := Device.Read_Device_ByT_sn(T_sn)
  85. if err != nil {
  86. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  87. c.ServeJSON()
  88. return
  89. }
  90. if Device_r.T_pid != c.T_pid {
  91. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权查看!"}
  92. c.ServeJSON()
  93. return
  94. }
  95. r_jsons.Data = Device.DeviceToDevice_R(Device_r)
  96. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  97. c.ServeJSON()
  98. return
  99. }
  100. func (c *DeviceController) Device_Add() {
  101. var err error
  102. T_sn := c.GetString("T_sn")
  103. var_ := Device.Device{
  104. T_pid: c.T_pid,
  105. T_sn: T_sn,
  106. T_protocol: 3,
  107. T_monitor: 0, // 监控状态 已监控
  108. T_State: 1, // 状态 正常
  109. T_ist: 1, // 温度 1开启
  110. T_ish: 1, // 湿度 1开启
  111. }
  112. if len(T_sn) < 8 {
  113. c.Data["json"] = lib.JSONS{Code: 202, Msg: "SN 太短 必须8个字符以上"}
  114. c.ServeJSON()
  115. return
  116. }
  117. _, err = Device.Read_Device_ByT_sn(T_sn)
  118. if err == nil {
  119. c.Data["json"] = lib.JSONS{Code: 202, Msg: "重复SN!"}
  120. c.ServeJSON()
  121. return
  122. }
  123. var_.T_devName = T_sn
  124. // 创建数据库
  125. if !Device.CREATE_DeviceData(T_sn) {
  126. c.Data["json"] = lib.JSONS{Code: 302, Msg: "添加失败!"}
  127. c.ServeJSON()
  128. return
  129. }
  130. err = Device.Add_Device(var_)
  131. if err != nil {
  132. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  133. c.ServeJSON()
  134. return
  135. }
  136. // 添加设备后自动重启
  137. MqttIds := strings.Split(conf.MqttIds, ",")
  138. for _, id := range MqttIds {
  139. NatsServer.Set_RestartShutdown(Device.Device_task{
  140. T_sn: T_sn,
  141. T_task: "1",
  142. }, id)
  143. }
  144. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "设备添加", var_)
  145. NatsServer.Read_DeviceParameter(T_sn, "") // 获取主机信息
  146. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  147. c.ServeJSON()
  148. return
  149. }
  150. func (c *DeviceController) Device_Edit() {
  151. T_SN := c.GetString("T_sn")
  152. Device_r, err := Device.Read_Device_ByT_sn(T_SN)
  153. if err != nil {
  154. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  155. c.ServeJSON()
  156. return
  157. }
  158. clos := make([]string, 0)
  159. // 监控状态 0 未监控 1 监控
  160. T_monitor, T_monitor_err := c.GetInt("T_monitor")
  161. if T_monitor_err == nil {
  162. Device_r.T_monitor = T_monitor
  163. clos = append(clos, "T_monitor")
  164. }
  165. // 温度显示
  166. T_ist, T_ist_err := c.GetInt("T_ist")
  167. if T_ist_err == nil {
  168. Device_r.T_ist = T_ist
  169. clos = append(clos, "T_ist")
  170. }
  171. // 适度显示
  172. T_ish, T_ish_err := c.GetInt("T_ish")
  173. if T_ish_err == nil {
  174. Device_r.T_ish = T_ish
  175. clos = append(clos, "T_ish")
  176. }
  177. // 是否弃用
  178. T_State, T_State_err := c.GetInt("T_State")
  179. if T_State_err == nil {
  180. Device_r.T_State = T_State
  181. if T_State == 0 {
  182. Device_r.T_abandonTime = time.Now()
  183. clos = append(clos, "T_abandonTime")
  184. }
  185. clos = append(clos, "T_State")
  186. }
  187. // 验证时间
  188. T_VerifyTime := c.GetString("T_VerifyTime")
  189. VerifyTime, VerifyTime_is := lib.TimeStrToTime(T_VerifyTime)
  190. if VerifyTime_is {
  191. Device_r.T_VerifyTime = VerifyTime
  192. clos = append(clos, "T_VerifyTime")
  193. }
  194. // 验证到期时间
  195. T_Verify_End_Time := c.GetString("T_VerifyEndTime")
  196. Verify_End_Time, Verify_End_Time_is := lib.TimeStrToTime(T_Verify_End_Time)
  197. if Verify_End_Time_is {
  198. Device_r.T_VerifyEndTime = Verify_End_Time
  199. clos = append(clos, "T_VerifyEndTime")
  200. }
  201. // 校准到期时间
  202. T_Calibration_End_Time := c.GetString("T_CalibrationEndTime")
  203. Calibration_End_Time, Calibration_End_Time_is := lib.TimeStrToTime(T_Calibration_End_Time)
  204. if Calibration_End_Time_is {
  205. Device_r.T_CalibrationEndTime = Calibration_End_Time
  206. clos = append(clos, "T_CalibrationEndTime")
  207. }
  208. // 校准时间
  209. T_CalibrationTime := c.GetString("T_CalibrationTime")
  210. CalibrationTime, CalibrationTime_is := lib.TimeStrToTime(T_CalibrationTime)
  211. if CalibrationTime_is {
  212. Device_r.T_CalibrationTime = CalibrationTime
  213. clos = append(clos, "T_CalibrationTime")
  214. // 同步冷链验证校准开始时间
  215. NatsServer.Update_Task_BySN(T_SN, CalibrationTime)
  216. }
  217. // 巡检时间
  218. T_PatrolTime := c.GetString("T_PatrolTime")
  219. PatrolTime, PatrolTime_is := lib.TimeStrToTime(T_PatrolTime)
  220. if PatrolTime_is {
  221. Device_r.T_PatrolTime = PatrolTime
  222. clos = append(clos, "T_PatrolTime")
  223. }
  224. //金卫信数据对接
  225. SensorIdNo := c.GetString("sensorIdNo")
  226. if len(SensorIdNo) > 0 {
  227. Device_r.SensorIdNo = SensorIdNo
  228. clos = append(clos, "sensor_id_no")
  229. }
  230. IdNo := c.GetString("idNo")
  231. if len(IdNo) > 0 {
  232. Device_r.IdNo = IdNo
  233. clos = append(clos, "id_no")
  234. }
  235. DepaCode := c.GetString("depaCode")
  236. if len(DepaCode) > 0 {
  237. Device_r.DepaCode = DepaCode
  238. clos = append(clos, "depa_code")
  239. }
  240. DepaName := c.GetString("depaName")
  241. if len(DepaName) > 0 {
  242. Device_r.DepaName = DepaName
  243. clos = append(clos, "depa_name")
  244. }
  245. sensorName := c.GetString("sensorName")
  246. if len(sensorName) > 0 {
  247. Device_r.SensorName = sensorName
  248. clos = append(clos, "sensor_name")
  249. }
  250. if is := Device.Update_Device(Device_r, clos...); !is {
  251. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  252. c.ServeJSON()
  253. return
  254. }
  255. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "修改", Device_r)
  256. if is := Device.Update_Device_To_DeviceSensor(Device_r); is {
  257. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器修改", Device_r)
  258. }
  259. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  260. c.ServeJSON()
  261. return
  262. }
  263. func (c *DeviceController) Device_Applet_Get() {
  264. T_snid := c.GetString("T_snid")
  265. sn_id := strings.Split(strings.Trim(T_snid, "|"), ",")
  266. if len(sn_id) != 2 {
  267. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_snid err!"}
  268. c.ServeJSON()
  269. return
  270. }
  271. T_sn, T_id := sn_id[0], lib.To_int(sn_id[1])
  272. Device_r, err := Device.Read_Device_ByT_sn(T_sn)
  273. if err != nil {
  274. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  275. c.ServeJSON()
  276. return
  277. }
  278. //if Device_r.T_pid != c.T_pid {
  279. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权查看!"}
  280. // c.ServeJSON()
  281. // return
  282. //}
  283. Dsp, _ := Device.Read_DeviceSensorParameter(T_sn, T_id)
  284. DeviceData := Device.Read_DeviceData(T_sn, T_id)
  285. type JSONS struct {
  286. T_name string // 设备名称
  287. T_monitor int // 监控状态 0 未监控 1 监控 停止记录
  288. T_ist int // 温度 1开启 2关闭
  289. T_ish int // 湿度 1开启 2关闭
  290. T_t float32 // 温度
  291. T_rh float32 // 湿度
  292. T_Tlower float32 // 温度下限
  293. T_Tupper float32 // 温度上限
  294. T_RHlower float32 // 湿度下限
  295. T_RHupper float32 // 湿度上限
  296. }
  297. r_jsons := JSONS{
  298. T_name: Device_r.T_devName,
  299. T_monitor: Device_r.T_monitor,
  300. T_ist: Device_r.T_ist,
  301. T_ish: Device_r.T_ish,
  302. T_t: DeviceData.T_t,
  303. T_rh: DeviceData.T_rh,
  304. T_Tlower: Dsp.T_Tlower,
  305. T_Tupper: Dsp.T_Tupper,
  306. T_RHlower: Dsp.T_RHlower,
  307. T_RHupper: Dsp.T_RHupper,
  308. }
  309. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  310. c.ServeJSON()
  311. return
  312. }
  313. // 重启/关机
  314. func (c *DeviceController) Device_RestartShutdown() {
  315. T_sn := c.GetString("T_sn")
  316. T_task := c.GetString("T_task")
  317. device, err := Device.Read_Device_ByT_sn(T_sn)
  318. if err != nil {
  319. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  320. c.ServeJSON()
  321. return
  322. }
  323. NatsServer.Set_RestartShutdown(Device.Device_task{
  324. T_sn: T_sn,
  325. T_task: T_task,
  326. }, device.T_mqttid)
  327. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "重启/关机", T_sn+"-"+T_task)
  328. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  329. c.ServeJSON()
  330. return
  331. }
  332. // 版本升级
  333. func (c *DeviceController) Device_ProductUpgrade() {
  334. T_sn := c.GetString("T_sn")
  335. T_version := c.GetString("T_version")
  336. T_file := c.GetString("T_file")
  337. device, err := Device.Read_Device_ByT_sn(T_sn)
  338. if err != nil {
  339. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  340. c.ServeJSON()
  341. return
  342. }
  343. NatsServer.Up_ProductUpgrade(T_sn, T_version, T_file, device.T_mqttid)
  344. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "版本升级", T_sn+"-"+T_version+"-"+T_file)
  345. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  346. c.ServeJSON()
  347. return
  348. }
  349. // 2023-02-02 弃用
  350. //func (c *DeviceController) Device_Del() {
  351. // if admin_r.Id != 1 {
  352. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "没有权限!"}
  353. // c.ServeJSON()
  354. // return
  355. // }
  356. //
  357. // T_sn := c.GetString("T_sn")
  358. //
  359. // Device_r, err := Device.Read_Device_ByT_sn(T_sn)
  360. // if err != nil {
  361. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  362. // c.ServeJSON()
  363. // return
  364. // }
  365. //
  366. // Device.Delete_Device(Device_r)
  367. // DeviceSensor_list, _ := Device.Read_DeviceSensor_ByTsn(Device_r.T_sn)
  368. // for _, v := range DeviceSensor_list {
  369. // Device.Delete_DeviceSensor_ById(Device_r.T_sn, v.T_id)
  370. // }
  371. // Device.DELETE_DeviceSensor(Device_r.T_sn)
  372. // Device.DELETE_DeviceDatar(Device_r.T_sn)
  373. // Device.DELETE_DeviceParameter(Device_r.T_sn)
  374. // Device.DELETE_DeviceSensorParameter(Device_r.T_sn)
  375. //
  376. // System.Add_UserLogs(admin_r.T_uuid, "设备管理", "设备删除", T_sn)
  377. // c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  378. // c.ServeJSON()
  379. // return
  380. //
  381. //}
  382. // 设备日志
  383. func (c *DeviceController) DeviceLogs() {
  384. type R_JSONS struct {
  385. //必须的大写开头
  386. DeviceLogs []Warning.DeviceLogs
  387. Num int64
  388. Page int
  389. Page_size int
  390. }
  391. var r_jsons R_JSONS
  392. page, _ := c.GetInt("page")
  393. if page < 1 {
  394. page = 1
  395. }
  396. page_z, _ := c.GetInt("page_z")
  397. if page_z < 1 {
  398. page_z = conf.Page_size
  399. }
  400. T_sn := c.GetString("T_sn")
  401. c.Data["T_sn"] = T_sn
  402. r_jsons.DeviceLogs, r_jsons.Num = Warning.Read_DeviceLogs_List(T_sn, page, page_z)
  403. r_jsons.Page = page
  404. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  405. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  406. c.ServeJSON()
  407. }
  408. // 设备参数 ------------------------------------------
  409. // 设备参数列表
  410. func (c *DeviceController) Device_Parameter_List() {
  411. Sn := c.GetString("T_sn")
  412. page, _ := c.GetInt("page")
  413. if page < 1 {
  414. page = 1
  415. }
  416. page_z, _ := c.GetInt("page_z")
  417. if page_z < 1 {
  418. page_z = conf.Page_size
  419. }
  420. DeviceParameter_lite := Device.Read_DeviceParameter_SN_List(Sn, page, page_z)
  421. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceParameter_lite}
  422. c.ServeJSON()
  423. return
  424. }
  425. // 获取设备参数
  426. func (c *DeviceController) Device_Parameter_Get() {
  427. Sn := c.GetString("T_sn")
  428. device, err := Device.Read_Device_ByT_sn(Sn)
  429. if err != nil {
  430. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  431. c.ServeJSON()
  432. return
  433. }
  434. DeviceParameter_lite := Device.Read_DeviceParameter_SN(Sn)
  435. if len(DeviceParameter_lite) == 0 {
  436. NatsServer.Read_DeviceParameter(Sn, device.T_mqttid)
  437. c.Data["json"] = lib.JSONS{Code: 202, Msg: "未同步参数,请检查设备是否正常!"}
  438. c.ServeJSON()
  439. return
  440. }
  441. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceParameter_lite}
  442. c.ServeJSON()
  443. return
  444. }
  445. // 修改设备参数
  446. func (c *DeviceController) Device_Parameter_Pu() {
  447. //T_SN := c.GetString("T_sn")
  448. //T_name := c.GetString("T_name")
  449. //
  450. //T_saveT, _ := c.GetInt("T_saveT")
  451. //T_overA, _ := c.GetInt("T_overA")
  452. //T_outA, _ := c.GetInt("T_outA")
  453. //T_lostA, _ := c.GetInt("T_lostA")
  454. //T_bat, _ := c.GetInt("T_bat")
  455. //
  456. //T_warn, _ := c.GetInt("T_warn")
  457. //T_warnD, _ := c.GetInt("T_warnD")
  458. //
  459. //T_btname := c.GetString("T_btname")
  460. //T_btsid, _ := c.GetInt("T_btsid")
  461. //T_btchar, _ := c.GetInt("T_btchar")
  462. //
  463. //T_Msid, _ := c.GetInt("T_Msid")
  464. //T_State, _ := c.GetInt("T_State")
  465. //
  466. //Device_r, err := Device.Read_Device_ByT_sn(T_SN)
  467. //if err != nil {
  468. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  469. // c.ServeJSON()
  470. // return
  471. //}
  472. //
  473. //Deviceparameter := Device.DeviceParameter{
  474. // T_sn: T_SN,
  475. // T_name: T_name,
  476. // T_saveT: T_saveT,
  477. // T_overA: T_overA,
  478. // T_outA: T_outA,
  479. // T_lostA: T_lostA,
  480. // T_bat: T_bat,
  481. // T_warn: T_warn,
  482. // T_warnD: T_warnD,
  483. // T_btname: T_btname,
  484. // T_btsid: T_btsid,
  485. // T_btchar: T_btchar,
  486. // T_Msid: int64(T_Msid),
  487. // T_uuid: c.Admin_r.T_uuid,
  488. // T_SendState: 0,
  489. // T_State: T_State,
  490. //}
  491. //Deviceparameter, is := Device.Add_DeviceParameter(Deviceparameter)
  492. //if !is {
  493. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "Add_DeviceParameter ERR"}
  494. // c.ServeJSON()
  495. // return
  496. //}
  497. //System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "设备参数操作", Deviceparameter)
  498. //NatsServer.Pu_DeviceParameter(Deviceparameter)
  499. //
  500. //// 更新名称
  501. //Device_r.T_devName = Deviceparameter.T_name
  502. //Device.Update_Device(Device_r, "T_devName")
  503. //System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "修改", Device_r)
  504. T_SN := c.GetString("T_sn")
  505. Device_r, err := Device.Read_Device_ByT_sn(T_SN)
  506. if err != nil {
  507. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  508. c.ServeJSON()
  509. return
  510. }
  511. DeviceParameter_lite := Device.Read_DeviceParameter_SN(T_SN)
  512. if len(DeviceParameter_lite) == 0 {
  513. c.Data["json"] = lib.JSONS{Code: 202, Msg: "未同步参数,请检查设备是否正常!"}
  514. c.ServeJSON()
  515. return
  516. }
  517. DeviceParameter := DeviceParameter_lite[0]
  518. if v, err := c.GetInt("T_saveT"); err == nil {
  519. DeviceParameter.T_saveT = v
  520. }
  521. if v, err := c.GetInt("T_overA"); err == nil {
  522. DeviceParameter.T_overA = v
  523. }
  524. if v, err := c.GetInt("T_outA"); err == nil {
  525. DeviceParameter.T_outA = v
  526. }
  527. if v, err := c.GetInt("T_lostA"); err == nil {
  528. DeviceParameter.T_lostA = v
  529. }
  530. if v, err := c.GetInt("T_bat"); err == nil {
  531. DeviceParameter.T_bat = v
  532. }
  533. if v, err := c.GetInt("T_warn"); err == nil {
  534. DeviceParameter.T_warn = v
  535. }
  536. if v, err := c.GetInt("T_warnD"); err == nil {
  537. DeviceParameter.T_warnD = v
  538. }
  539. if v, err := c.GetInt("T_scan"); err == nil {
  540. DeviceParameter.T_scan = v
  541. }
  542. if v, err := c.GetInt("T_dormancy"); err == nil {
  543. DeviceParameter.T_dormancy = v
  544. }
  545. if v, err := c.GetInt("T_snum"); err == nil {
  546. DeviceParameter.T_snum = v
  547. }
  548. if v, err := c.GetInt("T_alarm"); err == nil {
  549. DeviceParameter.T_alarm = v
  550. }
  551. if v := c.GetString("T_btname"); len(v) > 0 {
  552. DeviceParameter.T_btname = v
  553. }
  554. if v, err := c.GetInt("T_btsid"); err == nil {
  555. DeviceParameter.T_btsid = v
  556. }
  557. if v, err := c.GetInt("T_btchar"); err == nil {
  558. DeviceParameter.T_btchar = v
  559. }
  560. if v, err := c.GetInt("T_Msid"); err == nil {
  561. DeviceParameter.T_Msid = int64(v)
  562. }
  563. if v := c.GetString("T_name"); len(v) > 0 {
  564. DeviceParameter.T_name = v
  565. }
  566. DeviceParameter.Id = 0
  567. DeviceParameter.T_State = 2
  568. DeviceParameter.T_uuid = c.Admin_r.T_uuid
  569. DeviceParameter.T_SendState = 0
  570. DeviceParameter.CreateTime = time.Now()
  571. DeviceParameter.UpdateTime = time.Now()
  572. Deviceparameter, is := Device.Add_DeviceParameter(DeviceParameter)
  573. if !is {
  574. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Add_DeviceParameter ERR"}
  575. c.ServeJSON()
  576. return
  577. }
  578. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "设备参数操作", Deviceparameter)
  579. NatsServer.Pu_DeviceParameter(Deviceparameter, Device_r.T_mqttid)
  580. if v := c.GetString("T_name"); len(v) > 0 {
  581. // 更新名称
  582. Device_r.T_devName = Deviceparameter.T_name
  583. Device.Update_Device(Device_r, "T_devName")
  584. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "修改设备名称", Device_r)
  585. }
  586. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  587. c.ServeJSON()
  588. return
  589. }
  590. // 设备参数同步
  591. func (c *DeviceController) Device_Parameter_Sync() {
  592. T_SN := c.GetString("T_sn")
  593. Device_r, err := Device.Read_Device_ByT_sn(T_SN)
  594. if err != nil {
  595. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  596. c.ServeJSON()
  597. return
  598. }
  599. go func() {
  600. NatsServer.Read_DeviceParameter(T_SN, Device_r.T_mqttid)
  601. time.Sleep(5 * time.Second)
  602. NatsServer.Read_DeviceSensorParameter(T_SN, Device_r.T_mqttid)
  603. }()
  604. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  605. c.ServeJSON()
  606. return
  607. }
  608. // 删除设备 传感器
  609. // 2023-02-02 弃用
  610. func (c *DeviceController) Device_Parameter_Del_Device() {
  611. Sn := c.GetString("Sn")
  612. Id, _ := c.GetInt("Id")
  613. device, err := Device.Read_Device_ByT_sn(Sn)
  614. if err != nil {
  615. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  616. c.ServeJSON()
  617. return
  618. }
  619. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 删除操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]")
  620. //c.Data["Device_lite"] = Device.Read_DeviceParameter_SN(Sn)
  621. Device.Delete_DeviceSensor_ById(Sn, Id)
  622. NatsServer.Del_DeviceSensor(Device.DeviceSensor_Del{
  623. T_sn: Sn, T_id: Id,
  624. }, device.T_mqttid)
  625. c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK"}
  626. c.ServeJSON()
  627. return
  628. }
  629. // 设备-传感器 ------------------------------------------
  630. // 传感器列表
  631. func (c *DeviceController) DeviceSensor_List() {
  632. type R_JSONS struct {
  633. //必须的大写开头
  634. Data []Device.DeviceSensor_R
  635. Num int64
  636. Page int
  637. Page_size int
  638. }
  639. var r_jsons R_JSONS
  640. page, _ := c.GetInt("page")
  641. if page < 1 {
  642. page = 1
  643. }
  644. page_z, _ := c.GetInt("page_z")
  645. if page_z < 1 {
  646. page_z = conf.Page_size
  647. }
  648. T_sn := c.GetString("T_sn")
  649. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  650. T_class_id, _ := c.GetInt("T_calssid")
  651. T_type := c.GetString("T_type")
  652. T_State, T_State_err := c.GetInt("T_state")
  653. if T_State_err != nil {
  654. T_State = -1
  655. }
  656. T_datashow, T_datashow_err := c.GetInt("T_datashow") //0 屏蔽数据展示 1 正常数据展示
  657. if T_datashow_err != nil {
  658. T_datashow = -1
  659. }
  660. if T_class_id > 0 {
  661. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  662. if err != nil {
  663. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  664. c.ServeJSON()
  665. return
  666. }
  667. if R_DeviceClass.T_pid != c.T_pid {
  668. c.Data["json"] = lib.JSONS{Code: 202, Msg: "R_DeviceClass.T_pid != T_pid Err!"}
  669. c.ServeJSON()
  670. return
  671. }
  672. }
  673. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  674. if err != nil {
  675. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  676. c.ServeJSON()
  677. return
  678. }
  679. r_jsons.Data, r_jsons.Num = Device.Read_DeviceSensorList(c.Admin_r, bindSN, c.T_pid, T_sn, T_name, T_class_id, T_datashow, T_type, T_State, page, page_z)
  680. r_jsons.Page = page
  681. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  682. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  683. c.ServeJSON()
  684. return
  685. }
  686. // 修改传感器
  687. func (c *DeviceController) DeviceSensor_Edit() {
  688. Sn := c.GetString("T_sn")
  689. Id, _ := c.GetInt("T_id")
  690. DeviceSensor, is := Device.Read_DeviceSensor_ByT_sn(Sn, Id)
  691. if !is {
  692. c.Data["json"] = lib.JSONS{Code: 202, Msg: "信息错误!"}
  693. c.ServeJSON()
  694. return
  695. }
  696. // 数据视图3D视图订阅
  697. if v, err := c.GetInt("T_type"); err == nil {
  698. if v == 0 {
  699. c.Data["json"] = lib.JSONS{Code: 202, Msg: "类型不能为默认!"}
  700. c.ServeJSON()
  701. return
  702. }
  703. DeviceSensor.T_type = v
  704. Device.Update_DeviceSensor(DeviceSensor, "T_type")
  705. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 类型", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+strconv.Itoa(v))
  706. }
  707. // 实时数据显示排序
  708. if v, err := c.GetInt("T_sort"); err == nil {
  709. DeviceSensor.T_sort = v
  710. Device.Update_DeviceSensor(DeviceSensor, "T_sort")
  711. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 排序操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+strconv.Itoa(v))
  712. }
  713. // 屏蔽数据展示
  714. if v, err := c.GetInt("T_datashow"); err == nil {
  715. DeviceSensor.T_datashow = v
  716. Device.Update_DeviceSensor(DeviceSensor, "T_datashow")
  717. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 数据展示", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+strconv.Itoa(v))
  718. }
  719. // 数据视图3D视图订阅
  720. if v := c.GetString("T_3dview"); len(v) > 0 {
  721. DeviceSensor.T_3dview = v
  722. Device.Update_DeviceSensor(DeviceSensor, "T_3dview")
  723. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 3D视图订阅", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+v)
  724. }
  725. // 数据视图3D视图订阅
  726. if v := c.GetString("T_number"); len(v) > 0 {
  727. DeviceSensor.T_number = v
  728. Device.Update_DeviceSensor(DeviceSensor, "T_number")
  729. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 探头编号", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+v)
  730. }
  731. //金卫信对接数据
  732. ProbeIdNo := c.GetString("probeIdNo")
  733. if len(ProbeIdNo) > 0 {
  734. DeviceSensor.ProbeIdNo = ProbeIdNo
  735. Device.Update_DeviceSensor(DeviceSensor, "probe_id_no")
  736. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 金卫信对接参数", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+ProbeIdNo)
  737. }
  738. c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK"}
  739. c.ServeJSON()
  740. return
  741. }
  742. // 删除传感器
  743. func (c *DeviceController) DeviceSensor_Del() {
  744. Sn := c.GetString("T_sn")
  745. Id, _ := c.GetInt("T_id")
  746. device, err := Device.Read_Device_ByT_sn(Sn)
  747. if err != nil {
  748. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  749. c.ServeJSON()
  750. return
  751. }
  752. _, is := Device.Read_DeviceSensor_ByT_sn(Sn, Id)
  753. if !is {
  754. c.Data["json"] = lib.JSONS{Code: 202, Msg: "信息错误!"}
  755. c.ServeJSON()
  756. return
  757. }
  758. // 0默认:从数据库删除 1:从设备删除
  759. T_mode, _ := c.GetInt("T_mode")
  760. if T_mode == 1 {
  761. Device.Delete_DeviceSensor_ById(Sn, Id)
  762. NatsServer.Del_DeviceSensor(Device.DeviceSensor_Del{
  763. T_sn: Sn, T_id: Id,
  764. }, device.T_mqttid)
  765. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 删除操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]")
  766. } else {
  767. Device.Delete_DeviceSensor_ById(Sn, Id)
  768. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 删除操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]")
  769. }
  770. c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK"}
  771. c.ServeJSON()
  772. return
  773. }
  774. // 传感器参数
  775. func (c *DeviceController) DeviceSensor_Parameter_Get() {
  776. Sn := c.GetString("T_sn")
  777. Id, _ := c.GetInt("T_id")
  778. device, err := Device.Read_Device_ByT_sn(Sn)
  779. if err != nil {
  780. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  781. c.ServeJSON()
  782. return
  783. }
  784. //c.Data["DeviceSensor"], _ = Device.Read_DeviceSensor_ByTsn_Tid(Sn, Id)
  785. DeviceSensorParameter_lite := Device.Read_DeviceSensorParameter_T_sn_T_id(Sn, Id)
  786. if len(DeviceSensorParameter_lite) == 0 {
  787. NatsServer.Read_DeviceSensorParameter(Sn, device.T_mqttid)
  788. c.Data["json"] = lib.JSONS{Code: 202, Msg: "未同步参数,请检查设备是否正常!"}
  789. c.ServeJSON()
  790. return
  791. }
  792. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceSensorParameter_lite}
  793. c.ServeJSON()
  794. return
  795. }
  796. // 传感器参数列表
  797. func (c *DeviceController) DeviceSensor_Parameter_List() {
  798. Sn := c.GetString("T_sn")
  799. Id, _ := c.GetInt("T_id")
  800. page, _ := c.GetInt("page")
  801. if page < 1 {
  802. page = 1
  803. }
  804. page_z, _ := c.GetInt("page_z")
  805. if page_z < 1 {
  806. page_z = conf.Page_size
  807. }
  808. DeviceSensorParameter_lite := Device.Read_DeviceSensorParameter_List(Sn, Id, 2, page, page_z)
  809. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceSensorParameter_lite}
  810. c.ServeJSON()
  811. return
  812. }
  813. // 修改传感器参数
  814. func (c *DeviceController) DeviceSensor_Parameter_Pu() {
  815. T_SN := c.GetString("T_sn")
  816. T_id, _ := c.GetInt("T_id")
  817. device, err := Device.Read_Device_ByT_sn(T_SN)
  818. if err != nil {
  819. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  820. c.ServeJSON()
  821. return
  822. }
  823. DeviceSensor, is := Device.Read_DeviceSensor_ByT_sn(T_SN, T_id)
  824. if !is {
  825. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id Err!"}
  826. c.ServeJSON()
  827. return
  828. }
  829. DeviceSensorParameter, is := Device.Read_DeviceSensorParameter(T_SN, T_id)
  830. if !is {
  831. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id Err!"}
  832. c.ServeJSON()
  833. return
  834. }
  835. T_name := DeviceSensor.T_name
  836. if v := c.GetString("T_name"); len(v) > 0 {
  837. T_name = v
  838. }
  839. T_Tlower := DeviceSensorParameter.T_Tlower
  840. if v, T_Tlower_err := c.GetFloat("T_Tlower"); T_Tlower_err == nil {
  841. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  842. T_Tlower = float32(temp)
  843. }
  844. T_Tupper := DeviceSensorParameter.T_Tupper
  845. if v, T_Tupper_err := c.GetFloat("T_Tupper"); T_Tupper_err == nil {
  846. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  847. T_Tupper = float32(temp)
  848. }
  849. T_RHlower := DeviceSensorParameter.T_RHlower
  850. if v, T_RHlower_err := c.GetFloat("T_RHlower"); T_RHlower_err == nil {
  851. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  852. T_RHlower = float32(temp)
  853. }
  854. T_RHupper := DeviceSensorParameter.T_RHupper
  855. if v, T_RHupper_err := c.GetFloat("T_RHupper"); T_RHupper_err == nil {
  856. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  857. T_RHupper = float32(temp)
  858. }
  859. T_enprel := DeviceSensorParameter.T_enprel
  860. if v, T_enprel_err := c.GetInt("T_enprel"); T_enprel_err == nil {
  861. T_enprel = v
  862. }
  863. T_tprel := DeviceSensorParameter.T_tprel
  864. if v, T_tprel_err := c.GetFloat("T_tprel"); T_tprel_err == nil {
  865. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  866. T_tprel = float32(temp)
  867. }
  868. T_tpreu := DeviceSensorParameter.T_tpreu
  869. if v, T_tpreu_err := c.GetFloat("T_tpreu"); T_tpreu_err == nil {
  870. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  871. T_tpreu = float32(temp)
  872. }
  873. T_hprel := DeviceSensorParameter.T_hprel
  874. if v, T_hprel_err := c.GetFloat("T_hprel"); T_hprel_err == nil {
  875. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  876. T_hprel = float32(temp)
  877. }
  878. T_hpreu := DeviceSensorParameter.T_hpreu
  879. if v, T_hpreu_err := c.GetFloat("T_hpreu"); T_hpreu_err == nil {
  880. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  881. T_hpreu = float32(temp)
  882. }
  883. T_enprelnote := DeviceSensorParameter.T_enprelnote
  884. if v, T_enprel_err := c.GetInt("T_enprelnote"); T_enprel_err == nil {
  885. T_enprelnote = v
  886. }
  887. //T_speed := DeviceSensorParameter.T_speed
  888. //if v, T_speed_err := c.GetInt("T_speed"); T_speed_err == nil {
  889. // T_speed = v
  890. //}
  891. //T_sense := DeviceSensorParameter.T_sense
  892. //if v, T_sense_err := c.GetInt("T_sense"); T_sense_err == nil {
  893. // T_sense = v
  894. //}
  895. T_en := DeviceSensorParameter.T_en
  896. if v, T_en_err := c.GetInt("T_en"); T_en_err == nil {
  897. T_en = v
  898. }
  899. T_free := DeviceSensorParameter.T_free
  900. if v, T_free_err := c.GetInt("T_free"); T_free_err == nil {
  901. T_free = v
  902. }
  903. dsp := Device.DeviceSensorParameter{
  904. T_sn: T_SN,
  905. T_id: T_id,
  906. T_name: T_name,
  907. T_Tlower: T_Tlower,
  908. T_Tupper: T_Tupper,
  909. T_RHlower: T_RHlower,
  910. T_RHupper: T_RHupper,
  911. //T_speed: T_speed,
  912. //T_sense: T_sense,
  913. T_en: T_en,
  914. T_free: T_free,
  915. T_enprel: T_enprel,
  916. T_tprel: T_tprel,
  917. T_tpreu: T_tpreu,
  918. T_hprel: T_hprel,
  919. T_hpreu: T_hpreu,
  920. T_enprelnote: T_enprelnote,
  921. T_uuid: c.Admin_r.T_uuid,
  922. T_SendState: 0,
  923. T_State: 2, // 用户提交
  924. }
  925. dsp, is = Device.Add_DeviceSensorParameter(dsp)
  926. if !is {
  927. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Add_DeviceSensorParameter Err!"}
  928. c.ServeJSON()
  929. return
  930. }
  931. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器参数操作", dsp)
  932. // 更新名称
  933. if len(T_name) > 0 {
  934. DeviceSensor.T_name = T_name
  935. if is = Device.Update_DeviceSensor(DeviceSensor, "T_name"); !is {
  936. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Update_DeviceSensor Err!"}
  937. c.ServeJSON()
  938. return
  939. }
  940. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "修改传感器名称", DeviceSensor)
  941. }
  942. NatsServer.Pu_DeviceParameter_Sensor(dsp, device.T_mqttid)
  943. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  944. c.ServeJSON()
  945. return
  946. }
  947. // 传感器管理列表
  948. func (c *DeviceController) DeviceSensor_Manage_List() {
  949. type R_JSONS struct {
  950. //必须的大写开头
  951. Data []Device.DeviceSensor_P
  952. Num int64
  953. Page int
  954. Page_size int
  955. }
  956. var r_jsons R_JSONS
  957. page, _ := c.GetInt("page")
  958. if page < 1 {
  959. page = 1
  960. }
  961. page_z, _ := c.GetInt("page_z")
  962. if page_z < 1 {
  963. page_z = conf.Page_size
  964. }
  965. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  966. T_calss_id, _ := c.GetInt("T_calssid")
  967. if T_calss_id > 0 {
  968. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_calss_id)
  969. if err != nil {
  970. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  971. c.ServeJSON()
  972. return
  973. }
  974. if R_DeviceClass.T_pid != c.T_pid {
  975. c.Data["json"] = lib.JSONS{Code: 202, Msg: "CompanyClass.T_pid != T_pid Err!"}
  976. c.ServeJSON()
  977. return
  978. }
  979. }
  980. T_en, T_en_err := c.GetInt("T_en") //启用停用 0 停用 1 启用 空 所有
  981. if T_en_err != nil {
  982. T_en = -1
  983. }
  984. T_free, T_free_err := c.GetInt("T_free") // 空库 0 正常 1 空库 空 所有
  985. if T_free_err != nil {
  986. T_free = -1
  987. }
  988. T_datashow, T_datashow_err := c.GetInt("T_datashow") //数据展示 空 全部 0 屏蔽数据展示 1 正常数据展示
  989. if T_datashow_err != nil {
  990. T_datashow = -1
  991. }
  992. T_sort, T_sort_err := c.GetInt("T_sort") //排序 空 升序 1 降序
  993. if T_sort_err != nil {
  994. T_sort = -1
  995. }
  996. T_abandon, _ := c.GetInt("T_abandon")
  997. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  998. if err != nil {
  999. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1000. c.ServeJSON()
  1001. return
  1002. }
  1003. r_jsons.Data, r_jsons.Num = Device.Read_DeviceSensorManageList(c.Admin_r, bindSN, c.T_pid, T_name, T_calss_id, T_en, T_free, T_datashow, T_sort, T_abandon, page, page_z)
  1004. r_jsons.Page = page
  1005. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1006. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1007. c.ServeJSON()
  1008. return
  1009. }
  1010. // 导出传感器管理列表
  1011. func (c *DeviceController) DeviceSensor_Manage_List_Excel() {
  1012. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  1013. T_calss_id, _ := c.GetInt("T_calssid")
  1014. if T_calss_id > 0 {
  1015. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_calss_id)
  1016. if err != nil {
  1017. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1018. c.ServeJSON()
  1019. return
  1020. }
  1021. if R_DeviceClass.T_pid != c.T_pid {
  1022. c.Data["json"] = lib.JSONS{Code: 202, Msg: "CompanyClass.T_pid != T_pid Err!"}
  1023. c.ServeJSON()
  1024. return
  1025. }
  1026. }
  1027. T_en, T_en_err := c.GetInt("T_en") //启用停用 0 停用 1 启用 空 所有
  1028. if T_en_err != nil {
  1029. T_en = -1
  1030. }
  1031. T_free, T_free_err := c.GetInt("T_free") // 空库 0 正常 1 空库 空 所有
  1032. if T_free_err != nil {
  1033. T_free = -1
  1034. }
  1035. T_datashow, T_datashow_err := c.GetInt("T_datashow") //数据展示 空 全部 0 屏蔽数据展示 1 正常数据展示
  1036. if T_datashow_err != nil {
  1037. T_datashow = -1
  1038. }
  1039. T_sort, T_sort_err := c.GetInt("T_sort") //排序 空 升序 1 降序
  1040. if T_sort_err != nil {
  1041. T_sort = -1
  1042. }
  1043. T_abandon, _ := c.GetInt("T_abandon")
  1044. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  1045. if err != nil {
  1046. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1047. c.ServeJSON()
  1048. return
  1049. }
  1050. DeviceSensor_data, _ := Device.Read_DeviceSensorManageList(c.Admin_r, bindSN, c.T_pid, T_name, T_calss_id, T_en, T_free, T_datashow, T_sort, T_abandon, 0, 9999)
  1051. f := excelize.NewFile() //设置单元格值
  1052. // 这里设置表头ÒÒ
  1053. Style1, _ := f.NewStyle(
  1054. &excelize.Style{
  1055. Font: &excelize.Font{Size: 20, Family: "宋体"},
  1056. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center"},
  1057. })
  1058. Style2, _ := f.NewStyle(
  1059. &excelize.Style{
  1060. Font: &excelize.Font{Size: 15, Family: "宋体"},
  1061. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1062. Border: []excelize.Border{
  1063. {Type: "left", Color: "000000", Style: 1},
  1064. {Type: "top", Color: "000000", Style: 1},
  1065. {Type: "bottom", Color: "000000", Style: 1},
  1066. {Type: "right", Color: "000000", Style: 1},
  1067. },
  1068. Fill: excelize.Fill{Type: "pattern", Color: []string{"D9D9D9"}, Pattern: 1},
  1069. })
  1070. Style3, _ := f.NewStyle(
  1071. &excelize.Style{
  1072. Font: &excelize.Font{Size: 15, Family: "宋体"},
  1073. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1074. Border: []excelize.Border{
  1075. {Type: "left", Color: "000000", Style: 1},
  1076. {Type: "top", Color: "000000", Style: 1},
  1077. {Type: "bottom", Color: "000000", Style: 1},
  1078. {Type: "right", Color: "000000", Style: 1},
  1079. },
  1080. })
  1081. f.MergeCell("Sheet1", "A1", "T1")
  1082. f.SetCellValue("Sheet1", "A1", "设备管理")
  1083. f.SetCellStyle("Sheet1", "A1", "T1", Style1)
  1084. // 写入表头
  1085. headers := []string{"序号", "公司名称", "SN", "分类", "规格", "传感器名称", "探头编号", "传感器类型", "启/停", "空库", "温度范围(℃)",
  1086. "湿度范围(%)", "预警", "预警温度范围", "预警湿度范围", "数据展示",
  1087. "验证日期", "验证到期时间", "校准日期", "校准到期时间"}
  1088. for col, header := range headers {
  1089. cell := fmt.Sprintf("%c%d", rune('A'+col), 2)
  1090. f.SetCellValue("Sheet1", cell, header)
  1091. }
  1092. // 这里设置表头
  1093. f.SetCellStyle("Sheet1", "A2", "T2", Style2)
  1094. f.SetRowHeight("Sheet1", 2, 25)
  1095. colsWidth := []float64{6, 30, 22, 10, 15, 15, 25, 15, 12, 12, 15, 15, 12, 15, 15, 15, 15, 15, 15, 15}
  1096. for col, width := range colsWidth {
  1097. cell := fmt.Sprintf("%c", rune('A'+col))
  1098. f.SetColWidth("Sheet1", cell, cell, width)
  1099. }
  1100. Company_r, err := Account.Read_Company_ById(c.T_pid)
  1101. if err != nil {
  1102. c.Data["json"] = lib.JSONS{Code: 202, Msg: "获取公司信息失败!"}
  1103. c.ServeJSON()
  1104. return
  1105. }
  1106. line := 2
  1107. for i, v := range DeviceSensor_data {
  1108. // 写入数据
  1109. line++
  1110. f.SetCellValue("Sheet1", fmt.Sprintf("A%d", line), i+1)
  1111. f.SetCellValue("Sheet1", fmt.Sprintf("B%d", line), Company_r.T_name) // 公司名称
  1112. f.SetCellValue("Sheet1", fmt.Sprintf("C%d", line), v.T_sn)
  1113. classList, specList := []string{}, []string{}
  1114. for _, r := range v.T_CompanyClassList {
  1115. if len(r.T_name) > 0 {
  1116. classList = append(classList, r.T_name)
  1117. }
  1118. if len(r.T_spec) > 0 {
  1119. specList = append(specList, r.T_spec)
  1120. }
  1121. }
  1122. f.SetCellValue("Sheet1", fmt.Sprintf("D%d", line), strings.Join(classList, "/")) // 分类
  1123. f.SetCellValue("Sheet1", fmt.Sprintf("E%d", line), strings.Join(specList, "/")) // 规格
  1124. f.SetCellValue("Sheet1", fmt.Sprintf("F%d", line), v.T_name)
  1125. f.SetCellValue("Sheet1", fmt.Sprintf("G%d", line), v.T_number)
  1126. f.SetCellValue("Sheet1", fmt.Sprintf("H%d", line), v.T_type_name)
  1127. T_en_str := "启用"
  1128. if v.T_en != nil && *v.T_en == 0 {
  1129. T_en_str = "停用"
  1130. }
  1131. f.SetCellValue("Sheet1", fmt.Sprintf("I%d", line), T_en_str)
  1132. T_free_str := "正常"
  1133. if v.T_free != nil && *v.T_free == 1 {
  1134. T_free_str = "停用"
  1135. }
  1136. f.SetCellValue("Sheet1", fmt.Sprintf("J%d", line), T_free_str)
  1137. T_Tlower, T_Tupper, T_RHlower, T_RHupper := "0", "0", "0", "0"
  1138. if v.T_Tlower != nil {
  1139. T_Tlower = fmt.Sprintf("%.1f", *v.T_Tlower)
  1140. }
  1141. if v.T_Tupper != nil {
  1142. T_Tupper = fmt.Sprintf("%.1f", *v.T_Tupper)
  1143. }
  1144. if v.T_RHlower != nil {
  1145. T_RHlower = fmt.Sprintf("%.1f", *v.T_RHlower)
  1146. }
  1147. if v.T_RHupper != nil {
  1148. T_RHupper = fmt.Sprintf("%.1f", *v.T_RHupper)
  1149. }
  1150. f.SetCellValue("Sheet1", fmt.Sprintf("K%d", line), fmt.Sprintf("%s ~ %s", T_Tlower, T_Tupper))
  1151. f.SetCellValue("Sheet1", fmt.Sprintf("L%d", line), fmt.Sprintf("%s ~ %s", T_RHlower, T_RHupper))
  1152. T_enprel_str := "开启"
  1153. if v.T_enprel != nil && *v.T_enprel == 0 {
  1154. T_enprel_str = "关闭"
  1155. }
  1156. f.SetCellValue("Sheet1", fmt.Sprintf("M%d", line), T_enprel_str)
  1157. T_tprel, T_tpreu, T_hprel, T_hpreu := "0", "0", "0", "0"
  1158. if v.T_tprel != nil {
  1159. T_tprel = fmt.Sprintf("%.1f", *v.T_tprel)
  1160. }
  1161. if v.T_tpreu != nil {
  1162. T_tpreu = fmt.Sprintf("%.1f", *v.T_tpreu)
  1163. }
  1164. if v.T_hprel != nil {
  1165. T_hprel = fmt.Sprintf("%.1f", *v.T_hprel)
  1166. }
  1167. if v.T_hpreu != nil {
  1168. T_hpreu = fmt.Sprintf("%.1f", *v.T_hpreu)
  1169. }
  1170. f.SetCellValue("Sheet1", fmt.Sprintf("N%d", line), fmt.Sprintf("%s ~ %s", T_tprel, T_tpreu))
  1171. f.SetCellValue("Sheet1", fmt.Sprintf("O%d", line), fmt.Sprintf("%s ~ %s", T_hprel, T_hpreu))
  1172. T_datashow_str := "屏蔽"
  1173. if v.T_datashow == 1 {
  1174. T_datashow_str = "显示"
  1175. }
  1176. f.SetCellValue("Sheet1", fmt.Sprintf("P%d", line), T_datashow_str)
  1177. f.SetCellValue("Sheet1", fmt.Sprintf("Q%d", line), v.T_Device.T_VerifyTime)
  1178. f.SetCellValue("Sheet1", fmt.Sprintf("R%d", line), v.T_Device.T_VerifyEndTime)
  1179. f.SetCellValue("Sheet1", fmt.Sprintf("S%d", line), v.T_Device.T_CalibrationTime)
  1180. f.SetCellValue("Sheet1", fmt.Sprintf("T%d", line), v.T_Device.T_CalibrationEndTime)
  1181. }
  1182. f.SetCellStyle("Sheet1", "A3", fmt.Sprintf("T%d", line), Style3)
  1183. timeStr := Company_r.T_name + "设备管理(" + lib.GetRandstring(6, "0123456789", 0) + ")"
  1184. // 保存文件
  1185. if err = f.SaveAs("ofile/" + timeStr + ".xlsx"); err != nil {
  1186. logs.Error(err)
  1187. }
  1188. // 上传 OSS
  1189. url, is := NatsServer.Qiniu_UploadFile(lib.GetCurrentDirectory()+"/ofile/"+timeStr+".xlsx", "ofile/"+timeStr+".xlsx")
  1190. if !is {
  1191. c.Data["json"] = lib.JSONS{Code: 202, Msg: "oss!"}
  1192. c.ServeJSON()
  1193. return
  1194. }
  1195. //删除目录
  1196. err = os.Remove("ofile/" + timeStr + ".xlsx")
  1197. if err != nil {
  1198. logs.Error(err)
  1199. }
  1200. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: url}
  1201. c.ServeJSON()
  1202. return
  1203. }
  1204. // 传感器列表-报警策略
  1205. func (c *DeviceController) DeviceSensor_Notice_UnbindList() {
  1206. type R_JSONS struct {
  1207. //必须的大写开头
  1208. Data []Device.DeviceSensor_
  1209. Num int64
  1210. Page int
  1211. Page_size int
  1212. }
  1213. var r_jsons R_JSONS
  1214. page, _ := c.GetInt("page")
  1215. if page < 1 {
  1216. page = 1
  1217. }
  1218. page_z, _ := c.GetInt("page_z")
  1219. if page_z < 1 {
  1220. page_z = conf.Page_size
  1221. }
  1222. T_class_id, _ := c.GetInt("T_calssid")
  1223. T_notice_id, _ := c.GetInt("T_notice_id")
  1224. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  1225. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  1226. if err != nil {
  1227. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1228. c.ServeJSON()
  1229. return
  1230. }
  1231. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1232. if err != nil {
  1233. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1234. c.ServeJSON()
  1235. return
  1236. }
  1237. if R_DeviceNotice.T_pid != c.T_pid {
  1238. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1239. c.ServeJSON()
  1240. return
  1241. }
  1242. var cnt int64
  1243. r_jsons.Data, r_jsons.Num = Device.Read_Unbind_DeviceSensor_List_T_Notice(c.T_pid, T_notice_id, T_class_id, T_name, bindSN, page, page_z)
  1244. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1245. r_jsons.Page = page
  1246. r_jsons.Page_size = int(page_size)
  1247. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1248. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1249. c.ServeJSON()
  1250. return
  1251. }
  1252. // 设备任务 ------------------------------------------
  1253. // 任务列表
  1254. func (c *DeviceController) DeviceTask_List() {
  1255. type R_JSONS struct {
  1256. //必须的大写开头
  1257. Data []Device.DeviceTask
  1258. Num int64
  1259. Page int
  1260. Page_size int
  1261. }
  1262. var r_jsons R_JSONS
  1263. page, _ := c.GetInt("page")
  1264. if page < 1 {
  1265. page = 1
  1266. }
  1267. page_z, _ := c.GetInt("page_z")
  1268. if page_z < 1 {
  1269. page_z = conf.Page_size
  1270. }
  1271. T_sn := c.GetString("T_sn")
  1272. Time_start := c.GetString("Time_start")
  1273. Time_end := c.GetString("Time_end")
  1274. if len(T_sn) < 6 {
  1275. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn!!!"}
  1276. c.ServeJSON()
  1277. return
  1278. }
  1279. r_jsons.Data, r_jsons.Num = Device.Read_DeviceTask_List(T_sn, Time_start, Time_end, page, page_z)
  1280. r_jsons.Page = page
  1281. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1282. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1283. c.ServeJSON()
  1284. return
  1285. }
  1286. func (c *DeviceController) DeviceTask_All() {
  1287. var r_jsons lib.R_JSONS
  1288. T_sn := c.GetString("T_sn")
  1289. if len(T_sn) < 6 {
  1290. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn!!!"}
  1291. c.ServeJSON()
  1292. return
  1293. }
  1294. r_jsons.Data, r_jsons.Num = Device.Read_DeviceTask_All(T_sn)
  1295. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1296. c.ServeJSON()
  1297. return
  1298. }
  1299. // 任务启停
  1300. func (c *DeviceController) DeviceTask_Post() {
  1301. T_sn := c.GetString("T_sn")
  1302. T_task := c.GetString("T_task")
  1303. device, err := Device.Read_Device_ByT_sn(T_sn)
  1304. if err != nil {
  1305. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1306. c.ServeJSON()
  1307. return
  1308. }
  1309. NatsServer.Set_DeviceTask(Device.Device_task{
  1310. T_sn: T_sn,
  1311. T_task: T_task,
  1312. }, device.T_mqttid)
  1313. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "远程启停", T_sn+"-"+T_task)
  1314. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1315. c.ServeJSON()
  1316. return
  1317. }
  1318. // 设备分类 ------------------------------------------
  1319. func (c *DeviceController) CompanyClass_List() {
  1320. type R_JSONS struct {
  1321. //必须的大写开头
  1322. Data []Company.CompanyClass_R
  1323. Num int64
  1324. Page int
  1325. Page_size int
  1326. }
  1327. var r_jsons R_JSONS
  1328. page, _ := c.GetInt("page")
  1329. if page < 1 {
  1330. page = 1
  1331. }
  1332. page_z, _ := c.GetInt("page_z")
  1333. if page_z < 1 {
  1334. page_z = conf.Page_size
  1335. }
  1336. T_name := c.GetString("T_name")
  1337. r_jsons.Data, r_jsons.Num = Company.Read_CompanyClass_List(c.T_pid, T_name, page, page_z)
  1338. r_jsons.Page = page
  1339. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1340. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1341. c.ServeJSON()
  1342. return
  1343. }
  1344. func (c *DeviceController) CompanyClass_All() {
  1345. type R_JSONS struct {
  1346. //必须的大写开头
  1347. Data []Company.CompanyClass_R
  1348. Num int64
  1349. Page int
  1350. Page_size int
  1351. }
  1352. var r_jsons R_JSONS
  1353. T_name := c.GetString("T_name")
  1354. r_jsons.Data = Company.Read_CompanyClass_All(c.T_pid, T_name)
  1355. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1356. c.ServeJSON()
  1357. return
  1358. }
  1359. // 查询公司及公司下所有子公司的公司分类
  1360. func (c *DeviceController) CompanyClass_All_For_Company() {
  1361. var r_jsons lib.R_JSONS
  1362. T_name := c.GetString("T_name")
  1363. // 查询公司
  1364. Company_r, err := Account.Read_Company_ById(c.T_pid)
  1365. if err != nil {
  1366. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1367. c.ServeJSON()
  1368. return
  1369. }
  1370. // 查询公司下面所有子公司id
  1371. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  1372. Account.Read_Company_All_Maps()
  1373. r_jsons.Data = Company.Read_CompanyClass_All_For_Company(T_pids, T_name)
  1374. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1375. c.ServeJSON()
  1376. return
  1377. }
  1378. func (c *DeviceController) CompanyClass_Get() {
  1379. id, _ := c.GetInt("T_id")
  1380. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1381. if err != nil {
  1382. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1383. c.ServeJSON()
  1384. return
  1385. }
  1386. if R_DeviceClass.T_pid != c.T_pid {
  1387. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1388. c.ServeJSON()
  1389. return
  1390. }
  1391. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Company.CompanyClassToCompanyClass_R(R_DeviceClass)}
  1392. c.ServeJSON()
  1393. return
  1394. }
  1395. func (c *DeviceController) CompanyClass_Add() {
  1396. T_name := c.GetString("T_name")
  1397. T_spec := c.GetString("T_spec")
  1398. t_c := Company.CompanyClass{
  1399. T_pid: c.T_pid,
  1400. T_name: T_name,
  1401. T_State: 1,
  1402. T_spec: T_spec,
  1403. }
  1404. Id, err := Company.Add_CompanyClass(t_c)
  1405. if err != nil {
  1406. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败"}
  1407. c.ServeJSON()
  1408. return
  1409. }
  1410. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "分类添加", t_c)
  1411. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
  1412. c.ServeJSON()
  1413. return
  1414. }
  1415. func (c *DeviceController) CompanyClass_Edit() {
  1416. T_name := c.GetString("T_name")
  1417. id, _ := c.GetInt("T_id")
  1418. T_spec := c.GetString("T_spec")
  1419. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1420. if err != nil {
  1421. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1422. c.ServeJSON()
  1423. return
  1424. }
  1425. if R_DeviceClass.T_pid != c.T_pid {
  1426. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1427. c.ServeJSON()
  1428. return
  1429. }
  1430. if len(T_name) > 0 {
  1431. R_DeviceClass.T_name = T_name
  1432. }
  1433. if len(T_name) > 0 {
  1434. R_DeviceClass.T_spec = T_spec
  1435. }
  1436. if is := Company.Update_CompanyClass(R_DeviceClass, "T_name", "T_spec"); !is {
  1437. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1438. c.ServeJSON()
  1439. return
  1440. }
  1441. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "分类修改", R_DeviceClass)
  1442. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1443. c.ServeJSON()
  1444. return
  1445. }
  1446. func (c *DeviceController) CompanyClass_Del() {
  1447. id, _ := c.GetInt("T_id")
  1448. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1449. if err != nil {
  1450. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1451. c.ServeJSON()
  1452. return
  1453. }
  1454. if R_DeviceClass.T_pid != c.T_pid {
  1455. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1456. c.ServeJSON()
  1457. return
  1458. }
  1459. if is := Company.Delete_CompanyClass_ById(id); !is {
  1460. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败"}
  1461. c.ServeJSON()
  1462. return
  1463. }
  1464. // 将传感器T_Class绑定的分类id替换为空字符串
  1465. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_Class_Id(id)
  1466. for _, v := range DeviceSensor_class_list {
  1467. Device.DeviceSensor_Bind_T_Class_Del(v.T_sn, v.T_id, id)
  1468. }
  1469. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类删除", strconv.Itoa(id))
  1470. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1471. c.ServeJSON()
  1472. return
  1473. }
  1474. // 设备分类绑定
  1475. func (c *DeviceController) DeviceClassBind_List() {
  1476. type R_JSONS struct {
  1477. //必须的大写开头
  1478. DeviceSensor_lite []Device.DeviceSensor_
  1479. Num int
  1480. Page int
  1481. Page_size int
  1482. Pages []lib.Page_T
  1483. }
  1484. var r_jsons R_JSONS
  1485. page, _ := c.GetInt("page")
  1486. if page < 1 {
  1487. page = 1
  1488. }
  1489. page_z, _ := c.GetInt("page_z")
  1490. if page_z < 1 {
  1491. page_z = conf.Page_size
  1492. }
  1493. T_name := c.GetString("T_name")
  1494. T_sn := c.GetString("T_sn")
  1495. T_class_id, _ := c.GetInt("T_class_id")
  1496. T_type, _ := c.GetInt("T_type")
  1497. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1498. if err != nil {
  1499. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1500. c.ServeJSON()
  1501. return
  1502. }
  1503. if R_DeviceClass.T_pid != c.T_pid {
  1504. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1505. c.ServeJSON()
  1506. return
  1507. }
  1508. var cnt int64
  1509. Device_lite, cnt := Device.Read_DeviceSensor_List_T_Class(c.T_pid, T_class_id, T_sn, T_name, T_type, page, page_z)
  1510. r_jsons.DeviceSensor_lite = Device_lite
  1511. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1512. r_jsons.Page = page
  1513. r_jsons.Page_size = int(page_size)
  1514. r_jsons.Pages = lib.Func_page(int64(page), int64(page_size))
  1515. r_jsons.Num = int(cnt)
  1516. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1517. c.ServeJSON()
  1518. return
  1519. }
  1520. func (c *DeviceController) ClassBind_Add() {
  1521. T_class_id, _ := c.GetInt("T_class_id")
  1522. T_sn := c.GetString("T_sn")
  1523. T_id, _ := c.GetInt("T_id")
  1524. if T_class_id == 0 || len(T_sn) == 0 {
  1525. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1526. c.ServeJSON()
  1527. return
  1528. }
  1529. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1530. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1531. c.ServeJSON()
  1532. return
  1533. }
  1534. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1535. if err != nil {
  1536. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1537. c.ServeJSON()
  1538. return
  1539. }
  1540. if R_DeviceClass.T_pid != c.T_pid {
  1541. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1542. c.ServeJSON()
  1543. return
  1544. }
  1545. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Class(T_sn, T_id, T_class_id)
  1546. if len(DeviceSensor_class_list) > 0 {
  1547. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1548. c.ServeJSON()
  1549. return
  1550. }
  1551. if err = Device.DeviceSensor_Bind_T_Class_Add(T_sn, T_id, T_class_id); err != nil {
  1552. c.Data["json"] = lib.JSONS{Code: 200, Msg: "绑定失败"}
  1553. c.ServeJSON()
  1554. return
  1555. }
  1556. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类绑定操作", strconv.Itoa(T_class_id)+"+>"+T_sn+"-"+strconv.Itoa(T_id))
  1557. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1558. c.ServeJSON()
  1559. return
  1560. }
  1561. func (c *DeviceController) ClassBind_Del() {
  1562. T_class_id, _ := c.GetInt("T_class_id")
  1563. T_sn := c.GetString("T_sn")
  1564. T_id, _ := c.GetInt("T_id")
  1565. if T_class_id == 0 || len(T_sn) == 0 {
  1566. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1567. c.ServeJSON()
  1568. return
  1569. }
  1570. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1571. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1572. c.ServeJSON()
  1573. return
  1574. }
  1575. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1576. if err != nil {
  1577. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1578. c.ServeJSON()
  1579. return
  1580. }
  1581. if R_DeviceClass.T_pid != c.T_pid {
  1582. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1583. c.ServeJSON()
  1584. return
  1585. }
  1586. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Class(T_sn, T_id, T_class_id)
  1587. if len(DeviceSensor_class_list) == 0 {
  1588. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1589. c.ServeJSON()
  1590. return
  1591. }
  1592. if err = Device.DeviceSensor_Bind_T_Class_Del(T_sn, T_id, T_class_id); err != nil {
  1593. c.Data["json"] = lib.JSONS{Code: 200, Msg: "删除失败"}
  1594. c.ServeJSON()
  1595. return
  1596. }
  1597. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类删除绑定操作", strconv.Itoa(T_class_id)+"->"+T_sn+"-"+strconv.Itoa(T_id))
  1598. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1599. c.ServeJSON()
  1600. return
  1601. }
  1602. // 报警策略 ------------------------------------------
  1603. func (c *DeviceController) CompanyNotice_List() {
  1604. type R_JSONS struct {
  1605. //必须的大写开头
  1606. Data []Company.CompanyNotice_R
  1607. Num int64
  1608. Page int
  1609. Page_size int
  1610. }
  1611. var r_jsons R_JSONS
  1612. page, _ := c.GetInt("page")
  1613. if page < 1 {
  1614. page = 1
  1615. }
  1616. page_z, _ := c.GetInt("page_z")
  1617. if page_z < 1 {
  1618. page_z = conf.Page_size
  1619. }
  1620. T_name := c.GetString("T_name")
  1621. r_jsons.Data, r_jsons.Num = Company.Read_CompanyNotice_List(c.T_pid, T_name, page, page_z)
  1622. r_jsons.Page = page
  1623. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1624. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1625. c.ServeJSON()
  1626. return
  1627. }
  1628. func (c *DeviceController) CompanyNotice_All() {
  1629. type R_JSONS struct {
  1630. //必须的大写开头
  1631. Data []Company.CompanyNotice_R
  1632. Num int64
  1633. Page int
  1634. Page_size int
  1635. }
  1636. var r_jsons R_JSONS
  1637. T_name := c.GetString("T_name")
  1638. r_jsons.Data = Company.Read_CompanyNotice_All(c.T_pid, T_name)
  1639. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1640. c.ServeJSON()
  1641. return
  1642. }
  1643. func (c *DeviceController) CompanyNotice_Get() {
  1644. id, _ := c.GetInt("T_id")
  1645. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1646. if err != nil {
  1647. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1648. c.ServeJSON()
  1649. return
  1650. }
  1651. if R_DeviceNotice.T_pid != c.T_pid {
  1652. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1653. c.ServeJSON()
  1654. return
  1655. }
  1656. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Company.CompanyNoticeToCompanyNotice_R(R_DeviceNotice)}
  1657. c.ServeJSON()
  1658. return
  1659. }
  1660. func (c *DeviceController) CompanyNotice_Add() {
  1661. T_name := c.GetString("T_name")
  1662. t_c := Company.CompanyNotice{
  1663. T_pid: c.T_pid,
  1664. T_name: T_name,
  1665. T_Notice_mechanism: Warning.Read_WarningType_All_T_Notice_mechanism(),
  1666. T_State: 1,
  1667. }
  1668. Id, err := Company.Add_CompanyNotice(t_c)
  1669. if err != nil {
  1670. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败"}
  1671. c.ServeJSON()
  1672. return
  1673. }
  1674. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略添加", t_c)
  1675. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
  1676. c.ServeJSON()
  1677. return
  1678. }
  1679. func (c *DeviceController) CompanyNotice_Edit() {
  1680. id, _ := c.GetInt("T_id")
  1681. T_name := c.GetString("T_name")
  1682. T_Notice_wx := c.GetString("T_Notice_wx")
  1683. T_Notice_wx2 := c.GetString("T_Notice_wx2")
  1684. T_Notice_app := c.GetString("T_Notice_app")
  1685. T_Notice_phone := c.GetString("T_Notice_phone")
  1686. T_Notice_message := c.GetString("T_Notice_message")
  1687. T_Notice_mailbox := c.GetString("T_Notice_mailbox")
  1688. T_Notice_mechanism := c.GetString("T_Notice_mechanism")
  1689. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1690. if err != nil {
  1691. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1692. c.ServeJSON()
  1693. return
  1694. }
  1695. if R_DeviceNotice.T_pid != c.T_pid {
  1696. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1697. c.ServeJSON()
  1698. return
  1699. }
  1700. R_DeviceNotice.Id = id
  1701. if len(T_name) > 0 {
  1702. R_DeviceNotice.T_name = T_name
  1703. }
  1704. if len(T_Notice_wx) > 0 {
  1705. if T_Notice_wx == "-" {
  1706. T_Notice_wx = ""
  1707. }
  1708. R_DeviceNotice.T_Notice_wx = T_Notice_wx
  1709. }
  1710. if len(T_Notice_wx2) > 0 {
  1711. if T_Notice_wx2 == "-" {
  1712. T_Notice_wx2 = ""
  1713. }
  1714. R_DeviceNotice.T_Notice_wx2 = T_Notice_wx2
  1715. }
  1716. if len(T_Notice_app) > 0 {
  1717. if T_Notice_app == "-" {
  1718. T_Notice_app = ""
  1719. }
  1720. R_DeviceNotice.T_Notice_app = T_Notice_app
  1721. }
  1722. if len(T_Notice_phone) > 0 {
  1723. if T_Notice_phone == "-" {
  1724. T_Notice_phone = ""
  1725. }
  1726. R_DeviceNotice.T_Notice_phone = T_Notice_phone
  1727. }
  1728. if len(T_Notice_message) > 0 {
  1729. R_DeviceNotice.T_Notice_message = T_Notice_message
  1730. }
  1731. if len(T_Notice_mailbox) > 0 {
  1732. if T_Notice_mailbox == "-" {
  1733. T_Notice_mailbox = ""
  1734. }
  1735. R_DeviceNotice.T_Notice_mailbox = T_Notice_mailbox
  1736. }
  1737. if len(T_Notice_mechanism) > 0 {
  1738. if T_Notice_mechanism == "-" {
  1739. T_Notice_mechanism = ""
  1740. }
  1741. R_DeviceNotice.T_Notice_mechanism = T_Notice_mechanism
  1742. }
  1743. if err = Company.Update_CompanyNotice(R_DeviceNotice, "T_name", "T_Notice_wx", "T_Notice_wx2", "T_Notice_app", "T_Notice_phone", "T_Notice_message", "T_Notice_mailbox", "T_Notice_mechanism"); err != nil {
  1744. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1745. c.ServeJSON()
  1746. return
  1747. }
  1748. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略修改", R_DeviceNotice)
  1749. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1750. c.ServeJSON()
  1751. return
  1752. }
  1753. func (c *DeviceController) CompanyNotice_Reset_Mechanism() {
  1754. id, _ := c.GetInt("T_id")
  1755. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1756. if err != nil {
  1757. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1758. c.ServeJSON()
  1759. return
  1760. }
  1761. if R_DeviceNotice.T_pid != c.T_pid {
  1762. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1763. c.ServeJSON()
  1764. return
  1765. }
  1766. R_DeviceNotice.T_Notice_mechanism = Warning.Read_WarningType_All_T_Notice_mechanism()
  1767. if err = Company.Update_CompanyNotice(R_DeviceNotice, "T_Notice_mechanism"); err != nil {
  1768. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1769. c.ServeJSON()
  1770. return
  1771. }
  1772. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略", R_DeviceNotice)
  1773. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1774. c.ServeJSON()
  1775. return
  1776. }
  1777. func (c *DeviceController) CompanyNotice_Del() {
  1778. id, _ := c.GetInt("T_id")
  1779. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1780. if err != nil {
  1781. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1782. c.ServeJSON()
  1783. return
  1784. }
  1785. if R_DeviceNotice.T_pid != c.T_pid {
  1786. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1787. c.ServeJSON()
  1788. return
  1789. }
  1790. if is := Company.Delete_CompanyNotice_ById(id); !is {
  1791. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败"}
  1792. c.ServeJSON()
  1793. return
  1794. }
  1795. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_Notice_Id(id)
  1796. for _, v := range DeviceSensor_class_list {
  1797. Device.DeviceSensor_Bind_T_Notice_Del(v.T_sn, v.T_id, id)
  1798. }
  1799. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略删除", strconv.Itoa(id))
  1800. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1801. c.ServeJSON()
  1802. return
  1803. }
  1804. // 设备通知绑定
  1805. func (c *DeviceController) DeviceNoticeBind_List() {
  1806. type R_JSONS struct {
  1807. //必须的大写开头
  1808. DeviceSensor_lite []Device.DeviceSensor_
  1809. Num int
  1810. Page int
  1811. Page_size int
  1812. Pages []lib.Page_T
  1813. }
  1814. var r_jsons R_JSONS
  1815. page, _ := c.GetInt("page")
  1816. if page < 1 {
  1817. page = 1
  1818. }
  1819. page_z, _ := c.GetInt("page_z")
  1820. if page_z < 1 {
  1821. page_z = conf.Page_size
  1822. }
  1823. T_name := c.GetString("T_name")
  1824. T_sn := c.GetString("T_sn")
  1825. T_notice_id, _ := c.GetInt("T_notice_id")
  1826. T_type, _ := c.GetInt("T_type")
  1827. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1828. if err != nil {
  1829. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1830. c.ServeJSON()
  1831. return
  1832. }
  1833. if R_DeviceNotice.T_pid != c.T_pid {
  1834. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1835. c.ServeJSON()
  1836. return
  1837. }
  1838. var cnt int64
  1839. Device_lite, cnt := Device.Read_DeviceSensor_List_T_Notice(c.T_pid, T_notice_id, page, page_z, T_sn, T_name, T_type)
  1840. r_jsons.DeviceSensor_lite = Device_lite
  1841. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1842. r_jsons.Page = page
  1843. r_jsons.Page_size = int(page_size)
  1844. r_jsons.Pages = lib.Func_page(int64(page), int64(page_size))
  1845. r_jsons.Num = int(cnt)
  1846. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1847. c.ServeJSON()
  1848. return
  1849. }
  1850. func (c *DeviceController) NoticeBind_Add() {
  1851. T_notice_id, _ := c.GetInt("T_notice_id")
  1852. T_sn := c.GetString("T_sn")
  1853. T_id, _ := c.GetInt("T_id")
  1854. if T_notice_id == 0 || len(T_sn) == 0 {
  1855. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_notice_id Err!"}
  1856. c.ServeJSON()
  1857. return
  1858. }
  1859. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1860. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1861. c.ServeJSON()
  1862. return
  1863. }
  1864. R_CompanyNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1865. if err != nil {
  1866. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1867. c.ServeJSON()
  1868. return
  1869. }
  1870. if R_CompanyNotice.T_pid != c.T_pid {
  1871. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1872. c.ServeJSON()
  1873. return
  1874. }
  1875. DeviceSensor_Notice_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1876. if len(DeviceSensor_Notice_list) > 0 {
  1877. c.Data["json"] = lib.JSONS{Code: 202, Msg: "重复绑定!"}
  1878. c.ServeJSON()
  1879. return
  1880. }
  1881. if err = Company.Add_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1882. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1883. c.ServeJSON()
  1884. return
  1885. }
  1886. if err = Device.DeviceSensor_Bind_T_Notice_Add(T_sn, T_id, T_notice_id); err != nil {
  1887. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1888. c.ServeJSON()
  1889. return
  1890. }
  1891. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略绑定添加", strconv.Itoa(T_notice_id)+"+>"+T_sn+"-"+strconv.Itoa(T_id))
  1892. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1893. c.ServeJSON()
  1894. return
  1895. }
  1896. func (c *DeviceController) NoticeBind_Del() {
  1897. T_notice_id, _ := c.GetInt("T_notice_id")
  1898. T_sn := c.GetString("T_sn")
  1899. T_id, _ := c.GetInt("T_id")
  1900. if T_notice_id == 0 || len(T_sn) == 0 {
  1901. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_notice_id Err!"}
  1902. c.ServeJSON()
  1903. return
  1904. }
  1905. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1906. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1907. c.ServeJSON()
  1908. return
  1909. }
  1910. R_DeviceClass, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1911. if err != nil {
  1912. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1913. c.ServeJSON()
  1914. return
  1915. }
  1916. if R_DeviceClass.T_pid != c.T_pid {
  1917. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1918. c.ServeJSON()
  1919. return
  1920. }
  1921. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1922. if len(DeviceSensor_class_list) == 0 {
  1923. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1924. c.ServeJSON()
  1925. return
  1926. }
  1927. if err = Company.Delete_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1928. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知删除绑定失败"}
  1929. c.ServeJSON()
  1930. return
  1931. }
  1932. if err = Device.DeviceSensor_Bind_T_Notice_Del(T_sn, T_id, T_notice_id); err != nil {
  1933. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知删除绑定失败"}
  1934. c.ServeJSON()
  1935. return
  1936. }
  1937. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "通知删除绑定删除", strconv.Itoa(T_notice_id)+"->"+T_sn+"-"+strconv.Itoa(T_id))
  1938. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1939. c.ServeJSON()
  1940. return
  1941. }
  1942. func (c *DeviceController) NoticeBind_Add_All() {
  1943. T_notice_id, _ := c.GetInt("T_notice_id")
  1944. T_snid := c.GetString("T_snid")
  1945. if T_notice_id == 0 {
  1946. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1947. c.ServeJSON()
  1948. return
  1949. }
  1950. T_snid_list := strings.Split(strings.Trim(T_snid, "|"), "|")
  1951. for _, v := range T_snid_list {
  1952. sn_id := strings.Split(v, ",")
  1953. T_sn := sn_id[0]
  1954. T_id := lib.To_int(sn_id[1])
  1955. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1956. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1957. c.ServeJSON()
  1958. return
  1959. }
  1960. R_CompanyNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1961. if err != nil {
  1962. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1963. c.ServeJSON()
  1964. return
  1965. }
  1966. if R_CompanyNotice.T_pid != c.T_pid {
  1967. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1968. c.ServeJSON()
  1969. return
  1970. }
  1971. DeviceSensor_Notice_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1972. if len(DeviceSensor_Notice_list) > 0 {
  1973. continue
  1974. }
  1975. if err = Company.Add_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1976. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1977. c.ServeJSON()
  1978. return
  1979. }
  1980. if err = Device.DeviceSensor_Bind_T_Notice_Add(T_sn, T_id, T_notice_id); err != nil {
  1981. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1982. c.ServeJSON()
  1983. return
  1984. }
  1985. }
  1986. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略一键绑定", strconv.Itoa(T_notice_id)+"+>"+T_snid)
  1987. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1988. c.ServeJSON()
  1989. return
  1990. }
  1991. func (c *DeviceController) NoticeBind_Del_All() {
  1992. T_notice_id, _ := c.GetInt("T_notice_id")
  1993. T_snid := c.GetString("T_snid")
  1994. if T_notice_id == 0 {
  1995. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1996. c.ServeJSON()
  1997. return
  1998. }
  1999. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  2000. if err != nil {
  2001. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  2002. c.ServeJSON()
  2003. return
  2004. }
  2005. if R_DeviceNotice.T_pid != c.T_pid {
  2006. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  2007. c.ServeJSON()
  2008. return
  2009. }
  2010. Device_lite, _ := Device.Read_DeviceSensor_List_T_Notice(c.T_pid, T_notice_id, 0, 9999, "", "", 0)
  2011. for _, sensor := range Device_lite {
  2012. T_sn := sensor.T_sn
  2013. T_id := sensor.T_id
  2014. if _, err = Device.Read_Device_ByT_sn(T_sn); err != nil {
  2015. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  2016. c.ServeJSON()
  2017. return
  2018. }
  2019. if R_DeviceNotice.T_pid != c.T_pid {
  2020. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  2021. c.ServeJSON()
  2022. return
  2023. }
  2024. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  2025. if len(DeviceSensor_class_list) == 0 {
  2026. continue
  2027. }
  2028. if err = Company.Delete_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  2029. c.Data["json"] = lib.JSONS{Code: 200, Msg: "报警策略删除失败"}
  2030. c.ServeJSON()
  2031. return
  2032. }
  2033. if err = Device.DeviceSensor_Bind_T_Notice_Del(T_sn, T_id, T_notice_id); err != nil {
  2034. c.Data["json"] = lib.JSONS{Code: 200, Msg: "报警策略删除失败"}
  2035. c.ServeJSON()
  2036. return
  2037. }
  2038. }
  2039. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略一键删除", strconv.Itoa(T_notice_id)+"->"+T_snid)
  2040. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  2041. c.ServeJSON()
  2042. return
  2043. }
  2044. // 传感器类型
  2045. func (c *DeviceController) DeviceSensorType_List_All() {
  2046. type R_JSONS struct {
  2047. //必须的大写开头
  2048. Data []Device.DeviceSensorType
  2049. Num int64
  2050. Page int
  2051. Page_size int
  2052. }
  2053. var r_jsons R_JSONS
  2054. r_jsons.Data = Device.Read_DeviceSensorType_List_All()
  2055. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2056. c.ServeJSON()
  2057. return
  2058. }
  2059. // 传感器类型 - 小程序
  2060. func (c *DeviceController) DeviceSensorType_List() {
  2061. var r_jsons lib.R_JSONS
  2062. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2063. if err != nil {
  2064. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2065. c.ServeJSON()
  2066. return
  2067. }
  2068. var T_pids []int
  2069. if c.Admin_r.T_pid > 0 {
  2070. // 查询公司
  2071. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2072. if err != nil {
  2073. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2074. c.ServeJSON()
  2075. return
  2076. }
  2077. // 查询公司下面所有子公司id
  2078. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2079. }
  2080. list, err := Device.Read_DeviceSensor_T_type(c.Admin_r, c.T_pid, bindSN, T_pids)
  2081. if err != nil {
  2082. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2083. c.ServeJSON()
  2084. return
  2085. }
  2086. if len(list) == 0 {
  2087. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2088. c.ServeJSON()
  2089. return
  2090. }
  2091. var ids []int
  2092. for _, v := range list {
  2093. id, _ := strconv.Atoi(v.(string))
  2094. ids = append(ids, id)
  2095. }
  2096. r_jsons.Data = Device.Read_DeviceSensorType_List_By_Ids(ids)
  2097. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2098. c.ServeJSON()
  2099. return
  2100. }
  2101. // 设备统计 - 小程序
  2102. func (c *DeviceController) Device_Applet_Stat() {
  2103. type Online struct {
  2104. T_type int
  2105. Count int64
  2106. Online int64 // 监控
  2107. NoNetwork int64 // 无网络
  2108. NotEnabled int64 // 未启用
  2109. }
  2110. type R_JSONS struct {
  2111. //必须的大写开头
  2112. Data Online
  2113. }
  2114. T_type, T_type_err := c.GetInt("T_type")
  2115. if T_type_err != nil || T_type == 0 {
  2116. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_type Err!"}
  2117. c.ServeJSON()
  2118. return
  2119. }
  2120. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2121. if err != nil {
  2122. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2123. c.ServeJSON()
  2124. return
  2125. }
  2126. var T_pids []int
  2127. if c.Admin_r.T_pid > 0 {
  2128. // 查询公司
  2129. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2130. if err != nil {
  2131. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2132. c.ServeJSON()
  2133. return
  2134. }
  2135. // 查询公司下面所有子公司id
  2136. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2137. }
  2138. snList, err := Device.Read_DeviceSensor_T_sn_ByT_type(c.Admin_r, c.T_pid, bindSN, T_pids, T_type)
  2139. if err != nil {
  2140. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2141. c.ServeJSON()
  2142. return
  2143. }
  2144. var r_jsons R_JSONS
  2145. r_jsons.Data.T_type = T_type
  2146. if len(snList) == 0 {
  2147. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2148. c.ServeJSON()
  2149. return
  2150. }
  2151. // 0 未启用 1 在线 2 离线
  2152. r_jsons.Data.Count = Device.Read_Device_Count_ByT_online(snList, "")
  2153. r_jsons.Data.Online = Device.Read_Device_Count_ByT_online(snList, "1")
  2154. r_jsons.Data.NoNetwork = Device.Read_Device_Count_ByT_online(snList, "2")
  2155. r_jsons.Data.NotEnabled = Device.Read_Device_Count_ByT_online(snList, "0")
  2156. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2157. c.ServeJSON()
  2158. return
  2159. }
  2160. // 传感器列表 - 小程序 View==1
  2161. func (c *DeviceController) DeviceSensor_Applet_List_View1() {
  2162. var r_jsons lib.R_JSONS
  2163. page, _ := c.GetInt("page")
  2164. if page < 1 {
  2165. page = 1
  2166. }
  2167. page_z, _ := c.GetInt("page_z")
  2168. if page_z < 1 {
  2169. page_z = conf.Page_size
  2170. }
  2171. T_name := c.GetString("T_name")
  2172. //T_online := c.GetString("T_online")
  2173. T_type, T_type_err := c.GetInt("T_type")
  2174. if T_type_err != nil {
  2175. T_type = -1
  2176. }
  2177. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2178. if err != nil {
  2179. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2180. c.ServeJSON()
  2181. return
  2182. }
  2183. var T_pids []int
  2184. if c.Admin_r.T_pid > 0 {
  2185. // 查询公司
  2186. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2187. if err != nil {
  2188. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2189. c.ServeJSON()
  2190. return
  2191. }
  2192. // 查询公司下面所有子公司id
  2193. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2194. }
  2195. Account.Read_Company_All_Maps()
  2196. r_jsons.Data, r_jsons.Num = Device.Read_DeviceSensor_List_For_Applet(c.Admin_r, bindSN, c.T_pid, T_pids, T_name, "3", 1, T_type, page, page_z)
  2197. r_jsons.Page = page
  2198. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  2199. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2200. c.ServeJSON()
  2201. return
  2202. }
  2203. // 传感器列表 - 小程序 View==2
  2204. func (c *DeviceController) DeviceSensor_Applet_List_View2() {
  2205. var r_jsons lib.R_JSONS
  2206. page, _ := c.GetInt("page")
  2207. if page < 1 {
  2208. page = 1
  2209. }
  2210. page_z, _ := c.GetInt("page_z")
  2211. if page_z < 1 {
  2212. page_z = conf.Page_size
  2213. }
  2214. T_name := c.GetString("T_name")
  2215. T_online := c.GetString("T_online")
  2216. T_type, T_type_err := c.GetInt("T_type")
  2217. if T_type_err != nil {
  2218. T_type = -1
  2219. }
  2220. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2221. if err != nil {
  2222. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2223. c.ServeJSON()
  2224. return
  2225. }
  2226. var T_pids []int
  2227. if c.Admin_r.T_pid > 0 {
  2228. // 查询公司
  2229. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2230. if err != nil {
  2231. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2232. c.ServeJSON()
  2233. return
  2234. }
  2235. // 查询公司下面所有子公司id
  2236. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2237. }
  2238. Account.Read_Company_All_Maps()
  2239. dsList, _ := Device.Read_DeviceSensor_List_For_Applet(c.Admin_r, bindSN, c.T_pid, T_pids, T_name, T_online, 1, T_type, page, 9999)
  2240. var deviceMap = make(map[string][]Device.DeviceSensor_Applet)
  2241. var num int64
  2242. type DeviceList struct {
  2243. T_sn string
  2244. DeviceSensorList []Device.DeviceSensor_Applet
  2245. }
  2246. var deviceList []DeviceList
  2247. for _, ds := range dsList {
  2248. _, ok := deviceMap[ds.T_sn]
  2249. if !ok {
  2250. num += 1
  2251. var list []Device.DeviceSensor_Applet
  2252. list = append(list, ds)
  2253. deviceMap[ds.T_sn] = list
  2254. device := DeviceList{
  2255. T_sn: ds.T_sn,
  2256. }
  2257. deviceList = append(deviceList, device)
  2258. } else {
  2259. deviceMap[ds.T_sn] = append(deviceMap[ds.T_sn], ds)
  2260. }
  2261. }
  2262. for i := 0; i < len(deviceList); i++ {
  2263. deviceList[i].DeviceSensorList = deviceMap[deviceList[i].T_sn]
  2264. }
  2265. var offset int
  2266. if page <= 1 {
  2267. offset = 0
  2268. } else {
  2269. offset = (page - 1) * page_z
  2270. }
  2271. offset_z := offset + page_z
  2272. if num < int64(offset_z) {
  2273. offset_z = int(num)
  2274. }
  2275. if offset > offset_z {
  2276. offset = offset_z
  2277. }
  2278. r_jsons.Data = deviceList[offset:offset_z]
  2279. r_jsons.Num = num
  2280. r_jsons.Page = page
  2281. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  2282. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2283. c.ServeJSON()
  2284. return
  2285. }
  2286. func Update_DeviceSensor_Parameter() {
  2287. list := Device.Read_DeviceSensor_All()
  2288. for _, sensor := range list {
  2289. dsp, is := Device.Read_DeviceSensorParameter(sensor.T_sn, sensor.T_id)
  2290. if !is {
  2291. continue
  2292. }
  2293. if sensor.T_sp == dsp.Id {
  2294. continue
  2295. }
  2296. sensor.T_sp = dsp.Id
  2297. Device.Update_DeviceSensor(sensor, "T_sp")
  2298. }
  2299. }
  2300. // 传感器列表 - 冷链物流运输客户端
  2301. func (c *DeviceController) DeviceSensor_List_BySN() {
  2302. type R_JSONS struct {
  2303. //必须的大写开头
  2304. Data []Device.DeviceSensor_R
  2305. Num int64
  2306. Page int
  2307. Page_size int
  2308. }
  2309. var r_jsons R_JSONS
  2310. T_sn := c.GetString("T_sn")
  2311. if len(T_sn) == 0 {
  2312. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn err!"}
  2313. c.ServeJSON()
  2314. return
  2315. }
  2316. r_jsons.Data, r_jsons.Num = Device.Read_DeviceSensorList_BySN(T_sn)
  2317. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2318. c.ServeJSON()
  2319. return
  2320. }
  2321. func (c *DeviceController) CompanyNoticeByUser() {
  2322. type R_JSONS struct {
  2323. //必须的大写开头
  2324. Data []Company.WarnTypes
  2325. Num int64
  2326. Page int
  2327. Page_size int
  2328. }
  2329. var r_jsons R_JSONS
  2330. T_name := c.GetString("T_name")
  2331. r_jsons.Data = Company.Read_CompanyNoticeByUser(c.T_pid, T_name)
  2332. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons.Data}
  2333. c.ServeJSON()
  2334. return
  2335. }