linstrom/main.go

131 lines
3.4 KiB
Go
Raw Normal View History

2024-09-13 13:02:32 +00:00
// TODO: Add EUPL banner everywhere
2024-08-28 15:20:38 +00:00
package main
import (
"embed"
2024-09-12 06:56:57 +00:00
"io"
2024-08-28 15:20:38 +00:00
"os"
"strings"
"time"
2024-08-28 15:20:38 +00:00
"github.com/go-webauthn/webauthn/webauthn"
"github.com/mstarongithub/passkey"
2024-08-28 15:20:38 +00:00
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
2024-12-18 14:24:56 +00:00
// "git.mstar.dev/mstar/linstrom/ap"
"git.mstar.dev/mstar/linstrom/config"
"git.mstar.dev/mstar/linstrom/server"
"git.mstar.dev/mstar/linstrom/storage"
"git.mstar.dev/mstar/linstrom/storage/cache"
"git.mstar.dev/mstar/linstrom/util"
2024-08-28 15:20:38 +00:00
)
//go:embed frontend-reactive/dist/* frontend-reactive/dist/assets
var reactiveFS embed.FS
//go:embed frontend-noscript
var nojsFS embed.FS
//go:embed duck.webp
var placeholderFile string
2024-08-28 15:20:38 +00:00
func main() {
2024-09-12 06:56:57 +00:00
setLogger()
2024-08-28 15:20:38 +00:00
setLogLevel()
if err := config.ReadAndWriteToGlobal(*flagConfigFile); err != nil {
log.Fatal().
Err(err).
Str("config-file", *flagConfigFile).
Msg("Failed to read config and couldn't write default")
}
// Request to only check config
if *flagConfigOnly {
return
}
2024-09-12 06:56:57 +00:00
storageCache, err := cache.NewCache(
config.GlobalConfig.Storage.MaxInMemoryCacheSize,
config.GlobalConfig.Storage.RedisUrl,
)
if err != nil {
log.Fatal().Err(err).Msg("Failed to start cache")
}
2024-09-15 13:18:05 +00:00
2024-09-16 15:42:16 +00:00
// var store *storage.Storage
// if config.GlobalConfig.Storage.DbIsPostgres != nil && *config.GlobalConfig.Storage.DbIsPostgres {
// store, err = storage.NewStoragePostgres(config.GlobalConfig.Storage.DatabaseUrl, storageCache)
// } else {
// store, err = storage.NewStorageSqlite(config.GlobalConfig.Storage.DatabaseUrl, storageCache)
// }
//
2024-09-15 13:18:05 +00:00
store, err := storage.NewStorage(config.GlobalConfig.Storage.BuildPostgresDSN(), storageCache)
2024-09-12 06:56:57 +00:00
if err != nil {
log.Fatal().Err(err).Msg("Failed to setup storage")
}
pkey, err := passkey.New(passkey.Config{
WebauthnConfig: &webauthn.Config{
RPDisplayName: "Linstrom",
RPID: "localhost",
RPOrigins: []string{"http://localhost:8000"},
},
UserStore: store,
SessionStore: store,
SessionMaxAge: time.Hour * 24,
}, passkey.WithLogger(&util.ZerologWrapper{}))
if err != nil {
log.Fatal().Err(err).Msg("Failed to setup passkey support")
}
server := server.NewServer(
store,
pkey,
util.NewFSWrapper(reactiveFS, "frontend-reactive/dist/", false),
util.NewFSWrapper(nojsFS, "frontend-noscript/", false),
&placeholderFile,
)
server.Start(":8000")
2024-09-13 13:02:32 +00:00
// TODO: Set up media server
2024-09-15 13:18:05 +00:00
// TODO: Set up queues
2024-09-13 13:02:32 +00:00
// TODO: Set up http server
// TODO: Set up plugins
// TODO: Start everything
2024-08-28 15:20:38 +00:00
}
func setLogLevel() {
log.Info().Str("new-level", *flagLogLevel).Msg("Attempting to set log level")
switch strings.ToLower(*flagLogLevel) {
case "trace":
zerolog.SetGlobalLevel(zerolog.TraceLevel)
case "debug":
zerolog.SetGlobalLevel(zerolog.DebugLevel)
case "info":
zerolog.SetGlobalLevel(zerolog.InfoLevel)
case "warn":
zerolog.SetGlobalLevel(zerolog.WarnLevel)
case "error":
zerolog.SetGlobalLevel(zerolog.ErrorLevel)
case "fatal":
zerolog.SetGlobalLevel(zerolog.FatalLevel)
default:
zerolog.SetGlobalLevel(zerolog.InfoLevel)
}
}
2024-09-12 06:56:57 +00:00
func setLogger(extraLogWriters ...io.Writer) {
if *flagPrettyPrint {
console := zerolog.ConsoleWriter{Out: os.Stderr}
log.Logger = zerolog.New(zerolog.MultiLevelWriter(append([]io.Writer{console}, extraLogWriters...)...)).
With().
Timestamp().
Logger()
} else {
log.Logger = zerolog.New(zerolog.MultiLevelWriter(
append([]io.Writer{log.Logger}, extraLogWriters...)...,
)).With().Timestamp().Logger()
}
}