-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathdefault_config.go
143 lines (119 loc) · 4.12 KB
/
default_config.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
package main
import (
"github.com/admpub/confl"
c "github.com/webx-top/tower/config"
)
var defaultConfig = []byte(`
app {
# 生产环境下的可执行文件。支持用“*”代替文件名的一部分,例如:"tower-app-*.exe"
exec : "tower-app-*.exe"
# 开发环境下用“go run”命令运行的源文件,一般为“main.go”
main : ""
# 你的项目在本机运行的端口列表,可以用半角逗号分隔也可以用减号指定范围,也可以两种结合起来用,例如: "5001,5003,5050-5060"。如果为空,则代表不支持访问端口。
port : "5001-5050"
# 指定app端口的参数名,例如:webx.exe -p 8080 其中的“-p”就是。如果为空,则代表不支持访问端口。
portParamName : "-p"
# 是否在执行 go build 以前执行 go generate
generate : false
# go build -o 命令生成的二进制文件保存位置
buildDir : ""
# go build所需的其它参数,例如:-tags sqlite 或 -tags sqlite,zbar
buildParams : ""
# 运行app所需的其它参数,例如:webx.exe -p 8080 -e 90 -d 100 其中的“-e 90 -d 100”就是(注意:默认是以半角空格作为分隔符,也支持自己指定分隔符,只需要符合这样的格式“:<分割符>:<参数>”,即只需要在参数前面加上“:<分隔符>:”就可以了,其中的“<分隔符>”替换成你自己的分隔符,例如“:~:-e~90~-d~100”。上面的buildParams也遵循这样的规则)。
params : ""
# 包路径替换规则,例如:{"^golang\\.org/x/(.*)$":"github.com/golang/$1"}
pkgMirrors : {}
# 自定义环境变量。例如: ["ENV_NAME_1=value1","ENV_NAME_2=value2"]
env : []
}
proxy {
# 你的项目对外公开访问的端口
port : "8080"
# 代理引擎。支持fast和standard
engine : "standard"
}
admin {
password : ""
ips : "127.0.0.1,::1"
}
watch {
# 要监控更改的文件扩展名。多个扩展名时使用"|"隔开,例如:go|html
fileExtension : "go"
# 默认会自动监控上面main参数所指定的文件所在之文件夹,如果你还要监控其它文件夹,请在这里指定。如要指定多个文件夹路径,请用“|”分隔。
otherDir : ""
# 忽略的路径(正则表达式),不填则不限制(排除某个完整的文件夹名请用“/文件夹名/”的格式)
ignoredPath : ""
}
# 是否显示细节信息。如果设置为true,会自动将下面的logLevel设置为Debug
verbose : false
# 日志等级。支持的值有Debug/Info/Warn/Error/Fatal
logLevel : "Debug"
# 是否在控制台显示request日志
logRequest : true
# 是否自动删除以前的可执行文件
autoClear : true
# 是否离线模式(即开发模式)
offline : true
`)
func convertOldConfigFormat(configFile string) error {
newmap := map[string]string{}
_, err := confl.DecodeFile(configFile, &newmap)
if err != nil {
return err
}
if v, ok := newmap["app_port"]; ok {
c.Conf.App.Port = v
}
if v, ok := newmap["pxy_port"]; ok {
c.Conf.Proxy.Port = v
}
if v, ok := newmap["pxy_engine"]; ok {
c.Conf.Proxy.Engine = v
}
if v, ok := newmap["auto_clear"]; ok {
b := atob(v)
c.Conf.AutoClear = b
}
if v, ok := newmap["log_level"]; ok {
c.Conf.LogLevel = v
}
if v, ok := newmap["app_buildDir"]; ok {
c.Conf.App.BuildDir = v
}
if v, ok := newmap["app_portParamName"]; ok {
c.Conf.App.PortParamName = v
}
if v, ok := newmap["app_runParams"]; ok {
c.Conf.App.RunParams = v
}
if v, ok := newmap["watch"]; ok {
c.Conf.Watch.FileExtension = v
}
if v, ok := newmap["watch_otherDir"]; ok {
c.Conf.Watch.OtherDir = v
} //编译模式下有效
if v, ok := newmap["watch_ignoredPath"]; ok {
c.Conf.Watch.IgnoredPath = v
}
if v, ok := newmap["offline_mode"]; ok {
b := atob(v)
c.Conf.Offline = b
}
if v, ok := newmap["admin_pwd"]; ok {
c.Conf.Admin.Password = v
}
if v, ok := newmap["admin_ip"]; ok {
c.Conf.Admin.IPs = v
}
if v, ok := newmap["log_request"]; ok {
b := atob(v)
c.Conf.LogRequest = b
}
if v, ok := newmap["main"]; ok {
c.Conf.App.MainFile = v
} //编译模式下有效
if v, ok := newmap["exec"]; ok {
c.Conf.App.ExecFile = v
} //非编译模式下有效
return nil
}