User.go 52 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071
  1. package controllers
  2. import (
  3. "Cold_Api/Nats/NatsServer"
  4. "Cold_Api/conf"
  5. "Cold_Api/controllers/lib"
  6. "Cold_Api/logs"
  7. "Cold_Api/models/Account"
  8. "Cold_Api/models/Company"
  9. "Cold_Api/models/Device"
  10. "Cold_Api/models/System"
  11. "Cold_Api/models/Warning"
  12. "encoding/json"
  13. "fmt"
  14. "github.com/beego/beego/v2/adapter/orm"
  15. beego "github.com/beego/beego/v2/server/web"
  16. uuid "github.com/satori/go.uuid"
  17. "github.com/shopspring/decimal"
  18. "github.com/xuri/excelize/v2"
  19. "math"
  20. "os"
  21. "strconv"
  22. "strings"
  23. "time"
  24. )
  25. type UserController struct {
  26. beego.Controller
  27. Admin_r Account.Admin // 登陆的用户
  28. T_pid int // 公司id
  29. }
  30. func (c *UserController) Prepare() {
  31. GetCookie := c.Ctx.GetCookie("User_tokey")
  32. GetString := c.GetString("User_tokey")
  33. User_tokey := GetCookie
  34. if len(User_tokey) == 0 {
  35. User_tokey = GetString
  36. }
  37. c.Admin_r = *Account.Admin_r
  38. T_pid := c.Admin_r.T_pid
  39. EntryPid, _ := Account.Redis_Tokey_T_pid_Get(User_tokey)
  40. if EntryPid > 0 {
  41. T_pid = EntryPid
  42. }
  43. c.T_pid = T_pid
  44. }
  45. // 获取微信二维码 ( 扫描后 ,Nats 自动绑定在 Admin->T_wx )
  46. func (c *UserController) User_WxQRCode() {
  47. T_name := c.GetString("T_name")
  48. WxQRCode_str, _ := NatsServer.Wx_GenerateQRCode("-|" + lib.AesEncryptCBC(c.Admin_r.T_uuid+"/"+T_name, "0123456789012345") + "|- @宝智达冷链 微信公众号通知")
  49. WxQRCode_str = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=" + WxQRCode_str
  50. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: WxQRCode_str}
  51. c.ServeJSON()
  52. return
  53. }
  54. // 用户绑定的公司列表
  55. func (c *UserController) Company_Tree() {
  56. var r_jsons lib.R_JSONS
  57. T_name := c.GetString("T_name")
  58. r_jsons.Data = Account.Read_Company_Tree(c.Admin_r, T_name)
  59. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  60. c.ServeJSON()
  61. return
  62. }
  63. // 所有公司树
  64. func (c *UserController) Company_List() {
  65. var r_jsons lib.R_JSONS
  66. T_name := c.GetString("T_name")
  67. r_jsons.Data = Account.Read_Company_List(T_name)
  68. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  69. c.ServeJSON()
  70. return
  71. }
  72. func (c *UserController) Company_Get() {
  73. var r_jsons lib.R_JSONS
  74. Company_r, err := Account.Read_Company_ById(c.T_pid)
  75. if err != nil {
  76. logs.Warning(lib.FuncName(), "获取公司信息失败", err)
  77. }
  78. r_jsons.Data = Account.CompanyToCompany_R(Company_r)
  79. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  80. c.ServeJSON()
  81. return
  82. }
  83. func (c *UserController) Company_Add() {
  84. T_mid, _ := c.GetInt("T_mid")
  85. T_name := c.GetString("T_name")
  86. T_plan := c.GetString("T_plan")
  87. T_data := c.GetString("T_data")
  88. T_v3d := c.GetString("T_v3d")
  89. var_ := Account.Company{
  90. T_mid: T_mid,
  91. T_name: T_name,
  92. T_State: 1,
  93. T_plan: T_plan,
  94. T_data: T_data,
  95. T_v3d: T_v3d,
  96. T_warning: 1,
  97. }
  98. id, err := Account.Add_Company(var_)
  99. if err != nil {
  100. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  101. c.ServeJSON()
  102. return
  103. }
  104. if c.Admin_r.T_pids != "*" {
  105. T_pids := []int{int(id)}
  106. if err = Account.Add_Company_bind(c.Admin_r, T_pids); err != nil {
  107. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  108. c.ServeJSON()
  109. return
  110. }
  111. }
  112. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "添加", var_)
  113. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: id}
  114. c.ServeJSON()
  115. return
  116. }
  117. func (c *UserController) Company_Edit() {
  118. Id, Id_err := c.GetInt("Id")
  119. if Id_err != nil {
  120. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  121. c.ServeJSON()
  122. return
  123. }
  124. Company_r, err := Account.Read_Company_ById(Id)
  125. if err != nil {
  126. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  127. c.ServeJSON()
  128. return
  129. }
  130. T_name := c.GetString("T_name")
  131. if len(T_name) > 0 {
  132. Company_r.T_name = T_name
  133. }
  134. is := Account.Update_Company(Company_r, "T_name")
  135. if !is {
  136. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  137. c.ServeJSON()
  138. return
  139. }
  140. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "修改", Company_r)
  141. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  142. c.ServeJSON()
  143. return
  144. }
  145. // 数字孪生
  146. func (c *UserController) Company_DigitalTwin() {
  147. Id, Id_err := c.GetInt("Id")
  148. if Id_err != nil {
  149. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  150. c.ServeJSON()
  151. return
  152. }
  153. Company_r, err := Account.Read_Company_ById(Id)
  154. if err != nil {
  155. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  156. c.ServeJSON()
  157. return
  158. }
  159. T_plan := c.GetString("T_plan")
  160. T_data := c.GetString("T_data")
  161. T_v3d := c.GetString("T_v3d")
  162. T_warning, _ := c.GetInt("T_warning")
  163. if len(T_plan) > 0 {
  164. Company_r.T_plan = T_plan
  165. }
  166. if len(T_data) > 0 {
  167. Company_r.T_data = T_data
  168. }
  169. if len(T_v3d) > 0 {
  170. Company_r.T_v3d = T_v3d
  171. }
  172. if T_warning > 0 {
  173. Company_r.T_warning = T_warning
  174. }
  175. is := Account.Update_Company(Company_r, "T_plan", "T_data", "T_v3d")
  176. if !is {
  177. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  178. c.ServeJSON()
  179. return
  180. }
  181. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "修改数字孪生", Company_r)
  182. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  183. c.ServeJSON()
  184. return
  185. }
  186. // 充值
  187. func (c *UserController) Company_Pay() {
  188. Id, Id_err := c.GetInt("Id")
  189. if Id_err != nil {
  190. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  191. c.ServeJSON()
  192. return
  193. }
  194. Company_r, err := Account.Read_Company_ById(Id)
  195. if err != nil {
  196. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  197. c.ServeJSON()
  198. return
  199. }
  200. T_balance, _ := c.GetFloat("T_balance")
  201. T_money64, _ := decimal.NewFromFloat(float64(Company_r.T_money) + T_balance).Round(2).Float64()
  202. Company_r.T_money = float32(T_money64)
  203. is := Account.Update_Company(Company_r, "T_money")
  204. if !is {
  205. c.Data["json"] = lib.JSONS{Code: 202, Msg: "充值失败!"}
  206. c.ServeJSON()
  207. return
  208. }
  209. // 添加充值记录
  210. bill := Company.CompanyBill{
  211. T_pid: Company_r.Id,
  212. T_type: "充值",
  213. T_project: "充值",
  214. T_bill: "充值",
  215. T_charging: float32(T_balance),
  216. T_balance: float32(T_money64),
  217. }
  218. _, err = Company.Add_CompanyBill(bill)
  219. if err != nil {
  220. c.Data["json"] = lib.JSONS{Code: 202, Msg: "充值失败!"}
  221. c.ServeJSON()
  222. return
  223. }
  224. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "充值", Company_r)
  225. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  226. c.ServeJSON()
  227. return
  228. }
  229. // 报警统计
  230. func (c *UserController) Company_Warning() {
  231. Id, Id_err := c.GetInt("Id")
  232. if Id_err != nil {
  233. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  234. c.ServeJSON()
  235. return
  236. }
  237. Company_r, err := Account.Read_Company_ById(Id)
  238. if err != nil {
  239. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  240. c.ServeJSON()
  241. return
  242. }
  243. T_warning, _ := c.GetInt("T_warning")
  244. if T_warning > 0 {
  245. Company_r.T_warning = T_warning
  246. }
  247. is := Account.Update_Company(Company_r, "T_warning")
  248. if !is {
  249. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  250. c.ServeJSON()
  251. return
  252. }
  253. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "修改报警统计", Company_r)
  254. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  255. c.ServeJSON()
  256. return
  257. }
  258. func (c *UserController) Company_Del() {
  259. Id, Id_err := c.GetInt("Id")
  260. if Id_err != nil {
  261. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  262. c.ServeJSON()
  263. return
  264. }
  265. Company_r, err := Account.Read_Company_ById(Id)
  266. if err != nil {
  267. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  268. c.ServeJSON()
  269. return
  270. }
  271. ids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  272. if cnt := Account.Read_Admin_Num_ByT_pid(ids); cnt > 0 {
  273. c.Data["json"] = lib.JSONS{Code: 202, Msg: "有关联用户,禁止删除!"}
  274. c.ServeJSON()
  275. return
  276. }
  277. o := orm.NewOrm()
  278. o.Begin()
  279. for _, id := range ids {
  280. if is := Account.Delete_Company(o, id); !is {
  281. o.Rollback()
  282. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  283. c.ServeJSON()
  284. return
  285. }
  286. if err = Account.Delete_Company_bind_T_pids(o, id); err != nil {
  287. o.Rollback()
  288. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  289. c.ServeJSON()
  290. return
  291. }
  292. }
  293. o.Commit()
  294. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "删除", Company_r)
  295. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  296. c.ServeJSON()
  297. return
  298. }
  299. // 进入公司
  300. func (c *UserController) Company_Entry() {
  301. GetCookie := c.Ctx.GetCookie("User_tokey")
  302. GetString := c.GetString("User_tokey")
  303. User_tokey := GetCookie
  304. if len(User_tokey) == 0 {
  305. User_tokey = GetString
  306. }
  307. T_pid, _ := c.GetInt("T_pid")
  308. // 操作pid
  309. company_r, err := Account.Read_Company_ById(T_pid)
  310. if err != nil {
  311. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  312. c.ServeJSON()
  313. return
  314. }
  315. visit := false
  316. if c.Admin_r.T_pid > 0 && strings.Contains(company_r.T_path, fmt.Sprintf("/%d/", c.Admin_r.T_pid)) {
  317. visit = true
  318. }
  319. if c.Admin_r.T_pid == 0 {
  320. if c.Admin_r.T_pids == "*" {
  321. visit = true
  322. } else {
  323. pids := lib.SplitStringToIntIds(c.Admin_r.T_pids, "P")
  324. if len(pids) > 0 {
  325. list := Account.ReadCompanyIds_T_pids(pids)
  326. for _, v := range list {
  327. if T_pid == v {
  328. visit = true
  329. break
  330. }
  331. }
  332. }
  333. }
  334. }
  335. if !visit {
  336. c.Data["json"] = lib.JSONS{Code: 202, Msg: "没有权限!"}
  337. c.ServeJSON()
  338. return
  339. }
  340. Account.Redis_Tokey_T_pid_Set(User_tokey, T_pid)
  341. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "进入公司", T_pid)
  342. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  343. c.ServeJSON()
  344. return
  345. }
  346. // 记账扣费
  347. func (c *UserController) Company_Charging() {
  348. Id, Id_err := c.GetInt("Id")
  349. if Id_err != nil {
  350. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  351. c.ServeJSON()
  352. return
  353. }
  354. Company_r, err := Account.Read_Company_ById(Id)
  355. if err != nil {
  356. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  357. c.ServeJSON()
  358. return
  359. }
  360. T_Charging, _ := c.GetInt("T_Charging")
  361. Company_r.T_Charging = T_Charging
  362. is := Account.Update_Company(Company_r, "T_Charging")
  363. if !is {
  364. c.Data["json"] = lib.JSONS{Code: 202, Msg: "充值失败!"}
  365. c.ServeJSON()
  366. return
  367. }
  368. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "记账扣费", Company_r)
  369. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  370. c.ServeJSON()
  371. return
  372. }
  373. // 检查 Tokey 是否过期
  374. // 用户管理
  375. func (c *UserController) User_List() {
  376. var r_jsons lib.R_JSONS
  377. page, _ := c.GetInt("page")
  378. if page < 1 {
  379. page = 1
  380. }
  381. page_z, _ := c.GetInt("page_z")
  382. if page_z < 1 {
  383. page_z = conf.Page_size
  384. }
  385. T_name := c.GetString("T_name")
  386. Account.Read_Power_All_Map()
  387. r_jsons.Data, r_jsons.Num = Account.Read_Admin_List(c.T_pid, T_name, page, page_z)
  388. r_jsons.Page = page
  389. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  390. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  391. c.ServeJSON()
  392. return
  393. }
  394. func (c *UserController) User_Get() {
  395. T_uuid := c.GetString("T_uuid")
  396. if len(T_uuid) < 8 {
  397. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  398. c.ServeJSON()
  399. return
  400. }
  401. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  402. if err != nil {
  403. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  404. c.ServeJSON()
  405. return
  406. }
  407. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Account.AdminToAdmin_R(admin_r)}
  408. c.ServeJSON()
  409. return
  410. }
  411. func (c *UserController) User_Info() {
  412. type User_ struct {
  413. User Account.Admin_R
  414. //Power Account.Power // 权限
  415. //Menu map[string]Account.Menu_R // 菜单
  416. //Menu []Account.Menu // 菜单
  417. }
  418. Admin_r := User_{}
  419. Admin_r.User = Account.AdminToAdmin_R(c.Admin_r)
  420. //Admin_r.Power, _ = Account.Read_Power_ById(admin_r.T_power)
  421. //Admin_r.Menu = Account.Read_Menu_Tree(Power.T_menu, T_pid)
  422. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Admin_r}
  423. c.ServeJSON()
  424. return
  425. }
  426. func (c *UserController) User_Post() {
  427. admin_r := c.Admin_r
  428. T_name := c.GetString("T_name")
  429. T_pass := c.GetString("T_pass")
  430. T_phone := c.GetString("T_phone")
  431. T_mail := c.GetString("T_mail")
  432. T_wx := c.GetString("T_wx")
  433. if len(T_pass) < 8 && len(T_pass) > 0 {
  434. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  435. c.ServeJSON()
  436. return
  437. }
  438. if len(T_name) > 0 {
  439. admin_r.T_name = T_name
  440. }
  441. if len(T_pass) >= 8 {
  442. admin_r.T_pass = T_pass
  443. }
  444. if len(T_phone) > 0 {
  445. admin_r.T_phone = T_phone
  446. }
  447. if len(T_mail) > 0 {
  448. admin_r.T_mail = T_mail
  449. }
  450. if len(T_wx) > 0 {
  451. if T_wx == "-" {
  452. T_wx = ""
  453. }
  454. admin_r.T_wx = T_wx
  455. }
  456. is := Account.Update_Admin(admin_r, "T_name", "T_pass", "T_phone", "T_mail", "T_wx")
  457. if !is {
  458. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  459. c.ServeJSON()
  460. return
  461. }
  462. admin_r.T_pass = "******"
  463. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "修改个人信息", admin_r)
  464. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  465. c.ServeJSON()
  466. return
  467. }
  468. func (c *UserController) User_Add() {
  469. T_power, _ := c.GetInt("T_power")
  470. T_name := c.GetString("T_name")
  471. T_user := c.GetString("T_user")
  472. T_pass := c.GetString("T_pass")
  473. T_phone := c.GetString("T_phone")
  474. T_mail := c.GetString("T_mail")
  475. T_wx := c.GetString("T_wx")
  476. T_uuid := uuid.NewV4().String()
  477. var_ := Account.Admin{
  478. T_uuid: T_uuid,
  479. T_pid: c.T_pid,
  480. T_name: T_name,
  481. T_user: T_user,
  482. T_phone: T_phone,
  483. T_mail: T_mail,
  484. T_wx: T_wx,
  485. T_pass: T_pass,
  486. T_power: T_power,
  487. T_State: 1,
  488. }
  489. if len(T_pass) < 8 {
  490. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  491. c.ServeJSON()
  492. return
  493. }
  494. _, err := Account.Read_Admin_T_user(T_user)
  495. if err == nil {
  496. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  497. c.ServeJSON()
  498. return
  499. }
  500. _, err = Account.Add_Admin(var_)
  501. if err != nil {
  502. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  503. c.ServeJSON()
  504. return
  505. }
  506. var_.T_pass = "******"
  507. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "添加", var_)
  508. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  509. c.ServeJSON()
  510. return
  511. }
  512. func (c *UserController) User_Edit() {
  513. T_uuid := c.GetString("T_uuid")
  514. if len(T_uuid) < 8 {
  515. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  516. c.ServeJSON()
  517. return
  518. }
  519. r, err := Account.Read_Admin_ByUuid(T_uuid)
  520. if err != nil {
  521. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  522. c.ServeJSON()
  523. return
  524. }
  525. T_power, T_power_err := c.GetInt("T_power")
  526. T_name := c.GetString("T_name")
  527. T_pass := c.GetString("T_pass")
  528. T_phone := c.GetString("T_phone")
  529. T_mail := c.GetString("T_mail")
  530. if T_power_err == nil {
  531. r.T_power = T_power
  532. }
  533. if len(T_pass) < 8 && len(T_pass) > 0 {
  534. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  535. c.ServeJSON()
  536. return
  537. }
  538. if len(T_name) > 0 {
  539. r.T_name = T_name
  540. }
  541. if len(T_pass) >= 8 {
  542. r.T_pass = T_pass
  543. }
  544. if len(T_phone) > 0 {
  545. r.T_phone = T_phone
  546. }
  547. if len(T_mail) > 0 {
  548. r.T_mail = T_mail
  549. }
  550. is := Account.Update_Admin(r, "T_power", "T_pid", "T_name", "T_pass", "T_phone", "T_mail")
  551. if !is {
  552. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  553. c.ServeJSON()
  554. return
  555. }
  556. if len(T_name) > 0 {
  557. if is = Company.Update_CompanyNotice_Bind_By_T_uuid(T_uuid, T_name); !is {
  558. logs.Println("修改用户 => 修改用户关联报警通知失败", T_uuid, T_name)
  559. }
  560. }
  561. r.T_pass = "******"
  562. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "编辑", r)
  563. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  564. c.ServeJSON()
  565. return
  566. }
  567. func (c *UserController) User_Del() {
  568. T_uuid := c.GetString("T_uuid")
  569. if len(T_uuid) <= 0 {
  570. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  571. c.ServeJSON()
  572. return
  573. }
  574. admin_r_lod, err := Account.Read_Admin_ByUuid(T_uuid)
  575. if err != nil {
  576. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  577. c.ServeJSON()
  578. return
  579. }
  580. if is := Account.Delete_Admin(admin_r_lod); !is {
  581. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  582. c.ServeJSON()
  583. return
  584. }
  585. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid(T_uuid); !is {
  586. logs.Println("删除用户 => 删除用户关联报警通知失败", T_uuid)
  587. }
  588. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "删除", T_uuid)
  589. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  590. c.ServeJSON()
  591. return
  592. }
  593. // 管理员
  594. func (c *UserController) User_Home() {
  595. // 报警标识
  596. //设备管理-设备报警 callthepolice
  597. //公司管理-设备报警 companyCallthepolice
  598. //T_warning_sign := c.GetString("T_warning_sign")
  599. power, err := Account.Read_Power_ById(c.Admin_r.T_power)
  600. if err != nil {
  601. c.Data["json"] = lib.JSONS{Code: 202, Msg: "获取菜单失败"}
  602. c.ServeJSON()
  603. return
  604. }
  605. ret := Account.Read_Menu_Bind_List(power.Id, power.T_menu, c.T_pid)
  606. var T_warning_sign string
  607. for _, v := range ret.MenuPermission {
  608. if v == Warning.CompanyCallthepolice {
  609. T_warning_sign = Warning.CompanyCallthepolice
  610. break
  611. }
  612. if v == Warning.Callthepolice {
  613. T_warning_sign = Warning.Callthepolice
  614. }
  615. }
  616. // 验证登录
  617. admin_r := c.Admin_r
  618. type NoticeRecord struct {
  619. Sms int // 短信
  620. Phone int // 电话
  621. }
  622. type Info struct {
  623. T_name string // 姓名
  624. T_pids string // 内部用户绑定的公司id
  625. T_pid int // 公司id
  626. T_Days int // 服务天输
  627. Admin []Account.Admin_ // 专属管理员
  628. WarningSign string // 报警标识
  629. WarningNum int64 // 报警数量
  630. UntreatedWarningNum int64 // 未处理报警数量
  631. NewsNum int64 // 消息数量
  632. WorkOrderNum int64 // 工单数量
  633. WarningRate float32 // 设备报警率
  634. UntreatedWorkOrderNum int64 // 未处理工单数量
  635. Balance float32 // 余额
  636. NoticeRecord NoticeRecord // 通知记录
  637. }
  638. var info Info
  639. info.T_name = admin_r.T_name
  640. info.T_pid = admin_r.T_pid
  641. if admin_r.T_pid > 0 {
  642. info.WarningSign = T_warning_sign
  643. bindSN, err := Account.Read_UserDevice_List(c.Admin_r)
  644. if err != nil {
  645. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  646. c.ServeJSON()
  647. return
  648. }
  649. power, _ := Account.Read_Power_ById(admin_r.T_power)
  650. company, _ := Account.Read_Company_ById(admin_r.T_pid)
  651. info.T_Days = lib.GetDiffDays(time.Now(), company.CreateTime)
  652. AdminList := Account.Read_Admin_List_T_pids(admin_r.T_pid)
  653. var Admin_ []Account.Admin_
  654. for _, v := range AdminList {
  655. Admin_ = append(Admin_, Account.Admin_RToAdmin_(v))
  656. }
  657. info.Admin = Admin_
  658. Company_r, err := Account.Read_Company_ById(c.T_pid)
  659. if err != nil {
  660. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  661. c.ServeJSON()
  662. return
  663. }
  664. T_pids := []int{}
  665. // 拥有公司管理-设备报警权限 统计公司及其所有子公司的今日报警数量、未处理报警数量、我的消息数量
  666. if T_warning_sign == Warning.CompanyCallthepolice {
  667. T_pids = Account.ReadCompanyIds_T_path(Company_r.T_path)
  668. info.WarningNum = Warning.Read_Warning_ALL_T_State_Count(0, T_pids, 1, bindSN, power.T_warning, true)
  669. info.UntreatedWarningNum = Warning.Read_Warning_ALL_T_State_Count(0, T_pids, 3, bindSN, power.T_warning, false)
  670. info.NewsNum = Warning.Read_Warning_ALL_T_State_Count(0, T_pids, 1, bindSN, "T1003|T1002|", false)
  671. }
  672. // 拥有设备管理-设备报警权限 统计本公司今日报警数量、未处理报警数量、我的消息数量
  673. if T_warning_sign == Warning.Callthepolice {
  674. info.WarningNum = Warning.Read_Warning_ALL_T_State_Count(admin_r.T_pid, T_pids, 1, bindSN, power.T_warning, true)
  675. info.UntreatedWarningNum = Warning.Read_Warning_ALL_T_State_Count(admin_r.T_pid, T_pids, 3, bindSN, power.T_warning, false)
  676. info.NewsNum = Warning.Read_Warning_ALL_T_State_Count(admin_r.T_pid, T_pids, 1, bindSN, "T1003|T1002|", false)
  677. }
  678. info.Balance = company.T_money
  679. info.NoticeRecord.Sms = Warning.Get_WarningSandNum_CurrentMonth(admin_r.T_pid, 1)
  680. info.NoticeRecord.Phone = Warning.Get_WarningSandNum_CurrentMonth(admin_r.T_pid, 2)
  681. }
  682. if admin_r.T_pid == 0 {
  683. if len(admin_r.T_pids) > 0 && admin_r.T_pids != "*" {
  684. info.T_pids = admin_r.T_pids
  685. info.WarningRate = Warning.Read_WarningRate_Yesterday(admin_r.T_uuid)
  686. }
  687. info.WorkOrderNum, info.UntreatedWorkOrderNum = NatsServer.Read_WorkOrderT_State_Count(admin_r.T_pids)
  688. }
  689. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: info}
  690. c.ServeJSON()
  691. return
  692. }
  693. // 内部用户管理
  694. func (c *UserController) Admin_List() {
  695. var r_jsons lib.R_JSONS
  696. page, _ := c.GetInt("page")
  697. if page < 1 {
  698. page = 1
  699. }
  700. page_z, _ := c.GetInt("page_z")
  701. if page_z < 1 {
  702. page_z = conf.Page_size
  703. }
  704. T_name := c.GetString("T_name")
  705. if c.Admin_r.T_pid > 0 {
  706. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权查看!"}
  707. c.ServeJSON()
  708. return
  709. }
  710. T_bind_company, _ := c.GetInt("T_bind_company") // 管理员绑定公司 0-全部 1-绑定公司
  711. Account.Read_Power_All_Map()
  712. userList, num := Account.Read_Admin_List(0, T_name, page, page_z)
  713. r_jsons.Data, r_jsons.Num = userList, num
  714. // 过滤已绑定公司列表
  715. if T_bind_company == 1 {
  716. var adminList []Account.Admin_R
  717. for _, v := range userList {
  718. if len(v.T_pids) == 0 || v.T_pids == "*" {
  719. continue
  720. }
  721. adminList = append(adminList, v)
  722. }
  723. r_jsons.Data = adminList
  724. }
  725. r_jsons.Page = page
  726. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  727. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  728. c.ServeJSON()
  729. return
  730. }
  731. func (c *UserController) Admin_Get() {
  732. T_uuid := c.GetString("T_uuid")
  733. if len(T_uuid) < 8 {
  734. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  735. c.ServeJSON()
  736. return
  737. }
  738. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  739. if err != nil {
  740. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  741. c.ServeJSON()
  742. return
  743. }
  744. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Account.AdminToAdmin_R(admin_r)}
  745. c.ServeJSON()
  746. return
  747. }
  748. func (c *UserController) Admin_Add() {
  749. T_power, _ := c.GetInt("T_power")
  750. T_name := c.GetString("T_name")
  751. T_user := c.GetString("T_user")
  752. T_pass := c.GetString("T_pass")
  753. T_phone := c.GetString("T_phone")
  754. T_mail := c.GetString("T_mail")
  755. T_wx := c.GetString("T_wx")
  756. var_ := Account.Admin{
  757. T_uuid: uuid.NewV4().String(),
  758. T_pid: 0,
  759. T_name: T_name,
  760. T_user: T_user,
  761. T_phone: T_phone,
  762. T_mail: T_mail,
  763. T_wx: T_wx,
  764. T_pass: T_pass,
  765. T_power: T_power,
  766. T_State: 1,
  767. }
  768. if len(T_pass) < 8 {
  769. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  770. c.ServeJSON()
  771. return
  772. }
  773. _, err := Account.Read_Admin_T_user(T_user)
  774. if err == nil {
  775. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  776. c.ServeJSON()
  777. return
  778. }
  779. _, err = Account.Add_Admin(var_)
  780. if err != nil {
  781. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  782. c.ServeJSON()
  783. return
  784. }
  785. var_.T_pass = "******"
  786. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "添加", var_)
  787. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  788. c.ServeJSON()
  789. return
  790. }
  791. func (c *UserController) Admin_Edit() {
  792. T_uuid := c.GetString("T_uuid")
  793. if len(T_uuid) < 8 {
  794. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  795. c.ServeJSON()
  796. return
  797. }
  798. r, err := Account.Read_Admin_ByUuid(T_uuid)
  799. if err != nil {
  800. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  801. c.ServeJSON()
  802. return
  803. }
  804. T_power, T_power_err := c.GetInt("T_power")
  805. T_name := c.GetString("T_name")
  806. T_pass := c.GetString("T_pass")
  807. T_phone := c.GetString("T_phone")
  808. T_mail := c.GetString("T_mail")
  809. T_wx := c.GetString("T_wx")
  810. if T_power_err == nil {
  811. r.T_power = T_power
  812. }
  813. if len(T_pass) < 8 && len(T_pass) > 0 {
  814. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  815. c.ServeJSON()
  816. return
  817. }
  818. if len(T_name) > 0 {
  819. r.T_name = T_name
  820. }
  821. if len(T_pass) >= 8 {
  822. r.T_pass = T_pass
  823. }
  824. if len(T_phone) > 0 {
  825. r.T_phone = T_phone
  826. }
  827. if len(T_mail) > 0 {
  828. r.T_mail = T_mail
  829. }
  830. if len(T_wx) > 0 {
  831. r.T_wx = T_wx
  832. }
  833. is := Account.Update_Admin(r, "T_power", "T_name", "T_pass", "T_phone", "T_mail", "T_wx")
  834. if !is {
  835. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  836. c.ServeJSON()
  837. return
  838. }
  839. if len(T_name) > 0 {
  840. if is = Company.Update_CompanyNotice_Bind_By_T_uuid(T_uuid, "内管-"+T_name); !is {
  841. logs.Println("修改内部用户 => 修改内部用户关联报警通知失败", T_uuid, T_name)
  842. }
  843. }
  844. r.T_pass = "********"
  845. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "修改", r)
  846. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  847. c.ServeJSON()
  848. return
  849. }
  850. func (c *UserController) Admin_Del() {
  851. T_uuid := c.GetString("T_uuid")
  852. if len(T_uuid) <= 0 {
  853. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  854. c.ServeJSON()
  855. return
  856. }
  857. admin_r_lod, err := Account.Read_Admin_ByUuid(T_uuid)
  858. if err != nil {
  859. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  860. c.ServeJSON()
  861. return
  862. }
  863. if admin_r_lod.Id == 1 {
  864. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权删除!"}
  865. c.ServeJSON()
  866. return
  867. }
  868. if is := Account.Delete_Admin(admin_r_lod); !is {
  869. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  870. c.ServeJSON()
  871. return
  872. }
  873. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid(T_uuid); !is {
  874. logs.Println("删除内部用户 => 删除内部用户关联报警通知失败", T_uuid)
  875. }
  876. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "删除", T_uuid)
  877. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  878. c.ServeJSON()
  879. return
  880. }
  881. // 报警通知的用户列表
  882. func (c *UserController) User_Notice_List() {
  883. T_name := c.GetString("T_name")
  884. type R_JSONS struct {
  885. //必须的大写开头
  886. AdminList []Account.Admin_R
  887. UserList []Account.Admin_R
  888. }
  889. var AdminList, UserList []Account.Admin_R
  890. var r_jsons R_JSONS
  891. // 操作pid
  892. company_r, err := Account.Read_Company_ById(c.T_pid)
  893. if err != nil {
  894. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  895. c.ServeJSON()
  896. return
  897. }
  898. T_pids := []int{}
  899. for _, v := range strings.Split(strings.Trim(company_r.T_path, "/"), "/") {
  900. pid, _ := strconv.Atoi(v)
  901. T_pids = append(T_pids, pid)
  902. }
  903. // 绑定公司id的内部用户列表
  904. AdminList = Account.Read_Admin_List_T_pids(c.T_pid)
  905. // 绑定公司id的公司用户列表
  906. //r_jsons.UserList = Account.Read_Admin_List_T_pid(c.T_pid)
  907. // 绑定上级公司用户列表
  908. UserList = Account.Read_Parent_Admin_List(T_pids)
  909. if len(T_name) > 0 {
  910. for _, v := range AdminList {
  911. if strings.Contains(v.T_name, T_name) {
  912. r_jsons.AdminList = append(r_jsons.AdminList, v)
  913. }
  914. }
  915. for _, v := range UserList {
  916. if strings.Contains(v.T_name, T_name) {
  917. r_jsons.UserList = append(r_jsons.UserList, v)
  918. }
  919. }
  920. } else {
  921. r_jsons.AdminList = AdminList
  922. r_jsons.UserList = UserList
  923. }
  924. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  925. c.ServeJSON()
  926. return
  927. }
  928. // 管理员绑定公司
  929. func (c *UserController) AdminCompanyBind_List() {
  930. var r_jsons lib.R_JSONS
  931. T_uuid := c.GetString("T_uuid")
  932. if len(T_uuid) < 8 {
  933. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  934. c.ServeJSON()
  935. return
  936. }
  937. r, err := Account.Read_Admin_ByUuid(T_uuid)
  938. if err != nil {
  939. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  940. c.ServeJSON()
  941. return
  942. }
  943. r_jsons.Data = Account.Read_Company_List_ByT_pids(r.T_pids)
  944. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  945. c.ServeJSON()
  946. return
  947. }
  948. func (c *UserController) AdminCompanyBind_Add() {
  949. T_uuid := c.GetString("T_uuid")
  950. if len(T_uuid) < 8 {
  951. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  952. c.ServeJSON()
  953. return
  954. }
  955. T_pid, _ := c.GetInt("T_pid")
  956. if T_pid == 0 {
  957. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  958. c.ServeJSON()
  959. return
  960. }
  961. r, err := Account.Read_Admin_ByUuid(T_uuid)
  962. if err != nil {
  963. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  964. c.ServeJSON()
  965. return
  966. }
  967. if r.T_pids == "*" {
  968. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  969. c.ServeJSON()
  970. return
  971. }
  972. Company_r, err := Account.Read_Company_ById(T_pid)
  973. if err != nil {
  974. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  975. c.ServeJSON()
  976. return
  977. }
  978. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  979. if err = Account.Add_Company_bind(r, T_pids); err != nil {
  980. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  981. c.ServeJSON()
  982. return
  983. }
  984. System.Add_UserLogs(c.Admin_r.T_uuid, "内部用户管理", "公司绑定添加", T_uuid+"-"+strconv.Itoa(T_pid))
  985. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  986. c.ServeJSON()
  987. return
  988. }
  989. func (c *UserController) AdminCompanyBind_Del() {
  990. T_uuid := c.GetString("T_uuid")
  991. if len(T_uuid) < 8 {
  992. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  993. c.ServeJSON()
  994. return
  995. }
  996. T_pid, _ := c.GetInt("T_pid")
  997. if T_pid == 0 {
  998. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  999. c.ServeJSON()
  1000. return
  1001. }
  1002. r, err := Account.Read_Admin_ByUuid(T_uuid)
  1003. Company_r, err := Account.Read_Company_ById(T_pid)
  1004. if err != nil {
  1005. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1006. c.ServeJSON()
  1007. return
  1008. }
  1009. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  1010. if len(T_pids) == 0 {
  1011. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1012. c.ServeJSON()
  1013. return
  1014. }
  1015. if err = Account.Delete_Company_bind(r, T_pids); err != nil {
  1016. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  1017. c.ServeJSON()
  1018. return
  1019. }
  1020. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid_T_pid(T_uuid, T_pids); !is {
  1021. logs.Println("删除内部用户公司绑定 => 删除内部用户绑定的公司关联报警通知失败", T_uuid)
  1022. }
  1023. System.Add_UserLogs(c.Admin_r.T_uuid, "内部用户管理", "公司绑定删除", T_uuid+"-"+strconv.Itoa(T_pid))
  1024. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1025. c.ServeJSON()
  1026. return
  1027. }
  1028. // 权限管理
  1029. func (c *UserController) Power_List() {
  1030. var r_jsons lib.R_JSONS
  1031. page, _ := c.GetInt("page")
  1032. if page < 1 {
  1033. page = 1
  1034. }
  1035. page_z, _ := c.GetInt("page_z")
  1036. if page_z < 1 {
  1037. page_z = conf.Page_size
  1038. }
  1039. Name := c.GetString("T_name")
  1040. r_jsons.Data, r_jsons.Num = Account.Read_Power_List(Name, page, page_z)
  1041. r_jsons.Page = page
  1042. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1043. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1044. c.ServeJSON()
  1045. return
  1046. }
  1047. // 添加用户 权限选择列表
  1048. func (c *UserController) Power_List_All() {
  1049. r, err := Account.Read_Power_ById(c.Admin_r.T_power)
  1050. if err != nil {
  1051. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1052. c.ServeJSON()
  1053. return
  1054. }
  1055. var r_jsons lib.R_JSONS
  1056. r_jsons.Data = Account.Read_Power_List_ALL_User(r.T_select)
  1057. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1058. c.ServeJSON()
  1059. return
  1060. }
  1061. func (c *UserController) Power_Get() {
  1062. type Data struct {
  1063. Power Account.Power_
  1064. Menu []Account.Menu
  1065. Menu_checked []int
  1066. Select []Account.Power_R
  1067. Warning []Warning.WarningType_R
  1068. }
  1069. var data Data
  1070. id, id_err := c.GetInt("T_id")
  1071. if id_err != nil || id == 0 {
  1072. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1073. c.ServeJSON()
  1074. return
  1075. }
  1076. power, err := Account.Read_Power_ById(id)
  1077. if err != nil {
  1078. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1079. c.ServeJSON()
  1080. return
  1081. }
  1082. data.Power = Account.PowerToPower_(power)
  1083. data.Menu, data.Menu_checked = Account.Read_Menu_List_All()
  1084. if err != nil {
  1085. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_menu Err!"}
  1086. c.ServeJSON()
  1087. return
  1088. }
  1089. if power.T_menu != "*" {
  1090. data.Menu_checked = lib.SplitStringToIntIds(power.T_menu, "M")
  1091. }
  1092. if err != nil {
  1093. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_menu Err!"}
  1094. c.ServeJSON()
  1095. return
  1096. }
  1097. data.Select = Account.Read_Power_List_ALL_T_select(power.T_select)
  1098. if err != nil {
  1099. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_select Err!"}
  1100. c.ServeJSON()
  1101. return
  1102. }
  1103. data.Warning = Warning.Read_WarningType_All_Power_T_Warning(power.T_warning)
  1104. if err != nil {
  1105. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_warning Err!"}
  1106. c.ServeJSON()
  1107. return
  1108. }
  1109. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: data}
  1110. c.ServeJSON()
  1111. return
  1112. }
  1113. func (c *UserController) Power_Add() {
  1114. T_name := c.GetString("T_name")
  1115. T_select := c.GetString("T_select")
  1116. T_warning := c.GetString("T_warning")
  1117. T_menu := c.GetString("T_menu")
  1118. var_ := Account.Power{
  1119. T_name: T_name,
  1120. T_select: T_select,
  1121. T_warning: T_warning,
  1122. T_menu: T_menu,
  1123. T_State: 1,
  1124. }
  1125. _, err := Account.Add_Power(var_)
  1126. if err != nil {
  1127. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  1128. c.ServeJSON()
  1129. return
  1130. }
  1131. System.Add_UserLogs_T(c.Admin_r.T_uuid, "权限管理", "添加", var_)
  1132. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1133. c.ServeJSON()
  1134. return
  1135. }
  1136. func (c *UserController) Power_Edit() {
  1137. Id, Id_err := c.GetInt("T_id")
  1138. if Id_err != nil || Id == 0 {
  1139. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1140. c.ServeJSON()
  1141. return
  1142. }
  1143. if Id == 1 {
  1144. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权修改!"}
  1145. c.ServeJSON()
  1146. return
  1147. }
  1148. r, err := Account.Read_Power_ById(Id)
  1149. if err != nil {
  1150. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1151. c.ServeJSON()
  1152. return
  1153. }
  1154. T_name := c.GetString("T_name")
  1155. T_select := c.GetString("T_select")
  1156. T_warning := c.GetString("T_warning")
  1157. T_menu := c.GetString("T_menu")
  1158. if len(T_name) > 0 {
  1159. r.T_name = T_name
  1160. }
  1161. if len(T_select) > 0 {
  1162. r.T_select = T_select
  1163. }
  1164. if len(T_warning) > 0 {
  1165. r.T_warning = T_warning
  1166. }
  1167. if len(T_menu) > 0 {
  1168. r.T_menu = T_menu
  1169. }
  1170. is := Account.Update_Power(r, "T_name", "T_select", "T_warning", "T_menu")
  1171. if !is {
  1172. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  1173. c.ServeJSON()
  1174. return
  1175. }
  1176. System.Add_UserLogs_T(c.Admin_r.T_uuid, "权限管理", "修改", r)
  1177. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1178. c.ServeJSON()
  1179. return
  1180. }
  1181. func (c *UserController) Power_Del() {
  1182. id, id_err := c.GetInt("T_id")
  1183. if id_err != nil || id == 0 {
  1184. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1185. c.ServeJSON()
  1186. return
  1187. }
  1188. r, err := Account.Read_Power_ById(id)
  1189. if err != nil {
  1190. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1191. c.ServeJSON()
  1192. return
  1193. }
  1194. if cnt := Account.Read_Admin_Num_ByT_power(id); cnt > 0 {
  1195. c.Data["json"] = lib.JSONS{Code: 202, Msg: "有关联用户,禁止删除!"}
  1196. c.ServeJSON()
  1197. return
  1198. }
  1199. is := Account.Delete_Power(r)
  1200. if !is {
  1201. c.Data["json"] = lib.JSONS{Code: 302, Msg: "删除失败!"}
  1202. c.ServeJSON()
  1203. return
  1204. }
  1205. System.Add_UserLogs(c.Admin_r.T_uuid, "权限管理", "删除", strconv.Itoa(id))
  1206. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1207. c.ServeJSON()
  1208. return
  1209. }
  1210. // 菜单列表
  1211. func (c *UserController) User_Menu_List() {
  1212. type R_JSONS struct {
  1213. //必须的大写开头
  1214. Data interface{}
  1215. Permission interface{}
  1216. }
  1217. var r_jsons R_JSONS
  1218. power, err := Account.Read_Power_ById(c.Admin_r.T_power)
  1219. if err != nil {
  1220. c.Data["json"] = lib.JSONS{Code: 202, Msg: "获取菜单失败"}
  1221. c.ServeJSON()
  1222. return
  1223. }
  1224. //logs.Println("登录用户 菜单 pid 为:", c.T_pid)
  1225. ret := Account.Read_Menu_Bind_List(power.Id, power.T_menu, c.T_pid)
  1226. r_jsons.Data = ret.Menu
  1227. r_jsons.Permission = ret.Permission
  1228. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1229. c.ServeJSON()
  1230. return
  1231. }
  1232. // 权限菜单列表
  1233. func (c *UserController) Menu_List_All() {
  1234. var r_jsons lib.R_JSONS
  1235. r_jsons.Data, _ = Account.Read_Menu_List_All()
  1236. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1237. c.ServeJSON()
  1238. return
  1239. }
  1240. func (c *UserController) Menu_Excel() {
  1241. filename := fmt.Sprintf("冷链3.0菜单")
  1242. f := excelize.NewFile()
  1243. Style1, _ := f.NewStyle(
  1244. &excelize.Style{
  1245. Font: &excelize.Font{Bold: true, Size: 16, Family: "宋体"},
  1246. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center"},
  1247. })
  1248. Style2, _ := f.NewStyle(
  1249. &excelize.Style{
  1250. Font: &excelize.Font{Bold: true, Size: 14, Family: "宋体"},
  1251. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1252. Border: []excelize.Border{
  1253. {Type: "left", Color: "000000", Style: 1},
  1254. {Type: "top", Color: "000000", Style: 1},
  1255. {Type: "bottom", Color: "000000", Style: 1},
  1256. {Type: "right", Color: "000000", Style: 1},
  1257. },
  1258. })
  1259. f.MergeCell("Sheet1", "A1", "G1")
  1260. f.SetRowStyle("Sheet1", 1, 1, Style1)
  1261. f.SetCellValue("Sheet1", "A1", "Menu")
  1262. f.SetRowHeight("Sheet1", 1, 30)
  1263. f.MergeCell("Sheet1", "H1", "M1")
  1264. f.SetRowStyle("Sheet1", 1, 1, Style1)
  1265. f.SetCellValue("Sheet1", "H1", "API")
  1266. f.SetRowHeight("Sheet1", 1, 30)
  1267. f.SetCellStyle("Sheet1", "A2", "G2", Style2)
  1268. f.SetRowHeight("Sheet1", 2, 25)
  1269. // 这里设置表头
  1270. f.SetCellValue("Sheet1", "A2", "ID")
  1271. f.SetCellValue("Sheet1", "B2", "t_mid")
  1272. f.SetCellValue("Sheet1", "C2", "t_name")
  1273. f.SetCellValue("Sheet1", "D2", "t_permission")
  1274. f.SetCellValue("Sheet1", "E2", "t_sort")
  1275. f.SetCellValue("Sheet1", "F2", "t_pid")
  1276. f.SetCellValue("Sheet1", "G2", "t_icon")
  1277. f.SetCellValue("Sheet1", "H2", "ID")
  1278. f.SetCellValue("Sheet1", "I2", "t__menu__id")
  1279. f.SetCellValue("Sheet1", "J2", "t_name")
  1280. f.SetCellValue("Sheet1", "K2", "t_uri")
  1281. f.SetCellValue("Sheet1", "L2", "t_method")
  1282. f.SetCellValue("Sheet1", "M2", "t_enable")
  1283. // 设置列宽
  1284. f.SetColWidth("Sheet1", "A", "M", 15)
  1285. line := 2
  1286. menu := Account.Read_Menu_All()
  1287. for _, m := range menu {
  1288. Menu_Call(f, m, line)
  1289. }
  1290. Style11, _ := f.NewStyle(
  1291. &excelize.Style{
  1292. Font: &excelize.Font{Size: 10, Family: "宋体"},
  1293. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1294. Border: []excelize.Border{
  1295. {Type: "top", Color: "000000", Style: 1},
  1296. },
  1297. })
  1298. Style22, _ := f.NewStyle(
  1299. &excelize.Style{
  1300. Font: &excelize.Font{Size: 10, Family: "宋体"},
  1301. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1302. Border: []excelize.Border{
  1303. {Type: "left", Color: "000000", Style: 1},
  1304. },
  1305. })
  1306. Style33, _ := f.NewStyle(
  1307. &excelize.Style{
  1308. Font: &excelize.Font{Size: 10, Family: "宋体"},
  1309. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1310. Border: []excelize.Border{
  1311. {Type: "right", Color: "000000", Style: 1},
  1312. },
  1313. })
  1314. Style44, _ := f.NewStyle(
  1315. &excelize.Style{
  1316. Font: &excelize.Font{Size: 10, Family: "宋体"},
  1317. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1318. Border: []excelize.Border{
  1319. {Type: "bottom", Color: "000000", Style: 1},
  1320. },
  1321. })
  1322. //// 循环写入数据
  1323. for _, v := range menu {
  1324. line1 := line
  1325. line = Menu_Call(f, v, line)
  1326. f.SetCellStyle("Sheet1", fmt.Sprintf("A%d", line1), fmt.Sprintf("M%d", line1), Style11)
  1327. f.SetCellStyle("Sheet1", fmt.Sprintf("A%d", line), fmt.Sprintf("A%d", line), Style22)
  1328. f.SetCellStyle("Sheet1", fmt.Sprintf("M%d", line), fmt.Sprintf("M%d", line), Style33)
  1329. f.SetCellStyle("Sheet1", fmt.Sprintf("A%d", line), fmt.Sprintf("M%d", line), Style44)
  1330. }
  1331. timeStr := filename + fmt.Sprintf("(%s)", lib.GetRandstring(8, "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789", 0))
  1332. // 保存文件
  1333. if err := f.SaveAs("ofile/" + timeStr + ".xlsx"); err != nil {
  1334. fmt.Println(err)
  1335. }
  1336. var url string
  1337. ////// 上传 OSS
  1338. //url, is := NatsServer.Qiniu_UploadFile(lib.GetCurrentDirectory()+"/ofile/"+timeStr+".xlsx", "ofile/"+timeStr+".xlsx")
  1339. //if !is {
  1340. // c.Data["json"] = lib.JSONS{Code: 202, Msg: "oss!"}
  1341. // c.ServeJSON()
  1342. // return
  1343. //}
  1344. ////删除目录
  1345. //err = os.Remove("ofile/" + timeStr + ".xlsx")
  1346. //if err != nil {
  1347. // fmt.Println(err)
  1348. //}
  1349. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: url}
  1350. c.ServeJSON()
  1351. return
  1352. }
  1353. func Menu_Call(f *excelize.File, v Account.Menu, line int) int {
  1354. line++
  1355. f.SetCellValue("Sheet1", fmt.Sprintf("A%d", line), v.Id)
  1356. f.SetCellValue("Sheet1", fmt.Sprintf("B%d", line), v.T_mid)
  1357. f.SetCellValue("Sheet1", fmt.Sprintf("C%d", line), v.T_name)
  1358. f.SetCellValue("Sheet1", fmt.Sprintf("D%d", line), v.T_permission)
  1359. f.SetCellValue("Sheet1", fmt.Sprintf("E%d", line), v.T_sort)
  1360. f.SetCellValue("Sheet1", fmt.Sprintf("F%d", line), v.T_pid)
  1361. f.SetCellValue("Sheet1", fmt.Sprintf("G%d", line), v.T_icon)
  1362. apiList := Account.Read_API_List_ByMenuId(v.Id)
  1363. for _, api := range apiList {
  1364. f.SetCellValue("Sheet1", fmt.Sprintf("H%d", line), api.Id)
  1365. f.SetCellValue("Sheet1", fmt.Sprintf("I%d", line), api.T_Menu_Id)
  1366. f.SetCellValue("Sheet1", fmt.Sprintf("J%d", line), api.T_name)
  1367. f.SetCellValue("Sheet1", fmt.Sprintf("K%d", line), api.T_uri)
  1368. f.SetCellValue("Sheet1", fmt.Sprintf("L%d", line), api.T_method)
  1369. f.SetCellValue("Sheet1", fmt.Sprintf("M%d", line), api.T_enable)
  1370. line++
  1371. }
  1372. return line
  1373. }
  1374. // 流量池
  1375. func (c *UserController) Flow_Pool() {
  1376. var r_jsons lib.R_JSONS
  1377. r_jsons.Data, _ = lib.Yidong_group_data_margin()
  1378. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1379. c.ServeJSON()
  1380. return
  1381. }
  1382. // 账单下载
  1383. func (c *UserController) CompanyBill_Excel() {
  1384. T_month := c.GetString("T_month")
  1385. _, err := time.Parse("2006-01", T_month)
  1386. if err != nil {
  1387. c.Data["json"] = lib.JSONS{Code: 202, Msg: "日期格式错误!"}
  1388. c.ServeJSON()
  1389. return
  1390. }
  1391. year, month := strings.Split(T_month, "-")[0], strings.Split(T_month, "-")[1]
  1392. company, _ := Account.Read_Company_ById(c.Admin_r.T_pid)
  1393. if err != nil {
  1394. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1395. c.ServeJSON()
  1396. return
  1397. }
  1398. filename := fmt.Sprintf("%s%s年%s月账单", company.T_name, year, month)
  1399. f := excelize.NewFile()
  1400. Style1, _ := f.NewStyle(
  1401. &excelize.Style{
  1402. Font: &excelize.Font{Bold: true, Size: 16, Family: "宋体"},
  1403. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center"},
  1404. })
  1405. Style2, _ := f.NewStyle(
  1406. &excelize.Style{
  1407. Font: &excelize.Font{Bold: true, Size: 14, Family: "宋体"},
  1408. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1409. Border: []excelize.Border{
  1410. {Type: "left", Color: "000000", Style: 1},
  1411. {Type: "top", Color: "000000", Style: 1},
  1412. {Type: "bottom", Color: "000000", Style: 1},
  1413. {Type: "right", Color: "000000", Style: 1},
  1414. },
  1415. })
  1416. f.MergeCell("Sheet1", "A1", "G1")
  1417. f.SetRowStyle("Sheet1", 1, 1, Style1)
  1418. f.SetCellValue("Sheet1", "A1", filename)
  1419. f.SetRowHeight("Sheet1", 1, 30)
  1420. f.SetCellStyle("Sheet1", "A2", "G2", Style2)
  1421. f.SetRowHeight("Sheet1", 2, 25)
  1422. // 这里设置表头
  1423. f.SetCellValue("Sheet1", "A2", "编号")
  1424. f.SetCellValue("Sheet1", "B2", "项目")
  1425. f.SetCellValue("Sheet1", "C2", "说明")
  1426. f.SetCellValue("Sheet1", "D2", "扣费/充值")
  1427. f.SetCellValue("Sheet1", "E2", "金额(元)")
  1428. f.SetCellValue("Sheet1", "F2", "余额(元)")
  1429. f.SetCellValue("Sheet1", "G2", "时间")
  1430. // 设置列宽
  1431. f.SetColWidth("Sheet1", "A", "A", 10)
  1432. f.SetColWidth("Sheet1", "B", "B", 50)
  1433. f.SetColWidth("Sheet1", "C", "C", 15)
  1434. f.SetColWidth("Sheet1", "D", "D", 12)
  1435. f.SetColWidth("Sheet1", "E", "E", 15)
  1436. f.SetColWidth("Sheet1", "F", "F", 15)
  1437. f.SetColWidth("Sheet1", "G", "G", 20)
  1438. line := 2
  1439. CompanyBill_List, err := Company.Read_CompanyBill_List(c.Admin_r.T_pid, T_month)
  1440. if err != nil {
  1441. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1442. c.ServeJSON()
  1443. return
  1444. }
  1445. // 循环写入数据
  1446. for i, v := range CompanyBill_List {
  1447. line++
  1448. f.SetCellValue("Sheet1", fmt.Sprintf("A%d", line), i+1)
  1449. f.SetCellValue("Sheet1", fmt.Sprintf("B%d", line), v.T_project)
  1450. f.SetCellValue("Sheet1", fmt.Sprintf("C%d", line), v.T_bill)
  1451. f.SetCellValue("Sheet1", fmt.Sprintf("D%d", line), v.T_type)
  1452. f.SetCellValue("Sheet1", fmt.Sprintf("E%d", line), v.T_charging)
  1453. f.SetCellValue("Sheet1", fmt.Sprintf("F%d", line), v.T_balance)
  1454. f.SetCellValue("Sheet1", fmt.Sprintf("G%d", line), v.CreateTime.Format("2006-01-02"))
  1455. }
  1456. Style4, _ := f.NewStyle(
  1457. &excelize.Style{
  1458. Font: &excelize.Font{Size: 12, Family: "宋体"},
  1459. Alignment: &excelize.Alignment{Horizontal: "center", Vertical: "center", WrapText: true},
  1460. Border: []excelize.Border{
  1461. {Type: "left", Color: "000000", Style: 1},
  1462. {Type: "top", Color: "000000", Style: 1},
  1463. {Type: "bottom", Color: "000000", Style: 1},
  1464. {Type: "right", Color: "000000", Style: 1},
  1465. },
  1466. })
  1467. f.SetCellStyle("Sheet1", "A2", fmt.Sprintf("G%d", line), Style4)
  1468. timeStr := filename + fmt.Sprintf("(%s)", lib.GetRandstring(8, "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789", 0))
  1469. // 保存文件
  1470. if err = f.SaveAs("ofile/" + timeStr + ".xlsx"); err != nil {
  1471. fmt.Println(err)
  1472. }
  1473. var url string
  1474. //// 上传 OSS
  1475. url, is := NatsServer.Qiniu_UploadFile(lib.GetCurrentDirectory()+"/ofile/"+timeStr+".xlsx", "ofile/"+timeStr+".xlsx")
  1476. if !is {
  1477. c.Data["json"] = lib.JSONS{Code: 202, Msg: "oss!"}
  1478. c.ServeJSON()
  1479. return
  1480. }
  1481. //删除目录
  1482. err = os.Remove("ofile/" + timeStr + ".xlsx")
  1483. if err != nil {
  1484. fmt.Println(err)
  1485. }
  1486. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: url}
  1487. c.ServeJSON()
  1488. return
  1489. }
  1490. // 获取微信支付二维码
  1491. func (c *UserController) WxPay_QRCode() {
  1492. if c.Admin_r.T_pid == 0 {
  1493. c.Data["json"] = lib.JSONS{Code: 202, Msg: "非公司用户不能充值"}
  1494. c.ServeJSON()
  1495. return
  1496. }
  1497. Total, _ := c.GetFloat("Total")
  1498. Title := "冷链3.0-" + c.Admin_r.T_user
  1499. res, err := lib.PayTransactionNative(Title, Total)
  1500. if err != nil {
  1501. c.Data["json"] = lib.JSONS{Code: 202, Msg: err.Error()}
  1502. c.ServeJSON()
  1503. return
  1504. }
  1505. if res.Code != 200 {
  1506. c.Data["json"] = lib.JSONS{Code: 202, Msg: res.Message}
  1507. c.ServeJSON()
  1508. return
  1509. }
  1510. var_ := Company.CompanyPayOrder{
  1511. T_pid: c.Admin_r.T_pid,
  1512. T_type: "微信",
  1513. T_title: Title,
  1514. T_total: Total,
  1515. T_order_no: res.OrderNo,
  1516. T_remark: c.Admin_r.T_uuid,
  1517. }
  1518. _, err = Company.Add_CompanyPayOrder(var_)
  1519. if err != nil {
  1520. c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加订单失败!"}
  1521. c.ServeJSON()
  1522. return
  1523. }
  1524. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: res}
  1525. c.ServeJSON()
  1526. return
  1527. }
  1528. // 微信支付回调
  1529. func (c *UserController) WxPay_Notify() {
  1530. type RequestBody struct {
  1531. TradeNo string
  1532. Status string
  1533. }
  1534. type JSON struct {
  1535. Code int
  1536. Message string
  1537. }
  1538. buf := make([]byte, 1024)
  1539. n, _ := c.Ctx.Request.Body.Read(buf)
  1540. logs.Info("Body================ ", string(buf[0:n]))
  1541. //解密
  1542. adc_str, _ := lib.AesDeCrypt(buf[0:n], []byte(conf.Weixin_PwdKey))
  1543. //adc_str, _ := lib.AesDeCrypt(buf[0:n], []byte(conf.Weixin_PwdKey))
  1544. var body RequestBody
  1545. logs.Info("data================ ", string(adc_str))
  1546. err := json.Unmarshal(adc_str, &body)
  1547. if err != nil {
  1548. c.Data["json"] = JSON{Code: 202, Message: "json.Unmarshal is err:" + err.Error()}
  1549. c.ServeJSON()
  1550. }
  1551. payOrder, err := Company.Get_CompanyPayOrder_ByT_order_no(body.TradeNo)
  1552. if err != nil {
  1553. c.Data["json"] = JSON{Code: 202, Message: "查询失败!"}
  1554. c.ServeJSON()
  1555. return
  1556. }
  1557. //交易状态
  1558. //SUCCESS:支付成功
  1559. //REFUND:转入退款
  1560. //NOTPAY:未支付
  1561. //CLOSED:已关闭
  1562. //REVOKED:已撤销(付款码支付)
  1563. //USERPAYING:用户支付中(付款码支付)
  1564. //PAYERROR:支付失败(其他原因,如银行返回失败)
  1565. payOrder.T_status = body.Status
  1566. err = Company.Update_CompanyPayOrder(payOrder, "T_status")
  1567. if err != nil {
  1568. c.Data["json"] = JSON{Code: 202, Message: "更新状态失败!"}
  1569. c.ServeJSON()
  1570. return
  1571. }
  1572. // 添加充值记录
  1573. // 余额加上充值金额
  1574. if body.Status == "SUCCESS" {
  1575. Company_r, err := Account.Read_Company_ById(payOrder.T_pid)
  1576. if err != nil {
  1577. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  1578. c.ServeJSON()
  1579. return
  1580. }
  1581. T_money64, _ := decimal.NewFromFloat(float64(Company_r.T_money) + payOrder.T_total).Round(2).Float64()
  1582. Company_r.T_money = float32(T_money64)
  1583. is := Account.Update_Company(Company_r, "T_money")
  1584. if !is {
  1585. c.Data["json"] = lib.JSONS{Code: 202, Msg: "充值失败!"}
  1586. c.ServeJSON()
  1587. return
  1588. }
  1589. }
  1590. c.Data["json"] = JSON{Code: 200, Message: "成功"}
  1591. c.ServeJSON()
  1592. return
  1593. }
  1594. // 获取微信支付订单状态
  1595. func (c *UserController) WxPay_GetOrderState() {
  1596. OrderNo := c.GetString("OrderNo")
  1597. payOrder, err := Company.Get_CompanyPayOrder_ByT_order_no(OrderNo)
  1598. if err != nil {
  1599. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1600. c.ServeJSON()
  1601. return
  1602. }
  1603. c.Data["json"] = lib.JSONS{Code: 200, Msg: "成功", Data: payOrder}
  1604. c.ServeJSON()
  1605. return
  1606. }
  1607. // 设备分类绑定
  1608. func (c *UserController) UserDeviceBind_List() {
  1609. var r_jsons lib.R_JSONS
  1610. page, _ := c.GetInt("page")
  1611. if page < 1 {
  1612. page = 1
  1613. }
  1614. page_z, _ := c.GetInt("page_z")
  1615. if page_z < 1 {
  1616. page_z = conf.Page_size
  1617. }
  1618. T_name := c.GetString("T_name")
  1619. T_uuid := c.GetString("T_uuid")
  1620. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  1621. if err != nil {
  1622. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1623. c.ServeJSON()
  1624. return
  1625. }
  1626. bindSN, err := Account.Read_UserDevice_List(admin_r)
  1627. if err != nil {
  1628. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1629. c.ServeJSON()
  1630. return
  1631. }
  1632. if len(bindSN) == 0 {
  1633. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1634. c.ServeJSON()
  1635. return
  1636. }
  1637. r_jsons.Data, r_jsons.Num = Device.Read_Device_List(&c.Admin_r, bindSN, c.T_pid, T_name, "", "", page, page_z)
  1638. r_jsons.Page = page
  1639. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1640. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1641. c.ServeJSON()
  1642. return
  1643. }
  1644. func (c *UserController) UserDeviceUnbind_List() {
  1645. var r_jsons lib.R_JSONS
  1646. page, _ := c.GetInt("page")
  1647. if page < 1 {
  1648. page = 1
  1649. }
  1650. page_z, _ := c.GetInt("page_z")
  1651. if page_z < 1 {
  1652. page_z = conf.Page_size
  1653. }
  1654. T_name := c.GetString("T_name")
  1655. T_uuid := c.GetString("T_uuid")
  1656. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  1657. if err != nil {
  1658. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1659. c.ServeJSON()
  1660. return
  1661. }
  1662. bindSN, err := Account.Read_UserDevice_List(admin_r)
  1663. if err != nil {
  1664. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1665. c.ServeJSON()
  1666. return
  1667. }
  1668. r_jsons.Data, r_jsons.Num = Device.Read_User_Unbind_Device_List(&c.Admin_r, bindSN, c.T_pid, T_name, page, page_z)
  1669. r_jsons.Page = page
  1670. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  1671. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  1672. c.ServeJSON()
  1673. return
  1674. }
  1675. func (c *UserController) UserDeviceBind_Add() {
  1676. T_sn := c.GetString("T_sn")
  1677. T_uuid := c.GetString("T_uuid")
  1678. T_oneHey, _ := c.GetInt("T_oneKey") // 一键绑定
  1679. if T_oneHey == 1 {
  1680. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  1681. if err != nil {
  1682. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1683. c.ServeJSON()
  1684. return
  1685. }
  1686. bindSN, err := Account.Read_UserDevice_List(admin_r)
  1687. if err != nil {
  1688. c.Data["json"] = lib.JSONS{Code: 202, Msg: "查询失败!"}
  1689. c.ServeJSON()
  1690. return
  1691. }
  1692. Unbind_Device_List, _ := Device.Read_User_Unbind_Device_List(&c.Admin_r, bindSN, c.T_pid, "", 0, 9999)
  1693. var UserDeviceList []Account.UserDevice
  1694. for _, r := range Unbind_Device_List {
  1695. UserDeviceList = append(UserDeviceList, Account.UserDevice{T_sn: r.T_sn, T_uuid: T_uuid})
  1696. }
  1697. if _, err = Account.Add_UserDevice_Multi(T_uuid, UserDeviceList); err != nil {
  1698. c.Data["json"] = lib.JSONS{Code: 200, Msg: "绑定失败"}
  1699. c.ServeJSON()
  1700. return
  1701. }
  1702. System.Add_UserLogs(c.Admin_r.T_uuid, "用户管理", "一键绑定主机操作", T_uuid+"-"+T_sn)
  1703. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1704. c.ServeJSON()
  1705. return
  1706. }
  1707. if len(T_uuid) == 0 || len(T_sn) == 0 {
  1708. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1709. c.ServeJSON()
  1710. return
  1711. }
  1712. if len(T_uuid) < 8 {
  1713. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1714. c.ServeJSON()
  1715. return
  1716. }
  1717. device, err := Device.Read_Device_ByT_sn(T_sn)
  1718. if err != nil {
  1719. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  1720. c.ServeJSON()
  1721. return
  1722. }
  1723. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  1724. if err != nil {
  1725. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1726. c.ServeJSON()
  1727. return
  1728. }
  1729. if admin_r.T_pid != device.T_pid {
  1730. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1731. c.ServeJSON()
  1732. return
  1733. }
  1734. userdievice, err := Account.Read_UserDevice_ByT_uuid_T_sn(T_uuid, T_sn)
  1735. if userdievice.Id > 0 {
  1736. c.Data["json"] = lib.JSONS{Code: 202, Msg: "重复绑定!"}
  1737. c.ServeJSON()
  1738. return
  1739. }
  1740. if _, err = Account.Add_UserDevice(Account.UserDevice{T_sn: T_sn, T_uuid: T_uuid}); err != nil {
  1741. c.Data["json"] = lib.JSONS{Code: 200, Msg: "绑定失败"}
  1742. c.ServeJSON()
  1743. return
  1744. }
  1745. System.Add_UserLogs(c.Admin_r.T_uuid, "用户管理", "绑定主机操作", T_uuid+"-"+T_sn)
  1746. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1747. c.ServeJSON()
  1748. return
  1749. }
  1750. func (c *UserController) UserDeviceBind_Del() {
  1751. T_sn := c.GetString("T_sn")
  1752. T_uuid := c.GetString("T_uuid")
  1753. if len(T_uuid) == 0 || len(T_sn) == 0 {
  1754. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn T_id T_class_id Err!"}
  1755. c.ServeJSON()
  1756. return
  1757. }
  1758. if len(T_uuid) < 8 {
  1759. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1760. c.ServeJSON()
  1761. return
  1762. }
  1763. device, err := Device.Read_Device_ByT_sn(T_sn)
  1764. if err != nil {
  1765. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_sn Err!"}
  1766. c.ServeJSON()
  1767. return
  1768. }
  1769. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  1770. if err != nil {
  1771. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  1772. c.ServeJSON()
  1773. return
  1774. }
  1775. if admin_r.T_pid != device.T_pid {
  1776. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  1777. c.ServeJSON()
  1778. return
  1779. }
  1780. userdievice, err := Account.Read_UserDevice_ByT_uuid_T_sn(T_uuid, T_sn)
  1781. if err != nil {
  1782. if err.Error() == orm.ErrNoRows.Error() {
  1783. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1784. c.ServeJSON()
  1785. return
  1786. }
  1787. c.Data["json"] = lib.JSONS{Code: 202, Msg: "解绑失败!"}
  1788. c.ServeJSON()
  1789. return
  1790. }
  1791. if err = Account.Delete_UserDevice(Account.UserDevice{Id: userdievice.Id, T_sn: T_sn, T_uuid: T_uuid}); err != nil {
  1792. c.Data["json"] = lib.JSONS{Code: 200, Msg: "删除失败"}
  1793. c.ServeJSON()
  1794. return
  1795. }
  1796. System.Add_UserLogs(c.Admin_r.T_uuid, "用户管理", "解绑主机操作", T_uuid+"-"+T_sn)
  1797. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  1798. c.ServeJSON()
  1799. return
  1800. }