ADD possibilité d'inverser le sens du chat
[euphorik.git] / modules / include / euphorik_bd.hrl
index a3a7f20..053c046 100755 (executable)
+% Copyright 2008 Grégory Burri
+%
+% This file is part of Euphorik.
+%
+% Euphorik is free software: you can redistribute it and/or modify
+% it under the terms of the GNU General Public License as published by
+% the Free Software Foundation, either version 3 of the License, or
+% (at your option) any later version.
+%
+% Euphorik is distributed in the hope that it will be useful,
+% but WITHOUT ANY WARRANTY; without even the implied warranty of
+% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+% GNU General Public License for more details.
+%
+% You should have received a copy of the GNU General Public License
+% along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.
+%
 % @author GBurri
-% Version 3
-
-% Pour générer des id\r
--record(counter,\r
-   {\r
-      key,\r
-      value\r
-   }).\r
-\r
-% décrit un enregistrement d'un message\r
+
+
+% Version de la BD
+-define(VERSION_BD, 2).
+
+
+% Pour générer des id
+-record(counter,
+   {
+      key,
+      value
+   }).
+   
+   
+% Mémorse toutes les propriétés, entre autre la version des données
+-record(proprietes,
+   {
+      nom,
+      valeur
+   }).
+
+
+% décrit un enregistrement d'un message
 -record(minichat,
-   {\r
-      id, % integer\r
+   {
+      id, % integer
       auteur_id, % -> #user.id
       date, % erlang:now()
-      pseudo, % chaine de caractère
-      contenu % chaine de caractère
-   }).\r
+      pseudo, % chaine de caractère
+      contenu, % chaine de caractère
+      troll_id = undefined, % l'id du troll associé correspondant
+      racine_id = undefined % la racine, par défaut correspond à l'id du message
+   }).
    
-   \r
-% type bag\r
-% 'repondant' repond à 'cible'\r
--record(reponse_minichat,\r
-   {\r
-      repondant, % -> #minichat.id\r
-      cible % -> #minichat.id\r
-   }). \r
-
-\r
--record(user,\r
-   {\r
-      id,\r
-      cookie, % string()\r
+   
+% type bag
+% 'repondant' repond à 'cible'
+-record(reponse_minichat,
+   {
+      repondant, % -> #minichat.id
+      cible % -> #minichat.id
+   }). 
+
+
+-record(user,
+   {
+      id,
+      cookie, % string()
       pseudo = [], % string()
       login = [], % string()
       password = [], % string() (md5)
-      email = [], % string()\r
-      date_creation, % erlang:now()\r
-      date_derniere_connexion, % erlang:now(), est mis à jour lors de n'importe quelle activitée (envoie de message par exemple)\r
+      email = [], % string()
+      date_creation, % erlang:now()
+      date_derniere_connexion, % erlang:now(), est mis à jour lors de n'importe quelle activitée (envoie de message par exemple)
       css = [], % string()
-      indice_flood = 0, % integer() est incrémenté lorsque l'utilisateur envoie trop rapidement des messages.
-      page_principale = 1, % la page de la conversation principale
-      conversations = [] % [{integer(), integer()}], la liste des messages correspondant au conversation ainsi que la page affichée\r
-   }). 
+      nick_format = nick, %atom(), peut valoir 'nick', 'login' ou 'nick_login'
+      view_times = true,
+      view_tooltips = true,
+      ostentatious_master = light, % peut valoir invisible, light ou heavy. seulement pour ek_master
+      chat_order = reverse, % peut valoir chrono ou reverse
+      indice_flood = 0, % integer() est incrémenté lorsque l'utilisateur envoie trop rapidement des messages.
+      conversations = [], % [{integer(), bool}], la liste des messages correspondant au conversation {racine, reduite?}
+      ek_master = false,
+      last_ip = undefined % integer(), undefined si inconnu
+   }).
+
+
+% identificateur : (ip)
+-record(ip_table,
+   {
+      ip, % {integer(), integer(), integer(), integer()}
+      ban = undefined, % la date du dernier bannissement
+      ban_duration = 0, % le temps de ban en minute
+      nb_try_register = 0,
+      nb_try_login = 0, % pour l'instant pas utilisé
+      date_last_try_register,
+      date_last_try_login % pour l'instant pas utilisé
+   }).
+   
    
+-record(troll,
+   {
+      id,
+      id_user,
+      date_create, % erlang:now()
+      date_post = undefined, % date à laquelle le troll est affiché sur la page principale. undefined initialement puis erlang:now() quand affiché
+      content % chaine de caractère
+   }).
    
\ No newline at end of file