ADD ajout d'une version de protocole, chaque message du client est taggé avec la...
[euphorik.git] / modules / erl / euphorik_requests.erl
index 28019da..616d0e7 100755 (executable)
 % \r
 % Ce module est fait pour répondre à des requêtes 'AJAX'.\r
 % Il est définit comme 'appmods' pour l'url "request" dans yaws.\r
-% Par exemple http://www.euphorik.ch/request abouti sur la fonction out() de ce module.
-% @author G.Burri
+% Par exemple http://www.euphorik.ch/request abouti sur la fonction out() de ce module.\r
+% @author G.Burri\r
+\r
 \r
-
 -module(euphorik_requests).\r
 -export([out/1]).\r
 -include_lib("xmerl/include/xmerl.hrl").\r
--include_lib("yaws/include/yaws_api.hrl").
-
+-include_lib("yaws/include/yaws_api.hrl").\r
+-include("../include/euphorik_defines.hrl").\r
+\r
 \r
-out(A) ->
-   %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
+out(A) ->\r
+   %io:format("~p~n", [A]), % utilisé parfois pendant le debug\r
+   IP = case inet:peername(A#arg.clisock) of\r
+      {ok, {Adresse, _Port}} -> Adresse;\r
+      _ -> inconnue\r
+   end,\r
+   % passive -> active, permet de recevoir {tcp_closed, _} lorsque le socket se ferme\r
    % keepalive -> true, evite que des firewalls coupe la connexion TCP sans prévenir\r
    inet:setopts(A#arg.clisock, [{active, true}, {keepalive, true}]),\r
    {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)),\r
-   Ret = traiter_donnees(Contenu, IP),
+   Ret = traiter_donnees(Contenu, IP),\r
    {content, "application/json", Ret}.\r
-
 \r
-traiter_donnees(Contenu, IP) ->
-   case json:decode_string(Contenu) of
-      {ok, {struct, [{action, Action}| Reste]}} ->
-         json:encode(traiter_action(Action, Reste, IP));
-      _ ->
-         error
-   end.
-   
-
-% authentification d'un client
-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);
-% modification du profile
-traiter_action("set_profile", JSON, _) ->
-   euphorik_protocole:profile(JSON);
-% un utilisateur attend un événement (par exemple l'arrivé d'un nouveau message)
-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);
-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);
-traiter_action("list_banned_ips", JSON, _) ->
-   euphorik_protocole:list_banned_ips(JSON);
-traiter_action("unban", JSON, _) ->
-   euphorik_protocole:unban_ip(JSON).
+\r
+% Décode les données JSON.\r
+traiter_donnees(Contenu, IP) ->\r
+   {ok, {struct, [{header, {struct, [{action, Action}, {version, Version_client}]}} | Reste]}} = json:decode_string(Contenu),\r
+   json:encode(\r
+      if Version_client =:= ?VERSION_PROTOCOLE ->\r
+            traiter_action(Action, Reste, IP);\r
+         true ->\r
+            euphorik_protocole:erreur(lists:flatten(io_lib:format(\r
+               "La version du protocole du client (~w) ne correspond à celle du serveur (~w)", [Version_client, ?VERSION_PROTOCOLE]\r
+            )))\r
+      end\r
+   ).\r
+   \r
+\r
+% authentification d'un client\r
+traiter_action("authentification", JSON, IP) ->\r
+   euphorik_protocole:login(JSON, IP);\r
+% un client s'enregistre (pseudo + password)\r
+traiter_action("register", JSON, IP) ->\r
+   euphorik_protocole:register(JSON, IP);\r
+% modification du profile\r
+traiter_action("set_profile", JSON, _) ->\r
+   euphorik_protocole:profile(JSON);\r
+% un utilisateur attend un événement (par exemple l'arrivé d'un nouveau message)\r
+traiter_action("wait_event", JSON, _) ->\r
+   euphorik_protocole:wait_event(JSON);\r
+% un utilisateur envoie un message\r
+traiter_action("put_message", JSON, _) ->\r
+   euphorik_protocole:put_message(JSON);\r
+traiter_action("ban", JSON, _) ->\r
+   euphorik_protocole:ban(JSON);\r
+traiter_action("slap", JSON, _) ->\r
+   euphorik_protocole:slap(JSON);\r
+traiter_action("put_troll", JSON, _) ->\r
+   euphorik_protocole:put_troll(JSON);\r
+traiter_action("mod_troll", JSON, _) ->\r
+   euphorik_protocole:mod_troll(JSON);\r
+traiter_action("del_troll", JSON, _) ->\r
+   euphorik_protocole:del_troll(JSON);\r
+traiter_action("list_banned_ips", JSON, _) ->\r
+   euphorik_protocole:list_banned_ips(JSON);\r
+traiter_action("unban", JSON, _) ->\r
+   euphorik_protocole:unban_ip(JSON).\r
  
\ No newline at end of file