2020-10-22 16:54:50 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
2021-03-17 14:09:10 +01:00
|
|
|
"time"
|
|
|
|
|
2020-10-22 16:54:50 +02:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
)
|
|
|
|
|
2020-11-01 18:39:12 +01:00
|
|
|
type Session struct {
|
2021-08-23 18:41:19 +02:00
|
|
|
ImplicitHosting bool
|
2021-11-01 17:49:02 +01:00
|
|
|
InactiveCursors bool
|
2021-08-23 18:41:19 +02:00
|
|
|
MercifulReconnect bool
|
|
|
|
APIToken string
|
2021-03-17 14:09:10 +01:00
|
|
|
|
2021-04-24 20:53:37 +02:00
|
|
|
CookieEnabled bool
|
2021-03-17 14:09:10 +01:00
|
|
|
CookieName string
|
|
|
|
CookieExpiration time.Time
|
|
|
|
CookieSecure bool
|
2020-10-22 16:54:50 +02:00
|
|
|
}
|
|
|
|
|
2020-11-01 18:39:12 +01:00
|
|
|
func (Session) Init(cmd *cobra.Command) error {
|
2021-03-16 15:24:58 +01:00
|
|
|
cmd.PersistentFlags().Bool("session.implicit_hosting", true, "allow implicit control switching")
|
|
|
|
if err := viper.BindPFlag("session.implicit_hosting", cmd.PersistentFlags().Lookup("session.implicit_hosting")); err != nil {
|
2020-12-02 11:24:20 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-11-01 21:35:15 +01:00
|
|
|
cmd.PersistentFlags().Bool("session.inactive_cursors", false, "show inactive cursors on the screen")
|
2021-11-01 17:49:02 +01:00
|
|
|
if err := viper.BindPFlag("session.inactive_cursors", cmd.PersistentFlags().Lookup("session.inactive_cursors")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-08-23 18:41:19 +02:00
|
|
|
cmd.PersistentFlags().Bool("session.merciful_reconnect", true, "allow reconnecting to websocket even if previous connection was not closed")
|
|
|
|
if err := viper.BindPFlag("session.merciful_reconnect", cmd.PersistentFlags().Lookup("session.merciful_reconnect")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-03-16 15:24:58 +01:00
|
|
|
cmd.PersistentFlags().String("session.api_token", "", "API token for interacting with external services")
|
|
|
|
if err := viper.BindPFlag("session.api_token", cmd.PersistentFlags().Lookup("session.api_token")); err != nil {
|
2021-03-15 13:34:14 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-03-17 14:09:10 +01:00
|
|
|
// cookie
|
2021-04-24 20:53:37 +02:00
|
|
|
cmd.PersistentFlags().Bool("session.cookie.enabled", true, "whether cookies authentication should be enabled")
|
|
|
|
if err := viper.BindPFlag("session.cookie.enabled", cmd.PersistentFlags().Lookup("session.cookie.enabled")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-03-17 14:09:10 +01:00
|
|
|
cmd.PersistentFlags().String("session.cookie.name", "NEKO_SESSION", "name of the cookie that holds token")
|
|
|
|
if err := viper.BindPFlag("session.cookie.name", cmd.PersistentFlags().Lookup("session.cookie.name")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd.PersistentFlags().Int("session.cookie.expiration", 365*24, "expiration of the cookie in hours")
|
|
|
|
if err := viper.BindPFlag("session.cookie.expiration", cmd.PersistentFlags().Lookup("session.cookie.expiration")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd.PersistentFlags().Bool("session.cookie.secure", true, "use secure cookies")
|
|
|
|
if err := viper.BindPFlag("session.cookie.secure", cmd.PersistentFlags().Lookup("session.cookie.secure")); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-10-22 16:54:50 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-11-01 18:39:12 +01:00
|
|
|
func (s *Session) Set() {
|
2021-03-16 15:24:58 +01:00
|
|
|
s.ImplicitHosting = viper.GetBool("session.implicit_hosting")
|
2021-11-01 17:49:02 +01:00
|
|
|
s.InactiveCursors = viper.GetBool("session.inactive_cursors")
|
2021-08-23 18:41:19 +02:00
|
|
|
s.MercifulReconnect = viper.GetBool("session.merciful_reconnect")
|
2021-03-16 15:24:58 +01:00
|
|
|
s.APIToken = viper.GetString("session.api_token")
|
2021-03-17 14:09:10 +01:00
|
|
|
|
2021-04-24 20:53:37 +02:00
|
|
|
s.CookieEnabled = viper.GetBool("session.cookie.enabled")
|
2021-03-17 14:09:10 +01:00
|
|
|
s.CookieName = viper.GetString("session.cookie.name")
|
|
|
|
s.CookieExpiration = time.Now().Add(time.Duration(viper.GetInt("session.cookie.expiration")) * time.Hour)
|
|
|
|
s.CookieSecure = viper.GetBool("session.cookie.secure")
|
2020-10-22 16:54:50 +02:00
|
|
|
}
|