MOD mise en forme de util.js et conf.js, à faire pour tous les autres js
[euphorik.git] / doc / TODO.txt
1 == TODO ==\r
2 \r
3 Ce fichier est obsolète, Redmine le remplace : http://www.euphorik.ch:81
4
5 === v1.2 ===
6 * Pouvoir auto répondre à une conversation
7 * Possibilité d'ajouter des messages dans son profil
8    * Les messages sont soient publics soient privées (Par défaut privées)
9    * Un bouton "+" se trouve à coté de chaque message afin de pouvoir l'ajouter dans son profil
10    * Une série de mots clefs peuvent être ajoutée (tags) le message et alors indexé par rapport à ceux ci
11       * Par exemple : "news", "event", etc..
12       * Proposer les mots clefs les plus courants ?
13    * Une page "conversations" regroupe tous les messages publiques
14       * Il est possible de faire une recherche temps réelle sur les tags
15 * Downloader automatiquement toutes les images et substituer l'url original par une url locale relative
16    * Lorsqu'une image est postée un processus est lancé (de manière asynchrone évidemment), il va télécharger l'image et la stocker sur le serveur puis substituer l'url dans le message
17 * 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
18    * Eventuellement mettre à jour automatiquement le Copyright (date) et les personnes responsables 
19 * Système de censure par les admins (suppression d'un message)
20    * Ne supprime pas réellement le message mais le censure
21    * L'admin vois toujours le message (grisé, ou tracé)
22    * Les utilisateurs normaux voient à la place "<censuré, raison : blabla>"
23 ( * Intégrer les totoz : http://www.totoz.eu/ (avec une limite de 3 par messages par exemple) 
24    * avoir une option pour les cacher ou les voir
25    * Masquer systématiquement ceux qui dépassent une certaine taille en pixel ) -> site trop trash
26 (* Avoir une liste d'amis dans le profile
27    * Pouvoir n'afficher les messages que des amis (et des personnes y répondant)
28    * Ajouter une personne à ses amis avec une toolbar similaire à celle de banissement ) -> réflechir très fort à la réelle nécessité
29 === v1.3 ===
30 * Shift-enter pour ajouter une ligne dans la ligne de saisie (retour à la ligne)
31    * Crée un <br /> XHTML (lf -> br coté client)
32    * A chaque Shift-enter la textbox s'agrandit d'une ligne
33    * Pouvoir activer pas défaut la présentation multi-ligne via le profile (le nombre de ligne)
34 * Système de commande /<commande>
35    * /nick : changer de pseudo
36    * /me : "*<pseudo> <message>"
37    * /blam <login> : permet d'envoyer un blame à qqun (uniquement depuis un modo vers un non-modo)   
38    * /+ 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.
39 * Ajout des wikilien : [[chien de prairie]] -> http://fr.wikipedia.org/wiki/Chien_de_prairie
40 === v1.4 ===
41 * gestion des timezone (fuseaux horaire) :
42    * L'utilisateur peut simplement définir une timezone dans son profil, les dates sont alors affichées en fonction de sa zone (en option)
43 * Transfert des messages JSON (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
44    * voir : http://cert.startcom.org/ pour un certif gratuit ou du coté de cacert.org (linuxfr.org l'utilise)
45 * Mega stabilisation du code pour la cloture de la version 1 ! .. et en route pour la version 2 !
46 === v2.0 ===
47 * Création des channels, un file de discussion ainsi qu'un troll de la semaine par channel (est ce que les channels enfants possèdent aussi un troll de la semaine??)
48    * Un channel possède un nom, une langue, une description et une série de mots clefs (tags)
49    * Un channel peut être l'enfant d'un autre channel (et ceci de manière récursive).
50       * lorsque l'on se trouve sur un parent on voit récursivement les messages de tous les enfants
51       * S'il l'on répond à un message d'un channel enfant le message fait alors "partie" de ce channel enfant
52    * Une page ressence tous les channels, il est possible de faire des recherches de channel par mot clef de la même manière que pour les conversations
53    * N'importe qui peut créer un channel
54       * Il est alors admin pour ce channel et peu nommer d'autres admins (à réflechir)
55    * Le site euphorik.ch ne montre que le channel "euphorik"
56 * Création d'un site à l'échelle mondiale
57    * Ce site permet d'accèder à tous les channels
58    * Traduction du site en plusieurs langues
59
60
61 [ok] Réaliser la structure suivante :
62    * Table minichat : {id, auteur_id, date, pseudo, contenu, reponses_minichat_id} reponses_minichat_id peut être null
63    * Table reponse_minichat : {id, minichat_id} la clef est (id, minichat_id)
64    * Table user : {id, cookie, pseudo, date_creation, date_derniere_connexion, css}
65 [ok] Implémenter le protocole dans 'fonctionnement_minichat.txt'
66 [ok] Trier la requête et limiter à N le nombre de messages affichés
67 [ok] réaliser un controller sous la forme d'une application pour receptionner tout ce qui vient des formulaires
68 [ok] Ajouter un lien minichat.iduser -> user.id
69 [ok] Ajouter un id pour les messages qui est un entier auto incrémenté
70 [ok] Afficher un captcha le md5 de la valeur est l'envoyer avec
71 [ok] Formater les dates
72 [ok] Trouver et remplacer les url http://www.youpla.com par <a href="http://www.youpla.com">[url]</a>
73 [ok] Traitement des smiles, remplacer :) par "<img src="img/smiles/content.gif" />"
74    * Pour ne pas entrer en conflit avec totoz.eu la notation est la suivante : [=slurp]
75    * La notation totoz.eu est : [:slurp]
76 [ok] Afficher les smiles disponibles, on peut clicker dessus pour en ajouter un dans le text
77 [ok] Mettre en évidence les posts auquels l'utilisateur courant à répondu ainsi que ses propres posts
78    * Vérifier le captcha
79    * Mettre un cookie
80 [ok] Mémoriser le pseudo et le remettre à chaque fois (si cookie)
81 [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).
82 [ok] Pouvoir répondre à un ou plusieurs messages en cliquant dessus (javascript)
83    * 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
84    * le(s) pseudo(s) de l'auteur du message auquel on répond préfixe notre message
85    * 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)
86 [ok] Maintenir le focus sur la ligne de saisie après l'envoie d'un message
87 [ok] Ajouter plusieurs messages d'un coup pour eviter des lenteurs au chargement
88 [pas besoin] Catcher les exceptions de parsage de l'xml dans euphorik_request
89 [ok] Ne pas virer les balises html mais remplacer les <> par &lt; &gt;
90 [ok mais limité] Avoir accès aux archives (par page, par exemple)
91 [ok] Interdir les {} dans les pseudo
92 [plus besoin] Finir le deamon
93 [plus besoin] tester si le captcha_crypt existe (en regardant les fichiers images temporaires)
94 [ok] Virer les balises html des messages et pseudo lors du stockage du message (et trimer).
95 [ok] afficher les pseudo des messages auquels un message répond (modification du protocole, il faut ajouter une liste de pseudo pour chaque message)
96 [ok] Possibilité de logout
97 [ok] Filtrer les { et } dans les pseudo sur la page profile
98 [ok] différentier [url] [gif] [png] et le reste des url. utiliser lightbox pour les images
99 [ok] Déplacer le formatage des messages du coté du client -> permet de demander à lightbox de reparser lors de l'ajout d'une image
100 [ok] Demander une confirmation lors d'un logout (are you sure jane ?) (vie la système de messagebox)
101 [ok] Possibilité d'enregistrement avec une page dédiée au profil.
102   * Pour se logger il suffit de donner un tuple login + password (le pseudo courant de chat est une données supplémentaire).
103   * La css choisie est une donnée personnelle.
104   * Les personnes enregistrées on un pseudo d'une couleur différente.
105   * (Ajout de smiles personnels)?
106 [ok] Ajouter des messages d'erreur ("login impossible", "captcha incorrect")
107 [ok] Ajouter des messages systèmes
108 [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
109    * S'il récidive alors il est suspendu pendant 5^2 puis 5^3
110    * Utiliser les messages systèmes pour annonce le flood
111 [ok] Pouvoir modifier la css (dark/light)
112  * Créer le style lite
113  * Créer le style old (avec le style de l'ancien site)   
114 [ok] Ne pas afficher la css dans le profile
115 [ok] Ne pas effacer le message (dans le <input>) si l'on recoit un "pas ok" lors de l'envoie
116 [ok] Conversations : 
117    [ok] implémenter coté serveur et client la sauvegarde et la restauration des conversations
118    [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)
119    [ok] Navigation vers les pages précédentes
120    [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
121    [ok] Mettre à jour la CSS de chaque skin 
122 [ok] Remplacer l'XML par du JSON. gain en simplicité et en temps d'execution.
123    [ok] Tester sur un prototype : l'authentification -> concluant
124    [ok] Si concluant passage complet à JSON
125    [ok] Les id ne sont plus passés en base 36
126    [ok] Flusher le profil lors du déchargement de la page ? -> oui
127    [ok] Envoyer les infos des conversations avec l'attente d'events ? -> oui
128 [ok] Problème de rafraichissement des couleurs des messages auquels on répond
129 [ok] Problème dans l'alternance des couleurs des messages
130 [ok] Utiliser une listbox pour la liste des css
131 [ok] Changer les noms des css : Light -> Cold, Old -> Classic
132 [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 ?"
133 [ok] Ralentir volontairement le connexion lors d'un mauvais login (ou après n mauvais login)
134 [ok] Pouvoir afficher le login et/ou le pseudo. Avoir dans le profile une liste box avec ces choix :
135    * pseudo
136    * login
137    * pseudo(login)
138 * Créer un favicon (joli)
139 [ok] Créer une page 'about'
140 [ok] Ajouter de nouveaux smiles et changer la syntax pour eviter le conflit avec totoz :
141    * "slurp" : http://forum-images.hardware.fr/images/perso/huit.gif
142    * "agreed" : http://forum-images.hardware.fr/icones/smilies/jap.gif
143    * "dodo" (tete avec un bonnet de nuit et des ZZZZ)
144    * "hum?" : http://forum-images.hardware.fr/icones/smilies/heink.gif
145    * "pas reveillé" avec une tasse de café et des cernes : http://forum-images.hardware.fr/images/perso/elmoricq.gif
146    * "interrogation" genre http://forum-images.hardware.fr/icones/confused.gif
147    * http://forum-images.hardware.fr/images/perso/dao.gif ou http://forum-images.hardware.fr/icones/redface.gif
148    * http://forum-images.hardware.fr/icones/ohwell.gif
149 [ok] Tester avec des caractères accentués sur Firefox, Safari, Opera et IE7. Les messages doivent être envoyés en UTF8.
150 [ok] Tester avec des caractères exotiques (jap, coréen, etc..)
151 [ok] Modifier la syntaxe des smiles actuels (pour pas qu'ils entre en conflit avec totoz)
152 [ok] Trouver un moyen pour éviter la création à la suite de plusieurs comptes (via register). 
153 [ok] Restructurer le code Erlang : déplacer certaines fonctions d'un module à l'autre (ev. créer des modules)
154 [ok] remplacer lightbox par : http://leandrovieira.com/projects/jquery/lightbox/
155 [ok] Problème des images dans les trolls
156 [ok] Finir l'édition (mémoriser le contenu) des trolls
157 [ok] Est-ce que client.dernierMessageErreur est vraiment utile ??
158 [ok] marquer <aucun login> lors de l'affichage des login dans le chat pour les personnes n'en ayant pas : finalement il n'affiche tout simplement pas les logins
159 [ok] 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?"
160 [ok] 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)
161    * Une page "admin" avec :
162       * Trolls : La liste des trolls proposés. L'admin peut éditer ses propres trolls.
163       * Les ip bannis : avec la date d'échéance et le pseudo. Un admin peut décider de débannir un utilisateur
164    * 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)
165       * Un kick : l'utilisateur (ip) est kické et bannis pour 15 min
166       * Un ban : l'utilisateur (ip) est kické et bannis pour 3 jours
167       * Modification de la BD -> ajouter une relation "banned_ip"
168 [ok] Passer à jQuery 1.2.4
169 [ok] La largeur de la ligne de saisie doit corresponde à la largeur de la fenêtre
170 [ok] Lorsqu'un troll de la semaine est posté un message l'est également par le sys formant la racine de la conversation lié au troll
171    * Il est alors possible de voir la conversation lié au troll en cliquant sur le troll de la page principale
172 [ok] Faire des infos bulles à la facebook
173 [ok] Mettre les constantes au niveau du serveur dans euphorik_defines.hrl (par exemple les temps lié au flood)
174 [ok] Créer un style common puis adapter les CSS (classic et cold -> web2.0)
175    * Alignement du menu, du troll et des trolls de la partie admin à l'aide de line-height
176 [ok] Finir les options d'affichage des bulles et des dates
177 [ok] Stocker quelque part la version de la BD
178    * Créer une table "proprietes" contenant des tuples {propriete, nom, val}
179 [ok] Définir la bonne feuille de style au chargement de la page pour éviter le "clignotement" pas beau
180    * Le cookie envoyé par le client doit permettre de retrouver le user      
181 [ok] Finir le script de mise en production
182    * Make des modules.
183    * Compactage 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.
184       * Modifier le script pour virer les lignes matchant /^\W*;;.*$/
185    * Virer les commentaires dans les pages HTML
186    * processus :
187       1) copie des fichiers (+minimisation)
188       2) Execution d'un scripte erlang pour recharger tous les modules au sein du noeud
189       3) Executer euphorik_bd:update() pour mettre à jour la BD
190 [ok] 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/
191 [ok] Limiter la mise en évidence de la conversation lorsque le curseur se trouve sur les pseudos
192 [ok] Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)
193 [ok] Afficher l'ip dans le print_users().
194 [ok] Enlever le petit carré mis en couleur et mettre le pseudo + date en couleur à la place
195 [ok] Mettre dans la FAQ la signification des couleurs associées aux messages.
196 [ok] Elaborer une stratégie de mise à jour de la structure de la BD quand celle ci est modifiée (voir euphorik_bd:vers_version())   
197 \r
198
199 === Bugs ===
200 1 : Critique
201 2 : Urgent
202 3 : Peu grave
203
204 [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.
205 [ok] Au bout d'un moment opera n'écoute plus rien... et donc n'affiche plus les nouveaux messages..
206 [ok] La méthod traiterSmiles est très lourde ! (4 secondes pour 80 appels (une page normale))
207 [ok] Utiliser Alpha truc à la place d'opacity sous explorer
208 [ok] les heures sont formatées par le serveur avec un espace devant : " 12.30:10", zarb
209 [ok] un undefined est mis lorsque l'on répond à qqun qui n'a pas de pseudo (traiter ces pseudo par le formateur)
210 [ok] On ne peut pas réponde aux messages du système
211 [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()
212 [ok] Bug rafraichissement des conversations, exemple :
213    - la page 2 de la conv est affiché (mess 1 à 10) et la conv principale contient les mess de 11 à 2.
214    - lors de l'ajout d'un mess dans la conv celle ci n'est pas rafraichit.
215    - 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)
216 [ok] En changeant de page puis en revenant sur la page principale les smiles ne sont plus highlightés lorsque le curseur les survol
217    * Plus reproduit
218 [ok] 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é)
219    * Plus reproduit
220 [ok] 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é
221 [ok] jQuery définit l'option "X-Requested-With" à "XMLHttpRequest dans l'entête HTTP. De ce fait Yaws exige absolument de l'xml...
222    Solution actuelle : jquery.js est modifié pour ne plus définir cette option. Trouver un autre moyen plus élégant.
223 [ok] Les smiles ne devraient pas dépasser de la fenêtre lorsqu'ils sont affichés
224 [ok] Les processus en attente ne se termine pas lorsque le socket est fermé (pour l'instant un timeout de 1heure est appliqué)
225 [ok] Possibilité d'enregistrer plusieurs users avec le même login
226 [ok] le return ne marche pas sous IE
227 [ok] Lors du click sur le bouton slap/kick/ban il faut fermer la mini fenêtre
228 [ok] Lors de l'extraction d'une conv il arrive que la conv extractée soit bien créée mais vide, le bouton ne ferme pas la conv (très étrange, bug de firefox?)
229    * Arrive une fois sur 20 environ
230    * Jamais reproduit avec Opera
231    * Peut être un bug lié à jQuery
232    * Reproduit sur Firefox 2 et 3 !
233 [ok] Lors d'un logout il faut faire un full refresh (pour mettre à jour les messages auquel on répond par exemple)
234 [ok] Après être passé de la page Admin à Chat le client continu de réaliser de temps en temp des requêtes "lists_banned_ips"
235    * action=%7B%22action%22%3A%22list_banned_ips%22%2C%22cookie%22%3A%22<<cookie>>%22%7D
236 [ok] Le widget select qui permet la sélection des css n'est pas initialisé correctement au chargement du site
237 [ok] Il est possible d'envoyer plusieurs fois le même message en pressant très rapidement plusieurs fois sur ENTER... (à vérifier)
238 [ok] griser le login dans le profil pour montrer qu'on ne peut pas l'éditer
239
240
241 === Idées ===
242 Une fois l'idée validée elle est déplacée dans une version à venir.
243
244 1 : A implémenter tout de suite !
245 2 : A implémenter dans un futur proche
246 3 : Ca peut attendre
247 4 : A discuter
248 A : Abandonné
249 ok : Implémenté
250
251 [3] Gestion de l'historique (calendrier)
252 [3] Afficher une page concernant la grammaire, ya un topic sur HFR
253 [3] Compatibilité avec wmcoinoin
254    * http://moules.org/les_normes/le_backend (utilisé la DTD et non le schéma qui n'est pas correct)
255    * http://pycoincoin.free.fr/wikini/wakka.php?wiki=PagePrincipale
256 [3] Recharger automatiquement la page lorsque les numéros de la version du protocole ne sont plus égaux (kiki)
257 [3] Idée de bernie :
258    * Pouvoir STFUER des personnes, lorsqu'elle envoie un message un autre truc à la con est écrit à la place
259    * la phrase à la con est prise parmis une liste éditable depuis le panneau d'admin
260    * La stfuation se fait depuis le panel de bannissement (slap, stfu, kick, ban)
261 [4] Créer un style "super old school" (couleur 8 bit, pas de smiles/images, police à chasse fixe)
262 [4] Unifier tout le code en anglais (sauf les commentaires)
263 [4] Inscrire le nom de l'image dans les liens vers des images (à la place de simplement [jpg] ou [gif])
264 [4] Réduire les pseudos trop long en mettant un ".." à la fin et permettre de le voir en entier lorsque le curseur le survol.
265 [4] Compatible OpenID pour l'identification
266 [4] Outil de localisation des personnes un peu comme ca : http://bouchot.org/cps
267 [4] Pouvoir voir le profile des personnes.
268    * Voir leurs derniers messages
269    * Une page de recherche de personne
270 [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.
271    * Ce système est utilisé dans le chat principal (avec le troll de la semaine posté par un admin).
272    * Chaque troll possède un certain nombre de tag.
273    * il est possible de faire une recherche sur l'ensemble des users.
274    * Voir description.txt pour plus d'info sur les trolls
275 [4] Pouvoir privatiser une conversation entre 2 ou plusieurs personnes
276 [4] Pouvoir choisir une couleur pour son pseudo
277 [4] Créer un gamebot pour lancer des jeux
278    * Définir une interface pour la création de nouveau jeu au sein du serveur
279    * Jeu d'énigmes
280    * jeu du pendu
281    * Jeu des chiffres et des lettres : "[Lettres tirées] - E N X U L S Z C M I - (trouvez le mot de plus long avec ces lettres)"
282 [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
283 [4] Bot de traduction
284 [4] RSS
285 [4] Système de vote sur les messages, + ou - qui donne des points aux messages...
286 [4] Voir les personnes connectées + un statut
287 [4] Avoir une liste d'amis
288 [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.
289 [4] Système de trolls. Voir decription.txt.
290
291 [A] smiles personnalisés, on peut en ajouter dans la préférence utilisateur.
292 [ok] Pouvoir insérer des tags qui sont des liens vers des conversations, par exemple : {R4S} =~ /\{\w+\}/
293 [ok] 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.
294    * Il est possible d'ouvrir plusieurs conversations
295    * Les messages faisant partie des conversations ne sont plus visibles dans le flux général
296    * (une colonne peut avoir le focus, dans ce cas on répond automatiquement à la dernière personne qui nous a répondu)
297    * Chaque colonne possède une entête avec le message d'origine et trois boutons :
298       * un pour copier l'id de la conversation dans la textbox (voir point suivant) 
299       * un pour fermer la conversation
300       * un pour créer une url vers cette conversation (un peu à la manière de google maps)
301 [ok] Pouvoir cacher les dates