dispatch/commands/dispatch.go

132 lines
3.5 KiB
Go
Raw Normal View History

package commands
import (
2016-01-04 18:26:32 +00:00
"fmt"
"io/ioutil"
"log"
"os"
2018-12-15 10:30:29 +00:00
"runtime"
2015-12-11 03:35:48 +00:00
"github.com/khlieng/dispatch/assets"
2018-12-11 09:51:20 +00:00
"github.com/khlieng/dispatch/config"
2015-12-11 03:35:48 +00:00
"github.com/khlieng/dispatch/server"
"github.com/khlieng/dispatch/storage"
"github.com/khlieng/dispatch/storage/bleve"
"github.com/khlieng/dispatch/storage/boltdb"
2018-11-22 10:31:02 +00:00
"github.com/khlieng/dispatch/version"
2018-11-11 06:08:53 +00:00
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
2016-01-04 18:26:32 +00:00
const logo = `
____ _ _ _
| _ \ (_) ___ _ __ __ _ | |_ ___ | |__
| | | || |/ __|| '_ \ / _ || __|/ __|| '_ \
| |_| || |\__ \| |_) || (_| || |_| (__ | | | |
|____/ |_||___/| .__/ \__,_| \__|\___||_| |_|
|_|
2018-11-16 04:17:20 +00:00
%s
Commit: %s
Build Date: %s
2018-12-15 10:30:29 +00:00
Runtime: %s
2018-11-16 04:17:20 +00:00
2016-01-04 18:26:32 +00:00
`
var rootCmd = &cobra.Command{
Use: "dispatch",
Short: "Web-based IRC client in Go.",
PersistentPreRun: func(cmd *cobra.Command, args []string) {
2018-12-11 09:51:20 +00:00
if viper.GetBool("version") {
printVersion()
os.Exit(0)
}
2018-12-11 09:51:20 +00:00
if cmd == cmd.Root() {
2018-12-15 10:30:29 +00:00
fmt.Printf(logo, version.Tag, version.Commit, version.Date, runtime.Version())
2016-01-04 18:26:32 +00:00
}
2020-04-20 01:02:15 +00:00
storage.Initialize(viper.GetString("dir"), viper.GetString("data"), viper.GetString("conf"))
2020-04-20 01:02:15 +00:00
initConfig(storage.Path.Config(), viper.GetBool("reset-config"))
2016-01-04 18:26:32 +00:00
},
2016-01-07 22:59:38 +00:00
Run: func(cmd *cobra.Command, args []string) {
if viper.GetBool("dev") {
log.Println("Running in development mode, access client at http://localhost:3000")
}
2020-04-20 01:02:15 +00:00
log.Println("Storing data at", storage.Path.DataRoot())
2016-01-07 22:59:38 +00:00
2020-04-20 01:02:15 +00:00
db, err := boltdb.New(storage.Path.Database())
if err != nil {
log.Fatal(err)
}
defer db.Close()
2018-12-11 09:51:20 +00:00
cfg, cfgUpdated := config.LoadConfig()
dispatch := server.New(cfg)
go func() {
for {
dispatch.SetConfig(<-cfgUpdated)
log.Println("New config loaded")
}
}()
dispatch.Store = db
dispatch.SessionStore = db
dispatch.GetMessageStore = func(user *storage.User) (storage.MessageStore, error) {
2020-04-20 01:02:15 +00:00
return boltdb.New(storage.Path.Log(user.Username))
2018-12-11 09:51:20 +00:00
}
2018-12-11 09:51:20 +00:00
dispatch.GetMessageSearchProvider = func(user *storage.User) (storage.MessageSearchProvider, error) {
2020-04-20 01:02:15 +00:00
return bleve.New(storage.Path.Index(user.Username))
}
2018-12-11 09:51:20 +00:00
dispatch.Run()
2016-01-07 22:59:38 +00:00
},
2016-01-04 18:26:32 +00:00
}
2016-01-04 18:26:32 +00:00
func Execute() {
rootCmd.Execute()
}
func init() {
rootCmd.AddCommand(clearCmd)
rootCmd.AddCommand(configCmd)
rootCmd.AddCommand(versionCmd)
rootCmd.PersistentFlags().String("data", storage.DefaultDirectory(), "directory to store data in")
rootCmd.PersistentFlags().String("conf", storage.DefaultDirectory(), "directory to store configuration in")
2016-01-04 18:26:32 +00:00
rootCmd.PersistentFlags().String("dir", storage.DefaultDirectory(), "directory to store config and data in")
2018-04-14 23:25:21 +00:00
rootCmd.PersistentFlags().Bool("reset-config", false, "reset to the default configuration, overwriting the current one")
rootCmd.Flags().StringP("address", "a", "", "interface to which the server will bind")
rootCmd.Flags().IntP("port", "p", 80, "port to listen on")
rootCmd.Flags().Bool("dev", false, "development mode")
rootCmd.Flags().BoolP("version", "v", false, "show version")
2018-12-11 09:51:20 +00:00
viper.BindPFlags(rootCmd.PersistentFlags())
viper.BindPFlags(rootCmd.Flags())
2016-01-14 05:35:26 +00:00
viper.SetDefault("hexIP", false)
2018-12-11 09:51:20 +00:00
viper.SetDefault("verify_certificates", true)
}
2018-04-14 23:25:21 +00:00
func initConfig(configPath string, overwrite bool) {
if _, err := os.Stat(configPath); overwrite || os.IsNotExist(err) {
config, err := assets.Asset("config.default.toml")
if err != nil {
log.Println(err)
return
}
2016-01-04 18:26:32 +00:00
log.Println("Writing default config to", configPath)
err = ioutil.WriteFile(configPath, config, 0600)
if err != nil {
log.Println(err)
}
}
}