+/**
+ * Les fonctions debutReq et finReq servent, par exemple, à afficher à l'utilisateur
+ * qu'une communication est en cours.\r
+ * @param funError un fonction executée lors d'un réponse 'error' de la part du serveur, peut être redéfinit pour une requête.
+ * @param funDebutReq fonction appelée au début d'une requête (facultatif)
+ * @param funFinReq fonction appelée à la fin d'une requête (facultatif)\r
+ */\r
+euphorik.Communication = function(funError, funDebutReq, funFinReq) {\r
+ this.funError = funError;
+ this.funDebutReq = funDebutReq;
+ this.funFinReq = funFinReq;\r
+};
+
+/**
+ * Charge un fichier depuis une url et retourne son contenu.
+ */
+euphorik.Communication.prototype.load = function(url) {
+ if (this.funDebutReq) {
+ this.funDebutReq();
+ }
+ var contenu = "";
+ $.ajax({async: false, url: url, success : function(page) { contenu += page; }});
+ if (this.funFinReq) {
+ this.funFinReq();
+ }
+ return contenu;
+}\r
+
+/**
+ * Effectue une requête JSON auprès du serveur.
+ * @param action une chaine spécifiant l'action, par exemple "put_message"
+ * @param json les données à envoyer associé à l'action, par exemple {"cookie" : "LKJDLAKSJBFLKASN", "nick" : "Paul", "content" : "Bonjour", "answer_to" : [] }
+ * @param funOk la fonction exécuté après réception des données du serveur
+ * @param funError la fonction exécuté si une erreur arrive (facultatif)
+ * @param asynchrone true pour une communication asychrone (facultatif, truepar défaut)
+ * @param paramsSupp un objet contenant des paramètres supplémentaire pour la fonction ajax de jQuery (facultatif)