User.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737
  1. package controllers
  2. import (
  3. "Cold_Api/conf"
  4. "Cold_Api/controllers/lib"
  5. "Cold_Api/models/Admin"
  6. "Cold_Api/models/System"
  7. "crypto/md5"
  8. "encoding/hex"
  9. "fmt"
  10. beego "github.com/beego/beego/v2/server/web"
  11. uuid "github.com/satori/go.uuid"
  12. "math"
  13. "strconv"
  14. "time"
  15. )
  16. type UserController struct {
  17. beego.Controller
  18. }
  19. // 管理员
  20. func (c *UserController) Admin_html() {
  21. // 验证登录
  22. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  23. if !b_ {
  24. c.Ctx.Redirect(302, "Login")
  25. return
  26. }
  27. if admin_r.Id != 1 {
  28. c.Ctx.Redirect(302, "Login")
  29. return
  30. }
  31. fmt.Println("登录OK")
  32. page, _ := c.GetInt("page")
  33. println(page)
  34. if page < 1 {
  35. page = 1
  36. }
  37. c.Data["Admin_Power"], _ = Admin.Read_AdminPower_ById(admin_r.Admin_power)
  38. Name := c.GetString("Name")
  39. c.Data["Name"] = Name
  40. c.Data["Power_List"] = Admin.Read_Power_List_ALL_Power_Administration(1)
  41. var cnt int64
  42. c.Data["List"], cnt = Admin.Read_Admin_List_ALL_Admin_master(page, Name, 0)
  43. fmt.Println("cnt:", cnt)
  44. page_size := math.Ceil(float64(cnt) / float64(conf.Page_size))
  45. c.Data["Page"] = page
  46. c.Data["Page_size"] = page_size
  47. c.Data["Pages"] = lib.Func_page(int64(page), int64(page_size))
  48. c.Data["cnt"] = cnt
  49. c.TplName = "User/Admin.html"
  50. }
  51. // 检查 Tokey 是否过期
  52. func (c *UserController) InspectTokey() {
  53. // 验证登录
  54. b_ := lib.Verification_Tokey(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  55. if !b_ {
  56. c.Data["json"] = lib.JSONS{Code: 301, Msg: "请退出重新登录!"}
  57. c.ServeJSON()
  58. return
  59. }
  60. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  61. c.ServeJSON()
  62. return
  63. }
  64. func (c *UserController) Admin_() {
  65. // 验证登录
  66. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  67. if !b_ {
  68. c.Ctx.Redirect(302, "Login")
  69. return
  70. }
  71. if admin_r.Id != 1 {
  72. c.Ctx.Redirect(302, "Login")
  73. return
  74. }
  75. if admin_r.Admin_master != 0 {
  76. c.Ctx.Redirect(302, "Login")
  77. return
  78. }
  79. id, _ := c.GetInt("id")
  80. c.Data["id"] = id
  81. c.Data["Power_List"] = Admin.Read_Power_List_ALL_Power_Administration(1)
  82. Admin_uuid := c.GetString("Admin_uuid")
  83. c.Data["Admin_uuid"] = Admin_uuid
  84. if len(Admin_uuid) > 0 {
  85. c.Data["Date"], _ = Admin.Read_Admin_ByUuid(Admin_uuid)
  86. }
  87. c.TplName = "User/Admin-.html"
  88. }
  89. func (c *UserController) Admin_Post() {
  90. // 验证登录
  91. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  92. if !b_ {
  93. c.Ctx.Redirect(302, "Login")
  94. return
  95. }
  96. if admin_r.Id != 1 {
  97. c.Ctx.Redirect(302, "Login")
  98. return
  99. }
  100. if admin_r.Admin_master != 0 {
  101. c.Ctx.Redirect(302, "Login")
  102. return
  103. }
  104. Admin_uuid := c.GetString("Admin_uuid")
  105. Admin_name := c.GetString("Admin_name")
  106. Admin_user := c.GetString("Admin_user")
  107. Admin_telephone := c.GetString("Admin_telephone")
  108. Admin_mail := c.GetString("Admin_mail")
  109. Admin_text := c.GetString("Admin_text")
  110. Admin_gender, _ := c.GetInt("Admin_gender")
  111. Admin_power, _ := c.GetInt("Admin_power")
  112. var_ := Admin.Admin{
  113. Admin_uuid: uuid.NewV4().String(),
  114. Admin_name: Admin_name,
  115. Admin_master: admin_r.Admin_master,
  116. Admin_user: Admin_user,
  117. Admin_telephone: Admin_telephone,
  118. Admin_mail: Admin_mail,
  119. Admin_text: Admin_text,
  120. Admin_gender: Admin_gender,
  121. Admin_power: Admin_power,
  122. Admin_panel_plan: "",
  123. Admin_panel_data: "",
  124. T_State: 1,
  125. }
  126. if len(Admin_uuid) > 0 {
  127. var_.Admin_uuid = Admin_uuid
  128. err := Admin.Update_Admin_ById_Basics(var_)
  129. if err != nil {
  130. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  131. c.ServeJSON()
  132. return
  133. }
  134. } else {
  135. s_pass := uuid.NewV4().String()[:6]
  136. h := md5.New()
  137. h.Write([]byte(s_pass))
  138. s := hex.EncodeToString(h.Sum(nil))
  139. fmt.Println(s)
  140. var_.Admin_pass = s
  141. var_.Admin_master = 0
  142. err, _ := Admin.Read_Admin_Admin_user(Admin_user)
  143. if err == nil {
  144. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  145. c.ServeJSON()
  146. return
  147. }
  148. _, err = Admin.Add_Admin(var_)
  149. if err != nil {
  150. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  151. c.ServeJSON()
  152. return
  153. }
  154. var_.Admin_pass = "***********"
  155. System.Add_UserLogs_T(admin_r.Admin_uuid, "管理员", "管理员操作", var_)
  156. c.Data["json"] = lib.JSONS{Code: 210, Msg: "ok!", Data: s_pass}
  157. c.ServeJSON()
  158. return
  159. }
  160. var_.Admin_pass = "***********"
  161. System.Add_UserLogs_T(admin_r.Admin_uuid, "管理员", "管理员操作", var_)
  162. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  163. c.ServeJSON()
  164. return
  165. }
  166. func (c *UserController) Admin_Del() {
  167. // 验证登录
  168. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  169. if !b_ {
  170. c.Ctx.Redirect(302, "Login")
  171. return
  172. }
  173. if admin_r.Id != 1 {
  174. c.Ctx.Redirect(302, "Login")
  175. return
  176. }
  177. if admin_r.Admin_master != 0 {
  178. c.Ctx.Redirect(302, "Login")
  179. return
  180. }
  181. Admin_uuid := c.GetString("Admin_uuid")
  182. if len(Admin_uuid) > 0 {
  183. admin_r_lod, err := Admin.Read_Admin_ByUuid(Admin_uuid)
  184. if err != nil {
  185. c.Data["json"] = lib.JSONS{Code: 201, Msg: "e!"}
  186. c.ServeJSON()
  187. return
  188. }
  189. if admin_r_lod.Admin_master < admin_r.Admin_master {
  190. c.Data["json"] = lib.JSONS{Code: 202, Msg: "e!"}
  191. c.ServeJSON()
  192. return
  193. }
  194. admin_r_lod.T_State = 0
  195. Admin.Update_Admin(admin_r_lod, "T_State")
  196. //Admin.Update_Delete_Admin_ByAdmin_uuid(Admin_uuid)
  197. } else {
  198. c.Data["json"] = lib.JSONS{Code: 203, Msg: "e!"}
  199. c.ServeJSON()
  200. return
  201. }
  202. System.Add_UserLogs(admin_r.Admin_uuid, "管理员", "管理员删除", Admin_uuid)
  203. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  204. c.ServeJSON()
  205. return
  206. }
  207. func (c *UserController) User_Entry() {
  208. // 验证登录
  209. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  210. if !b_ {
  211. c.Ctx.Redirect(302, "Login")
  212. return
  213. }
  214. //if(admin_r.Admin_master != 0){
  215. // c.Ctx.Redirect(302, "Login")
  216. // return
  217. //}
  218. Admin_uuid := c.GetString("Admin_uuid")
  219. if len(Admin_uuid) > 0 {
  220. admin_r_a, err := Admin.Read_Admin_ByUuid(Admin_uuid)
  221. if err != nil {
  222. c.Data["json"] = lib.JSONS{Code: 201, Msg: "e!"}
  223. c.ServeJSON()
  224. return
  225. }
  226. if admin_r.Id != admin_r_a.Admin_master {
  227. c.Data["json"] = lib.JSONS{Code: 202, Msg: "e!"}
  228. c.ServeJSON()
  229. return
  230. }
  231. User_tokey := Admin.Add_Tokey_Set(admin_r_a.Admin_uuid)
  232. c.Ctx.SetCookie("User_tokey", User_tokey, time.Second*60*60)
  233. } else {
  234. c.Data["json"] = lib.JSONS{Code: 203, Msg: "e!"}
  235. c.ServeJSON()
  236. return
  237. }
  238. System.Add_UserLogs(admin_r.Admin_uuid, "用户管理", "无钥匙进入", Admin_uuid)
  239. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  240. c.ServeJSON()
  241. return
  242. }
  243. // 用户管理
  244. func (c *UserController) User_html() {
  245. // 验证登录
  246. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  247. if !b_ {
  248. c.Ctx.Redirect(302, "Login")
  249. return
  250. }
  251. page, _ := c.GetInt("page")
  252. println(page)
  253. if page < 1 {
  254. page = 1
  255. }
  256. Name := c.GetString("Name")
  257. c.Data["Name"] = Name
  258. c.Data["Power_List"] = Admin.Read_Power_List_ALL_Power_Administration(0)
  259. Adminpower, _ := Admin.Read_AdminPower_ById(admin_r.Admin_power)
  260. var cnt int64
  261. if Adminpower.Power_User_r != 1 {
  262. c.Ctx.Redirect(302, "Login")
  263. return
  264. }
  265. c.Data["List"], cnt = Admin.Read_Admin_List_ALL_User(page, Name, admin_r.Id)
  266. fmt.Println("cnt:", cnt)
  267. page_size := math.Ceil(float64(cnt) / float64(conf.Page_size))
  268. c.Data["Page"] = page
  269. c.Data["Page_size"] = page_size
  270. c.Data["Pages"] = lib.Func_page(int64(page), int64(page_size))
  271. c.Data["cnt"] = cnt
  272. c.TplName = "User/User.html"
  273. }
  274. func (c *UserController) User_() {
  275. // 验证登录
  276. b_, _ := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  277. if !b_ {
  278. c.Ctx.Redirect(302, "Login")
  279. return
  280. }
  281. id, _ := c.GetInt("id")
  282. c.Data["id"] = id
  283. c.Data["Power_List"] = Admin.Read_Power_List_ALL_Power_Administration(0)
  284. Admin_uuid := c.GetString("Admin_uuid")
  285. c.Data["Admin_uuid"] = Admin_uuid
  286. if len(Admin_uuid) > 0 {
  287. c.Data["Date"], _ = Admin.Read_Admin_ByUuid(Admin_uuid)
  288. }
  289. c.TplName = "User/User-.html"
  290. }
  291. func (c *UserController) User_Info() {
  292. // 验证登录
  293. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  294. if !b_ {
  295. c.Ctx.Redirect(302, "Login")
  296. return
  297. }
  298. c.Data["id"] = admin_r.Id
  299. c.Data["Date"] = admin_r
  300. c.TplName = "User/User-Info.html"
  301. }
  302. func (c *UserController) User_Info_() {
  303. // 验证登录
  304. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  305. if !b_ {
  306. c.Ctx.Redirect(302, "Login")
  307. return
  308. }
  309. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: admin_r}
  310. c.ServeJSON()
  311. return
  312. }
  313. func (c *UserController) User_Get() {
  314. // 验证登录
  315. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  316. if !b_ {
  317. c.Ctx.Redirect(302, "Login")
  318. return
  319. }
  320. type Admin_ struct {
  321. Admin_uuid string
  322. Admin_power int // 权限
  323. Admin_name string //
  324. Admin_telephone string // 电话
  325. Admin_mail string // 邮箱
  326. Admin_gender int // 性别 0未知 1男 2女
  327. Admin_text string // 详情
  328. Admin_rh int // 显示湿度
  329. }
  330. Admin_r := Admin_{}
  331. Admin_r.Admin_rh = admin_r.Admin_rh
  332. Admin_r.Admin_uuid = admin_r.Admin_uuid
  333. Admin_r.Admin_power = admin_r.Admin_power
  334. Admin_r.Admin_name = admin_r.Admin_name
  335. Admin_r.Admin_telephone = admin_r.Admin_telephone
  336. Admin_r.Admin_mail = admin_r.Admin_mail
  337. Admin_r.Admin_gender = admin_r.Admin_gender
  338. Admin_r.Admin_text = admin_r.Admin_text
  339. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Admin_r}
  340. c.ServeJSON()
  341. return
  342. }
  343. func (c *UserController) User_Post() {
  344. // 验证登录
  345. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  346. if !b_ {
  347. c.Ctx.Redirect(302, "Login")
  348. return
  349. }
  350. //Adminpower,_ := Admin.Read_AdminPower_ById(admin_r.Admin_power)
  351. //
  352. //if Adminpower.Power_User_r != 1 {
  353. // c.Data["json"] = lib.JSONS{Code: 307, Msg: "Adminpower.Power_User_r!"}
  354. // c.ServeJSON()
  355. // return
  356. //}
  357. Admin_uuid := c.GetString("Admin_uuid")
  358. Admin_name := c.GetString("Admin_name")
  359. Admin_user := c.GetString("Admin_user")
  360. Admin_pass := c.GetString("Admin_pass")
  361. Admin_telephone := c.GetString("Admin_telephone")
  362. Admin_mail := c.GetString("Admin_mail")
  363. Admin_text := c.GetString("Admin_text")
  364. Admin_gender, _ := c.GetInt("Admin_gender")
  365. Admin_power, _ := c.GetInt("Admin_power")
  366. var_ := Admin.Admin{
  367. Admin_uuid: uuid.NewV4().String(),
  368. Admin_name: Admin_name,
  369. Admin_master: admin_r.Id,
  370. Admin_user: Admin_user,
  371. Admin_telephone: Admin_telephone,
  372. Admin_mail: Admin_mail,
  373. Admin_text: Admin_text,
  374. Admin_pass: Admin_pass,
  375. Admin_gender: Admin_gender,
  376. Admin_power: Admin_power,
  377. T_State: 1,
  378. }
  379. if len(Admin_pass) > 0 && len(Admin_pass) < 7 {
  380. c.Data["json"] = lib.JSONS{Code: 302, Msg: "Admin_pass Err!"}
  381. c.ServeJSON()
  382. return
  383. }
  384. if len(Admin_uuid) > 0 {
  385. var_.Admin_uuid = Admin_uuid
  386. err, _ := Admin.ReadLogin_verification(var_.Admin_user, var_.Admin_pass)
  387. if err == nil {
  388. c.Data["json"] = lib.JSONS{Code: 307, Msg: "ReadLogin_verification !"}
  389. c.ServeJSON()
  390. return
  391. }
  392. err, r_u := Admin.Read_Admin_ByAdmin_uuid(Admin_uuid)
  393. if err != nil {
  394. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  395. c.ServeJSON()
  396. return
  397. }
  398. // 修改密码只有本人
  399. if len(Admin_pass) > 0 && r_u.Id != admin_r.Id {
  400. c.Data["json"] = lib.JSONS{Code: 302, Msg: "r_u != admin_r!"}
  401. c.ServeJSON()
  402. return
  403. }
  404. err = Admin.Update_Admin_ById_Basics(var_)
  405. if err != nil {
  406. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  407. c.ServeJSON()
  408. return
  409. }
  410. } else {
  411. s_pass := uuid.NewV4().String()[:6]
  412. h := md5.New()
  413. h.Write([]byte(s_pass))
  414. s := hex.EncodeToString(h.Sum(nil))
  415. fmt.Println(s)
  416. var_.Admin_pass = s
  417. // 是否 内部人员
  418. //Adminpower,_ := Admin.Read_AdminPower_ById(admin_r.Admin_power)
  419. //if Adminpower.Power_Administration == 1 {
  420. // var_.Admin_master = 1
  421. //}
  422. err, _ := Admin.Read_Admin_Admin_user(Admin_user)
  423. if err == nil {
  424. c.Data["json"] = lib.JSONS{Code: 302, Msg: "账户重复!"}
  425. c.ServeJSON()
  426. return
  427. }
  428. _, err = Admin.Add_Admin(var_)
  429. if err != nil {
  430. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  431. c.ServeJSON()
  432. return
  433. }
  434. var_.Admin_pass = "****************"
  435. System.Add_UserLogs_T(admin_r.Admin_uuid, "用户管理", "操作", var_)
  436. c.Data["json"] = lib.JSONS{Code: 210, Msg: "ok!", Data: s_pass}
  437. c.ServeJSON()
  438. return
  439. }
  440. var_.Admin_pass = "****************"
  441. System.Add_UserLogs_T(admin_r.Admin_uuid, "用户管理", "操作", var_)
  442. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  443. c.ServeJSON()
  444. return
  445. }
  446. func (c *UserController) User_Del() {
  447. // 验证登录
  448. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  449. if !b_ {
  450. c.Ctx.Redirect(302, "Login")
  451. return
  452. }
  453. Admin_uuid := c.GetString("Admin_uuid")
  454. if len(Admin_uuid) > 0 {
  455. admin_r_lod, err := Admin.Read_Admin_ByUuid(Admin_uuid)
  456. if err != nil {
  457. c.Data["json"] = lib.JSONS{Code: 201, Msg: "e!"}
  458. c.ServeJSON()
  459. return
  460. }
  461. if admin_r_lod.Admin_master < admin_r.Admin_master {
  462. c.Data["json"] = lib.JSONS{Code: 202, Msg: "e!"}
  463. c.ServeJSON()
  464. return
  465. }
  466. admin_r_lod.T_State = 0
  467. Admin.Update_Admin(admin_r_lod, "T_State")
  468. //Admin.Update_Delete_Admin_ByAdmin_uuid(Admin_uuid)
  469. } else {
  470. c.Data["json"] = lib.JSONS{Code: 203, Msg: "e!"}
  471. c.ServeJSON()
  472. return
  473. }
  474. System.Add_UserLogs_T(admin_r.Admin_uuid, "用户管理", "删除", Admin_uuid)
  475. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  476. c.ServeJSON()
  477. return
  478. }
  479. // 权限管理
  480. func (c *UserController) Power_html() {
  481. // 验证登录
  482. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  483. if !b_ {
  484. c.Ctx.Redirect(302, "Login")
  485. return
  486. }
  487. if admin_r.Id != 1 {
  488. c.Ctx.Redirect(302, "Login")
  489. return
  490. }
  491. if admin_r.Admin_master != 0 {
  492. c.Ctx.Redirect(302, "Login")
  493. return
  494. }
  495. c.Data["Admin_Power"], _ = Admin.Read_AdminPower_ById(admin_r.Admin_power)
  496. fmt.Println("登录OK")
  497. page, _ := c.GetInt("page")
  498. println(page)
  499. if page < 1 {
  500. page = 1
  501. }
  502. Name := c.GetString("Name")
  503. c.Data["Name"] = Name
  504. var cnt int64
  505. c.Data["List"], cnt = Admin.Read_Power_List_ALL(page, Name)
  506. fmt.Println("cnt:", cnt)
  507. page_size := math.Ceil(float64(cnt) / float64(conf.Page_size))
  508. c.Data["Page"] = page
  509. c.Data["Page_size"] = page_size
  510. c.Data["Pages"] = lib.Func_page(int64(page), int64(page_size))
  511. c.Data["cnt"] = cnt
  512. c.TplName = "User/Power.html"
  513. }
  514. func (c *UserController) Power_() {
  515. // 验证登录
  516. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  517. if !b_ {
  518. c.Ctx.Redirect(302, "Login")
  519. return
  520. }
  521. if admin_r.Id != 1 {
  522. c.Ctx.Redirect(302, "Login")
  523. return
  524. }
  525. if admin_r.Admin_master != 0 {
  526. c.Ctx.Redirect(302, "Login")
  527. return
  528. }
  529. id, _ := c.GetInt("id")
  530. c.Data["id"] = id
  531. if id > 0 {
  532. c.Data["Date"], _ = Admin.Read_AdminPower_ById(id)
  533. }
  534. c.TplName = "User/Power-.html"
  535. }
  536. func (c *UserController) Power_Post() {
  537. var err error
  538. // 验证登录
  539. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  540. if !b_ {
  541. c.Ctx.Redirect(302, "Login")
  542. return
  543. }
  544. if admin_r.Id != 1 {
  545. c.Ctx.Redirect(302, "Login")
  546. return
  547. }
  548. if admin_r.Admin_master != 0 {
  549. c.Ctx.Redirect(302, "Login")
  550. return
  551. }
  552. id, _ := c.GetInt("id")
  553. c.Data["id"] = id
  554. Power_name := c.GetString("Power_name")
  555. Power_Administration, _ := c.GetInt("Power_Administration")
  556. Power_User_r, _ := c.GetInt("Power_User_r")
  557. Power_User_entry, _ := c.GetInt("Power_User_entry")
  558. Power_Device_r, _ := c.GetInt("Power_Device_r")
  559. Power_Device_a, _ := c.GetInt("Power_Device_a")
  560. Power_Device_Parameter_e, _ := c.GetInt("Power_Device_Parameter_e")
  561. Power_DeviceSensor_Parameter_e, _ := c.GetInt("Power_DeviceSensor_Parameter_e")
  562. Power_Device_Bind_e, _ := c.GetInt("Power_Device_Bind_e")
  563. Power_DeviceSensor_Compensate_e, _ := c.GetInt("Power_DeviceSensor_Compensate_e")
  564. Power_DeviceSensor_Class, _ := c.GetInt("Power_DeviceSensor_Class")
  565. Power_DataScreen_r, _ := c.GetInt("Power_DataScreen_r")
  566. Logs_Sys_r, _ := c.GetInt("Logs_Sys_r")
  567. Logs_User_r, _ := c.GetInt("Logs_User_r")
  568. var_ := Admin.AdminPower{
  569. Power_name: Power_name,
  570. Power_Administration: Power_Administration,
  571. Power_User_r: Power_User_r,
  572. Power_User_entry: Power_User_entry,
  573. Power_Device_r: Power_Device_r,
  574. Power_Device_a: Power_Device_a,
  575. Power_Device_Parameter_e: Power_Device_Parameter_e,
  576. Power_DeviceSensor_Parameter_e: Power_DeviceSensor_Parameter_e,
  577. Power_Device_Bind_e: Power_Device_Bind_e,
  578. Power_DeviceSensor_Class: Power_DeviceSensor_Class,
  579. Power_DeviceSensor_Compensate_e: Power_DeviceSensor_Compensate_e,
  580. Power_DataScreen_r: Power_DataScreen_r,
  581. Logs_Sys_r: Logs_Sys_r,
  582. Logs_User_r: Logs_User_r,
  583. T_State: 1,
  584. }
  585. if id > 0 {
  586. var_.Id = id
  587. fmt.Println("Power_DataScreen_r:", var_.Power_DataScreen_r)
  588. err = Admin.Update_AdminPower_ById_Basics(var_)
  589. if err != nil {
  590. c.Data["json"] = lib.JSONS{Code: 302, Msg: "修改失败!"}
  591. c.ServeJSON()
  592. return
  593. }
  594. } else {
  595. _, err = Admin.Add_AdminPower(var_)
  596. if err != nil {
  597. c.Data["json"] = lib.JSONS{Code: 301, Msg: "添加失败!"}
  598. c.ServeJSON()
  599. return
  600. }
  601. }
  602. System.Add_UserLogs_T(admin_r.Admin_uuid, "权限管理", "权限操作", var_)
  603. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  604. c.ServeJSON()
  605. return
  606. }
  607. func (c *UserController) Power_Del() {
  608. // 验证登录
  609. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  610. if !b_ {
  611. c.Ctx.Redirect(302, "Login")
  612. return
  613. }
  614. if admin_r.Id != 1 {
  615. c.Ctx.Redirect(302, "Login")
  616. return
  617. }
  618. if admin_r.Admin_master != 0 {
  619. c.Data["json"] = lib.JSONS{Code: 203, Msg: "没有权限!"}
  620. c.ServeJSON()
  621. return
  622. }
  623. id, _ := c.GetInt("Id")
  624. c.Data["id"] = id
  625. if id > 0 {
  626. admin_r_lod, err := Admin.Read_AdminPower_ById(id)
  627. if err != nil {
  628. c.Data["json"] = lib.JSONS{Code: 201, Msg: "e!"}
  629. c.ServeJSON()
  630. return
  631. }
  632. Admin_List_ALL_AdminPower := Admin.Read_Admin_List_ALL_AdminPower(admin_r_lod.Id)
  633. if len(Admin_List_ALL_AdminPower) > 0 {
  634. S_Msg := "无法删除!【"
  635. for _, v := range Admin_List_ALL_AdminPower {
  636. S_Msg += v.Admin_name + ","
  637. }
  638. c.Data["json"] = lib.JSONS{Code: 205, Msg: S_Msg + "】 属于该权限!删除这些账号后即可删除! "}
  639. c.ServeJSON()
  640. return
  641. }
  642. Admin.Update_Delete_AdminPower_Byid(admin_r_lod.Id)
  643. } else {
  644. c.Data["json"] = lib.JSONS{Code: 204, Msg: "e!"}
  645. c.ServeJSON()
  646. return
  647. }
  648. System.Add_UserLogs(admin_r.Admin_uuid, "权限管理", "权限删除", strconv.Itoa(id))
  649. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  650. c.ServeJSON()
  651. return
  652. }
  653. // 同步面板
  654. func (c *UserController) Panel_plan_Syn() {
  655. // 验证登录
  656. b_, admin_r := lib.Verification(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
  657. if !b_ {
  658. c.Data["json"] = lib.JSONS{Code: 201, Msg: "User_tokey Err!"}
  659. c.ServeJSON()
  660. return
  661. }
  662. s_, user_r := Admin.Read_Admin_ByAdmin_uuid(c.GetString("Admin_uuid"))
  663. if s_ != nil {
  664. c.Data["json"] = lib.JSONS{Code: 202, Msg: "Admin_uuid Err!"}
  665. c.ServeJSON()
  666. return
  667. }
  668. user_r.Admin_panel_plan = admin_r.Admin_panel_plan
  669. Admin.Update_Admin(user_r, "Admin_panel_plan")
  670. System.Add_UserLogs(admin_r.Admin_uuid, "设备管理", "同步面板操作", "面板:"+admin_r.Admin_panel_plan+"|"+admin_r.Admin_uuid+"->"+user_r.Admin_uuid)
  671. c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
  672. c.ServeJSON()
  673. return
  674. }