From 1269889704386de951d7f91eb169eb1e1bb36cc0 Mon Sep 17 00:00:00 2001
From: Ludovic Pouzenc <ludovic@pouzenc.fr>
Date: Sat, 30 Jun 2018 11:10:17 +0200
Subject: Sous-dossier app entre old4 et old5

---
 appli_3_alpha_old/app/include/connect.inc.php      |  14 +
 appli_3_alpha_old/app/include/ical.inc.php         |  68 +++
 appli_3_alpha_old/app/include/je.inc.php           | 175 ++++++++
 appli_3_alpha_old/app/include/ju.inc.php           | 107 +++++
 appli_3_alpha_old/app/include/ludo/TODO_list.txt   |  24 +
 appli_3_alpha_old/app/include/ludo/auth.inc.php    |  78 ++++
 appli_3_alpha_old/app/include/ludo/config.inc.php  |  71 +++
 .../app/include/ludo/div_create_or_modif.php       |  86 ++++
 .../app/include/ludo/fonctions.inc.php             | 494 +++++++++++++++++++++
 .../app/include/ludo/html_elements.inc.php         | 138 ++++++
 .../app/include/ludo/mail_textarea.php             |  44 ++
 appli_3_alpha_old/app/include/ludo/majDispo.php    |  41 ++
 appli_3_alpha_old/app/include/ludo/redir.inc.php   |  20 +
 .../app/include/ludo/session_verify.inc.php        |   9 +
 14 files changed, 1369 insertions(+)
 create mode 100644 appli_3_alpha_old/app/include/connect.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ical.inc.php
 create mode 100644 appli_3_alpha_old/app/include/je.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ju.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/TODO_list.txt
 create mode 100644 appli_3_alpha_old/app/include/ludo/auth.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/config.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/div_create_or_modif.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/fonctions.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/html_elements.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/mail_textarea.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/majDispo.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/redir.inc.php
 create mode 100644 appli_3_alpha_old/app/include/ludo/session_verify.inc.php

(limited to 'appli_3_alpha_old/app/include')

