c5_labsci/web/admin/rigger/debug_user.go
2026-01-27 00:52:00 +08:00

226 lines
5.7 KiB
Go

package rigger
import (
"ciyon/web/admin"
c "ciyon/zciyon"
"fmt"
"net/http"
)
func debug_user_setwhere(post *c.CiyPost) (map[string]any, *c.CiySQL) {
query := post.Getobj("query")
csql := c.NewCiySQL("zc_debug_user")
csql.Where("name like", c.Getstr(query, "name"))
csql.Where("user like", c.Getstr(query, "user"))
csql.Where("targettype", c.Getstr(query, "targettype"))
csql.Where("isuse", c.Getstr(query, "isuse"))
order := c.Getstr(query, "order", "id desc")
csql.Order(order)
query["order"] = order
return query, csql
}
func Debug_user_init(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
where, csql := debug_user_setwhere(post)
pageno := post.Getint("pageno", 1)
pagecount := post.Getint("pagecount", 10)
csql.Limit(pageno, pagecount)
rows, mainrowcount, err := c.CiyDB.Get(csql, post.Getint("count"))
if err != nil {
return c.ErrJSON(w, "读取错误", err)
}
ret := map[string]any{}
ret["where"] = where
ret["pageno"] = pageno
ret["pagecount"] = pagecount
ret["count"] = mainrowcount
ret["list"] = rows
if post.Getbool("field") {
field, fshow := c.CiyDB.GetField(csql)
c.FieldAdd(&field, &fshow, 0, "_btn", "操作")
ret["fshow"] = fshow
ret["field"] = field
}
if post.Getbool("once") {
once := map[string]any{}
input := make([]map[string]any, 0)
isusevals := c.CiyDB.Getdbcodes("zc_debug_user", "isuse")
input = append(input, map[string]any{
"form": "targettype",
"type": "select",
"name": "子系统",
"select": "targettype",
"all": "全部",
})
input = append(input, map[string]any{
"form": "isuse",
"type": "select",
"name": "开关",
"select": isusevals,
"all": "全部",
})
// input = append(input, map[string]any{
// "form": "isuse",
// "type": "switch",
// "name": "开关",
// "value": isusevals,
// })
input = append(input, map[string]any{
"form": "name",
"type": "input",
"name": "显示名",
"prop": ` style="width:8em;"`,
})
input = append(input, map[string]any{
"form": "user",
"type": "input",
"name": "用户名",
"prop": ` style="width:8em;"`,
})
once["input"] = input
ret["once"] = once
}
return c.SuccJSON(w, r, ret)
}
func Debug_user_update(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(c.CiyDB, userid, "p991u") {
return c.ErrJSON(w, "您未被授权操作")
}
id := post.Getint("id")
targettype := post.Getint("targettype")
if targettype <= 0 {
return c.ErrJSON(w, "请选择子系统")
}
isuse := post.Getint("isuse")
name := post.Get("name")
if name == "" {
return c.ErrJSON(w, "请填写显示名")
}
user := post.Get("user")
if user == "" {
return c.ErrJSON(w, "请填写用户名")
}
pass := post.Get("pass")
if pass == "" {
return c.ErrJSON(w, "请填写密码")
}
var err error
var datarow map[string]any
if id > 0 {
csql := c.NewCiySQL("zc_debug_user")
csql.Where("id", id)
datarow, err = c.CiyDB.Getone(csql)
if datarow == nil {
return c.ErrJSON(w, "数据不存在", err)
}
}
updata := map[string]any{}
err = c.CiyDB.Tran(func() error {
var csql *c.CiySQL
csql = c.NewCiySQL("zc_debug_user")
csql.Where("targettype", targettype)
csql.Where("user", user)
csql.Column("id")
chkid := c.Toint(c.CiyDB.Get1(csql))
if chkid > 0 && ((id > 0 && chkid != id) || id == 0) {
return fmt.Errorf("数据已存在")
}
updata["targettype"] = targettype
updata["isuse"] = isuse
updata["name"] = name
updata["user"] = user
updata["pass"] = pass
csql = c.NewCiySQL("zc_debug_user")
if id > 0 {
csql.Where("id", id)
_, err = c.CiyDB.Update(csql, updata)
} else {
id, err = c.CiyDB.Insert(csql, updata)
}
updata["id"] = id
if err != nil {
return fmt.Errorf("更新失败:%v", err)
}
admin.SaveLogDB(c.CiyDB, "zc_debug_user", datarow, updata)
return nil
})
if err != nil {
return c.ErrJSON(w, "事务"+err.Error())
}
ret := map[string]any{}
ret["data"] = updata
return c.SuccJSON(w, r, ret)
}
func Debug_user_del(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(c.CiyDB, userid, "p991u") {
return c.ErrJSON(w, "您未被授权操作")
}
ids := post.Get("ids")
if ids == "" {
return c.ErrJSON(w, "请选择至少一条")
}
csql := c.NewCiySQL("zc_debug_user")
csql.Where("id in", ids)
rows, _, err := c.CiyDB.Get(csql)
if err != nil {
return c.ErrJSON(w, "读取数据错误", err)
}
vids := make([]int, 0)
err = c.CiyDB.Tran(func() error {
for _, row := range rows {
delid := c.Toint(row["id"])
c.Delme(c.CiyDB, delid, "zc_debug_user")
admin.SaveLogDB(c.CiyDB, "zc_debug_user", row, nil)
vids = append(vids, delid)
}
return nil
})
if err != nil {
return c.ErrJSON(w, "事务"+err.Error())
}
ret := map[string]any{}
ret["ids"] = vids
return c.SuccJSON(w, r, ret)
}
func Debug_user_getlocal(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(c.CiyDB, userid, "p991n") {
return c.ErrJSON(w, "您未被授权操作")
}
targettype := post.Getint("targettype")
if targettype == 0 {
return c.ErrJSON(w, "请选择子系统")
}
csql := c.NewCiySQL("zc_debug_user")
csql.Where("targettype", targettype)
csql.Where("isuse", 1)
csql.Column("id,name,user,pass")
rows, _, err := c.CiyDB.Get(csql)
if err != nil {
return c.ErrJSON(w, "读取错误", err)
}
ret := map[string]any{}
ret["list"] = rows
return c.SuccJSON(w, r, ret)
}