FIX bug du process qui ne se terminait pas lorsque la connexion tcp était fermé ...
[euphorik.git] / modules / erl / euphorik_requests.erl
index 6562e52..edc0e17 100755 (executable)
@@ -20,10 +20,15 @@ tester() ->
 
 \r
 out(A) ->
-   %io:format("~p~n~n", [A]),\r
-   %inet:setopts(A#arg.clisock, inet:getopts(A#arg.clisock, [active])),\r
+   %io:format("~p~n", [A]), % utilisé parfois pendant le debug
+   IP = case inet:peername(A#arg.clisock) of
+      {ok, {Adresse, _Port}} -> Adresse;
+      _ -> inconnue
+   end,
+   % passive -> active, permet de recevoir {tcp_closed, _} lorsque le socket se ferme\r
+   inet:setopts(A#arg.clisock, [{active, true}]),\r
    {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)),\r
-   Ret = traiter_donnees(Contenu, 1),
+   Ret = traiter_donnees(Contenu, IP),
    {content, "application/json", Ret}.\r
 
 \r
@@ -37,8 +42,8 @@ traiter_donnees(Contenu, IP) ->
    
 
 % authentification d'un client
-traiter_action("authentification", JSON, _) ->
-   euphorik_protocole:login(JSON);
+traiter_action("authentification", JSON, IP) ->
+   euphorik_protocole:login(JSON, IP);
 % un client s'enregistre (pseudo + password)
 traiter_action("register", JSON, IP) ->
    euphorik_protocole:register(JSON, IP);
@@ -50,5 +55,15 @@ traiter_action("wait_event", JSON, _) ->
    euphorik_protocole:wait_event(JSON);
 % un utilisateur envoie un message
 traiter_action("put_message", JSON, _) ->
-   euphorik_protocole:put_message(JSON).
+   euphorik_protocole:put_message(JSON);
+traiter_action("ban", JSON, _) ->
+   euphorik_protocole:ban(JSON);
+traiter_action("slap", JSON, _) ->
+   euphorik_protocole:slap(JSON);
+traiter_action("put_troll", JSON, _) ->
+   euphorik_protocole:put_troll(JSON);
+traiter_action("mod_troll", JSON, _) ->
+   euphorik_protocole:mod_troll(JSON);
+traiter_action("del_troll", JSON, _) ->
+   euphorik_protocole:del_troll(JSON).
  
\ No newline at end of file