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

172 lines
4.1 KiB
Go

package rigger
import (
"fmt"
"net/http"
"ciyon/web/admin"
. "ciyon/zciyon"
)
func logdb_setwhere(post *CiyPost) (map[string]any, *CiySQL) {
query := post.Getobj("query")
csql := NewCiySQL("zc_log")
liid := Getint(query, "liid")
if liid == 1 {
csql.Where("readuser=0")
}
if liid == 2 {
csql.Where("readuser>0")
}
csql.Where("loguser", Getstr(query, "loguser"))
csql.Where("readuser", Getstr(query, "readuser"))
csql.Where("types", Getstr(query, "types"))
csql.Where_daterange("addtimes", Getstr(query, "addtimes"))
csql.Where("logs like", Getstr(query, "logs"))
order := Getstr(query, "order", "id desc")
csql.Order(order)
query["order"] = order
return query, csql
}
func Logdb_init(w http.ResponseWriter, r *http.Request) bool {
post := NewCiyPost(w, r)
_, userid := admin.Verifyfast(CiyDB, post)
if userid == 0 {
return false
}
where, csql := logdb_setwhere(post)
pageno := post.Getint("pageno", 1)
pagecount := post.Getint("pagecount", 10)
csql.Limit(pageno, pagecount)
rows, mainrowcount, err := CiyDB.Get(csql, post.Getint("count"))
if err != nil {
return 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 := CiyDB.GetField(csql)
ret["fshow"] = fshow
ret["field"] = field
}
if post.Getbool("once") {
once := map[string]any{}
input := make([]map[string]any, 0)
input = append(input, map[string]any{
"form": "loguser",
"type": "select",
"name": "操作人",
"prop": ` style="min-width:6em;"`,
"select": "adminuser",
"all": "全部",
})
input = append(input, map[string]any{
"form": "readuser",
"type": "select",
"name": "审阅人",
"prop": ` style="min-width:6em;"`,
"select": "adminuser",
"all": "全部",
})
input = append(input, map[string]any{
"form": "types",
"type": "input",
"name": "LOG分类",
"prop": ` style="width:8em;"`,
})
input = append(input, map[string]any{
"form": "addtimes",
"type": "daterange",
"name": "发生日期",
})
input = append(input, map[string]any{
"form": "logs",
"type": "input",
"name": "详情",
"prop": ` style="width:8em;"`,
})
once["input"] = input
ret["once"] = once
}
return SuccJSON(w, ret)
}
func Logdb_del(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, "p553d") {
return ErrJSON(w, "您未被授权操作")
}
ids := post.Get("ids")
if ids == "" {
return ErrJSON(w, "请选择至少一条")
}
csql := NewCiySQL("zc_log")
csql.Where("id in", ids)
rows, _, err := CiyDB.Get(csql)
if err != nil {
return ErrJSON(w, "读取数据错误", err)
}
vids := make([]int, 0)
err = CiyDB.Tran(func() error {
for _, row := range rows {
delid := Toint(row["id"])
Delme(CiyDB, delid, "zc_log")
vids = append(vids, delid)
}
return nil
})
if err != nil {
return ErrJSON(w, "事务"+err.Error())
}
ret := map[string]any{}
ret["ids"] = vids
return SuccJSON(w, ret)
}
func Logdb_multiread(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, "p553s") {
return ErrJSON(w, "您未被授权操作")
}
ids := post.Get("ids")
csql := NewCiySQL("zc_log")
csql.Where("id in", ids)
rows, _, err := CiyDB.Get(csql)
if err != nil {
return ErrJSON(w, "读取数据错误", err)
}
vids := make([]int, 0)
err = CiyDB.Tran(func() error {
for _, row := range rows {
rowid := Toint(row["id"])
updata := map[string]any{}
updata["readuser"] = userid
csql = NewCiySQL("zc_log")
csql.Where("id", rowid)
_, err = CiyDB.Update(csql, updata)
if err != nil {
return fmt.Errorf("更新失败:%v", err)
}
vids = append(vids, rowid)
}
return nil
})
if err != nil {
return ErrJSON(w, "事务"+err.Error())
}
ret := map[string]any{}
ret["ids"] = vids
return SuccJSON(w, ret)
}