KunWeb/web/admin/rigger/role_u.go
2025-05-16 01:00:48 +08:00

121 lines
2.8 KiB
Go

package rigger
import (
"fmt"
"net/http"
"strings"
"ciyon/web/admin"
. "ciyon/zciyon"
)
func Role_u_init(w http.ResponseWriter, r *http.Request) bool {
post := NewCiyPost(w, r)
_, userid := admin.Verifyfast(CiyDB, post)
if userid == 0 {
return false
}
id := post.Getint("id")
var err error
ret := map[string]any{}
csql := NewCiySQL("zc_role")
csql.Where("id", id)
ret["data"], err = CiyDB.Getone(csql)
if err != nil {
return ErrJSON(w, "读取role失败:"+err.Error())
}
csql = NewCiySQL("zc_menu")
csql.Where("isuse", 1).Order("csort desc,id")
ret["pcmenu"], _, err = CiyDB.Get(csql)
if err != nil {
return ErrJSON(w, "读取menu失败:"+err.Error())
}
csql = NewCiySQL("zc_power")
csql.Order("csort desc,id")
ret["powers"], _, err = CiyDB.Get(csql)
if err != nil {
return ErrJSON(w, "读取power失败:"+err.Error())
}
return SuccJSON(w, ret)
}
func Role_u_update(w http.ResponseWriter, r *http.Request) bool {
post := NewCiyPost(w, r)
_, userid := admin.Verifyfast(CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(CiyDB, userid, "p502u") {
return ErrJSON(w, "您未被授权操作")
}
id := post.Getint("id")
name := post.Get("name")
if name == "" {
return ErrJSON(w, "请填写角色名称")
}
memo := post.Get("memo")
pman := post.Get("pman")
pmans := strings.Split(pman, ",")
powers := []string{}
for _, pmain := range pmans {
if pmain == "" {
continue
}
power := post.Get("power_" + pmain)
if power == "" {
continue
}
powerno := post.Get("power_" + pmain + "_no")
if powerno == "" {
powers = append(powers, pmain)
} else {
ps := strings.Split(power, ",")
for _, p := range ps {
if p == "" {
continue
}
powers = append(powers, p)
}
}
}
power := "." + strings.Join(powers, ".") + "."
var err error
var datarow map[string]any
if id > 0 {
csql := NewCiySQL("zc_role")
csql.Where("id", id)
datarow, err = CiyDB.Getone(csql)
if datarow == nil {
return ErrJSON(w, "数据不存在", err)
}
}
err = CiyDB.Tran(func() error {
updata := map[string]any{}
updata["name"] = name
updata["power"] = power
updata["memo"] = memo
updata["uptimes"] = Tostamp()
csql := NewCiySQL("zc_role")
if id > 0 {
csql.Where("id", id)
_, err = CiyDB.Update(csql, updata)
if datarow["power"] != power {
CiyDB.Execute("update zc_admin set power=? where roleid=?", power, id)
CiyDB.Execute("update zc_online set usrchg=2 where user in (select id from zc_admin where roleid=?)", id)
}
} else {
id, err = CiyDB.Insert(csql, updata)
updata["id"] = id
}
if err != nil {
return fmt.Errorf("更新失败:%v", err)
}
admin.SaveLogDB(CiyDB, "zc_role", datarow, updata)
return nil
})
if err != nil {
return ErrJSON(w, "事务"+err.Error())
}
return SuccJSON(w)
}