--- TODO --\r
-[ok] * Réaliser la structure suivante :\r
- * Table minichat : {id, auteur_id, date, pseudo, contenu, reponses_minichat_id} reponses_minichat_id peut être null\r
- * Table reponse_minichat : {id, minichat_id} la clef est (id, minichat_id)\r
- * Table user : {id, cookie, pseudo, date_creation, date_derniere_connexion, css}\r
-[ok] Implémenter le protocol dans 'fonctionnement_minichat.txt'\r
-[ok] Trier la requête et limiter à N le nombre de messages affichés\r
-[ok] réaliser un controller sous la forme d'une application pour receptionner tout ce qui vient des formulaires\r
-[ok] Ajouter un lien minichat.iduser -> user.id\r
-[ok] Ajouter un id pour les messages qui est un entier auto incrémenté\r
-[ok] Afficher un captcha le md5 de la valeur est l'envoyer avec\r
-[ok] Formater les dates\r
-[ok] Trouver et remplacer les url http://www.youpla.com par <a href="http://www.youpla.com">[url]</a>\r
-[ok] Traitement des smiles (remplacer :) par "<img src="img/smiles/content.gif" />"\r
-[ok] Afficher les smiles disponibles, on peut clicker dessus pour en ajouter un dans le text\r
-[ok] Mettre en évidence les posts auquels l'utilisateur courant à répondu ainsi que ses propres posts\r
- * Vérifier le captcha\r
- * Mettre un cookie\r
-[ok] Mémoriser le pseudo et le remettre à chaque fois (si cookie)\r
-[ok] Afficher un <pseudo> et <message> pour renseigner l'utilisateur sur les différents zones de texte. Lorsque l'utilisateur click sur une zone le message disparait. (javascript).\r
-[ok] Pouvoir répondre à un ou plusieurs messages en cliquant dessus (javascript)\r
- * L'utilisateur peut clicker sur un message, cela appond le nom et l'id du message à son message, exe : "kiki:G3E> " "G3E" et l'id du message en base 36, si l'id est omis alors le dernier message dont le pseudo est kiki est pris en compte\r
- * le(s) pseudo(s) de l'auteur du message auquel on répond préfixe notre message\r
- * Lorsque l'on passe le curseur sur un message on voit la conversation avec une mise en évidence des réponses (les messages ne faisant pas partie de la conversation sont grisés ou masqués)\r
-[ok] Maintenir le focus sur la ligne de saisie après l'envoie d'un message\r
-[ok] Ajouter plusieurs messages d'un coup pour eviter des lenteurs au chargement\r
-[pas besoin] Catcher les exceptions de parsage de l'xml dans euphorik_request\r
-[ok] * Ne pas virer les balises html mais remplacer les <> par < >\r
-[ok mais limité] Avoir accès aux archives (par page, par exemple)\r
-[ok] Profiling pour améliorer les performances (surtout du coté client)\r
-[ok] Interdir les {} dans les pseudo\r
-[plus besoin] Finir le deamon\r
-[plus besoin] tester si le captcha_crypt existe (en regardant les fichiers images temporaires)\r
-[ok] Virer les balises html des messages et pseudo lors du stockage du message (et trimer).\r
-[ok] afficher les pseudo des messages auquels un message répond (modification du protocole, il faut ajouter une liste de pseudo pour chaque message)\r
-[ok] Possibilité de logout\r
+== TODO ==\r
+\r
+=== v1.0.1 ===
+* Pouvoir afficher les utilisateurs (print_users(admin)) qui sont admin\r
+<<<<<<< .working\r
+* Mettre dans la FAQ la signification des couleurs associées aux messages.\r
+* Ne pas pouvoir poster avec "<nick>"\r
+* Ajouter euphorik_common.erl au repo !!\r
+* Compilation :\r
+ * Compiler avec le flag +debug_info pour le developpement\r
+ * Compiler avec le flag +native lors de la mise en production\r
+ * Faire d'abord des tests en local pour voir s'il y a vraiment des gains, utiliser le module test_euphorik\r
+ * Regarder également si la comsommation de la mémoire est différentes\r
+ * La compilation DOIT se faire sur la machine cible, il faut donc d'abord copier les fichiers dans /tmp sur euphorik.ch\r
+ puis lancer la compilation à distance et finalement copier les fichiers sur /var/www/euphorik\r
+* Appliquer les flags suivant à Yaws : http://forum.trapexit.org/mailinglists/viewtopic.php?t=6725&sid=8729e02f79c3ef0e0794add77b74b6ce\r
+=======\r
+* Ne pas pouvoir poster avec "<nick>" -> mettre en constante\r
+* Ajouter euphorik_common.erl au repo !!\r
+* Compilation :\r
+ * Compiler avec le flag +debug_info pour le developpement\r
+ * Compiler avec le flag +native lors de la mise en production\r
+ * Faire d'abord des tests en local pour voir s'il y a vraiment des gains, utiliser le module test_euphorik\r
+ * Regarder également si la comsommation de la mémoire est différentes\r
+ * La compilation DOIT se faire sur la machine cible, il faut donc d'abord copier les fichiers dans /tmp sur euphorik.ch\r
+ puis lancer la compilation à distance et finalement copier les fichiers sur /var/www/euphorik\r
+* Appliquer les flags suivant à Yaws : http://forum.trapexit.org/mailinglists/viewtopic.php?t=6725&sid=8729e02f79c3ef0e0794add77b74b6ce\r
+>>>>>>> .merge-right.r271\r
+=== v1.1 ===\r
+* Revoir le système de conversation : \r
+ * Pouvoir extraire "toute la conversation" ou seulement une "sous conversation" (ce qui est actuellement le cas)\r
+ * Tous les messages auquels on répond doivent faire partie de la conversation !!\r
+ * Fermer temporairement une conversation (la réduire sous la forme d'un onglet)\r
+ * lien vers une conversation : http://www.euphorik.ch/?conv=45\r
+* Mettre un icon (genre sablier ou truc qui tourne à la apple) lorsque le chat se charge (également lors d'un changement de page par exemple)\r
+ * L'icon apparait tout en haut (absolute)\r
+ * Simuler un réseau lent\r
+* Mise à jour automatique de la version dans le about en fonction du tag/branche courant (lors de la mise en production) ?\r
+* Tests de monter en charge coté serveur, analyse de la complexité (regarder du coté des TODO dans le code). Utiliser eventuellement Tsung\r
+* Profiling pour améliorer les performances (client et serveur)\r
+ * traitementComplet() de euphorik.js est très très lent à executer\r
+* Pouvoir récupérer son mdp (ou en générer un autre) via son email. Marquer dans le profile que l'email sert à cela et n'est pas visible pas les autres personnes\r
+* (Pouvoir inverser le chat) tester la faisabilité\r
+=== v1.2 ===\r
+* Avoir une liste d'amis dans le profile\r
+ * Pouvoir n'afficher les messages que des amis (et des personnes y répondant)\r
+ * Ajouter une personne à ses amis avec une toolbar similaire à celle de banissement\r
+* Création d'un script ruby dans /tool pour apposer automatiquement une entête concernant la licence voir : http://www.gnu.org/licenses/gpl-howto.fr.html\r
+ * Eventuellement mettre à jour automatiquement le Copyright (date) et les personnes responsables \r
+* Système de censure par les admins (suppression d'un message)\r
+ * Ne supprime pas réellement le message mais le censure\r
+ * L'admin vois toujours le message (grisé, ou tracé)\r
+ * Les utilisateurs normaux voient à la place "<censuré, raison : blabla>"\r
+* Intégrer les totoz : http://www.totoz.eu/ (avec une limite de 3 par messages par exemple) \r
+ * avoir une option pour les cacher ou les voir\r
+ * Masquer systématiquement ceux qui dépassent une certaine taille en pixel\r
+=== V1.3 ===\r
+* Shift-enter pour ajouter une ligne dans la ligne de saisie (retour à la ligne)\r
+ * Crée un <br /> XHTML (lf -> br coté client)\r
+ * A chaque Shift-enter la textbox s'agrandit d'une ligne\r
+ * Pouvoir activer pas défaut la présentation multi-ligne via le profile\r
+* Système de commande /<commande>\r
+ * /nick : changer de pseudo\r
+ * /me : "*<pseudo> <message>"\r
+ * /blam <login> : permet d'envoyer un blame à qqun (uniquement depuis un modo vers un non-modo) \r
+ * /+ blabla Pourvoir ajouter du texte (correctif en général) à son dernier message par une commande. Le texte ajouté est mise en évidence. Ceci peut être fait plusieurs fois.\r
+* Ajout des wikilien : [[chien de prairie]] -> http://fr.wikipedia.org/wiki/Chien_de_prairie\r
+=== V1.4 ===\r
+* Elaborer une stratégie de mise à jour de la structure de la BD quand celle ci est modifiée (voir euphorik_bd:vers_version()) \r
+* Ajouter un skin "simple" sans images ni fioritures (éventuellement le proposer par défaut)\r
+* Créer un style "super old school" (couleur 8 bit, pas de smiles/images, font fixe)\r
+=== V1.5 ===\r
+* Gestion de l'historique au niveau du navigateur (pouvoir revenir aux pages précédentes). Utiliser un plugin jQuery si possible.\r
+* gestion des timezone (fuseaux horaire) :\r
+ * L'utilisateur peut simplement définir une timezone dans son profil, les dates sont alors affichées en fonction de sa zone (en option)\r
+* Transfert des messages XML (AJAX) en https et le noter dans la faq (même la mafia chinoise ne peut pas sniffer les messages). En fait il suffit (sauf erreur) de sécuriser euphorik : https://www.euphorik.ch\r
+ * voir : http://cert.startcom.org/ pour un certif gratuit\r
+* Conversations : url vers conversation(s) + également un bouton sur chaque conversation pour obtenir l'url vers celle ci. (genre google map)\r
+\r
+
+[ok] Réaliser la structure suivante :
+ * Table minichat : {id, auteur_id, date, pseudo, contenu, reponses_minichat_id} reponses_minichat_id peut être null
+ * Table reponse_minichat : {id, minichat_id} la clef est (id, minichat_id)
+ * Table user : {id, cookie, pseudo, date_creation, date_derniere_connexion, css}
+[ok] Implémenter le protocole dans 'fonctionnement_minichat.txt'
+[ok] Trier la requête et limiter à N le nombre de messages affichés
+[ok] réaliser un controller sous la forme d'une application pour receptionner tout ce qui vient des formulaires
+[ok] Ajouter un lien minichat.iduser -> user.id
+[ok] Ajouter un id pour les messages qui est un entier auto incrémenté
+[ok] Afficher un captcha le md5 de la valeur est l'envoyer avec
+[ok] Formater les dates
+[ok] Trouver et remplacer les url http://www.youpla.com par <a href="http://www.youpla.com">[url]</a>
+[ok] Traitement des smiles, remplacer :) par "<img src="img/smiles/content.gif" />"
+ * Pour ne pas entrer en conflit avec totoz.eu la notation est la suivante : [=slurp]
+ * La notation totoz.eu est : [:slurp]
+[ok] Afficher les smiles disponibles, on peut clicker dessus pour en ajouter un dans le text
+[ok] Mettre en évidence les posts auquels l'utilisateur courant à répondu ainsi que ses propres posts
+ * Vérifier le captcha
+ * Mettre un cookie
+[ok] Mémoriser le pseudo et le remettre à chaque fois (si cookie)
+[ok] Afficher un <pseudo> et <message> pour renseigner l'utilisateur sur les différents zones de texte. Lorsque l'utilisateur click sur une zone le message disparait. (javascript).
+[ok] Pouvoir répondre à un ou plusieurs messages en cliquant dessus (javascript)
+ * L'utilisateur peut cliquer sur un message, cela appond le nom et l'id du message à son message, exe : "kiki:G3E> " "G3E" et l'id du message en base 36, si l'id est omis alors le dernier message dont le pseudo est kiki est pris en compte
+ * le(s) pseudo(s) de l'auteur du message auquel on répond préfixe notre message
+ * Lorsque l'on passe le curseur sur un message on voit la conversation avec une mise en évidence des réponses (les messages ne faisant pas partie de la conversation sont grisés ou masqués)
+[ok] Maintenir le focus sur la ligne de saisie après l'envoie d'un message
+[ok] Ajouter plusieurs messages d'un coup pour eviter des lenteurs au chargement
+[pas besoin] Catcher les exceptions de parsage de l'xml dans euphorik_request
+[ok] Ne pas virer les balises html mais remplacer les <> par < >
+[ok mais limité] Avoir accès aux archives (par page, par exemple)
+[ok] Interdir les {} dans les pseudo
+[plus besoin] Finir le deamon
+[plus besoin] tester si le captcha_crypt existe (en regardant les fichiers images temporaires)
+[ok] Virer les balises html des messages et pseudo lors du stockage du message (et trimer).
+[ok] afficher les pseudo des messages auquels un message répond (modification du protocole, il faut ajouter une liste de pseudo pour chaque message)
+[ok] Possibilité de logout