1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- package legacy
- import (
- "bytes"
- "fmt"
- "os"
- "path/filepath"
- )
- func ParseClientConfig(filePath string) (
- cfg ClientCommonConf,
- proxyCfgs map[string]ProxyConf,
- visitorCfgs map[string]VisitorConf,
- err error,
- ) {
- var content []byte
- content, err = GetRenderedConfFromFile(filePath)
- if err != nil {
- return
- }
- configBuffer := bytes.NewBuffer(nil)
- configBuffer.Write(content)
-
- cfg, err = UnmarshalClientConfFromIni(content)
- if err != nil {
- return
- }
- if err = cfg.Validate(); err != nil {
- err = fmt.Errorf("parse config error: %v", err)
- return
- }
-
- var buf []byte
- buf, err = getIncludeContents(cfg.IncludeConfigFiles)
- if err != nil {
- err = fmt.Errorf("getIncludeContents error: %v", err)
- return
- }
- configBuffer.WriteString("\n")
- configBuffer.Write(buf)
-
- proxyCfgs, visitorCfgs, err = LoadAllProxyConfsFromIni(cfg.User, configBuffer.Bytes(), cfg.Start)
- if err != nil {
- return
- }
- return
- }
- func getIncludeContents(paths []string) ([]byte, error) {
- out := bytes.NewBuffer(nil)
- for _, path := range paths {
- absDir, err := filepath.Abs(filepath.Dir(path))
- if err != nil {
- return nil, err
- }
- if _, err := os.Stat(absDir); os.IsNotExist(err) {
- return nil, err
- }
- files, err := os.ReadDir(absDir)
- if err != nil {
- return nil, err
- }
- for _, fi := range files {
- if fi.IsDir() {
- continue
- }
- absFile := filepath.Join(absDir, fi.Name())
- if matched, _ := filepath.Match(filepath.Join(absDir, filepath.Base(path)), absFile); matched {
- tmpContent, err := GetRenderedConfFromFile(absFile)
- if err != nil {
- return nil, fmt.Errorf("render extra config %s error: %v", absFile, err)
- }
- out.Write(tmpContent)
- out.WriteString("\n")
- }
- }
- }
- return out.Bytes(), nil
- }
|