mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-24 22:08:58 -05:00
So far Phoenix have been embedded into the binary and we can customize the required config based on flags, env variables and optionally via config file. For now I'm embedding the whole Phonix content, optherwise the all-in-one binary `ocis` will get pretty complicated until we add the generate commands to that repo as well and provide a mechanism to inject the embedding.
171 lines
5.0 KiB
Go
171 lines
5.0 KiB
Go
package command
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"os"
|
|
"os/signal"
|
|
"time"
|
|
|
|
"github.com/oklog/run"
|
|
"github.com/owncloud/ocis-phoenix/pkg/router/debug"
|
|
"github.com/owncloud/ocis-phoenix/pkg/router/server"
|
|
"github.com/rs/zerolog/log"
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
)
|
|
|
|
// Server is the entrypoint for the server command.
|
|
func Server() *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "server",
|
|
Short: "Start integrated server",
|
|
Long: "",
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
var gr run.Group
|
|
|
|
{
|
|
server := &http.Server{
|
|
Addr: viper.GetString("debug.addr"),
|
|
Handler: debug.Router(
|
|
debug.WithToken(viper.GetString("debug.token")),
|
|
debug.WithPprof(viper.GetBool("debug.pprof")),
|
|
),
|
|
ReadTimeout: 5 * time.Second,
|
|
WriteTimeout: 10 * time.Second,
|
|
}
|
|
|
|
gr.Add(func() error {
|
|
log.Info().
|
|
Str("addr", viper.GetString("debug.addr")).
|
|
Msg("Starting debug server")
|
|
|
|
return server.ListenAndServe()
|
|
}, func(reason error) {
|
|
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
|
defer cancel()
|
|
|
|
if err := server.Shutdown(ctx); err != nil {
|
|
log.Error().
|
|
Err(err).
|
|
Msg("Failed to shutdown debug server gracefully")
|
|
|
|
return
|
|
}
|
|
|
|
log.Info().
|
|
Err(reason).
|
|
Msg("Shutdown debug server gracefully")
|
|
})
|
|
}
|
|
|
|
{
|
|
server := &http.Server{
|
|
Addr: viper.GetString("http.addr"),
|
|
Handler: server.Router(
|
|
server.WithRoot(viper.GetString("http.root")),
|
|
server.WithPath(viper.GetString("asset.path")),
|
|
server.WithCustom(viper.GetString("config.custom")),
|
|
server.WithServer(viper.GetString("config.server")),
|
|
server.WithTheme(viper.GetString("config.theme")),
|
|
server.WithVersion(viper.GetString("config.version")),
|
|
server.WithClient(viper.GetString("config.client")),
|
|
server.WithApps(viper.GetStringSlice("config.apps")),
|
|
),
|
|
ReadTimeout: 5 * time.Second,
|
|
WriteTimeout: 10 * time.Second,
|
|
}
|
|
|
|
gr.Add(func() error {
|
|
log.Info().
|
|
Str("addr", viper.GetString("http.addr")).
|
|
Msg("Starting http server")
|
|
|
|
return server.ListenAndServe()
|
|
}, func(reason error) {
|
|
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
|
defer cancel()
|
|
|
|
if err := server.Shutdown(ctx); err != nil {
|
|
log.Error().
|
|
Err(err).
|
|
Msg("Failed to shutdown http server gracefully")
|
|
|
|
return
|
|
}
|
|
|
|
log.Info().
|
|
Err(reason).
|
|
Msg("Shutdown http server gracefully")
|
|
})
|
|
}
|
|
|
|
{
|
|
stop := make(chan os.Signal, 1)
|
|
|
|
gr.Add(func() error {
|
|
signal.Notify(stop, os.Interrupt)
|
|
|
|
<-stop
|
|
|
|
return nil
|
|
}, func(err error) {
|
|
close(stop)
|
|
})
|
|
}
|
|
|
|
return gr.Run()
|
|
},
|
|
}
|
|
|
|
cmd.Flags().String("debug-addr", "", "Address to bind debug server")
|
|
viper.BindPFlag("debug.addr", cmd.Flags().Lookup("debug-addr"))
|
|
viper.BindEnv("debug.addr", "PHOENIX_DEBUG_ADDR")
|
|
|
|
cmd.Flags().String("debug-token", "", "Token to grant metrics access")
|
|
viper.BindPFlag("debug.token", cmd.Flags().Lookup("debug-token"))
|
|
viper.BindEnv("debug.token", "PHOENIX_DEBUG_TOKEN")
|
|
|
|
cmd.Flags().Bool("debug-pprof", false, "Enable pprof debugging")
|
|
viper.BindPFlag("debug.pprof", cmd.Flags().Lookup("debug-pprof"))
|
|
viper.BindEnv("debug.pprof", "PHOENIX_DEBUG_PPROF")
|
|
|
|
cmd.Flags().String("http-addr", "", "Address to bind http server")
|
|
viper.BindPFlag("http.addr", cmd.Flags().Lookup("http-addr"))
|
|
viper.BindEnv("http.addr", "PHOENIX_HTTP_ADDR")
|
|
|
|
cmd.Flags().String("http-root", "", "Root path for http endpoint")
|
|
viper.BindPFlag("http.root", cmd.Flags().Lookup("http-root"))
|
|
viper.BindEnv("http.root", "PHOENIX_HTTP_ROOT")
|
|
|
|
cmd.Flags().String("asset-path", "", "Path to custom assets")
|
|
viper.BindPFlag("asset.path", cmd.Flags().Lookup("asset-path"))
|
|
viper.BindEnv("asset.path", "PHOENIX_ASSET_PATH")
|
|
|
|
cmd.Flags().String("config-custom", "", "Path to custom config")
|
|
viper.BindPFlag("config.custom", cmd.Flags().Lookup("config-custom"))
|
|
viper.BindEnv("config.custom", "PHOENIX_CONFIG_CUSTOM")
|
|
|
|
cmd.Flags().String("config-server", "", "URL to ownCloud server")
|
|
viper.BindPFlag("config.server", cmd.Flags().Lookup("config-server"))
|
|
viper.BindEnv("config.server", "PHOENIX_CONFIG_SERVER")
|
|
|
|
cmd.Flags().String("config-theme", "", "The to use with Phoenix")
|
|
viper.BindPFlag("config.theme", cmd.Flags().Lookup("config-theme"))
|
|
viper.BindEnv("config.theme", "PHOENIX_CONFIG_THEME")
|
|
|
|
cmd.Flags().String("config-version", "", "Config version for Phoenix")
|
|
viper.BindPFlag("config.version", cmd.Flags().Lookup("config-version"))
|
|
viper.BindEnv("config.version", "PHOENIX_CONFIG_VERSION")
|
|
|
|
cmd.Flags().String("config-client", "", "Client ID used for OAuth2")
|
|
viper.BindPFlag("config.client", cmd.Flags().Lookup("config-client"))
|
|
viper.BindEnv("config.client", "PHOENIX_CONFIG_CLIENT")
|
|
|
|
cmd.Flags().StringSlice("config-apps", []string{}, "List of enabled apps")
|
|
viper.BindPFlag("config.apps", cmd.Flags().Lookup("config-apps"))
|
|
viper.BindEnv("config.apps", "PHOENIX_CONFIG_APPS")
|
|
|
|
return cmd
|
|
}
|