ADD election des trolls par un daemon chaque semaine
[euphorik.git] / modules / erl / euphorik_requests.erl
index 4af2f7e..f8dad51 100755 (executable)
@@ -9,7 +9,6 @@
    tester/0,\r
    out/1\r
 ]).\r
-\r
 -include_lib("xmerl/include/xmerl.hrl").\r
 -include_lib("yaws/include/yaws_api.hrl").
 
@@ -20,12 +19,13 @@ tester() ->
 
 \r
 out(A) ->
-   %io:format("~p~n~n", [A]),
+   %io:format("~p~n", [A]), % utilisé parfois pendant le debug
    IP = case inet:peername(A#arg.clisock) of
-         {ok, {Adresse, _Port}} -> Adresse;
+      {ok, {Adresse, _Port}} -> Adresse;
       _ -> inconnue
-   end,\r
-   %inet:setopts(A#arg.clisock, inet:getopts(A#arg.clisock, [active])),\r
+   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, IP),
    {content, "application/json", Ret}.\r
@@ -56,5 +56,13 @@ traiter_action("wait_event", JSON, _) ->
 traiter_action("put_message", JSON, _) ->
    euphorik_protocole:put_message(JSON);
 traiter_action("ban", JSON, _) ->
-   euphorik_protocole: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