Files
Erupe/server/channelserver/repo_scenario.go
Houmgaor ba7ec122f8 revert: remove SQLite support
An MMO server without multiplayer defeats the purpose. PostgreSQL
is the right choice and Docker Compose already solves the setup
pain. This reverts the common/db wrapper, SQLite schema, config
Driver field, modernc.org/sqlite dependency, and all repo type
changes while keeping the dashboard, wizard, and CI improvements
from the previous commit.
2026-03-05 23:05:55 +01:00

36 lines
921 B
Go

package channelserver
import (
"fmt"
"github.com/jmoiron/sqlx"
)
// ScenarioRepository centralizes all database access for the scenario_counter table.
type ScenarioRepository struct {
db *sqlx.DB
}
// NewScenarioRepository creates a new ScenarioRepository.
func NewScenarioRepository(db *sqlx.DB) *ScenarioRepository {
return &ScenarioRepository{db: db}
}
// GetCounters returns all scenario counters.
func (r *ScenarioRepository) GetCounters() ([]Scenario, error) {
rows, err := r.db.Query("SELECT scenario_id, category_id FROM scenario_counter")
if err != nil {
return nil, fmt.Errorf("query scenario_counter: %w", err)
}
defer func() { _ = rows.Close() }()
var result []Scenario
for rows.Next() {
var s Scenario
if err := rows.Scan(&s.MainID, &s.CategoryID); err != nil {
return nil, fmt.Errorf("scan scenario_counter: %w", err)
}
result = append(result, s)
}
return result, rows.Err()
}