modify api limit auth

master
jager 3 years ago
parent 49037549cf
commit 8c8a544997

@ -19,8 +19,6 @@ import (
"idata/internal/service/user" "idata/internal/service/user"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/jageros/hawox/errcode"
"github.com/jageros/hawox/httpx"
) )
func Registry(engine *gin.Engine) { func Registry(engine *gin.Engine) {
@ -32,20 +30,7 @@ func Registry(engine *gin.Engine) {
ur.GET("/secret", jwt.CheckToken, user.Secret) ur.GET("/secret", jwt.CheckToken, user.Secret)
ur.GET("/open", jwt.CheckToken, user.OpenApi) ur.GET("/open", jwt.CheckToken, user.OpenApi)
apiR := r.Group("/api", auth) apiR := r.Group("/api")
apiR.GET("/soup", soup.GetRandSoup) apiR.GET("/soup", soup.GetRandSoup)
apiR.GET("/almanac", almanac.Almanac) apiR.GET("/almanac", almanac.Almanac)
} }
func auth(ctx *gin.Context) {
uid, ok1 := httpx.DecodeUrlVal(ctx, "uid")
secret, ok2 := httpx.DecodeUrlVal(ctx, "secret")
if !ok1 || !ok2 {
httpx.ErrInterrupt(ctx, errcode.InvalidParam)
return
}
if !user.Auth(uid, secret) {
httpx.ErrInterrupt(ctx, errcode.VerifyErr)
return
}
}

@ -17,10 +17,10 @@ import "strconv"
type ApiType int64 type ApiType int64
const ( const (
Soup ApiType = 1 << iota Soup ApiType = 1 << iota // 1鸡汤句子
Weather Weather // 2天气
Obscenity Obscenity // 3脏词检测
Astro Almanac // 4黄历
) )
func Type(ty string) ApiType { func Type(ty string) ApiType {
@ -35,8 +35,8 @@ func Type(ty string) ApiType {
return Weather return Weather
case "obscenity": case "obscenity":
return Obscenity return Obscenity
case "astro": case "almanac":
return Astro return Almanac
} }
return ApiType(0) return ApiType(0)
} }

@ -20,31 +20,13 @@ import (
"idata/internal/apity" "idata/internal/apity"
"idata/internal/consts" "idata/internal/consts"
"idata/internal/service/user" "idata/internal/service/user"
"idata/internal/types"
"strconv" "strconv"
"strings" "strings"
"time" "time"
) )
func Almanac(ctx *gin.Context) { func Almanac(ctx *gin.Context) {
uid, ok := httpx.DecodeUrlVal(ctx, "uid") if !user.Auth(ctx, apity.Almanac) {
if !ok {
return
}
var opened bool
err := user.OperateSync(uid, func(u types.RWUser) {
opened = u.ApiCanReq(apity.Astro)
if opened && !u.IsVip() {
u.SetScore(u.Score() - 1)
}
})
if err != nil {
httpx.ErrInterrupt(ctx, errcode.WithErrcode(1, err))
return
}
if !opened {
httpx.ErrInterrupt(ctx, errcode.New(1, "未获得此Api权限"))
return return
} }
date, ok := httpx.DecodeUrlVal(ctx, "date") date, ok := httpx.DecodeUrlVal(ctx, "date")
@ -60,6 +42,10 @@ func Almanac(ctx *gin.Context) {
} }
} }
dd := astro.GetDate(strs[0]) dd := astro.GetDate(strs[0])
if dd == nil {
httpx.ErrInterrupt(ctx, errcode.InvalidParam)
return
}
data, err := dd.Map(hour) data, err := dd.Map(hour)
if err != nil { if err != nil {
httpx.ErrInterrupt(ctx, errcode.WithErrcode(2, err)) httpx.ErrInterrupt(ctx, errcode.WithErrcode(2, err))

@ -14,31 +14,13 @@ package soup
import ( import (
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/jageros/hawox/errcode"
"github.com/jageros/hawox/httpx" "github.com/jageros/hawox/httpx"
"idata/internal/apity" "idata/internal/apity"
"idata/internal/service/user" "idata/internal/service/user"
"idata/internal/types"
) )
func GetRandSoup(ctx *gin.Context) { func GetRandSoup(ctx *gin.Context) {
uid, ok := httpx.DecodeUrlVal(ctx, "uid") if !user.Auth(ctx, apity.Soup) {
if !ok {
return
}
var opened bool
err := user.OperateSync(uid, func(u types.RWUser) {
opened = u.ApiCanReq(apity.Soup)
if opened && !u.IsVip() {
u.SetScore(u.Score() - 1)
}
})
if err != nil {
httpx.ErrInterrupt(ctx, errcode.WithErrcode(1, err))
return
}
if !opened {
httpx.ErrInterrupt(ctx, errcode.New(1, "未获得此Api权限"))
return return
} }
text := getContent() text := getContent()

@ -164,12 +164,29 @@ func OpenApi(ctx *gin.Context) {
httpx.PkgMsgWrite(ctx, nil) httpx.PkgMsgWrite(ctx, nil)
} }
func Auth(uid, secret string) bool { func Auth(ctx *gin.Context, ty apity.ApiType) bool {
var ok bool uid, ok1 := httpx.DecodeUrlVal(ctx, "uid")
err := Operate(uid, func(u types.RUser) { secret, ok2 := httpx.DecodeUrlVal(ctx, "secret")
if u.Secret() == secret { if !ok1 || !ok2 {
ok = true return false
}
var opened bool
err := OperateSync(uid, func(u types.RWUser) {
if u.Secret() != secret {
return
}
opened = u.ApiCanReq(ty)
if opened && !u.IsVip() {
u.SetScore(u.Score() - 1)
} }
}) })
return err == nil && ok if err != nil {
httpx.ErrInterrupt(ctx, errcode.WithErrcode(-1, err))
return false
}
if !opened {
httpx.ErrInterrupt(ctx, errcode.VerifyErr)
}
return opened
} }

Loading…
Cancel
Save