Fix: various bug fix

This commit is contained in:
2025-10-16 07:12:01 +08:00
parent 5bbab63a2c
commit 0dea850cfa
16 changed files with 185 additions and 56 deletions

View File

@@ -6,11 +6,14 @@ import (
"gitea.konchin.com/ytshih/inp2025/middlewares"
"gitea.konchin.com/ytshih/inp2025/models"
"gitea.konchin.com/ytshih/inp2025/types"
"gitea.konchin.com/ytshih/inp2025/utils"
"github.com/uptrace/bunrouter"
)
type PostLoginOutput struct {
LoginCount int `msgpack:"loginCount"`
}
func (self *Handlers) PostLogin(
w http.ResponseWriter,
req bunrouter.Request,
@@ -25,11 +28,12 @@ func (self *Handlers) PostLogin(
}
res, err := self.db.NewUpdate().
Model((*models.User)(nil)).
Model(&user).
Set("login_count = login_count + ?", 1).
Set("is_logged = ?", true).
Where("is_logged = ?", false).
Where("username = ?", user.Username).
Returning("*").
Exec(ctx)
if err != nil {
return middlewares.HTTPError{
@@ -46,8 +50,6 @@ func (self *Handlers) PostLogin(
OriginError: err,
}
}
// debug
return utils.Success(w)
if cnt == 0 {
return middlewares.HTTPError{
StatusCode: http.StatusUnauthorized,
@@ -55,5 +57,7 @@ func (self *Handlers) PostLogin(
}
}
}
return utils.Success(w)
return bunrouter.JSON(w, PostLoginOutput{
LoginCount: user.LoginCount,
})
}

View File

@@ -24,6 +24,7 @@ func (self *Handlers) PostLogout(
}
_, err := self.db.NewUpdate().
Model((*models.User)(nil)).
Set("is_logged = ?", false).
Where("username = ?", user.Username).
Exec(ctx)

View File

@@ -11,6 +11,11 @@ import (
"github.com/uptrace/bunrouter"
)
type PostRegisterInput struct {
Username string `json:"username"`
Password string `json:"password"`
}
func (self *Handlers) PostRegister(
w http.ResponseWriter,
req bunrouter.Request,
@@ -26,15 +31,20 @@ func (self *Handlers) PostRegister(
}
}
var user models.User
if err := json.Unmarshal(b, &user); err != nil {
var input PostRegisterInput
if err := json.Unmarshal(b, &input); err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to unmarshal json into user",
Message: "failed to unmarshal json",
OriginError: err,
}
}
user := models.User{
Username: input.Username,
Password: input.Password,
LoginCount: 0,
}
res, err := self.db.NewInsert().
Model(&user).
On("CONFLICT (username) DO NOTHING").