mirror of
https://github.com/Mezeporta/Erupe.git
synced 2026-03-22 23:54:33 +01:00
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.
23 lines
668 B
Go
23 lines
668 B
Go
package entranceserver
|
|
|
|
import "github.com/jmoiron/sqlx"
|
|
|
|
// EntranceServerRepository implements EntranceServerRepo with PostgreSQL.
|
|
type EntranceServerRepository struct {
|
|
db *sqlx.DB
|
|
}
|
|
|
|
// NewEntranceServerRepository creates a new EntranceServerRepository.
|
|
func NewEntranceServerRepository(db *sqlx.DB) *EntranceServerRepository {
|
|
return &EntranceServerRepository{db: db}
|
|
}
|
|
|
|
func (r *EntranceServerRepository) GetCurrentPlayers(serverID int) (uint16, error) {
|
|
var currentPlayers uint16
|
|
err := r.db.QueryRow("SELECT current_players FROM servers WHERE server_id=$1", serverID).Scan(¤tPlayers)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
return currentPlayers, nil
|
|
}
|