X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_requests.erl;h=616d0e75c7d2584dcb164eafa0abce32283c88de;hp=28019da95d8be378766e1fd1e5641e45d9ef7656;hb=c01d54fd6a515a6f2860e3b18ff574afa5caa83b;hpb=eaeff7851380cf9a416fd609fd9e90297f8f5918 diff --git a/modules/erl/euphorik_requests.erl b/modules/erl/euphorik_requests.erl index 28019da..616d0e7 100755 --- a/modules/erl/euphorik_requests.erl +++ b/modules/erl/euphorik_requests.erl @@ -18,66 +18,72 @@ % % Ce module est fait pour répondre à des requêtes 'AJAX'. % Il est définit comme 'appmods' pour l'url "request" dans yaws. -% 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. +% @author G.Burri + - -module(euphorik_requests). -export([out/1]). -include_lib("xmerl/include/xmerl.hrl"). --include_lib("yaws/include/yaws_api.hrl"). - +-include_lib("yaws/include/yaws_api.hrl"). +-include("../include/euphorik_defines.hrl"). + -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) -> + %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 % keepalive -> true, evite que des firewalls coupe la connexion TCP sans prévenir inet:setopts(A#arg.clisock, [{active, true}, {keepalive, true}]), {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)), - Ret = traiter_donnees(Contenu, IP), + Ret = traiter_donnees(Contenu, IP), {content, "application/json", Ret}. - -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). + +% Décode les données JSON. +traiter_donnees(Contenu, IP) -> + {ok, {struct, [{header, {struct, [{action, Action}, {version, Version_client}]}} | Reste]}} = json:decode_string(Contenu), + json:encode( + if Version_client =:= ?VERSION_PROTOCOLE -> + traiter_action(Action, Reste, IP); + true -> + euphorik_protocole:erreur(lists:flatten(io_lib:format( + "La version du protocole du client (~w) ne correspond à celle du serveur (~w)", [Version_client, ?VERSION_PROTOCOLE] + ))) + 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). \ No newline at end of file