summaryrefslogtreecommitdiff
path: root/config
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2021-11-17 11:41:11 +0100
committerSimon Ser <contact@emersion.fr>2021-11-17 11:41:11 +0100
commit3941f67380ebd706cbb8f1c7a642d4222a7efd4f (patch)
tree57a5aabecfc7b3d89a0eb38161f2296b99dd211d /config
parent61e6b2efa4086d8f8c36acb4f8fb59a25b2b802d (diff)
Add config option to globally disable multi-upstream mode
Closes: https://todo.sr.ht/~emersion/soju/122
Diffstat (limited to 'config')
-rw-r--r--config/config.go12
1 files changed, 12 insertions, 0 deletions
diff --git a/config/config.go b/config/config.go
index 560b651..410d9c2 100644
--- a/config/config.go
+++ b/config/config.go
@@ -51,6 +51,7 @@ type Server struct {
AcceptProxyIPs IPSet
MaxUserNetworks int
+ MultiUpstream bool
}
func Defaults() *Server {
@@ -63,6 +64,7 @@ func Defaults() *Server {
SQLDriver: "sqlite3",
SQLSource: "soju.db",
MaxUserNetworks: -1,
+ MultiUpstream: true,
}
}
@@ -138,6 +140,16 @@ func parse(cfg scfg.Block) (*Server, error) {
if srv.MaxUserNetworks, err = strconv.Atoi(max); err != nil {
return nil, fmt.Errorf("directive %q: %v", d.Name, err)
}
+ case "multi-upstream-mode":
+ var str string
+ if err := d.ParseParams(&str); err != nil {
+ return nil, err
+ }
+ v, err := strconv.ParseBool(str)
+ if err != nil {
+ return nil, fmt.Errorf("directive %q: %v", d.Name, err)
+ }
+ srv.MultiUpstream = v
default:
return nil, fmt.Errorf("unknown directive %q", d.Name)
}