更新获取接口

This commit is contained in:
李志强 2026-04-13 10:09:00 +08:00
parent ccad4c05f7
commit 53decd0084
2 changed files with 81 additions and 49 deletions

View File

@ -34,13 +34,14 @@ var validModules = map[string]bool{
func (c *ApiGetCardController) cardErr(httpStatus, code int, msg string) {
c.Ctx.Output.SetStatus(httpStatus)
c.Data["json"] = map[string]interface{}{"code": code, "msg": msg}
_ = c.ServeJSON()
c.Ctx.Output.Header("Content-Type", "text/plain; charset=utf-8")
_ = c.Ctx.Output.Body([]byte(msg))
}
func (c *ApiGetCardController) cardOK(data interface{}) {
c.Data["json"] = map[string]interface{}{"code": 200, "msg": "success", "data": data}
_ = c.ServeJSON()
func (c *ApiGetCardController) cardOK(text string) {
c.Ctx.Output.SetStatus(200)
c.Ctx.Output.Header("Content-Type", "text/plain; charset=utf-8")
_ = c.Ctx.Output.Body([]byte(text))
}
// GetCard 提取一张卡(不可重复提取)
@ -179,11 +180,8 @@ func (c *ApiGetCardController) extractKrio(platform, dataType string, now time.T
c.cardOK(buildCardResult(&row.Account, &row.Password, row.Token, row.DataType))
}
// buildCardResult 根据账号类型组装返回数据
func buildCardResult(account, password *string, token string, dataType string) map[string]interface{} {
result := map[string]interface{}{
"type": dataType,
}
// buildCardResult 根据账号类型返回格式化字符串
func buildCardResult(account, password *string, token string, dataType string) string {
acc := ""
pwd := ""
if account != nil {
@ -194,14 +192,10 @@ func buildCardResult(account, password *string, token string, dataType string) m
}
switch dataType {
case "account":
result["account"] = acc
result["password"] = pwd
case "tk":
result["token"] = token
return fmt.Sprintf("账号:%s / 密码:%s", acc, pwd)
case "account_tk":
result["account"] = acc
result["password"] = pwd
result["token"] = token
return fmt.Sprintf("账号:%s / 密码:%s / Token%s", acc, pwd, token)
default: // tk
return token
}
return result
}

View File

@ -95,20 +95,7 @@ func listPoolRows(c *beego.Controller, module string) {
dataType := strings.TrimSpace(c.GetString("type"))
status := strings.TrimSpace(c.GetString("status"))
var table string
switch module {
case "cursor":
table = new(models.PlatformAccountPoolCursor).TableName()
case "windsurf":
table = new(models.PlatformAccountPoolWindsurf).TableName()
case "krio":
table = new(models.PlatformAccountPoolKiro).TableName()
default:
poolJSONErr(c, 400, 400, "无效模块")
return
}
qs := models.Orm.QueryTable(table)
applyFilters := func(qs orm.QuerySeter) orm.QuerySeter {
if dataType != "" && isValidPoolType(dataType) {
qs = qs.Filter("data_type", dataType)
}
@ -119,26 +106,77 @@ func listPoolRows(c *beego.Controller, module string) {
qs = qs.Filter("is_extracted", 1)
}
if keyword != "" {
qs = qs.Filter("account__icontains", keyword).Filter("remark__icontains", keyword)
qs = qs.Filter("account__icontains", keyword)
}
total, err := qs.Count()
return qs
}
var list interface{}
var total int64
var err error
switch module {
case "cursor":
qs := applyFilters(models.Orm.QueryTable(new(models.PlatformAccountPoolCursor)))
total, err = qs.Count()
if err != nil {
poolJSONErr(c, 500, 500, "获取列表失败: "+err.Error())
return
}
var rows []orm.Params
_, err = qs.OrderBy("-id").Limit(pageSize, (page-1)*pageSize).Values(&rows)
var rows []models.PlatformAccountPoolCursor
_, err = qs.OrderBy("-id").Limit(pageSize, (page-1)*pageSize).All(&rows)
if err != nil && err != orm.ErrNoRows {
poolJSONErr(c, 500, 500, "cursor查询失败: "+err.Error())
return
}
if rows == nil {
rows = []models.PlatformAccountPoolCursor{}
}
list = rows
case "windsurf":
qs := applyFilters(models.Orm.QueryTable(new(models.PlatformAccountPoolWindsurf)))
total, err = qs.Count()
if err != nil {
poolJSONErr(c, 500, 500, "获取列表失败: "+err.Error())
return
}
var rows []models.PlatformAccountPoolWindsurf
_, err = qs.OrderBy("-id").Limit(pageSize, (page-1)*pageSize).All(&rows)
if err != nil && err != orm.ErrNoRows {
poolJSONErr(c, 500, 500, "获取列表失败: "+err.Error())
return
}
if rows == nil {
rows = []models.PlatformAccountPoolWindsurf{}
}
list = rows
case "krio":
qs := applyFilters(models.Orm.QueryTable(new(models.PlatformAccountPoolKiro)))
total, err = qs.Count()
if err != nil {
poolJSONErr(c, 500, 500, "获取列表失败: "+err.Error())
return
}
var rows []models.PlatformAccountPoolKiro
_, err = qs.OrderBy("-id").Limit(pageSize, (page-1)*pageSize).All(&rows)
if err != nil && err != orm.ErrNoRows {
poolJSONErr(c, 500, 500, "获取列表失败: "+err.Error())
return
}
if rows == nil {
rows = []models.PlatformAccountPoolKiro{}
}
list = rows
default:
poolJSONErr(c, 400, 400, "无效模块")
return
}
c.Data["json"] = map[string]interface{}{
"code": 200,
"msg": "success",
"data": map[string]interface{}{
"list": rows,
"list": list,
"total": total,
},
}