跳到主要内容
版本:2.8.x(Latest)

设置掌握程度的功能本质上是一种编辑,只改变ProficiencyLevel一个字段,所以这里使用PATCH方式比PUT更为合适。

添加Api


api/words/v1/words_learn.go

...

type SetLevelReq struct {
g.Meta `path:"words/{id}/level" method:"patch"`
Id uint `json:"id" v:"required"`
Level ProficiencyLevel `json:"level" v:"required|between:1,5"`
}

type SetLevelRes struct {
}

words/{id}/levelwords/level/{id}这两种路由风格均可,但是前者更符合资源层级关系,推荐使用。

编写Logic


internal/logic/words/words_learn.go

...

// SetLevel 设置单词熟练度
func (w *Words) SetLevel(ctx context.Context, uid, id uint, level v1.ProficiencyLevel) error {
if level < 0 || level > 5 {
return gerror.New("熟练度值不合法")
}

var (
cls = dao.Words.Columns()
orm = dao.Words.Ctx(ctx)
)
if uid > 0 {
orm = orm.Where(cls.Uid, uid)
}

_, err := orm.Data(cls.ProficiencyLevel, level).Where(cls.Id, id).Update()
return err
}****

为了防止数据异常,我们要在入库前检测等级是否在1-5之间。

Controller调用Logic


internal/controller/words/words_v1_set_level.go

package words  

import (
"context"

"star/api/words/v1"
)

func (c *ControllerV1) SetLevel(ctx context.Context, req *v1.SetLevelReq) (res *v1.SetLevelRes, err error) {
uid, err := c.users.GetUid(ctx)
if err != nil {
return nil, err
}

err = c.words.SetLevel(ctx, uid, req.Id, req.Level)
return nil, err
}

接口测试


$ curl -X PATCH http://127.0.0.1:8000/v1/words/1/level \
-H "Authorization: eyJhbGci...5U" \
-H "Content-Type: application/json" \
-d '{
"proficiency_level": 5
}'

{
    "code": 0,
    "message": "",
    "data": null
}