Browse Source

conf: 替换 confutil 包

pull/1/head
miraclesu 8 years ago
parent
commit
7f7e6b4ae4
  1. 5
      conf/conf.go
  2. 93
      utils/confutil.go
  3. 29
      utils/confutil_test.go
  4. 5
      utils/test.json
  5. 4
      utils/test1.json

5
conf/conf.go

@ -9,10 +9,11 @@ import (
"github.com/fsnotify/fsnotify"
"github.com/go-gomail/gomail"
"sunteng/commons/confutil"
"sunteng/commons/db/imgo"
"sunteng/commons/event"
"sunteng/commons/log"
"github.com/shunfei/cronsun/utils"
)
var (
@ -113,7 +114,7 @@ func cleanKeyPrefix(p string) string {
}
func (c *Conf) parse() error {
err := confutil.LoadExtendConf(*confFile, c)
err := utils.LoadExtendConf(*confFile, c)
if err != nil {
return err
}

93
utils/confutil.go

@ -0,0 +1,93 @@
// 加载json(可配置扩展字段)配置文件
//
// {
// "Debug": true,
// "Log": "@extend:./log.json"
// }
package utils
import (
"bytes"
"encoding/json"
"fmt"
"io/ioutil"
"os"
"path/filepath"
"regexp"
)
var (
extendTag = "@extend:"
pwdTag = "@pwd@"
rootTag = "@root@"
root = ""
)
// 设置扩展标识,如果不设置,默认为 '@extend:'
func SetExtendTag(tag string) {
extendTag = tag
}
func SetRoot(r string) {
root = r
}
// 设置当前路径标识,如果不设置,默认为 '@pwd@'
// @pwd@ 会被替换成当前文件的路径,
// 至于是绝对路径还是相对路径,取决于读取文件时,传入的是绝对路径还是相对路径
func SetPathTag(tag string) {
pwdTag = tag
}
//加载json(可配置扩展字段)配置文件
func LoadExtendConf(filePath string, v interface{}) error {
data, err := extendFile(filePath)
if err != nil {
return err
}
return json.Unmarshal(data, v)
}
func extendFile(filePath string) (data []byte, err error) {
fi, err := os.Stat(filePath)
if err != nil {
return
}
if fi.IsDir() {
err = fmt.Errorf(filePath + " is not a file.")
return
}
b, err := ioutil.ReadFile(filePath)
if err != nil {
return
}
if len(root) != 0 {
b = bytes.Replace(b, []byte(rootTag), []byte(root), -1)
}
dir := filepath.Dir(filePath)
return extendFileContent(dir, bytes.Replace(b, []byte(pwdTag), []byte(dir), -1))
}
func extendFileContent(dir string, content []byte) (data []byte, err error) {
//检查是不是规范的json
test := new(interface{})
err = json.Unmarshal(content, &test)
if err != nil {
return
}
// 替换子json文件
reg := regexp.MustCompile(`"` + extendTag + `.*?"`)
data = reg.ReplaceAllFunc(content, func(match []byte) []byte {
match = match[len(extendTag)+1 : len(match)-1]
sb, e := extendFile(filepath.Join(dir, string(match)))
if e != nil {
err = fmt.Errorf("替换json配置[%s]失败:%s\n", match, e.Error())
}
return sb
})
return
}

29
utils/confutil_test.go

@ -0,0 +1,29 @@
package utils
import (
"testing"
. "github.com/smartystreets/goconvey/convey"
)
func TestLoadExtendConf(t *testing.T) {
testFile := "test.json"
type conf struct {
Debug bool
Num int
Log struct {
Level int
Path string
}
}
Convey("confutil package test", t, func() {
Convey("load test file should be success", func() {
c := &conf{}
err := LoadExtendConf(testFile, c)
So(err, ShouldBeNil)
So(c.Debug, ShouldBeTrue)
So(c.Log.Path, ShouldEqual, "./tmp")
})
})
}

5
utils/test.json

@ -0,0 +1,5 @@
{
"Debug": true,
"Num": 1,
"Log": "@extend:test1.json"
}

4
utils/test1.json

@ -0,0 +1,4 @@
{
"Level": 2,
"Path": "@pwd@/tmp"
}
Loading…
Cancel
Save