X-Git-Url: http://git.euphorik.ch/index.cgi?a=blobdiff_plain;ds=inline;f=modules%2Ferl%2Feuphorik_requests.erl;h=42348cfcc857271f5b80968a5303d4f04489862a;hb=ccb7fdfe9914f47cc38f96e5973851f2c6f0c4b6;hp=abfdd93befb680db3c2b76ff321a3561fb060b7d;hpb=bacec85920574375f4b8df20d6a0457e1fffc658;p=euphorik.git
diff --git a/modules/erl/euphorik_requests.erl b/modules/erl/euphorik_requests.erl
index abfdd93..42348cf 100755
--- a/modules/erl/euphorik_requests.erl
+++ b/modules/erl/euphorik_requests.erl
@@ -14,74 +14,67 @@
-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)]).
-
- XML =
- ""
- "2"
- "1"
- "31"
- "",
- io:format("Messages de la premières page : ~p~n", [traiter_xml(XML)]).
-
- %~ traiter_xml(""
- %~ "4UDUSY6Z2IZNTQO484S8X"
- %~ "Pifou"
- %~ "test & plop"
- %~ "").
- %~ traiter_xml(
- %~ ""
- %~ "").
+tester() ->
+ que_dal.
% 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),
- {content, "text/xml", Ret}.
+ Ret = traiter_donnees(Contenu),
+ %{content, "text/xml", Ret}.
+ {content, "application/json", Ret}.
-traiter_xml(Contenu) ->
- {XML, _} = xmerl_scan:string(Contenu),
- traiter_action(XML#xmlElement.attributes, XML).
+traiter_donnees(Contenu) ->
+ % FIXME : ne plus encapsuler le JSON dans de l'xml... apparement yaws veux absolument de l'xml (voir post mi-avril 2008 sur la mailing list)
+ Reponse = case xmerl_scan:string(Contenu) of
+ {#xmlElement{name = json, content = [#xmlText{value = J}|_]}, _} ->
+ case json:decode_string(J) of
+ {ok, {struct, [{action, Action}| Reste]}} ->
+ %io:format("~p~n", [euphorik_protocole:login(JSON)]),
+ json:encode(traiter_action(Action, Reste));
+ _ ->
+ error
+ end;
+ _ -> error
+ end,
+ if Reponse =:= error ->
+ euphorik_protocole:erreur("Format XML/JSON incorrect");
+ true ->
+ Reponse
+ end.
+
+
+% authentification d'un client
+traiter_action("authentification", JSON) ->
+ euphorik_protocole:login(JSON));
+% un client s'enregistre (pseudo + password)
+traiter_action("register", JSON) ->
+ euphorik_protocole:register(JSON);
+% 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:message(JSON).
+
-% un client demande la génération d'un captcha (obsolète)
-%~ traiter_action([#xmlAttribute{value="generationCaptcha"}], XML) ->
- %~ euphorik_protocole:generation_captcha(XML);
-% un client se log pour la première fois (obsolète)
-%~ traiter_action([#xmlAttribute{value="loginCaptcha"}], XML) ->
- %~ euphorik_protocole:nouveau_user_captcha(XML);
-
-% un client s'enregistre (pseudo + password)
traiter_action([#xmlAttribute{value="register"}], XML) ->
- euphorik_protocole:nouveau_user_login(XML);
-% authentification d'un client
-traiter_action([#xmlAttribute{value="login"}], XML) ->
+ euphorik_protocole:nouveau_user_login(XML);
+traiter_action([#xmlAttribute{value="login"}], XML) ->
euphorik_protocole:login(XML);
-% modification du profile
traiter_action([#xmlAttribute{value="profile"}], XML) ->
- euphorik_protocole:profile(XML);
-% un utilisateur demande les messages
-traiter_action([#xmlAttribute{value="refreshMessages"}], XML) ->
- euphorik_protocole:refreshMessage(XML);
-% un utilisateur envoie un message
-traiter_action([#xmlAttribute{value="message"}], XML) ->
- euphorik_protocole:message(XML).
-
-
-
+ euphorik_protocole:profile(XML);
+traiter_action([#xmlAttribute{value="refreshMessages"}], XML) ->
+ euphorik_protocole:refreshMessage(XML);
+% un utilisateur envoie un message
+traiter_action([#xmlAttribute{value="message"}], XML) ->
+ euphorik_protocole:message(XML).
+
\ No newline at end of file