dispatch/commands/dispatch.go

147 lines
3.9 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"))
err := initConfig(storage.Path.Config(), viper.GetBool("reset-config"))
if err != nil {
log.Fatal(err)
}
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()
storage.GetMessageStore = func(user *storage.User) (storage.MessageStore, error) {
return boltdb.New(storage.Path.Log(user.Username))
}
storage.GetMessageSearchProvider = func(user *storage.User) (storage.MessageSearchProvider, error) {
return bleve.New(storage.Path.Index(user.Username))
}
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.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
2020-06-16 09:26:07 +00:00
viper.SetDefault("identd", true)
2020-06-15 23:22:23 +00:00
viper.SetDefault("auto_ctcp", true)
2018-12-11 09:51:20 +00:00
viper.SetDefault("verify_certificates", true)
2020-06-16 01:04:27 +00:00
2020-05-20 05:21:12 +00:00
viper.SetDefault("https.enabled", true)
viper.SetDefault("https.port", 443)
2020-06-16 01:04:27 +00:00
2020-05-20 05:21:12 +00:00
viper.SetDefault("auth.anonymous", true)
viper.SetDefault("auth.login", true)
viper.SetDefault("auth.registration", true)
2020-06-16 01:04:27 +00:00
2020-05-20 05:21:12 +00:00
viper.SetDefault("dcc.enabled", true)
viper.SetDefault("dcc.autoget.delete", true)
2020-06-16 01:04:27 +00:00
viper.SetDefault("proxy.protocol", "socks5")
viper.SetDefault("proxy.host", "127.0.0.1")
viper.SetDefault("proxy.port", 1080)
}
func initConfig(configPath string, overwrite bool) error {
2018-04-14 23:25:21 +00:00
if _, err := os.Stat(configPath); overwrite || os.IsNotExist(err) {
config, err := assets.Asset("config.default.toml")
if err != nil {
return err
}
2016-01-04 18:26:32 +00:00
log.Println("Writing default config to", configPath)
return ioutil.WriteFile(configPath, config, 0600)
}
return nil
}