mirror of
https://github.com/nabbar/golib.git
synced 2025-10-21 14:59:35 +08:00

- use lib nutsdb (https://github.com/xujiajun/nutsdb) - implement client to use embedded db cluster - convert nutsdb lib as clustered nutsdb with lib cluster (based on dragonboat) - implement disk backend lib for dragonboat - add complete config with nutsdb, node & cluster with validator
108 lines
3.2 KiB
Go
108 lines
3.2 KiB
Go
/***********************************************************************************************************************
|
|
*
|
|
* MIT License
|
|
*
|
|
* Copyright (c) 2021 Nicolas JUHEL
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*
|
|
*
|
|
**********************************************************************************************************************/
|
|
|
|
package nutsdb
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/go-playground/validator/v10"
|
|
"github.com/nabbar/golib/cluster"
|
|
liberr "github.com/nabbar/golib/errors"
|
|
"github.com/xujiajun/nutsdb"
|
|
)
|
|
|
|
type Config struct {
|
|
DB NutsDBOptions `mapstructure:"db" json:"db" yaml:"db" toml:"db"`
|
|
Cluster cluster.Config `mapstructure:"cluster" json:"cluster" yaml:"cluster" toml:"cluster"`
|
|
Directory NutsDBFolder `mapstructure:"directories" json:"directories" yaml:"directories" toml:"directories" `
|
|
}
|
|
|
|
func (c Config) GetConfigFolder() NutsDBFolder {
|
|
return c.Directory
|
|
}
|
|
|
|
func (c Config) GetConfigDB() (nutsdb.Options, liberr.Error) {
|
|
if dir, err := c.Directory.GetDirectoryData(); err != nil {
|
|
return nutsdb.Options{}, err
|
|
} else {
|
|
return c.DB.GetNutsDBOptions(dir), nil
|
|
}
|
|
}
|
|
|
|
func (c Config) GetConfigCluster() (cluster.Config, liberr.Error) {
|
|
cfg := c.Cluster
|
|
|
|
if dir, err := c.Directory.GetDirectoryWal(); err != nil {
|
|
return cfg, err
|
|
} else {
|
|
cfg.Node.WALDir = dir
|
|
}
|
|
|
|
if dir, err := c.Directory.GetDirectoryHost(); err != nil {
|
|
return cfg, err
|
|
} else {
|
|
cfg.Node.NodeHostDir = dir
|
|
}
|
|
|
|
return cfg, nil
|
|
}
|
|
|
|
func (c Config) GetOptions() (Options, liberr.Error) {
|
|
return NewOptions(c.DB, c.Directory)
|
|
}
|
|
|
|
func (c Config) Validate() liberr.Error {
|
|
val := validator.New()
|
|
err := val.Struct(c)
|
|
|
|
if e, ok := err.(*validator.InvalidValidationError); ok {
|
|
return ErrorValidateConfig.ErrorParent(e)
|
|
}
|
|
|
|
out := ErrorValidateConfig.Error(nil)
|
|
|
|
for _, e := range err.(validator.ValidationErrors) {
|
|
//nolint goerr113
|
|
out.AddParent(fmt.Errorf("config field '%s' is not validated by constraint '%s'", e.Field(), e.ActualTag()))
|
|
}
|
|
|
|
if out.HasParent() {
|
|
return out
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c Config) ValidateDB() liberr.Error {
|
|
return c.DB.Validate()
|
|
}
|
|
|
|
func (c Config) ValidateCluster() liberr.Error {
|
|
return c.Cluster.Validate()
|
|
}
|