mirror of
https://github.com/Mezeporta/Erupe.git
synced 2026-03-21 23:22:34 +01:00
Fix rasta_id=0 overwriting NULL in SaveMercenary, which prevented game state saving for characters without a mercenary (#163). Also includes: - CHANGELOG updated with all 10 post-RC1 commits - Setup wizard fmt.Printf replaced with zap structured logging - technical-debt.md updated with 6 newly completed items - Scenario binary format documented (docs/scenario-format.md) - Tests: alliance nil-guard (#171), handler dispatch table, migrations (sorted/SQL/baseline), setup wizard (10 tests), protbot protocol sign/entrance/channel (23 tests)
57 lines
1.5 KiB
Go
57 lines
1.5 KiB
Go
package setup
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/gorilla/mux"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
// Run starts a temporary HTTP server serving the setup wizard.
|
|
// It blocks until the user completes setup and config.json is written.
|
|
func Run(logger *zap.Logger, port int) error {
|
|
ws := &wizardServer{
|
|
logger: logger,
|
|
done: make(chan struct{}),
|
|
}
|
|
|
|
r := mux.NewRouter()
|
|
r.HandleFunc("/", ws.handleIndex).Methods("GET")
|
|
r.HandleFunc("/api/setup/detect-ip", ws.handleDetectIP).Methods("GET")
|
|
r.HandleFunc("/api/setup/client-modes", ws.handleClientModes).Methods("GET")
|
|
r.HandleFunc("/api/setup/test-db", ws.handleTestDB).Methods("POST")
|
|
r.HandleFunc("/api/setup/init-db", ws.handleInitDB).Methods("POST")
|
|
r.HandleFunc("/api/setup/finish", ws.handleFinish).Methods("POST")
|
|
|
|
srv := &http.Server{
|
|
Addr: fmt.Sprintf(":%d", port),
|
|
Handler: r,
|
|
}
|
|
|
|
logger.Info("Setup wizard available",
|
|
zap.String("url", fmt.Sprintf("http://localhost:%d", port)))
|
|
logger.Warn("Open the URL above in your browser to configure Erupe")
|
|
|
|
// Start the HTTP server in a goroutine.
|
|
errCh := make(chan error, 1)
|
|
go func() {
|
|
if err := srv.ListenAndServe(); err != http.ErrServerClosed {
|
|
errCh <- err
|
|
}
|
|
}()
|
|
|
|
// Wait for either completion or server error.
|
|
select {
|
|
case <-ws.done:
|
|
logger.Info("Setup complete, shutting down wizard")
|
|
if err := srv.Shutdown(context.Background()); err != nil {
|
|
logger.Warn("Error shutting down wizard server", zap.Error(err))
|
|
}
|
|
return nil
|
|
case err := <-errCh:
|
|
return fmt.Errorf("setup wizard server error: %w", err)
|
|
}
|
|
}
|