diff options
author | Runxi Yu <me@runxiyu.org> | 2025-01-13 12:25:46 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-01-13 12:25:46 +0800 |
commit | 8724c4b8935aceefdc3cea4e82dfba7d28a36cc6 (patch) | |
tree | 3712dbd26f69cea86f85f07751b49d172f6f833c /config.go | |
parent | Close connections on QUIT (diff) | |
download | maild-8724c4b8935aceefdc3cea4e82dfba7d28a36cc6.tar.gz maild-8724c4b8935aceefdc3cea4e82dfba7d28a36cc6.tar.zst maild-8724c4b8935aceefdc3cea4e82dfba7d28a36cc6.zip |
Bug fixes
Diffstat (limited to 'config.go')
-rw-r--r-- | config.go | 13 |
1 files changed, 8 insertions, 5 deletions
@@ -22,14 +22,16 @@ var config struct { Conn string `scfg:"conn"` } `scfg:"db"` MX struct { - Net string `scfg:"net"` + Net string `scfg:"net"` Addr string `scfg:"addr"` } `scfg:"mx"` _tls_config *tls.Config } var ( - config_mutex sync.RWMutex // covers things like the database too - global_db *pgxpool.Pool // only call Close() after replacing this global variable + config_mutex sync.RWMutex // covers things like the database too + config_context context.Context + config_context_cancel context.CancelFunc + global_db *pgxpool.Pool // only call Close() after replacing this global variable ) // load_config loads the configuration file and sets up global things according @@ -47,6 +49,7 @@ func load_config(path string) error { if err != nil { return err } + config_context, config_context_cancel = context.WithCancel(context.Background()) // TLS key loading and TLS config creation cer, err := tls.LoadX509KeyPair(config.TLS.Cert, config.TLS.Key) @@ -62,7 +65,7 @@ func load_config(path string) error { if config.DB.Type != "postgres" { return err_unsupported_database_type } - global_db, err = pgxpool.New(context.Background(), config.DB.Conn) + global_db, err = pgxpool.New(config_context, config.DB.Conn) // BUG: Context-related leak: cancel context when the config is invalidated if err != nil { return err @@ -77,7 +80,7 @@ func load_config(path string) error { // config_fetch_one fetches one value from the configuration. // -// Consequtive calls do not guarantee a consistent snapshot of the +// Consecutive calls do not guarantee a consistent snapshot of the // configuration. Use config_consistent_run in these cases. func config_fetch_one[T any](x *T) T { config_mutex.RLock() |