2017-03-08 19:03:47 +01:00
|
|
|
// Copyright 2016 fatedier, fatedier@gmail.com
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"strconv"
|
2017-05-24 19:45:38 +02:00
|
|
|
"strings"
|
2017-03-08 19:03:47 +01:00
|
|
|
|
|
|
|
ini "github.com/vaughan0/go-ini"
|
|
|
|
)
|
|
|
|
|
|
|
|
var ClientCommonCfg *ClientCommonConf
|
|
|
|
|
|
|
|
// client common config
|
|
|
|
type ClientCommonConf struct {
|
|
|
|
ConfigFile string
|
|
|
|
ServerAddr string
|
2018-01-17 14:49:37 +01:00
|
|
|
ServerPort int
|
|
|
|
ServerUdpPort int // this is specified by login response message from frps
|
2017-03-08 19:03:47 +01:00
|
|
|
HttpProxy string
|
|
|
|
LogFile string
|
|
|
|
LogWay string
|
|
|
|
LogLevel string
|
|
|
|
LogMaxDays int64
|
|
|
|
PrivilegeToken string
|
2017-07-12 20:20:49 +02:00
|
|
|
AdminAddr string
|
2018-01-17 14:49:37 +01:00
|
|
|
AdminPort int
|
2017-07-12 20:20:49 +02:00
|
|
|
AdminUser string
|
|
|
|
AdminPwd string
|
2017-03-08 19:03:47 +01:00
|
|
|
PoolCount int
|
2017-05-17 11:47:20 +02:00
|
|
|
TcpMux bool
|
2017-03-08 19:03:47 +01:00
|
|
|
User string
|
2017-05-24 19:10:58 +02:00
|
|
|
LoginFailExit bool
|
2017-05-24 19:45:38 +02:00
|
|
|
Start map[string]struct{}
|
2017-06-04 13:56:21 +02:00
|
|
|
Protocol string
|
2017-03-08 19:03:47 +01:00
|
|
|
HeartBeatInterval int64
|
|
|
|
HeartBeatTimeout int64
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetDeaultClientCommonConf() *ClientCommonConf {
|
|
|
|
return &ClientCommonConf{
|
|
|
|
ConfigFile: "./frpc.ini",
|
|
|
|
ServerAddr: "0.0.0.0",
|
|
|
|
ServerPort: 7000,
|
2017-10-24 12:20:07 +02:00
|
|
|
ServerUdpPort: 0,
|
2017-03-08 19:03:47 +01:00
|
|
|
HttpProxy: "",
|
|
|
|
LogFile: "console",
|
|
|
|
LogWay: "console",
|
|
|
|
LogLevel: "info",
|
|
|
|
LogMaxDays: 3,
|
|
|
|
PrivilegeToken: "",
|
2017-07-12 20:20:49 +02:00
|
|
|
AdminAddr: "127.0.0.1",
|
|
|
|
AdminPort: 0,
|
|
|
|
AdminUser: "",
|
|
|
|
AdminPwd: "",
|
2017-03-08 19:03:47 +01:00
|
|
|
PoolCount: 1,
|
2017-05-17 11:47:20 +02:00
|
|
|
TcpMux: true,
|
2017-03-08 19:03:47 +01:00
|
|
|
User: "",
|
2017-05-24 19:10:58 +02:00
|
|
|
LoginFailExit: true,
|
2017-05-24 19:45:38 +02:00
|
|
|
Start: make(map[string]struct{}),
|
2017-06-04 13:56:21 +02:00
|
|
|
Protocol: "tcp",
|
2017-05-14 18:08:21 +02:00
|
|
|
HeartBeatInterval: 30,
|
|
|
|
HeartBeatTimeout: 90,
|
2017-03-08 19:03:47 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func LoadClientCommonConf(conf ini.File) (cfg *ClientCommonConf, err error) {
|
|
|
|
var (
|
|
|
|
tmpStr string
|
|
|
|
ok bool
|
|
|
|
v int64
|
|
|
|
)
|
|
|
|
cfg = GetDeaultClientCommonConf()
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "server_addr")
|
|
|
|
if ok {
|
|
|
|
cfg.ServerAddr = tmpStr
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "server_port")
|
|
|
|
if ok {
|
2018-01-17 14:49:37 +01:00
|
|
|
v, err = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
err = fmt.Errorf("Parse conf error: invalid server_port")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
cfg.ServerPort = int(v)
|
2017-03-08 19:03:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "http_proxy")
|
|
|
|
if ok {
|
|
|
|
cfg.HttpProxy = tmpStr
|
|
|
|
} else {
|
|
|
|
// get http_proxy from env
|
|
|
|
cfg.HttpProxy = os.Getenv("http_proxy")
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "log_file")
|
|
|
|
if ok {
|
|
|
|
cfg.LogFile = tmpStr
|
|
|
|
if cfg.LogFile == "console" {
|
|
|
|
cfg.LogWay = "console"
|
|
|
|
} else {
|
|
|
|
cfg.LogWay = "file"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "log_level")
|
|
|
|
if ok {
|
|
|
|
cfg.LogLevel = tmpStr
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "log_max_days")
|
|
|
|
if ok {
|
2017-07-12 20:20:49 +02:00
|
|
|
if v, err = strconv.ParseInt(tmpStr, 10, 64); err == nil {
|
|
|
|
cfg.LogMaxDays = v
|
|
|
|
}
|
2017-03-08 19:03:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "privilege_token")
|
|
|
|
if ok {
|
|
|
|
cfg.PrivilegeToken = tmpStr
|
|
|
|
}
|
|
|
|
|
2017-07-12 20:20:49 +02:00
|
|
|
tmpStr, ok = conf.Get("common", "admin_addr")
|
|
|
|
if ok {
|
|
|
|
cfg.AdminAddr = tmpStr
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "admin_port")
|
|
|
|
if ok {
|
|
|
|
if v, err = strconv.ParseInt(tmpStr, 10, 64); err == nil {
|
2018-01-17 14:49:37 +01:00
|
|
|
cfg.AdminPort = int(v)
|
|
|
|
} else {
|
|
|
|
err = fmt.Errorf("Parse conf error: invalid admin_port")
|
|
|
|
return
|
2017-07-12 20:20:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "admin_user")
|
|
|
|
if ok {
|
|
|
|
cfg.AdminUser = tmpStr
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "admin_pwd")
|
|
|
|
if ok {
|
|
|
|
cfg.AdminPwd = tmpStr
|
|
|
|
}
|
|
|
|
|
2017-03-08 19:03:47 +01:00
|
|
|
tmpStr, ok = conf.Get("common", "pool_count")
|
|
|
|
if ok {
|
|
|
|
v, err = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
cfg.PoolCount = 1
|
|
|
|
} else {
|
|
|
|
cfg.PoolCount = int(v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-17 11:47:20 +02:00
|
|
|
tmpStr, ok = conf.Get("common", "tcp_mux")
|
|
|
|
if ok && tmpStr == "false" {
|
|
|
|
cfg.TcpMux = false
|
|
|
|
} else {
|
|
|
|
cfg.TcpMux = true
|
|
|
|
}
|
|
|
|
|
2017-03-08 19:03:47 +01:00
|
|
|
tmpStr, ok = conf.Get("common", "user")
|
|
|
|
if ok {
|
|
|
|
cfg.User = tmpStr
|
|
|
|
}
|
|
|
|
|
2017-05-24 19:45:38 +02:00
|
|
|
tmpStr, ok = conf.Get("common", "start")
|
|
|
|
if ok {
|
|
|
|
proxyNames := strings.Split(tmpStr, ",")
|
|
|
|
for _, name := range proxyNames {
|
2017-07-12 20:20:49 +02:00
|
|
|
cfg.Start[strings.TrimSpace(name)] = struct{}{}
|
2017-05-24 19:45:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-24 19:10:58 +02:00
|
|
|
tmpStr, ok = conf.Get("common", "login_fail_exit")
|
|
|
|
if ok && tmpStr == "false" {
|
|
|
|
cfg.LoginFailExit = false
|
|
|
|
} else {
|
|
|
|
cfg.LoginFailExit = true
|
|
|
|
}
|
|
|
|
|
2017-06-04 13:56:21 +02:00
|
|
|
tmpStr, ok = conf.Get("common", "protocol")
|
|
|
|
if ok {
|
|
|
|
// Now it only support tcp and kcp.
|
|
|
|
if tmpStr != "kcp" {
|
|
|
|
tmpStr = "tcp"
|
|
|
|
}
|
|
|
|
cfg.Protocol = tmpStr
|
|
|
|
}
|
|
|
|
|
2017-03-08 19:03:47 +01:00
|
|
|
tmpStr, ok = conf.Get("common", "heartbeat_timeout")
|
|
|
|
if ok {
|
|
|
|
v, err = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
if err != nil {
|
2018-01-17 14:49:37 +01:00
|
|
|
err = fmt.Errorf("Parse conf error: invalid heartbeat_timeout")
|
2017-03-08 19:03:47 +01:00
|
|
|
return
|
|
|
|
} else {
|
|
|
|
cfg.HeartBeatTimeout = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "heartbeat_interval")
|
|
|
|
if ok {
|
|
|
|
v, err = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
if err != nil {
|
2018-01-17 14:49:37 +01:00
|
|
|
err = fmt.Errorf("Parse conf error: invalid heartbeat_interval")
|
2017-03-08 19:03:47 +01:00
|
|
|
return
|
|
|
|
} else {
|
|
|
|
cfg.HeartBeatInterval = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if cfg.HeartBeatInterval <= 0 {
|
2018-01-17 14:49:37 +01:00
|
|
|
err = fmt.Errorf("Parse conf error: invalid heartbeat_interval")
|
2017-03-08 19:03:47 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if cfg.HeartBeatTimeout < cfg.HeartBeatInterval {
|
2018-01-17 14:49:37 +01:00
|
|
|
err = fmt.Errorf("Parse conf error: invalid heartbeat_timeout, heartbeat_timeout is less than heartbeat_interval")
|
2017-03-08 19:03:47 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|