Mercurial Hosting > luan
changeset 1204:5d0cbd908582
remove Io socket support
add SSL for Rpc
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Tue, 06 Mar 2018 19:48:15 -0700 |
parents | 7e6d132904fd |
children | 8f14426f8ada |
files | src/luan/modules/Io.luan src/luan/modules/IoLuan.java src/luan/modules/Rpc.luan |
diffstat | 3 files changed, 34 insertions(+), 22 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/modules/Io.luan Tue Mar 06 13:29:56 2018 -0700 +++ b/src/luan/modules/Io.luan Tue Mar 06 19:48:15 2018 -0700 @@ -10,7 +10,7 @@ Io.schemes = IoLuan.newSchemes() Io.uri = IoLuan.uri Io.stdin = IoLuan.defaultStdin.table() -Io.socket_server = IoLuan.socket_server +--Io.socket_server = IoLuan.socket_server Io.stdout = IoLuan.textWriter(System.out) Io.stderr = IoLuan.textWriter(System.err) Io.unrestricted = IoLuan.unrestricted
--- a/src/luan/modules/IoLuan.java Tue Mar 06 13:29:56 2018 -0700 +++ b/src/luan/modules/IoLuan.java Tue Mar 06 19:48:15 2018 -0700 @@ -682,7 +682,7 @@ add( schemes, "string", String.class ); add( schemes, "file", LuanState.class, String.class ); add( schemes, "classpath", LuanState.class, String.class ); - add( schemes, "socket", String.class ); +// add( schemes, "socket", String.class ); add( schemes, "http", LuanState.class, String.class, LuanTable.class ); add( schemes, "https", LuanState.class, String.class, LuanTable.class ); add( schemes, "luan", LuanState.class, String.class ); @@ -717,7 +717,7 @@ throw new LuanException( "invalid scheme '"+scheme+"' in '"+name+"'" ); return (LuanTable)Luan.first(opener.call(luan,new Object[]{location,options})); } - +/* public static final class LuanSocket extends LuanIO { public final Socket socket; @@ -778,7 +778,7 @@ } }; } - +*/ public static class BaseOs extends LuanIO { private final String cmd;
--- a/src/luan/modules/Rpc.luan Tue Mar 06 13:29:56 2018 -0700 +++ b/src/luan/modules/Rpc.luan Tue Mar 06 19:48:15 2018 -0700 @@ -1,4 +1,8 @@ java() +local Socket = require "java:java.net.Socket" +local ServerSocket = require "java:java.net.ServerSocket" +local SSLSocketFactory = require "java:javax.net.ssl.SSLSocketFactory" +local SSLServerSocketFactory = require "java:javax.net.ssl.SSLServerSocketFactory" local RpcClient = require "java:luan.lib.rpc.RpcClient" local RpcServer = require "java:luan.lib.rpc.RpcServer" local RpcCall = require "java:luan.lib.rpc.RpcCall" @@ -27,6 +31,8 @@ Rpc.port = 9101 +Rpc.cipher_suite = "SSL_DH_anon_WITH_RC4_128_MD5" + local function java_args(list) for i,v in ipairs(list) do list[i] = JavaLuan.toJava(v) @@ -75,9 +81,8 @@ return binary_in, len_in end -function Rpc.caller(socket) - local java_socket = socket.java.socket - local client = RpcClient.new(java_socket) +local function rpc_caller(socket) + local client = RpcClient.new(socket) return function(fn_name,...) local args = {...} local binary_in, len_in = encode_binary(args) @@ -111,10 +116,8 @@ Rpc.functions = {} -function Rpc.responder(socket,fns) - fns = fns or Rpc.functions - local java_socket = socket.java.socket - local server = RpcServer.new(java_socket) +local function rpc_responder(socket,fns) + local server = RpcServer.new(socket) local responder = {} function responder.is_closed() return server.isClosed() @@ -156,9 +159,15 @@ return responder end_function -function Rpc.remote_socket(socket_uri) - local socket = Io.uri(socket_uri) - local call = Rpc.caller(socket) +function Rpc.remote(domain) + local socket + if Rpc.cipher_suite == nil then + socket = Socket.new(domain,Rpc.port) + else + socket = SSLSocketFactory.getDefault().createSocket(domain,Rpc.port) + socket.setEnabledCipherSuites{Rpc.cipher_suite} + end + local call = rpc_caller(socket) local mt = {} function mt.__index(_,key) return function(...) @@ -170,21 +179,24 @@ return t end_function -function Rpc.remote(domain) - local socket = "socket:"..domain..":"..Rpc.port - return Rpc.remote_socket(socket) -end_function - function Rpc.serve(port,fns) - local socket_server = Io.socket_server(port or Rpc.port) + port = port or Rpc.port + fns = fns or Rpc.functions + local socket_server + if Rpc.cipher_suite == nil then + socket_server = ServerSocket.new(port) + else + socket_server = SSLServerSocketFactory.getDefault().createServerSocket(port) + socket_server.setEnabledCipherSuites{Rpc.cipher_suite} + end while true do try { function() - local socket = socket_server() + local socket = socket_server.accept() local function server() try { function() - local responder = Rpc.responder(socket) + local responder = rpc_responder(socket,fns) while not responder.is_closed() do responder.respond() end