123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- // Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
- //
- // This Source Code Form is subject to the terms of the MIT License.
- // If a copy of the MIT was not distributed with this file,
- // You can obtain one at https://github.com/gogf/gf.
- // Package gcfg provides reading, caching and managing for configuration.
- package gcfg
- import (
- "context"
- "github.com/gogf/gf/v2/container/gvar"
- "github.com/gogf/gf/v2/errors/gcode"
- "github.com/gogf/gf/v2/errors/gerror"
- "github.com/gogf/gf/v2/internal/command"
- "github.com/gogf/gf/v2/internal/intlog"
- "github.com/gogf/gf/v2/internal/utils"
- "github.com/gogf/gf/v2/os/genv"
- )
- // Config is the configuration management object.
- type Config struct {
- adapter Adapter
- }
- const (
- DefaultInstanceName = "config" // DefaultName is the default instance name for instance usage.
- DefaultConfigFileName = "config" // DefaultConfigFile is the default configuration file name.
- )
- // New creates and returns a Config object with default adapter of AdapterFile.
- func New() (*Config, error) {
- adapterFile, err := NewAdapterFile()
- if err != nil {
- return nil, err
- }
- return &Config{
- adapter: adapterFile,
- }, nil
- }
- // NewWithAdapter creates and returns a Config object with given adapter.
- func NewWithAdapter(adapter Adapter) *Config {
- return &Config{
- adapter: adapter,
- }
- }
- // Instance returns an instance of Config with default settings.
- // The parameter `name` is the name for the instance. But very note that, if the file "name.toml"
- // exists in the configuration directory, it then sets it as the default configuration file. The
- // toml file type is the default configuration file type.
- func Instance(name ...string) *Config {
- var instanceName = DefaultInstanceName
- if len(name) > 0 && name[0] != "" {
- instanceName = name[0]
- }
- return localInstances.GetOrSetFuncLock(instanceName, func() interface{} {
- adapterFile, err := NewAdapterFile()
- if err != nil {
- intlog.Errorf(context.Background(), `%+v`, err)
- return nil
- }
- if instanceName != DefaultInstanceName {
- adapterFile.SetFileName(instanceName)
- }
- return NewWithAdapter(adapterFile)
- }).(*Config)
- }
- // SetAdapter sets the adapter of current Config object.
- func (c *Config) SetAdapter(adapter Adapter) {
- c.adapter = adapter
- }
- // GetAdapter returns the adapter of current Config object.
- func (c *Config) GetAdapter() Adapter {
- return c.adapter
- }
- // Available checks and returns the configuration service is available.
- // The optional parameter `pattern` specifies certain configuration resource.
- //
- // It returns true if configuration file is present in default AdapterFile, or else false.
- // Note that this function does not return error as it just does simply check for backend configuration service.
- func (c *Config) Available(ctx context.Context, resource ...string) (ok bool) {
- return c.adapter.Available(ctx, resource...)
- }
- // Get retrieves and returns value by specified `pattern`.
- // It returns all values of current Json object if `pattern` is given empty or string ".".
- // It returns nil if no value found by `pattern`.
- //
- // It returns a default value specified by `def` if value for `pattern` is not found.
- func (c *Config) Get(ctx context.Context, pattern string, def ...interface{}) (*gvar.Var, error) {
- var (
- err error
- value interface{}
- )
- value, err = c.adapter.Get(ctx, pattern)
- if err != nil {
- return nil, err
- }
- if value == nil {
- if len(def) > 0 {
- return gvar.New(def[0]), nil
- }
- return nil, nil
- }
- return gvar.New(value), nil
- }
- // GetWithEnv returns the configuration value specified by pattern `pattern`.
- // If the configuration value does not exist, then it retrieves and returns the environment value specified by `key`.
- // It returns the default value `def` if none of them exists.
- //
- // Fetching Rules: Environment arguments are in uppercase format, eg: GF_PACKAGE_VARIABLE.
- func (c *Config) GetWithEnv(ctx context.Context, pattern string, def ...interface{}) (*gvar.Var, error) {
- value, err := c.Get(ctx, pattern)
- if err != nil && gerror.Code(err) != gcode.CodeNotFound {
- return nil, err
- }
- if value == nil {
- if v := genv.Get(utils.FormatEnvKey(pattern)); v != nil {
- return v, nil
- }
- if len(def) > 0 {
- return gvar.New(def[0]), nil
- }
- return nil, nil
- }
- return value, nil
- }
- // GetWithCmd returns the configuration value specified by pattern `pattern`.
- // If the configuration value does not exist, then it retrieves and returns the command line option specified by `key`.
- // It returns the default value `def` if none of them exists.
- //
- // Fetching Rules: Command line arguments are in lowercase format, eg: gf.package.variable.
- func (c *Config) GetWithCmd(ctx context.Context, pattern string, def ...interface{}) (*gvar.Var, error) {
- value, err := c.Get(ctx, pattern)
- if err != nil && gerror.Code(err) != gcode.CodeNotFound {
- return nil, err
- }
- if value == nil {
- if v := command.GetOpt(utils.FormatCmdKey(pattern)); v != "" {
- return gvar.New(v), nil
- }
- if len(def) > 0 {
- return gvar.New(def[0]), nil
- }
- return nil, nil
- }
- return value, nil
- }
- // Data retrieves and returns all configuration data as map type.
- func (c *Config) Data(ctx context.Context) (data map[string]interface{}, err error) {
- return c.adapter.Data(ctx)
- }
- // MustGet acts as function Get, but it panics if error occurs.
- func (c *Config) MustGet(ctx context.Context, pattern string, def ...interface{}) *gvar.Var {
- v, err := c.Get(ctx, pattern, def...)
- if err != nil {
- panic(err)
- }
- if v == nil {
- return nil
- }
- return v
- }
- // MustGetWithEnv acts as function GetWithEnv, but it panics if error occurs.
- func (c *Config) MustGetWithEnv(ctx context.Context, pattern string, def ...interface{}) *gvar.Var {
- v, err := c.GetWithEnv(ctx, pattern, def...)
- if err != nil {
- panic(err)
- }
- return v
- }
- // MustGetWithCmd acts as function GetWithCmd, but it panics if error occurs.
- func (c *Config) MustGetWithCmd(ctx context.Context, pattern string, def ...interface{}) *gvar.Var {
- v, err := c.GetWithCmd(ctx, pattern, def...)
- if err != nil {
- panic(err)
- }
- return v
- }
- // MustData acts as function Data, but it panics if error occurs.
- func (c *Config) MustData(ctx context.Context) map[string]interface{} {
- v, err := c.Data(ctx)
- if err != nil {
- panic(err)
- }
- return v
- }
|