X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_requests.erl;h=2fb69c0b784a4caae1d71119b55f36a3e2470f14;hp=a289f0dcaae40b792a536c36515946d809210e90;hb=e04de9d41e7955b0092fc33b8619b4627af6b3f3;hpb=6feaef2a51f7226c41d69f9e86f605718b78aa02 diff --git a/modules/erl/euphorik_requests.erl b/modules/erl/euphorik_requests.erl index a289f0d..2fb69c0 100755 --- a/modules/erl/euphorik_requests.erl +++ b/modules/erl/euphorik_requests.erl @@ -1,7 +1,8 @@ % coding: utf-8 -% Ce module est fait pour répondre à des requêtes 'AJAX'. -% Auteur : G.Burri -% Date : 22.10.2007 +% 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 -module(euphorik_requests). -export([ @@ -13,55 +14,55 @@ -include_lib("yaws/include/yaws_api.hrl"). % Test du module -tester() -> - %~ {XML, _} = xmerl_scan:string( - %~ "" - %~ " b1b1b4e72e6f3d00e477cf37cced5851" - %~ " LKJDLA" - %~ ""), - %~ io:format("Nouvel user : ~p~n", [nouveau_user(XML)]). - - {XML2, _} = xmerl_scan:string( - "" - " 5DZQ2HCRO7JIX3QCSWRNL" - ""), - io:format("Login : ~p~n", [euphorik_protocole:login(XML2)]). +tester() -> - %~ {XML, _} = xmerl_scan:string( - %~ "" - %~ "5" - %~ "1" + %~ {XML2, _} = xmerl_scan:string( + %~ "" + %~ " 5DZQ2HCRO7JIX3QCSWRNL" %~ ""), - %~ io:format("Messages de la premières page : ~p~n", [euphorik_protocole:refreshMessage(XML)]). + %~ io:format("Login : ~p~n", [euphorik_protocole:login(XML2)]). + + XML = + "3FSDCH0FD4ML8WEPN2B5T" + "10" + "", + io:format("Messages de la premières page : ~p~n", [traiter_donnees(XML)]). %~ traiter_xml("" %~ "4UDUSY6Z2IZNTQO484S8X" %~ "Pifou" %~ "test & plop" - %~ ""). - %~ traiter_xml( - %~ "" %~ ""). + % il faut catcher toutes les exceptions possibles out(A) -> %inet:setopts(A#arg.clisock, inet:getopts(A#arg.clisock, [active])), {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)), - Ret = traiter_xml(Contenu), + Ret = traiter_donnees(Contenu), {content, "text/xml", Ret}. -traiter_xml(Contenu) -> - {XML, _} = xmerl_scan:string(Contenu), - traiter_action(XML#xmlElement.attributes, XML). - - -% un client demande la génération d'un captcha -traiter_action([#xmlAttribute{value="generationCaptcha"}], XML) -> - euphorik_protocole:generation_captcha(XML); -% un client se log pour la première fois -traiter_action([#xmlAttribute{value="loginCaptcha"}], XML) -> - euphorik_protocole:nouveau_user_captcha(XML); +traiter_donnees(Contenu) -> + case xmerl_scan:string(Contenu) of + {XML, _} -> + case XML of + #xmlElement{name = json, content = [#xmlText{value = J}|_]} -> + case json:decode_string(J) of + {ok, {struct, [{action, Action}| Reste]}} -> + traiter_action(Action, Reste); + _ -> + erreur + end; + _ -> + traiter_action(XML#xmlElement.attributes, XML) + end; + _ -> erreur + end. + + +traiter_action("authentification", JSON) -> + euphorik_protocole:login(JSON); % un client s'enregistre (pseudo + password) traiter_action([#xmlAttribute{value="register"}], XML) -> euphorik_protocole:nouveau_user_login(XML); @@ -71,10 +72,10 @@ traiter_action([#xmlAttribute{value="login"}], XML) -> % modification du profile traiter_action([#xmlAttribute{value="profile"}], XML) -> euphorik_protocole:profile(XML); -% le client désire les messages +% un utilisateur demande les messages traiter_action([#xmlAttribute{value="refreshMessages"}], XML) -> euphorik_protocole:refreshMessage(XML); -% envoie d'un message +% un utilisateur envoie un message traiter_action([#xmlAttribute{value="message"}], XML) -> euphorik_protocole:message(XML).