ADD trois mode d'affichage pour les pseudos
[euphorik.git] / modules / erl / euphorik_requests.erl
index a289f0d..7ee5c7d 100755 (executable)
@@ -1,7 +1,8 @@
 % coding: utf-8\r
-% 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'.\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
 
 -module(euphorik_requests).\r
 -export([\r
 \r
 -include_lib("xmerl/include/xmerl.hrl").\r
 -include_lib("yaws/include/yaws_api.hrl").
+
 \r
-% Test du module\r
-tester() ->\r
-   %~ {XML, _} = xmerl_scan:string(\r
-      %~ "<action name=\"loginCaptcha\">"\r
-      %~ "  <captchaCrypt>b1b1b4e72e6f3d00e477cf37cced5851</captchaCrypt>"\r
-      %~ "  <captchaInput>LKJDLA</captchaInput>"\r
-      %~ "</action>"),\r
-   %~ io:format("Nouvel user : ~p~n", [nouveau_user(XML)]).
-   \r
-   {XML2, _} = xmerl_scan:string(\r
-      "<action name=\"login\">"\r
-      "  <cookie>5DZQ2HCRO7JIX3QCSWRNL</cookie>"\r
-      "</action>"),\r
-   io:format("Login : ~p~n", [euphorik_protocole:login(XML2)]).
-   \r
-   %~ {XML, _} = xmerl_scan:string(\r
-      %~ "<action name=\"refreshMessages\">"\r
-      %~ "<nombreMessage>5</nombreMessage>"\r
-      %~ "<page>1</page>"\r
-      %~ "</action>"),\r
-   %~ io:format("Messages de la premières page : ~p~n", [euphorik_protocole:refreshMessage(XML)]).
-   \r
-   %~ traiter_xml("<action name=\"message\">"\r
-      %~ "<cookie>4UDUSY6Z2IZNTQO484S8X</cookie>"\r
-      %~ "<pseudo>Pifou</pseudo>"\r
-      %~ "<contenu>test &amp; plop</contenu>"\r
-      %~ "</action>").
-   %~ traiter_xml(
-      %~ "<action name=\"generationCaptcha\">"
-      %~ "</action>").\r
+% Test du module (TODO)\r
+tester() ->
+   que_dal.\r
+
 \r
 % il faut catcher toutes les exceptions possibles\r
 out(A) ->\r
    %inet:setopts(A#arg.clisock, inet:getopts(A#arg.clisock, [active])),\r
    {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)),\r
-   Ret = traiter_xml(Contenu),\r
-   {content, "text/xml", Ret}.\r
+   Ret = traiter_donnees(Contenu),
+   {content, "application/json", Ret}.\r
 
 \r
-traiter_xml(Contenu) ->\r
-   {XML, _} = xmerl_scan:string(Contenu),\r
-   traiter_action(XML#xmlElement.attributes, XML).\r
-
+traiter_donnees(Contenu) ->
+   case json:decode_string(Contenu) of
+      {ok, {struct, [{action, Action}| Reste]}} ->
+         json:encode(traiter_action(Action, Reste));
+      _ ->
+         error
+   end.
+   
 
-% un client demande la génération d'un captcha
-traiter_action([#xmlAttribute{value="generationCaptcha"}], XML) ->
-   euphorik_protocole:generation_captcha(XML); \r
-% un client se log pour la première fois\r
-traiter_action([#xmlAttribute{value="loginCaptcha"}], XML) ->\r
-   euphorik_protocole:nouveau_user_captcha(XML); 
+% authentification d'un client
+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); \r
-% authentification d'un client\r
-traiter_action([#xmlAttribute{value="login"}], XML) ->\r
-   euphorik_protocole:login(XML); 
+traiter_action("register", JSON) ->
+   euphorik_protocole:register(JSON);
 % modification du profile
-traiter_action([#xmlAttribute{value="profile"}], XML) ->
-   euphorik_protocole:profile(XML); \r
-% le client désire les messages\r
-traiter_action([#xmlAttribute{value="refreshMessages"}], XML) ->\r
- euphorik_protocole:refreshMessage(XML); \r
-% envoie d'un message\r
-traiter_action([#xmlAttribute{value="message"}], XML) ->\r
-   euphorik_protocole:message(XML).\r
\r
-
-\r
+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).
\ No newline at end of file