MOD Avancement sur la mise à jour de la BD pour la 1.1 et le système de mise à jour
[euphorik.git] / doc / TODO.txt
index 6e4c09f..0864852 100755 (executable)
@@ -1,20 +1,20 @@
-== TODO ==\r
+== TODO ==
 \r
-=== v1.0 ===\r
-* Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)
-* Pouvoir afficher les utilisateurs (print_users(admin)) qui sont admin\r
-   * Afficher l'ip dans le print_users().\r
-* Limiter la mise en évidence de la conversation lorsque le curseur se trouve sur les pseudos\r
-* Mettre dans la FAQ la signification des couleurs associées aux messages.\r
-* Enlever le petit carré mis en couleur et mettre le pseudo + date en couleur à la place\r
-* Ne pas pouvoir poster avec "<nick>"\r
-* Lorsque le curseur se trouve sur le nom d'une personne à qui l'on répond n'highliter que cette conversation !! (très bonne idée)\r
-=== v1.1 ===\r
+=== v1.1 ===
+* Faire l'update vers la version 2 pour les changements de la BD :
+   * suppression de #user.page_principale
+   * modification de #user.conversations (les pages ne sont plus mémorisées)
+   * ajout de #minichat.racine_id\r
+* La validation du profil fait revenir sur la page de chat\r
+* Gestion de l'historique au niveau du navigateur (pouvoir revenir aux pages précédentes). Utiliser un plugin jQuery si possible. Voir du coté des ancres (fragment d'url) : #ancre.\r
+   * http://www.euphorik.ch/#page=chat\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
+   * Tous les messages auquels on répond doivent faire partie de la conversation !
+   * L'entête de la conversation contient le premier message (la racine)\r
+   * Possibilité de fermer temporairement une conversation (la réduire sous la forme d'un onglet)\r
+   * lien vers une conversation : http://www.euphorik.ch/#conv=45
+   * faire un backup de la base v1 avant d'écrire la mise à jour 1->2, permet de revenir à la 1 si des modifs supplémentaires sont nécessaires\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
 * 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
+* Pouvoir récupérer son mdp (ou en générer unhttp://www.euphorik.ch/ 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é
+* Modifier le comportement du système de reponse :
+   * Ne plus concatener les id des messages auquels on répond
+   * Un élément se place entre le pseudo et la ligne de saisie du message et affiche le nombre de message auquel on répond
+      * Lorsque l'on passe le curseur sur cet élément les messages sont affichés en dessous du bouton
+   * Les messages auquels ont répond sont mis en évidence
+      * lors de la mise à jour des messages la liste est interrogé pour savoir s'il faut le mettre en évidence
+* Ne plus mémoriser le numéro de page dans le profile\r
+=== v1.2 ===
+* Possibilité d'ajouter des messages dans son profil
+   * Les messages sont soient publics soient privées (Par défaut privées)
+   * Un bouton "+" se trouve à coté de chaque message afin de pouvoir l'ajouter dans son profil
+   * Une série de mots clefs peuvent être ajoutée (tags) le message et alors indexé par rapport à ceux ci
+      * Par exemple : "news", "event", etc..
+      * Proposer les mots clefs les plus courants ?
+   * Une page "conversations" regroupe tous les messages publiques
+      * Il est possible de faire une recherche temps réelle sur les tags\r
+* Downloader automatiquement toutes les images et substituer l'url original par une url locale\r
+   * Lorsqu'une image est posté 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\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
    * /+ 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
    * processus :
       1) copie des fichiers (+minimisation)
       2) Execution d'un scripte erlang pour recharger tous les modules au sein du noeud
-      3) Executer euphorik_bd:update() pour mettre à jour la BD
-[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/
-      
+      3) Executer euphorik_bd:update() pour mettre à jour la BD\r
+[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/\r
+[ok] Limiter la mise en évidence de la conversation lorsque le curseur se trouve sur les pseudos\r
+[ok] Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)\r
+[ok] Afficher l'ip dans le print_users().
+[ok] Enlever le petit carré mis en couleur et mettre le pseudo + date en couleur à la place
+[ok] Mettre dans la FAQ la signification des couleurs associées aux messages.\r
+[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())   
+=== v1.0.1 ===
+[ok] Ne pas pouvoir poster avec "<nick>"
+\r
 === Bugs ===
 1 : Critique
 2 : Urgent
 3 : Peu grave\r
 \r