diff --git a/appli_3_alpha_old/app/include/connect.inc.php b/appli_3_alpha_old/app/include/connect.inc.php
new file mode 100644
index 0000000..b985b10
--- /dev/null
+++ b/appli_3_alpha_old/app/include/connect.inc.php
@@ -0,0 +1,14 @@
+<?php 
+/*
+ * Param�tres de connexion � la base MySQL
+ */
+ 
+// $bd repr�sente le nom de la database � utiliser
+$bd = "awor";
+// mysql_connect(<nom_ou_ip_serveur_mysql>, <utilisateur_mysql>, <mot_de_passe_en_clair_mysql>);
+$link = @mysql_connect('localhost', 'lud_restricted', 'maille_ess_ku_elle');
+
+@mysql_select_db($bd , $link);
+
+// NB : La gestion d'erreur est inhib�e. Cet include ne g�n�rera jamais de code, m�me si la connexion n'a pas pu �tre �tablie
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ical.inc.php b/appli_3_alpha_old/app/include/ical.inc.php
new file mode 100644
index 0000000..5df8e4c
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ical.inc.php
@@ -0,0 +1,68 @@
+<?php
+/*
+ * Fonction de g�n�ration d'iCal
+ */
+ 
+// Constantes d'erreur
+define("ERR_ICAL_NO_DATA", -1);
+define("ERR_ICAL_SQL_ERROR", -2);
+ 
+ function generationIcal($idP, &$iCal_name, &$iCal_content, &$errmsg)
+{
+	require_once('connect.inc.php');
+	$query = 'SELECT DISTINCT R.idR,R.objetR,P.courrielP,UNIX_TIMESTAMP(C.dateHeure),C.duree,R.lieuR,R.ordreJourR,L.idL'
+		. ' FROM Liste L,Reunion R,Appartenir A,Creneau C,Personne P'
+		. " WHERE ((A.idP = $idP AND A.idL = L.idL) OR R.idP_Orga = $idP)"
+		. ' AND  R.idL = L.idL AND C.idC = R.idC_Fixe AND P.idP = R.idP_Orga';
+	
+	if ( ! $result = @mysql_query($query) )
+	{
+		// Cas d'erreur
+		$errmsg =mysql_generate_errmsg();
+		return ERR_ICAL_SQL_ERROR;
+	}
+	else
+	{
+		if (mysql_num_rows($result)<1)
+		{
+			return ERR_ICAL_NO_DATA;
+		}
+		else
+		{
+			$time = time();
+			$iCal_name = "iCal_${idP}_${time}.ics";
+			$iCal_content = "BEGIN:VCALENDAR\r\n" . "VERSION:2.0\r\n";
+			while ( list($idR, $objetR, $courrielP, $dateDeb, $duree, $lieuR, $ordreJourR, $idL) = mysql_fetch_array($result) )
+			{
+				// TODO : Il est probablement judicieux d'ajouter � l'UID un timestamp unix !!!!!
+				$iCal_content .= "BEGIN:VEVENT\r\n" . "UID:awor_${idP}.${idR}\r\n" . "SUMMARY:$objetR ($courrielP)\r\n";
+				$iCal_content .= 'DTSTART:' . date('Ymd\THis', $dateDeb) . "\r\n";
+				$iCal_content .= 'DTEND:' . date('Ymd\THis', $dateDeb+60*$duree) . "\r\n";
+				$iCal_content .= "LOCATION:$lieuR\r\n";
+				$iCal_content .= "DESCRIPTION:$ordreJourR\r\n";
+				
+				$query = 'SELECT P.courrielP FROM Appartenir A,Personne P' . " WHERE A.idP=P.idP AND A.idL='$idL'";
+				if ( ! $result = mysql_query($query) )
+				{
+					// Cas d'erreur
+					$errmsg =mysql_generate_errmsg();
+					$ret=ERR_ICAL_SQL_ERROR;
+					break;
+				}
+				else
+				{
+					while ( list($mail_autres) = mysql_fetch_array($result) )
+					{
+						$iCal_content .= "ATTENDEE:mailto:$mail_autres\r\n";
+					}
+				}
+				// TODO : v�rifier la pertinance de la variable utilis�e
+				$iCal_content .= 'URL:http://' . $_SERVER['HTTP_HOST'] . "\r\n";
+				$iCal_content .= "END:VEVENT\r\n";
+			}
+			$iCal_content .= "END:VCALENDAR\r\n";
+			return 0;
+		}
+	}
+}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/je.inc.php b/appli_3_alpha_old/app/include/je.inc.php
new file mode 100644
index 0000000..e902a1a
--- /dev/null
+++ b/appli_3_alpha_old/app/include/je.inc.php
@@ -0,0 +1,175 @@
+<?php
+require_once ('include/connect.inc.php');
+
+	function traiter_formulaire_valider_modif_personnes()
+	{
+		//V�rification a faire pour savoir si c'est bien le propri�taire ?!! $_SESSION['session_idP']
+		$tabParticipant = array();
+		if (isset($_GET['dataParticipants'])) $tabParticipant = $_GET['dataParticipants'];
+		$idL=-1;
+		if (!isset($_GET['idL']) && isset($_GET['listname'])) 
+		{
+			if (isset($_GET['isPrivate']))	$isPrivate = 'oui'; else $isPrivate = 'non';
+			$idL = list_new($_GET['listname'],$_GET['idP'],$isPrivate); 
+		}
+		else {$idL = $_GET['idL'];}
+			
+		if ($idL != -1) list_modif($idL,$tabParticipant);
+	}
+	
+	function traiter_formulaire_delete_list()
+	{
+		//V�rification a faire pour savoir si c'est bien le propri�taire ?!! $_SESSION['session_idP']
+		if (isset($_GET['idL'])) list_delete($_GET['idL']);
+	}
+	
+	function list_delete($idL)
+	{
+		$result = mysql_query("DELETE FROM Appartenir WHERE idL=$idL;");
+		$result = mysql_query("DELETE FROM Liste WHERE idL=$idL;");
+	}
+	
+	function list_new($listname,$idP,$isPrivate)
+	{
+		$result = mysql_query("INSERT INTO Liste (libelleL,estPrivee,idP_Createur) VALUES ('$listname','$isPrivate',$idP)") or die (mysql_error());
+		if (mysql_affected_rows() > 0)
+		{
+			return (mysql_insert_id());
+		}
+	}
+	
+	function list_modif($idL,$tabParticipant)
+	{
+		$result = mysql_query("SELECT P.idP,P.courrielP FROM Appartenir A, Personne P WHERE P.idP = A.idP AND A.idL=$idL") or die (mysql_error());
+		if (mysql_num_rows($result)>=0)
+		{
+			//Fabrication des trois tableaux
+			$tabOldPers = array();
+			$tabOldPersMail = array();
+			$tabNewPers = array();
+			if (!empty($tabParticipant)) $tabNewPers = $tabParticipant;
+			for($i=0;$i<mysql_num_rows($result);$i++)
+			{
+				$row = mysql_fetch_array($result);
+				$tabOldPers[$i] = $row[0];
+				$tabOldPersMail[$i] = $row[1];
+			}			
+			//Boucle permettant de mettre a NULL les �lements identiques aux deux tableaux
+			$i = 0;
+			while ($i < count($tabOldPers))
+			{
+				$exist=false;
+				for ($j=0;$j<count($tabNewPers);$j++)
+				{
+					if (($tabOldPers[$i] == $tabNewPers[$j]) or ($tabOldPersMail[$i] == $tabNewPers[$j]))  
+					{
+						$exist = true;
+						$tabNewPers[$j]=NULL;
+					}
+				}
+				if ($exist)
+				{
+					$tabOldPers[$i]=NULL;
+					$tabOldPersMail[$i]=NULL;
+				}
+				$i++;
+			}
+		}
+		
+		//Construction du tableau des participants a ajouter
+		$tabAdd = array();
+		foreach ($tabNewPers as $pers)
+		{
+			//Si c'est une adresse Mail : Inscription + Ajout Sinon Ajour simplement
+			if (!stristr($pers,'@')===false)
+			{
+				$tabAdd[] = new_pers($pers);
+			}
+			else
+			{
+				if ($pers != NULL)	$tabAdd[] = $pers;
+			} 
+		}
+		//Enleve les redondances d'idP
+		$tabAdd=array_unique($tabAdd);
+		//Envoie a la fonction d'ajout de personne
+		list_add_pers($tabAdd,$idL);
+		
+		//Construction du tableau des participants a ajouter
+		$tabRemove = array();
+		foreach ($tabOldPers as $pers)
+		{
+			if ($pers != NULL)	$tabRemove[] = $pers;
+		}
+		//Envoie a la fonction de suppression de personne
+		list_remove_pers($tabRemove,$idL);
+		
+	}
+	
+	function list_add_pers ($tabPers,$idL)
+	{
+		foreach ($tabPers as $pers)
+		{
+			$result=mysql_query("INSERT INTO Appartenir (idP,idL) VALUES ($pers,$idL);");
+		}
+
+	}
+	
+	function list_remove_pers ($tabPers,$idL)
+	{
+		
+		foreach ($tabPers as $pers)
+		{
+			$result = mysql_query("DELETE FROM Appartenir WHERE idP=$pers AND idL=$idL;");
+		}
+		
+	}
+	
+	
+	//Fonction Inscription qui prends en parametre une adresse mail $persMail et qui retourne l'id de la perssonne (s'il elle existe) 
+	// ou Insert une personne et retourne son identifiant
+	function new_pers ($persMail)
+	{
+		$result = mysql_query("SELECT idP,courrielP FROM Personne WHERE courrielP = '$persMail'");
+		if (mysql_num_rows($result)>0)
+		{
+			$row = mysql_fetch_array($result);
+			return ($row['idP']);
+		}
+		else
+		{
+			$result = mysql_query("INSERT INTO Personne (courrielP,loginP) VALUES ('$persMail','$persMail')");
+			return (mysql_insert_id());
+		}
+			
+		return (0);
+	}
+	
+	
+	
+	//Fonction qui affiche toutes les liste public ainsi que les liste priv�e poss�d�es par idP
+	function generate_html_array_list ($idP)
+	{
+		$result = mysql_query("SELECT idL,libelleL,estPrivee,idP_Createur FROM Liste WHERE idP_Createur=$idP OR estPrivee='non' ORDER BY estPrivee,libelleL");
+		echo "<table>\n<tr>\n<th>Supprimer</th>\n<th>Type</th>\n<th>Libell&eacute;</th>\n</tr>\n";	
+		if (mysql_num_rows($result)>0)
+		{
+			
+			for($i=0;$i<mysql_num_rows($result);$i++)
+			{
+				$row = mysql_fetch_array($result);
+				echo "<tr>\n<td>";
+				if ($row['estPrivee'] == 'oui' || $row['idP_Createur']==$idP) echo "<a href=\"#\" onclick=\"loadid('popdeletelist.php?idL=".$row[0]."','popdeletelist',true);popon('popdeletelist')\"><img src=\"images/supprimer.png\" alt=\"Supprimer ".$row[1]."\" /></a></td>\n" ; else echo "</td>\n";
+				if ($row['estPrivee'] == 'oui') echo "<td>estPriv&eacute;e" ; else echo "<td>Public";
+				echo "</td>\n<td>";
+				echo "<a href=\"#\" onclick=\"loadid('poppersonne.php?idL=".$row['idL']."&amp;idP_orga=".$idP."','poppersonne',true);popon('poppersonne')\">";
+				echo $row['libelleL'];
+				echo "</a></td>\n";
+				echo "</tr>\n";
+			}
+			
+		}
+		echo "</table>\n";
+		
+	}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ju.inc.php b/appli_3_alpha_old/app/include/ju.inc.php
new file mode 100644
index 0000000..3402f39
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ju.inc.php
@@ -0,0 +1,107 @@
+<?php
+function traiter_formulaire_popfichier()
+{
+	$file = "fichier";
+	if(isset($_FILES[$file]))
+	{
+		if($_FILES[$file]["error"] == 0)
+		{
+			//R�cup�ration de l'extension
+			$ext = explode(".", $_FILES[$file]["name"]);
+			$ext = array_pop($ext);
+			if($ext == "txt" || $ext == "doc" || $ext == "jpg" || $ext == "gif" || $ext == "zip")
+			{
+				if(move_uploaded_file($_FILES[$file]["tmp_name"], $_SERVER['DOCUMENT_ROOT']."/fichiers/".$_FILES[$file]["name"]))
+				{
+					echo "DEBUG :".$_SERVER['DOCUMENT_ROOT']."/fichiers/\n";
+					$requete = "INSERT INTO Fichier(nomFic, idR) VALUES ('".$_FILES[$file]["name"]."', '".$_GET["idR"]."')";
+					mysql_query($requete);
+					echo "DEBUG : ".mysql_error()."<br/>\n";
+					echo "DEBUG : ".$requete."<br/>\n";
+				}
+				else
+				{
+					echo "NOK"; 
+				}
+			}
+		}
+		else
+		{
+			switch($_FILES[$file]["error"])
+			{
+				case 1 : $erreur = "Le fichier a une taille trop importante."; break;
+				case 2 : $erreur = "Le fichier a une taille trop importante."; break;
+				case 3 : $erreur = "Le fichier n'a pas ete envoye en entier."; break;
+				case 4 : $erreur = "Aucun fichier recu."; break;
+			}
+			echo $erreur;
+		}
+	}
+	else
+	{
+		echo "isset";
+	}
+}
+
+// Modifi�e par Ludo pour les probl�mes de vriables de session et pour d'autres d�tails :
+// S'il n'y a pas de commentaire, on affiche le tableau vide
+function generate_html_reunion_commentaires($idR)
+{
+	$idP = $_SESSION['session_idP'];
+	$requete = "SELECT * FROM Repondre WHERE idP != '".$idP."' AND idR = '".$idR."'";
+	//echo "DEBUG : requete : $requete\n";
+	$resultat = mysql_query($requete);
+	if($resultat != false)
+	{
+		echo '<table cellspacing="0" class="commentaires" summary="Liste des commentaires laiss�s pour les personnes convi�es � cette r�union">
+		<thead>
+			<tr>
+				<th>Commentaires <a href="#">(Editer votre commentaire)</a></th>
+			</tr>
+		</thead>';
+		if(mysql_num_rows($resultat) > 0)
+		{
+			while($fichier = mysql_fetch_array($resultat))
+			{
+				if ( isset($_SESSION['session_nomP']) && isset($_SESSION['session_prenomP']) )
+				{
+					$nom = $_SESSION['session_nomP']." ".$_SESSION['session_prenomP'];
+				}
+				else
+				{
+					$nom = $fichier["idP"];
+				}
+				echo '<tr><td>'.$nom." : ".$fichier["commentaireReponse"]."</td></tr>\n";
+			}
+		}
+		else
+		{
+			echo "<tr><td>Aucun commentaire pour le moment.</td></tr>\n";
+		}
+		echo '</table>';
+	}
+}
+	
+function generate_html_reunion_fichiers($idR)
+{
+	$requete = "SELECT * FROM Fichier WHERE idR = '".$idR."'";
+	$resultat = mysql_query($requete);
+	if($resultat != false)
+	{
+		if(mysql_num_rows($resultat) > 0)
+		{
+			echo '<table cellspacing="0" class="fichiers" summary="Liste des fichiers post�s par les participants de la r�union.">';
+			echo '<thead>';
+			echo '<tr>';
+			echo '<th>Fichiers attach&eacute;s <a href="#" onclick="popon(\'popfichier\')">(Ajouter un fichier)</a></th>';
+			echo '</tr>'."\n";
+			echo '</thead>';
+			while($fichier = mysql_fetch_array($resultat))
+			{
+				echo "<tr><td><a href=\"../fichiers/".$fichier["nomFic"]."\">".$fichier["nomFic"]."</a></td></tr>\n";
+			}
+			echo '</table>';
+		}
+	}
+}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ludo/TODO_list.txt b/appli_3_alpha_old/app/include/ludo/TODO_list.txt
new file mode 100644
index 0000000..724c46c
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/TODO_list.txt
@@ -0,0 +1,24 @@
+Accueil > _Listes_ (virer le lien)
+
+mysql_free_result après les requetes et mysql_close ?
+
+configuration de PHP dans un fichier INI :
+array parse_ini_file ( string filename [, bool process_sections] )
+
+
+Vérifier que les redirections vers authentification et le retour fasse bien suivre les paramètres
+--> bookmarque details_reunion?idR=1
+ 	 
+
+faire une fonction JS qui appelle une page php ou créer toute seule un cookie qui gère la préférence du css.
+
+Se préoccuper des accents et des encodages de pages !
+
+Faire un pied de page avec nos noms, et les logos valide XHTML, CSS...
+
+TODO : un script php qui purge la base
+-> export SQL ancienne base ?
+-> suppression des réunions plus vielles que...
+-> suppression des Personnes n'ayant jamais changé leur profil et n'ayant plus de réunion les concernant
+-> suppression de tout les créneaux non référencés
+-> suppression de toutes les listes privées obsoletes
diff --git a/appli_3_alpha_old/app/include/ludo/auth.inc.php b/appli_3_alpha_old/app/include/ludo/auth.inc.php
new file mode 100644
index 0000000..18b339d
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/auth.inc.php
@@ -0,0 +1,78 @@
+<?php
+/*
+ * Collection de fonctions pour une authentification externe POP3
+ */
+
+// Constantes d'erreur
+define("ERR_POP3_AUTH_BADSOCK", -1);
+define("ERR_POP3_AUTH_SERVERNACK", -2);
+define("ERR_POP3_AUTH_BADUSER", -3);
+define("ERR_POP3_AUTH_BADPASS", -4);
+define("ERR_BAD_PARAMS", -100);
+
+// Fonction d'authentification pop3
+function pop3_auth_simple($mail, $upw)
+{
+	if ( ($ret = ereg ( "(^.*)@([[:alnum:]]+\.[[:alnum:]]+)", $mail, $re_tokens ) ) )
+	{
+		/* $re_tokens	[]
+		 *			[0] : email complet
+		 *			[1] : nom_mail
+		 *			[2] : serveur_mail
+		 */
+		require_once('config.inc.php');
+		$srv_conf = $CONFIG['AUTH']['POP']['SERVERS'][strtolower($re_tokens[2])];
+		if ( is_array($srv_conf) )
+		{
+			$server=$srv_conf['subdomain'];
+			$port=$srv_conf['port'];
+			if ( $srv_conf['username_is_full_mail'] )
+				{ $user = $mail; } else { $user = $re_tokens[1]; }
+			return pop3_auth ($server, $port, $user, $upw);
+		}
+	}
+	/* DEBUG
+	echo $mail . "\n" . $ret . "\n";;
+	print_r($re_tokens);
+	*/
+	return ERR_BAD_PARAMS;
+}
+
+function pop3_auth ($server, $port, $user, $upw)
+{
+	//echo "DEBUG : fsockopen($server, $port, $errno, $errstr, 10);";
+	$sock = @fsockopen($server, $port, $errno, $errstr, 10);
+	if ( $sock === false)
+	{
+		return ERR_POP3_AUTH_BADSOCK;
+	}
+
+	//stream_set_timeout ( $sock, 1, 0 );
+	
+	fputs($sock, "user $user\r\n");
+
+	if ( pop3_GetAndTestReply($sock) === false )
+	{
+		return ERR_POP3_AUTH_BADUSER;
+	}
+
+	fputs($sock, "pass $upw\r\n");
+
+	if ( pop3_GetAndTestReply($sock) === false )
+	{
+		return ERR_POP3_AUTH_BADPASS;
+	}
+
+	fputs($sock, "quit\r\n");
+	
+	return 0;
+}
+
+// Fonction interne testant les r�ponses du serveur POP3
+function pop3_GetAndTestReply($sock)
+{
+	$reply = fgets($sock, 128);
+	echo $reply . "\n";
+	return ( substr($reply, 0, 4) == "+OK " );
+}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ludo/config.inc.php b/appli_3_alpha_old/app/include/ludo/config.inc.php
new file mode 100644
index 0000000..ea3d0ba
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/config.inc.php
@@ -0,0 +1,71 @@
+<?php
+$CONFIG = array
+(
+	'adminMail' => 'jmi@iut-blagnac.fr',
+	'automatedMail' => 'no_reply@iut-blagnac.fr',
+	'AUTH' => array
+	(
+		'POP' => array
+		(
+			'SERVERS' => array
+			(
+				'wanadoo.fr' => array
+				(
+					'subdomain' => 'pop.orange.fr',
+					'port' => 110,
+					'username_is_full_mail' => false
+				),
+				'orange.fr' => array
+				(
+					'subdomain' => 'pop.orange.fr',
+					'port' => 110,
+					'username_is_full_mail' => false
+				)
+			)
+		),
+		'bypass_if_local' => false
+	),
+	'CSS' => array
+	(
+		'CHOOSER_LIST' => array
+		(
+			// 'nom � afficher' => 'nom_fichier_sans_extension'
+			'standard' => 'ice',
+			'bleu' => 'style1'
+		)
+	),
+	'MAIL' => array
+	(
+		'TEMPLATES' => array
+		(
+			'cree' => array
+			(
+				'caption' => 'Nouvelle R�union',
+				'tpl_file' => 'mail_cree.php'
+			),
+			'modif' => array
+			(
+				'caption' => 'R�union modifi�e',
+				'tpl_file' => 'mail_modif.php'
+			),
+			'annul' => array
+			(
+				'caption' => 'R�union annul�e',
+				'tpl_file' => 'mail_annul.php'
+			),
+			'fixee' => array
+			(
+				'caption' => 'R�union fix�e',
+				'tpl_file' => 'mail_fixee.php'
+			)
+		)
+	),
+	'UPLOAD' => array
+	(
+		'accepted_files' => array
+		(
+			'jpg', 'jpeg', 'gif', 'png', 'svg', 'pdf', 'ps', 'txt', 'rtf', 'csv', 'doc', 'docx', 'ppt', 'xls', 'sxw','sxp','sxd', 'odt', 'odg', 'odp', 'avi', 'mpg', 'mpeg', 'rm', 'flv', 'mp3', 'mp4', 'ogg','htm','html','zip', 'rar', 'tar', 'gz', 'bz2', 'ace' 
+		)
+	)
+);
+?>
diff --git a/appli_3_alpha_old/app/include/ludo/div_create_or_modif.php b/appli_3_alpha_old/app/include/ludo/div_create_or_modif.php
new file mode 100644
index 0000000..e6c3f8e
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/div_create_or_modif.php
@@ -0,0 +1,86 @@
+<?php
+$isModif=false;
+if ( isset ( $_GET['idR']) )
+{
+	if ( ! isset($_GET['objetR']) || ! isset($_GET['lieuR']) || ! isset($_GET['ordreJourR']) || ! isset($_GET['remarquesR']) )
+	{
+		$errmsg="Impossible de modifier la r�union : Param�tres incorrects\n";
+		return;
+	}
+	$idR=addslashes($_GET['idR']);
+	$objetR=addslashes($_GET['objetR']);
+	$lieuR=addslashes($_GET['lieuR']);
+	$ordreJourR=addslashes($_GET['ordreJourR']);
+	$remarquesR=addslashes($_GET['remarquesR']);
+	
+	$isModif=true;
+}
+?>
+<form action="" method="post">
+	<table class="detail_reunion" summary="D�tail de la r�union que vous avez s�lectionn�e">
+		<thead>
+			<tr>
+				<th colspan="2">
+					<?php if ($isModif) { echo 'Modification des d�tails de la r�union'; } else { echo 'Cr�ation d\'une r�union'; } ?>
+				</th>
+			</tr>
+		</thead>
+		<tbody>
+			<tr>
+				<td><strong>Objet :</strong></td>
+				<td>
+					<input name="objetR" type="text" size="40" <?php if ($isModif) { echo 'value="' . $objetR .'"'; } ?>></input>
+				</td>
+			</tr>
+<!--			<tr>
+				<td><strong>Organisateur :</strong></td>
+				<td>
+					<?php// echo "$prenomP $nomP\n"; ?>
+				</td>
+			</tr>
+-->
+			<tr>
+				<td><strong>Lieu :</strong></td>
+				<td>
+					<input name="lieuR" type="text" size="40" <?php if ($isModif) { echo 'value="' . $lieuR .'"'; } ?>></input>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Ordre du jour :</strong></td>
+				<td>
+					<textarea name="ordreJourR" cols="40" rows="3"><?php if ($isModif) { echo $ordreJourR; } ?></textarea>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Remarques :</strong></td>
+				<td>
+					<textarea name="remarquesR" cols="40" rows="3"><?php if ($isModif) { echo $remarquesR; } ?></textarea>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Etat :</strong></td>
+				<td>
+					<input name="isCancelled" type="checkbox">Annul�e</input>
+					<?php
+						// TODO : refl�ter l'�tat de la BD pour l'annulation !
+					?>
+				</td>
+			</tr>
+			<tr>
+				<!--<td>&nbsp;</td>-->
+				<td colspan="2">
+					<input name="Valider" type="submit" value="Valider"></input>
+					<?php
+						// TODO : refl�ter l'�tat de la BD pour l'annulation !
+						//~ echo '<a href="#confirmAnnulation" onclick="loadid(\'include/ludo/popConfirmAnnulR.php?idR=';
+						//~ echo $idR . "','popfixer',true);popon('popfixer');\">Annuler</a>";
+					?>
+				</td>
+			</tr>
+		</tbody>
+	</table>
+	<input name="action" type="hidden" value="modif_detail_reunion" />
+<?php
+	echo ' <input name="idR" type="hidden" value="' . $idR . '" />'
+?>
+</form>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ludo/fonctions.inc.php b/appli_3_alpha_old/app/include/ludo/fonctions.inc.php
new file mode 100644
index 0000000..f24a8c2
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/fonctions.inc.php
@@ -0,0 +1,494 @@
+<?php
+/*
+ * Fonctions de g�n�ration de message d'erreur pour utilisateur (et le debuggueur !)
+ */
+// Fonction retournant un message d'erreur correspondant � une erreur mysql
+function mysql_generate_errmsg()
+{
+	if ( isset($_REQUEST['debug']) )
+	{
+		return 'Erreur SQL num�ro ' . mysql_errno() . ' : ' . mysql_error();
+	}else{
+		return 'Une erreur de base de donn�es s\'est produite, veuillez r�essayer ult�rieurement.';
+	}
+}
+
+// Fonction retournant un message d'erreur correspondant � un numero d'erreur de pop3_auth(...)
+function pop3_generate_errmsg($errno)
+{
+	require_once 'auth.inc.php';
+
+	if ( isset($_REQUEST['debug']) )
+	{
+		$msg = 'Erreur authentification POP3 de code ' . $errno;
+	}else{
+		switch ($errno)
+		{
+			case ERR_POP3_AUTH_BADUSER :
+			case ERR_POP3_AUTH_BADPASS :
+				$msg = 'Authentification rejet�e : V�rifiez votre identifiant et saisissez votre mot de passe � nouveau';
+			break;
+			case ERR_BAD_PARAMS :
+				$msg = 'Adresse email invalide, ou serveur mail non r�pertori�';
+			break;
+			default :
+				$msg = 'Une erreur de communication avec le service d\'authentification s\'est produite,' .
+				'veuillez r�essayer ult�rieurement.';
+			break;
+		}
+	}
+	return $msg;
+}
+
+/*
+ * G�n�ration du code html d'une case du tableau crois� Cr�neau/Presonnes ayant comme personne $idP,
+ * comme cr�neau $idC. Si $idEditable est vrai je pourrai cliquer sur le bouton
+ * pour donner ma disponibilit�. $estDispo peut-�tre 'oui', 'non', ou '' et signifie que la personne a d�j� r�pondu 'oui', non'
+ * ou n'a pas encore r�pondu.
+ */
+// G�n�ration d'une case
+function generate_html_dispo_case($idR, $idP, $idC, $isEditable, $estDispo, $withTD=false, $class='')
+{
+	// Alignement html
+	require_once('html_elements.inc.php');
+	if ( ! $isEditable )
+	{
+		if ( $withTD ) { echo "			<td $class>\n				"; }
+		// Cas g�n�ral, on n'est pas la personne concern�e
+		if ( ! isset($estDispo) || $estDispo == '' ) 
+		{	// Dispo Inconnue (icone ?)
+			generate_html_dispo_inconnu($idP, $idC);
+		}
+		else
+		{
+			if ( $estDispo == 'oui' )
+			{	// Disponible
+				generate_html_dispo_oui($idP, $idC);
+			}else
+			{	// Non Disponible
+				generate_html_dispo_non($idP, $idC);
+			}
+		}
+	}
+	else
+	{
+		if ( $withTD ) { echo "			<td id=\"dispo_idC${idC}\" $class>\n				"; }
+		// On est la personne concern�e, on peut donc choisir le cr�neau
+		if ( ! isset($estDispo) || $estDispo == '' )
+		{	// Dispo Inconnue
+			generate_html_dispo_dire_oui($idR, $idC);
+			echo '			&nbsp;&nbsp;';
+			generate_html_dispo_dire_non($idR, $idC);
+		}
+		else
+		{
+			if ( $estDispo == 'oui' )
+			{	// Disponible
+				generate_html_dispo_oui($idP, $idC);
+				echo '				&nbsp;&nbsp;'."\n				";
+				generate_html_dispo_dire_non($idR, $idC);
+			}else
+			{
+				// Non Disponible
+				generate_html_dispo_dire_oui($idR, $idC);
+				echo '				&nbsp;&nbsp;'."\n				";
+				generate_html_dispo_non($idP, $idC);
+			}
+		}
+	}
+	if ( $withTD ) { echo "			</td>\n"; }
+}
+
+// G�n�ration du tableau complet
+// TODO : id�e : class du tableau diff�rnete quand annul�e -> tableau gris�...
+
+function generate_html_array_personnes_crenaux($idR)
+{
+	if ( isset($_SESSION['session_idP']) )
+	{
+		$idP_Self=$_SESSION['session_idP'];
+	}
+	else
+	{
+		// TODO : Erreur
+	}
+	
+	// Connexion � la base et s�lection de la database
+	require_once 'include/connect.inc.php';
+
+	// R�cup�ration des param�tres de la r�union...
+	$montrerDispoR=$estAnnulee=$is_admin=$estFixee=false;
+	$idP_orga=null;
+	$query="SELECT r.montrerDispoR, r.estAnnulee, r.idP_Orga, r.idC_Fixe, r.idL FROM Reunion r WHERE r.idR='$idR'";
+	$result = @mysql_query($query);
+	if ( $result && ( mysql_num_rows($result) === 1 ) )
+	{
+		list($montrerDispoR, $estAnnulee, $idP_orga, $idC_Fixe, $idL_interne) = mysql_fetch_row($result); 
+		$is_admin = ( $idP_Self == $idP_orga );
+		$montrerDispoR = ( ( $montrerDispoR === 'oui' ) || $is_admin ) ;
+		//echo "DEBUG : annul�� $estAnnulee\n";
+		$estAnnulee = ( $estAnnulee == 'oui' );
+		$estFixee = ( $idC_Fixe != null);
+	}
+	else
+	{
+		// TODO : erreur
+	}
+	// DEBUG : tests en for�ant les variables
+	//$estAnnulee=true;
+	
+	//~ echo "DEBUG : \nmontrerDispoR==$montrerDispoR\nestAnnulee==$estAnnulee\nestFixee==$estFixee\nis_admin==$is_admin\n";
+?>
+<form id="formmail" action="sendmail.php" method="post">
+	<table class="details" summary="Disponibilit� des personnes pour chaque cr�neau possible de la r�union">
+		<thead>
+		<tr>
+<?php
+	if ( $is_admin ) { echo '			<th>Mail</th>' . "\n"; }
+	echo '			<th>Personnes</th>' . "\n";	
+
+	// Remplissage des ent�tes de colonnes (cr�neaux)
+	$query="SELECT idC, UNIX_TIMESTAMP(dateHeure), duree FROM Creneau WHERE idR='$idR' ORDER BY dateHeure ASC;";
+	$creneaux=array();
+	$dispos=array();
+	if ( $result = @mysql_query($query) )
+	{
+		while ( list($idC, $date_deb, $duree) = mysql_fetch_row($result) )
+		{
+			// Calcul des dates
+			//echo $date_deb . "\n";
+			$date_fin = $date_deb + 60 * $duree;
+			if ( $idC != $idC_Fixe ) { echo '			<th>'; } else  { echo '			<th class="selected">'; }
+			if ( $is_admin && ! $estFixee && ! $estAnnulee )
+			{
+				echo '<a href="#popfixer" onclick="loadid(\'popfixer.php?idC=' . $idC;
+				echo '&amp;idR=' . $idR . '\',\'popfixer\',true);popon(\'popfixer\');">';
+			}
+			echo date('d/m/y', $date_deb) . '<br />' . date('H:i', $date_deb)  . ' - ' . date('H:i', $date_fin);
+			if ( $is_admin && ! $estFixee && ! $estAnnulee ) { echo '</a>'; }
+			echo "</th>\n";
+			
+			// Comptage des personnes disponibles et indisponibles
+			$creneaux[] = $idC;
+			$dispos[$idC]['nbDispo']=0;
+			$dispos[$idC]['nbNonDispo']=0;
+			$dispo_max_id=-1;
+			$dispo_max_val=0;
+		}
+	}
+	if ( $is_admin && ! $estFixee && ! $estAnnulee )
+	{
+?>
+			<th>
+				<a href="#popcreneau" onclick="loadid('popcreneau.php?idR=<?php echo $idR; ?>','popcreneau',true);popon('popcreneau');">
+					<img src="./images/editCreneau2.gif" alt="Editer les creneaux" title="Editer les creneaux" height="21" width="22" />
+				</a>
+			</th>
+<?php
+	}
+	//print_r($creneaux);
+?>
+		</tr>
+		</thead>
+		<tbody>
+<?php
+	// Remplissage du tableau, ligne � ligne
+	// Requette �crivant les disponibilit�s dans un tableau associatif en une seule fois
+	if ( $montrerDispoR )
+	{
+		$query='SELECT ch.idC, ch.idP, ch.estDispo FROM Choisir ch, Creneau c, Personne p, Appartenir a, Reunion r WHERE '
+			."c.idR=$idR AND r.idR=$idR AND a.idL=r.idL AND p.idP=a.idP AND ch.idC = c.idC AND ch.idP = p.idP;";
+	}
+	else
+	{
+		$query='SELECT ch.idC, ch.idP, ch.estDispo FROM Choisir ch, Creneau c WHERE '
+			."c.idR='$idR' AND ch.idC=c.idC AND ch.idP='$idP_Self';";
+	}
+	//echo $query . "\n";
+	if ( $result = @mysql_query($query) )
+	{
+		while ( list($idC, $idP, $estDispo) = mysql_fetch_row($result) )
+		{
+			//echo "idC == '$idC'\n";
+			$dispos[$idC][$idP]=$estDispo;
+			if ( $estDispo=='non' ) { $dispos[$idC]['nbNonDispo']++; }
+			if ( $estDispo=='oui' )
+			{
+				$dispos[$idC]['nbDispo']++;
+				if ( $dispos[$idC]['nbDispo'] > $dispo_max_val )
+				{
+					$dispo_max_id=$idC;
+					$dispo_max_val=$dispos[$idC]['nbDispo'];
+				}
+			}
+		}
+	}
+	//print_r($dispos);
+	
+
+	$query='SELECT p.idP, p.prenomP, p.nomP FROM Personne p, Appartenir a, Reunion r WHERE '
+		. "r.idR='$idR' AND a.idL=r.idL AND p.idP=a.idP ORDER BY p.nomP, p.prenomP;";
+	
+	if ( $result = @mysql_query($query) ) 
+	{
+		// On �crit ligne � ligne les personnes et les disponibilit�s
+		while ( $p = mysql_fetch_array($result) )	// Boucle sur chaque personne
+		{
+			echo "		<tr>\n";
+			// Colonne de checkbox pour envoi email si $is_admin == true
+			if  ( $is_admin ) { echo '			<td><input name="mail_idP' . $p[0] . '" type="checkbox" checked="checked" /></td>' . "\n"; }
+			// Nom pr�nom
+			echo "				<td>$p[1] $p[2]</td>\n";
+			// Disponibilit�s
+			foreach ( $creneaux as $c_id )	// Pour chaque cr�neau
+			{
+				if (isset($dispos[$c_id][$p[0]]))
+				{
+					$estDispo=$dispos[$c_id][$p[0]];
+				}
+				else
+				{
+					$estDispo='';
+				}
+				//echo "DEBUG : generate_html_dispo_case($p[0], $c_id, ( $p[0]==$idP_Self ), $estDispo);\n";
+				if ( $c_id != $idC_Fixe ) { $class=''; } else  { $class='class="selected"'; }
+				
+				generate_html_dispo_case($idR, $p[0], $c_id, ( ! $estFixee && ! $estAnnulee && ( $p[0]==$idP_Self ) ),$estDispo, true, $class);
+			}
+			// Colonne vide pour l'ajout de personnes
+			if  ( $is_admin && ! $estFixee && ! $estAnnulee ) { echo "			<td>&nbsp;</td>\n"; }
+			echo "		</tr>\n";
+		}
+		// Si $is_admin, on met une ligne avec bouton envoyer pour les mails et ic�ne ajout de personnes
+		if  ( $is_admin )
+		{
+				echo "		<tr>\n			<td>\n";
+				echo '				<input name="idR" value="' . $idR . '" type="hidden" />' . "\n";
+?>
+				<input value="Envoyer" type="submit" />
+			</td>
+			<td>
+				<?php
+					echo '<a href="#poppersonne" onclick="loadid(\'poppersonne.php?idR=' . $idR;
+					echo '&amp;idL=' . $idL_interne . '&amp;idP_orga=' . $idP_orga . '\',\'poppersonne\',true);popon(\'poppersonne\');">' . "\n";
+				?>
+					<img src="images/addP.gif" alt="Ajouter une personne" title="Ajouter une personne" height="17" width="19" />
+				</a>
+			</td>
+<?php
+			foreach ( $creneaux as $c ) { echo "			<td>&nbsp;</td>\n"; }
+			if ( $is_admin && ! $estFixee && ! $estAnnulee ) { echo "			<td>&nbsp;</td>\n"; }
+			echo "		</tr>\n";
+		}
+
+		// On inscrit les lignes de totaux si les disponibilit�s sont r�v�l�es
+		if ( $is_admin  && ! $estFixee && ! $estAnnulee)
+		{
+			echo "		<tr>\n";
+			echo "			<td>&nbsp;</td>\n";
+			echo "			<td>Personnes pr�sentes</td>\n";
+			foreach ( $creneaux as $c_id )
+			{
+				if ( $c_id == $dispo_max_id )
+				{
+					echo '			<td><em>' . $dispos[$c_id]['nbDispo'] . "</em></td>\n";
+				}
+				else
+				{
+					echo '			<td>' . $dispos[$c_id]['nbDispo'] . "</td>\n";
+				}
+			}
+			echo "			<td>&nbsp;</td>\n";
+			echo "		</tr>\n";
+			
+			echo "		<tr>\n";
+			echo "			<td>&nbsp;</td>\n";
+			echo "			<td>Personnes absentes</td>\n";
+			foreach ( $creneaux as $c_id )
+			{
+				echo '			<td>' . $dispos[$c_id]['nbNonDispo'] . "</td>\n";
+			}
+			echo "			<td>&nbsp;</td>\n";
+			echo "		</tr>\n";
+		}
+	}
+	echo "		</tbody>\n";
+	echo "	</table>\n</form>\n";
+}
+
+function traiter_formulaire_fixer_creneau()
+{
+	if ( ! isset($_GET['idR']) || !isset($_GET['idC']) )
+	{
+		$errmsg="Impossible de fixer la r�union : param�tres manquants ou erron�";
+		return;
+	}
+	$idR=addslashes($_GET['idR']);
+	$idC=addslashes($_GET['idC']);
+	
+	$query="UPDATE Reunion SET idC_Fixe=$idC WHERE idR=$idR;";
+	if ( ! mysql_query($query) || mysql_affected_rows() != 1 )
+	{
+		$errmsg='Impossible de fixer la r�union : ' . mysql_generate_errmsg();
+	}
+}
+
+function traiter_formulaire_creer_reunion()
+{
+	include_once('include/je.inc.php');
+	$idP=$_SESSION['session_idP'];
+	
+	// Cr�ation de la R�union
+	$query='INSERT INTO Reunion(idP_Orga) VALUES' . "('$idP');";
+	if ( ! $result = @mysql_query($query) || (mysql_affected_rows() != 1) )
+	{
+		// Cas d'erreur
+		$errmsg ='Erreur lors de la cr�ation de la liste de participants : ' . mysql_generate_errmsg();
+		return;
+	}
+	$idR=mysql_insert_id();
+
+	// Cr�ation de la Liste des participants
+	if ( ! $idL=list_new("interne_idR_$idR","NULL",true) )
+	{
+		$errmsg ='Erreur lors de la cr�ation de la liste de participants : Erreur de base de donn�e';
+		return;	
+	}
+	
+	$query="UPDATE Reunion SET idL='$idL' WHERE idR='$idR'";
+	if ( ! $result = @mysql_query($query) || (mysql_affected_rows() != 1) )
+	{
+		// Cas d'erreur
+		$errmsg = 'Erreur lors de la cr�ation de la liste de participants : ' . mysql_generate_errmsg();
+		return;
+	}
+	// TODO : moins bourin !
+	$_REQUEST['idR']=$idR;
+	return;
+}
+
+function traiter_formulaire_modif_detail_reunion()
+{
+	if ( ! isset($_GET['idR']) || !isset($_POST['objetR']) || !isset($_POST['lieuR']) || !isset($_POST['ordreJourR']) || !isset($_POST['remarquesR']) )
+	{
+		$errmsg = 'Impossible de modifier de d�tail de la r�union : Param�tres manquants';
+		// DEBUG :
+		echo "DEBUG : $query\n$errmsg\n";
+		return;
+	}
+	
+	$idR=addslashes($_GET['idR']);
+	$objetR=addslashes($_POST['objetR']);
+	$lieuR=addslashes($_POST['lieuR']);
+	$ordreJourR=addslashes($_POST['ordreJourR']);
+	$remarquesR=addslashes($_POST['remarquesR']);
+	$estAnnulee=( isset($_POST['isCancelled']) && ($_POST['isCancelled']==='on') )?'oui':'non';
+	
+	$query="UPDATE Reunion SET objetR='$objetR', lieuR='$lieuR', ordreJourR='$ordreJourR', remarquesR='$remarquesR', estAnnulee='$estAnnulee'  WHERE idR='$idR'";
+	if ( ! $result = @mysql_query($query) || (mysql_affected_rows() != 1) )
+	{
+		// Cas d'erreur
+		$errmsg = 'Erreur lors de la modification de la r�union : ' . mysql_generate_errmsg();
+		// DEBUG :
+		echo "DEBUG : $query\n$errmsg\n";
+		return;
+	}
+	// DEBUG :
+	//echo "DEBUG : $query\n$errmsg\n";
+	return;
+}
+
+function generate_html_reunion_detail2($idR)
+{
+	$query='SELECT r.objetR, r.ordreJourR, r.lieuR, r.remarquesR, r.montrerDispoR, r.estAnnulee, r.idP_Orga, r.idC_Fixe, p.nomP, p.prenomP'
+			. " FROM Reunion r, Personne p WHERE r.idR='$idR' AND p.idP=r.idP_Orga";
+	$result = @mysql_query($query);
+	if ( ! $result || ( mysql_num_rows($result) !== 1 ) )
+	{
+		$errmsg="Impossible de r�cupr�rer les informations de la r�union : Erreur de base de donn�es\n";
+		return;
+	}
+	
+	list($objetR, $ordreJourR, $lieuR, $remarquesR, $montrerDispoR, $estAnnulee, $idP_Orga, $idC_Fixe, $nomP, $prenomP) = mysql_fetch_row($result); 
+	if ( $estAnnulee=='oui' ) { $etat = 'reunion_fixee'; } elseif ( $idC_Fixe!=null)  { $etat ='reunion_fixee'; } else { $etat = 'reunion_en_cours'; }
+	
+?>
+	<table class="detail_reunion" summary="D�tail de la r�union que vous avez s�lectionn�e">
+		<thead>
+			<tr>
+				<th colspan="2">
+					D�tails de la r�union
+<?php
+	//~ echo "DEBUG : SESSION['session_idP']==" . $_SESSION['session_idP'] . "\n" . "idP_Orga==" . $idP_Orga;
+	if ( isset($_SESSION['session_idP']) && ($_SESSION['session_idP'] == $idP_Orga ) )
+	{
+		echo '					';
+		echo '<a href="#popfixer" onclick="loadid(\'include/ludo/div_create_or_modif.php?idR=';
+		echo $idR . '&amp;objetR=' . urlencode($objetR) . '&amp;lieuR=' . urlencode($lieuR) . '&amp;ordreJourR=';
+		echo urlencode($ordreJourR) . '&amp;remarquesR=' . urlencode($remarquesR);
+		echo "','details_reunion',false)\">(Editer)</a>\n";
+	}
+
+?>
+				</th>
+			</tr>
+		</thead>
+		<tbody>
+			<tr>
+				<td><strong>Objet :</strong></td>
+				<td>
+					<?php echo $objetR . "\n"; ?>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Organisateur :</strong></td>
+				<td>
+					<?php echo "$prenomP $nomP\n"; ?>
+				</td>
+			</tr>
+
+			<tr>
+				<td><strong>Lieu :</strong></td>
+				<td>
+					<?php echo $lieuR . "\n"; ?>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Ordre du jour :</strong></td>
+				<td>
+					<?php echo $ordreJourR . "\n"; ?>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Remarques :</strong></td>
+				<td>
+					<?php echo $remarquesR . "\n"; ?>
+				</td>
+			</tr>
+			<tr>
+				<td><strong>Etat :</strong></td>
+<?php
+	echo '				<td class="' . $etat .'">' ."\n";
+	switch($etat)
+	{
+		case 'reunion_fixee':
+			echo "Fix�e\n";
+		break;
+		case 'reunion_en_cours':
+			echo "En pr�paration\n";
+		break;
+		case 'reunion_annulee':
+			echo "Annul�e\n";
+		break;
+	}
+	if ( $montrerDispoR === 'non' ) { echo ', disponibilit�s masqu�es'; }
+	echo "\n				</td>\n";
+?>
+				</td>
+			</tr>
+		</tbody>
+	</table>	
+<?php
+}
+
+?>
diff --git a/appli_3_alpha_old/app/include/ludo/html_elements.inc.php b/appli_3_alpha_old/app/include/ludo/html_elements.inc.php
new file mode 100644
index 0000000..4275653
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/html_elements.inc.php
@@ -0,0 +1,138 @@
+<?php
+/*
+ * Fonctions de g�n�ration de code HTML...
+ */
+ function generate_html_doctype_and_head($title)
+{
+echo '<?xml version="1.0" encoding="ISO-8859-1"?>'."\n"
+?>
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" lang="fr">
+	<head>
+		<?php echo "<title>AWOR - $title</title>\n"; ?>
+		<meta name="keywords" content="AWOR, Application Web, Organisation, R�union, Reunion" />
+		<meta name="description" content="Application Web d'Organisation de R�union (AWOR). Facilite la vie des organisateurs !" />
+		<meta name="author" content="J�r�mie D�noyer, Ludovic Pouzenc, Andriana Semouchtchak, Julien S�r�" />
+		<script type="text/javascript" src="script.js"></script>
+<?php
+	if ( isset($_COOKIE['awor']['custom_css'] ) )
+	{
+		$cssfile = $_COOKIE['awor']['custom_css'];
+	}
+	else
+	{
+		include 'config.inc.php';
+		$cssfile=$CONFIG['CSS']['CHOOSER_LIST']['standard'];
+	}
+	echo '		<link href="css/' . $cssfile . '.css" rel="stylesheet" type="text/css" />' . "\n";
+	echo '		<link href="css/' . $cssfile . '_nohelp.css" rel="alternate stylesheet" type="text/css" title="nohelp"/>' . "\n";
+?>
+		<link href="css/print.css" rel="alternate stylesheet" type="text/css" title="print"/>
+	</head>
+<?php
+}
+
+function generate_html_divs_menu()
+{
+?>
+<div id="titre"><h2>AWOR</h2></div>
+<div id="main_menu">
+	<ul id="menu">
+		<li><a href="index.php">R&eacute;unions</a></li>
+		<li><a href="listes.php">Listes</a></li>
+		<li><a href="profil.php">Mon profil</a></li>
+		<li><a href="ical.php">iCal</a></li>
+		<li id="deconnection"><a href="deco.php">D&eacute;connexion</a></li>
+	</ul>
+</div>
+<?php
+}
+
+function generate_html_div_help($help_file='')
+{
+	//echo "DEBUG : function generate_html_div_help()\n";
+	if ($help_file=='' ) { $help_file='help/' . basename($_SERVER['PHP_SELF']) . '.hlp'; }
+	//$help_file='modele_page.php.hlp';
+	//echo "DEBUG : $help_file\n";
+	if ( is_readable($help_file) )
+	//if ( @fopen($help_file, 'r')!==false )
+	{
+		echo '<div id="no_help">' . "\n<h2><a href=\"#css_standard\" onclick=\"setActiveStyleSheet('standard');\">?</a></h2>\n" . "</div>\n";
+		echo '<div id="help">' . "\n<h2><a href=\"#css_nohelp\" onclick=\"setActiveStyleSheet('nohelp');\">Aide</a></h2>\n";
+		readfile($help_file);
+		echo "</div>\n";
+	}
+}
+
+function generate_html_div_errmsg($errmsg)
+{
+	echo '<div class="errmsg">' . "\n" . '<span class="errmsg">' . $errmsg . "</span>\n";
+	require_once('config.inc.php');
+	if ( isset( $CONFIG['adminMail'] ) && ( ! isset($_REQUEST['debug'] ) ) )
+	{
+		echo '<span class="contactAdm">Si le probl�me persiste, vous pouvez contacter l\'administrateur par email � l\'adresse suivante : ';
+		echo '<a href="mailto:' . $CONFIG['adminMail'] . '">' . $CONFIG['adminMail'] . "</a></span>\n";
+	}
+	echo "</div>\n";
+}
+
+function generate_html_div_css_chooser()
+{
+	// TODO : fonction JS qui fait ce qu'il faut !! (a mettre dans le head ??)
+	require_once('config.inc.php');
+	if ( ! is_array($CONFIG['CSS']['CHOOSER_LIST']) ) { return false; }
+	
+	if (  isset($_COOKIE['awor']['custom_css'] ) ) { $css_selected=$_COOKIE['awor']['custom_css']; };
+	echo '<div class="css_chooser">' . "\n";
+	echo '	<select>' . "\n";
+	foreach ( $CONFIG['CSS']['CHOOSER_LIST'] as $file => $name )
+	{
+		echo '		<option value="' . $file;
+		if ( $file == $css_selected ) { echo ' selected="selected'; }
+		echo '">' . $name . '</option>' . "\n";
+	}
+	echo '	</select>'. "\n";
+	echo '</div>'. "\n";
+}
+
+function generate_html_div_deconnect()
+{
+	echo '<div class="deco"><a href="deco.php">Deconnexion</a></div>'."\n";
+}
+function generate_html_div_back()
+{
+	echo '<div class="retour"><a href="index.php">Retour</a></div>'."\n";
+}
+
+function generate_html_dispo_inconnu($idP, $idC)
+{
+	echo '<img src="./images/question.gif" alt="Inconnu" height="15" width="15" />' . "\n";
+}
+
+function generate_html_dispo_oui($idP, $idC)
+{
+	echo '<img src="./images/ok.gif" alt="Disponible" height="16" width="16" />' . "\n";
+}
+
+function generate_html_dispo_non($idP, $idC)
+{
+	echo '<img src="./images/del.gif" alt="Non disponible" height="15" width="15" />' . "\n";
+}
+
+function generate_html_dispo_dire_oui($idR, $idC)
+{
+	//~ echo '<img src="./images/button_ok.png" alt="Dire que je suis disponible" height="25" width="25" />' . "\n";
+	echo "<a href=\"#dispo_idC${idC}\" onclick=\"loadid('include/ludo/majDispo.php?idR=$idR&amp;idC=$idC&amp;estDispo=oui','dispo_idC${idC}',false);\">";
+	echo '<img src="./images/button_ok.png" alt="Dire que je suis disponible" height="25" width="25" /></a>' . "\n";
+}
+
+function generate_html_dispo_dire_non($idR, $idC)
+{
+	echo "<a href=\"#dispo_idC${idC}\" onclick=\"loadid('include/ludo/majDispo.php?idR=$idR&amp;idC=$idC&amp;estDispo=non','dispo_idC${idC}',false);\">";
+	echo '<img src="./images/button_del.png" alt="Dire que je suis pas disponible" height="25" width="25" /></a>' . "\n";
+}
+
+function generate_html_reunion_detail_button($idR)
+{
+	echo '<a href="details_reunion.php?idR=' . $idR . '"><img src="images/details.png" alt="D&eacute;tails" width="20" height="20" /></a>';
+}
diff --git a/appli_3_alpha_old/app/include/ludo/mail_textarea.php b/appli_3_alpha_old/app/include/ludo/mail_textarea.php
new file mode 100644
index 0000000..4861e1d
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/mail_textarea.php
@@ -0,0 +1,44 @@
+<?php
+require_once('session_verify.inc.php');
+include('config.inc.php');
+//~ require_once('/home/lud/shares/public_html/awor/appli_3_alpha/include/connect.inc.php');
+
+//include('include/connect.inc.php');
+
+if ( isset($_GET['model']) ) { $model=$_GET['model']; } else { $model='empty'; }
+?>
+
+<textarea name="msgText" cols="80" rows="8">
+<?php
+	if ( $model != 'empty')
+	{
+		include('../connect.inc.php');
+		if ( ! isset($CONFIG['MAIL']['TEMPLATES'][$model]['tpl_file']) )
+		{
+			echo 'D�sol�, mod�le indisponible...';
+		}
+		else
+		{
+			// On r�cup�re quelques information � propos de la r�union pour que les templates puissent �tre customis�s
+			$objetR=$ordreJourR=$lieuR=$remarquesR="";
+			if (isset( $_GET['idR']) )
+			{
+				$idR=addslashes($_GET['idR']);
+				$result = mysql_query("SELECT objetR, ordreJourR, lieuR, remarquesR FROM Reunion WHERE idR='$idR'");
+				if (mysql_num_rows($result)===1)
+				{
+					list($objetR, $ordreJourR, $lieuR, $remarquesR) = mysql_fetch_array($result);
+				}
+			}
+			//echo 'DEBUG : ../../templates/' . $CONFIG['MAIL']['TEMPLATES'][$model]['tpl_file'] . "\n";
+			if (!@include('../../templates/' . $CONFIG['MAIL']['TEMPLATES'][$model]['tpl_file']) )
+			{
+				echo 'D�sol�, impossible de charger le fichier mod�le...';
+			}
+		}
+	}
+	//print_r($_REQUEST);
+	//print_r($CONFIG);
+?>
+</textarea>
+
diff --git a/appli_3_alpha_old/app/include/ludo/majDispo.php b/appli_3_alpha_old/app/include/ludo/majDispo.php
new file mode 100644
index 0000000..ab7c200
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/majDispo.php
@@ -0,0 +1,41 @@
+<?php
+require('session_verify.inc.php');
+require('fonctions.inc.php');
+
+// TODO : v�rification que la r�union nous concerne bien !
+
+if ( /*!isset($_GET['idR']) ||*/  !isset($_GET['idC']) ||  !isset($_GET['estDispo']) ||   !isset($_SESSION['session_idP']) )
+{
+	$errmsg="Param�tres incorrects\n";
+}
+
+if ( isset( $errmsg ) )
+{
+	// TODO
+}
+else
+{
+	$idR=addslashes($_GET['idR']);
+	$idC=addslashes($_GET['idC']);
+	$estDispo=addslashes($_GET['estDispo']);
+	$idP=$_SESSION['session_idP'];
+	
+	
+	// TODO Traitement
+
+/*	echo "DEBUG : query==UPDATE Choisir SET estDispo = '$estDispo' WHERE idC='$idC' AND idP='$idP'";
+	$query="UPDATE Choisir SET estDispo = '$estDispo' WHERE idC='$idC' AND idP='$idP'";
+	$result = @mysql_query($query);
+	if ( ! $result || ( mysql_num_rows($result) !== 1 ) )
+	{
+		$query="INSERT INTO Choisir(idC,idP,estDispo) VALUES ('$idC', '$idP', '$estDispo')";
+		$result = @mysql_query($query);
+		if ( ! $result || ( mysql_num_rows($result) !== 1 ) )
+		{
+			echo "Erreur BD\n";
+			return;
+		}
+	}	*/
+	generate_html_dispo_case($idR, $idP, $idC, true, $estDispo, false);
+}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ludo/redir.inc.php b/appli_3_alpha_old/app/include/ludo/redir.inc.php
new file mode 100644
index 0000000..6baf40d
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/redir.inc.php
@@ -0,0 +1,20 @@
+<?php
+function html_redir($dest)
+{
+	header("Location: $dest");
+require_once('html_elements.inc.php');
+generate_html_doctype_and_head("Redirection");
+?>
+<body>
+	<h1>Redirection</h1>
+	<p>Si vous voyez cette page, merci de suivre le lien ci-dessous</p>
+<?php
+	// Ne respecte pas le XHTML s'il y a des param�tres les & doivent �tre remplac�e par &amp;
+	echo '<p><a href="' . $dest . '">' . $dest . '</a></p>' . "\n";
+?>
+</body>
+</html>
+<?php
+	exit();
+}
+?>
\ No newline at end of file
diff --git a/appli_3_alpha_old/app/include/ludo/session_verify.inc.php b/appli_3_alpha_old/app/include/ludo/session_verify.inc.php
new file mode 100644
index 0000000..f1cea8b
--- /dev/null
+++ b/appli_3_alpha_old/app/include/ludo/session_verify.inc.php
@@ -0,0 +1,9 @@
+<?php
+session_start();
+if ( ! isset($_SESSION['session_loginP']) )
+{
+	require('redir.inc.php');
+	$dest='auth_dialog.php?retour=' . $_SERVER['PHP_SELF'];
+	html_redir($dest);
+}
+?>
\ No newline at end of file
-- 
cgit v1.2.3