Draft: big refactor

This commit is contained in:
2025-09-16 16:03:27 +08:00
parent f527230f1e
commit 08c23bb29b
33 changed files with 339 additions and 155 deletions

View File

@@ -0,0 +1,37 @@
package auth
import (
"net/http"
"gitea.konchin.com/ytshih/inp2025/game/models"
"gitea.konchin.com/ytshih/inp2025/game/server/middlewares"
"gitea.konchin.com/ytshih/inp2025/game/types"
"gitea.konchin.com/ytshih/inp2025/game/utils"
"github.com/uptrace/bunrouter"
)
func (self *Handlers) GetLogin(
w http.ResponseWriter,
req bunrouter.Request,
) error {
ctx := req.Context()
user, ok := ctx.Value(types.User("")).(models.User)
if !ok {
return middlewares.HTTPError{
StatusCode: http.StatusUnauthorized,
Message: "user not found",
}
}
err := self.db.InsertUserStatus(ctx,
models.UserStatus{Username: user.Username})
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to update user status",
OriginError: err,
}
}
return utils.Success(w)
}

View File

@@ -0,0 +1,13 @@
package auth
import (
"gitea.konchin.com/ytshih/inp2025/game/interfaces"
)
type Handlers struct {
db interfaces.Database
}
func NewHandlers(db interfaces.Database) *Handlers {
return &Handlers{db: db}
}

View File

@@ -0,0 +1,40 @@
package auth
import (
"net/http"
"gitea.konchin.com/ytshih/inp2025/game/models"
"gitea.konchin.com/ytshih/inp2025/game/server/middlewares"
"gitea.konchin.com/ytshih/inp2025/game/types"
"gitea.konchin.com/ytshih/inp2025/game/utils"
"github.com/uptrace/bunrouter"
)
// PostLogout
//
// @Success 200
// @Router /auth/logout [post]
func (self *Handlers) PostLogout(
w http.ResponseWriter,
req bunrouter.Request,
) error {
ctx := req.Context()
user, ok := ctx.Value(types.User("")).(models.User)
if !ok {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "missing user",
}
}
if err := self.db.DeleteUserStatus(ctx, user.Username); err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to delete user status",
OriginError: err,
}
}
return utils.Success(w)
}

View File

@@ -0,0 +1,62 @@
package auth
import (
"encoding/json"
"io"
"net/http"
"gitea.konchin.com/ytshih/inp2025/game/models"
"gitea.konchin.com/ytshih/inp2025/game/server/middlewares"
"gitea.konchin.com/ytshih/inp2025/game/types"
"gitea.konchin.com/ytshih/inp2025/game/utils"
"github.com/uptrace/bunrouter"
)
// PostRegister
//
// @Accept json
// @Param request body models.User true "query params"
// @Success 200
// @Failure 400
// @Router /auth/register [post]
func (self *Handlers) PostRegister(
w http.ResponseWriter,
req bunrouter.Request,
) error {
ctx := req.Context()
b, err := io.ReadAll(req.Body)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to read body payload",
OriginError: err,
}
}
var user models.User
if err := json.Unmarshal(b, &user); err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to unmarshal json into user",
OriginError: err,
}
}
if err := self.db.InsertUser(ctx, user); err != nil {
if err == types.UsernameConflictError {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "username already exist",
OriginError: err,
}
}
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to insert user",
OriginError: err,
}
}
return utils.Success(w)
}