diff options
| author | James Barnett <noreply@jamesbarnett.xyz> | 2018-12-23 20:42:03 +0000 |
|---|---|---|
| committer | James Barnett <noreply@jamesbarnett.xyz> | 2018-12-23 20:42:03 +0000 |
| commit | b8942fb705dd7461699bfefe1430b38784d0f960 (patch) | |
| tree | b6e77f68d850f00675b1d5de006e022b2c224d03 /slowpoke.go | |
| parent | 1509996c093e41a76be6ad5fd9429f100d65f60c (diff) | |
| download | slowpoke-b8942fb705dd7461699bfefe1430b38784d0f960.tar.xz slowpoke-b8942fb705dd7461699bfefe1430b38784d0f960.zip | |
Add configurable buffer size
Diffstat (limited to 'slowpoke.go')
| -rw-r--r-- | slowpoke.go | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/slowpoke.go b/slowpoke.go index 3178196..98182f6 100644 --- a/slowpoke.go +++ b/slowpoke.go @@ -12,16 +12,18 @@ type Slowpoke struct { conn net.Conn targetAddr string latency time.Duration + bufferSize int isClosed bool close chan bool logger *logging.Logger } -func New(conn net.Conn, targetAddr string, latency time.Duration, logger *logging.Logger) *Slowpoke { +func New(conn net.Conn, targetAddr string, latency time.Duration, bufferSize int, logger *logging.Logger) *Slowpoke { return &Slowpoke{ conn: conn, targetAddr: targetAddr, latency: latency, + bufferSize: bufferSize, isClosed: false, close: make(chan bool), logger: logger, @@ -47,13 +49,12 @@ func (s *Slowpoke) StartTransfer() { s.logger.Infof("Connection between client %s and target %s closed", s.conn.RemoteAddr(), target.RemoteAddr()) } -func createBuffer() []byte { - // TODO configurable - return make([]byte, 1500) +func (s *Slowpoke) createBuffer() []byte { + return make([]byte, s.bufferSize) } func (s *Slowpoke) transferWithLatency(source net.Conn, target net.Conn) { - byteBuffer := createBuffer() + byteBuffer := s.createBuffer() var transferDirection string // If the data source is the client then we are sending |