兼容无token下拉取任务列表
This commit is contained in:
@@ -1,15 +1,21 @@
|
|||||||
syntax = "v1"
|
syntax = "v1"
|
||||||
|
|
||||||
|
@server (
|
||||||
|
prefix: /gapi/task/v1
|
||||||
|
group: task
|
||||||
|
)
|
||||||
|
service novatask {
|
||||||
|
@doc "获取任务列表"
|
||||||
|
@handler GetTaskList
|
||||||
|
get /tasks (GetTaskListReq) returns (GetTaskListResp)
|
||||||
|
}
|
||||||
|
|
||||||
@server (
|
@server (
|
||||||
prefix: /gapi/task/v1
|
prefix: /gapi/task/v1
|
||||||
group: task
|
group: task
|
||||||
jwt: Auth
|
jwt: Auth
|
||||||
)
|
)
|
||||||
service novatask {
|
service novatask {
|
||||||
@doc "获取任务列表"
|
|
||||||
@handler GetTaskList
|
|
||||||
get /tasks (GetTaskListReq) returns (GetTaskListResp)
|
|
||||||
|
|
||||||
@doc "校验任务结果"
|
@doc "校验任务结果"
|
||||||
@handler VerifyTaskResult
|
@handler VerifyTaskResult
|
||||||
get /task/:id (TaskIdPath) returns (VerifyTaskResultResp)
|
get /task/:id (TaskIdPath) returns (VerifyTaskResultResp)
|
||||||
|
|||||||
@@ -102,11 +102,6 @@
|
|||||||
],
|
],
|
||||||
"consumes": [
|
"consumes": [
|
||||||
"multipart/form-data"
|
"multipart/form-data"
|
||||||
],
|
|
||||||
"security": [
|
|
||||||
{
|
|
||||||
"apiKey": []
|
|
||||||
}
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,6 +13,18 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
|
func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
|
||||||
|
server.AddRoutes(
|
||||||
|
[]rest.Route{
|
||||||
|
{
|
||||||
|
// 获取任务列表
|
||||||
|
Method: http.MethodGet,
|
||||||
|
Path: "/tasks",
|
||||||
|
Handler: task.GetTaskListHandler(serverCtx),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
rest.WithPrefix("/gapi/task/v1"),
|
||||||
|
)
|
||||||
|
|
||||||
server.AddRoutes(
|
server.AddRoutes(
|
||||||
[]rest.Route{
|
[]rest.Route{
|
||||||
{
|
{
|
||||||
@@ -27,12 +39,6 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
|
|||||||
Path: "/task/:id",
|
Path: "/task/:id",
|
||||||
Handler: task.VerifyTaskResultHandler(serverCtx),
|
Handler: task.VerifyTaskResultHandler(serverCtx),
|
||||||
},
|
},
|
||||||
{
|
|
||||||
// 获取任务列表
|
|
||||||
Method: http.MethodGet,
|
|
||||||
Path: "/tasks",
|
|
||||||
Handler: task.GetTaskListHandler(serverCtx),
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
rest.WithJwt(serverCtx.Config.Auth.AccessSecret),
|
rest.WithJwt(serverCtx.Config.Auth.AccessSecret),
|
||||||
rest.WithPrefix("/gapi/task/v1"),
|
rest.WithPrefix("/gapi/task/v1"),
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import (
|
|||||||
"github.com/zeromicro/go-zero/rest/httpx"
|
"github.com/zeromicro/go-zero/rest/httpx"
|
||||||
"net/http"
|
"net/http"
|
||||||
"nova_task/internal/logic/task"
|
"nova_task/internal/logic/task"
|
||||||
|
"nova_task/internal/pkg/encrypt/jwt"
|
||||||
"nova_task/internal/svc"
|
"nova_task/internal/svc"
|
||||||
"nova_task/internal/types"
|
"nova_task/internal/types"
|
||||||
)
|
)
|
||||||
@@ -17,8 +18,10 @@ func GetTaskListHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uid, _ := jwt.ParseUid(r, svcCtx.Config.Auth.AccessSecret)
|
||||||
|
|
||||||
l := task.NewGetTaskListLogic(r.Context(), svcCtx)
|
l := task.NewGetTaskListLogic(r.Context(), svcCtx)
|
||||||
resp, err := l.GetTaskList(&req)
|
resp, err := l.GetTaskList(uid, &req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
httpx.ErrorCtx(r.Context(), w, err)
|
httpx.ErrorCtx(r.Context(), w, err)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -28,8 +28,8 @@ func NewGetTaskListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetTa
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *GetTaskListLogic) GetTaskList(req *types.GetTaskListReq) (*types.GetTaskListResp, error) {
|
func (l *GetTaskListLogic) GetTaskList(uid int, req *types.GetTaskListReq) (*types.GetTaskListResp, error) {
|
||||||
uid := cast.ToStringMapInt(l.ctx.Value("data"))["id"]
|
//uid := cast.ToStringMapInt(l.ctx.Value("data"))["id"]
|
||||||
tasks, err := l.svcCtx.TaskModel.FindTasksByCommunity(l.ctx, req.CommunityId)
|
tasks, err := l.svcCtx.TaskModel.FindTasksByCommunity(l.ctx, req.CommunityId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
l.Errorw("get task list failed", logx.Field("err", err), logx.Field("communityId", req.CommunityId))
|
l.Errorw("get task list failed", logx.Field("err", err), logx.Field("communityId", req.CommunityId))
|
||||||
@@ -43,10 +43,13 @@ func (l *GetTaskListLogic) GetTaskList(req *types.GetTaskListReq) (*types.GetTas
|
|||||||
taskSeq = cast.ToInt(time.Now().Format("20060102"))
|
taskSeq = cast.ToInt(time.Now().Format("20060102"))
|
||||||
}
|
}
|
||||||
var finishState int8
|
var finishState int8
|
||||||
tp, err := l.svcCtx.TaskProgressModel.FindOneByUidTaskIdTaskSeq(l.ctx, uid, t.CommunityId, taskSeq)
|
if uid > 0 {
|
||||||
if err == nil {
|
tp, err := l.svcCtx.TaskProgressModel.FindOneByUidTaskIdTaskSeq(l.ctx, uid, t.CommunityId, taskSeq)
|
||||||
finishState = tp.Stage
|
if err == nil {
|
||||||
|
finishState = tp.Stage
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
resp.Tasks = append(resp.Tasks, types.Task{
|
resp.Tasks = append(resp.Tasks, types.Task{
|
||||||
Id: t.Id,
|
Id: t.Id,
|
||||||
Title: t.Title,
|
Title: t.Title,
|
||||||
|
|||||||
@@ -40,67 +40,63 @@ func (b *TokenBuilder) GenerateToken(kvs map[string]any) (string, int64, error)
|
|||||||
return tkStr, expiredAt, err
|
return tkStr, expiredAt, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *TokenBuilder) ParseUidFromToken(tokenStr string) (string, string, string, int64, error) {
|
func (b *TokenBuilder) ParseUidFromToken(tokenStr string) (int, int64, error) {
|
||||||
r := &http.Request{Header: http.Header{}}
|
r := &http.Request{Header: http.Header{}}
|
||||||
r.Header.Set("Authorization", fmt.Sprintf("Bearer %s", tokenStr))
|
r.Header.Set("Authorization", fmt.Sprintf("Bearer %s", tokenStr))
|
||||||
parser := token.NewTokenParser()
|
parser := token.NewTokenParser()
|
||||||
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", "", "", 0, err
|
return 0, 0, err
|
||||||
}
|
}
|
||||||
if !tok.Valid {
|
if !tok.Valid {
|
||||||
return "", "", "", 0, errors.New("token is invalid")
|
return 0, 0, errors.New("token is invalid")
|
||||||
}
|
}
|
||||||
var appid, userId, tgId string
|
var userId int
|
||||||
var expiredAt int64
|
var expiredAt int64
|
||||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||||
if uid, ok := claims["uid"]; ok {
|
if data, ok := claims["data"]; ok {
|
||||||
userId = cast.ToString(uid)
|
userId, _ = cast.ToStringMapInt(data)["id"]
|
||||||
}
|
|
||||||
if aid, ok := claims["app_id"]; ok {
|
|
||||||
appid = cast.ToString(aid)
|
|
||||||
}
|
|
||||||
if tid, ok := claims["tg_id"]; ok {
|
|
||||||
tgId = cast.ToString(tid)
|
|
||||||
}
|
}
|
||||||
if exp, ok := claims["exp"]; ok {
|
if exp, ok := claims["exp"]; ok {
|
||||||
expiredAt = cast.ToInt64(exp)
|
expiredAt = cast.ToInt64(exp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return appid, userId, tgId, expiredAt, nil
|
return userId, expiredAt, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ParseUid 解析出uid
|
// ParseUid 解析出uid
|
||||||
func (b *TokenBuilder) ParseUid(r *http.Request) (string, error) {
|
func (b *TokenBuilder) ParseUid(r *http.Request) (int, error) {
|
||||||
parser := token.NewTokenParser()
|
parser := token.NewTokenParser()
|
||||||
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return 0, err
|
||||||
}
|
}
|
||||||
if !tok.Valid {
|
if !tok.Valid {
|
||||||
return "", errors.New("token is invalid")
|
return 0, errors.New("token is invalid")
|
||||||
}
|
}
|
||||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||||
if uid, ok := claims["uid"]; ok {
|
if data, ok := claims["data"]; ok {
|
||||||
return cast.ToString(uid), nil
|
uid, _ := cast.ToStringMapInt(data)["id"]
|
||||||
|
return uid, nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return "", errors.New("token not exist uid")
|
return 0, errors.New("token not exist uid")
|
||||||
}
|
}
|
||||||
|
|
||||||
func ParseUid(r *http.Request, accessSecret string) (string, error) {
|
func ParseUid(r *http.Request, accessSecret string) (int, error) {
|
||||||
parser := token.NewTokenParser()
|
parser := token.NewTokenParser()
|
||||||
tok, err := parser.ParseToken(r, accessSecret, "")
|
tok, err := parser.ParseToken(r, accessSecret, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return 0, err
|
||||||
}
|
}
|
||||||
if !tok.Valid {
|
if !tok.Valid {
|
||||||
return "", errors.New("token is invalid")
|
return 0, errors.New("token is invalid")
|
||||||
}
|
}
|
||||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||||
if uid, ok := claims["uid"]; ok {
|
if data, ok := claims["data"]; ok {
|
||||||
return cast.ToString(uid), nil
|
uid, _ := cast.ToStringMapInt(data)["id"]
|
||||||
|
return uid, nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return "", errors.New("token not exist uid")
|
return 0, errors.New("token not exist uid")
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user