123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340 |
- package controllers
- import (
- "ColdVerify_server/conf"
- "ColdVerify_server/lib"
- "ColdVerify_server/models/Account"
- "ColdVerify_server/models/System"
- beego "github.com/beego/beego/v2/server/web"
- uuid "github.com/satori/go.uuid"
- "math"
- "time"
- )
- type AccountController struct {
- beego.Controller
- }
- func (c *AccountController) Login_html() {
- c.TplName = "login.html"
- }
- // 验证登录
- func (c *AccountController) Login_verification() {
- Admin_user := c.GetString("bzd_username")
- Admin_pass := c.GetString("bzd_password")
- println("Login_verification", Admin_user, Admin_pass)
- err, user_r := Account.Read_User_verification(Admin_user, Admin_pass)
- if err != nil {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "登录失败-请检查账号密码"}
- } else {
- User_tokey := Account.Add_Tokey(user_r.T_uuid)
- c.Ctx.SetCookie("User_tokey", User_tokey, time.Second*60*60)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK!", Data: User_tokey}
- System.Add_UserLogs(user_r.T_uuid, "登陆", "用户登陆", "")
- }
- c.ServeJSON()
- return
- }
- // 验证登录
- func (c *AccountController) Login_Admin_verification() {
- Admin_user := c.GetString("bzd_username")
- Admin_pass := c.GetString("bzd_password")
- println("Login_Admin_verification", Admin_user, Admin_pass)
- err, user_r := Account.Read_Admin_verification(Admin_user, Admin_pass)
- if err != nil {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "登录失败-请检查账号密码"}
- } else {
- User_tokey := Account.Add_Tokey(user_r.T_uuid)
- c.Ctx.SetCookie("User_tokey", User_tokey, time.Second*60*60)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "OK!", Data: User_tokey}
- System.Add_UserLogs(user_r.T_uuid, "登陆", "管理员登陆", "")
- }
- c.ServeJSON()
- return
- }
- // --------------------------------------------------------------------------------------------------------------
- // 管理员-列表-
- func (c *AccountController) List() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- var r_jsons lib.R_JSONS
- page, _ := c.GetInt("page")
- if page < 1 {
- page = 1
- }
- page_z, _ := c.GetInt("page_z")
- if page_z < 1 {
- page_z = conf.Page_size
- }
- T_name := c.GetString("T_name")
- var cnt int
- PowerList := Account.Read_Power_List_ALL_1()
- PowerMap := Account.UserPowerListToPowerMap(PowerList)
- List, cnt := Account.Read_Admin_List(T_name, page, page_z, PowerMap)
- page_size := math.Ceil(float64(cnt) / float64(page_z))
- r_jsons.List = List
- r_jsons.Page = page
- r_jsons.Page_size = int(page_size)
- r_jsons.Pages = lib.Func_page(int64(page), int64(page_size))
- r_jsons.Num = cnt
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
- c.ServeJSON()
- return
- }
- // 管理员-添加-
- func (c *AccountController) Add() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- T_uuid := uuid.NewV4().String()
- T_power, _ := c.GetInt("T_power")
- T_name := c.GetString("T_name")
- T_user := c.GetString("T_user")
- T_pass := c.GetString("T_pass")
- var_ := Account.Admin{
- T_uuid: T_uuid,
- T_power: T_power,
- T_name: T_name,
- T_user: T_user,
- T_pass: T_pass,
- T_State: 1,
- }
- if err, _ := Account.Read_Admin_ByT_user(T_user); err == nil {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "用户名已存在!"}
- c.ServeJSON()
- return
- }
- Id, err := Account.Add_Admin(var_)
- if err != nil {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "添加失败!"}
- c.ServeJSON()
- return
- }
- System.Add_UserLogs_T(User_r.T_uuid, "管理员用户", "添加", var_)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: Id}
- c.ServeJSON()
- return
- }
- // 管理员-修改-
- func (c *AccountController) Up() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- T_uuid := c.GetString("T_uuid")
- T_power, _ := c.GetInt("T_power")
- T_name := c.GetString("T_name")
- T_user := c.GetString("T_user")
- T_pass := c.GetString("T_pass")
- err, r := Account.Read_Admin_ByT_uuid(T_uuid)
- if err != nil {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id 错误!"}
- c.ServeJSON()
- return
- }
- err, r2 := Account.Read_Admin_ByT_user(T_user)
- if err == nil && T_uuid != r2.T_uuid {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "用户名已存在!"}
- c.ServeJSON()
- return
- }
- if T_power > 0 {
- r.T_power = T_power
- }
- if len(T_name) > 0 {
- r.T_name = T_name
- }
- if len(T_user) > 0 {
- r.T_user = T_user
- }
- if len(T_pass) > 0 {
- r.T_pass = T_pass
- }
- if !Account.Update_Admin(r, "T_power", "T_name", "T_user", "T_pass") {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
- c.ServeJSON()
- return
- }
- System.Add_UserLogs_T(User_r.T_uuid, "管理员用户", "修改", r)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
- c.ServeJSON()
- return
- }
- // 管理员-删除-
- func (c *AccountController) Del() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- T_uuid := c.GetString("T_uuid")
- if User_r.T_uuid == T_uuid {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "禁止删除自己!"}
- c.ServeJSON()
- return
- }
- if err, r := Account.Read_Admin_ByT_uuid(T_uuid); err == nil {
- if !Account.Delete_Admin_(r) {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "删除失败!"}
- c.ServeJSON()
- return
- }
- System.Add_UserLogs_T(User_r.T_uuid, "管理员用户", "删除", r)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
- c.ServeJSON()
- return
- }
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "Id 错误!"}
- c.ServeJSON()
- return
- }
- // 用户权限-所有列表-
- func (c *AccountController) UserPower_List_All() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- var r_jsons lib.R_JSONS
- r_jsons.List = Account.Read_Power_List_ALL_Admin_Power(User_r.T_power)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
- c.ServeJSON()
- return
- }
- // 管理员-全部列表-
- func (c *AccountController) List_All() {
- // 验证登录 User_is, User_r
- User_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- if User_r.T_power > 2 {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "无权操作!"}
- c.ServeJSON()
- return
- }
- PowerList := Account.Read_Power_List_ALL_1()
- PowerMap := Account.UserPowerListToPowerMap(PowerList)
- var r_jsons lib.R_JSONS
- r_jsons.List = Account.Read_Admin_List_ALL_Power(PowerMap)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!", Data: r_jsons}
- c.ServeJSON()
- return
- }
- // 修改密码
- func (c *AccountController) UpPassword() {
- // 验证登录 User_is, User_r
- user_r, User_is := Account.Verification_Admin(c.Ctx.GetCookie("User_tokey"), c.GetString("User_tokey"))
- if !User_is {
- c.Data["json"] = lib.JSONS{Code: 201, Msg: "请重新登录!"}
- c.ServeJSON()
- return
- }
- T_oldpass := c.GetString("T_oldpass")
- T_pass := c.GetString("T_pass")
- if T_oldpass != user_r.T_pass {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "旧密码错误!"}
- c.ServeJSON()
- return
- }
- if len(T_pass) > 0 {
- user_r.T_pass = T_pass
- }
- if !Account.Update_Admin(user_r, "T_pass") {
- c.Data["json"] = lib.JSONS{Code: 202, Msg: "修改失败!"}
- c.ServeJSON()
- return
- }
- user_r.T_pass = "********"
- System.Add_UserLogs_T(user_r.T_uuid, "管理员管理", "修改密码", user_r)
- c.Data["json"] = lib.JSONS{Code: 200, Msg: "ok!"}
- c.ServeJSON()
- return
- }
|