global.go (1814B)
1 // GoToSocial 2 // Copyright (C) GoToSocial Authors admin@gotosocial.org 3 // SPDX-License-Identifier: AGPL-3.0-or-later 4 // 5 // This program is free software: you can redistribute it and/or modify 6 // it under the terms of the GNU Affero General Public License as published by 7 // the Free Software Foundation, either version 3 of the License, or 8 // (at your option) any later version. 9 // 10 // This program is distributed in the hope that it will be useful, 11 // but WITHOUT ANY WARRANTY; without even the implied warranty of 12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 // GNU Affero General Public License for more details. 14 // 15 // You should have received a copy of the GNU Affero General Public License 16 // along with this program. If not, see <http://www.gnu.org/licenses/>. 17 18 package config 19 20 import ( 21 "github.com/spf13/cobra" 22 ) 23 24 var global *ConfigState 25 26 func init() { 27 // init global state 28 global = NewState() 29 } 30 31 // TODO: in the future we should move away from using globals in this config 32 // package, and instead pass the ConfigState round in a global gts state. 33 34 // Config provides you safe access to the global configuration. 35 func Config(fn func(cfg *Configuration)) { 36 global.Config(fn) 37 } 38 39 // Reload will reload the current configuration values from file. 40 func Reload() error { 41 return global.Reload() 42 } 43 44 // LoadEarlyFlags will bind specific flags from given Cobra command to global viper 45 // instance, and load the current configuration values. This is useful for flags like 46 // .ConfigPath which have to parsed first in order to perform early configuration load. 47 func LoadEarlyFlags(cmd *cobra.Command) error { 48 return global.LoadEarlyFlags(cmd) 49 } 50 51 // BindFlags binds given command's pflags to the global viper instance. 52 func BindFlags(cmd *cobra.Command) error { 53 return global.BindFlags(cmd) 54 }