X-Git-Url: http://git.euphorik.ch/index.cgi?a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_requests.erl;h=2fb69c0b784a4caae1d71119b55f36a3e2470f14;hb=35b6b48d4c8fe3a262a4f01f9b97f0b2d7fdbbdf;hp=5b3a6d2a01b5438d62e63012cf0f26a0672d7e2f;hpb=897468be6fa01ab87f38189f2daf266f3289c9fb;p=euphorik.git
diff --git a/modules/erl/euphorik_requests.erl b/modules/erl/euphorik_requests.erl
index 5b3a6d2..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,13 +14,7 @@
-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)]).
+tester() ->
%~ {XML2, _} = xmerl_scan:string(
%~ ""
@@ -28,20 +23,15 @@ tester() ->
%~ io:format("Login : ~p~n", [euphorik_protocole:login(XML2)]).
XML =
- ""
- "2"
- "1"
- "31"
+ "3FSDCH0FD4ML8WEPN2B5T"
+ "10"
"",
- io:format("Messages de la premières page : ~p~n", [traiter_xml(XML)]).
+ io:format("Messages de la premières page : ~p~n", [traiter_donnees(XML)]).
%~ traiter_xml(""
%~ "4UDUSY6Z2IZNTQO484S8X"
%~ "Pifou"
%~ "test & plop"
- %~ "").
- %~ traiter_xml(
- %~ ""
%~ "").
@@ -49,21 +39,30 @@ tester() ->
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);
@@ -73,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).