From 87152f8706dd4f6cd6baa8cfd6b496b6734be7c2 Mon Sep 17 00:00:00 2001 From: qk-santi <94850169+qk-santi@users.noreply.github.com> Date: Mon, 12 Feb 2024 09:58:51 +0100 Subject: [PATCH 1/3] define ports by amount, not individually --- src/cli/cli.go | 27 +++++++---- src/croc/croc.go | 102 ++++++++++++++++++++++++++++++++---------- src/croc/croc_test.go | 14 +++--- 3 files changed, 105 insertions(+), 38 deletions(-) diff --git a/src/cli/cli.go b/src/cli/cli.go index 4e8945d96..d91beea1b 100644 --- a/src/cli/cli.go +++ b/src/cli/cli.go @@ -72,7 +72,8 @@ func Run() (err error) { &cli.BoolFlag{Name: "no-local", Usage: "disable local relay when sending"}, &cli.BoolFlag{Name: "no-multi", Usage: "disable multiplexing"}, &cli.BoolFlag{Name: "git", Usage: "enable .gitignore respect / don't send ignored files"}, - &cli.StringFlag{Name: "ports", Value: "9009,9010,9011,9012,9013", Usage: "ports of the local relay (optional)"}, + &cli.IntFlag{Name: "port", Value: 9009, Usage: "base port for the relay"}, + &cli.IntFlag{Name: "transfers", Value: 4, Usage: "number of ports to use for transfers"}, }, HelpName: "croc send", Action: send, @@ -85,7 +86,8 @@ func Run() (err error) { Action: relay, Flags: []cli.Flag{ &cli.StringFlag{Name: "host", Usage: "host of the relay"}, - &cli.StringFlag{Name: "ports", Value: "9009,9010,9011,9012,9013", Usage: "ports of the relay"}, + &cli.IntFlag{Name: "port", Value: 9009, Usage: "base port for the relay"}, + &cli.IntFlag{Name: "transfers", Value: 4, Usage: "number of ports to use for transfers"}, }, }, } @@ -174,10 +176,15 @@ func send(c *cli.Context) (err error) { setDebugLevel(c) comm.Socks5Proxy = c.String("socks5") comm.HttpProxy = c.String("connect") - portsString := c.String("ports") - if portsString == "" { - portsString = "9009,9010,9011,9012,9013" + portString := c.Int("port") + if portString == 0 { + portString = 9009 } + transfersString := c.Int("transfers") + if transfersString == 0 { + transfersString = 4 + } + crocOptions := croc.Options{ SharedSecret: c.String("code"), IsSender: true, @@ -189,7 +196,8 @@ func send(c *cli.Context) (err error) { DisableLocal: c.Bool("no-local"), OnlyLocal: c.Bool("local"), IgnoreStdin: c.Bool("ignore-stdin"), - RelayPorts: strings.Split(portsString, ","), + BasePort: portString, + TransferPorts: transfersString, Ask: c.Bool("ask"), NoMultiplexing: c.Bool("no-multi"), RelayPassword: determinePass(c), @@ -222,8 +230,11 @@ func send(c *cli.Context) (err error) { if !c.IsSet("no-local") { crocOptions.DisableLocal = rememberedOptions.DisableLocal } - if !c.IsSet("ports") && len(rememberedOptions.RelayPorts) > 0 { - crocOptions.RelayPorts = rememberedOptions.RelayPorts + if !c.IsSet("port") && rememberedOptions.BasePort > 0 { + crocOptions.BasePort = rememberedOptions.BasePort + } + if !c.IsSet("transfers") && rememberedOptions.TransferPorts > 0 { + crocOptions.TransferPorts = rememberedOptions.TransferPorts } if !c.IsSet("code") { crocOptions.SharedSecret = rememberedOptions.SharedSecret diff --git a/src/croc/croc.go b/src/croc/croc.go index a4e23a195..10cebd1e3 100644 --- a/src/croc/croc.go +++ b/src/croc/croc.go @@ -60,7 +60,8 @@ type Options struct { Debug bool RelayAddress string RelayAddress6 string - RelayPorts []string + BasePort int + TransferPorts int RelayPassword string Stdout bool NoPrompt bool @@ -529,21 +530,26 @@ func (c *Client) sendCollectFiles(filesInfo []FileInfo) (err error) { func (c *Client) setupLocalRelay() { // setup the relay locally - firstPort, _ := strconv.Atoi(c.Options.RelayPorts[0]) - openPorts := utils.FindOpenPorts("127.0.0.1", firstPort, len(c.Options.RelayPorts)) - if len(openPorts) < len(c.Options.RelayPorts) { + basePort := c.Options.BasePort + transferPorts := c.Options.TransferPorts + ports := make([]string, transferPorts+1) + for i := range ports { + ports[i] = strconv.Itoa(basePort + i) + } + openPorts := utils.FindOpenPorts("127.0.0.1", basePort, transferPorts+1) + if len(openPorts) < len(ports) { panic("not enough open ports to run local relay") } for i, port := range openPorts { - c.Options.RelayPorts[i] = fmt.Sprint(port) + ports[i] = fmt.Sprint(port) } - for _, port := range c.Options.RelayPorts { + for _, port := range ports { go func(portStr string) { debugString := "warn" if c.Options.Debug { debugString = "debug" } - err := tcp.Run(debugString, "127.0.0.1", portStr, c.Options.RelayPassword, strings.Join(c.Options.RelayPorts[1:], ",")) + err := tcp.Run(debugString, "127.0.0.1", portStr, c.Options.RelayPassword, fmt.Sprintf(strconv.Itoa(basePort)+","+strconv.Itoa(transferPorts))) if err != nil { panic(err) } @@ -562,7 +568,7 @@ func (c *Client) broadcastOnLocalNetwork(useipv6 bool) { // look for peers first settings := peerdiscovery.Settings{ Limit: -1, - Payload: []byte("croc" + c.Options.RelayPorts[0]), + Payload: []byte("croc" + strconv.Itoa(c.Options.BasePort)), Delay: 20 * time.Millisecond, TimeLimit: timeLimit, } @@ -582,10 +588,10 @@ func (c *Client) transferOverLocalRelay(errchan chan<- error) { time.Sleep(500 * time.Millisecond) log.Debug("establishing connection") var banner string - conn, banner, ipaddr, err := tcp.ConnectToTCPServer("127.0.0.1:"+c.Options.RelayPorts[0], c.Options.RelayPassword, c.Options.SharedSecret[:3]) + conn, banner, ipaddr, err := tcp.ConnectToTCPServer("127.0.0.1:"+strconv.Itoa(c.Options.BasePort), c.Options.RelayPassword, c.Options.SharedSecret[:3]) log.Debugf("banner: %s", banner) if err != nil { - err = fmt.Errorf("could not connect to 127.0.0.1:%s: %w", c.Options.RelayPorts[0], err) + err = fmt.Errorf("could not connect to 127.0.0.1:%s: %w", c.Options.BasePort, err) log.Debug(err) // not really an error because it will try to connect over the actual relay return @@ -604,10 +610,26 @@ func (c *Client) transferOverLocalRelay(errchan chan<- error) { c.conn[0] = conn log.Debug("exchanged header message") c.Options.RelayAddress = "127.0.0.1" - c.Options.RelayPorts = strings.Split(banner, ",") + var basePort, transferPorts int + banner_split := strings.Split(banner, ",") + if len(banner_split) != 2 { + panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) + } + basePort, err = strconv.Atoi(banner_split[0]) + if err == nil { + c.Options.BasePort = basePort + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } + transferPorts, err = strconv.Atoi(banner_split[1]) + if err == nil { + c.Options.TransferPorts = transferPorts + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} + c.Options.TransferPorts = 1 } c.ExternalIP = ipaddr errchan <- c.transfer() @@ -705,7 +727,7 @@ func (c *Client) Send(filesInfo []FileInfo, emptyFoldersToTransfer []FileInfo, t log.Debugf("error getting local ips: %v", err) } // prepend the port that is being listened to - ips = append([]string{c.Options.RelayPorts[0]}, ips...) + ips = append([]string{strconv.Itoa(c.Options.BasePort)}, ips...) } bips, _ := json.Marshal(ips) if err = conn.Send(bips); err != nil { @@ -725,10 +747,26 @@ func (c *Client) Send(filesInfo []FileInfo, emptyFoldersToTransfer []FileInfo, t } c.conn[0] = conn - c.Options.RelayPorts = strings.Split(banner, ",") + var basePort, transferPorts int + banner_split := strings.Split(banner, ",") + if len(banner_split) != 2 { + panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) + } + basePort, err = strconv.Atoi(banner_split[0]) + if err == nil { + c.Options.BasePort = basePort + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } + transferPorts, err = strconv.Atoi(banner_split[1]) + if err == nil { + c.Options.TransferPorts = transferPorts + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} + c.Options.TransferPorts = 1 } c.ExternalIP = ipaddr log.Debug("exchanged header message") @@ -948,10 +986,26 @@ func (c *Client) Receive() (err error) { if err = c.conn[0].Send(handshakeRequest); err != nil { log.Errorf("handshake send error: %v", err) } - c.Options.RelayPorts = strings.Split(banner, ",") + var basePort, transferPorts int + banner_split := strings.Split(banner, ",") + if len(banner_split) != 2 { + panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) + } + basePort, err = strconv.Atoi(banner_split[0]) + if err == nil { + c.Options.BasePort = basePort + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } + transferPorts, err = strconv.Atoi(banner_split[1]) + if err == nil { + c.Options.TransferPorts = transferPorts + } else { + panic(fmt.Sprintf("could not get transfer ports: %v", err)) + } if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} + c.Options.TransferPorts = 1 } log.Debug("exchanged header message") fmt.Fprintf(os.Stderr, "\rsecuring channel...") @@ -1255,9 +1309,9 @@ func (c *Client) processMessagePake(m message.Message) (err error) { // connects to the other ports of the server for transfer var wg sync.WaitGroup - wg.Add(len(c.Options.RelayPorts)) - for i := 0; i < len(c.Options.RelayPorts); i++ { - log.Debugf("port: [%s]", c.Options.RelayPorts[i]) + wg.Add(c.Options.TransferPorts + 1) + for i := 0; i <= c.Options.TransferPorts; i++ { + log.Debugf("port: [%d]", c.Options.BasePort+i) go func(j int) { defer wg.Done() var host string @@ -1270,7 +1324,7 @@ func (c *Client) processMessagePake(m message.Message) (err error) { return } } - server := net.JoinHostPort(host, c.Options.RelayPorts[j]) + server := net.JoinHostPort(host, strconv.Itoa(c.Options.BasePort+j)) log.Debugf("connecting to %s", server) c.conn[j+1], _, _, err = tcp.ConnectToTCPServer( server, @@ -1748,7 +1802,7 @@ func (c *Client) updateState() (err error) { if err != nil { return } - for i := 0; i < len(c.Options.RelayPorts); i++ { + for i := 0; i <= c.Options.TransferPorts; i++ { log.Debugf("starting sending over comm %d", i) go c.sendData(i) } @@ -1861,7 +1915,7 @@ func (c *Client) sendData(i int) { defer func() { log.Debugf("finished with %d", i) c.numfinished++ - if c.numfinished == len(c.Options.RelayPorts) { + if c.numfinished == c.Options.TransferPorts+1 { log.Debug("closing file") if err := c.fread.Close(); err != nil { log.Errorf("error closing file: %v", err) @@ -1885,7 +1939,7 @@ func (c *Client) sendData(i int) { time.Sleep(r.Delay()) } - if math.Mod(curi, float64(len(c.Options.RelayPorts))) == float64(i) { + if math.Mod(curi, float64(c.Options.TransferPorts+1)) == float64(i) { // check to see if this is a chunk that the recipient wants usableChunk := true c.mutex.Lock() diff --git a/src/croc/croc_test.go b/src/croc/croc_test.go index 445ec5afe..0a4447d69 100644 --- a/src/croc/croc_test.go +++ b/src/croc/croc_test.go @@ -18,7 +18,7 @@ import ( func init() { log.SetLevel("trace") - go tcp.Run("debug", "127.0.0.1", "8281", "pass123", "8282,8283,8284,8285") + go tcp.Run("debug", "127.0.0.1", "8281", "pass123", "8281,4") go tcp.Run("debug", "127.0.0.1", "8282", "pass123") go tcp.Run("debug", "127.0.0.1", "8283", "pass123") go tcp.Run("debug", "127.0.0.1", "8284", "pass123") @@ -35,7 +35,7 @@ func TestCrocReadme(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - RelayPorts: []string{"8281"}, + BasePort: 8281, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -102,7 +102,7 @@ func TestCrocEmptyFolder(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - RelayPorts: []string{"8281"}, + BasePort: 8281, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -169,7 +169,7 @@ func TestCrocSymlink(t *testing.T) { SharedSecret: "8124-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - RelayPorts: []string{"8281"}, + BasePort: 8281, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -271,7 +271,8 @@ func TestCrocLocal(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8181", - RelayPorts: []string{"8181", "8182"}, + BasePort: 8181, + TransferPorts: 1, RelayPassword: "pass123", Stdout: true, NoPrompt: true, @@ -351,7 +352,8 @@ func TestCrocError(t *testing.T) { SharedSecret: "8123-testingthecroc2", Debug: true, RelayAddress: "doesntexistok.com:8381", - RelayPorts: []string{"8381", "8382"}, + BasePort: 8381, + TransferPorts: 1, RelayPassword: "pass123", Stdout: true, NoPrompt: true, From c83eb59963d1689614336d6d42ac5ba887e77f79 Mon Sep 17 00:00:00 2001 From: qk-santi <94850169+qk-santi@users.noreply.github.com> Date: Sat, 17 Feb 2024 18:41:41 +0100 Subject: [PATCH 2/3] Revert "define ports by amount, not individually" This reverts commit 87152f8706dd4f6cd6baa8cfd6b496b6734be7c2. --- src/cli/cli.go | 27 ++++------- src/croc/croc.go | 102 ++++++++++-------------------------------- src/croc/croc_test.go | 14 +++--- 3 files changed, 38 insertions(+), 105 deletions(-) diff --git a/src/cli/cli.go b/src/cli/cli.go index d91beea1b..4e8945d96 100644 --- a/src/cli/cli.go +++ b/src/cli/cli.go @@ -72,8 +72,7 @@ func Run() (err error) { &cli.BoolFlag{Name: "no-local", Usage: "disable local relay when sending"}, &cli.BoolFlag{Name: "no-multi", Usage: "disable multiplexing"}, &cli.BoolFlag{Name: "git", Usage: "enable .gitignore respect / don't send ignored files"}, - &cli.IntFlag{Name: "port", Value: 9009, Usage: "base port for the relay"}, - &cli.IntFlag{Name: "transfers", Value: 4, Usage: "number of ports to use for transfers"}, + &cli.StringFlag{Name: "ports", Value: "9009,9010,9011,9012,9013", Usage: "ports of the local relay (optional)"}, }, HelpName: "croc send", Action: send, @@ -86,8 +85,7 @@ func Run() (err error) { Action: relay, Flags: []cli.Flag{ &cli.StringFlag{Name: "host", Usage: "host of the relay"}, - &cli.IntFlag{Name: "port", Value: 9009, Usage: "base port for the relay"}, - &cli.IntFlag{Name: "transfers", Value: 4, Usage: "number of ports to use for transfers"}, + &cli.StringFlag{Name: "ports", Value: "9009,9010,9011,9012,9013", Usage: "ports of the relay"}, }, }, } @@ -176,15 +174,10 @@ func send(c *cli.Context) (err error) { setDebugLevel(c) comm.Socks5Proxy = c.String("socks5") comm.HttpProxy = c.String("connect") - portString := c.Int("port") - if portString == 0 { - portString = 9009 + portsString := c.String("ports") + if portsString == "" { + portsString = "9009,9010,9011,9012,9013" } - transfersString := c.Int("transfers") - if transfersString == 0 { - transfersString = 4 - } - crocOptions := croc.Options{ SharedSecret: c.String("code"), IsSender: true, @@ -196,8 +189,7 @@ func send(c *cli.Context) (err error) { DisableLocal: c.Bool("no-local"), OnlyLocal: c.Bool("local"), IgnoreStdin: c.Bool("ignore-stdin"), - BasePort: portString, - TransferPorts: transfersString, + RelayPorts: strings.Split(portsString, ","), Ask: c.Bool("ask"), NoMultiplexing: c.Bool("no-multi"), RelayPassword: determinePass(c), @@ -230,11 +222,8 @@ func send(c *cli.Context) (err error) { if !c.IsSet("no-local") { crocOptions.DisableLocal = rememberedOptions.DisableLocal } - if !c.IsSet("port") && rememberedOptions.BasePort > 0 { - crocOptions.BasePort = rememberedOptions.BasePort - } - if !c.IsSet("transfers") && rememberedOptions.TransferPorts > 0 { - crocOptions.TransferPorts = rememberedOptions.TransferPorts + if !c.IsSet("ports") && len(rememberedOptions.RelayPorts) > 0 { + crocOptions.RelayPorts = rememberedOptions.RelayPorts } if !c.IsSet("code") { crocOptions.SharedSecret = rememberedOptions.SharedSecret diff --git a/src/croc/croc.go b/src/croc/croc.go index 10cebd1e3..a4e23a195 100644 --- a/src/croc/croc.go +++ b/src/croc/croc.go @@ -60,8 +60,7 @@ type Options struct { Debug bool RelayAddress string RelayAddress6 string - BasePort int - TransferPorts int + RelayPorts []string RelayPassword string Stdout bool NoPrompt bool @@ -530,26 +529,21 @@ func (c *Client) sendCollectFiles(filesInfo []FileInfo) (err error) { func (c *Client) setupLocalRelay() { // setup the relay locally - basePort := c.Options.BasePort - transferPorts := c.Options.TransferPorts - ports := make([]string, transferPorts+1) - for i := range ports { - ports[i] = strconv.Itoa(basePort + i) - } - openPorts := utils.FindOpenPorts("127.0.0.1", basePort, transferPorts+1) - if len(openPorts) < len(ports) { + firstPort, _ := strconv.Atoi(c.Options.RelayPorts[0]) + openPorts := utils.FindOpenPorts("127.0.0.1", firstPort, len(c.Options.RelayPorts)) + if len(openPorts) < len(c.Options.RelayPorts) { panic("not enough open ports to run local relay") } for i, port := range openPorts { - ports[i] = fmt.Sprint(port) + c.Options.RelayPorts[i] = fmt.Sprint(port) } - for _, port := range ports { + for _, port := range c.Options.RelayPorts { go func(portStr string) { debugString := "warn" if c.Options.Debug { debugString = "debug" } - err := tcp.Run(debugString, "127.0.0.1", portStr, c.Options.RelayPassword, fmt.Sprintf(strconv.Itoa(basePort)+","+strconv.Itoa(transferPorts))) + err := tcp.Run(debugString, "127.0.0.1", portStr, c.Options.RelayPassword, strings.Join(c.Options.RelayPorts[1:], ",")) if err != nil { panic(err) } @@ -568,7 +562,7 @@ func (c *Client) broadcastOnLocalNetwork(useipv6 bool) { // look for peers first settings := peerdiscovery.Settings{ Limit: -1, - Payload: []byte("croc" + strconv.Itoa(c.Options.BasePort)), + Payload: []byte("croc" + c.Options.RelayPorts[0]), Delay: 20 * time.Millisecond, TimeLimit: timeLimit, } @@ -588,10 +582,10 @@ func (c *Client) transferOverLocalRelay(errchan chan<- error) { time.Sleep(500 * time.Millisecond) log.Debug("establishing connection") var banner string - conn, banner, ipaddr, err := tcp.ConnectToTCPServer("127.0.0.1:"+strconv.Itoa(c.Options.BasePort), c.Options.RelayPassword, c.Options.SharedSecret[:3]) + conn, banner, ipaddr, err := tcp.ConnectToTCPServer("127.0.0.1:"+c.Options.RelayPorts[0], c.Options.RelayPassword, c.Options.SharedSecret[:3]) log.Debugf("banner: %s", banner) if err != nil { - err = fmt.Errorf("could not connect to 127.0.0.1:%s: %w", c.Options.BasePort, err) + err = fmt.Errorf("could not connect to 127.0.0.1:%s: %w", c.Options.RelayPorts[0], err) log.Debug(err) // not really an error because it will try to connect over the actual relay return @@ -610,26 +604,10 @@ func (c *Client) transferOverLocalRelay(errchan chan<- error) { c.conn[0] = conn log.Debug("exchanged header message") c.Options.RelayAddress = "127.0.0.1" - var basePort, transferPorts int - banner_split := strings.Split(banner, ",") - if len(banner_split) != 2 { - panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) - } - basePort, err = strconv.Atoi(banner_split[0]) - if err == nil { - c.Options.BasePort = basePort - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } - transferPorts, err = strconv.Atoi(banner_split[1]) - if err == nil { - c.Options.TransferPorts = transferPorts - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } + c.Options.RelayPorts = strings.Split(banner, ",") if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.TransferPorts = 1 + c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} } c.ExternalIP = ipaddr errchan <- c.transfer() @@ -727,7 +705,7 @@ func (c *Client) Send(filesInfo []FileInfo, emptyFoldersToTransfer []FileInfo, t log.Debugf("error getting local ips: %v", err) } // prepend the port that is being listened to - ips = append([]string{strconv.Itoa(c.Options.BasePort)}, ips...) + ips = append([]string{c.Options.RelayPorts[0]}, ips...) } bips, _ := json.Marshal(ips) if err = conn.Send(bips); err != nil { @@ -747,26 +725,10 @@ func (c *Client) Send(filesInfo []FileInfo, emptyFoldersToTransfer []FileInfo, t } c.conn[0] = conn - var basePort, transferPorts int - banner_split := strings.Split(banner, ",") - if len(banner_split) != 2 { - panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) - } - basePort, err = strconv.Atoi(banner_split[0]) - if err == nil { - c.Options.BasePort = basePort - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } - transferPorts, err = strconv.Atoi(banner_split[1]) - if err == nil { - c.Options.TransferPorts = transferPorts - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } + c.Options.RelayPorts = strings.Split(banner, ",") if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.TransferPorts = 1 + c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} } c.ExternalIP = ipaddr log.Debug("exchanged header message") @@ -986,26 +948,10 @@ func (c *Client) Receive() (err error) { if err = c.conn[0].Send(handshakeRequest); err != nil { log.Errorf("handshake send error: %v", err) } - var basePort, transferPorts int - banner_split := strings.Split(banner, ",") - if len(banner_split) != 2 { - panic(fmt.Sprintf("Expected port and number of transfer ports in banner: %v", banner)) - } - basePort, err = strconv.Atoi(banner_split[0]) - if err == nil { - c.Options.BasePort = basePort - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } - transferPorts, err = strconv.Atoi(banner_split[1]) - if err == nil { - c.Options.TransferPorts = transferPorts - } else { - panic(fmt.Sprintf("could not get transfer ports: %v", err)) - } + c.Options.RelayPorts = strings.Split(banner, ",") if c.Options.NoMultiplexing { log.Debug("no multiplexing") - c.Options.TransferPorts = 1 + c.Options.RelayPorts = []string{c.Options.RelayPorts[0]} } log.Debug("exchanged header message") fmt.Fprintf(os.Stderr, "\rsecuring channel...") @@ -1309,9 +1255,9 @@ func (c *Client) processMessagePake(m message.Message) (err error) { // connects to the other ports of the server for transfer var wg sync.WaitGroup - wg.Add(c.Options.TransferPorts + 1) - for i := 0; i <= c.Options.TransferPorts; i++ { - log.Debugf("port: [%d]", c.Options.BasePort+i) + wg.Add(len(c.Options.RelayPorts)) + for i := 0; i < len(c.Options.RelayPorts); i++ { + log.Debugf("port: [%s]", c.Options.RelayPorts[i]) go func(j int) { defer wg.Done() var host string @@ -1324,7 +1270,7 @@ func (c *Client) processMessagePake(m message.Message) (err error) { return } } - server := net.JoinHostPort(host, strconv.Itoa(c.Options.BasePort+j)) + server := net.JoinHostPort(host, c.Options.RelayPorts[j]) log.Debugf("connecting to %s", server) c.conn[j+1], _, _, err = tcp.ConnectToTCPServer( server, @@ -1802,7 +1748,7 @@ func (c *Client) updateState() (err error) { if err != nil { return } - for i := 0; i <= c.Options.TransferPorts; i++ { + for i := 0; i < len(c.Options.RelayPorts); i++ { log.Debugf("starting sending over comm %d", i) go c.sendData(i) } @@ -1915,7 +1861,7 @@ func (c *Client) sendData(i int) { defer func() { log.Debugf("finished with %d", i) c.numfinished++ - if c.numfinished == c.Options.TransferPorts+1 { + if c.numfinished == len(c.Options.RelayPorts) { log.Debug("closing file") if err := c.fread.Close(); err != nil { log.Errorf("error closing file: %v", err) @@ -1939,7 +1885,7 @@ func (c *Client) sendData(i int) { time.Sleep(r.Delay()) } - if math.Mod(curi, float64(c.Options.TransferPorts+1)) == float64(i) { + if math.Mod(curi, float64(len(c.Options.RelayPorts))) == float64(i) { // check to see if this is a chunk that the recipient wants usableChunk := true c.mutex.Lock() diff --git a/src/croc/croc_test.go b/src/croc/croc_test.go index 0a4447d69..445ec5afe 100644 --- a/src/croc/croc_test.go +++ b/src/croc/croc_test.go @@ -18,7 +18,7 @@ import ( func init() { log.SetLevel("trace") - go tcp.Run("debug", "127.0.0.1", "8281", "pass123", "8281,4") + go tcp.Run("debug", "127.0.0.1", "8281", "pass123", "8282,8283,8284,8285") go tcp.Run("debug", "127.0.0.1", "8282", "pass123") go tcp.Run("debug", "127.0.0.1", "8283", "pass123") go tcp.Run("debug", "127.0.0.1", "8284", "pass123") @@ -35,7 +35,7 @@ func TestCrocReadme(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - BasePort: 8281, + RelayPorts: []string{"8281"}, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -102,7 +102,7 @@ func TestCrocEmptyFolder(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - BasePort: 8281, + RelayPorts: []string{"8281"}, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -169,7 +169,7 @@ func TestCrocSymlink(t *testing.T) { SharedSecret: "8124-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8281", - BasePort: 8281, + RelayPorts: []string{"8281"}, RelayPassword: "pass123", Stdout: false, NoPrompt: true, @@ -271,8 +271,7 @@ func TestCrocLocal(t *testing.T) { SharedSecret: "8123-testingthecroc", Debug: true, RelayAddress: "127.0.0.1:8181", - BasePort: 8181, - TransferPorts: 1, + RelayPorts: []string{"8181", "8182"}, RelayPassword: "pass123", Stdout: true, NoPrompt: true, @@ -352,8 +351,7 @@ func TestCrocError(t *testing.T) { SharedSecret: "8123-testingthecroc2", Debug: true, RelayAddress: "doesntexistok.com:8381", - BasePort: 8381, - TransferPorts: 1, + RelayPorts: []string{"8381", "8382"}, RelayPassword: "pass123", Stdout: true, NoPrompt: true, From e1644401dad356fb4aa31434cd2ea7f666b54f39 Mon Sep 17 00:00:00 2001 From: qk-santi <94850169+qk-santi@users.noreply.github.com> Date: Sat, 17 Feb 2024 19:09:53 +0100 Subject: [PATCH 3/3] version compatible basePort and transfers --- src/cli/cli.go | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/src/cli/cli.go b/src/cli/cli.go index 4e8945d96..ed4d78674 100644 --- a/src/cli/cli.go +++ b/src/cli/cli.go @@ -72,7 +72,8 @@ func Run() (err error) { &cli.BoolFlag{Name: "no-local", Usage: "disable local relay when sending"}, &cli.BoolFlag{Name: "no-multi", Usage: "disable multiplexing"}, &cli.BoolFlag{Name: "git", Usage: "enable .gitignore respect / don't send ignored files"}, - &cli.StringFlag{Name: "ports", Value: "9009,9010,9011,9012,9013", Usage: "ports of the local relay (optional)"}, + &cli.IntFlag{Name: "port", Value: 9009, Usage: "base port for the relay"}, + &cli.IntFlag{Name: "transfers", Value: 4, Usage: "number of ports to use for transfers"}, }, HelpName: "croc send", Action: send, @@ -174,10 +175,21 @@ func send(c *cli.Context) (err error) { setDebugLevel(c) comm.Socks5Proxy = c.String("socks5") comm.HttpProxy = c.String("connect") - portsString := c.String("ports") - if portsString == "" { - portsString = "9009,9010,9011,9012,9013" + + portParam := c.Int("port") + if portParam == 0 { + portParam = 9009 + } + transfersParam := c.Int("transfers") + if transfersParam == 0 { + transfersParam = 4 } + + ports := make([]string, transfersParam+1) + for i := 0; i <= transfersParam; i++ { + ports[i] = strconv.Itoa(portParam + i) + } + crocOptions := croc.Options{ SharedSecret: c.String("code"), IsSender: true, @@ -189,7 +201,7 @@ func send(c *cli.Context) (err error) { DisableLocal: c.Bool("no-local"), OnlyLocal: c.Bool("local"), IgnoreStdin: c.Bool("ignore-stdin"), - RelayPorts: strings.Split(portsString, ","), + RelayPorts: ports, Ask: c.Bool("ask"), NoMultiplexing: c.Bool("no-multi"), RelayPassword: determinePass(c),