OUPS
[euphorik.git] / modules / erl / euphorik_requests.erl
1 % coding: utf-8
2 % Copyright 2008 Grégory Burri
3 %
4 % This file is part of Euphorik.
5 %
6 % Euphorik is free software: you can redistribute it and/or modify
7 % it under the terms of the GNU General Public License as published by
8 % the Free Software Foundation, either version 3 of the License, or
9 % (at your option) any later version.
10 %
11 % Euphorik is distributed in the hope that it will be useful,
12 % but WITHOUT ANY WARRANTY; without even the implied warranty of
13 % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 % GNU General Public License for more details.
15 %
16 % You should have received a copy of the GNU General Public License
17 % along with Euphorik. If not, see <http://www.gnu.org/licenses/>.
18 %
19 % Ce module est fait pour répondre à des requêtes 'AJAX'.
20 % Il est définit comme 'appmods' pour l'url "request" dans yaws.
21 % Par exemple http://www.euphorik.ch/request abouti sur la fonction out() de ce module.
22 % @author G.Burri
23
24
25 -module(euphorik_requests).
26 -export([out/1]).
27 -include_lib("xmerl/include/xmerl.hrl").
28 -include_lib("yaws/include/yaws_api.hrl").
29 -include("../include/euphorik_defines.hrl").
30
31
32 out(A) ->
33 %io:format("~p~n", [A]), % utilisé parfois pendant le debug
34 IP = case inet:peername(A#arg.clisock) of
35 {ok, {Adresse, _Port}} -> Adresse;
36 _ -> inconnue
37 end,
38 % passive -> active, permet de recevoir {tcp_closed, _} lorsque le socket se ferme
39 % keepalive -> true, evite que des firewalls coupe la connexion TCP sans prévenir
40 inet:setopts(A#arg.clisock, [{active, true}, {keepalive, true}]),
41 {value, {_, Contenu}} = lists:keysearch("action", 1, yaws_api:parse_post(A)),
42 Ret = traiter_donnees(Contenu, IP),
43 %io:format("~p~n", [Ret]),
44 {content, "application/json", Ret}.
45
46
47 % Décode les données JSON.
48 traiter_donnees(Contenu, IP) ->
49 {ok, {struct, [{header, {struct, [{action, Action}, {version, Version_client}]}} | Reste]}} = json:decode_string(Contenu),
50 json:encode(
51 if Version_client =:= ?VERSION_PROTOCOLE ->
52 traiter_action(Action, Reste, IP);
53 true ->
54 euphorik_protocole:erreur(lists:flatten(io_lib:format(
55 "La version du protocole du client (~w) ne correspond à celle du serveur (~w)", [Version_client, ?VERSION_PROTOCOLE]
56 )))
57 end
58 ).
59
60
61 % authentification d'un client
62 traiter_action("authentification", JSON, IP) ->
63 euphorik_protocole:login(JSON, IP);
64 % un client s'enregistre (pseudo + password)
65 traiter_action("register", JSON, IP) ->
66 euphorik_protocole:register(JSON, IP);
67 % modification du profile
68 traiter_action("set_profile", JSON, _) ->
69 euphorik_protocole:profile(JSON);
70 % un utilisateur attend un événement (par exemple l'arrivé d'un nouveau message)
71 traiter_action("wait_event", JSON, _) ->
72 euphorik_protocole:wait_event(JSON);
73 % un utilisateur envoie un message
74 traiter_action("put_message", JSON, _) ->
75 euphorik_protocole:put_message(JSON);
76 traiter_action("ban", JSON, _) ->
77 euphorik_protocole:ban(JSON);
78 traiter_action("slap", JSON, _) ->
79 euphorik_protocole:slap(JSON);
80 traiter_action("put_troll", JSON, _) ->
81 euphorik_protocole:put_troll(JSON);
82 traiter_action("mod_troll", JSON, _) ->
83 euphorik_protocole:mod_troll(JSON);
84 traiter_action("del_troll", JSON, _) ->
85 euphorik_protocole:del_troll(JSON);
86 traiter_action("list_banned_ips", JSON, _) ->
87 euphorik_protocole:list_banned_ips(JSON);
88 traiter_action("unban", JSON, _) ->
89 euphorik_protocole:unban_ip(JSON).
90