User.go 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125
  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/System"
  10. "Cold_Api/models/Warning"
  11. "github.com/beego/beego/v2/adapter/orm"
  12. beego "github.com/beego/beego/v2/server/web"
  13. uuid "github.com/satori/go.uuid"
  14. "math"
  15. "strconv"
  16. "time"
  17. )
  18. type UserController struct {
  19. beego.Controller
  20. Admin_r Account.Admin // 登陆的用户
  21. T_pid int // 公司id
  22. }
  23. func (c *UserController) Prepare() {
  24. GetCookie := c.Ctx.GetCookie("User_tokey")
  25. GetString := c.GetString("User_tokey")
  26. User_tokey := GetCookie
  27. if len(User_tokey) == 0 {
  28. User_tokey = GetString
  29. }
  30. c.Admin_r = *Account.Admin_r
  31. T_pid := c.Admin_r.T_pid
  32. if T_pid == 0 {
  33. T_pid, _ = Account.Redis_Tokey_T_pid_Get(User_tokey)
  34. }
  35. c.T_pid = T_pid
  36. }
  37. // 获取微信二维码 ( 扫描后 ,Nats 自动绑定在 Admin->T_wx )
  38. func (c *UserController) User_WxQRCode() {
  39. T_name := c.GetString("T_name")
  40. WxQRCode_str, _ := NatsServer.Wx_GenerateQRCode("-|" + lib.AesEncryptCBC(c.Admin_r.T_uuid+"/"+T_name, "0123456789012345") + "|- @宝智达冷链 微信公众号通知")
  41. WxQRCode_str = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=" + WxQRCode_str
  42. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: WxQRCode_str}
  43. c.ServeJSON()
  44. return
  45. }
  46. // 公司管理
  47. func (c *UserController) Company_Tree() {
  48. var r_jsons lib.R_JSONS
  49. T_name := c.GetString("T_name")
  50. r_jsons.Data = Account.Read_Company_Tree(c.Admin_r, T_name)
  51. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  52. c.ServeJSON()
  53. return
  54. }
  55. func (c *UserController) Company_List() {
  56. var r_jsons lib.R_JSONS
  57. T_name := c.GetString("T_name")
  58. r_jsons.Data = Account.Read_Company_List(T_name)
  59. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  60. c.ServeJSON()
  61. return
  62. }
  63. func (c *UserController) Company_Get() {
  64. var r_jsons lib.R_JSONS
  65. Company_r, err := Account.Read_Company_ById(c.T_pid)
  66. if err != nil {
  67. logs.Warning(lib.FuncName(), "获取公司信息失败", err)
  68. }
  69. r_jsons.Data = Account.CompanyToCompany_R(Company_r)
  70. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  71. c.ServeJSON()
  72. return
  73. }
  74. func (c *UserController) Company_Add() {
  75. T_mid, _ := c.GetInt("T_mid")
  76. T_name := c.GetString("T_name")
  77. T_plan := c.GetString("T_plan")
  78. T_data := c.GetString("T_data")
  79. T_v3d := c.GetString("T_v3d")
  80. var_ := Account.Company{
  81. T_mid: T_mid,
  82. T_name: T_name,
  83. T_State: 1,
  84. T_plan: T_plan,
  85. T_data: T_data,
  86. T_v3d: T_v3d,
  87. }
  88. id, err := Account.Add_Company(var_)
  89. if err != nil {
  90. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  91. c.ServeJSON()
  92. return
  93. }
  94. if c.Admin_r.T_pids != "*" {
  95. T_pids := []int{int(id)}
  96. if err = Account.Add_Company_bind(c.Admin_r, T_pids); err != nil {
  97. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  98. c.ServeJSON()
  99. return
  100. }
  101. }
  102. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "添加", var_)
  103. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: id}
  104. c.ServeJSON()
  105. return
  106. }
  107. func (c *UserController) Company_Edit() {
  108. Id, Id_err := c.GetInt("Id")
  109. if Id_err != nil {
  110. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  111. c.ServeJSON()
  112. return
  113. }
  114. Company_r, err := Account.Read_Company_ById(Id)
  115. if err != nil {
  116. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  117. c.ServeJSON()
  118. return
  119. }
  120. T_name := c.GetString("T_name")
  121. T_plan := c.GetString("T_plan")
  122. T_data := c.GetString("T_data")
  123. T_v3d := c.GetString("T_v3d")
  124. if len(T_name) > 0 {
  125. Company_r.T_name = T_name
  126. }
  127. if len(T_plan) > 0 {
  128. Company_r.T_plan = T_plan
  129. }
  130. if len(T_data) > 0 {
  131. Company_r.T_data = T_data
  132. }
  133. if len(T_v3d) > 0 {
  134. Company_r.T_v3d = T_v3d
  135. }
  136. is := Account.Update_Company(Company_r, "T_name", "T_plan", "T_data", "T_v3d")
  137. if !is {
  138. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  139. c.ServeJSON()
  140. return
  141. }
  142. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "修改", Company_r)
  143. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  144. c.ServeJSON()
  145. return
  146. }
  147. func (c *UserController) Company_Del() {
  148. Id, Id_err := c.GetInt("Id")
  149. if Id_err != nil {
  150. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  151. c.ServeJSON()
  152. return
  153. }
  154. Company_r, err := Account.Read_Company_ById(Id)
  155. if err != nil {
  156. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  157. c.ServeJSON()
  158. return
  159. }
  160. ids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  161. if cnt := Account.Read_Admin_Num_ByT_pid(ids); cnt > 0 {
  162. c.Data["json"] = lib.JSONS{Code: 202, Msg: "有关联用户,禁止删除!"}
  163. c.ServeJSON()
  164. return
  165. }
  166. o := orm.NewOrm()
  167. o.Begin()
  168. for _, id := range ids {
  169. if is := Account.Delete_Company(o, id); !is {
  170. o.Rollback()
  171. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  172. c.ServeJSON()
  173. return
  174. }
  175. if err = Account.Delete_Company_bind_T_pids(o, id); err != nil {
  176. o.Rollback()
  177. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  178. c.ServeJSON()
  179. return
  180. }
  181. }
  182. o.Commit()
  183. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "删除", Company_r)
  184. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  185. c.ServeJSON()
  186. return
  187. }
  188. // 进入公司
  189. func (c *UserController) Company_Entry() {
  190. GetCookie := c.Ctx.GetCookie("User_tokey")
  191. GetString := c.GetString("User_tokey")
  192. User_tokey := GetCookie
  193. if len(User_tokey) == 0 {
  194. User_tokey = GetString
  195. }
  196. T_pid, _ := c.GetInt("T_pid")
  197. if T_pid < 0 {
  198. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  199. c.ServeJSON()
  200. return
  201. }
  202. Account.Redis_Tokey_T_pid_Set(User_tokey, T_pid)
  203. System.Add_UserLogs_T(c.Admin_r.T_uuid, "公司管理", "进入公司", T_pid)
  204. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  205. c.ServeJSON()
  206. return
  207. }
  208. // 检查 Tokey 是否过期
  209. // 用户管理
  210. func (c *UserController) User_List() {
  211. var r_jsons lib.R_JSONS
  212. page, _ := c.GetInt("page")
  213. if page < 1 {
  214. page = 1
  215. }
  216. page_z, _ := c.GetInt("page_z")
  217. if page_z < 1 {
  218. page_z = conf.Page_size
  219. }
  220. T_name := c.GetString("T_name")
  221. Account.Read_Power_All_Map()
  222. r_jsons.Data, r_jsons.Num = Account.Read_Admin_List(c.T_pid, T_name, page, page_z)
  223. r_jsons.Page = page
  224. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  225. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  226. c.ServeJSON()
  227. return
  228. }
  229. func (c *UserController) User_Get() {
  230. T_uuid := c.GetString("T_uuid")
  231. if len(T_uuid) < 8 {
  232. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  233. c.ServeJSON()
  234. return
  235. }
  236. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  237. if err != nil {
  238. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  239. c.ServeJSON()
  240. return
  241. }
  242. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Account.AdminToAdmin_R(admin_r)}
  243. c.ServeJSON()
  244. return
  245. }
  246. func (c *UserController) User_Info() {
  247. type User_ struct {
  248. User Account.Admin_R
  249. //Power Account.Power // 权限
  250. //Menu map[string]Account.Menu_R // 菜单
  251. //Menu []Account.Menu // 菜单
  252. }
  253. Admin_r := User_{}
  254. Admin_r.User = Account.AdminToAdmin_R(c.Admin_r)
  255. //Admin_r.Power, _ = Account.Read_Power_ById(admin_r.T_power)
  256. //Admin_r.Menu = Account.Read_Menu_Tree(Power.T_menu, T_pid)
  257. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Admin_r}
  258. c.ServeJSON()
  259. return
  260. }
  261. func (c *UserController) User_Post() {
  262. admin_r := c.Admin_r
  263. T_name := c.GetString("T_name")
  264. T_pass := c.GetString("T_pass")
  265. T_phone := c.GetString("T_phone")
  266. T_mail := c.GetString("T_mail")
  267. T_wx := c.GetString("T_wx")
  268. if len(T_pass) < 8 && len(T_pass) > 0 {
  269. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  270. c.ServeJSON()
  271. return
  272. }
  273. if len(T_name) > 0 {
  274. admin_r.T_name = T_name
  275. }
  276. if len(T_pass) >= 8 {
  277. admin_r.T_pass = T_pass
  278. }
  279. if len(T_phone) > 0 {
  280. admin_r.T_phone = T_phone
  281. }
  282. if len(T_mail) > 0 {
  283. admin_r.T_mail = T_mail
  284. }
  285. if len(T_wx) > 0 {
  286. if T_wx == "-" {
  287. T_wx = ""
  288. }
  289. admin_r.T_wx = T_wx
  290. }
  291. is := Account.Update_Admin(admin_r, "T_name", "T_pass", "T_phone", "T_mail", "T_wx")
  292. if !is {
  293. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  294. c.ServeJSON()
  295. return
  296. }
  297. admin_r.T_pass = "******"
  298. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "修改个人信息", admin_r)
  299. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  300. c.ServeJSON()
  301. return
  302. }
  303. func (c *UserController) User_Add() {
  304. T_power, _ := c.GetInt("T_power")
  305. T_name := c.GetString("T_name")
  306. T_user := c.GetString("T_user")
  307. T_pass := c.GetString("T_pass")
  308. T_phone := c.GetString("T_phone")
  309. T_mail := c.GetString("T_mail")
  310. T_wx := c.GetString("T_wx")
  311. T_uuid := uuid.NewV4().String()
  312. var_ := Account.Admin{
  313. T_uuid: T_uuid,
  314. T_pid: c.T_pid,
  315. T_name: T_name,
  316. T_user: T_user,
  317. T_phone: T_phone,
  318. T_mail: T_mail,
  319. T_wx: T_wx,
  320. T_pass: T_pass,
  321. T_power: T_power,
  322. T_State: 1,
  323. }
  324. if len(T_pass) < 8 {
  325. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  326. c.ServeJSON()
  327. return
  328. }
  329. _, err := Account.Read_Admin_T_user(T_user)
  330. if err == nil {
  331. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  332. c.ServeJSON()
  333. return
  334. }
  335. _, err = Account.Add_Admin(var_)
  336. if err != nil {
  337. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  338. c.ServeJSON()
  339. return
  340. }
  341. var_.T_pass = "******"
  342. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "添加", var_)
  343. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  344. c.ServeJSON()
  345. return
  346. }
  347. func (c *UserController) User_Edit() {
  348. T_uuid := c.GetString("T_uuid")
  349. if len(T_uuid) < 8 {
  350. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  351. c.ServeJSON()
  352. return
  353. }
  354. r, err := Account.Read_Admin_ByUuid(T_uuid)
  355. if err != nil {
  356. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  357. c.ServeJSON()
  358. return
  359. }
  360. T_power, T_power_err := c.GetInt("T_power")
  361. T_name := c.GetString("T_name")
  362. T_pass := c.GetString("T_pass")
  363. T_phone := c.GetString("T_phone")
  364. T_mail := c.GetString("T_mail")
  365. if T_power_err == nil {
  366. r.T_power = T_power
  367. }
  368. if len(T_pass) < 8 && len(T_pass) > 0 {
  369. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  370. c.ServeJSON()
  371. return
  372. }
  373. if len(T_name) > 0 {
  374. r.T_name = T_name
  375. }
  376. if len(T_pass) >= 8 {
  377. r.T_pass = T_pass
  378. }
  379. if len(T_phone) > 0 {
  380. r.T_phone = T_phone
  381. }
  382. if len(T_mail) > 0 {
  383. r.T_mail = T_mail
  384. }
  385. is := Account.Update_Admin(r, "T_power", "T_pid", "T_name", "T_pass", "T_phone", "T_mail")
  386. if !is {
  387. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  388. c.ServeJSON()
  389. return
  390. }
  391. if len(T_name) > 0 {
  392. if is = Company.Update_CompanyNotice_Bind_By_T_uuid(T_uuid, T_name); !is {
  393. logs.Println("修改用户 => 修改用户关联报警通知失败", T_uuid, T_name)
  394. }
  395. }
  396. r.T_pass = "******"
  397. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "编辑", r)
  398. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  399. c.ServeJSON()
  400. return
  401. }
  402. func (c *UserController) User_Del() {
  403. T_uuid := c.GetString("T_uuid")
  404. if len(T_uuid) <= 0 {
  405. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  406. c.ServeJSON()
  407. return
  408. }
  409. admin_r_lod, err := Account.Read_Admin_ByUuid(T_uuid)
  410. if err != nil {
  411. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  412. c.ServeJSON()
  413. return
  414. }
  415. if is := Account.Delete_Admin(admin_r_lod); !is {
  416. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  417. c.ServeJSON()
  418. return
  419. }
  420. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid(T_uuid); !is {
  421. logs.Println("删除用户 => 删除用户关联报警通知失败", T_uuid)
  422. }
  423. System.Add_UserLogs_T(c.Admin_r.T_uuid, "用户管理", "删除", T_uuid)
  424. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  425. c.ServeJSON()
  426. return
  427. }
  428. // 管理员
  429. func (c *UserController) User_Home() {
  430. // 验证登录
  431. admin_r := c.Admin_r
  432. type Info struct {
  433. T_name string // 姓名
  434. T_pid int // 公司id
  435. T_Days int // 服务天输
  436. Admin []Account.Admin_ // 专属管理员
  437. WarningNum int64 // 报警数量
  438. UntreatedWarningNum int64 // 未处理报警数量
  439. WorkOrderNum int64 // 工单数量
  440. UntreatedWorkOrderNum int64 // 未处理工单数量
  441. }
  442. var info Info
  443. info.T_name = admin_r.T_name
  444. info.T_pid = admin_r.T_pid
  445. if admin_r.T_pid > 0 {
  446. power, _ := Account.Read_Power_ById(admin_r.T_power)
  447. company, _ := Account.Read_Company_ById(admin_r.T_pid)
  448. info.T_Days = lib.GetDiffDays(time.Now(), company.CreateTime)
  449. AdminList := Account.Read_Admin_List_T_pids(admin_r.T_pid)
  450. var Admin_ []Account.Admin_
  451. for _, v := range AdminList {
  452. Admin_ = append(Admin_, Account.Admin_RToAdmin_(v))
  453. }
  454. info.Admin = Admin_
  455. info.WarningNum = Warning.Read_Warning_ALL_T_State_Count(admin_r.T_pid, 1, power.T_warning, true)
  456. info.UntreatedWarningNum = Warning.Read_Warning_ALL_T_State_Count(admin_r.T_pid, 3, power.T_warning, false)
  457. }
  458. if admin_r.T_pid == 0 {
  459. info.WorkOrderNum, info.UntreatedWorkOrderNum = NatsServer.Read_WorkOrderT_State_Count(admin_r.T_pids)
  460. }
  461. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: info}
  462. c.ServeJSON()
  463. return
  464. }
  465. // 内部用户管理
  466. func (c *UserController) Admin_List() {
  467. var r_jsons lib.R_JSONS
  468. page, _ := c.GetInt("page")
  469. if page < 1 {
  470. page = 1
  471. }
  472. page_z, _ := c.GetInt("page_z")
  473. if page_z < 1 {
  474. page_z = conf.Page_size
  475. }
  476. T_name := c.GetString("T_name")
  477. Account.Read_Power_All_Map()
  478. r_jsons.Data, r_jsons.Num = Account.Read_Admin_List(0, T_name, page, page_z)
  479. r_jsons.Page = page
  480. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  481. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  482. c.ServeJSON()
  483. return
  484. }
  485. func (c *UserController) Admin_Get() {
  486. T_uuid := c.GetString("T_uuid")
  487. if len(T_uuid) < 8 {
  488. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  489. c.ServeJSON()
  490. return
  491. }
  492. admin_r, err := Account.Read_Admin_ByUuid(T_uuid)
  493. if err != nil {
  494. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  495. c.ServeJSON()
  496. return
  497. }
  498. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Account.AdminToAdmin_R(admin_r)}
  499. c.ServeJSON()
  500. return
  501. }
  502. func (c *UserController) Admin_Add() {
  503. T_power, _ := c.GetInt("T_power")
  504. T_name := c.GetString("T_name")
  505. T_user := c.GetString("T_user")
  506. T_pass := c.GetString("T_pass")
  507. T_phone := c.GetString("T_phone")
  508. T_mail := c.GetString("T_mail")
  509. T_wx := c.GetString("T_wx")
  510. var_ := Account.Admin{
  511. T_uuid: uuid.NewV4().String(),
  512. T_pid: 0,
  513. T_name: T_name,
  514. T_user: T_user,
  515. T_phone: T_phone,
  516. T_mail: T_mail,
  517. T_wx: T_wx,
  518. T_pass: T_pass,
  519. T_power: T_power,
  520. T_State: 1,
  521. }
  522. if len(T_pass) < 8 {
  523. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  524. c.ServeJSON()
  525. return
  526. }
  527. _, err := Account.Read_Admin_T_user(T_user)
  528. if err == nil {
  529. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  530. c.ServeJSON()
  531. return
  532. }
  533. _, err = Account.Add_Admin(var_)
  534. if err != nil {
  535. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  536. c.ServeJSON()
  537. return
  538. }
  539. var_.T_pass = "******"
  540. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "添加", var_)
  541. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  542. c.ServeJSON()
  543. return
  544. }
  545. func (c *UserController) Admin_Edit() {
  546. T_uuid := c.GetString("T_uuid")
  547. if len(T_uuid) < 8 {
  548. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  549. c.ServeJSON()
  550. return
  551. }
  552. r, err := Account.Read_Admin_ByUuid(T_uuid)
  553. if err != nil {
  554. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  555. c.ServeJSON()
  556. return
  557. }
  558. T_power, T_power_err := c.GetInt("T_power")
  559. T_name := c.GetString("T_name")
  560. T_pass := c.GetString("T_pass")
  561. T_phone := c.GetString("T_phone")
  562. T_mail := c.GetString("T_mail")
  563. T_wx := c.GetString("T_wx")
  564. if T_power_err == nil {
  565. r.T_power = T_power
  566. }
  567. if len(T_pass) < 8 && len(T_pass) > 0 {
  568. c.Data["json"] = lib.JSONS{Code: 202, Msg: "密码异常!"}
  569. c.ServeJSON()
  570. return
  571. }
  572. if len(T_name) > 0 {
  573. r.T_name = T_name
  574. }
  575. if len(T_pass) >= 8 {
  576. r.T_pass = T_pass
  577. }
  578. if len(T_phone) > 0 {
  579. r.T_phone = T_phone
  580. }
  581. if len(T_mail) > 0 {
  582. r.T_mail = T_mail
  583. }
  584. if len(T_wx) > 0 {
  585. r.T_wx = T_wx
  586. }
  587. is := Account.Update_Admin(r, "T_power", "T_name", "T_pass", "T_phone", "T_mail", "T_wx")
  588. if !is {
  589. c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
  590. c.ServeJSON()
  591. return
  592. }
  593. if len(T_name) > 0 {
  594. if is = Company.Update_CompanyNotice_Bind_By_T_uuid(T_uuid, "内管-"+T_name); !is {
  595. logs.Println("修改内部用户 => 修改内部用户关联报警通知失败", T_uuid, T_name)
  596. }
  597. }
  598. r.T_pass = "********"
  599. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "修改", r)
  600. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  601. c.ServeJSON()
  602. return
  603. }
  604. func (c *UserController) Admin_Del() {
  605. T_uuid := c.GetString("T_uuid")
  606. if len(T_uuid) <= 0 {
  607. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  608. c.ServeJSON()
  609. return
  610. }
  611. admin_r_lod, err := Account.Read_Admin_ByUuid(T_uuid)
  612. if err != nil {
  613. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  614. c.ServeJSON()
  615. return
  616. }
  617. if admin_r_lod.Id == 1 {
  618. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权删除!"}
  619. c.ServeJSON()
  620. return
  621. }
  622. if is := Account.Delete_Admin(admin_r_lod); !is {
  623. c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
  624. c.ServeJSON()
  625. return
  626. }
  627. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid(T_uuid); !is {
  628. logs.Println("删除内部用户 => 删除内部用户关联报警通知失败", T_uuid)
  629. }
  630. System.Add_UserLogs_T(c.Admin_r.T_uuid, "内部用户管理", "删除", T_uuid)
  631. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  632. c.ServeJSON()
  633. return
  634. }
  635. // 报警通知的用户列表
  636. func (c *UserController) User_Notice_List() {
  637. type R_JSONS struct {
  638. //必须的大写开头
  639. AdminList []Account.Admin_R
  640. UserList []Account.Admin_R
  641. }
  642. var r_jsons R_JSONS
  643. // 绑定公司id的内部用户列表
  644. r_jsons.AdminList = Account.Read_Admin_List_T_pids(c.T_pid)
  645. // 绑定公司id的公司用户列表
  646. r_jsons.UserList = Account.Read_Admin_List_T_pid(c.T_pid)
  647. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  648. c.ServeJSON()
  649. return
  650. }
  651. // 管理员绑定公司
  652. func (c *UserController) AdminCompanyBind_List() {
  653. var r_jsons lib.R_JSONS
  654. T_uuid := c.GetString("T_uuid")
  655. if len(T_uuid) < 8 {
  656. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  657. c.ServeJSON()
  658. return
  659. }
  660. r, err := Account.Read_Admin_ByUuid(T_uuid)
  661. if err != nil {
  662. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  663. c.ServeJSON()
  664. return
  665. }
  666. r_jsons.Data = Account.Read_Company_List_ByT_pids(r.T_pids)
  667. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  668. c.ServeJSON()
  669. return
  670. }
  671. func (c *UserController) AdminCompanyBind_Add() {
  672. T_uuid := c.GetString("T_uuid")
  673. if len(T_uuid) < 8 {
  674. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  675. c.ServeJSON()
  676. return
  677. }
  678. T_pid, _ := c.GetInt("T_pid")
  679. if T_pid == 0 {
  680. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  681. c.ServeJSON()
  682. return
  683. }
  684. r, err := Account.Read_Admin_ByUuid(T_uuid)
  685. if err != nil {
  686. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  687. c.ServeJSON()
  688. return
  689. }
  690. if r.T_pids == "*" {
  691. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  692. c.ServeJSON()
  693. return
  694. }
  695. Company_r, err := Account.Read_Company_ById(T_pid)
  696. if err != nil {
  697. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  698. c.ServeJSON()
  699. return
  700. }
  701. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  702. if err = Account.Add_Company_bind(r, T_pids); err != nil {
  703. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  704. c.ServeJSON()
  705. return
  706. }
  707. System.Add_UserLogs(c.Admin_r.T_uuid, "内部用户管理", "公司绑定添加", T_uuid+"-"+strconv.Itoa(T_pid))
  708. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  709. c.ServeJSON()
  710. return
  711. }
  712. func (c *UserController) AdminCompanyBind_Del() {
  713. T_uuid := c.GetString("T_uuid")
  714. if len(T_uuid) < 8 {
  715. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_uuid Err!"}
  716. c.ServeJSON()
  717. return
  718. }
  719. T_pid, _ := c.GetInt("T_pid")
  720. if T_pid == 0 {
  721. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  722. c.ServeJSON()
  723. return
  724. }
  725. r, err := Account.Read_Admin_ByUuid(T_uuid)
  726. Company_r, err := Account.Read_Company_ById(T_pid)
  727. if err != nil {
  728. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_pid Err!"}
  729. c.ServeJSON()
  730. return
  731. }
  732. T_pids := Account.ReadCompanyIds_T_path(Company_r.T_path)
  733. if err = Account.Delete_Company_bind(r, T_pids); err != nil {
  734. c.Data["json"] = lib.JSONS{Code: 202, Msg: "公司绑定失败"}
  735. c.ServeJSON()
  736. return
  737. }
  738. if is := Company.Delete_CompanyNotice_Bind_By_T_uuid_T_pid(T_uuid, T_pids); !is {
  739. logs.Println("删除内部用户公司绑定 => 删除内部用户绑定的公司关联报警通知失败", T_uuid)
  740. }
  741. System.Add_UserLogs(c.Admin_r.T_uuid, "内部用户管理", "公司绑定删除", T_uuid+"-"+strconv.Itoa(T_pid))
  742. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  743. c.ServeJSON()
  744. return
  745. }
  746. // 权限管理
  747. func (c *UserController) Power_List() {
  748. var r_jsons lib.R_JSONS
  749. page, _ := c.GetInt("page")
  750. if page < 1 {
  751. page = 1
  752. }
  753. page_z, _ := c.GetInt("page_z")
  754. if page_z < 1 {
  755. page_z = conf.Page_size
  756. }
  757. Name := c.GetString("T_name")
  758. r_jsons.Data, r_jsons.Num = Account.Read_Power_List(Name, page, page_z)
  759. r_jsons.Page = page
  760. r_jsons.Page_size = int(math.Ceil(float64(r_jsons.Num) / float64(page_z)))
  761. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  762. c.ServeJSON()
  763. return
  764. }
  765. // 添加用户 权限选择列表
  766. func (c *UserController) Power_List_All() {
  767. r, err := Account.Read_Power_ById(c.Admin_r.T_power)
  768. if err != nil {
  769. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  770. c.ServeJSON()
  771. return
  772. }
  773. var r_jsons lib.R_JSONS
  774. r_jsons.Data = Account.Read_Power_List_ALL_User(r.T_select)
  775. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  776. c.ServeJSON()
  777. return
  778. }
  779. func (c *UserController) Power_Get() {
  780. type Data struct {
  781. Power Account.Power_
  782. Menu []Account.Menu
  783. Menu_checked []int
  784. Select []Account.Power_R
  785. Warning []Warning.WarningType_R
  786. }
  787. var data Data
  788. id, id_err := c.GetInt("T_id")
  789. if id_err != nil || id == 0 {
  790. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  791. c.ServeJSON()
  792. return
  793. }
  794. power, err := Account.Read_Power_ById(id)
  795. if err != nil {
  796. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_id Err!"}
  797. c.ServeJSON()
  798. return
  799. }
  800. data.Power = Account.PowerToPower_(power)
  801. data.Menu, data.Menu_checked = Account.Read_Menu_List_All()
  802. if err != nil {
  803. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_menu Err!"}
  804. c.ServeJSON()
  805. return
  806. }
  807. if power.T_menu != "*" {
  808. data.Menu_checked = lib.SplitStringToIntIds(power.T_menu, "M")
  809. }
  810. if err != nil {
  811. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_menu Err!"}
  812. c.ServeJSON()
  813. return
  814. }
  815. data.Select = Account.Read_Power_List_ALL_T_select(power.T_select)
  816. if err != nil {
  817. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_select Err!"}
  818. c.ServeJSON()
  819. return
  820. }
  821. data.Warning = Warning.Read_WarningType_All_Power_T_Warning(power.T_warning)
  822. if err != nil {
  823. c.Data["json"] = lib.JSONS{Code: 202, Msg: "T_warning Err!"}
  824. c.ServeJSON()
  825. return
  826. }
  827. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: data}
  828. c.ServeJSON()
  829. return
  830. }
  831. func (c *UserController) Power_Add() {
  832. T_name := c.GetString("T_name")
  833. T_select := c.GetString("T_select")
  834. T_warning := c.GetString("T_warning")
  835. T_menu := c.GetString("T_menu")
  836. var_ := Account.Power{
  837. T_name: T_name,
  838. T_select: T_select,
  839. T_warning: T_warning,
  840. T_menu: T_menu,
  841. T_State: 1,
  842. }
  843. _, err := Account.Add_Power(var_)
  844. if err != nil {
  845. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  846. c.ServeJSON()
  847. return
  848. }
  849. System.Add_UserLogs_T(c.Admin_r.T_uuid, "权限管理", "添加", var_)
  850. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  851. c.ServeJSON()
  852. return
  853. }
  854. func (c *UserController) Power_Edit() {
  855. Id, Id_err := c.GetInt("T_id")
  856. if Id_err != nil || Id == 0 {
  857. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  858. c.ServeJSON()
  859. return
  860. }
  861. if Id == 1 {
  862. c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权修改!"}
  863. c.ServeJSON()
  864. return
  865. }
  866. r, err := Account.Read_Power_ById(Id)
  867. if err != nil {
  868. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  869. c.ServeJSON()
  870. return
  871. }
  872. T_name := c.GetString("T_name")
  873. T_select := c.GetString("T_select")
  874. T_warning := c.GetString("T_warning")
  875. T_menu := c.GetString("T_menu")
  876. if len(T_name) > 0 {
  877. r.T_name = T_name
  878. }
  879. if len(T_select) > 0 {
  880. r.T_select = T_select
  881. }
  882. if len(T_warning) > 0 {
  883. r.T_warning = T_warning
  884. }
  885. if len(T_menu) > 0 {
  886. r.T_menu = T_menu
  887. }
  888. is := Account.Update_Power(r, "T_name", "T_select", "T_warning", "T_menu")
  889. if !is {
  890. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  891. c.ServeJSON()
  892. return
  893. }
  894. System.Add_UserLogs_T(c.Admin_r.T_uuid, "权限管理", "修改", r)
  895. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  896. c.ServeJSON()
  897. return
  898. }
  899. func (c *UserController) Power_Del() {
  900. id, id_err := c.GetInt("T_id")
  901. if id_err != nil || id == 0 {
  902. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  903. c.ServeJSON()
  904. return
  905. }
  906. r, err := Account.Read_Power_ById(id)
  907. if err != nil {
  908. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id Err!"}
  909. c.ServeJSON()
  910. return
  911. }
  912. if cnt := Account.Read_Admin_Num_ByT_power(id); cnt > 0 {
  913. c.Data["json"] = lib.JSONS{Code: 202, Msg: "有关联用户,禁止删除!"}
  914. c.ServeJSON()
  915. return
  916. }
  917. is := Account.Delete_Power(r)
  918. if !is {
  919. c.Data["json"] = lib.JSONS{Code: 302, Msg: "删除失败!"}
  920. c.ServeJSON()
  921. return
  922. }
  923. System.Add_UserLogs(c.Admin_r.T_uuid, "权限管理", "删除", strconv.Itoa(id))
  924. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  925. c.ServeJSON()
  926. return
  927. }
  928. // 菜单列表
  929. func (c *UserController) User_Menu_List() {
  930. type R_JSONS struct {
  931. //必须的大写开头
  932. Data interface{}
  933. Permission interface{}
  934. }
  935. var r_jsons R_JSONS
  936. power, err := Account.Read_Power_ById(c.Admin_r.T_power)
  937. if err != nil {
  938. c.Data["json"] = lib.JSONS{Code: 202, Msg: "获取菜单失败"}
  939. c.ServeJSON()
  940. return
  941. }
  942. logs.Println("登录用户 菜单 pid 为:", c.T_pid)
  943. ret := Account.Read_Menu_Bind_List(power.Id, power.T_menu, c.T_pid)
  944. r_jsons.Data = ret.Menu
  945. r_jsons.Permission = ret.Permission
  946. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  947. c.ServeJSON()
  948. return
  949. }
  950. // 权限菜单列表
  951. func (c *UserController) Menu_List_All() {
  952. var r_jsons lib.R_JSONS
  953. r_jsons.Data, _ = Account.Read_Menu_List_All()
  954. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  955. c.ServeJSON()
  956. return
  957. }
  958. // 流量池
  959. func (c *UserController) Flow_Pool() {
  960. var r_jsons lib.R_JSONS
  961. r_jsons.Data, _ = lib.Yidong_group_data_margin()
  962. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
  963. c.ServeJSON()
  964. return
  965. }