mirror of
https://github.com/nabbar/golib.git
synced 2025-09-26 20:01:15 +08:00

Package Monitoring : - use packag dedicated to monitor component - each monitor work as standalone server to monitor health - collect metrics to export them to prometheus exporter Package Prometheus : - review to simplify use for API and not API metrics - optimize code Package Status : - Rework to use Monitor package - Rework to use native json / text Marshaller interface Context : - rework context config (context var) to use sync map and sync RWMutex (WORM) - move gin context to dedicated sub package (dependancies of logger make circular dependencies) - optimize code Config : - rework to optimize sync / collect of component - rework status to monitor - remove monitor managment from config to each component - add a func to set default logger to implement inherit default logger options - optimize code IOUtils : - isolate logger / closer interface as a usable & public interface & instance - this interface / instance allow to collect io.closer over a context to close all if context is done Logger : - rework to use context.config map - rework to use ioutils closer - rework to allow options to inherit a default options, or the last version of options - optimize code Size : - Add package Size to calculate and manipulate size Byte or bit - Add encoding : Text/JSON/Yaml/Toml... - Add option to défine default unit : Byte or bit Other : - adjust following code - optimize code - limit use of atomic value - rework to use RWMutex instead of sync.Mutex to maximize capabilities of read instead of write - remove 32bit build for CI/CD - add darwin/arm64 build for CI/CD Bump Dependencies
166 lines
4.4 KiB
Go
166 lines
4.4 KiB
Go
/*
|
|
* MIT License
|
|
*
|
|
* Copyright (c) 2022 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 cobra
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"io"
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
|
|
"github.com/mitchellh/go-homedir"
|
|
liblog "github.com/nabbar/golib/logger"
|
|
"github.com/pelletier/go-toml"
|
|
spfcbr "github.com/spf13/cobra"
|
|
"gopkg.in/yaml.v3"
|
|
)
|
|
|
|
var cfgFile string
|
|
|
|
func (c *cobra) getDefaultPath(baseName string) (string, error) {
|
|
path := ""
|
|
|
|
// Find home directory.
|
|
home, err := homedir.Dir()
|
|
c.getLog().CheckError(liblog.WarnLevel, liblog.InfoLevel, "Loading home dir", err)
|
|
|
|
// set configname based on package name
|
|
if baseName == "" {
|
|
return "", fmt.Errorf("arguments missing: requires the destination file path")
|
|
}
|
|
|
|
path = filepath.Clean(home + string(filepath.Separator) + baseName + ".json")
|
|
|
|
if path == "." || path == ".json" {
|
|
return "", fmt.Errorf("arguments missing: requires the destination file path")
|
|
}
|
|
|
|
return path, nil
|
|
}
|
|
|
|
func (c *cobra) ConfigureCheckArgs(basename string, args []string) error {
|
|
if len(args) < 1 {
|
|
var err error
|
|
cfgFile, err = c.getDefaultPath(basename)
|
|
return err
|
|
} else if len(args) > 1 {
|
|
return fmt.Errorf("arguments error: too many file path specify")
|
|
} else {
|
|
cfgFile = args[0]
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c *cobra) ConfigureWriteConfig(basename string, defaultConfig func() io.Reader) error {
|
|
pkg := c.getPackageName()
|
|
|
|
if basename == "" && pkg != "" {
|
|
basename = "." + strings.ToLower(pkg)
|
|
}
|
|
|
|
var (
|
|
fs *os.File
|
|
)
|
|
|
|
defer func() {
|
|
if fs != nil {
|
|
_ = fs.Close()
|
|
}
|
|
}()
|
|
|
|
buf, err := ioutil.ReadAll(defaultConfig())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(filepath.Ext(cfgFile)) > 0 && strings.ToLower(filepath.Ext(cfgFile)) != ".json" {
|
|
var mod = make(map[string]interface{}, 0)
|
|
|
|
err = json.Unmarshal(buf, &mod)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
switch strings.ToLower(filepath.Ext(cfgFile)) {
|
|
case ".toml":
|
|
buf, err = toml.Marshal(mod)
|
|
case ".yml", ".yaml":
|
|
buf, err = yaml.Marshal(mod)
|
|
default:
|
|
return fmt.Errorf("extension file '%s' not compatible", filepath.Ext(cfgFile))
|
|
}
|
|
}
|
|
|
|
fs, err = os.OpenFile(cfgFile, os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0600)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = fs.Write(buf)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
err = os.Chmod(cfgFile, 0600)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
println(fmt.Sprintf("\n\t>> Config File '%s' has been created and file permission have been set.", cfgFile))
|
|
println("\t>> To explicitly specify this config file when you call this tool, use the '-c' flag like this: ")
|
|
println(fmt.Sprintf("\t\t\t %s -c %s <cmd>...\n", pkg, cfgFile))
|
|
return nil
|
|
}
|
|
|
|
func (c *cobra) AddCommandConfigure(basename string, defaultConfig func() io.Reader) {
|
|
pkg := c.getPackageName()
|
|
|
|
if basename == "" && pkg != "" {
|
|
basename = "." + strings.ToLower(pkg)
|
|
}
|
|
|
|
c.c.AddCommand(&spfcbr.Command{
|
|
Use: "configure <file path with valid extension (json, yaml, toml, ...) to be generated>",
|
|
Example: "configure ~/." + strings.ToLower(pkg) + ".yml",
|
|
Short: "Generate config file",
|
|
Long: `Generates a configuration file based on giving existing config flag
|
|
override by passed flag in command line and completed with default for non existing values.`,
|
|
|
|
RunE: func(cmd *spfcbr.Command, args []string) error {
|
|
return c.ConfigureWriteConfig(basename, defaultConfig)
|
|
},
|
|
|
|
Args: func(cmd *spfcbr.Command, args []string) error {
|
|
return c.ConfigureCheckArgs(basename, args)
|
|
},
|
|
})
|
|
}
|