From 7e3e4a611d7b1088c01602f3f9c3745d8c9174c7 Mon Sep 17 00:00:00 2001 From: 9seconds Date: Tue, 9 Aug 2022 17:02:06 +0300 Subject: [PATCH] Add parameter for a simple run that sets socks5 proxies up --- internal/cli/simple_run.go | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/internal/cli/simple_run.go b/internal/cli/simple_run.go index f03d1bc02..e633aba6a 100644 --- a/internal/cli/simple_run.go +++ b/internal/cli/simple_run.go @@ -20,10 +20,11 @@ type SimpleRun struct { DomainFrontingPort uint64 `kong:"name='domain-fronting-port',short='p',default='443',help='A port to access for domain fronting.'"` //nolint: lll DOHIP net.IP `kong:"name='doh-ip',short='n',default='9.9.9.9',help='IP address of DNS-over-HTTP to use.'"` //nolint: lll Timeout time.Duration `kong:"name='timeout',short='t',default='10s',help='Network timeout to use'"` //nolint: lll + Socks5Proxies []string `kong:"name='socks5-proxy',short='s',help='Socks5 proxies to use for network access.'"` //nolint: lll AntiReplayCacheSize string `kong:"name='antireplay-cache-size',short='a',default='1MB',help='A size of anti-replay cache to use.'"` //nolint: lll } -func (s *SimpleRun) Run(cli *CLI, version string) error { //nolint: cyclop +func (s *SimpleRun) Run(cli *CLI, version string) error { //nolint: cyclop,funlen conf := &config.Config{} if err := conf.BindTo.Set(s.BindTo); err != nil { @@ -66,6 +67,16 @@ func (s *SimpleRun) Run(cli *CLI, version string) error { //nolint: cyclop return fmt.Errorf("incorrect antireplay-cache-size: %w", err) } + for _, v := range s.Socks5Proxies { + proxyURL := config.TypeProxyURL{} + + if err := proxyURL.Set(v); err != nil { + return fmt.Errorf("incorrect socks5 proxy URL: %w", err) + } + + conf.Network.Proxies = append(conf.Network.Proxies, proxyURL) + } + conf.Debug.Value = s.Debug conf.AllowFallbackOnUnknownDC.Value = true conf.Defense.AntiReplay.Enabled.Value = true