X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=modules%2Ferl%2Feuphorik_requests.erl;h=42348cfcc857271f5b80968a5303d4f04489862a;hp=2fb69c0b784a4caae1d71119b55f36a3e2470f14;hb=ccb7fdfe9914f47cc38f96e5973851f2c6f0c4b6;hpb=35b6b48d4c8fe3a262a4f01f9b97f0b2d7fdbbdf diff --git a/modules/erl/euphorik_requests.erl b/modules/erl/euphorik_requests.erl index 2fb69c0..42348cf 100755 --- a/modules/erl/euphorik_requests.erl +++ b/modules/erl/euphorik_requests.erl @@ -15,24 +15,7 @@ % Test du module tester() -> - - %~ {XML2, _} = xmerl_scan:string( - %~ "" - %~ " 5DZQ2HCRO7JIX3QCSWRNL" - %~ ""), - %~ 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" - %~ ""). + que_dal. % il faut catcher toutes les exceptions possibles @@ -40,44 +23,58 @@ 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_donnees(Contenu), - {content, "text/xml", Ret}. + %{content, "text/xml", Ret}. + {content, "application/json", Ret}. -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_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)); _ -> - traiter_action(XML#xmlElement.attributes, XML) + error end; - _ -> erreur - 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); + 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). + + + + 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