X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=unixsocketwatcher.ml;h=f9971562efe802c11784b30718cabbe45c957c82;hb=a877e56110b9cc1fc11b8e747ebec44e18d8b812;hp=4fe845bdc343759d6970a45879c7938bf89f2465;hpb=99f2f33d2b4582259a8100c81497d784b4c84415;p=vsys.git diff --git a/unixsocketwatcher.ml b/unixsocketwatcher.ml index 4fe845b..f997156 100644 --- a/unixsocketwatcher.ml +++ b/unixsocketwatcher.ml @@ -43,42 +43,27 @@ let mkentry fqp exec_fqp perm slice_name = e->logprint "Error creating FIFO: %s->%s. May be something wrong at the frontend.\n" fqp exec_fqp;Failed let receive_event (listening_socket_spec:fname_and_fd) (_:fname_and_fd) = - (* Do we care about this file? *) - try let (_,listening_socket) = listening_socket_spec in + try let (data_socket, addr) = accept listening_socket in match addr with | ADDR_UNIX(fname) -> - let entry_info = try - Hashtbl.find unix_socket_watcher addr with _ -> None in - match entry_info with - | Some(_,execpath,slice_name,fd) -> - begin - let len = String.length fqp_in in - let fqp = String.sub fqp_in 0 (len-3) in - let fqp_out = String.concat "." [fqp;"out"] in - let fifo_fdout = - try openfile fqp_out [O_WRONLY;O_NONBLOCK] 0o777 with - _-> (* The client is opening the descriptor too fast *) - sleep 1;try openfile fqp_out [O_WRONLY;O_NONBLOCK] 0o777 with - _-> - logprint "%s Output pipe not open, using stdout in place of %s\n" slice_name fqp_out;stdout - in - ignore(sigprocmask SIG_BLOCK [Sys.sigchld]); - ( - clear_nonblock fifo_fdin; - let pid=try Some(create_process execpath [|execpath;slice_name|] fifo_fdin fifo_fdout fifo_fdout) with e -> None in - match pid with - | Some(pid) -> - if (fifo_fdout <> stdout) then close_if_open fifo_fdout; - Hashtbl.add pidmap pid (fqp_in,fifo_fdout) - | None ->logprint "Error executing service: %s\n" execpath;reopenentry fqp_in - ); - ignore(sigprocmask SIG_UNBLOCK [Sys.sigchld]); - end - | None -> () - with e-> logprint "Error connecting service %s\n" execpath - | _ -> logprint "Serious error! Got a non UNIX connection over a UNIX socket\n" + begin + let entry_info = + try + Hashtbl.find unix_socket_table fname + with _ -> None in + match entry_info with + | Some(execpath,slice_name,fd) -> + begin + + + + end + | None -> () + end + | _ -> logprint "Serious error! Got a non UNIX connection over a UNIX socket\n" + with e-> logprint "Error accepting socket\n" (** Close sockets that just got removed *) let closeentry fqp =