root.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. // Copyright 2018 fatedier, fatedier@gmail.com
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package main
  15. import (
  16. "fmt"
  17. "io/ioutil"
  18. "os"
  19. "github.com/spf13/cobra"
  20. "github.com/fatedier/frp/g"
  21. "github.com/fatedier/frp/models/config"
  22. "github.com/fatedier/frp/server"
  23. "github.com/fatedier/frp/utils/log"
  24. "github.com/fatedier/frp/utils/version"
  25. )
  26. const (
  27. CfgFileTypeIni = iota
  28. CfgFileTypeCmd
  29. )
  30. var (
  31. cfgFile string
  32. showVersion bool
  33. bindAddr string
  34. bindPort int
  35. bindUdpPort int
  36. kcpBindPort int
  37. proxyBindAddr string
  38. vhostHttpPort int
  39. vhostHttpsPort int
  40. dashboardAddr string
  41. dashboardPort int
  42. dashboardUser string
  43. dashboardPwd string
  44. assetsDir string
  45. logFile string
  46. logWay string
  47. logLevel string
  48. logMaxDays int64
  49. token string
  50. authTimeout int64
  51. subDomainHost string
  52. tcpMux bool
  53. allowPorts string
  54. maxPoolCount int64
  55. maxPortsPerClient int64
  56. )
  57. func init() {
  58. rootCmd.PersistentFlags().StringVarP(&cfgFile, "", "c", "", "config file of frps")
  59. rootCmd.PersistentFlags().BoolVarP(&showVersion, "version", "v", false, "version of frpc")
  60. rootCmd.PersistentFlags().StringVarP(&bindAddr, "bind_addr", "", "0.0.0.0", "bind address")
  61. rootCmd.PersistentFlags().IntVarP(&bindPort, "bind_port", "p", 7000, "bind port")
  62. rootCmd.PersistentFlags().IntVarP(&bindUdpPort, "bind_udp_port", "", 0, "bind udp port")
  63. rootCmd.PersistentFlags().IntVarP(&kcpBindPort, "kcp_bind_port", "", 0, "kcp bind udp port")
  64. rootCmd.PersistentFlags().StringVarP(&proxyBindAddr, "proxy_bind_addr", "", "0.0.0.0", "proxy bind address")
  65. rootCmd.PersistentFlags().IntVarP(&vhostHttpPort, "vhost_http_port", "", 0, "vhost http port")
  66. rootCmd.PersistentFlags().IntVarP(&vhostHttpsPort, "vhost_https_port", "", 0, "vhost https port")
  67. rootCmd.PersistentFlags().StringVarP(&dashboardAddr, "dashboard_addr", "", "0.0.0.0", "dasboard address")
  68. rootCmd.PersistentFlags().IntVarP(&dashboardPort, "dashboard_port", "", 0, "dashboard port")
  69. rootCmd.PersistentFlags().StringVarP(&dashboardUser, "dashboard_user", "", "admin", "dashboard user")
  70. rootCmd.PersistentFlags().StringVarP(&dashboardPwd, "dashboard_pwd", "", "admin", "dashboard password")
  71. rootCmd.PersistentFlags().StringVarP(&logFile, "log_file", "", "console", "log file")
  72. rootCmd.PersistentFlags().StringVarP(&logWay, "log_way", "", "console", "log way")
  73. rootCmd.PersistentFlags().StringVarP(&logLevel, "log_level", "", "info", "log level")
  74. rootCmd.PersistentFlags().Int64VarP(&logMaxDays, "log_max_days", "", 3, "log_max_days")
  75. rootCmd.PersistentFlags().StringVarP(&token, "token", "t", "", "auth token")
  76. rootCmd.PersistentFlags().Int64VarP(&authTimeout, "auth_timeout", "", 900, "auth timeout")
  77. rootCmd.PersistentFlags().StringVarP(&subDomainHost, "subdomain_host", "", "", "subdomain host")
  78. rootCmd.PersistentFlags().Int64VarP(&maxPortsPerClient, "max_ports_per_client", "", 0, "max ports per client")
  79. }
  80. var rootCmd = &cobra.Command{
  81. Use: "frps",
  82. Short: "frps is the server of frp (https://github.com/fatedier/frp)",
  83. RunE: func(cmd *cobra.Command, args []string) error {
  84. if showVersion {
  85. fmt.Println(version.Full())
  86. return nil
  87. }
  88. var err error
  89. if cfgFile != "" {
  90. err = parseServerCommonCfg(CfgFileTypeIni, cfgFile)
  91. } else {
  92. err = parseServerCommonCfg(CfgFileTypeCmd, "")
  93. }
  94. if err != nil {
  95. return err
  96. }
  97. err = runServer()
  98. if err != nil {
  99. fmt.Println(err)
  100. os.Exit(1)
  101. }
  102. return nil
  103. },
  104. }
  105. func Execute() {
  106. if err := rootCmd.Execute(); err != nil {
  107. os.Exit(1)
  108. }
  109. }
  110. func parseServerCommonCfg(fileType int, filePath string) (err error) {
  111. if fileType == CfgFileTypeIni {
  112. err = parseServerCommonCfgFromIni(filePath)
  113. } else if fileType == CfgFileTypeCmd {
  114. err = parseServerCommonCfgFromCmd()
  115. }
  116. if err != nil {
  117. return
  118. }
  119. g.GlbServerCfg.CfgFile = filePath
  120. err = g.GlbServerCfg.ServerCommonConf.Check()
  121. if err != nil {
  122. return
  123. }
  124. config.InitServerCfg(&g.GlbServerCfg.ServerCommonConf)
  125. return
  126. }
  127. func parseServerCommonCfgFromIni(filePath string) (err error) {
  128. b, err := ioutil.ReadFile(filePath)
  129. if err != nil {
  130. return err
  131. }
  132. content := string(b)
  133. cfg, err := config.UnmarshalServerConfFromIni(&g.GlbServerCfg.ServerCommonConf, content)
  134. if err != nil {
  135. return err
  136. }
  137. g.GlbServerCfg.ServerCommonConf = *cfg
  138. return
  139. }
  140. func parseServerCommonCfgFromCmd() (err error) {
  141. g.GlbServerCfg.BindAddr = bindAddr
  142. g.GlbServerCfg.BindPort = bindPort
  143. g.GlbServerCfg.BindUdpPort = bindUdpPort
  144. g.GlbServerCfg.KcpBindPort = kcpBindPort
  145. g.GlbServerCfg.ProxyBindAddr = proxyBindAddr
  146. g.GlbServerCfg.VhostHttpPort = vhostHttpPort
  147. g.GlbServerCfg.VhostHttpsPort = vhostHttpsPort
  148. g.GlbServerCfg.DashboardAddr = dashboardAddr
  149. g.GlbServerCfg.DashboardPort = dashboardPort
  150. g.GlbServerCfg.DashboardUser = dashboardUser
  151. g.GlbServerCfg.DashboardPwd = dashboardPwd
  152. g.GlbServerCfg.LogFile = logFile
  153. g.GlbServerCfg.LogWay = logWay
  154. g.GlbServerCfg.LogLevel = logLevel
  155. g.GlbServerCfg.LogMaxDays = logMaxDays
  156. g.GlbServerCfg.Token = token
  157. g.GlbServerCfg.AuthTimeout = authTimeout
  158. g.GlbServerCfg.SubDomainHost = subDomainHost
  159. g.GlbServerCfg.MaxPortsPerClient = maxPortsPerClient
  160. return
  161. }
  162. func runServer() (err error) {
  163. log.InitLog(g.GlbServerCfg.LogWay, g.GlbServerCfg.LogFile, g.GlbServerCfg.LogLevel,
  164. g.GlbServerCfg.LogMaxDays)
  165. svr, err := server.NewService()
  166. if err != nil {
  167. return err
  168. }
  169. log.Info("Start frps success")
  170. server.ServerService = svr
  171. svr.Run()
  172. return
  173. }