control.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package main
  2. import (
  3. "io"
  4. "sync"
  5. "encoding/json"
  6. "github.com/fatedier/frp/pkg/models"
  7. "github.com/fatedier/frp/pkg/utils/conn"
  8. "github.com/fatedier/frp/pkg/utils/log"
  9. )
  10. func ControlProcess(cli *models.ProxyClient, wait *sync.WaitGroup) {
  11. defer wait.Done()
  12. c := &conn.Conn{}
  13. err := c.ConnectServer(ServerAddr, ServerPort)
  14. if err != nil {
  15. log.Error("ProxyName [%s], connect to server [%s:%d] error, %v", cli.Name, ServerAddr, ServerPort, err)
  16. return
  17. }
  18. defer c.Close()
  19. req := &models.ClientCtlReq{
  20. Type: models.ControlConn,
  21. ProxyName: cli.Name,
  22. Passwd: cli.Passwd,
  23. }
  24. buf, _ := json.Marshal(req)
  25. err = c.Write(string(buf) + "\n")
  26. if err != nil {
  27. log.Error("ProxyName [%s], write to server error, %v", cli.Name, err)
  28. return
  29. }
  30. res, err := c.ReadLine()
  31. if err != nil {
  32. log.Error("ProxyName [%s], read from server error, %v", cli.Name, err)
  33. return
  34. }
  35. log.Debug("ProxyName [%s], read [%s]", cli.Name, res)
  36. clientCtlRes := &models.ClientCtlRes{}
  37. if err = json.Unmarshal([]byte(res), &clientCtlRes); err != nil {
  38. log.Error("ProxyName [%s], format server response error, %v", cli.Name, err)
  39. return
  40. }
  41. if clientCtlRes.Code != 0 {
  42. log.Error("ProxyName [%s], start proxy error, %s", cli.Name, clientCtlRes.Msg)
  43. return
  44. }
  45. for {
  46. // ignore response content now
  47. _, err := c.ReadLine()
  48. if err == io.EOF {
  49. log.Debug("ProxyName [%s], server close this control conn", cli.Name)
  50. break
  51. } else if err != nil {
  52. log.Warn("ProxyName [%s], read from server error, %v", cli.Name, err)
  53. continue
  54. }
  55. cli.StartTunnel(ServerAddr, ServerPort)
  56. }
  57. }