Device.go 70 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658
  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. //金卫信对接数据
  726. ProbeIdNo := c.GetString("probeIdNo")
  727. if len(ProbeIdNo) > 0 {
  728. DeviceSensor.ProbeIdNo = ProbeIdNo
  729. Device.Update_DeviceSensor(DeviceSensor, "probe_id_no")
  730. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 金卫信对接参数", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]"+ProbeIdNo)
  731. }
  732. c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK"}
  733. c.ServeJSON()
  734. return
  735. }
  736. // 删除传感器
  737. func (c *DeviceController) DeviceSensor_Del() {
  738. Sn := c.GetString("T_sn")
  739. Id, _ := c.GetInt("T_id")
  740. device, err := Device.Read_Device_ByT_sn(Sn)
  741. if err != nil {
  742. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  743. c.ServeJSON()
  744. return
  745. }
  746. _, is := Device.Read_DeviceSensor_ByT_sn(Sn, Id)
  747. if !is {
  748. c.Data["json"] = lib.JSONS{Code: 202, Msg: "信息错误!"}
  749. c.ServeJSON()
  750. return
  751. }
  752. // 0默认:从数据库删除 1:从设备删除
  753. T_mode, _ := c.GetInt("T_mode")
  754. if T_mode == 1 {
  755. Device.Delete_DeviceSensor_ById(Sn, Id)
  756. NatsServer.Del_DeviceSensor(Device.DeviceSensor_Del{
  757. T_sn: Sn, T_id: Id,
  758. }, device.T_mqttid)
  759. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 删除操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]")
  760. } else {
  761. Device.Delete_DeviceSensor_ById(Sn, Id)
  762. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器 删除操作", "SN:"+Sn+" ["+strconv.Itoa(Id)+"]")
  763. }
  764. c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK"}
  765. c.ServeJSON()
  766. return
  767. }
  768. // 传感器参数
  769. func (c *DeviceController) DeviceSensor_Parameter_Get() {
  770. Sn := c.GetString("T_sn")
  771. Id, _ := c.GetInt("T_id")
  772. device, err := Device.Read_Device_ByT_sn(Sn)
  773. if err != nil {
  774. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  775. c.ServeJSON()
  776. return
  777. }
  778. //c.Data["DeviceSensor"], _ = Device.Read_DeviceSensor_ByTsn_Tid(Sn, Id)
  779. DeviceSensorParameter_lite := Device.Read_DeviceSensorParameter_T_sn_T_id(Sn, Id)
  780. if len(DeviceSensorParameter_lite) == 0 {
  781. NatsServer.Read_DeviceSensorParameter(Sn, device.T_mqttid)
  782. c.Data["json"] = lib.JSONS{Code: 202, Msg: "未同步参数,请检查设备是否正常!"}
  783. c.ServeJSON()
  784. return
  785. }
  786. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceSensorParameter_lite}
  787. c.ServeJSON()
  788. return
  789. }
  790. // 传感器参数列表
  791. func (c *DeviceController) DeviceSensor_Parameter_List() {
  792. Sn := c.GetString("T_sn")
  793. Id, _ := c.GetInt("T_id")
  794. page, _ := c.GetInt("page")
  795. if page < 1 {
  796. page = 1
  797. }
  798. page_z, _ := c.GetInt("page_z")
  799. if page_z < 1 {
  800. page_z = conf.Page_size
  801. }
  802. DeviceSensorParameter_lite := Device.Read_DeviceSensorParameter_List(Sn, Id, 2, page, page_z)
  803. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: DeviceSensorParameter_lite}
  804. c.ServeJSON()
  805. return
  806. }
  807. // 修改传感器参数
  808. func (c *DeviceController) DeviceSensor_Parameter_Pu() {
  809. T_SN := c.GetString("T_sn")
  810. T_id, _ := c.GetInt("T_id")
  811. device, err := Device.Read_Device_ByT_sn(T_SN)
  812. if err != nil {
  813. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  814. c.ServeJSON()
  815. return
  816. }
  817. DeviceSensor, is := Device.Read_DeviceSensor_ByT_sn(T_SN, T_id)
  818. if !is {
  819. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id Err!"}
  820. c.ServeJSON()
  821. return
  822. }
  823. DeviceSensorParameter, is := Device.Read_DeviceSensorParameter(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. T_name := DeviceSensor.T_name
  830. if v := c.GetString("T_name"); len(v) > 0 {
  831. T_name = v
  832. }
  833. T_Tlower := DeviceSensorParameter.T_Tlower
  834. if v, T_Tlower_err := c.GetFloat("T_Tlower"); T_Tlower_err == nil {
  835. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  836. T_Tlower = float32(temp)
  837. }
  838. T_Tupper := DeviceSensorParameter.T_Tupper
  839. if v, T_Tupper_err := c.GetFloat("T_Tupper"); T_Tupper_err == nil {
  840. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  841. T_Tupper = float32(temp)
  842. }
  843. T_RHlower := DeviceSensorParameter.T_RHlower
  844. if v, T_RHlower_err := c.GetFloat("T_RHlower"); T_RHlower_err == nil {
  845. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  846. T_RHlower = float32(temp)
  847. }
  848. T_RHupper := DeviceSensorParameter.T_RHupper
  849. if v, T_RHupper_err := c.GetFloat("T_RHupper"); T_RHupper_err == nil {
  850. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  851. T_RHupper = float32(temp)
  852. }
  853. T_enprel := DeviceSensorParameter.T_enprel
  854. if v, T_enprel_err := c.GetInt("T_enprel"); T_enprel_err == nil {
  855. T_enprel = v
  856. }
  857. T_tprel := DeviceSensorParameter.T_tprel
  858. if v, T_tprel_err := c.GetFloat("T_tprel"); T_tprel_err == nil {
  859. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  860. T_tprel = float32(temp)
  861. }
  862. T_tpreu := DeviceSensorParameter.T_tpreu
  863. if v, T_tpreu_err := c.GetFloat("T_tpreu"); T_tpreu_err == nil {
  864. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  865. T_tpreu = float32(temp)
  866. }
  867. T_hprel := DeviceSensorParameter.T_hprel
  868. if v, T_hprel_err := c.GetFloat("T_hprel"); T_hprel_err == nil {
  869. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  870. T_hprel = float32(temp)
  871. }
  872. T_hpreu := DeviceSensorParameter.T_hpreu
  873. if v, T_hpreu_err := c.GetFloat("T_hpreu"); T_hpreu_err == nil {
  874. temp, _ := decimal.NewFromFloat(v).Round(2).Float64()
  875. T_hpreu = float32(temp)
  876. }
  877. T_enprelnote := DeviceSensorParameter.T_enprelnote
  878. if v, T_enprel_err := c.GetInt("T_enprelnote"); T_enprel_err == nil {
  879. T_enprelnote = v
  880. }
  881. //T_speed := DeviceSensorParameter.T_speed
  882. //if v, T_speed_err := c.GetInt("T_speed"); T_speed_err == nil {
  883. // T_speed = v
  884. //}
  885. //T_sense := DeviceSensorParameter.T_sense
  886. //if v, T_sense_err := c.GetInt("T_sense"); T_sense_err == nil {
  887. // T_sense = v
  888. //}
  889. T_en := DeviceSensorParameter.T_en
  890. if v, T_en_err := c.GetInt("T_en"); T_en_err == nil {
  891. T_en = v
  892. }
  893. T_free := DeviceSensorParameter.T_free
  894. if v, T_free_err := c.GetInt("T_free"); T_free_err == nil {
  895. T_free = v
  896. }
  897. dsp := Device.DeviceSensorParameter{
  898. T_sn: T_SN,
  899. T_id: T_id,
  900. T_name: T_name,
  901. T_Tlower: T_Tlower,
  902. T_Tupper: T_Tupper,
  903. T_RHlower: T_RHlower,
  904. T_RHupper: T_RHupper,
  905. //T_speed: T_speed,
  906. //T_sense: T_sense,
  907. T_en: T_en,
  908. T_free: T_free,
  909. T_enprel: T_enprel,
  910. T_tprel: T_tprel,
  911. T_tpreu: T_tpreu,
  912. T_hprel: T_hprel,
  913. T_hpreu: T_hpreu,
  914. T_enprelnote: T_enprelnote,
  915. T_uuid: c.Admin_r.T_uuid,
  916. T_SendState: 0,
  917. T_State: 2, // 用户提交
  918. }
  919. dsp, is = Device.Add_DeviceSensorParameter(dsp)
  920. if !is {
  921. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Add_DeviceSensorParameter Err!"}
  922. c.ServeJSON()
  923. return
  924. }
  925. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "传感器参数操作", dsp)
  926. // 更新名称
  927. if len(T_name) > 0 {
  928. DeviceSensor.T_name = T_name
  929. if is = Device.Update_DeviceSensor(DeviceSensor, "T_name"); !is {
  930. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Update_DeviceSensor Err!"}
  931. c.ServeJSON()
  932. return
  933. }
  934. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "修改传感器名称", DeviceSensor)
  935. }
  936. NatsServer.Pu_DeviceParameter_Sensor(dsp, device.T_mqttid)
  937. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  938. c.ServeJSON()
  939. return
  940. }
  941. // 传感器管理列表
  942. func (c *DeviceController) DeviceSensor_Manage_List() {
  943. type R_JSONS struct {
  944. //必须的大写开头
  945. Data []Device.DeviceSensor_P
  946. Num int64
  947. Page int
  948. Page_size int
  949. }
  950. var r_jsons R_JSONS
  951. page, _ := c.GetInt("page")
  952. if page < 1 {
  953. page = 1
  954. }
  955. page_z, _ := c.GetInt("page_z")
  956. if page_z < 1 {
  957. page_z = conf.Page_size
  958. }
  959. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  960. T_calss_id, _ := c.GetInt("T_calssid")
  961. if T_calss_id > 0 {
  962. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_calss_id)
  963. if err != nil {
  964. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  965. c.ServeJSON()
  966. return
  967. }
  968. if R_DeviceClass.T_pid != c.T_pid {
  969. c.Data["json"] = lib.JSONS{Code: 202, Msg: "CompanyClass.T_pid != T_pid Err!"}
  970. c.ServeJSON()
  971. return
  972. }
  973. }
  974. T_en, T_en_err := c.GetInt("T_en") //启用停用 0 停用 1 启用 空 所有
  975. if T_en_err != nil {
  976. T_en = -1
  977. }
  978. T_free, T_free_err := c.GetInt("T_free") // 空库 0 正常 1 空库 空 所有
  979. if T_free_err != nil {
  980. T_free = -1
  981. }
  982. T_datashow, T_datashow_err := c.GetInt("T_datashow") //数据展示 空 全部 0 屏蔽数据展示 1 正常数据展示
  983. if T_datashow_err != nil {
  984. T_datashow = -1
  985. }
  986. T_sort, T_sort_err := c.GetInt("T_sort") //排序 空 升序 1 降序
  987. if T_sort_err != nil {
  988. T_sort = -1
  989. }
  990. T_abandon, _ := c.GetInt("T_abandon")
  991. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  992. if err != nil {
  993. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  994. c.ServeJSON()
  995. return
  996. }
  997. 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)
  998. r_jsons.Page = page
  999. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1000. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1001. c.ServeJSON()
  1002. return
  1003. }
  1004. // 导出传感器管理列表
  1005. func (c *DeviceController) DeviceSensor_Manage_List_Excel() {
  1006. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  1007. T_calss_id, _ := c.GetInt("T_calssid")
  1008. if T_calss_id > 0 {
  1009. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_calss_id)
  1010. if err != nil {
  1011. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1012. c.ServeJSON()
  1013. return
  1014. }
  1015. if R_DeviceClass.T_pid != c.T_pid {
  1016. c.Data["json"] = lib.JSONS{Code: 202, Msg: "CompanyClass.T_pid != T_pid Err!"}
  1017. c.ServeJSON()
  1018. return
  1019. }
  1020. }
  1021. T_en, T_en_err := c.GetInt("T_en") //启用停用 0 停用 1 启用 空 所有
  1022. if T_en_err != nil {
  1023. T_en = -1
  1024. }
  1025. T_free, T_free_err := c.GetInt("T_free") // 空库 0 正常 1 空库 空 所有
  1026. if T_free_err != nil {
  1027. T_free = -1
  1028. }
  1029. T_datashow, T_datashow_err := c.GetInt("T_datashow") //数据展示 空 全部 0 屏蔽数据展示 1 正常数据展示
  1030. if T_datashow_err != nil {
  1031. T_datashow = -1
  1032. }
  1033. T_sort, T_sort_err := c.GetInt("T_sort") //排序 空 升序 1 降序
  1034. if T_sort_err != nil {
  1035. T_sort = -1
  1036. }
  1037. T_abandon, _ := c.GetInt("T_abandon")
  1038. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  1039. if err != nil {
  1040. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1041. c.ServeJSON()
  1042. return
  1043. }
  1044. 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)
  1045. f := excelize.NewFile() //设置单元格值
  1046. // 这里设置表头ÒÒ
  1047. Style1, _ := f.NewStyle(
  1048. &excelize.Style{
  1049. Font: &excelize.Font{Size: 20, Family: "宋体"},
  1050. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center"},
  1051. })
  1052. Style2, _ := f.NewStyle(
  1053. &excelize.Style{
  1054. Font: &excelize.Font{Size: 15, Family: "宋体"},
  1055. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1056. Border: []excelize.Border{
  1057. {Type: "left", Color: "000000", Style: 1},
  1058. {Type: "top", Color: "000000", Style: 1},
  1059. {Type: "bottom", Color: "000000", Style: 1},
  1060. {Type: "right", Color: "000000", Style: 1},
  1061. },
  1062. Fill: excelize.Fill{Type: "pattern", Color: []string{"D9D9D9"}, Pattern: 1},
  1063. })
  1064. Style3, _ := f.NewStyle(
  1065. &excelize.Style{
  1066. Font: &excelize.Font{Size: 15, Family: "宋体"},
  1067. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1068. Border: []excelize.Border{
  1069. {Type: "left", Color: "000000", Style: 1},
  1070. {Type: "top", Color: "000000", Style: 1},
  1071. {Type: "bottom", Color: "000000", Style: 1},
  1072. {Type: "right", Color: "000000", Style: 1},
  1073. },
  1074. })
  1075. f.MergeCell("Sheet1", "A1", "T1")
  1076. f.SetCellValue("Sheet1", "A1", "设备管理")
  1077. f.SetCellStyle("Sheet1", "A1", "T1", Style1)
  1078. // 写入表头
  1079. headers := []string{"序号", "公司名称", "SN", "编号", "分类", "规格", "传感器名称", "传感器类型", "启/停", "空库", "温度范围(℃)",
  1080. "湿度范围(%)", "预警", "预警温度范围", "预警湿度范围", "数据展示",
  1081. "验证日期", "验证到期时间", "校准日期", "校准到期时间"}
  1082. for col, header := range headers {
  1083. cell := fmt.Sprintf("%c%d", rune('A'+col), 2)
  1084. f.SetCellValue("Sheet1", cell, header)
  1085. }
  1086. // 这里设置表头
  1087. f.SetCellStyle("Sheet1", "A2", "T2", Style2)
  1088. f.SetRowHeight("Sheet1", 2, 25)
  1089. colsWidth := []float64{6, 30, 22, 10, 15, 15, 25, 15, 12, 12, 15, 15, 12, 15, 15, 15, 15, 15, 15, 15}
  1090. for col, width := range colsWidth {
  1091. cell := fmt.Sprintf("%c", rune('A'+col))
  1092. f.SetColWidth("Sheet1", cell, cell, width)
  1093. }
  1094. Company_r, err := Account.Read_Company_ById(c.T_pid)
  1095. if err != nil {
  1096. c.Data["json"] = lib.JSONS{Code: 202, Msg: "获取公司信息失败!"}
  1097. c.ServeJSON()
  1098. return
  1099. }
  1100. line := 2
  1101. for i, v := range DeviceSensor_data {
  1102. // 写入数据
  1103. line++
  1104. f.SetCellValue("Sheet1", fmt.Sprintf("A%d", line), i+1)
  1105. f.SetCellValue("Sheet1", fmt.Sprintf("B%d", line), Company_r.T_name) // 公司名称
  1106. f.SetCellValue("Sheet1", fmt.Sprintf("C%d", line), v.T_sn)
  1107. f.SetCellValue("Sheet1", fmt.Sprintf("D%d", line), v.T_id)
  1108. classList, specList := []string{}, []string{}
  1109. for _, r := range v.T_CompanyClassList {
  1110. if len(r.T_name) > 0 {
  1111. classList = append(classList, r.T_name)
  1112. }
  1113. if len(r.T_spec) > 0 {
  1114. specList = append(specList, r.T_spec)
  1115. }
  1116. }
  1117. f.SetCellValue("Sheet1", fmt.Sprintf("E%d", line), strings.Join(classList, "/")) // 分类
  1118. f.SetCellValue("Sheet1", fmt.Sprintf("F%d", line), strings.Join(specList, "/")) // 规格
  1119. f.SetCellValue("Sheet1", fmt.Sprintf("G%d", line), v.T_name)
  1120. f.SetCellValue("Sheet1", fmt.Sprintf("H%d", line), v.T_type_name)
  1121. T_en_str := "启用"
  1122. if v.T_en != nil && *v.T_en == 0 {
  1123. T_en_str = "停用"
  1124. }
  1125. f.SetCellValue("Sheet1", fmt.Sprintf("I%d", line), T_en_str)
  1126. T_free_str := "正常"
  1127. if v.T_free != nil && *v.T_free == 1 {
  1128. T_free_str = "停用"
  1129. }
  1130. f.SetCellValue("Sheet1", fmt.Sprintf("J%d", line), T_free_str)
  1131. T_Tlower, T_Tupper, T_RHlower, T_RHupper := "0", "0", "0", "0"
  1132. if v.T_Tlower != nil {
  1133. T_Tlower = fmt.Sprintf("%.0f", *v.T_Tlower)
  1134. }
  1135. if v.T_Tupper != nil {
  1136. T_Tupper = fmt.Sprintf("%.0f", *v.T_Tupper)
  1137. }
  1138. if v.T_RHlower != nil {
  1139. T_RHlower = fmt.Sprintf("%.0f", *v.T_RHlower)
  1140. }
  1141. if v.T_RHupper != nil {
  1142. T_RHupper = fmt.Sprintf("%.0f", *v.T_RHupper)
  1143. }
  1144. f.SetCellValue("Sheet1", fmt.Sprintf("K%d", line), fmt.Sprintf("%s ~ %s", T_Tlower, T_Tupper))
  1145. f.SetCellValue("Sheet1", fmt.Sprintf("L%d", line), fmt.Sprintf("%s ~ %s", T_RHlower, T_RHupper))
  1146. T_enprel_str := "开启"
  1147. if v.T_enprel != nil && *v.T_enprel == 0 {
  1148. T_enprel_str = "关闭"
  1149. }
  1150. f.SetCellValue("Sheet1", fmt.Sprintf("M%d", line), T_enprel_str)
  1151. T_tprel, T_tpreu, T_hprel, T_hpreu := "0", "0", "0", "0"
  1152. if v.T_tprel != nil {
  1153. T_tprel = fmt.Sprintf("%.0f", *v.T_tprel)
  1154. }
  1155. if v.T_tpreu != nil {
  1156. T_tpreu = fmt.Sprintf("%.0f", *v.T_tpreu)
  1157. }
  1158. if v.T_hprel != nil {
  1159. T_hprel = fmt.Sprintf("%.0f", *v.T_hprel)
  1160. }
  1161. if v.T_hpreu != nil {
  1162. T_hpreu = fmt.Sprintf("%.0f", *v.T_hpreu)
  1163. }
  1164. f.SetCellValue("Sheet1", fmt.Sprintf("N%d", line), fmt.Sprintf("%s ~ %s", T_tprel, T_tpreu))
  1165. f.SetCellValue("Sheet1", fmt.Sprintf("O%d", line), fmt.Sprintf("%s ~ %s", T_hprel, T_hpreu))
  1166. T_datashow_str := "屏蔽"
  1167. if v.T_datashow == 1 {
  1168. T_datashow_str = "显示"
  1169. }
  1170. f.SetCellValue("Sheet1", fmt.Sprintf("P%d", line), T_datashow_str)
  1171. f.SetCellValue("Sheet1", fmt.Sprintf("Q%d", line), v.T_Device.T_VerifyTime)
  1172. f.SetCellValue("Sheet1", fmt.Sprintf("R%d", line), v.T_Device.T_VerifyEndTime)
  1173. f.SetCellValue("Sheet1", fmt.Sprintf("S%d", line), v.T_Device.T_CalibrationTime)
  1174. f.SetCellValue("Sheet1", fmt.Sprintf("T%d", line), v.T_Device.T_CalibrationEndTime)
  1175. }
  1176. f.SetCellStyle("Sheet1", "A3", fmt.Sprintf("T%d", line), Style3)
  1177. timeStr := Company_r.T_name + "设备管理(" + lib.GetRandstring(6, "0123456789", 0) + ")"
  1178. // 保存文件
  1179. if err = f.SaveAs("ofile/" + timeStr + ".xlsx"); err != nil {
  1180. logs.Error(err)
  1181. }
  1182. // 上传 OSS
  1183. url, is := NatsServer.Qiniu_UploadFile(lib.GetCurrentDirectory()+"/ofile/"+timeStr+".xlsx", "ofile/"+timeStr+".xlsx")
  1184. if !is {
  1185. c.Data["json"] = lib.JSONS{Code: 202, Msg: "oss!"}
  1186. c.ServeJSON()
  1187. return
  1188. }
  1189. //删除目录
  1190. err = os.Remove("ofile/" + timeStr + ".xlsx")
  1191. if err != nil {
  1192. logs.Error(err)
  1193. }
  1194. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: url}
  1195. c.ServeJSON()
  1196. return
  1197. }
  1198. // 传感器列表-报警策略
  1199. func (c *DeviceController) DeviceSensor_Notice_UnbindList() {
  1200. type R_JSONS struct {
  1201. //必须的大写开头
  1202. Data []Device.DeviceSensor_
  1203. Num int64
  1204. Page int
  1205. Page_size int
  1206. }
  1207. var r_jsons R_JSONS
  1208. page, _ := c.GetInt("page")
  1209. if page < 1 {
  1210. page = 1
  1211. }
  1212. page_z, _ := c.GetInt("page_z")
  1213. if page_z < 1 {
  1214. page_z = conf.Page_size
  1215. }
  1216. T_class_id, _ := c.GetInt("T_calssid")
  1217. T_notice_id, _ := c.GetInt("T_notice_id")
  1218. T_name := c.GetString("T_name") // 包含 T_name、T_sn
  1219. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  1220. if err != nil {
  1221. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1222. c.ServeJSON()
  1223. return
  1224. }
  1225. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1226. if err != nil {
  1227. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1228. c.ServeJSON()
  1229. return
  1230. }
  1231. if R_DeviceNotice.T_pid != c.T_pid {
  1232. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1233. c.ServeJSON()
  1234. return
  1235. }
  1236. var cnt int64
  1237. 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)
  1238. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1239. r_jsons.Page = page
  1240. r_jsons.Page_size = int(page_size)
  1241. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1242. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1243. c.ServeJSON()
  1244. return
  1245. }
  1246. // 设备任务 ------------------------------------------
  1247. // 任务列表
  1248. func (c *DeviceController) DeviceTask_List() {
  1249. type R_JSONS struct {
  1250. //必须的大写开头
  1251. Data []Device.DeviceTask
  1252. Num int64
  1253. Page int
  1254. Page_size int
  1255. }
  1256. var r_jsons R_JSONS
  1257. page, _ := c.GetInt("page")
  1258. if page < 1 {
  1259. page = 1
  1260. }
  1261. page_z, _ := c.GetInt("page_z")
  1262. if page_z < 1 {
  1263. page_z = conf.Page_size
  1264. }
  1265. T_sn := c.GetString("T_sn")
  1266. Time_start := c.GetString("Time_start")
  1267. Time_end := c.GetString("Time_end")
  1268. if len(T_sn) < 6 {
  1269. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn!!!"}
  1270. c.ServeJSON()
  1271. return
  1272. }
  1273. r_jsons.Data, r_jsons.Num = Device.Read_DeviceTask_List(T_sn, Time_start, Time_end, page, page_z)
  1274. r_jsons.Page = page
  1275. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1276. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1277. c.ServeJSON()
  1278. return
  1279. }
  1280. func (c *DeviceController) DeviceTask_All() {
  1281. var r_jsons lib.R_JSONS
  1282. T_sn := c.GetString("T_sn")
  1283. if len(T_sn) < 6 {
  1284. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn!!!"}
  1285. c.ServeJSON()
  1286. return
  1287. }
  1288. r_jsons.Data, r_jsons.Num = Device.Read_DeviceTask_All(T_sn)
  1289. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1290. c.ServeJSON()
  1291. return
  1292. }
  1293. // 任务启停
  1294. func (c *DeviceController) DeviceTask_Post() {
  1295. T_sn := c.GetString("T_sn")
  1296. T_task := c.GetString("T_task")
  1297. device, err := Device.Read_Device_ByT_sn(T_sn)
  1298. if err != nil {
  1299. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1300. c.ServeJSON()
  1301. return
  1302. }
  1303. NatsServer.Set_DeviceTask(Device.Device_task{
  1304. T_sn: T_sn,
  1305. T_task: T_task,
  1306. }, device.T_mqttid)
  1307. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "远程启停", T_sn+"-"+T_task)
  1308. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1309. c.ServeJSON()
  1310. return
  1311. }
  1312. // 设备分类 ------------------------------------------
  1313. func (c *DeviceController) CompanyClass_List() {
  1314. type R_JSONS struct {
  1315. //必须的大写开头
  1316. Data []Company.CompanyClass_R
  1317. Num int64
  1318. Page int
  1319. Page_size int
  1320. }
  1321. var r_jsons R_JSONS
  1322. page, _ := c.GetInt("page")
  1323. if page < 1 {
  1324. page = 1
  1325. }
  1326. page_z, _ := c.GetInt("page_z")
  1327. if page_z < 1 {
  1328. page_z = conf.Page_size
  1329. }
  1330. T_name := c.GetString("T_name")
  1331. r_jsons.Data, r_jsons.Num = Company.Read_CompanyClass_List(c.T_pid, T_name, page, page_z)
  1332. r_jsons.Page = page
  1333. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1334. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1335. c.ServeJSON()
  1336. return
  1337. }
  1338. func (c *DeviceController) CompanyClass_All() {
  1339. type R_JSONS struct {
  1340. //必须的大写开头
  1341. Data []Company.CompanyClass_R
  1342. Num int64
  1343. Page int
  1344. Page_size int
  1345. }
  1346. var r_jsons R_JSONS
  1347. T_name := c.GetString("T_name")
  1348. r_jsons.Data = Company.Read_CompanyClass_All(c.T_pid, T_name)
  1349. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1350. c.ServeJSON()
  1351. return
  1352. }
  1353. // 查询公司及公司下所有子公司的公司分类
  1354. func (c *DeviceController) CompanyClass_All_For_Company() {
  1355. var r_jsons lib.R_JSONS
  1356. T_name := c.GetString("T_name")
  1357. // 查询公司
  1358. Company_r, err := Account.Read_Company_ById(c.T_pid)
  1359. if err != nil {
  1360. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1361. c.ServeJSON()
  1362. return
  1363. }
  1364. // 查询公司下面所有子公司id
  1365. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  1366. Account.Read_Company_All_Maps()
  1367. r_jsons.Data = Company.Read_CompanyClass_All_For_Company(T_pids, T_name)
  1368. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1369. c.ServeJSON()
  1370. return
  1371. }
  1372. func (c *DeviceController) CompanyClass_Get() {
  1373. id, _ := c.GetInt("T_id")
  1374. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1375. if err != nil {
  1376. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1377. c.ServeJSON()
  1378. return
  1379. }
  1380. if R_DeviceClass.T_pid != c.T_pid {
  1381. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1382. c.ServeJSON()
  1383. return
  1384. }
  1385. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Company.CompanyClassToCompanyClass_R(R_DeviceClass)}
  1386. c.ServeJSON()
  1387. return
  1388. }
  1389. func (c *DeviceController) CompanyClass_Add() {
  1390. T_name := c.GetString("T_name")
  1391. T_spec := c.GetString("T_spec")
  1392. t_c := Company.CompanyClass{
  1393. T_pid: c.T_pid,
  1394. T_name: T_name,
  1395. T_State: 1,
  1396. T_spec: T_spec,
  1397. }
  1398. Id, err := Company.Add_CompanyClass(t_c)
  1399. if err != nil {
  1400. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败"}
  1401. c.ServeJSON()
  1402. return
  1403. }
  1404. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "分类添加", t_c)
  1405. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
  1406. c.ServeJSON()
  1407. return
  1408. }
  1409. func (c *DeviceController) CompanyClass_Edit() {
  1410. T_name := c.GetString("T_name")
  1411. id, _ := c.GetInt("T_id")
  1412. T_spec := c.GetString("T_spec")
  1413. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1414. if err != nil {
  1415. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1416. c.ServeJSON()
  1417. return
  1418. }
  1419. if R_DeviceClass.T_pid != c.T_pid {
  1420. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1421. c.ServeJSON()
  1422. return
  1423. }
  1424. if len(T_name) > 0 {
  1425. R_DeviceClass.T_name = T_name
  1426. }
  1427. if len(T_name) > 0 {
  1428. R_DeviceClass.T_spec = T_spec
  1429. }
  1430. if is := Company.Update_CompanyClass(R_DeviceClass, "T_name", "T_spec"); !is {
  1431. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1432. c.ServeJSON()
  1433. return
  1434. }
  1435. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "分类修改", R_DeviceClass)
  1436. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1437. c.ServeJSON()
  1438. return
  1439. }
  1440. func (c *DeviceController) CompanyClass_Del() {
  1441. id, _ := c.GetInt("T_id")
  1442. R_DeviceClass, err := Company.Read_CompanyClass_ById(id)
  1443. if err != nil {
  1444. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1445. c.ServeJSON()
  1446. return
  1447. }
  1448. if R_DeviceClass.T_pid != c.T_pid {
  1449. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1450. c.ServeJSON()
  1451. return
  1452. }
  1453. if is := Company.Delete_CompanyClass_ById(id); !is {
  1454. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败"}
  1455. c.ServeJSON()
  1456. return
  1457. }
  1458. // 将传感器T_Class绑定的分类id替换为空字符串
  1459. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_Class_Id(id)
  1460. for _, v := range DeviceSensor_class_list {
  1461. Device.DeviceSensor_Bind_T_Class_Del(v.T_sn, v.T_id, id)
  1462. }
  1463. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类删除", strconv.Itoa(id))
  1464. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1465. c.ServeJSON()
  1466. return
  1467. }
  1468. // 设备分类绑定
  1469. func (c *DeviceController) DeviceClassBind_List() {
  1470. type R_JSONS struct {
  1471. //必须的大写开头
  1472. DeviceSensor_lite []Device.DeviceSensor_
  1473. Num int
  1474. Page int
  1475. Page_size int
  1476. Pages []lib.Page_T
  1477. }
  1478. var r_jsons R_JSONS
  1479. page, _ := c.GetInt("page")
  1480. if page < 1 {
  1481. page = 1
  1482. }
  1483. page_z, _ := c.GetInt("page_z")
  1484. if page_z < 1 {
  1485. page_z = conf.Page_size
  1486. }
  1487. T_name := c.GetString("T_name")
  1488. T_sn := c.GetString("T_sn")
  1489. T_class_id, _ := c.GetInt("T_class_id")
  1490. T_type, _ := c.GetInt("T_type")
  1491. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1492. if err != nil {
  1493. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1494. c.ServeJSON()
  1495. return
  1496. }
  1497. if R_DeviceClass.T_pid != c.T_pid {
  1498. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1499. c.ServeJSON()
  1500. return
  1501. }
  1502. var cnt int64
  1503. Device_lite, cnt := Device.Read_DeviceSensor_List_T_Class(c.T_pid, T_class_id, T_sn, T_name, T_type, page, page_z)
  1504. r_jsons.DeviceSensor_lite = Device_lite
  1505. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1506. r_jsons.Page = page
  1507. r_jsons.Page_size = int(page_size)
  1508. r_jsons.Pages = lib.Func_page(int64(page), int64(page_size))
  1509. r_jsons.Num = int(cnt)
  1510. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1511. c.ServeJSON()
  1512. return
  1513. }
  1514. func (c *DeviceController) ClassBind_Add() {
  1515. T_class_id, _ := c.GetInt("T_class_id")
  1516. T_sn := c.GetString("T_sn")
  1517. T_id, _ := c.GetInt("T_id")
  1518. if T_class_id == 0 || len(T_sn) == 0 {
  1519. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1520. c.ServeJSON()
  1521. return
  1522. }
  1523. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1524. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1525. c.ServeJSON()
  1526. return
  1527. }
  1528. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1529. if err != nil {
  1530. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1531. c.ServeJSON()
  1532. return
  1533. }
  1534. if R_DeviceClass.T_pid != c.T_pid {
  1535. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1536. c.ServeJSON()
  1537. return
  1538. }
  1539. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Class(T_sn, T_id, T_class_id)
  1540. if len(DeviceSensor_class_list) > 0 {
  1541. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1542. c.ServeJSON()
  1543. return
  1544. }
  1545. if err = Device.DeviceSensor_Bind_T_Class_Add(T_sn, T_id, T_class_id); err != nil {
  1546. c.Data["json"] = lib.JSONS{Code: 200, Msg: "绑定失败"}
  1547. c.ServeJSON()
  1548. return
  1549. }
  1550. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类绑定操作", strconv.Itoa(T_class_id)+"+>"+T_sn+"-"+strconv.Itoa(T_id))
  1551. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1552. c.ServeJSON()
  1553. return
  1554. }
  1555. func (c *DeviceController) ClassBind_Del() {
  1556. T_class_id, _ := c.GetInt("T_class_id")
  1557. T_sn := c.GetString("T_sn")
  1558. T_id, _ := c.GetInt("T_id")
  1559. if T_class_id == 0 || len(T_sn) == 0 {
  1560. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1561. c.ServeJSON()
  1562. return
  1563. }
  1564. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1565. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1566. c.ServeJSON()
  1567. return
  1568. }
  1569. R_DeviceClass, err := Company.Read_CompanyClass_ById(T_class_id)
  1570. if err != nil {
  1571. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1572. c.ServeJSON()
  1573. return
  1574. }
  1575. if R_DeviceClass.T_pid != c.T_pid {
  1576. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1577. c.ServeJSON()
  1578. return
  1579. }
  1580. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Class(T_sn, T_id, T_class_id)
  1581. if len(DeviceSensor_class_list) == 0 {
  1582. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1583. c.ServeJSON()
  1584. return
  1585. }
  1586. if err = Device.DeviceSensor_Bind_T_Class_Del(T_sn, T_id, T_class_id); err != nil {
  1587. c.Data["json"] = lib.JSONS{Code: 200, Msg: "删除失败"}
  1588. c.ServeJSON()
  1589. return
  1590. }
  1591. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "分类删除绑定操作", strconv.Itoa(T_class_id)+"->"+T_sn+"-"+strconv.Itoa(T_id))
  1592. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1593. c.ServeJSON()
  1594. return
  1595. }
  1596. // 报警策略 ------------------------------------------
  1597. func (c *DeviceController) CompanyNotice_List() {
  1598. type R_JSONS struct {
  1599. //必须的大写开头
  1600. Data []Company.CompanyNotice_R
  1601. Num int64
  1602. Page int
  1603. Page_size int
  1604. }
  1605. var r_jsons R_JSONS
  1606. page, _ := c.GetInt("page")
  1607. if page < 1 {
  1608. page = 1
  1609. }
  1610. page_z, _ := c.GetInt("page_z")
  1611. if page_z < 1 {
  1612. page_z = conf.Page_size
  1613. }
  1614. T_name := c.GetString("T_name")
  1615. r_jsons.Data, r_jsons.Num = Company.Read_CompanyNotice_List(c.T_pid, T_name, page, page_z)
  1616. r_jsons.Page = page
  1617. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1618. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1619. c.ServeJSON()
  1620. return
  1621. }
  1622. func (c *DeviceController) CompanyNotice_All() {
  1623. type R_JSONS struct {
  1624. //必须的大写开头
  1625. Data []Company.CompanyNotice_R
  1626. Num int64
  1627. Page int
  1628. Page_size int
  1629. }
  1630. var r_jsons R_JSONS
  1631. T_name := c.GetString("T_name")
  1632. r_jsons.Data = Company.Read_CompanyNotice_All(c.T_pid, T_name)
  1633. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1634. c.ServeJSON()
  1635. return
  1636. }
  1637. func (c *DeviceController) CompanyNotice_Get() {
  1638. id, _ := c.GetInt("T_id")
  1639. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1640. if err != nil {
  1641. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1642. c.ServeJSON()
  1643. return
  1644. }
  1645. if R_DeviceNotice.T_pid != c.T_pid {
  1646. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1647. c.ServeJSON()
  1648. return
  1649. }
  1650. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Company.CompanyNoticeToCompanyNotice_R(R_DeviceNotice)}
  1651. c.ServeJSON()
  1652. return
  1653. }
  1654. func (c *DeviceController) CompanyNotice_Add() {
  1655. T_name := c.GetString("T_name")
  1656. t_c := Company.CompanyNotice{
  1657. T_pid: c.T_pid,
  1658. T_name: T_name,
  1659. T_Notice_mechanism: Warning.Read_WarningType_All_T_Notice_mechanism(),
  1660. T_State: 1,
  1661. }
  1662. Id, err := Company.Add_CompanyNotice(t_c)
  1663. if err != nil {
  1664. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败"}
  1665. c.ServeJSON()
  1666. return
  1667. }
  1668. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略添加", t_c)
  1669. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
  1670. c.ServeJSON()
  1671. return
  1672. }
  1673. func (c *DeviceController) CompanyNotice_Edit() {
  1674. id, _ := c.GetInt("T_id")
  1675. T_name := c.GetString("T_name")
  1676. T_Notice_wx := c.GetString("T_Notice_wx")
  1677. T_Notice_wx2 := c.GetString("T_Notice_wx2")
  1678. T_Notice_app := c.GetString("T_Notice_app")
  1679. T_Notice_phone := c.GetString("T_Notice_phone")
  1680. T_Notice_message := c.GetString("T_Notice_message")
  1681. T_Notice_mailbox := c.GetString("T_Notice_mailbox")
  1682. T_Notice_mechanism := c.GetString("T_Notice_mechanism")
  1683. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1684. if err != nil {
  1685. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1686. c.ServeJSON()
  1687. return
  1688. }
  1689. if R_DeviceNotice.T_pid != c.T_pid {
  1690. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1691. c.ServeJSON()
  1692. return
  1693. }
  1694. R_DeviceNotice.Id = id
  1695. if len(T_name) > 0 {
  1696. R_DeviceNotice.T_name = T_name
  1697. }
  1698. if len(T_Notice_wx) > 0 {
  1699. if T_Notice_wx == "-" {
  1700. T_Notice_wx = ""
  1701. }
  1702. R_DeviceNotice.T_Notice_wx = T_Notice_wx
  1703. }
  1704. if len(T_Notice_wx2) > 0 {
  1705. if T_Notice_wx2 == "-" {
  1706. T_Notice_wx2 = ""
  1707. }
  1708. R_DeviceNotice.T_Notice_wx2 = T_Notice_wx2
  1709. }
  1710. if len(T_Notice_app) > 0 {
  1711. if T_Notice_app == "-" {
  1712. T_Notice_app = ""
  1713. }
  1714. R_DeviceNotice.T_Notice_app = T_Notice_app
  1715. }
  1716. if len(T_Notice_phone) > 0 {
  1717. if T_Notice_phone == "-" {
  1718. T_Notice_phone = ""
  1719. }
  1720. R_DeviceNotice.T_Notice_phone = T_Notice_phone
  1721. }
  1722. if len(T_Notice_message) > 0 {
  1723. R_DeviceNotice.T_Notice_message = T_Notice_message
  1724. }
  1725. if len(T_Notice_mailbox) > 0 {
  1726. if T_Notice_mailbox == "-" {
  1727. T_Notice_mailbox = ""
  1728. }
  1729. R_DeviceNotice.T_Notice_mailbox = T_Notice_mailbox
  1730. }
  1731. if len(T_Notice_mechanism) > 0 {
  1732. if T_Notice_mechanism == "-" {
  1733. T_Notice_mechanism = ""
  1734. }
  1735. R_DeviceNotice.T_Notice_mechanism = T_Notice_mechanism
  1736. }
  1737. 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 {
  1738. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1739. c.ServeJSON()
  1740. return
  1741. }
  1742. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略修改", R_DeviceNotice)
  1743. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1744. c.ServeJSON()
  1745. return
  1746. }
  1747. func (c *DeviceController) CompanyNotice_Reset_Mechanism() {
  1748. id, _ := c.GetInt("T_id")
  1749. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1750. if err != nil {
  1751. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1752. c.ServeJSON()
  1753. return
  1754. }
  1755. if R_DeviceNotice.T_pid != c.T_pid {
  1756. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1757. c.ServeJSON()
  1758. return
  1759. }
  1760. R_DeviceNotice.T_Notice_mechanism = Warning.Read_WarningType_All_T_Notice_mechanism()
  1761. if err = Company.Update_CompanyNotice(R_DeviceNotice, "T_Notice_mechanism"); err != nil {
  1762. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败"}
  1763. c.ServeJSON()
  1764. return
  1765. }
  1766. System.Add_UserLogs_T(c.Admin_r.T_uuid, "设备管理", "报警策略", R_DeviceNotice)
  1767. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1768. c.ServeJSON()
  1769. return
  1770. }
  1771. func (c *DeviceController) CompanyNotice_Del() {
  1772. id, _ := c.GetInt("T_id")
  1773. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(id)
  1774. if err != nil {
  1775. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1776. c.ServeJSON()
  1777. return
  1778. }
  1779. if R_DeviceNotice.T_pid != c.T_pid {
  1780. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1781. c.ServeJSON()
  1782. return
  1783. }
  1784. if is := Company.Delete_CompanyNotice_ById(id); !is {
  1785. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败"}
  1786. c.ServeJSON()
  1787. return
  1788. }
  1789. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_Notice_Id(id)
  1790. for _, v := range DeviceSensor_class_list {
  1791. Device.DeviceSensor_Bind_T_Notice_Del(v.T_sn, v.T_id, id)
  1792. }
  1793. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略删除", strconv.Itoa(id))
  1794. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1795. c.ServeJSON()
  1796. return
  1797. }
  1798. // 设备通知绑定
  1799. func (c *DeviceController) DeviceNoticeBind_List() {
  1800. type R_JSONS struct {
  1801. //必须的大写开头
  1802. DeviceSensor_lite []Device.DeviceSensor_
  1803. Num int
  1804. Page int
  1805. Page_size int
  1806. Pages []lib.Page_T
  1807. }
  1808. var r_jsons R_JSONS
  1809. page, _ := c.GetInt("page")
  1810. if page < 1 {
  1811. page = 1
  1812. }
  1813. page_z, _ := c.GetInt("page_z")
  1814. if page_z < 1 {
  1815. page_z = conf.Page_size
  1816. }
  1817. T_name := c.GetString("T_name")
  1818. T_sn := c.GetString("T_sn")
  1819. T_notice_id, _ := c.GetInt("T_notice_id")
  1820. T_type, _ := c.GetInt("T_type")
  1821. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1822. if err != nil {
  1823. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1824. c.ServeJSON()
  1825. return
  1826. }
  1827. if R_DeviceNotice.T_pid != c.T_pid {
  1828. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1829. c.ServeJSON()
  1830. return
  1831. }
  1832. var cnt int64
  1833. Device_lite, cnt := Device.Read_DeviceSensor_List_T_Notice(c.T_pid, T_notice_id, page, page_z, T_sn, T_name, T_type)
  1834. r_jsons.DeviceSensor_lite = Device_lite
  1835. page_size := math.Ceil(float64(cnt) / float64(page_z))
  1836. r_jsons.Page = page
  1837. r_jsons.Page_size = int(page_size)
  1838. r_jsons.Pages = lib.Func_page(int64(page), int64(page_size))
  1839. r_jsons.Num = int(cnt)
  1840. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1841. c.ServeJSON()
  1842. return
  1843. }
  1844. func (c *DeviceController) NoticeBind_Add() {
  1845. T_notice_id, _ := c.GetInt("T_notice_id")
  1846. T_sn := c.GetString("T_sn")
  1847. T_id, _ := c.GetInt("T_id")
  1848. if T_notice_id == 0 || len(T_sn) == 0 {
  1849. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_notice_id Err!"}
  1850. c.ServeJSON()
  1851. return
  1852. }
  1853. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1854. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1855. c.ServeJSON()
  1856. return
  1857. }
  1858. R_CompanyNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1859. if err != nil {
  1860. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1861. c.ServeJSON()
  1862. return
  1863. }
  1864. if R_CompanyNotice.T_pid != c.T_pid {
  1865. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1866. c.ServeJSON()
  1867. return
  1868. }
  1869. DeviceSensor_Notice_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1870. if len(DeviceSensor_Notice_list) > 0 {
  1871. c.Data["json"] = lib.JSONS{Code: 202, Msg: "重复绑定!"}
  1872. c.ServeJSON()
  1873. return
  1874. }
  1875. if err = Company.Add_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1876. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1877. c.ServeJSON()
  1878. return
  1879. }
  1880. if err = Device.DeviceSensor_Bind_T_Notice_Add(T_sn, T_id, T_notice_id); err != nil {
  1881. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1882. c.ServeJSON()
  1883. return
  1884. }
  1885. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略绑定添加", strconv.Itoa(T_notice_id)+"+>"+T_sn+"-"+strconv.Itoa(T_id))
  1886. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1887. c.ServeJSON()
  1888. return
  1889. }
  1890. func (c *DeviceController) NoticeBind_Del() {
  1891. T_notice_id, _ := c.GetInt("T_notice_id")
  1892. T_sn := c.GetString("T_sn")
  1893. T_id, _ := c.GetInt("T_id")
  1894. if T_notice_id == 0 || len(T_sn) == 0 {
  1895. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_notice_id Err!"}
  1896. c.ServeJSON()
  1897. return
  1898. }
  1899. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1900. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1901. c.ServeJSON()
  1902. return
  1903. }
  1904. R_DeviceClass, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1905. if err != nil {
  1906. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_class_id Err!"}
  1907. c.ServeJSON()
  1908. return
  1909. }
  1910. if R_DeviceClass.T_pid != c.T_pid {
  1911. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1912. c.ServeJSON()
  1913. return
  1914. }
  1915. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1916. if len(DeviceSensor_class_list) == 0 {
  1917. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1918. c.ServeJSON()
  1919. return
  1920. }
  1921. if err = Company.Delete_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1922. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知删除绑定失败"}
  1923. c.ServeJSON()
  1924. return
  1925. }
  1926. if err = Device.DeviceSensor_Bind_T_Notice_Del(T_sn, T_id, T_notice_id); err != nil {
  1927. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知删除绑定失败"}
  1928. c.ServeJSON()
  1929. return
  1930. }
  1931. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "通知删除绑定删除", strconv.Itoa(T_notice_id)+"->"+T_sn+"-"+strconv.Itoa(T_id))
  1932. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1933. c.ServeJSON()
  1934. return
  1935. }
  1936. func (c *DeviceController) NoticeBind_Add_All() {
  1937. T_notice_id, _ := c.GetInt("T_notice_id")
  1938. T_snid := c.GetString("T_snid")
  1939. if T_notice_id == 0 {
  1940. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1941. c.ServeJSON()
  1942. return
  1943. }
  1944. T_snid_list := strings.Split(strings.Trim(T_snid, "|"), "|")
  1945. for _, v := range T_snid_list {
  1946. sn_id := strings.Split(v, ",")
  1947. T_sn := sn_id[0]
  1948. T_id := lib.To_int(sn_id[1])
  1949. if _, err := Device.Read_Device_ByT_sn(T_sn); err != nil {
  1950. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1951. c.ServeJSON()
  1952. return
  1953. }
  1954. R_CompanyNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1955. if err != nil {
  1956. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1957. c.ServeJSON()
  1958. return
  1959. }
  1960. if R_CompanyNotice.T_pid != c.T_pid {
  1961. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1962. c.ServeJSON()
  1963. return
  1964. }
  1965. DeviceSensor_Notice_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  1966. if len(DeviceSensor_Notice_list) > 0 {
  1967. continue
  1968. }
  1969. if err = Company.Add_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  1970. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1971. c.ServeJSON()
  1972. return
  1973. }
  1974. if err = Device.DeviceSensor_Bind_T_Notice_Add(T_sn, T_id, T_notice_id); err != nil {
  1975. c.Data["json"] = lib.JSONS{Code: 200, Msg: "通知绑定失败"}
  1976. c.ServeJSON()
  1977. return
  1978. }
  1979. }
  1980. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略一键绑定", strconv.Itoa(T_notice_id)+"+>"+T_snid)
  1981. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1982. c.ServeJSON()
  1983. return
  1984. }
  1985. func (c *DeviceController) NoticeBind_Del_All() {
  1986. T_notice_id, _ := c.GetInt("T_notice_id")
  1987. T_snid := c.GetString("T_snid")
  1988. if T_notice_id == 0 {
  1989. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1990. c.ServeJSON()
  1991. return
  1992. }
  1993. R_DeviceNotice, err := Company.Read_CompanyNotice_ById(T_notice_id)
  1994. if err != nil {
  1995. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  1996. c.ServeJSON()
  1997. return
  1998. }
  1999. if R_DeviceNotice.T_pid != c.T_pid {
  2000. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  2001. c.ServeJSON()
  2002. return
  2003. }
  2004. Device_lite, _ := Device.Read_DeviceSensor_List_T_Notice(c.T_pid, T_notice_id, 0, 9999, "", "", 0)
  2005. for _, sensor := range Device_lite {
  2006. T_sn := sensor.T_sn
  2007. T_id := sensor.T_id
  2008. if _, err = Device.Read_Device_ByT_sn(T_sn); err != nil {
  2009. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  2010. c.ServeJSON()
  2011. return
  2012. }
  2013. if R_DeviceNotice.T_pid != c.T_pid {
  2014. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_notice_id Err!"}
  2015. c.ServeJSON()
  2016. return
  2017. }
  2018. DeviceSensor_class_list := Device.Read_DeviceSensor_ALL_T_sn_T_id_T_Notice(T_sn, T_id, T_notice_id)
  2019. if len(DeviceSensor_class_list) == 0 {
  2020. continue
  2021. }
  2022. if err = Company.Delete_T_Notice_bind(T_sn, T_id, T_notice_id); err != nil {
  2023. c.Data["json"] = lib.JSONS{Code: 200, Msg: "报警策略删除失败"}
  2024. c.ServeJSON()
  2025. return
  2026. }
  2027. if err = Device.DeviceSensor_Bind_T_Notice_Del(T_sn, T_id, T_notice_id); err != nil {
  2028. c.Data["json"] = lib.JSONS{Code: 200, Msg: "报警策略删除失败"}
  2029. c.ServeJSON()
  2030. return
  2031. }
  2032. }
  2033. System.Add_UserLogs(c.Admin_r.T_uuid, "设备管理", "报警策略一键删除", strconv.Itoa(T_notice_id)+"->"+T_snid)
  2034. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  2035. c.ServeJSON()
  2036. return
  2037. }
  2038. // 传感器类型
  2039. func (c *DeviceController) DeviceSensorType_List_All() {
  2040. type R_JSONS struct {
  2041. //必须的大写开头
  2042. Data []Device.DeviceSensorType
  2043. Num int64
  2044. Page int
  2045. Page_size int
  2046. }
  2047. var r_jsons R_JSONS
  2048. r_jsons.Data = Device.Read_DeviceSensorType_List_All()
  2049. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2050. c.ServeJSON()
  2051. return
  2052. }
  2053. // 传感器类型 - 小程序
  2054. func (c *DeviceController) DeviceSensorType_List() {
  2055. var r_jsons lib.R_JSONS
  2056. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2057. if err != nil {
  2058. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2059. c.ServeJSON()
  2060. return
  2061. }
  2062. var T_pids []int
  2063. if c.Admin_r.T_pid > 0 {
  2064. // 查询公司
  2065. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2066. if err != nil {
  2067. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2068. c.ServeJSON()
  2069. return
  2070. }
  2071. // 查询公司下面所有子公司id
  2072. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2073. }
  2074. list, err := Device.Read_DeviceSensor_T_type(c.Admin_r, c.T_pid, bindSN, T_pids)
  2075. if err != nil {
  2076. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2077. c.ServeJSON()
  2078. return
  2079. }
  2080. if len(list) == 0 {
  2081. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2082. c.ServeJSON()
  2083. return
  2084. }
  2085. var ids []int
  2086. for _, v := range list {
  2087. id, _ := strconv.Atoi(v.(string))
  2088. ids = append(ids, id)
  2089. }
  2090. r_jsons.Data = Device.Read_DeviceSensorType_List_By_Ids(ids)
  2091. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2092. c.ServeJSON()
  2093. return
  2094. }
  2095. // 设备统计 - 小程序
  2096. func (c *DeviceController) Device_Applet_Stat() {
  2097. type Online struct {
  2098. T_type int
  2099. Count int64
  2100. Online int64 // 监控
  2101. NoNetwork int64 // 无网络
  2102. NotEnabled int64 // 未启用
  2103. }
  2104. type R_JSONS struct {
  2105. //必须的大写开头
  2106. Data Online
  2107. }
  2108. T_type, T_type_err := c.GetInt("T_type")
  2109. if T_type_err != nil || T_type == 0 {
  2110. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_type Err!"}
  2111. c.ServeJSON()
  2112. return
  2113. }
  2114. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2115. if err != nil {
  2116. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2117. c.ServeJSON()
  2118. return
  2119. }
  2120. var T_pids []int
  2121. if c.Admin_r.T_pid > 0 {
  2122. // 查询公司
  2123. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2124. if err != nil {
  2125. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2126. c.ServeJSON()
  2127. return
  2128. }
  2129. // 查询公司下面所有子公司id
  2130. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2131. }
  2132. snList, err := Device.Read_DeviceSensor_T_sn_ByT_type(c.Admin_r, c.T_pid, bindSN, T_pids, T_type)
  2133. if err != nil {
  2134. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2135. c.ServeJSON()
  2136. return
  2137. }
  2138. var r_jsons R_JSONS
  2139. r_jsons.Data.T_type = T_type
  2140. if len(snList) == 0 {
  2141. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2142. c.ServeJSON()
  2143. return
  2144. }
  2145. // 0 未启用 1 在线 2 离线
  2146. r_jsons.Data.Count = Device.Read_Device_Count_ByT_online(snList, "")
  2147. r_jsons.Data.Online = Device.Read_Device_Count_ByT_online(snList, "1")
  2148. r_jsons.Data.NoNetwork = Device.Read_Device_Count_ByT_online(snList, "2")
  2149. r_jsons.Data.NotEnabled = Device.Read_Device_Count_ByT_online(snList, "0")
  2150. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2151. c.ServeJSON()
  2152. return
  2153. }
  2154. // 传感器列表 - 小程序 View==1
  2155. func (c *DeviceController) DeviceSensor_Applet_List_View1() {
  2156. var r_jsons lib.R_JSONS
  2157. page, _ := c.GetInt("page")
  2158. if page < 1 {
  2159. page = 1
  2160. }
  2161. page_z, _ := c.GetInt("page_z")
  2162. if page_z < 1 {
  2163. page_z = conf.Page_size
  2164. }
  2165. T_name := c.GetString("T_name")
  2166. //T_online := c.GetString("T_online")
  2167. T_type, T_type_err := c.GetInt("T_type")
  2168. if T_type_err != nil {
  2169. T_type = -1
  2170. }
  2171. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2172. if err != nil {
  2173. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2174. c.ServeJSON()
  2175. return
  2176. }
  2177. var T_pids []int
  2178. if c.Admin_r.T_pid > 0 {
  2179. // 查询公司
  2180. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2181. if err != nil {
  2182. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2183. c.ServeJSON()
  2184. return
  2185. }
  2186. // 查询公司下面所有子公司id
  2187. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2188. }
  2189. Account.Read_Company_All_Maps()
  2190. 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)
  2191. r_jsons.Page = page
  2192. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  2193. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2194. c.ServeJSON()
  2195. return
  2196. }
  2197. // 传感器列表 - 小程序 View==2
  2198. func (c *DeviceController) DeviceSensor_Applet_List_View2() {
  2199. var r_jsons lib.R_JSONS
  2200. page, _ := c.GetInt("page")
  2201. if page < 1 {
  2202. page = 1
  2203. }
  2204. page_z, _ := c.GetInt("page_z")
  2205. if page_z < 1 {
  2206. page_z = conf.Page_size
  2207. }
  2208. T_name := c.GetString("T_name")
  2209. T_online := c.GetString("T_online")
  2210. T_type, T_type_err := c.GetInt("T_type")
  2211. if T_type_err != nil {
  2212. T_type = -1
  2213. }
  2214. bindSN, err := Account.Read_UserDevice_List(*c.Admin_r)
  2215. if err != nil {
  2216. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  2217. c.ServeJSON()
  2218. return
  2219. }
  2220. var T_pids []int
  2221. if c.Admin_r.T_pid > 0 {
  2222. // 查询公司
  2223. Company_r, err := Account.Read_Company_ById(c.Admin_r.T_pid)
  2224. if err != nil {
  2225. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  2226. c.ServeJSON()
  2227. return
  2228. }
  2229. // 查询公司下面所有子公司id
  2230. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  2231. }
  2232. Account.Read_Company_All_Maps()
  2233. 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)
  2234. var deviceMap = make(map[string][]Device.DeviceSensor_Applet)
  2235. var num int64
  2236. type DeviceList struct {
  2237. T_sn string
  2238. DeviceSensorList []Device.DeviceSensor_Applet
  2239. }
  2240. var deviceList []DeviceList
  2241. for _, ds := range dsList {
  2242. _, ok := deviceMap[ds.T_sn]
  2243. if !ok {
  2244. num += 1
  2245. var list []Device.DeviceSensor_Applet
  2246. list = append(list, ds)
  2247. deviceMap[ds.T_sn] = list
  2248. device := DeviceList{
  2249. T_sn: ds.T_sn,
  2250. }
  2251. deviceList = append(deviceList, device)
  2252. } else {
  2253. deviceMap[ds.T_sn] = append(deviceMap[ds.T_sn], ds)
  2254. }
  2255. }
  2256. for i := 0; i < len(deviceList); i++ {
  2257. deviceList[i].DeviceSensorList = deviceMap[deviceList[i].T_sn]
  2258. }
  2259. var offset int
  2260. if page <= 1 {
  2261. offset = 0
  2262. } else {
  2263. offset = (page - 1) * page_z
  2264. }
  2265. offset_z := offset + page_z
  2266. if num < int64(offset_z) {
  2267. offset_z = int(num)
  2268. }
  2269. if offset > offset_z {
  2270. offset = offset_z
  2271. }
  2272. r_jsons.Data = deviceList[offset:offset_z]
  2273. r_jsons.Num = num
  2274. r_jsons.Page = page
  2275. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  2276. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2277. c.ServeJSON()
  2278. return
  2279. }
  2280. func Update_DeviceSensor_Parameter() {
  2281. list := Device.Read_DeviceSensor_All()
  2282. for _, sensor := range list {
  2283. dsp, is := Device.Read_DeviceSensorParameter(sensor.T_sn, sensor.T_id)
  2284. if !is {
  2285. continue
  2286. }
  2287. if sensor.T_sp == dsp.Id {
  2288. continue
  2289. }
  2290. sensor.T_sp = dsp.Id
  2291. Device.Update_DeviceSensor(sensor, "T_sp")
  2292. }
  2293. }
  2294. // 传感器列表 - 冷链物流运输客户端
  2295. func (c *DeviceController) DeviceSensor_List_BySN() {
  2296. type R_JSONS struct {
  2297. //必须的大写开头
  2298. Data []Device.DeviceSensor_R
  2299. Num int64
  2300. Page int
  2301. Page_size int
  2302. }
  2303. var r_jsons R_JSONS
  2304. T_sn := c.GetString("T_sn")
  2305. if len(T_sn) == 0 {
  2306. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn err!"}
  2307. c.ServeJSON()
  2308. return
  2309. }
  2310. r_jsons.Data, r_jsons.Num = Device.Read_DeviceSensorList_BySN(T_sn)
  2311. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  2312. c.ServeJSON()
  2313. return
  2314. }
  2315. func (c *DeviceController) CompanyNoticeByUser() {
  2316. type R_JSONS struct {
  2317. //必须的大写开头
  2318. Data []Company.WarnTypes
  2319. Num int64
  2320. Page int
  2321. Page_size int
  2322. }
  2323. var r_jsons R_JSONS
  2324. T_name := c.GetString("T_name")
  2325. r_jsons.Data = Company.Read_CompanyNoticeByUser(c.T_pid, T_name)
  2326. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons.Data}
  2327. c.ServeJSON()
  2328. return
  2329. }