-[1] Traiter les tags TODO et FIXME dans le code
+[1] Il arrive qu'après le poste d'un message le refresh ne se fasse plus, peut-être une "race-condition" dans la classe PageEvent de euphorik.js\r
+   * Observé sur opera et firefox\r
+   * Après quelques analyses il apparait que firefox attend alors que le processus n'existe plus du coté yaws\r
+   * Cela arrive après 5-10min\r
+   * Regarder du coté des paramètres (options) du socket coté yaws s'il n'y a pas un indice, par exemple un timeout\r
+   * solution de secours : timeout de (1 à 5 min) sur la connexion ajax\r
+   * Est-ce que yaws tient compte du "Keep-Alive 300" de l'entête HTTP ? (=5min) (normalement pas puisque HTTP/1.1) après avoir regardé les sources il me semble que non\r
+   * Normalement si le socket est fermé du coté de yaws, le client devrait être avertis... !?\r
+   * Après beaucoup d'investigation il semblerai que se soit le firewall/routeur qui coupe la connexion sans prévenir,\r
+      pour éviter cela il est possible de mettre 'keepalive' à true au niveau du socket, voir : \r
+         - http://erlang.org/doc/man/inet.html#setopts-2\r
+         - http://forums.globalscape.com/tm.aspx?m=4114
+[2] Le minificateur js doit ajouter un espace après une expression régulière sinon il est possible que le caractère qui suit celle ci soit pris pour un modificateur de la regexp
+[2] Le widget select qui permet la sélection des css n'est pas initialisé correctement au chargement du site\r
+[2] Traiter les tags TODO et FIXME dans le code\r
 [2] Le changement de skin n'est pas mémorisé lorsque l'on est pas connecté (normal puisque le style est mémorisé dans le profil)
    * solution 1 : permettre le changement de skin uniquement pour les personnes enregistré ?
    * solution 2 : mémoriser le skin courant dans un cookie\r
+[2] Il est possible d'envoyer plusieurs fois le même message en pressant très rapidement plusieurs fois sur ENTER... (à vérifier)\r
 [2] Après l'ajout d'une image il n'est pas possible de naviger depuis celle ci vers les autres images en utilisant Next et Prev de lightbox après l'avoir affich\r
 [2] Plein de bugs sous MS internet explorer 7
    * click sur le lien du conv insère sont id systématiquement au début du message
    * le changement de skin foire complétement
-[2] griser le login dans le profil pour montrer qu'on ne peut pas l'éditer
 [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) est plutot moche, le texte est d'abors affiché puis le style est appliqué.
+[3] Le changement de page sous Firefox (pas essayé avec d'autre nav) est plutot moche, le texte est d'abord 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é
    * Jamais reproduit avec Opera
    * Peut être un bug lié à jQuery
    * Reproduit sur Firefox 2 et 3 !
-[ok] Lors d'un logout il faut faire un full refresh (pour mettre à jour les messages auquel on répond par exemple)
+[ok] Lors d'un logout il faut faire un full refresh (pour mettre à jour les messages auquel on répond par exemple)\r
+[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"
+   * action=%7B%22action%22%3A%22list_banned_ips%22%2C%22cookie%22%3A%22<<cookie>>%22%7D
+[ok] Le widget select qui permet la sélection des css n'est pas initialisé correctement au chargement du site
+[ok] Il est possible d'envoyer plusieurs fois le même message en pressant très rapidement plusieurs fois sur ENTER... (à vérifier)
+[ok] griser le login dans le profil pour montrer qu'on ne peut pas l'éditer
+
 
 === Idées ===\r
 Une fois l'idée validée elle est déplacée dans une version à venir.\r