|
@@ -17,6 +17,7 @@ package client
|
|
import (
|
|
import (
|
|
"encoding/json"
|
|
"encoding/json"
|
|
"fmt"
|
|
"fmt"
|
|
|
|
+ "io/ioutil"
|
|
"net/http"
|
|
"net/http"
|
|
"sort"
|
|
"sort"
|
|
"strings"
|
|
"strings"
|
|
@@ -32,7 +33,7 @@ type GeneralResponse struct {
|
|
Msg string `json:"msg"`
|
|
Msg string `json:"msg"`
|
|
}
|
|
}
|
|
|
|
|
|
-// api/reload
|
|
|
|
|
|
+// GET api/reload
|
|
type ReloadResp struct {
|
|
type ReloadResp struct {
|
|
GeneralResponse
|
|
GeneralResponse
|
|
}
|
|
}
|
|
@@ -42,19 +43,19 @@ func (svr *Service) apiReload(w http.ResponseWriter, r *http.Request) {
|
|
buf []byte
|
|
buf []byte
|
|
res ReloadResp
|
|
res ReloadResp
|
|
)
|
|
)
|
|
|
|
+
|
|
|
|
+ log.Info("Http request: [/api/reload]")
|
|
defer func() {
|
|
defer func() {
|
|
log.Info("Http response [/api/reload]: code [%d]", res.Code)
|
|
log.Info("Http response [/api/reload]: code [%d]", res.Code)
|
|
buf, _ = json.Marshal(&res)
|
|
buf, _ = json.Marshal(&res)
|
|
w.Write(buf)
|
|
w.Write(buf)
|
|
}()
|
|
}()
|
|
|
|
|
|
- log.Info("Http request: [/api/reload]")
|
|
|
|
-
|
|
|
|
content, err := config.GetRenderedConfFromFile(g.GlbClientCfg.CfgFile)
|
|
content, err := config.GetRenderedConfFromFile(g.GlbClientCfg.CfgFile)
|
|
if err != nil {
|
|
if err != nil {
|
|
res.Code = 1
|
|
res.Code = 1
|
|
res.Msg = err.Error()
|
|
res.Msg = err.Error()
|
|
- log.Error("reload frpc config file error: %v", err)
|
|
|
|
|
|
+ log.Warn("reload frpc config file error: %v", err)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
@@ -62,7 +63,7 @@ func (svr *Service) apiReload(w http.ResponseWriter, r *http.Request) {
|
|
if err != nil {
|
|
if err != nil {
|
|
res.Code = 2
|
|
res.Code = 2
|
|
res.Msg = err.Error()
|
|
res.Msg = err.Error()
|
|
- log.Error("reload frpc common section error: %v", err)
|
|
|
|
|
|
+ log.Warn("reload frpc common section error: %v", err)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
@@ -70,7 +71,7 @@ func (svr *Service) apiReload(w http.ResponseWriter, r *http.Request) {
|
|
if err != nil {
|
|
if err != nil {
|
|
res.Code = 3
|
|
res.Code = 3
|
|
res.Msg = err.Error()
|
|
res.Msg = err.Error()
|
|
- log.Error("reload frpc proxy config error: %v", err)
|
|
|
|
|
|
+ log.Warn("reload frpc proxy config error: %v", err)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
@@ -78,7 +79,7 @@ func (svr *Service) apiReload(w http.ResponseWriter, r *http.Request) {
|
|
if err != nil {
|
|
if err != nil {
|
|
res.Code = 4
|
|
res.Code = 4
|
|
res.Msg = err.Error()
|
|
res.Msg = err.Error()
|
|
- log.Error("reload frpc proxy config error: %v", err)
|
|
|
|
|
|
+ log.Warn("reload frpc proxy config error: %v", err)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
log.Info("success reload conf")
|
|
log.Info("success reload conf")
|
|
@@ -163,7 +164,7 @@ func NewProxyStatusResp(status *proxy.ProxyStatus) ProxyStatusResp {
|
|
return psr
|
|
return psr
|
|
}
|
|
}
|
|
|
|
|
|
-// api/status
|
|
|
|
|
|
+// GET api/status
|
|
func (svr *Service) apiStatus(w http.ResponseWriter, r *http.Request) {
|
|
func (svr *Service) apiStatus(w http.ResponseWriter, r *http.Request) {
|
|
var (
|
|
var (
|
|
buf []byte
|
|
buf []byte
|
|
@@ -175,14 +176,14 @@ func (svr *Service) apiStatus(w http.ResponseWriter, r *http.Request) {
|
|
res.Https = make([]ProxyStatusResp, 0)
|
|
res.Https = make([]ProxyStatusResp, 0)
|
|
res.Stcp = make([]ProxyStatusResp, 0)
|
|
res.Stcp = make([]ProxyStatusResp, 0)
|
|
res.Xtcp = make([]ProxyStatusResp, 0)
|
|
res.Xtcp = make([]ProxyStatusResp, 0)
|
|
|
|
+
|
|
|
|
+ log.Info("Http request: [/api/status]")
|
|
defer func() {
|
|
defer func() {
|
|
log.Info("Http response [/api/status]")
|
|
log.Info("Http response [/api/status]")
|
|
buf, _ = json.Marshal(&res)
|
|
buf, _ = json.Marshal(&res)
|
|
w.Write(buf)
|
|
w.Write(buf)
|
|
}()
|
|
}()
|
|
|
|
|
|
- log.Info("Http request: [/api/status]")
|
|
|
|
-
|
|
|
|
ps := svr.ctl.pm.GetAllProxyStatus()
|
|
ps := svr.ctl.pm.GetAllProxyStatus()
|
|
for _, status := range ps {
|
|
for _, status := range ps {
|
|
switch status.Type {
|
|
switch status.Type {
|
|
@@ -209,12 +210,14 @@ func (svr *Service) apiStatus(w http.ResponseWriter, r *http.Request) {
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
-// api/config
|
|
|
|
|
|
+// GET api/config
|
|
func (svr *Service) apiGetConfig(w http.ResponseWriter, r *http.Request) {
|
|
func (svr *Service) apiGetConfig(w http.ResponseWriter, r *http.Request) {
|
|
var (
|
|
var (
|
|
buf []byte
|
|
buf []byte
|
|
res GeneralResponse
|
|
res GeneralResponse
|
|
)
|
|
)
|
|
|
|
+
|
|
|
|
+ log.Info("Http get request: [/api/config]")
|
|
defer func() {
|
|
defer func() {
|
|
log.Info("Http get response [/api/config]")
|
|
log.Info("Http get response [/api/config]")
|
|
if len(buf) > 0 {
|
|
if len(buf) > 0 {
|
|
@@ -224,12 +227,12 @@ func (svr *Service) apiGetConfig(w http.ResponseWriter, r *http.Request) {
|
|
w.Write(buf)
|
|
w.Write(buf)
|
|
}
|
|
}
|
|
}()
|
|
}()
|
|
- log.Info("Http get request: [/api/config]")
|
|
|
|
|
|
|
|
if g.GlbClientCfg.CfgFile == "" {
|
|
if g.GlbClientCfg.CfgFile == "" {
|
|
w.WriteHeader(400)
|
|
w.WriteHeader(400)
|
|
res.Code = 1
|
|
res.Code = 1
|
|
res.Msg = "frpc don't configure a config file path"
|
|
res.Msg = "frpc don't configure a config file path"
|
|
|
|
+ log.Warn("%s", res.Msg)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
@@ -238,7 +241,7 @@ func (svr *Service) apiGetConfig(w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(400)
|
|
w.WriteHeader(400)
|
|
res.Code = 2
|
|
res.Code = 2
|
|
res.Msg = err.Error()
|
|
res.Msg = err.Error()
|
|
- log.Error("load frpc config file error: %v", err)
|
|
|
|
|
|
+ log.Warn("load frpc config file error: %v", err)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
@@ -253,3 +256,74 @@ func (svr *Service) apiGetConfig(w http.ResponseWriter, r *http.Request) {
|
|
}
|
|
}
|
|
buf = []byte(strings.Join(newRows, "\n"))
|
|
buf = []byte(strings.Join(newRows, "\n"))
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+// PUT api/config
|
|
|
|
+func (svr *Service) apiPutConfig(w http.ResponseWriter, r *http.Request) {
|
|
|
|
+ var (
|
|
|
|
+ buf []byte
|
|
|
|
+ res GeneralResponse
|
|
|
|
+ )
|
|
|
|
+
|
|
|
|
+ log.Info("Http put request: [/api/config]")
|
|
|
|
+ defer func() {
|
|
|
|
+ log.Info("Http put response: [/api/config]")
|
|
|
|
+ buf, _ = json.Marshal(&res)
|
|
|
|
+ w.Write(buf)
|
|
|
|
+ }()
|
|
|
|
+
|
|
|
|
+ // get new config content
|
|
|
|
+ body, err := ioutil.ReadAll(r.Body)
|
|
|
|
+ if err != nil {
|
|
|
|
+ res.Code = 1
|
|
|
|
+ res.Msg = fmt.Sprintf("read request body error: %v", err)
|
|
|
|
+ log.Warn("%s", res.Msg)
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // get token from origin content
|
|
|
|
+ token := ""
|
|
|
|
+ b, err := ioutil.ReadFile(g.GlbClientCfg.CfgFile)
|
|
|
|
+ if err != nil {
|
|
|
|
+ res.Code = 2
|
|
|
|
+ res.Msg = err.Error()
|
|
|
|
+ log.Warn("load frpc config file error: %v", err)
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ content := string(b)
|
|
|
|
+
|
|
|
|
+ for _, row := range strings.Split(content, "\n") {
|
|
|
|
+ row = strings.TrimSpace(row)
|
|
|
|
+ if strings.HasPrefix(row, "token") {
|
|
|
|
+ token = row
|
|
|
|
+ break
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ tmpRows := make([]string, 0)
|
|
|
|
+ for _, row := range strings.Split(string(body), "\n") {
|
|
|
|
+ row = strings.TrimSpace(row)
|
|
|
|
+ if strings.HasPrefix(row, "token") {
|
|
|
|
+ continue
|
|
|
|
+ }
|
|
|
|
+ tmpRows = append(tmpRows, row)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ newRows := make([]string, 0)
|
|
|
|
+ if token != "" {
|
|
|
|
+ for _, row := range tmpRows {
|
|
|
|
+ newRows = append(newRows, row)
|
|
|
|
+ if strings.HasPrefix(row, "[common]") {
|
|
|
|
+ newRows = append(newRows, token)
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ content = strings.Join(newRows, "\n")
|
|
|
|
+
|
|
|
|
+ err = ioutil.WriteFile(g.GlbClientCfg.CfgFile, []byte(content), 0644)
|
|
|
|
+ if err != nil {
|
|
|
|
+ res.Code = 3
|
|
|
|
+ res.Msg = fmt.Sprintf("write content to frpc config file error: %v", err)
|
|
|
|
+ log.Warn("%s", res.Msg)
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+}
|