ADD avancement sur les trolls, partie d'administration presque terminée
[euphorik.git] / doc / TODO.txt
index 2f732f1..f6b6b16 100755 (executable)
@@ -1,55 +1,36 @@
 == TODO ==\r
 \r
 === v1.0 ===\r
-[ok] Conversations : \r
-   [ok] implémenter coté serveur et client la sauvegarde et la restauration des conversations\r
-   [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
-   [ok] Navigation vers les pages précédentes\r
-   [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
-   [ok] Mettre à jour la CSS de chaque skin 
-* Flush le profil lors du déchargement de la page
-* Envoyer les infos des conversations avec l'attente d'events
-* Problème de rafraichissement des couleurs des messages auquels on répond\r
-* Remplacer l'XML par du JSON. gain en simplicité et en temps d'execution.\r
-   * Tester sur un prototype : l'authentification\r
-   * Si concluant passage complet à JSON\r
-   * Les id ne sont plus passés en base 36
-* Changer les noms des css : Light -> Cold, Old -> Classic\r
-* Utiliser une listbox pour la liste des css\r
-* 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
-* 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 ?"\r
-* Ralentir volontairement le connexion lors d'un mauvais login (ou après n mauvais login)\r
-* Pouvoir afficher le login et/ou le pseudo.\r
-   Avoir dans le profile une liste box avec ces choix :\r
-   * pseudo\r
-   * login\r
-   * pseudo(login)\r
-* Réduire les pseudo trop long en mettant un ".." à la fin et permettre de le voir en entier lorsque le curseur le survol.\r
-* 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
-* Tester avec des caractères exotiques (jap, coréen, etc..)\r
-* Rendre compatible IE 7\r
-* Créer un favicon (joli)\r
+[80%] 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
+   * Une page "admin" avec :\r
+      * Trolls : La liste des trolls proposés. L'admin peut éditer ses propres trolls.\r
+      * Les ip bannis : avec la date d'échéance et le pseudo. Un admin peut décider de débannir un utilisateur\r
+   * 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
+      * Un kick : l'utilisateur (ip) est kické et bannis pour 15 min\r
+      * Un ban : l'utilisateur (ip) est kické et bannis pour 3 jours\r
+      * Modification de la BD -> ajouter une relation "banned_ip"\r
+* Créer un style common puis adapter les CSS (classic et cold -> web2.0)\r
+* Rendre compatible IE 7 (pfff..)\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
+   * Simuler un réseau lent\r
 * 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
-* Inscrire le nom de l'image dans les les liens vers des images (à la place de simplement [jpg] ou [gif])\r
-* Ajouter de nouveaux smiles et changer la syntax pour eviter le conflit avec totoz :\r
-   * "slurp" : http://forum-images.hardware.fr/images/perso/huit.gif\r
-   * "agreed" : http://forum-images.hardware.fr/icones/smilies/jap.gif\r
-   * "dodo" (tete avec un bonnet de nuit et des ZZZZ)\r
-   * "hum?" : http://forum-images.hardware.fr/icones/smilies/heink.gif\r
-   * "pas reveillé" avec une tasse de café et des cernes : http://forum-images.hardware.fr/images/perso/elmoricq.gif\r
-   * "interrogation" genre http://forum-images.hardware.fr/icones/confused.gif\r
-   * http://forum-images.hardware.fr/images/perso/dao.gif ou http://forum-images.hardware.fr/icones/redface.gif\r
-   * http://forum-images.hardware.fr/icones/ohwell.gif\r
-* 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
-* Finir le script de mise en production\r
-   * 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.
-   * modifier le script pour virer les lignes matchant /^\W*;;;.*$/\r
-* Traiter les tags TODO et FIXME dans le code\r
+* 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
+* Traiter les tags TODO et FIXME dans le code
+   * Mettre les constantes au niveau du serveur dans euphorik_defines.hrl (par exemple les temps lié au flood)\r
 * Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)\r
-* Restructurer le code Erlang : déplacer certaines fonctions d'un module à l'autre (ev. créer des modules)\r
-* Choisir une licence et la mettre un peu partout dans les sources\r
-* Créer une page 'about'\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
+* Passer à jQuery 1.2.4\r
+* Mise à jour automatique de la version dans le about en fonction du tag/branche courant ?
+* La largeur de la ligne de saisie doit corresponde à la largeur de la fenêtre
+* Corriger les bugs de niveau [1] et [2]\r
+* Finir le script de mise en production\r
+   * Make des modules.\r
+   * 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.\r
+      * Modifier le script pour virer les lignes matchant /^\W*;;;.*$/
+   * Virer les commentaires dans les pages HTML\r
 === v1.1 ===\r
+* Passer sur git !?\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
@@ -57,8 +38,7 @@
 === v1.2 ===\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 d'une certaine taille (en pixel?)\r
-   * modifier la syntaxe des smiles actuels (pour pas qu'ils entre en conflit avec totoz)\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
@@ -79,6 +59,7 @@
 * 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
 
  * Créer le style lite
  * Créer le style old (avec le style de l'ancien site)   
 [ok] Ne pas afficher la css dans le profile
-[ok] Ne pas effacer le message (dans le <input>) si l'on recoit un "pas ok" lors de l'envoie
-
+[ok] Ne pas effacer le message (dans le <input>) si l'on recoit un "pas ok" lors de l'envoie\r
+[ok] Conversations : \r
+   [ok] implémenter coté serveur et client la sauvegarde et la restauration des conversations\r
+   [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
+   [ok] Navigation vers les pages précédentes\r
+   [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
+   [ok] Mettre à jour la CSS de chaque skin \r
+[ok] Remplacer l'XML par du JSON. gain en simplicité et en temps d'execution.\r
+   [ok] Tester sur un prototype : l'authentification -> concluant\r
+   [ok] Si concluant passage complet à JSON\r
+   [ok] Les id ne sont plus passés en base 36\r
+   [ok] Flusher le profil lors du déchargement de la page ? -> oui\r
+   [ok] Envoyer les infos des conversations avec l'attente d'events ? -> oui
+[ok] Problème de rafraichissement des couleurs des messages auquels on répond
+[ok] Problème dans l'alternance des couleurs des messages
+[ok] Utiliser une listbox pour la liste des css
+[ok] Changer les noms des css : Light -> Cold, Old -> Classic
+[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 ?"
+[ok] Ralentir volontairement le connexion lors d'un mauvais login (ou après n mauvais login)
+[ok] Pouvoir afficher le login et/ou le pseudo. Avoir dans le profile une liste box avec ces choix :
+   * pseudo
+   * login
+   * pseudo(login)
+* Créer un favicon (joli)
+[ok] Créer une page 'about'
+[ok] Ajouter de nouveaux smiles et changer la syntax pour eviter le conflit avec totoz :
+   * "slurp" : http://forum-images.hardware.fr/images/perso/huit.gif
+   * "agreed" : http://forum-images.hardware.fr/icones/smilies/jap.gif
+   * "dodo" (tete avec un bonnet de nuit et des ZZZZ)
+   * "hum?" : http://forum-images.hardware.fr/icones/smilies/heink.gif
+   * "pas reveillé" avec une tasse de café et des cernes : http://forum-images.hardware.fr/images/perso/elmoricq.gif
+   * "interrogation" genre http://forum-images.hardware.fr/icones/confused.gif
+   * http://forum-images.hardware.fr/images/perso/dao.gif ou http://forum-images.hardware.fr/icones/redface.gif
+   * http://forum-images.hardware.fr/icones/ohwell.gif
+[ok] Tester avec des caractères accentués sur Firefox, Safari, Opera et IE7. Les messages doivent être envoyés en UTF8.
+[ok] Tester avec des caractères exotiques (jap, coréen, etc..)
+[ok] Modifier la syntaxe des smiles actuels (pour pas qu'ils entre en conflit avec totoz)
+[ok] Trouver un moyen pour éviter la création à la suite de plusieurs comptes (via register). 
+[ok] Restructurer le code Erlang : déplacer certaines fonctions d'un module à l'autre (ev. créer des modules)
+[ok] remplacer lightbox par : http://leandrovieira.com/projects/jquery/lightbox/
 
 === Bugs ===
 1 : Critique
 2 : Urgent
 3 : Peu grave\r
-\r
-[1] Problème d'utf-8 avec opera, firefox et konqueror, le prologue (<?xml charset="utf8"...) n'est pas supporté par certains navigateur
-[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?)
-[2] Quand on revient en arrière dans firefox le message en rédaction est perdu
-[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
-[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é)
-[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
-[2] cliquer sur les smiles ne marche pas sous IE\r
+     
+[1] Possibilité d'enregistrer plusieurs users avec le même login
+[1] 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?)
+   * Arrive une fois sur 20 environ
+   * Jamais reproduit avec Opera\r
+[2] cliquer sur les smiles ne marche pas sous IE
+[2] Les smiles ne devraient pas dépasser de la fenêtre lorsqu'ils sont affichés\r
 [2] le return ne marche pas sous IE
+[2] Lors d'un login ou d'un logout il faut faire un full refresh (pour mettre à jour les messages auquel on répond par exemple)
+[3] Quand on revient en arrière dans firefox le message en rédaction est perdu
+   * Pas sous Opera, apparemment Firefox recharge toute la page (donc impossible qu'il puisse remettre le message)
+   * Eventuellement sauvegarder le message en rédaction dans le profile...\r
+[3] Le changement de page sous Firefox (pas essayé avec d'autre nav) es plutot moche, le texte est d'abors affiché puis le style est appliqué.
+[3] Quelques fichiers sont encore en iso-8859-1 (Makefile, euphorik_bd.hrl, etc..) tout passer en UTF-8
+[3] Un message envoyé sans être authentifié ne sera pas taggé comme appartenant à l'utilisateur.
+   a) L'utilisateur attend des messages SANS donné de cookie car il n'est pas authentifié
+   b) L'utilisateur envoie un message
+      i) Il se register sans login/pass (réalisé automatiquement)
+      ii) Il envoie le message (put_message)
+   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)
 [3] Traiter le cas ou le cookie n'existe pas coté serveur (et plus généralement traiter tous les cas d'inputs exeptionnels)
-[3] "Return" ne marche pas sous safari\r
+[3] "Return" ne marche pas sous safari
+[3] Le "cachage" des messages ne marche pas sous Konqueror, voir : "#page.minichat #conversations div.cache {" dans pageMinichat.css.
+       "-khtml-opacity: 0.3;" ne fonctionne pas\r
 [3] Amélioration des requêtes MNESIA, voir : http://mail.google.com/mail/#label/Erlang+mailing-list/117f688280569a58
 [3] la page est completement rechargé après avoir submité le profile dans opera
 [3] après le login un '?' s'ajoute à l'adresse (opera, firefox)
-\r
+
+[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
 [ok] Au bout d'un moment opera n'écoute plus rien... et donc n'affiche plus les nouveaux messages..\r
 [ok] La méthod traiterSmiles est très lourde ! (4 secondes pour 80 appels (une page normale))\r
 [ok] Utiliser Alpha truc à la place d'opacity sous explorer\r
 [ok] les heures sont formatées par le serveur avec un espace devant : " 12.30:10", zarb\r
 [ok] un undefined est mis lorsque l'on répond à qqun qui n'a pas de pseudo (traiter ces pseudo par le formateur)\r
 [ok] On ne peut pas réponde aux messages du système\r
-[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
-
+[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()
+[ok] Bug rafraichissement des conversations, exemple :
+   - la page 2 de la conv est affiché (mess 1 à 10) et la conv principale contient les mess de 11 à 2.
+   - lors de l'ajout d'un mess dans la conv celle ci n'est pas rafraichit.
+   - 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)
+[ok] En changeant de page puis en revenant sur la page principale les smiles ne sont plus highlightés lorsque le curseur les survol
+   * Plus reproduit
+[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é)
+   * Plus reproduit\r
+[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é
+[ok] jQuery définit l'option "X-Requested-With" à "XMLHttpRequest dans l'entête HTTP. De ce fait Yaws exige absolument de l'xml...
+   Solution actuelle : jquery.js est modifié pour ne plus définir cette option. Trouver un autre moyen plus élégant.
 
 === Idées ===\r
 Une fois l'idée validée elle est déplacée dans une version à venir.\r
@@ -187,16 +230,25 @@ ok : Implémenté
       * un pour créer une url vers cette conversation (un peu à la manière de google maps)
 [2] Raccourcis pour répondre aux conversations (genre CTRL+2 pour répondre au deuxième)\r
 [2] Syntaxe avancée des messagees :\r
-   * Possibilité d'utiliser les balises <i>, <b>, <code>, <q> (quoted text)
+   * Possibilité d'utiliser les balises <i>, <b>, <code>, <q> (quoted text)\r
+   * Utiliser la syntaxe de mediaWiki
    * La balise <hide> pour mettre des spoilers
 [2] Pouvoir cacher les dates\r
-[3] Gestion de l'historique (calendrier)\r
+[3] Gestion de l'historique (calendrier)
+[3] Idée de bernie :
+   * Pouvoir STFUER des personnes, lorsqu'elle envoie un message un autre truc à la con est écrit à la place
+   * la phrase à la con est piché parmis une liste éditable depuis le panneau d'admin
+   * La stfuation se fait depuis le panel de bannissement (slap, stfu, kick, ban)
+[4] Unifier tout le code en anglais (sauf les commentaires)
+[4] Inscrire le nom de l'image dans les les liens vers des images (à la place de simplement [jpg] ou [gif])
+[4] Réduire les pseudos trop long en mettant un ".." à la fin et permettre de le voir en entier lorsque le curseur le survol.\r
+[4] Compatible OpenID pour l'identification\r
 [4] Outil de localisation des personnes un peu comme ca : http://bouchot.org/cps
 [4] Pouvoir voir le profile des personnes.
    * Voir leurs derniers messages
    * Une page de recherche de personne\r
 [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
-   * Ce système est utilisé dans le chat principale (avec le troll de la semaine posté par un admin).\r
+   * Ce système est utilisé dans le chat principal (avec le troll de la semaine posté par un admin).\r
    * Chaque troll possède un certain nombre de tag.\r
    * il est possible de faire une recherche sur l'ensemble des users.\r
    * Voir description.txt pour plus d'info sur les trolls\r
@@ -212,7 +264,7 @@ ok : Implémenté
 [4] Voir les personnes connectées
 [4] Avoir une liste d'amis
 [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.
-[4] Plusieurs canaux\r
+[4] Système de trolls. Voir decription.txt.\r
 \r
 [A] smiles personnalisés, on peut en ajouter dans la préférence utilisateur.
 [ok] Pouvoir insérer des tags qui sont des liens vers des conversations, par exemple : {R4S} =~ /\{\w+\}/