mirror of
				https://github.com/fatedier/frp
				synced 2025-10-20 10:03:07 +08:00 
			
		
		
		
	 aa31d7ad0b
			
		
	
	
		aa31d7ad0b
		
			
		
	
	
	
	
		
			
			* support bandwidth_limit set by server plugin * limiter at proxy level * bandwidth_limit_mode * updates tests for bandwidth_limit_mode default * bandwidth_limit_mode as string * add checkForSrv for bandwidth_limit_mode * bandwidth_limit flags for sub cmds * gci write
		
			
				
	
	
		
			117 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2018 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 sub
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 
 | |
| 	"github.com/spf13/cobra"
 | |
| 
 | |
| 	"github.com/fatedier/frp/pkg/config"
 | |
| 	"github.com/fatedier/frp/pkg/consts"
 | |
| )
 | |
| 
 | |
| func init() {
 | |
| 	RegisterCommonFlags(stcpCmd)
 | |
| 
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&proxyName, "proxy_name", "n", "", "proxy name")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&role, "role", "", "server", "role")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&sk, "sk", "", "", "secret key")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&serverName, "server_name", "", "", "server name")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&localIP, "local_ip", "i", "127.0.0.1", "local ip")
 | |
| 	stcpCmd.PersistentFlags().IntVarP(&localPort, "local_port", "l", 0, "local port")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&bindAddr, "bind_addr", "", "", "bind addr")
 | |
| 	stcpCmd.PersistentFlags().IntVarP(&bindPort, "bind_port", "", 0, "bind port")
 | |
| 	stcpCmd.PersistentFlags().BoolVarP(&useEncryption, "ue", "", false, "use encryption")
 | |
| 	stcpCmd.PersistentFlags().BoolVarP(&useCompression, "uc", "", false, "use compression")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&bandwidthLimit, "bandwidth_limit", "", "", "bandwidth limit")
 | |
| 	stcpCmd.PersistentFlags().StringVarP(&bandwidthLimitMode, "bandwidth_limit_mode", "", config.BandwidthLimitModeClient, "bandwidth limit mode")
 | |
| 
 | |
| 	rootCmd.AddCommand(stcpCmd)
 | |
| }
 | |
| 
 | |
| var stcpCmd = &cobra.Command{
 | |
| 	Use:   "stcp",
 | |
| 	Short: "Run frpc with a single stcp proxy",
 | |
| 	RunE: func(cmd *cobra.Command, args []string) error {
 | |
| 		clientCfg, err := parseClientCommonCfgFromCmd()
 | |
| 		if err != nil {
 | |
| 			fmt.Println(err)
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 
 | |
| 		proxyConfs := make(map[string]config.ProxyConf)
 | |
| 		visitorConfs := make(map[string]config.VisitorConf)
 | |
| 
 | |
| 		var prefix string
 | |
| 		if user != "" {
 | |
| 			prefix = user + "."
 | |
| 		}
 | |
| 
 | |
| 		switch role {
 | |
| 		case "server":
 | |
| 			cfg := &config.STCPProxyConf{}
 | |
| 			cfg.ProxyName = prefix + proxyName
 | |
| 			cfg.ProxyType = consts.STCPProxy
 | |
| 			cfg.UseEncryption = useEncryption
 | |
| 			cfg.UseCompression = useCompression
 | |
| 			cfg.Role = role
 | |
| 			cfg.Sk = sk
 | |
| 			cfg.LocalIP = localIP
 | |
| 			cfg.LocalPort = localPort
 | |
| 			cfg.BandwidthLimit, err = config.NewBandwidthQuantity(bandwidthLimit)
 | |
| 			if err != nil {
 | |
| 				fmt.Println(err)
 | |
| 				os.Exit(1)
 | |
| 			}
 | |
| 			cfg.BandwidthLimitMode = bandwidthLimitMode
 | |
| 			err = cfg.CheckForCli()
 | |
| 			if err != nil {
 | |
| 				fmt.Println(err)
 | |
| 				os.Exit(1)
 | |
| 			}
 | |
| 			proxyConfs[cfg.ProxyName] = cfg
 | |
| 		case "visitor":
 | |
| 			cfg := &config.STCPVisitorConf{}
 | |
| 			cfg.ProxyName = prefix + proxyName
 | |
| 			cfg.ProxyType = consts.STCPProxy
 | |
| 			cfg.UseEncryption = useEncryption
 | |
| 			cfg.UseCompression = useCompression
 | |
| 			cfg.Role = role
 | |
| 			cfg.Sk = sk
 | |
| 			cfg.ServerName = serverName
 | |
| 			cfg.BindAddr = bindAddr
 | |
| 			cfg.BindPort = bindPort
 | |
| 			err = cfg.Check()
 | |
| 			if err != nil {
 | |
| 				fmt.Println(err)
 | |
| 				os.Exit(1)
 | |
| 			}
 | |
| 			visitorConfs[cfg.ProxyName] = cfg
 | |
| 		default:
 | |
| 			fmt.Println("invalid role")
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 
 | |
| 		err = startService(clientCfg, proxyConfs, visitorConfs, "")
 | |
| 		if err != nil {
 | |
| 			fmt.Println(err)
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 		return nil
 | |
| 	},
 | |
| }
 |