2
2
mirror of https://github.com/m1k1o/neko.git synced 2024-07-24 14:40:50 +12:00

77 lines
2.5 KiB
Go
Raw Normal View History

2020-01-18 23:30:09 +00:00
package config
import (
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
type WebSocket struct {
Password string
AdminPassword string
2020-04-06 20:14:30 +00:00
Proxy bool
2021-11-16 23:00:24 +01:00
Locks []string
2021-11-16 23:48:40 +01:00
ControlProtection bool
2022-10-30 21:06:05 -04:00
FileTransfer bool
UnprivFileTransfer bool
FileTransferPath string
2020-01-18 23:30:09 +00:00
}
func (WebSocket) Init(cmd *cobra.Command) error {
2020-01-29 01:27:59 +00:00
cmd.PersistentFlags().String("password", "neko", "password for connecting to stream")
2020-01-18 23:30:09 +00:00
if err := viper.BindPFlag("password", cmd.PersistentFlags().Lookup("password")); err != nil {
return err
}
2020-04-05 01:24:54 +00:00
cmd.PersistentFlags().String("password_admin", "admin", "admin password for connecting to stream")
if err := viper.BindPFlag("password_admin", cmd.PersistentFlags().Lookup("password_admin")); err != nil {
2020-01-18 23:30:09 +00:00
return err
}
2020-04-06 20:14:30 +00:00
cmd.PersistentFlags().Bool("proxy", false, "enable reverse proxy mode")
if err := viper.BindPFlag("proxy", cmd.PersistentFlags().Lookup("proxy")); err != nil {
return err
}
2021-11-16 23:00:24 +01:00
cmd.PersistentFlags().StringSlice("locks", []string{}, "resources, that will be locked when starting (control, login)")
if err := viper.BindPFlag("locks", cmd.PersistentFlags().Lookup("locks")); err != nil {
return err
}
cmd.PersistentFlags().Bool("control_protection", false, "control protection means, users can gain control only if at least one admin is in the room")
2021-11-16 23:48:40 +01:00
if err := viper.BindPFlag("control_protection", cmd.PersistentFlags().Lookup("control_protection")); err != nil {
return err
}
2022-10-30 21:06:05 -04:00
cmd.PersistentFlags().Bool("file_transfer", false, "allow file transfer for admins")
if err := viper.BindPFlag("file_transfer", cmd.PersistentFlags().Lookup("file_transfer")); err != nil {
return err
}
cmd.PersistentFlags().Bool("unpriv_file_transfer", false, "allow file transfer for non admins")
if err := viper.BindPFlag("unpriv_file_transfer", cmd.PersistentFlags().Lookup("unpriv_file_transfer")); err != nil {
return err
}
cmd.PersistentFlags().String("file_transfer_path", "/home/neko/Downloads", "path to use for file transfer")
if err := viper.BindPFlag("file_transfer_path", cmd.PersistentFlags().Lookup("file_transfer_path")); err != nil {
return err
}
2020-01-18 23:30:09 +00:00
return nil
}
func (s *WebSocket) Set() {
s.Password = viper.GetString("password")
2020-04-05 01:24:54 +00:00
s.AdminPassword = viper.GetString("password_admin")
2020-04-06 20:14:30 +00:00
s.Proxy = viper.GetBool("proxy")
2021-11-16 23:00:24 +01:00
s.Locks = viper.GetStringSlice("locks")
2021-11-16 23:48:40 +01:00
s.ControlProtection = viper.GetBool("control_protection")
2022-10-30 21:06:05 -04:00
s.FileTransfer = viper.GetBool("file_transfer")
s.UnprivFileTransfer = viper.GetBool("unpriv_file_transfer")
s.FileTransferPath = viper.GetString("file_transfer_path")
2020-01-18 23:30:09 +00:00
}