-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.go
More file actions
99 lines (86 loc) · 2.53 KB
/
main.go
File metadata and controls
99 lines (86 loc) · 2.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
package main
import (
"context"
"embed"
"flag"
"fmt"
"log/slog"
"os"
"os/signal"
"strings"
"syscall"
_ "github.com/cksidharthan/s3-browser/docs"
"github.com/cksidharthan/s3-browser/internal/server"
)
//go:embed frontend/dist
var frontendFS embed.FS
// @title S3 Browser API
// @version 1.0
// @description A modern web-based file manager for S3-compatible storage systems
// @host localhost:8080
// @BasePath /api
func main() {
// Define command-line flags
var (
port = flag.String("port", "8080", "Port to run the server on")
logLevel = flag.String("log-level", "info", "Log level (debug, info, warn, error)")
help = flag.Bool("help", false, "Show help message")
)
flag.Parse()
// Show help if requested
if *help {
fmt.Println("S3 Browser - A modern web-based file manager for S3-compatible storage")
fmt.Println("")
fmt.Println("Usage:")
flag.PrintDefaults()
fmt.Println("")
fmt.Println("Examples:")
fmt.Println(" s3-browser")
fmt.Println(" s3-browser -port 3000")
fmt.Println(" s3-browser -port 8080 -log-level debug")
fmt.Println(" s3-browser -help")
os.Exit(0)
}
// Parse log level
var logLevelVar slog.Level
switch strings.ToLower(*logLevel) {
case "debug":
logLevelVar = slog.LevelDebug
case "info":
logLevelVar = slog.LevelInfo
case "warn", "warning":
logLevelVar = slog.LevelWarn
case "error":
logLevelVar = slog.LevelError
default:
fmt.Printf("Invalid log level: %s. Using 'info' instead.\n", *logLevel)
logLevelVar = slog.LevelInfo
}
// Initialize structured logger with configurable level
logger := slog.New(slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{
AddSource: true,
Level: logLevelVar,
}))
// Log startup information
logger.Info("Starting S3 Browser",
slog.String("port", *port),
slog.String("log_level", logLevelVar.String()),
)
// Create server
srv := server.New(logger, frontendFS)
// Create context that listens for the interrupt signal from the OS
ctx, stop := signal.NotifyContext(context.Background(), os.Interrupt, syscall.SIGTERM)
defer stop()
// Determine server address
serverAddr := ":" + *port
// Environment variable takes precedence over flag for compatibility
if envPort := os.Getenv("PORT"); envPort != "" {
serverAddr = ":" + envPort
logger.Info("Using PORT environment variable", slog.String("port", envPort))
}
if err := srv.Start(ctx, serverAddr); err != nil && err != context.Canceled {
logger.Error("Failed to start server", slog.String("error", err.Error()))
os.Exit(1)
}
logger.Info("Application terminated")
}