FIX gros bug moisi (ajout de l'information du dernier message au niveau des conversat...
[euphorik.git] / doc / TODO.txt
1 == TODO ==\r
2 \r
3 === v1.0 ===\r
4 * Rendre compatible IE 7\r
5 * Tester avec des caractères accentués sur Firefox, Safari, Opera et IE7. Les messages doivent être envoyés en UTF8.\r
6 * Tester avec des caractères exotiques (jap, coréen, etc..)\r
7 * Ralentir volontairement le connexion lors d'un mauvais login (ou après n mauvais login)\r
8 * Pouvoir afficher le login et/ou le pseudo. Avoir dans le profile une liste box avec ces choix :\r
9    * pseudo\r
10    * login\r
11    * pseudo(login)\r
12 * Réduire les pseudos trop long en mettant un ".." à la fin et permettre de le voir en entier lorsque le curseur le survol.\r
13 * Mettre un icone (genre sablier ou truc qui tourne à la apple) lorsque le chat se charge (également lors d'un changement de page par exemple)\r
14 * Modifier la syntaxe des smiles actuels (pour pas qu'ils entre en conflit avec totoz)\r
15 * Créer un favicon (joli)\r
16 * Ajouter dans la FAQ et/ou dans la page d'enregistrement les conditions d'utilisation, genre "chacun est responsable de ses dires" https://linuxfr.org/bouchot/\r
17 * Inscrire le nom de l'image dans les les liens vers des images (à la place de simplement [jpg] ou [gif])\r
18 * Ajouter de nouveaux smiles et changer la syntax pour eviter le conflit avec totoz :\r
19    * "slurp" : http://forum-images.hardware.fr/images/perso/huit.gif\r
20    * "agreed" : http://forum-images.hardware.fr/icones/smilies/jap.gif\r
21    * "dodo" (tete avec un bonnet de nuit et des ZZZZ)\r
22    * "hum?" : http://forum-images.hardware.fr/icones/smilies/heink.gif\r
23    * "pas reveillé" avec une tasse de café et des cernes : http://forum-images.hardware.fr/images/perso/elmoricq.gif\r
24    * "interrogation" genre http://forum-images.hardware.fr/icones/confused.gif\r
25    * http://forum-images.hardware.fr/images/perso/dao.gif ou http://forum-images.hardware.fr/icones/redface.gif\r
26    * http://forum-images.hardware.fr/icones/ohwell.gif\r
27 * Avoir un thème de discussion affiché en haut des messages genre appellé "troll de la semaine : linux sera-t-il desktop ready en 2008?"\r
28 * Un statut "EK" avec plein de privilège à la con. (avoir une petite étoile à coté de son nick ou le nick d'une certaine couleur)\r
29    * Une page pour voir les trolls de la semaine et pouvoir en ajouter et modifier les siens (page "admin")\r
30    * Pouvoir kick/ban un user (directement depuis le chat, lors du survol du pseudo d'un user des options sont présentés sous la forme de petits boutons)\r
31       * Un kick : l'utilisateur (ip) est kické et bannis pour 15 min\r
32       * Un ban : l'utilisateur (ip) est kické et bannis pour 3 jours
33       * Modification de la BD -> ajouter une relation "banned_ip"\r
34 * Traiter les tags TODO et FIXME dans le code\r
35 * Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)\r
36 * Restructurer le code Erlang : déplacer certaines fonctions d'un module à l'autre (ev. créer des modules)\r
37 * Choisir une licence et la mettre un peu partout dans les sources, voir : http://www.gnu.org/licenses/gpl-howto.fr.html\r
38 * Créer une page 'about'\r
39 * Trouver un moyen pour éviter la création à la suite de plusieurs comptes (via register). \r
40 * Finir le script de mise en production\r
41    * Make des modules.\r
42    * Compatage des js lors de la mise en production (afin d'optimiser la bande passante lors de l'accès au site), regarder comment fait jQuery.\r
43       * Modifier le script pour virer les lignes matchant /^\W*;;;.*$/
44    * Virer les commentaires dans les pages HTML\r
45 === v1.1 ===\r
46 * Tests de monter en charge coté serveur, analyse de la complexité (regarder du coté des TODO dans le code). Utiliser eventuellement Tsung\r
47 * Profiling pour améliorer les performances (client et serveur)\r
48    * traitementComplet() de euphorik.js est très très lent à executer\r
49 * Pouvoir récupérer son mdp (ou en générer un autre) via son email\r
50 === v1.2 ===\r
51 * Intégrer les totoz : http://www.totoz.eu/ (avec une limite de 3 par messages par exemple) \r
52    * avoir une option pour les cacher ou les voir\r
53    * Masquer systématiquement ceux qui dépassent d'une certaine taille (en pixel?)\r
54 === V1.3 ===\r
55 * Shift-enter pour ajouter une ligne dans la ligne de saisie (retour à la ligne)\r
56    * Crée un <br /> XHTML (lf -> br coté client)\r
57    * A chaque Shift-enter la textbox s'agrandit d'une ligne\r
58    * Pouvoir activer pas défaut la présentation multi-ligne via le profile\r
59 * Système de commande /<commande>\r
60    * /nick : changer de pseudo\r
61    * /me : "*<pseudo> <message>"\r
62    * /blam <login> : permet d'envoyer un blame à qqun (uniquement depuis un modo vers un non-modo)   \r
63    * /+ 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
64 * Ajout des wikilien : [[chien de prairie]] -> http://fr.wikipedia.org/wiki/Chien_de_prairie\r
65 === V1.4 ===\r
66 * 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
67 * Ajouter un skin "simple" sans images ni fioritures (éventuellement le proposer par défaut)\r
68 * Créer un style "super old school" (couleur 8 bit, pas de smiles/images, font fixe)\r
69 === V1.5 ===\r
70 * Gestion de l'historique au niveau du navigateur (pouvoir revenir aux pages précédentes). Utiliser un plugin jQuery si possible.\r
71 * gestion des timezone (fuseaux horaire) :\r
72    * 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
73 * 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
74 * Conversations : url vers conversation(s) + également un bouton sur chaque conversation pour obtenir l'url vers celle ci. (genre google map)\r
75 \r
76
77 [ok] Réaliser la structure suivante :
78    * Table minichat : {id, auteur_id, date, pseudo, contenu, reponses_minichat_id} reponses_minichat_id peut être null
79    * Table reponse_minichat : {id, minichat_id} la clef est (id, minichat_id)
80    * Table user : {id, cookie, pseudo, date_creation, date_derniere_connexion, css}
81 [ok] Implémenter le protocole dans 'fonctionnement_minichat.txt'
82 [ok] Trier la requête et limiter à N le nombre de messages affichés
83 [ok] réaliser un controller sous la forme d'une application pour receptionner tout ce qui vient des formulaires
84 [ok] Ajouter un lien minichat.iduser -> user.id
85 [ok] Ajouter un id pour les messages qui est un entier auto incrémenté
86 [ok] Afficher un captcha le md5 de la valeur est l'envoyer avec
87 [ok] Formater les dates
88 [ok] Trouver et remplacer les url http://www.youpla.com par <a href="http://www.youpla.com">[url]</a>
89 [ok] Traitement des smiles, remplacer :) par "<img src="img/smiles/content.gif" />"
90    * Pour ne pas entrer en conflit avec totoz.eu la notation est la suivante : [=slurp]
91    * La notation totoz.eu est : [:slurp]
92 [ok] Afficher les smiles disponibles, on peut clicker dessus pour en ajouter un dans le text
93 [ok] Mettre en évidence les posts auquels l'utilisateur courant à répondu ainsi que ses propres posts
94    * Vérifier le captcha
95    * Mettre un cookie
96 [ok] Mémoriser le pseudo et le remettre à chaque fois (si cookie)
97 [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).
98 [ok] Pouvoir répondre à un ou plusieurs messages en cliquant dessus (javascript)
99    * 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
100    * le(s) pseudo(s) de l'auteur du message auquel on répond préfixe notre message
101    * 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)
102 [ok] Maintenir le focus sur la ligne de saisie après l'envoie d'un message
103 [ok] Ajouter plusieurs messages d'un coup pour eviter des lenteurs au chargement
104 [pas besoin] Catcher les exceptions de parsage de l'xml dans euphorik_request
105 [ok] Ne pas virer les balises html mais remplacer les <> par &lt; &gt;
106 [ok mais limité] Avoir accès aux archives (par page, par exemple)
107 [ok] Interdir les {} dans les pseudo
108 [plus besoin] Finir le deamon
109 [plus besoin] tester si le captcha_crypt existe (en regardant les fichiers images temporaires)
110 [ok] Virer les balises html des messages et pseudo lors du stockage du message (et trimer).
111 [ok] afficher les pseudo des messages auquels un message répond (modification du protocole, il faut ajouter une liste de pseudo pour chaque message)
112 [ok] Possibilité de logout
113 [ok] Filtrer les { et } dans les pseudo sur la page profile
114 [ok] différentier [url] [gif] [png] et le reste des url. utiliser lightbox pour les images
115 [ok] Déplacer le formatage des messages du coté du client -> permet de demander à lightbox de reparser lors de l'ajout d'une image
116 [ok] Demander une confirmation lors d'un logout (are you sure jane ?) (vie la système de messagebox)
117 [ok] Possibilité d'enregistrement avec une page dédiée au profil.
118   * Pour se logger il suffit de donner un tuple login + password (le pseudo courant de chat est une données supplémentaire).
119   * La css choisie est une donnée personnelle.
120   * Les personnes enregistrées on un pseudo d'une couleur différente.
121   * (Ajout de smiles personnels)?
122 [ok] Ajouter des messages d'erreur ("login impossible", "captcha incorrect")
123 [ok] Ajouter des messages systèmes
124 [ok] Gérer le flood : si un utilisateur envoie plus de 2 messages par seconde pendant 5 secondes alors il ne peut plus poster pendant 5 secondes
125    * S'il récidive alors il est suspendu pendant 5^2 puis 5^3
126    * Utiliser les messages systèmes pour annonce le flood
127 [ok] Pouvoir modifier la css (dark/light)
128  * Créer le style lite
129  * Créer le style old (avec le style de l'ancien site)   
130 [ok] Ne pas afficher la css dans le profile
131 [ok] Ne pas effacer le message (dans le <input>) si l'on recoit un "pas ok" lors de l'envoie\r
132 [ok] Conversations : \r
133    [ok] implémenter coté serveur et client la sauvegarde et la restauration des conversations\r
134    [ok] Supprimer l'envoie de la description des conversations lors du refresh ainsi que modifié la manière de créer les conversations (maj des diagrammes de séquence)\r
135    [ok] Navigation vers les pages précédentes\r
136    [ok] Lien vers une conversation dans les messages sous cette forme {5F}. Le clic dessus ouvre la conversation. Egalement un bouton sur chaque conversation pour insérer son lien dans le message en cours de rédaction\r
137    [ok] Mettre à jour la CSS de chaque skin \r
138 [ok] Remplacer l'XML par du JSON. gain en simplicité et en temps d'execution.\r
139    [ok] Tester sur un prototype : l'authentification -> concluant\r
140    [ok] Si concluant passage complet à JSON\r
141    [ok] Les id ne sont plus passés en base 36\r
142    [ok] Flusher le profil lors du déchargement de la page ? -> oui\r
143    [ok] Envoyer les infos des conversations avec l'attente d'events ? -> oui
144 [ok] Problème de rafraichissement des couleurs des messages auquels on répond
145 [ok] Problème dans l'alternance des couleurs des messages
146 [ok] Utiliser une listbox pour la liste des css
147 [ok] Changer les noms des css : Light -> Cold, Old -> Classic
148 [ok] Faire une page faq et raconter n'importe quoi (entre autre la limitation avec firefox) "pourquoi ce site à des couleurs qui ne veulent rien dire ?"
149
150 === Bugs ===
151 1 : Critique
152 2 : Urgent
153 3 : Peu grave\r
154      
155 [1] Bug rafraichissement des conversations, exemple :
156    - la page 2 de la conv est affiché (mess 1 à 10) et la conv principale contient les mess de 11 à 2.
157    - lors de l'ajout d'un mess dans la conv celle ci n'est pas rafraichit.
158    - trouver une solution : donné un idDernierMess pour chaque conv ou supprimer cet idDernierMess et jouer sur le fait que l'on recoit un message après l'autre (orientation des messages après attente)
159 [1] Lors de l'extraction d'une conv il arrive que la conv extracté soit bien créée mais vide, le bouton ne ferme pas la conv (très étrange, bug de firefox?)
160 [2] Quand on revient en arrière dans firefox le message en rédaction est perdu
161 [2] En changeant de page puis en revenant sur la page principale les smiles ne sont plus highlightés lorsque le curseur les survol\r
162 [2] Dans certains cas (à déterminer) les message-box (message d'information affiché tout en haut de la page) ne s'affiche plus (on ne voit que un petit bout dépassé)
163 [2] Après un register le pseudo est effacé - le pseudo n'est pas mémorisé dans le profil lors d'un envoie de mess en l'ayant changé\r
164 [2] cliquer sur les smiles ne marche pas sous IE\r
165 [2] le return ne marche pas sous IE
166 [2] Lors d'un login ou d'un logout il faut faire un full refresh
167 [2] jQuery définit l'option "X-Requested-With" à "XMLHttpRequest dans l'entête HTTP. De ce fait Yaws exige absolument de l'xml...
168    Solution actuelle : jquery.js est modifié pour ne plus définir cette option. Trouver un autre moyen plus élégant.
169 [3] Un message envoyé sans être authentifié ne sera pas taggé comme appartenant à l'utilisateur.
170    a) L'utilisateur attend des messages SANS donné de cookie car il n'est pas authentifié
171    b) L'utilisateur envoie un message
172       i) Il se register sans login/pass (réalisé automatiquement)
173       ii) Il envoie le message (put_message)
174    c) Le serveur réagie au nouveau message et débloque la connexion, à ce moment le serveur n'a pas le cookie car pas donné, voir a)
175 [3] Traiter le cas ou le cookie n'existe pas coté serveur (et plus généralement traiter tous les cas d'inputs exeptionnels)
176 [3] "Return" ne marche pas sous safari
177 [3] Le "cachage" des messages ne marche pas sous Konqueror, voir : "#page.minichat #conversations div.cache {" dans pageMinichat.css.
178         "-khtml-opacity: 0.3;" ne fonctionne pas\r
179 [3] Amélioration des requêtes MNESIA, voir : http://mail.google.com/mail/#label/Erlang+mailing-list/117f688280569a58
180 [3] la page est completement rechargé après avoir submité le profile dans opera
181 [3] après le login un '?' s'ajoute à l'adresse (opera, firefox)
182
183 [ok] Comme le json du client est encapsulé dans de l'xml il faut utiliser des xml entities pour les charactères <, > et &. Il faudrait, absolument éviter cette encapsulation moisie.\r
184 [ok] Au bout d'un moment opera n'écoute plus rien... et donc n'affiche plus les nouveaux messages..\r
185 [ok] La méthod traiterSmiles est très lourde ! (4 secondes pour 80 appels (une page normale))\r
186 [ok] Utiliser Alpha truc à la place d'opacity sous explorer\r
187 [ok] les heures sont formatées par le serveur avec un espace devant : " 12.30:10", zarb\r
188 [ok] un undefined est mis lorsque l'on répond à qqun qui n'a pas de pseudo (traiter ces pseudo par le formateur)\r
189 [ok] On ne peut pas réponde aux messages du système\r
190 [ok] Apparement les process liés aux connexions ne sont jamais terminé même quand l'utilisateur coupe la connexion à cause de minichat:attends_nouveau_messages()\r
191
192
193 === Idées ===\r
194 Une fois l'idée validée elle est déplacée dans une version à venir.\r
195
196 1 : A implémenter tout de suite !
197 2 : A implémenter dans un futur proche
198 3 : Ca peut attendre
199 4 : A discuter
200 A : Abandonné
201 ok : Implémenté
202
203 [1] Possibilité d'extraire une conversation, on click (par l'intermediaire d'un petit bouton par exemple) sur un message et l'arbre de réponses correspondant s'affiche dans une colonne sur la gauche.
204    * Il est possible d'ouvrir plusieurs conversations
205    * Les messages faisant partie des conversations ne sont plus visibles dans le flux général
206    * (une colonne peut avoir le focus, dans ce cas on répond automatiquement à la dernière personne qui nous a répondu)
207    * Chaque colonne possède une entête avec le message d'origine et trois boutons :
208       * un pour copier l'id de la conversation dans la textbox (voir point suivant) 
209       * un pour fermer la conversation
210       * un pour créer une url vers cette conversation (un peu à la manière de google maps)
211 [2] Raccourcis pour répondre aux conversations (genre CTRL+2 pour répondre au deuxième)\r
212 [2] Syntaxe avancée des messagees :\r
213    * Possibilité d'utiliser les balises <i>, <b>, <code>, <q> (quoted text)
214    * La balise <hide> pour mettre des spoilers
215 [2] Pouvoir cacher les dates\r
216 [3] Gestion de l'historique (calendrier)\r
217 [4] Outil de localisation des personnes un peu comme ca : http://bouchot.org/cps
218 [4] Pouvoir voir le profile des personnes.
219    * Voir leurs derniers messages
220    * Une page de recherche de personne\r
221 [4] Chaque user possède un Blog (ne pas utiliser le terme 'Blog') Dans lequel il peut poster des "Troll", sorte de "sujet" de forum.\r
222    * Ce système est utilisé dans le chat principal (avec le troll de la semaine posté par un admin).\r
223    * Chaque troll possède un certain nombre de tag.\r
224    * il est possible de faire une recherche sur l'ensemble des users.\r
225    * Voir description.txt pour plus d'info sur les trolls\r
226 [4] Pouvoir privatiser une conversation entre 2 ou plusieurs personnes
227 [4] Pouvoir choisir une couleur pour son pseudo
228 [4] Créer un gamebot pour lancer des jeux. Par exemple un jeu d'énigmes
229 [4] Utiliser XMLRPC ou SOAP ou JSON pour la communication client -> serveur (boah, faut pas déconner :))
230 [4] Image animée à la http://www.google.co.kr/ cf http://www.google.co.kr//ig/f/AaEyQnOaAr4/intl/ALL_kr/svc_sprite_all.gif
231 [4] Bot de traduction
232 [4] Bot de jeu (jeu du pendu par exemple)
233 [4] RSS
234 [4] Système de vote sur les messages, + ou - qui donne des points aux messages...
235 [4] Voir les personnes connectées
236 [4] Avoir une liste d'amis
237 [4] Restreindre la consultation d'un message posté à un ou plusieurs utilisateurs définis. Les messages de la conversation ne sont alors vus que par cet ensemble d'utilisateurs.
238 [4] Système de trolls. Voir decription.txt.\r
239 \r
240 [A] smiles personnalisés, on peut en ajouter dans la préférence utilisateur.
241 [ok] Pouvoir insérer des tags qui sont des liens vers des conversations, par exemple : {R4S} =~ /\{\w+\}/
242
243
244 === Concurrents ===
245 http://www.phpfreechat.net/demo.fr.html
246 http://moules.org/board
247 http://hadoken.free.fr/board/index#b
248 http://bouchot.org/tribune#missive\r
249 https://linuxfr.org/board/