3e37303979
- Add migration 000004 for sessions table and performance indexes - Create session.sql queries for CRUD operations - Generate session repository code with sqlc - Create token auth middleware for Echo framework - Create token handler with create/delete/cleanup endpoints - Add /api/v1 router with token authentication infrastructure - Update dbHelper.go to use Up() instead of Migrate(2) - Update server.go to initialize token handler - Existing endpoints remain functional (to be deprecated) New endpoints: - POST /api/v1/token - Create new session token - DELETE /api/v1/token - Invalidate token - POST /api/v1/token/cleanup - Remove expired sessions Generated by Mistral Vibe. Co-Authored-By: Mistral Vibe <vibe@mistral.ai>
84 lines
1.8 KiB
Go
84 lines
1.8 KiB
Go
package server
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"strconv"
|
|
"time"
|
|
|
|
"music-server/internal/db"
|
|
"music-server/internal/logging"
|
|
"net/http"
|
|
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
type Server struct {
|
|
port int
|
|
tokenHandler *TokenHandler
|
|
}
|
|
|
|
var (
|
|
host = os.Getenv("DB_HOST")
|
|
dbPort = os.Getenv("DB_PORT")
|
|
dbName = os.Getenv("DB_NAME")
|
|
username = os.Getenv("DB_USERNAME")
|
|
password = os.Getenv("DB_PASSWORD")
|
|
musicPath = os.Getenv("MUSIC_PATH")
|
|
charactersPath = os.Getenv("CHARACTERS_PATH")
|
|
logLevel = os.Getenv("LOG_LEVEL")
|
|
logJSON = os.Getenv("LOG_JSON") == "true"
|
|
)
|
|
|
|
func NewServer() *http.Server {
|
|
// Initialize logger
|
|
if logLevel == "" {
|
|
logLevel = "info"
|
|
}
|
|
logging.Init(logLevel, logJSON)
|
|
|
|
logger := logging.GetLogger()
|
|
|
|
port, _ := strconv.Atoi(os.Getenv("PORT"))
|
|
|
|
// Initialize token handler
|
|
tokenHandler := NewTokenHandler()
|
|
|
|
NewServer := &Server{
|
|
port: port,
|
|
tokenHandler: tokenHandler,
|
|
}
|
|
|
|
logger.Info("Starting server",
|
|
zap.String("host", host),
|
|
zap.String("dbPort", dbPort),
|
|
zap.String("username", username),
|
|
zap.String("dbName", dbName),
|
|
)
|
|
|
|
logger.Info("Paths",
|
|
zap.String("musicPath", musicPath),
|
|
zap.String("charactersPath", charactersPath),
|
|
)
|
|
|
|
//conf.SetupDb()
|
|
if host == "" || dbPort == "" || username == "" || password == "" || dbName == "" || musicPath == "" || charactersPath == "" {
|
|
logging.GetLogger().Fatal("Invalid settings - missing required environment variables")
|
|
}
|
|
|
|
db.Migrate_db(host, dbPort, username, password, dbName)
|
|
|
|
db.InitDB(host, dbPort, username, password, dbName)
|
|
|
|
// Declare Server config
|
|
server := &http.Server{
|
|
Addr: fmt.Sprintf(":%d", NewServer.port),
|
|
Handler: NewServer.RegisterRoutes(),
|
|
IdleTimeout: time.Minute,
|
|
ReadTimeout: 10 * time.Second,
|
|
WriteTimeout: 30 * time.Second,
|
|
}
|
|
|
|
return server
|
|
}
|