\r
-include_lib("xmerl/include/xmerl.hrl").\r
-include_lib("yaws/include/yaws_api.hrl").
+
\r
-% Test du module\r
+% Test du module (TODO)\r
tester() ->
- \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 =\r
- "<action name=\"refreshMessages\"><cookie>3FSDCH0FD4ML8WEPN2B5T</cookie>"
- "<nombreMessage>10</nombreMessage>"
- "</action>",\r
- io:format("Messages de la premières page : ~p~n", [traiter_xml(XML)]).
- \r
- %~ traiter_xml("<action name=\"message\">"\r
- %~ "<cookie>4UDUSY6Z2IZNTQO484S8X</cookie>"\r
- %~ "<pseudo>Pifou</pseudo>"\r
- %~ "<contenu>test & plop</contenu>"\r
- %~ "</action>").\r
+ 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
+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\r
+ inet:setopts(A#arg.clisock, [{active, true}]),\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, IP),
+ {content, "application/json", Ret}.\r
\r
-traiter_xml(Contenu) ->\r
- {XML, _} = xmerl_scan:string(Contenu),\r
- traiter_action(XML#xmlElement.attributes, XML).\r
- \r
+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([#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, IP) ->
+ euphorik_protocole:register(JSON, IP);
% modification du profile
-traiter_action([#xmlAttribute{value="profile"}], XML) ->
- euphorik_protocole:profile(XML); \r
-% un utilisateur demande les messages\r
-traiter_action([#xmlAttribute{value="refreshMessages"}], XML) ->\r
- euphorik_protocole:refreshMessage(XML); \r
-% un utilisateur envoie 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);
+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).
+
\ No newline at end of file