Draft: big refactor

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

View File

@@ -0,0 +1,29 @@
package api
import (
"net/http"
"gitea.konchin.com/ytshih/inp2025/game/server/middlewares"
"github.com/uptrace/bunrouter"
)
// GetLobbyUsers
//
// @Router /api/lobby/users [get]
func (self *Handlers) GetLobbyUsers(
w http.ResponseWriter,
req bunrouter.Request,
) error {
ctx := req.Context()
userStatuses, err := self.db.GetUserStatuses(ctx)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to get user statuses",
OriginError: err,
}
}
return bunrouter.JSON(w, userStatuses)
}

View File

@@ -0,0 +1,55 @@
package api
import (
"database/sql"
"net/http"
"gitea.konchin.com/ytshih/inp2025/game/server/middlewares"
"github.com/uptrace/bunrouter"
)
type GetUserOutput struct {
Username string `json:"username"`
}
// GetUser
//
// @Accept json
// @Param username query string true "Username to be queried"
// @Success 200
// @Failure 400
// @Router /api/user [get]
func (self *Handlers) GetUser(
w http.ResponseWriter,
req bunrouter.Request,
) error {
ctx := req.Context()
username := req.URL.Query().Get("username")
if username == "" {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "must provide username",
}
}
user, err := self.db.GetUser(ctx, username)
if err != nil {
if err == sql.ErrNoRows {
return middlewares.HTTPError{
StatusCode: http.StatusNotFound,
Message: "user not exist",
OriginError: err,
}
}
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to get user",
OriginError: err,
}
}
return bunrouter.JSON(w, GetUserOutput{
Username: user.Username,
})
}

View File

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