mirror of
https://github.com/Mezeporta/Erupe.git
synced 2026-03-27 18:12:50 +01:00
refactor: replace raw SQL with repository interfaces in entranceserver and API server
Extract all direct database calls from entranceserver (2 calls) and API server (17 calls) into typed repository interfaces with PostgreSQL implementations, matching the pattern established in signserver and channelserver. Entranceserver: EntranceServerRepo, EntranceSessionRepo API server: APIUserRepo, APICharacterRepo, APISessionRepo Also fix the 3 remaining fmt.Sprintf calls inside logger invocations in handlers_commands.go and handlers_stage.go, replacing them with structured zap fields. Unskip 5 TestNewAuthData* tests that previously required a real database — they now run with mock repos.
This commit is contained in:
22
server/entranceserver/repo_session.go
Normal file
22
server/entranceserver/repo_session.go
Normal file
@@ -0,0 +1,22 @@
|
||||
package entranceserver
|
||||
|
||||
import "github.com/jmoiron/sqlx"
|
||||
|
||||
// EntranceSessionRepository implements EntranceSessionRepo with PostgreSQL.
|
||||
type EntranceSessionRepository struct {
|
||||
db *sqlx.DB
|
||||
}
|
||||
|
||||
// NewEntranceSessionRepository creates a new EntranceSessionRepository.
|
||||
func NewEntranceSessionRepository(db *sqlx.DB) *EntranceSessionRepository {
|
||||
return &EntranceSessionRepository{db: db}
|
||||
}
|
||||
|
||||
func (r *EntranceSessionRepository) GetServerIDForCharacter(charID uint32) (uint16, error) {
|
||||
var sid uint16
|
||||
err := r.db.QueryRow("SELECT(SELECT server_id FROM sign_sessions WHERE char_id=$1) AS _", charID).Scan(&sid)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
return sid, nil
|
||||
}
|
||||
Reference in New Issue
Block a user