-
Notifications
You must be signed in to change notification settings - Fork 36
/
globalobj.go
68 lines (55 loc) · 1.31 KB
/
globalobj.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package utils
import (
"encoding/json"
"fmt"
"github.com/llr104/LiFrame/core/logs"
"github.com/pkg/errors"
"io/ioutil"
)
/*
存储一切有关Zinx框架的全局参数,供其他模块使用
一些参数也可以通过 用户根据 LiFrame.json来配置
*/
type GlobalObj struct {
AppConfig Config
}
/*
定义一个全局的对象
*/
var GlobalObject *GlobalObj
var Log *logs.LiLogger
//读取用户的配置文件
func (g *GlobalObj) Load(configFile string) {
if confFileExists, _ := PathExists(configFile); confFileExists != true {
text := fmt.Sprintf("Config File %s is not exist!!", configFile)
Log.Error(text)
panic(errors.New(text))
}
data, err := ioutil.ReadFile(configFile)
if err != nil {
panic(err)
}
//将json数据解析到struct中
err = json.Unmarshal(data, &g.AppConfig)
if err != nil {
Log.Error("load config error")
panic(err)
}
Log.Info("Config:%v", g.AppConfig)
if g.AppConfig.LogFile != ""{
logCfg := fmt.Sprintf(`{"filename":"%s"}`,g.AppConfig.LogFile)
Log.SetLogger(logs.AdapterFile, logCfg)
}
}
/*
提供init方法,默认加载
*/
func init() {
Log = logs.GetLiLogger()
Log.SetLogger(logs.AdapterConsole)
Log.EnableFuncCallDepth(true)
//初始化GlobalObject变量,设置一些默认值
GlobalObject = &GlobalObj{
AppConfig: NewConfig(),
}
}