66 lines
2.0 KiB
Lua
66 lines
2.0 KiB
Lua
|
-- load our favourite library
|
||
|
local dispatch = require("dispatch")
|
||
|
local handler = dispatch.newhandler()
|
||
|
|
||
|
-- make sure the user knows how to invoke us
|
||
|
if table.getn(arg) < 1 then
|
||
|
print("Usage")
|
||
|
print(" lua forward.lua <iport:ohost:oport> ...")
|
||
|
os.exit(1)
|
||
|
end
|
||
|
|
||
|
-- function to move data from one socket to the other
|
||
|
local function move(foo, bar)
|
||
|
local live
|
||
|
while 1 do
|
||
|
local data, error, partial = foo:receive(2048)
|
||
|
live = data or error == "timeout"
|
||
|
data = data or partial
|
||
|
local result, error = bar:send(data)
|
||
|
if not live or not result then
|
||
|
foo:close()
|
||
|
bar:close()
|
||
|
break
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
-- for each tunnel, start a new server
|
||
|
for i, v in ipairs(arg) do
|
||
|
-- capture forwarding parameters
|
||
|
local _, _, iport, ohost, oport = string.find(v, "([^:]+):([^:]+):([^:]+)")
|
||
|
assert(iport, "invalid arguments")
|
||
|
-- create our server socket
|
||
|
local server = assert(handler.tcp())
|
||
|
assert(server:setoption("reuseaddr", true))
|
||
|
assert(server:bind("*", iport))
|
||
|
assert(server:listen(32))
|
||
|
-- handler for the server object loops accepting new connections
|
||
|
handler:start(function()
|
||
|
while 1 do
|
||
|
local client = assert(server:accept())
|
||
|
assert(client:settimeout(0))
|
||
|
-- for each new connection, start a new client handler
|
||
|
handler:start(function()
|
||
|
-- handler tries to connect to peer
|
||
|
local peer = assert(handler.tcp())
|
||
|
assert(peer:settimeout(0))
|
||
|
assert(peer:connect(ohost, oport))
|
||
|
-- if sucessful, starts a new handler to send data from
|
||
|
-- client to peer
|
||
|
handler:start(function()
|
||
|
move(client, peer)
|
||
|
end)
|
||
|
-- afte starting new handler, enter in loop sending data from
|
||
|
-- peer to client
|
||
|
move(peer, client)
|
||
|
end)
|
||
|
end
|
||
|
end)
|
||
|
end
|
||
|
|
||
|
-- simply loop stepping the server
|
||
|
while 1 do
|
||
|
handler:step()
|
||
|
end
|