2016-03-14 11:18:24 +08: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.
|
|
|
|
|
2016-02-18 18:24:48 +08:00
|
|
|
package server
|
2016-01-27 21:24:36 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strconv"
|
2016-04-18 15:16:40 +08:00
|
|
|
"strings"
|
2016-01-27 21:24:36 +08:00
|
|
|
|
|
|
|
ini "github.com/vaughan0/go-ini"
|
2016-04-18 15:16:40 +08:00
|
|
|
|
|
|
|
"frp/utils/vhost"
|
2016-01-27 21:24:36 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// common config
|
|
|
|
var (
|
2016-02-05 14:36:04 +08:00
|
|
|
BindAddr string = "0.0.0.0"
|
2016-03-14 00:21:40 +08:00
|
|
|
BindPort int64 = 7000
|
2016-05-19 00:04:19 +08:00
|
|
|
VhostHttpPort int64 = 0 // if VhostHttpPort equals 0, don't listen a public port for http
|
|
|
|
DashboardPort int64 = 0 // if DashboardPort equals 0, dashboard is not available
|
2016-03-14 00:21:40 +08:00
|
|
|
LogFile string = "console"
|
|
|
|
LogWay string = "console" // console or file
|
|
|
|
LogLevel string = "info"
|
2016-05-03 21:41:57 +08:00
|
|
|
LogMaxDays int64 = 3
|
2016-03-17 10:25:23 +08:00
|
|
|
HeartBeatTimeout int64 = 90
|
2016-02-25 10:28:34 +08:00
|
|
|
UserConnTimeout int64 = 10
|
2016-04-18 15:16:40 +08:00
|
|
|
|
|
|
|
VhostMuxer *vhost.HttpMuxer
|
2016-01-27 21:24:36 +08:00
|
|
|
)
|
|
|
|
|
2016-02-18 18:24:48 +08:00
|
|
|
var ProxyServers map[string]*ProxyServer = make(map[string]*ProxyServer)
|
2016-01-27 21:24:36 +08:00
|
|
|
|
|
|
|
func LoadConf(confFile string) (err error) {
|
|
|
|
var tmpStr string
|
|
|
|
var ok bool
|
|
|
|
|
|
|
|
conf, err := ini.LoadFile(confFile)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// common
|
|
|
|
tmpStr, ok = conf.Get("common", "bind_addr")
|
|
|
|
if ok {
|
|
|
|
BindAddr = tmpStr
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "bind_port")
|
|
|
|
if ok {
|
|
|
|
BindPort, _ = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
}
|
|
|
|
|
2016-04-18 15:16:40 +08:00
|
|
|
tmpStr, ok = conf.Get("common", "vhost_http_port")
|
|
|
|
if ok {
|
|
|
|
VhostHttpPort, _ = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
} else {
|
|
|
|
VhostHttpPort = 0
|
|
|
|
}
|
|
|
|
|
2016-05-19 00:04:19 +08:00
|
|
|
tmpStr, ok = conf.Get("common", "dashboard_port")
|
|
|
|
if ok {
|
|
|
|
DashboardPort, _ = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
} else {
|
|
|
|
DashboardPort = 0
|
|
|
|
}
|
|
|
|
|
2016-01-27 21:24:36 +08:00
|
|
|
tmpStr, ok = conf.Get("common", "log_file")
|
|
|
|
if ok {
|
|
|
|
LogFile = tmpStr
|
2016-03-14 00:21:40 +08:00
|
|
|
if LogFile == "console" {
|
|
|
|
LogWay = "console"
|
|
|
|
} else {
|
|
|
|
LogWay = "file"
|
|
|
|
}
|
2016-01-27 21:24:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpStr, ok = conf.Get("common", "log_level")
|
|
|
|
if ok {
|
|
|
|
LogLevel = tmpStr
|
|
|
|
}
|
|
|
|
|
2016-05-03 21:41:57 +08:00
|
|
|
tmpStr, ok = conf.Get("common", "log_max_days")
|
|
|
|
if ok {
|
|
|
|
LogMaxDays, _ = strconv.ParseInt(tmpStr, 10, 64)
|
|
|
|
}
|
|
|
|
|
2016-01-27 21:24:36 +08:00
|
|
|
// servers
|
|
|
|
for name, section := range conf {
|
|
|
|
if name != "common" {
|
2016-02-18 18:24:48 +08:00
|
|
|
proxyServer := &ProxyServer{}
|
2016-04-18 15:16:40 +08:00
|
|
|
proxyServer.CustomDomains = make([]string, 0)
|
2016-01-27 21:24:36 +08:00
|
|
|
proxyServer.Name = name
|
|
|
|
|
2016-04-18 15:16:40 +08:00
|
|
|
proxyServer.Type, ok = section["type"]
|
|
|
|
if ok {
|
|
|
|
if proxyServer.Type != "tcp" && proxyServer.Type != "http" {
|
|
|
|
return fmt.Errorf("Parse ini file error: proxy [%s] type error", proxyServer.Name)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
proxyServer.Type = "tcp"
|
|
|
|
}
|
|
|
|
|
2016-04-05 17:18:21 +08:00
|
|
|
proxyServer.AuthToken, ok = section["auth_token"]
|
2016-01-27 21:24:36 +08:00
|
|
|
if !ok {
|
2016-04-05 17:18:21 +08:00
|
|
|
return fmt.Errorf("Parse ini file error: proxy [%s] no auth_token found", proxyServer.Name)
|
2016-01-27 21:24:36 +08:00
|
|
|
}
|
|
|
|
|
2016-04-18 15:16:40 +08:00
|
|
|
// for tcp
|
|
|
|
if proxyServer.Type == "tcp" {
|
|
|
|
proxyServer.BindAddr, ok = section["bind_addr"]
|
|
|
|
if !ok {
|
|
|
|
proxyServer.BindAddr = "0.0.0.0"
|
|
|
|
}
|
2016-01-27 21:24:36 +08:00
|
|
|
|
2016-04-18 15:16:40 +08:00
|
|
|
portStr, ok := section["listen_port"]
|
|
|
|
if ok {
|
|
|
|
proxyServer.ListenPort, err = strconv.ParseInt(portStr, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Parse ini file error: proxy [%s] listen_port error", proxyServer.Name)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return fmt.Errorf("Parse ini file error: proxy [%s] listen_port not found", proxyServer.Name)
|
|
|
|
}
|
|
|
|
} else if proxyServer.Type == "http" {
|
|
|
|
// for http
|
|
|
|
domainStr, ok := section["custom_domains"]
|
|
|
|
if ok {
|
|
|
|
var suffix string
|
|
|
|
if VhostHttpPort != 80 {
|
|
|
|
suffix = fmt.Sprintf(":%d", VhostHttpPort)
|
|
|
|
}
|
|
|
|
proxyServer.CustomDomains = strings.Split(domainStr, ",")
|
|
|
|
for i, domain := range proxyServer.CustomDomains {
|
|
|
|
proxyServer.CustomDomains[i] = strings.ToLower(strings.TrimSpace(domain)) + suffix
|
|
|
|
}
|
2016-01-27 21:24:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
proxyServer.Init()
|
|
|
|
ProxyServers[proxyServer.Name] = proxyServer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(ProxyServers) == 0 {
|
|
|
|
return fmt.Errorf("Parse ini file error: no proxy config found")
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|