diff --git a/Class/class.combat.php b/Class/class.combat.php index 093800b..5992d2b 100644 --- a/Class/class.combat.php +++ b/Class/class.combat.php @@ -3,6 +3,7 @@ * class.combat.php * ------------------- * begin : Samedi 26 janvier 2008 + * update : Samedi 12 mai 2008 * email : nemunaire@gmail.com * * @@ -16,43 +17,95 @@ class Combat { var $Ntour = 0; var $ATtactique = 0; var $ENtactique = 0; + var $timestamp = 0; + var $vaisContenu = 0; + var $vaisContenuM = 0; + var $vaisContenuC = 0; + var $vaisContenuH = 0; + + var $debriM = 0; + var $debriC = 0; /** * Constructeur - * @param array $flotteAT tableau SQL des vaisseaux envoyés par l'attaquant - * @param array $flotteEN tableau SQL de la planète du défenseur - * @param array $defEN tableau SQL de la planète du défenseur + * @param array $flotteAT tableau SQL des vaisseaux envoyés par l'attaquant + * @param array $flotteEN tableau SQL de la planète du défenseur + * @param array $defEN tableau SQL de la planète du défenseur * * @return void * @access public */ function Combat($flotteAT, $flotteEN, $defEN) { include('includes/vars.php'); - //Génération des vaisseaux attaquants + //Génération des vaisseaux attaquants for ($i=1 ; $i<=12 ; $i++) { - if ($flotteAT['vaisseau'.$i] >= 1) { - $this->ATvais[] = array($i, $flotteAT['vaisseau'.$i], array(array($nomvais_pv[$i-1], $flotteAT['vaisseau'.$i])), array(array($nomvais_bc[$i-1], $flotteAT['vaisseau'.$i]))); + if ($flotteAT['vaisseau_'.$i] >= 1) { + //Création des groupes + $nbvais = $flotteAT['vaisseau_'.$i]; + $nbgroupes = floor(sqrt(ceil($nbvais/10))); + $nbvaispgroupe = floor($nbvais/$nbgroupes); + $nbrest = $nbvais - $nbvaispgroupe * $nbgroupes; + + if (isset($groupe)) unset($groupe); + $groupe = array(); + for ($j=0 ; $j < $nbgroupes ; $j++) { + if ($j == $nbgroupes) $nbvaispgroupe += $nbrest; + $groupe[] = array($nbvaispgroupe, $nomvais_bc[$i-1], $nomvais_pv[$i-1]); + } + $this->ATvais[] = array($i, $flotteAT['vaisseau_'.$i], $nbgroupes, $groupe); } } - //Génération des vaisseaux défenseurs + //Définition d'autres variables de la classe concernant la flotte + $this->refflotte = $flotteAT['id']; + $this->vaisContenu = $flotteAT['contenu_max']; + $this->vaisContenuM = $flotteAT['contenu_metal']; + $this->vaisContenuC = $flotteAT['contenu_cristal']; + $this->vaisContenuH = $flotteAT['contenu_hydrogene']; + $this->timestamp = $flotteAT['start_time'] + $flotteAT['end_time']; + + //Génération des vaisseaux défenseurs for ($i=1 ; $i<=12 ; $i++) { if ($flotteEN['vaisseau_'.$i] >= 1) { - $this->ENvais[] = array($i, $flotteEN['vaisseau_'.$i], array(array($nomvais_pv[$i-1], $flotteEN['vaisseau_'.$i])), array(array($nomvais_bc[$i-1], $flotteEN['vaisseau_'.$i]))); + //Création des groupes + $nbvais = $flotteEN['vaisseau_'.$i]; + $nbgroupes = floor(sqrt(ceil($nbvais/10))); + $nbvaispgroupe = floor($nbvais/$nbgroupes); + $nbrest = $nbvais - $nbvaispgroupe * $nbgroupes; + + if (isset($groupe)) unset($groupe); + $groupe = array(); + for ($j=0 ; $j < $nbgroupes ; $j++) { + if ($j == $nbgroupes) $nbvaispgroupe += $nbrest; + $groupe[] = array($nbvaispgroupe, $nomvais_bc[$i-1], $nomvais_pv[$i-1]); + } + $this->ENvais[] = array($i, $flotteEN['vaisseau_'.$i], $nbgroupes, $groupe); } } - //Génération des défenses défenseurs + //Génération des défenses défenseurs for ($i=1 ; $i<=5 ; $i++) { if ($defEN['def_'.$i] >= 1) { - $this->ENdef[] = array($i, $defEN['def_'.$i], array(array($nomvais_pv[$i-1], $defEN['def_'.$i])), array(array($nomvais_bc[$i-1], $defEN['def_'.$i]))); + //Création des groupes + $nbvais = $defEN['def_'.$i]; + $nbgroupes = floor(sqrt(ceil($nbvais/10))); + $nbvaispgroupe = floor($nbvais/$nbgroupes); + $nbrest = $nbvais - $nbvaispgroupe * $nbgroupes; + + if (isset($groupe)) unset($groupe); + $groupe = array(); + for ($j=0 ; $j < $nbgroupes ; $j++) { + if ($j == $nbgroupes) $nbvaispgroupe += $nbrest; + $groupe[] = array($nbvaispgroupe, $defense_bc[$i-1], $defense_pv[$i-1]); + } + $this->ENdef[] = array($i, $defEN['def_'.$i], $nbgroupes, $groupe); } } } /** * Change la tactique de l'attaquant - * @param int $tactique numéro de la tactique choisie + * @param int $tactique numéro de la tactique choisie * * @return void * @access public @@ -62,8 +115,8 @@ class Combat { } /** - * Change la tactique du défenseur - * @param int $tactique numéro de la tactique choisie + * Change la tactique du défenseur + * @param int $tactique numéro de la tactique choisie * * @return void * @access public @@ -73,12 +126,12 @@ class Combat { } /** - * Régénére les boucliers - * @param int $pourcentage pourcentage de régénération - * @param bool $attaquant régénére le bouclier de l'attaquant si true, sinon régénrére celui du défenseur - * @param bool $retour si true, renvoie true ou false si !le pourcentage a été consommé ou non, si false, retrourne ne nombre de pourcentage restant + * Régénére les boucliers + * @param int $pourcentage pourcentage de régénération + * @param bool $attaquant régénére le bouclier de l'attaquant si true, sinon régénrére celui du défenseur + * @param bool $retour si true, renvoie true ou false si !le pourcentage a été consommé ou non, si false, retrourne ne nombre de pourcentage restant * - * @return float pourcentage non utilisé + * @return float pourcentage non utilisé * @access public */ function regenereBC($pourcentage, $attaquant, $retour = false) { @@ -91,22 +144,23 @@ class Combat { $type = $this->ATvais[$i][0]-1; $maxbc = $nomvais_bc[$type]; $ajout = $maxbc*$pourcentage/100; - $norm += $maxbc * $this->ATvais[$i][1]; $cntbc = count($this->ATvais[$i][3]); for ($j=0 ; $j<$cntbc ; $j++) { - if ($this->ATvais[$i][3][$j][0] < $maxbc) { - $this->ATvais[$i][3][$j][0] += $ajout; + $norm += $maxbc * $this->ATvais[$i][3][$j][0]; + + if ($this->ATvais[$i][3][$j][1] < $maxbc) { + $this->ATvais[$i][3][$j][1] += $ajout; } - else $enplus += $ajout * $this->ATvais[$i][3][$j][1]; - if ($this->ATvais[$i][3][$j][0] > $maxbc) { - $enplus += ($this->ATvais[$i][3][$j][0] - $maxbc)*$this->ATvais[$i][3][$j][1]; - $this->ATvais[$i][3][$j][0] = $maxbc; + else $enplus += $ajout * $this->ATvais[$i][3][$j][0]; + if ($this->ATvais[$i][3][$j][1] > $maxbc) { + $enplus += ($this->ATvais[$i][3][$j][1] - $maxbc)*$this->ATvais[$i][3][$j][0]; + $this->ATvais[$i][3][$j][1] = $maxbc; } } } if ($retour) { - if($enplus/$norm == 1) return true; + if($enplus/$norm == 1) return $pourcentage; else return false; } else return $enplus/$norm; @@ -119,23 +173,23 @@ class Combat { $type = $this->ENvais[$i][0]-1; $maxbc = $nomvais_bc[$type]; $ajout = $maxbc*$pourcentage/100; - $norm += $maxbc * $this->ENvais[$i][1]; $cntbc = count($this->ENvais[$i][3]); for ($j=0 ; $j<$cntbc ; $j++) { - if ($this->ENvais[$i][3][$j][0] < $maxbc) { - $this->ENvais[$i][3][$j][0] += $ajout; + $norm += $maxbc * $this->ENvais[$i][3][$j][0]; + if ($this->ENvais[$i][3][$j][1] < $maxbc) { + $this->ENvais[$i][3][$j][1] += $ajout; } - else $enplus += $ajout * $this->ENvais[$i][3][$j][1]; - if ($this->ENvais[$i][3][$j][0] > $maxbc) { - $enplus += ($this->ENvais[$i][3][$j][0] - $maxbc)*$this->ENvais[$i][3][$j][1]; - $this->ENvais[$i][3][$j][0] = $maxbc; + else $enplus += $ajout * $this->ENvais[$i][3][$j][0]; + if ($this->ENvais[$i][3][$j][1] > $maxbc) { + $enplus += ($this->ENvais[$i][3][$j][1] - $maxbc)*$this->ENvais[$i][3][$j][0]; + $this->ENvais[$i][3][$j][1] = $maxbc; } } } $return = $enplus/$norm; - //Défenses + //Défenses $count = count($this->ENdef); $enplus = 0; $norm = 0; @@ -143,29 +197,33 @@ class Combat { $type = $this->ENdef[$i][0]-1; $maxbc = $defense_bc[$type]; $ajout = $maxbc*$pourcentage/100; - $norm += $maxbc * $this->ENdef[$i][1]; $cntbc = count($this->ENdef[$i][3]); for ($j=0 ; $j<$cntbc ; $j++) { - if ($this->ENdef[$i][3][$j][0] < $maxbc) { - $this->ENdef[$i][3][$j][0] += $ajout; + $norm += $maxbc * $this->ENdef[$i][3][$j][0]; + if ($this->ENdef[$i][3][$j][1] < $maxbc) { + $this->ENdef[$i][3][$j][1] += $ajout; } - else $enplus += $ajout * $this->ENdef[$i][3][$j][1]; - if ($this->ENdef[$i][3][$j][0] > $maxbc) { - $enplus += ($this->ENdef[$i][3][$j][0] - $maxbc)*$this->ENdef[$i][3][$j][1]; - $this->ENdef[$i][3][$j][0] = $maxbc; + else $enplus += $ajout * $this->ENdef[$i][3][$j][0]; + if ($this->ENdef[$i][3][$j][1] > $maxbc) { + $enplus += ($this->ENdef[$i][3][$j][1] - $maxbc)*$this->ENdef[$i][3][$j][0]; + $this->ENdef[$i][3][$j][1] = $maxbc; } } } $return += $enplus/$norm; - return $return/2; + if ($retour) { + if($enplus/$norm == 1) return $pourcentage; + else return false; + } + else return $return/2; } } /** * Calcul la puissance d'attaque disponible - * @param int $pourcentage pourcentage de régénération - * @param bool $attaquant calcul les points de l'attaquant si true, sinon calcul pour le défenseur + * @param int $pourcentage pourcentage de régénération + * @param bool $attaquant calcul les points de l'attaquant si true, sinon calcul pour le défenseur * * @return int points disponibles * @access public @@ -189,7 +247,7 @@ class Combat { $puissance += $maxat * $pourcentage/100 * $this->ENvais[$i][1]; } - //Défenses + //Défenses $count = count($this->ENdef); for ($i=0 ; $i<$count ; $i++) { $maxat = $defense_at[$this->ENdef[$i][0]-1]; @@ -202,77 +260,270 @@ class Combat { /** * Attaque les vaisseaux adverses * @param int $points points d'attaque disponible pour l'attaque - * @param bool $attaquant attaque le défenseur si true, sinon attaque l'attaquant + * @param bool $attaquant attaque le défenseur si true, sinon attaque l'attaquant * * @return void * @access public */ function attaquerVais($points, $attaquant) { + include('includes/vars.php'); if ($attaquant) { while($points > 0) { - // Calcul du nombre de vaisseaux et défenses à attaquer + // Calcul du nombre de vaisseaux et défenses à attaquer $nbvais = 0; + $nbgroupes = 0; $nb = count($this->ENvais); for ($i=0 ; $i<$nb ; $i++) { $nbvais += $this->ENvais[$i][1]; + $nbgroupes += $this->ENvais[$i][2]; } $nb = count($this->ENdef); for ($i=0 ; $i<$nb ; $i++) { $nbvais += $this->ENdef[$i][1]; + $nbgroupes += $this->ENdef[$i][2]; } - //S'il ne reste plus de vaisseaux et de défenses, on arrête la boucle - if ($nbvais < 0 || $points < 0) break; + //S'il ne reste plus de vaisseaux et de défenses, on arrête la boucle + if ($nbvais <= 0 || $nbgroupes <= 0 || $points <= 0) break; - //Calcul du nombre de points qui sera enlevé par vaisseau ou défense - $ppv = $points / $nbvais; + //Calcul du nombre de points qui sera enlevé par vaisseau ou défense + $ppv = $points / $nbgroupes; + $points = 0; - //On lance l'attaque - $nb = count($this->ENvais); - for ($i=0 ; $i<$nb ; $i++) { - $persage = 0; //Initialisation du nombre de point restant pour attaquer les PV - $nbpersage = 0; //Initialisation du nombre de vaisseaux affectuer par le persage - $nbj = count($this->ENvais[$i][3]); //Nombre de vaisseaux dans le groupe + //On lance l'attaque contre les vaisseaux + for ($j=0 ; $j<$nbgroupes ; $j++){ + $k = rand(0, count($this->ENvais)-1); + $l = rand(0, count($this->ENvais[$k][3])-1); - //Attaque des boucliers - for ($j=0 ; $j<$nbj ; $j++) { - $this->ENvais[$i][3][$j][0] -= $ppv; - if ($this->ENvais[$i][3][$j][0] <= 0) { - $persage += abs($this->ENvais[$i][3][$j][0]); - $nbpersage += $this->ENvais[$i][3][$j][1]; - $this->ENvais[$i][3][$j][0] = 0; - } - } - - //Attaque des PV - while($persage > 0) { - $j = count($this->ENvais[$i][2])-1; //Nombre de vaisseaux dans le groupe - if ($this->ENvais[$i][2][$j][0] * $this->ENvais[$i][2][$j][1] < $persage * $nbpersage) { //Si il y a suffisament de point de persage pour détruire tous les vaisseaux de cette ligne - //On efface les vaisseaux du nombre total - $nbvais -= $this->ENvais[$i][2][$j][1]; - $this->ENvais[$i][1] -= $this->ENvais[$i][2][$j][1]; - - //On efface le groupe - unset($this->ENvais[$i][2][$j]); - - //S'il ne reste aucun vaisseaux du type, on le supprime - if ($j == 0 || $this->ENvais[$i][1] == 0) { - unset($this->ENvais[$i]); - $persage = 0; + $this->ENvais[$k][3][$l][1] -= $ppv; + if ($this->ENvais[$k][3][$l][1] < 0) { + $this->ENvais[$k][3][$l][2] -= abs($this->ENvais[$k][3][$l][1]); + $this->ENvais[$k][3][$l][1] = 0; + if ($this->ENvais[$k][3][$l][2] <= 0) { + $this->ENvais[$k][1] -= $this->ENvais[$k][3][$l][0]; + $this->ENvais[$k][2] --; + unset($this->ENvais[$k][3][$l]); + $this->ENvais[$k][3] = array_merge($this->ENvais[$k][3]); + if (!count($this->ENvais[$k][3])) { + unset($this->ENvais[$k]); + $this->ENvais[$k] = array_merge($this->ENvais[$k]); } } - else { //Attaque vaisseau par vaisseau dans le groupe - $nbmod = floor(($this->ENvais[$i][2][$j][0] * $this->ENvais[$i][2][$j][1])/($persage * $nbpersage)); - $this->ENvais[$i][1] -= $nbmod; - $nbvais -= $nbmod; + } + } + //On lance l'attaque contre les défenses + for ($j=0 ; $j<$nbgroupes ; $j++){ + $k = rand(0, count($this->ENdef)-1); + $l = rand(0, count($this->ENdef[$k][3])-1); + + $this->ENdef[$k][3][$l][1] -= $ppv; + if ($this->ENdef[$k][3][$l][1] < 0) { + $this->ENdef[$k][3][$l][2] -= abs($this->ENdef[$k][3][$l][1]); + $this->ENdef[$k][3][$l][1] = 0; + if ($this->ENdef[$k][3][$l][2] <= 0) { + $this->ENdef[$k][1] -= $this->ENdef[$k][3][$l][0]; + $this->ENdef[$k][2] --; + unset($this->ENdef[$k][3][$l]); + $this->ENdef[$k][3] = array_merge($this->ENdef[$k][3]); + if (!count($this->ENdef[$k][3])) { + unset($this->ENdef[$k]); + $this->ENdef[$k] = array_merge($this->ENdef[$k]); + } } } } } + return count($this->ENvais) + count($this->ENdef); + } + else { + while($points > 0) { + // Calcul du nombre de vaisseaux et défenses à attaquer + $nbvais = 0; + $nbgroupes = 0; + $nb = count($this->ATvais); + for ($i=0 ; $i<$nb ; $i++) { + $nbvais += $this->ATvais[$i][1]; + $nbgroupes += $this->ATvais[$i][2]; + } + + //S'il ne reste plus de vaisseaux et de défenses, on arrête la boucle + if ($nbvais <= 0 || $nbgroupes <= 0 || $points <= 0) break; + + //Calcul du nombre de points qui sera enlevé par vaisseau ou défense + $ppv = $points / $nbvais; + $points = 0; + + //On lance l'attaque + for ($j=0 ; $j<$nbgroupes ; $j++){ + $k = rand(0, count($this->ENdef)-1); + $l = rand(0, count($this->ENdef[$k][3])-1); + + $this->ENdef[$k][3][$l][1] -= $ppv; + if ($this->ENdef[$k][3][$l][1] < 0) { + $this->ENdef[$k][3][$l][2] -= abs($this->ENdef[$k][3][$l][1]); + $this->ENdef[$k][3][$l][1] = 0; + if ($this->ENdef[$k][3][$l][2] <= 0) { + $this->ENdef[$k][1] -= $this->ENdef[$k][3][$l][0]; + $this->ENdef[$k][2] --; + unset($this->ENdef[$k][3][$l]); + $this->ENdef[$k][3] = array_merge($this->ENdef[$k][3]); + if (!count($this->ENdef[$k][3])) { + unset($this->ENdef[$k]); + $this->ENdef[$k] = array_merge($this->ENdef[$k]); + } + } + } + } + } + return count($this->ATvais); } } + function exportAT($pillage = false){ + include('includes/vars.php'); + $nb = count($this->ATvais); + $nbvais = 0; $vaisContenu = 0; $vaisseau_1 = 0; $vaisseau_2 = 0; $vaisseau_3 = 0; $vaisseau_4 = 0; $vaisseau_5 = 0; $vaisseau_6 = 0; $vaisseau_7 = 0; $vaisseau_8 = 0; $vaisseau_9 = 0; $vaisseau_10 = 0; $vaisseau_11 = 0; $vaisseau_12 = 0; + for($i=0 ; $i<$nb ; $i++) { + ${'vaisseau_'.$this->ATvais[$i][0]} += $this->ATvais[$i][1]; + $nbvais += $this->ATvais[$i][1]; + $this->vaisContenu += $nomvais_rs[$this->ATvais[$i][0]-1]; + } + $sommeCont = $this->vaisContenuM + $this->vaisContenuC + $this->vaisContenuH; + if ($sommeCont > $this->vaisContenu) { + $retirer = $sommeCont/$this->vaisContenu; + $this->vaisContenuM = floor($this->vaisContenuM/$retirer); + $this->vaisContenuC = floor($this->vaisContenuC/$retirer); + $this->vaisContenuH = floor($this->vaisContenuH/$retirer); + } + if ($pillage) { + $req = mysql_query("SELECT * FROM flottes WHERE `id` = '".$this->refflotte."'"); + $resultat = mysql_fetch_array($req); + $reqDef = mysql_query("SELECT * FROM `planete` WHERE `galaxie` = '".$resultat['end_galaxie']."' AND `ss` = '".$resultat['end_ss']."' AND `position` = '".$resultat['end_position']."'") or die ("erreur sql ".mysql_error()); + $resultatDef = mysql_fetch_array($reqDef); + $ressplus = pillage($resultatDef['metal'], $resultatDef['cristal'], $resultatDef['hydrogene'], $this->vaisContenu - $this->vaisContenuM - $this->vaisContenuC - $this->vaisContenuH); + $this->vaisContenuM += $ressplus[0]; + $this->vaisContenuC += $ressplus[1]; + $this->vaisContenuH += $ressplus[2]; + } + return '`nb_vais` = \''.$nbvais.'\', `contenu_max` = \''.$this->vaisContenu.'\', `contenu_metal` = \''.$this->vaisContenuM.'\', `contenu_cristal` = \''.$this->vaisContenuC.'\', `contenu_hydrogene` = \''.$this->vaisContenuH.'\', `vaisseau_1` = \''.$vaisseau_1.'\', `vaisseau_2` = \''.$vaisseau_2.'\', `vaisseau_3` = \''.$vaisseau_3.'\', `vaisseau_4` = \''.$vaisseau_4.'\', `vaisseau_5` = \''.$vaisseau_5.'\', `vaisseau_6` = \''.$vaisseau_6.'\', `vaisseau_7` = \''.$vaisseau_7.'\', `vaisseau_8` = \''.$vaisseau_8.'\', `vaisseau_9` = \''.$vaisseau_9.'\', `vaisseau_10` = \''.$vaisseau_10.'\', `vaisseau_11` = \''.$vaisseau_11.'\', `vaisseau_12` = \''.$vaisseau_12.'\''; + } + + function exportEN(){ + $nb = count($this->ENvais); + $vaisseau_1 = 0; $vaisseau_2 = 0; $vaisseau_3 = 0; $vaisseau_4 = 0; $vaisseau_5 = 0; $vaisseau_6 = 0; $vaisseau_7 = 0; $vaisseau_8 = 0; $vaisseau_9 = 0; $vaisseau_10 = 0; $vaisseau_11 = 0; $vaisseau_12 = 0; + for($i=0 ; $i<$nb ; $i++) { + ${'vaisseau_'.$this->ENvais[$i][0]} += $this->ENvais[$i][1]; + } + $nb = count($this->ENdef); + $def_1 = 0; $def_2 = 0; $def_3 = 0; $def_4 = 0; $def_5 = 0; + for($i=0 ; $i<$nb ; $i++) { + ${'def_'.$this->ENdef[$i][0]} += $this->ENdef[$i][1]; + } + return '`vaisseau_1` = \''.$vaisseau_1.'\', `vaisseau_2` = \''.$vaisseau_2.'\', `vaisseau_3` = \''.$vaisseau_3.'\', `vaisseau_4` = \''.$vaisseau_4.'\', `vaisseau_5` = \''.$vaisseau_5.'\', `vaisseau_6` = \''.$vaisseau_6.'\', `vaisseau_7` = \''.$vaisseau_7.'\', `vaisseau_8` = \''.$vaisseau_8.'\', `vaisseau_9` = \''.$vaisseau_9.'\', `vaisseau_10` = \''.$vaisseau_10.'\', `vaisseau_11` = \''.$vaisseau_11.'\', `vaisseau_12` = \''.$vaisseau_12.'\', `def_1` = \''.$def_1.'\', `def_2` = \''.$def_2.'\', `def_3` = \''.$def_3.'\', `def_4` = \''.$def_4.'\', `def_5` = \''.$def_5.'\''; + } + + function genRapport($fin, $ATgagnant = false){ + $req = mysql_query("SELECT * FROM `flottes` WHERE `id` = '".$this->refflotte."'"); + $resultat = mysql_fetch_array($req); + $reqDef = mysql_query("SELECT `id_user` FROM `planete` WHERE `galaxie` = '".$resultat['end_galaxie']."' AND `ss` = '".$resultat['end_ss']."' AND `position` = '".$resultat['end_position']."'") or die ("erreur sql ".mysql_error()); + $resultatDef = mysql_fetch_array($reqDef); + + if ($this->Ntour == 0) { + $rapportAT = '[b]Le combat contre '.trouvNom($resultatDef['id_user']).' est engagé ![/b] + + '; + $rapportEN = '[b]Un combat est engagé contre '.trouvNom($resultatDef['id_user']).' ![/b] + + '; + } + elseif ($fin) { + $rapportAT = '[b]Le combat contre '.trouvNom($resultatDef['id_user']).' est terminé ![/b] + + '; + $rapportEN = '[b]Le combat contre '.trouvNom($resultatDef['id_user']).' est terminé ![/b] + + '; + } + else { + $rapportAT = '[b]Suite du combat contre '.trouvNom($resultatDef['id_user']).' ![/b] + + '; + $rapportEN = '[b]Suite du combat contre '.trouvNom($resultatDef['id_user']).' ![/b] + + '; + } + $rapportAT .= 'Tactique lors de ce tour : '.txtTactique($this->ATtactique).'. + + Lieux : ['.$resultat['end_galaxie'].':'.$resultat['end_ss'].':'.$resultat['end_position'].'] METTRE UN LIEN + + Vaisseaux au début de notre côté : + Array + + Vaisseaux adverse au début : + Array + + Défenses adverse au début : + Array + + Etat de notre flotte à la fin de ce tour : + Grand Array ^^ + + Etat de la flotte adverse à la fin de ce tour : + Grand Array ^^ + + '; + + $rapportEN .= 'Tactique lors de ce tour : '.txtTactique($this->ENtactique).'. + + Lieux : ['.$resultat['end_galaxie'].':'.$resultat['end_ss'].':'.$resultat['end_position'].'] METTRE UN LIEN + + Vaisseaux au début de notre côté : + Array + + Défenses au début de notre côté : + Array + + Vaisseaux adverse au début : + Array + + Etat de notre flotte à la fin de ce tour : + Grand Array ^^ + + Etat de la flotte adverse à la fin de ce tour : + Grand Array ^^ + + '; + + if (floor($this->Ntour/2) == $this->Ntour/2 && !$fin) { + $rapportAT .= 'Vous pouvez profiter du temps de régénération des boucliers et des armes pour envoyer un nouvel ordre de tactique : Cliquez ici ! + + La prochaine attaque est prévue à '.date('/dm/ H:i:s', $this->timestamp+600); + $rapportEN .= 'Vous pouvez profiter du temps de régénération des boucliers et des armes pour envoyer un nouvel ordre de tactique : Cliquez ici ! + + La prochaine attaque est prévue à '.date('/dm/ H:i:s', $this->timestamp+300); + } + elseif (!$fin) { + $rapportAT .= 'Vous pouvez profiter du temps de régénération des boucliers et des armes pour envoyer un nouvel ordre de tactique : Cliquez ici ! + + La prochaine attaque est prévue à '.date('/dm/ H:i:s', $this->timestamp+300); + $rapportEN .= 'Vous pouvez profiter du temps de régénération des boucliers et des armes pour envoyer un nouvel ordre de tactique : Cliquez ici ! + + La prochaine attaque est prévue à '.date('/dm/ H:i:s', $this->timestamp+600); + } + elseif ($fin && $ATgagnant) { + $rapportAT .= 'Nous avons gagné le combat ! + + Nous repartons avec plein de choses.'; + $rapportEN .= 'Nous n\'avons pas pu repousser l\'envahisseur qui repart avec plein de chose.'; + } + elseif ($fin && !$ATgagnant) { + $rapportAT .= 'Nous avons perdu le combat !'; + $rapportEN .= 'Nous avons pu repousser l\'envahisseur qui repart sans rien.'; + } + + return array(mysql_real_escape_string($rapportAT), mysql_real_escape_string($rapportEN), $resultat['id_user'], $resultatDef['id_user']); + } } ?> \ No newline at end of file diff --git a/Class/class.gerefile.php b/Class/class.gerefile.php new file mode 100644 index 0000000..130e2ba --- /dev/null +++ b/Class/class.gerefile.php @@ -0,0 +1,90 @@ +limite = $limite; + } + + function addObjet($objet,$nombre,$temps) { + $nbF = count($this->file); + if ($nbF >= $this->limite) return false; + $this->chaine = false; + if($nbF == 0) $this->timestamp = time(); + if($nbF > 0 && $this->file[$nbF-1][0] == $objet) $this->file[$nbF-1][1] += $nombre; + else $this->file[] = array($objet, $nombre, $temps); + return true; + } + + function existe($objet) { + $this->file = array_merge($this->file); + $nbF=count($this->file); + for ($i=0 ; $i<$nbF ; $i++){ + if($objet == $this->file[$i][0]) return true; + } + return false; + } + + function delobjet($objet, $nombre=1) { + $this->file = array_merge($this->file); + for($i=count($this->file)-1 ; $i>=0 ; $i--) { + if($this->file[$i][0] == $objet){ + $nombre=min($nombre, $this->file[$i][1]); + $this->file[$i][1] -= $nombre; + if($this->file[$i][1]<=0) { + unset($this->file[$i]); + $this->file = array_merge($this->file); + } + } + } + return $nombre; + } + + function pret() { + $out = array(); + $nbF = count($this->file); + if ($nbF == 1 && $this->chaine) { + $nb = floor((time()-$this->timestamp)/$this->file[0][2]); + if ($nb > 0) { + $out[] = array($this->file[0][0], $nb); + $this->timestamp += $nb * $this->file[0][2]; + } + } + elseif ($nbF != 0) { + $this->file = array_merge($this->file); + for($i=0 ; $i<$nbF ; $i++){ + $tps = time() - $this->timestamp; + if($this->file[$i][1] * $this->file[$i][2] < $tps) { + $out[] = array($this->file[$i][0], $this->file[$i][1]); + $this->timestamp += $this->file[$i][1] * $this->file[$i][2]; + unset($this->file[$i]); + } + elseif ($this->file[$i][2] < $tps) { + for($j=0 ; $j*$this->file[$i][2]<$tps ; $j++) {} + $j--; + $out[] = array($this->file[$i][0], $j); + $this->timestamp += $j * $this->file[$i][2]; + $this->file[$i][1] -= $j; + break; + } + else { + return $out; + } + } + $this->file = array_merge($this->file); + } + return $out; + } + + function export(){ + $nbF = count($this->file); + $out = ''; + for($i=0;$i<$nbF;$i++){ + $out .= implode(',',$this->file[$i]).';'; + } + return $out; + } +} \ No newline at end of file diff --git a/Class/class.rapport.php b/Class/class.rapport.php new file mode 100644 index 0000000..d332ed7 --- /dev/null +++ b/Class/class.rapport.php @@ -0,0 +1,114 @@ +type = $type; + $this->utilA = $utilA; + $this->utilB = $utilB; + $this->timestamp = $time; + } + + function addInfo($info, $id){ + $this->var[$id] = $info; + } + + function send(){ + if ($this->type == '1') $this->sendCombat(); + elseif ($this->type == '2') $this->sendTransport(); + elseif ($this->type == '3') $this->sendColonisation(); + elseif ($this->type == '4') $this->sendRecyclage(); + elseif ($this->type == '5') $this->sendEspionnage(); + elseif ($this->type == '6') $this->sendAlliance(); + } + + function sendEspionnage(){ + include_once('includes/function.php'); + $titreA = 'Rapport d\'espionnage de '.$this->var[0]['nom_planete'].' ['.$this->var[0]['galaxie'].':'.$this->var[0]['ss'].':'.$this->var[0]['position'].']'; + $rapportA = 'Espionnage de '.trouvNom($this->utilB).' sur '.$this->var[0]['nom_planete'].'['.$this->var[0]['galaxie'].':'.$this->var[0]['ss'].':'.$this->var[0]['position'].']

'; + + $race = trouvInfo($this->utilB, 'race'); + $auth_level = 0; + include('includes/noms.php'); + include('includes/vars.php'); + + if (isset($this->var[1]) && $this->var[1] == false) $rapportA .= 'Nos sondes n\'ont pas pu récolter d\'information sur cette planète.'; + else { + $rapportA .= '
Ressources sur la planète :
Métal :'.$this->var[0]['metal'].'
Cristal :'.$this->var[0]['cristal'].'
Hydrogène :'.$this->var[0]['hydrogene'].'

'; + if (isset($this->var[1]) && $this->var[1] == true) { + $rapportA .= ''; + $nbvais = count($nomvaisn); + for($i=1 ; $i<$nbvais ; $i++) { + if ($this->var[0]['vaisseau_'.$i] >= 1) $rapportA .= ''; + } + $rapportA .= '
NombreVaisseaux
'.$this->var[0]['vaisseau_'.$i].''.$nomvaisn[$i-1].'

'; + } + if (isset($this->var[2]) && $this->var[2] == true) { + $rapportA .= ''; + $nbdef = count($nomterrn) - 7; + for($i=1 ; $i<$nbdef ; $i++) { + if ($this->var[0]['def_'.$i] >= 1) $rapportA .= ''; + } + $rapportA .= '
NombreDéfenses
'.$this->var[0]['def_'.$i].''.$nomterrn[$i+7].'

'; + } + if (isset($this->var[3]) && $this->var[3] == true) { + $rapportA .= ''; + $nbbat = count($batiment); + for($i=1 ; $i<$nbbat ; $i++) { + if ($this->var[0][$batimentVAR[$i-1]] >= 1) $rapportA .= ''; + } + $rapportA .= '
NiveauBatiment
'.$this->var[0][$batimentVAR[$i-1]].''.$batiment[$i-1].'

'; + } + if (isset($this->var[4]) && is_array($this->var[4])) { + $rapportA .= ''; + $nbtec = count($technolo); + for($i=1 ; $i<$nbtec ; $i++) { + if ($this->var[4][$technoloVAR[$i-1]] >= 1) $rapportA .= ''; + } + $rapportA .= '
NiveauTechnologie
'.$this->var[4][$technoloVAR[$i-1]].''.$technolo[$i-1].'

'; + } + if (isset($this->var[5]) && is_array($this->var[5])) { + //ISOLEMENT + } + } + + $titreB = 'Rapport de contre-espionnage'; + $rapportB = 'Nous vennons d\'apprendre que notre planète : '.$this->var[0]['nom_planete'].'['.$this->var[0]['galaxie'].':'.$this->var[0]['ss'].':'.$this->var[0]['position'].'] a été la cible d\'un espionnage de la part de '.trouvNom($this->utilA); + + $titreA = mysql_real_escape_string($titreA); + $rapportA = mysql_real_escape_string($rapportA); + $titreB = mysql_real_escape_string($titreB); + $rapportB = mysql_real_escape_string($rapportB); + $temps = $this->timestamp; + + mysql_query("INSERT INTO mail VALUES('', '1', '".trouvNom($this->utilA)."', '', '$titreA', '$rapportA', '$temps')"); + mysql_query("INSERT INTO mail VALUES('', '1', '".trouvNom($this->utilB)."', '', '$titreB', '$rapportB', '$temps')"); + } + + function sendAlliance(){ + include_once('includes/function.php'); + $titreA = 'Déclaration officielle de votre alliance !'; + $rapportA = 'Félicitations, votre alliance a recueilli suffisament de signature, sa déclaration est maintenant officielle !

Vous pouvez dès maintenant administrer votre alliance en vous randant sur la page Alliance.'; + + $titreA = mysql_real_escape_string($titreA); + $rapportA = mysql_real_escape_string($rapportA); + $temps = $this->timestamp; + + mysql_query("INSERT INTO mail VALUES('', '1', '".trouvNom($this->utilA)."', '', '$titreA', '$rapportA', '$temps')"); + } +} +?> \ No newline at end of file diff --git a/Class/class.smtp.php b/Class/class.smtp.php index 6b45c3a..75baf9c 100644 --- a/Class/class.smtp.php +++ b/Class/class.smtp.php @@ -28,13 +28,13 @@ class SMTP * @var int */ var $SMTP_PORT = 25; - + /** * SMTP reply line ending * @var string */ var $CRLF = "\r\n"; - + /** * Sets whether debugging is turned on * @var bool @@ -98,7 +98,7 @@ class SMTP } #connect to the smtp server - $this->smtp_conn = fsockopen($host, # the host of the server + @$this->smtp_conn = fsockopen($host, # the host of the server $port, # the port to use $errno, # error number if any $errstr, # error message if any @@ -502,7 +502,7 @@ class SMTP } $this->helo_rply = $rply; - + return true; } diff --git a/Class/flotte.php b/Class/flotte.php deleted file mode 100644 index 73ba1cc..0000000 --- a/Class/flotte.php +++ /dev/null @@ -1,246 +0,0 @@ -vaisseaux[0] = $vaisseau_1; $this->vaisseaux[1] = $vaisseau_2; $this->vaisseaux[2] = $vaisseau_3; $this->vaisseaux[3] = $vaisseau_4; $this->vaisseaux[4] = $vaisseau_5; $this->vaisseaux[5] = $vaisseau_6; $this->vaisseaux[6] = $vaisseau_7; $this->vaisseaux[7] = $vaisseau_8; $this->vaisseaux[8] = $vaisseau_9; $this->vaisseaux[9] = $vaisseau_10; $this->vaisseaux[10] = $vaisseau_11; $this->vaisseaux[11] = $vaisseau_12; - $this->ressources_max = $Tressources_max; - $this->vitesses_cd = $Tvitesses_cd; - $this->vitesses_ld = $Tvitesses_ld; - $this->preparation_cd = $Tpreparation_cd; - $this->preparation_ld = $Tpreparation_ld; - $this->chauffe_ld = $Tchauffe_ld; - $this->calcFret(); - } - - /** - * Ajouter $nombre vaisseaux de type $type - * - */ - function addVaisseaux($type, $nombre) { - $type--; - $this->vaisseaux[$type] += $nombre; - - $this->calcFret(); - } - - /** - * Supprime $nombre vaisseaux de type $type - * - */ - function delVaisseaux($type, $nombre) { - $type--; - $this->vaisseaux[$type] -= $nombre; - if ($this->vaisseaux[$type] < 0) $this->vaisseaux[$type] = 0; - - $this->calcFret(); - } - - /** - * Vérifie qu'il reste assez de place dans les vaisseaux pour transporter $nombre de ressources du type $type - * - */ - function verifRessources($type, $nombre) { - $type--; - if ($type == 0) { - if ($this->vaisseaux_fret[$type]+$nombre+$this->vaisseaux_fret[$type+1]+$this->vaisseaux_fret[$type+2] > $this->fret_max) return false; // Retourne false si la quantité à ajouter est trop importante - else return true; - } - elseif ($type == 1) { - if ($this->vaisseaux_fret[$type]+$nombre+$this->vaisseaux_fret[$type+1]+$this->vaisseaux_fret[$type-1] > $this->fret_max) return false; // Retourne false si la quantité à ajouter est trop importante - else return true; - } - elseif ($type == 2) { - if ($this->vaisseaux_fret[$type]+$nombre+$this->vaisseaux_fret[$type-1]+$this->vaisseaux_fret[$type-2] > $this->fret_max) return false; // Retourne false si la quantité à ajouter est trop importante - else return true; - } - else return false; - } - - /** - * Ajouter $nombre ressources de type $type - * - */ - function addRessources($type, $nombre) { - if ($this->verifRessources($type, $nombre) == true) { - $type--; - $this->vaisseaux_fret[$type] += $nombre; - return true; - } - else return false; - } - - /** - * Enlève $nombre ressources de type $type - * - */ - function delRessources($type, $nombre) { - $type--; - $this->vaisseaux_fret[$type] -= $nombre; - if ($this->vaisseaux_fret[$type] < 0) $this->vaisseaux_fret[$type] = 0; - } - - /** - * Enlève toutes les ressources de type $type - * Si $type = 0, enlève toutes les ressources - * - */ - function razRessources($type = 0) { - $type--; - if ($type == -1) $this->vaisseaux_fret = array(0,0,0); - else $this->vaisseaux_fret[$type] = 0; - } - - /** - * Recalcul le nombre maximum de ressource que peuvent transporter tous les vaisseaux - * - */ - function calcFret() { - $cnt = count($this->vaisseaux); - for ($i=0 ; $i<$cnt ; $i++) { - $this->fret_max += $this->vaisseaux[$i] * $this->ressources_max[$i]; - } - } - - /** - * Fixer position de départ - * - */ - function fixePosition($galaxie, $systeme, $planete, $time = 0) { - if ($time == 0) $time = time(); - - $this->position_galaxie = $galaxie; - $this->position_systeme = $systeme; - $this->position_planete = $planete; - $this->position_temps = $time; - } - - /** - * Déplacer la flotte vers une destination et calcul du temps de déplacement - * - */ - function deplacerFlotte($galaxie, $systeme, $planete, $coefficient = 1) { - $this->destination_galaxie = $galaxie; - $this->destination_systeme = $systeme; - $this->destination_planete = $planete; - $this->vitesse_coefficient = $coefficient; - - $this->calcTemps(); - } - - /** - * Recalcul le temps de déplacement - * - */ - function calcTemps() { - $start_galaxie = $this->position_galaxie; - $start_ss = $this->position_systeme; - $start_position = $this->position_planete; - $end_galaxie = $this->destination_galaxie; - $end_ss = $this->destination_systeme; - $end_position = $this->destination_planete; - - $AvaisType = ''; $AvaisVitesseC = ''; $AvaisVitesseL = ''; $AvaisPrepC = ''; $AvaisChauffe = ''; $AvaisContenu = 0; - for ($i=0 ; $i<=12 ; $i++) { - for ($j = 1; $j <= $this->vaisseaux[$i]; $j++) { - $AvaisType .= ($i).' '; - $AvaisVitesseC .= $this->vitesses_cd[$i].' '; - $AvaisVitesseL .= $this->vitesses_ld[$i].' '; - $AvaisPrepC .= $this->preparation_cd[$i].' '; - $AvaisPrepL .= $this->preparation_ld[$i].' '; - $AvaisChauffe .= $this->chauffe_ld[$i].' '; - } - } - $AvaisType = split(' ', trim($AvaisType)); $AvaisVitesseC = split(' ', trim($AvaisVitesseC)); $AvaisVitesseL = split(' ', trim($AvaisVitesseL)); $AvaisContenu = split(' ', trim($AvaisContenu)); $AvaisPrepC = split(' ', trim($AvaisPrepC)); $AvaisPrepL = split(' ', trim($AvaisPrepL)); $AvaisChauffe = split(' ', trim($AvaisChauffe)); - - if(min($AvaisVitesseL) != 0) { - $vitesse = min($AvaisVitesseL); - $preparation = max($AvaisPrepL); - $chauffe = max($AvaisChauffe); - } - else { - $vitesse = min($AvaisVitesseC); - $preparation = max($AvaisPrepC); - $chauffe = 0; - } - - $this->vaisseaux_nombre = count($AvaisType); - $coefvitesse = $this->vitesse_coefficient; - - if ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0 && $end_position-$start_position == 0) $temps = 0; - elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0 && $chauffe == 0) $temps = $preparation+abs($end_position-$start_position)*$vitesse/12; - elseif ($end_galaxie-$start_galaxie == 0 && $chauffe == 0) $temps = $preparation+abs($end_ss-$start_ss)*$vitesse; - elseif ($chauffe == 0) $temps = $preparation+abs($end_galaxie-$start_galaxie)*$vitesse*300; - elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0) $temps = $preparation+abs($end_position-$start_position)*($vitesse*2)/12+$preparation; - /*elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss <= $chauffe) $temps = abs($end_ss-$start_ss)*(($vitesse/$chauffe)*($chauffe-abs($end_ss-$start_ss))+$vitesse)+$preparation; - elseif ($end_galaxie-$start_galaxie == 0) $temps = $vitesse*abs($end_ss-$start_ss)+$vitesse*10+$preparation;*/ - elseif ($end_galaxie-$start_galaxie == 0) $temps = (abs($end_ss-$start_ss)*(($vitesse/$chauffe)*((abs($chauffe-abs($end_ss-$start_ss))+($chauffe-abs($end_ss-$start_ss)))/2)+$vitesse))+(20-(abs($chauffe-abs($end_ss-$start_ss))+($chauffe-abs($end_ss-$start_ss)))/2)*54+$preparation; - else $temps = (($vitesse/$chauffe)*($chauffe-abs($end_galaxie-$start_galaxie))+$vitesse)*300+108+$preparation; - - $this->destination_temps = $temps/$coefvitesse; - return $temps/$coefvitesse; - } - - /** - * Calcul la consomation de la flotte - * - */ - function calcConso() { - return intval($this->destination_temps*$this->vaisseaux_nombre/20); - } -} - -$race = 'humain'; -$auth_level = 7; -include('../languages/fr_FR/noms.php'); - -$flotte = new flotte($nomvais_rs,$nomvais_dc,$nomvais_lc,$nomvais_pdc,$nomvais_pdl,$nomvais_cdl,0,0,0,4); -$flotte->addRessources(1,11); -$flotte->deplacerFlotte(1,1,1); -$flotte->calcTemps(); -print_r ($flotte->calcConso()); -?> \ No newline at end of file diff --git a/Class/gererFile.php b/Class/gererFile.php deleted file mode 100644 index fd5b215..0000000 --- a/Class/gererFile.php +++ /dev/null @@ -1,67 +0,0 @@ -fileArray = $fileArray; - $this->fileTexte = implode(' ',$fileArray); - $this->tempsArray = $tempsArray; - $this->tempsTexte = implode(' ',$tempsArray); - } - - /** - * Ajouter une action à la file - * - */ - function add($file, $temps) { - $file = trim($file); - $temps = trim($temps); - $this->fileTexte .= ' '.$file; - $this->fileArray = explode(' ',$fileTexte); - $this->tempsTexte .= ' '.$temps; - $this->tempsArray = explode(' ',$tempsTexte); - } - - /** - * Supprime une action de la file - * - */ - function delId($id) { - $pos = strpos(implode(',', $fileTec).',', $_GET['tec'].','); - $this->fileTexte .= ' '.$file; - $this->fileArray = explode(' ',$fileTexte); - $this->tempsTexte .= ' '.$temps; - $this->tempsArray = explode(' ',$tempsTexte); - } -} - -$gestion = new gererFile(explode(' ','1 2 3 4 5'), explode(' ', '123 456 789 101112 131415 161718')); -$gestion->add('6', '192021'); -print $gestion->fileTexte; -?> \ No newline at end of file diff --git a/Class/phpmailer.lang-en.php b/Class/phpmailer.lang-fr.php similarity index 56% rename from Class/phpmailer.lang-en.php rename to Class/phpmailer.lang-fr.php index 2f45383..7ba2ef2 100644 --- a/Class/phpmailer.lang-en.php +++ b/Class/phpmailer.lang-fr.php @@ -1,6 +1,6 @@ diff --git a/Class/test/message.txt b/Class/test/message.txt deleted file mode 100644 index 2ae06f6..0000000 --- a/Class/test/message.txt +++ /dev/null @@ -1,355 +0,0 @@ -Received: from phpmailer ([127.0.0.1]) - by 127.0.0.1 with HTTP (PHPMailer); - Tue, 22 Jan 2008 23:56:42 +0100 -Date: Tue, 22 Jan 2008 23:56:42 +0100 -Return-Path: nobody@example.com -To: Test User -Cc: Carbon User -From: Unit Tester -Reply-to: Reply Guy -Subject: Unit Test: AltBody + Attachment -Message-ID: -X-Priority: 3 -X-Mailer: PHPMailer [version 1.71] -MIME-Version: 1.0 -Content-Type: multipart/mixed; - boundary="b1_a0169dc7929d1c609a827b4d1a0c3f74" - - ---b1_a0169dc7929d1c609a827b4d1a0c3f74 -Content-Type: multipart/alternative; - boundary="b2_a0169dc7929d1c609a827b4d1a0c3f74" - ---b2_a0169dc7929d1c609a827b4d1a0c3f74 -Content-Type: text/plain; charset = "iso-8859-1" -Content-Transfer-Encoding: 8bit - - -This is the text part of the email. - - ---b2_a0169dc7929d1c609a827b4d1a0c3f74 -Content-Type: text/html; charset = "iso-8859-1" -Content-Transfer-Encoding: 8bit - - -This is the HTML part of the email.

---------------------
Unit Test Information
---------------------
phpmailer version: 1.71
Content Type: text/html
Host: localhost
Attachments:
  • Name: phpmailer_test.php, Encoding: base64, Type: application/octet-stream

Changes
-------
  • Sender was changed to [nobody@example.com]
  • Mailer was changed to [smtp]


- - - ---b2_a0169dc7929d1c609a827b4d1a0c3f74-- ---b1_a0169dc7929d1c609a827b4d1a0c3f74 -Content-Type: application/octet-stream; name="test_attach.txt" -Content-Transfer-Encoding: base64 -Content-Disposition: attachment; filename="test_attach.txt" - -PD9waHANCi8qKioqKioqKioqKioqKioqKioqDQogIFVuaXQgVGVzdA0KICBUeXBlOiBwaHBtYWls -ZXIgY2xhc3MNCioqKioqKioqKioqKioqKioqKioqLw0KDQokSU5DTFVERV9ESVIgPSAiLi4vIjsN -Cg0KcmVxdWlyZSgicGhwdW5pdC5waHAiKTsNCnJlcXVpcmUoJElOQ0xVREVfRElSIC4gImNsYXNz -LnBocG1haWxlci5waHAiKTsNCmVycm9yX3JlcG9ydGluZyhFX0FMTCk7DQoNCi8qKg0KICogUGVy -Zm9ybXMgYXV0aGVudGljYXRpb24gdGVzdHMNCiAqLw0KY2xhc3MgcGhwbWFpbGVyVGVzdCBleHRl -bmRzIFRlc3RDYXNlDQp7DQogICAgLyoqDQogICAgICogSG9sZHMgdGhlIGRlZmF1bHQgcGhwbWFp -bGVyIGluc3RhbmNlLg0KICAgICAqIEBwcml2YXRlDQogICAgICogQHR5cGUgb2JqZWN0DQogICAg -ICovDQogICAgdmFyICRNYWlsID0gZmFsc2U7DQoNCiAgICAvKioNCiAgICAgKiBIb2xkcyB0aGUg -U01UUCBtYWlsIGhvc3QuDQogICAgICogQHB1YmxpYw0KICAgICAqIEB0eXBlIHN0cmluZw0KICAg -ICAqLw0KICAgIHZhciAkSG9zdCA9ICIiOw0KDQogICAgLyoqDQogICAgICogSG9sZHMgdGhlIGNo -YW5nZSBsb2cuDQogICAgICogQHByaXZhdGUNCiAgICAgKiBAdHlwZSBzdHJpbmcgYXJyYXkNCiAg -ICAgKi8NCiAgICB2YXIgJENoYW5nZUxvZyA9IGFycmF5KCk7DQoNCiAgICAgLyoqDQogICAgICog -SG9sZHMgdGhlIG5vdGUgbG9nLg0KICAgICAqIEBwcml2YXRlDQogICAgICogQHR5cGUgc3RyaW5n -IGFycmF5DQogICAgICovDQogICAgdmFyICROb3RlTG9nID0gYXJyYXkoKTsNCg0KICAgIC8qKg0K -ICAgICAqIENsYXNzIGNvbnN0dWN0b3IuDQogICAgICovDQogICAgZnVuY3Rpb24gcGhwbWFpbGVy -VGVzdCgkbmFtZSkgew0KICAgICAgICAvKiBtdXN0IGRlZmluZSB0aGlzIGNvbnN0cnVjdG9yICov -DQogICAgICAgICR0aGlzLT5UZXN0Q2FzZSggJG5hbWUgKTsNCiAgICB9DQoNCiAgICAvKioNCiAg -ICAgKiBSdW4gYmVmb3JlIGVhY2ggdGVzdCBpcyBzdGFydGVkLg0KICAgICAqLw0KICAgIGZ1bmN0 -aW9uIHNldFVwKCkgew0KICAgICAgICBnbG9iYWwgJGdsb2JhbF92YXJzOw0KICAgICAgICBnbG9i -YWwgJElOQ0xVREVfRElSOw0KDQogICAgICAgICR0aGlzLT5NYWlsID0gbmV3IFBIUE1haWxlcigp -Ow0KDQogICAgICAgICR0aGlzLT5NYWlsLT5Qcmlvcml0eSA9IDM7DQogICAgICAgICR0aGlzLT5N -YWlsLT5FbmNvZGluZyA9ICI4Yml0IjsNCiAgICAgICAgJHRoaXMtPk1haWwtPkNoYXJTZXQgPSAi -aXNvLTg4NTktMSI7DQogICAgICAgICR0aGlzLT5NYWlsLT5Gcm9tID0gInVuaXRfdGVzdEBwaHBt -YWlsZXIuc2YubmV0IjsNCiAgICAgICAgJHRoaXMtPk1haWwtPkZyb21OYW1lID0gIlVuaXQgVGVz -dGVyIjsNCiAgICAgICAgJHRoaXMtPk1haWwtPlNlbmRlciA9ICIiOw0KICAgICAgICAkdGhpcy0+ -TWFpbC0+U3ViamVjdCA9ICJVbml0IFRlc3QiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+Qm9keSA9 -ICIiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+QWx0Qm9keSA9ICIiOw0KICAgICAgICAkdGhpcy0+ -TWFpbC0+V29yZFdyYXAgPSAwOw0KICAgICAgICAkdGhpcy0+TWFpbC0+SG9zdCA9ICRnbG9iYWxf -dmFyc1sibWFpbF9ob3N0Il07DQogICAgICAgICR0aGlzLT5NYWlsLT5Qb3J0ID0gMjU7DQogICAg -ICAgICR0aGlzLT5NYWlsLT5IZWxvID0gImxvY2FsaG9zdC5sb2NhbGRvbWFpbiI7DQogICAgICAg -ICR0aGlzLT5NYWlsLT5TTVRQQXV0aCA9IGZhbHNlOw0KICAgICAgICAkdGhpcy0+TWFpbC0+VXNl -cm5hbWUgPSAiIjsNCiAgICAgICAgJHRoaXMtPk1haWwtPlBhc3N3b3JkID0gIiI7DQogICAgICAg -ICR0aGlzLT5NYWlsLT5QbHVnaW5EaXIgPSAkSU5DTFVERV9ESVI7DQoJCSR0aGlzLT5NYWlsLT5B -ZGRSZXBseVRvKCJub19yZXBseUBwaHBtYWlsZXIuc2YubmV0IiwgIlJlcGx5IEd1eSIpOw0KICAg -ICAgICAkdGhpcy0+TWFpbC0+U2VuZGVyID0gIm5vYm9keUBleGFtcGxlLmNvbSI7DQoNCiAgICAg -ICAgaWYoc3RybGVuKCR0aGlzLT5NYWlsLT5Ib3N0KSA+IDApDQogICAgICAgICAgICAkdGhpcy0+ -TWFpbC0+TWFpbGVyID0gInNtdHAiOw0KICAgICAgICBlbHNlDQogICAgICAgIHsNCiAgICAgICAg -ICAgICR0aGlzLT5NYWlsLT5NYWlsZXIgPSAibWFpbCI7DQogICAgICAgICAgICAkdGhpcy0+U2Vu -ZGVyID0gInVuaXRfdGVzdEBwaHBtYWlsZXIuc2YubmV0IjsNCiAgICAgICAgfQ0KDQogICAgICAg -IGdsb2JhbCAkZ2xvYmFsX3ZhcnM7DQogICAgICAgICR0aGlzLT5TZXRBZGRyZXNzKCRnbG9iYWxf -dmFyc1sibWFpbF90byJdLCAiVGVzdCBVc2VyIik7DQogICAgICAgIGlmKHN0cmxlbigkZ2xvYmFs -X3ZhcnNbIm1haWxfY2MiXSkgPiAwKQ0KICAgICAgICAgICAgJHRoaXMtPlNldEFkZHJlc3MoJGds -b2JhbF92YXJzWyJtYWlsX2NjIl0sICJDYXJib24gVXNlciIsICJjYyIpOw0KICAgIH0NCg0KICAg -IC8qKg0KICAgICAqIFJ1biBhZnRlciBlYWNoIHRlc3QgaXMgY29tcGxldGVkLg0KICAgICAqLw0K -ICAgIGZ1bmN0aW9uIHRlYXJEb3duKCkgew0KICAgICAgICAvLyBDbGVhbiBnbG9iYWwgdmFyaWFi -bGVzDQogICAgICAgICR0aGlzLT5NYWlsID0gTlVMTDsNCiAgICAgICAgJHRoaXMtPkNoYW5nZUxv -ZyA9IGFycmF5KCk7DQogICAgICAgICR0aGlzLT5Ob3RlTG9nID0gYXJyYXkoKTsNCiAgICB9DQoN -Cg0KICAgIC8qKg0KICAgICAqIEJ1aWxkIHRoZSBib2R5IG9mIHRoZSBtZXNzYWdlIGluIHRoZSBh -cHByb3ByaWF0ZSBmb3JtYXQuDQogICAgICogQHByaXZhdGUNCiAgICAgKiBAcmV0dXJucyB2b2lk -DQogICAgICovDQogICAgZnVuY3Rpb24gQnVpbGRCb2R5KCkgew0KICAgICAgICAkdGhpcy0+Q2hl -Y2tDaGFuZ2VzKCk7DQoNCiAgICAgICAgLy8gRGV0ZXJtaW5lIGxpbmUgZW5kaW5ncyBmb3IgbWVz -c2FnZQ0KICAgICAgICBpZigkdGhpcy0+TWFpbC0+Q29udGVudFR5cGUgPT0gInRleHQvaHRtbCIg -fHwgc3RybGVuKCR0aGlzLT5NYWlsLT5BbHRCb2R5KSA+IDApDQogICAgICAgIHsNCiAgICAgICAg -ICAgICRlb2wgPSAiPGJyLz4iOw0KICAgICAgICAgICAgJGJ1bGxldCA9ICI8bGk+IjsNCiAgICAg -ICAgICAgICRidWxsZXRfc3RhcnQgPSAiPHVsPiI7DQogICAgICAgICAgICAkYnVsbGV0X2VuZCA9 -ICI8L3VsPiI7DQogICAgICAgIH0NCiAgICAgICAgZWxzZQ0KICAgICAgICB7DQogICAgICAgICAg -ICAkZW9sID0gIlxuIjsNCiAgICAgICAgICAgICRidWxsZXQgPSAiIC0gIjsNCiAgICAgICAgICAg -ICRidWxsZXRfc3RhcnQgPSAiIjsNCiAgICAgICAgICAgICRidWxsZXRfZW5kID0gIiI7DQogICAg -ICAgIH0NCg0KICAgICAgICAkUmVwb3J0Qm9keSA9ICIiOw0KDQogICAgICAgICRSZXBvcnRCb2R5 -IC49ICItLS0tLS0tLS0tLS0tLS0tLS0tLS0iIC4gJGVvbDsNCiAgICAgICAgJFJlcG9ydEJvZHkg -Lj0gIlVuaXQgVGVzdCBJbmZvcm1hdGlvbiIgLiAkZW9sOw0KICAgICAgICAkUmVwb3J0Qm9keSAu -PSAiLS0tLS0tLS0tLS0tLS0tLS0tLS0tIiAuICRlb2w7DQogICAgICAgICRSZXBvcnRCb2R5IC49 -ICJwaHBtYWlsZXIgdmVyc2lvbjogIiAuICR0aGlzLT5NYWlsLT5WZXJzaW9uIC4gJGVvbDsNCiAg -ICAgICAgJFJlcG9ydEJvZHkgLj0gIkNvbnRlbnQgVHlwZTogIiAuICR0aGlzLT5NYWlsLT5Db250 -ZW50VHlwZSAuICRlb2w7DQoNCiAgICAgICAgaWYoc3RybGVuKCR0aGlzLT5NYWlsLT5Ib3N0KSA+ -IDApDQogICAgICAgICAgICAkUmVwb3J0Qm9keSAuPSAiSG9zdDogIiAuICR0aGlzLT5NYWlsLT5I -b3N0IC4gJGVvbDsNCg0KICAgICAgICAvLyBJZiBhdHRhY2htZW50cyB0aGVuIGNyZWF0ZSBhbiBh -dHRhY2htZW50IGxpc3QNCiAgICAgICAgaWYoY291bnQoJHRoaXMtPk1haWwtPmF0dGFjaG1lbnQp -ID4gMCkNCiAgICAgICAgew0KICAgICAgICAgICAgJFJlcG9ydEJvZHkgLj0gIkF0dGFjaG1lbnRz -OiIgLiAkZW9sOw0KICAgICAgICAgICAgJFJlcG9ydEJvZHkgLj0gJGJ1bGxldF9zdGFydDsNCiAg -ICAgICAgICAgIGZvcigkaSA9IDA7ICRpIDwgY291bnQoJHRoaXMtPk1haWwtPmF0dGFjaG1lbnQp -OyAkaSsrKQ0KICAgICAgICAgICAgew0KICAgICAgICAgICAgICAgICRSZXBvcnRCb2R5IC49ICRi -dWxsZXQgLiAiTmFtZTogIiAuICR0aGlzLT5NYWlsLT5hdHRhY2htZW50WyRpXVsxXSAuICIsICI7 -DQogICAgICAgICAgICAgICAgJFJlcG9ydEJvZHkgLj0gIkVuY29kaW5nOiAiIC4gJHRoaXMtPk1h -aWwtPmF0dGFjaG1lbnRbJGldWzNdIC4gIiwgIjsNCiAgICAgICAgICAgICAgICAkUmVwb3J0Qm9k -eSAuPSAiVHlwZTogIiAuICR0aGlzLT5NYWlsLT5hdHRhY2htZW50WyRpXVs0XSAuICRlb2w7DQog -ICAgICAgICAgICB9DQogICAgICAgICAgICAkUmVwb3J0Qm9keSAuPSAkYnVsbGV0X2VuZCAuICRl -b2w7DQogICAgICAgIH0NCg0KICAgICAgICAvLyBJZiB0aGVyZSBhcmUgY2hhbmdlcyB0aGVuIGxp -c3QgdGhlbQ0KICAgICAgICBpZihjb3VudCgkdGhpcy0+Q2hhbmdlTG9nKSA+IDApDQogICAgICAg -IHsNCiAgICAgICAgICAgICRSZXBvcnRCb2R5IC49ICJDaGFuZ2VzIiAuICRlb2w7DQogICAgICAg -ICAgICAkUmVwb3J0Qm9keSAuPSAiLS0tLS0tLSIgLiAkZW9sOw0KDQogICAgICAgICAgICAkUmVw -b3J0Qm9keSAuPSAkYnVsbGV0X3N0YXJ0Ow0KICAgICAgICAgICAgZm9yKCRpID0gMDsgJGkgPCBj -b3VudCgkdGhpcy0+Q2hhbmdlTG9nKTsgJGkrKykNCiAgICAgICAgICAgIHsNCiAgICAgICAgICAg -ICAgICAkUmVwb3J0Qm9keSAuPSAkYnVsbGV0IC4gJHRoaXMtPkNoYW5nZUxvZ1skaV1bMF0gLiAi -IHdhcyBjaGFuZ2VkIHRvIFsiIC4NCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAkdGhp -cy0+Q2hhbmdlTG9nWyRpXVsxXSAuICJdIiAuICRlb2w7DQogICAgICAgICAgICB9DQogICAgICAg -ICAgICAkUmVwb3J0Qm9keSAuPSAkYnVsbGV0X2VuZCAuICRlb2wgLiAkZW9sOw0KICAgICAgICB9 -DQoNCiAgICAgICAgLy8gSWYgdGhlcmUgYXJlIG5vdGVzIHRoZW4gbGlzdCB0aGVtDQogICAgICAg -IGlmKGNvdW50KCR0aGlzLT5Ob3RlTG9nKSA+IDApDQogICAgICAgIHsNCiAgICAgICAgICAgICRS -ZXBvcnRCb2R5IC49ICJOb3RlcyIgLiAkZW9sOw0KICAgICAgICAgICAgJFJlcG9ydEJvZHkgLj0g -Ii0tLS0tIiAuICRlb2w7DQoNCiAgICAgICAgICAgICRSZXBvcnRCb2R5IC49ICRidWxsZXRfc3Rh -cnQ7DQogICAgICAgICAgICBmb3IoJGkgPSAwOyAkaSA8IGNvdW50KCR0aGlzLT5Ob3RlTG9nKTsg -JGkrKykNCiAgICAgICAgICAgIHsNCiAgICAgICAgICAgICAgICAkUmVwb3J0Qm9keSAuPSAkYnVs -bGV0IC4gJHRoaXMtPk5vdGVMb2dbJGldIC4gJGVvbDsNCiAgICAgICAgICAgIH0NCiAgICAgICAg -ICAgICRSZXBvcnRCb2R5IC49ICRidWxsZXRfZW5kOw0KICAgICAgICB9DQoNCiAgICAgICAgLy8g -UmUtYXR0YWNoIHRoZSBvcmlnaW5hbCBib2R5DQogICAgICAgICR0aGlzLT5NYWlsLT5Cb2R5IC49 -ICRlb2wgLiAkZW9sIC4gJFJlcG9ydEJvZHk7DQogICAgfQ0KDQogICAgLyoqDQogICAgICogQ2hl -Y2sgd2hpY2ggZGVmYXVsdCBzZXR0aW5ncyBoYXZlIGJlZW4gY2hhbmdlZCBmb3IgdGhlIHJlcG9y -dC4NCiAgICAgKiBAcHJpdmF0ZQ0KICAgICAqIEByZXR1cm5zIHZvaWQNCiAgICAgKi8NCiAgICBm -dW5jdGlvbiBDaGVja0NoYW5nZXMoKSB7DQogICAgICAgIGlmKCR0aGlzLT5NYWlsLT5Qcmlvcml0 -eSAhPSAzKQ0KICAgICAgICAgICAgJHRoaXMtPkFkZENoYW5nZSgiUHJpb3JpdHkiLCAkdGhpcy0+ -TWFpbC0+UHJpb3JpdHkpOw0KICAgICAgICBpZigkdGhpcy0+TWFpbC0+RW5jb2RpbmcgIT0gIjhi -aXQiKQ0KICAgICAgICAgICAgJHRoaXMtPkFkZENoYW5nZSgiRW5jb2RpbmciLCAkdGhpcy0+TWFp -bC0+RW5jb2RpbmcpOw0KICAgICAgICBpZigkdGhpcy0+TWFpbC0+Q2hhclNldCAhPSAiaXNvLTg4 -NTktMSIpDQogICAgICAgICAgICAkdGhpcy0+QWRkQ2hhbmdlKCJDaGFyU2V0IiwgJHRoaXMtPk1h -aWwtPkNoYXJTZXQpOw0KICAgICAgICBpZigkdGhpcy0+TWFpbC0+U2VuZGVyICE9ICIiKQ0KICAg -ICAgICAgICAgJHRoaXMtPkFkZENoYW5nZSgiU2VuZGVyIiwgJHRoaXMtPk1haWwtPlNlbmRlcik7 -DQogICAgICAgIGlmKCR0aGlzLT5NYWlsLT5Xb3JkV3JhcCAhPSAwKQ0KICAgICAgICAgICAgJHRo -aXMtPkFkZENoYW5nZSgiV29yZFdyYXAiLCAkdGhpcy0+TWFpbC0+V29yZFdyYXApOw0KICAgICAg -ICBpZigkdGhpcy0+TWFpbC0+TWFpbGVyICE9ICJtYWlsIikNCiAgICAgICAgICAgICR0aGlzLT5B -ZGRDaGFuZ2UoIk1haWxlciIsICR0aGlzLT5NYWlsLT5NYWlsZXIpOw0KICAgICAgICBpZigkdGhp -cy0+TWFpbC0+UG9ydCAhPSAyNSkNCiAgICAgICAgICAgICR0aGlzLT5BZGRDaGFuZ2UoIlBvcnQi -LCAkdGhpcy0+TWFpbC0+UG9ydCk7DQogICAgICAgIGlmKCR0aGlzLT5NYWlsLT5IZWxvICE9ICJs -b2NhbGhvc3QubG9jYWxkb21haW4iKQ0KICAgICAgICAgICAgJHRoaXMtPkFkZENoYW5nZSgiSGVs -byIsICR0aGlzLT5NYWlsLT5IZWxvKTsNCiAgICAgICAgaWYoJHRoaXMtPk1haWwtPlNNVFBBdXRo -KQ0KICAgICAgICAgICAgJHRoaXMtPkFkZENoYW5nZSgiU01UUEF1dGgiLCAidHJ1ZSIpOw0KICAg -IH0NCg0KICAgIC8qKg0KICAgICAqIEFkZHMgYSBjaGFuZ2UgZW50cnkuDQogICAgICogQHByaXZh -dGUNCiAgICAgKiBAcmV0dXJucyB2b2lkDQogICAgICovDQogICAgZnVuY3Rpb24gQWRkQ2hhbmdl -KCRzTmFtZSwgJHNOZXdWYWx1ZSkgew0KICAgICAgICAkY3VyID0gY291bnQoJHRoaXMtPkNoYW5n -ZUxvZyk7DQogICAgICAgICR0aGlzLT5DaGFuZ2VMb2dbJGN1cl1bMF0gPSAkc05hbWU7DQogICAg -ICAgICR0aGlzLT5DaGFuZ2VMb2dbJGN1cl1bMV0gPSAkc05ld1ZhbHVlOw0KICAgIH0NCg0KICAg -IC8qKg0KICAgICAqIEFkZHMgYSBzaW1wbGUgbm90ZSB0byB0aGUgbWVzc2FnZS4NCiAgICAgKiBA -cHVibGljDQogICAgICogQHJldHVybnMgdm9pZA0KICAgICAqLw0KICAgIGZ1bmN0aW9uIEFkZE5v -dGUoJHNWYWx1ZSkgew0KICAgICAgICAkdGhpcy0+Tm90ZUxvZ1tdID0gJHNWYWx1ZTsNCiAgICB9 -DQoNCiAgICAvKioNCiAgICAgKiBBZGRzIGFsbCBvZiB0aGUgYWRkcmVzc2VzDQogICAgICogQHB1 -YmxpYw0KICAgICAqIEByZXR1cm5zIHZvaWQNCiAgICAgKi8NCiAgICBmdW5jdGlvbiBTZXRBZGRy -ZXNzKCRzQWRkcmVzcywgJHNOYW1lID0gIiIsICRzVHlwZSA9ICJ0byIpIHsNCiAgICAgICAgc3dp -dGNoKCRzVHlwZSkNCiAgICAgICAgew0KICAgICAgICAgICAgY2FzZSAidG8iOg0KICAgICAgICAg -ICAgICAgICR0aGlzLT5NYWlsLT5BZGRBZGRyZXNzKCRzQWRkcmVzcywgJHNOYW1lKTsNCiAgICAg -ICAgICAgICAgICBicmVhazsNCiAgICAgICAgICAgIGNhc2UgImNjIjoNCiAgICAgICAgICAgICAg -ICAkdGhpcy0+TWFpbC0+QWRkQ0MoJHNBZGRyZXNzLCAkc05hbWUpOw0KICAgICAgICAgICAgICAg -IGJyZWFrOw0KICAgICAgICAgICAgY2FzZSAiYmNjIjoNCiAgICAgICAgICAgICAgICAkdGhpcy0+ -TWFpbC0+QWRkQkNDKCRzQWRkcmVzcywgJHNOYW1lKTsNCiAgICAgICAgICAgICAgICBicmVhazsN -CiAgICAgICAgfQ0KICAgIH0NCg0KICAgIC8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8v -Ly8vLy8vLy8vLy8vLy8vLy8NCiAgICAvLyBVTklUIFRFU1RTDQogICAgLy8vLy8vLy8vLy8vLy8v -Ly8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLw0KDQogICAgLyoqDQogICAgICogVHJ5 -IGEgcGxhaW4gbWVzc2FnZS4NCiAgICAgKi8NCiAgICBmdW5jdGlvbiB0ZXN0X1dvcmRXcmFwKCkg -ew0KDQogICAgICAgICR0aGlzLT5NYWlsLT5Xb3JkV3JhcCA9IDQwOw0KICAgICAgICAkbXlfYm9k -eSA9ICJIZXJlIGlzIHRoZSBtYWluIGJvZHkgb2YgdGhpcyBtZXNzYWdlLiAgSXQgc2hvdWxkICIg -Lg0KICAgICAgICAgICAgICAgICAgICJiZSBxdWl0ZSBhIGZldyBsaW5lcy4gIEl0IHNob3VsZCBi -ZSB3cmFwcGVkIGF0IHRoZSAiIC4NCiAgICAgICAgICAgICAgICAgICAiNDAgY2hhcmFjdGVycy4g -IE1ha2Ugc3VyZSB0aGF0IGl0IGlzLiI7DQogICAgICAgICRuQm9keUxlbiA9IHN0cmxlbigkbXlf -Ym9keSk7DQogICAgICAgICRteV9ib2R5IC49ICJcblxuVGhpcyBpcyB0aGUgYWJvdmUgYm9keSBs -ZW5ndGg6ICIgLiAkbkJvZHlMZW47DQoNCiAgICAgICAgJHRoaXMtPk1haWwtPkJvZHkgPSAkbXlf -Ym9keTsNCiAgICAgICAgJHRoaXMtPk1haWwtPlN1YmplY3QgLj0gIjogV29yZHdyYXAiOw0KDQog -ICAgICAgICR0aGlzLT5CdWlsZEJvZHkoKTsNCiAgICAgICAgJHRoaXMtPmFzc2VydCgkdGhpcy0+ -TWFpbC0+U2VuZCgpLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZvKTsNCiAgICB9DQoNCiAgICAvKioN -CiAgICAgKiBUcnkgYSBwbGFpbiBtZXNzYWdlLg0KICAgICAqLw0KICAgIGZ1bmN0aW9uIHRlc3Rf -TG93X1ByaW9yaXR5KCkgew0KDQogICAgICAgICR0aGlzLT5NYWlsLT5Qcmlvcml0eSA9IDU7DQog -ICAgICAgICR0aGlzLT5NYWlsLT5Cb2R5ID0gIkhlcmUgaXMgdGhlIG1haW4gYm9keS4gIFRoZXJl -IHNob3VsZCBiZSAiIC4NCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAiYSByZXBseSB0byBh -ZGRyZXNzIGluIHRoaXMgbWVzc2FnZS4iOw0KICAgICAgICAkdGhpcy0+TWFpbC0+U3ViamVjdCAu -PSAiOiBMb3cgUHJpb3JpdHkiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+QWRkUmVwbHlUbygibm9i -b2R5QG5vYm9keS5jb20iLCAiTm9ib2R5IChVbml0IFRlc3QpIik7DQoNCiAgICAgICAgJHRoaXMt -PkJ1aWxkQm9keSgpOw0KICAgICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5NYWlsLT5TZW5kKCks -ICR0aGlzLT5NYWlsLT5FcnJvckluZm8pOw0KICAgIH0NCg0KICAgIC8qKg0KICAgICAqIFNpbXBs -ZSBwbGFpbiBmaWxlIGF0dGFjaG1lbnQgdGVzdC4NCiAgICAgKi8NCiAgICBmdW5jdGlvbiB0ZXN0 -X011bHRpcGxlX1BsYWluX0ZpbGVBdHRhY2htZW50KCkgew0KDQogICAgICAgICR0aGlzLT5NYWls -LT5Cb2R5ID0gIkhlcmUgaXMgdGhlIHRleHQgYm9keSI7DQogICAgICAgICR0aGlzLT5NYWlsLT5T -dWJqZWN0IC49ICI6IFBsYWluICsgTXVsdGlwbGUgRmlsZUF0dGFjaG1lbnRzIjsNCg0KICAgICAg -ICBpZighJHRoaXMtPk1haWwtPkFkZEF0dGFjaG1lbnQoInJvY2tzLnBuZyIpKQ0KICAgICAgICB7 -DQogICAgICAgICAgICAkdGhpcy0+YXNzZXJ0KGZhbHNlLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZv -KTsNCiAgICAgICAgICAgIHJldHVybjsNCiAgICAgICAgfQ0KDQogICAgICAgIGlmKCEkdGhpcy0+ -TWFpbC0+QWRkQXR0YWNobWVudCgicGhwbWFpbGVyX3Rlc3QucGhwIiwgInRlc3QudHh0IikpDQog -ICAgICAgIHsNCiAgICAgICAgICAgICR0aGlzLT5hc3NlcnQoZmFsc2UsICR0aGlzLT5NYWlsLT5F -cnJvckluZm8pOw0KICAgICAgICAgICAgcmV0dXJuOw0KICAgICAgICB9DQoNCiAgICAgICAgJHRo -aXMtPkJ1aWxkQm9keSgpOw0KICAgICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5NYWlsLT5TZW5k -KCksICR0aGlzLT5NYWlsLT5FcnJvckluZm8pOw0KICAgIH0NCg0KICAgIC8qKg0KICAgICAqIFNp -bXBsZSBwbGFpbiBzdHJpbmcgYXR0YWNobWVudCB0ZXN0Lg0KICAgICAqLw0KICAgIGZ1bmN0aW9u -IHRlc3RfUGxhaW5fU3RyaW5nQXR0YWNobWVudCgpIHsNCg0KICAgICAgICAkdGhpcy0+TWFpbC0+ -Qm9keSA9ICJIZXJlIGlzIHRoZSB0ZXh0IGJvZHkiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+U3Vi -amVjdCAuPSAiOiBQbGFpbiArIFN0cmluZ0F0dGFjaG1lbnQiOw0KDQogICAgICAgICRzQXR0YWNo -bWVudCA9ICJUaGVzZSBjaGFyYWN0ZXJzIGFyZSB0aGUgY29udGVudCBvZiB0aGUgIiAuDQogICAg -ICAgICAgICAgICAgICAgICAgICJzdHJpbmcgYXR0YWNobWVudC5cblRoaXMgbWlnaHQgYmUgdGFr -ZW4gZnJvbSBhICIuDQogICAgICAgICAgICAgICAgICAgICAgICJkYXRhYmFzZSBvciBzb21lIG90 -aGVyIHN1Y2ggdGhpbmcuICI7DQoNCiAgICAgICAgJHRoaXMtPk1haWwtPkFkZFN0cmluZ0F0dGFj -aG1lbnQoJHNBdHRhY2htZW50LCAic3RyaW5nX2F0dGFjaC50eHQiKTsNCg0KICAgICAgICAkdGhp -cy0+QnVpbGRCb2R5KCk7DQogICAgICAgICR0aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwtPlNlbmQo -KSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQogICAgfQ0KDQogICAgLyoqDQogICAgICogUGxh -aW4gcXVvdGVkLXByaW50YWJsZSBtZXNzYWdlLg0KICAgICAqLw0KICAgIGZ1bmN0aW9uIHRlc3Rf -UXVvdGVkX1ByaW50YWJsZSgpIHsNCg0KICAgICAgICAkdGhpcy0+TWFpbC0+Qm9keSA9ICJIZXJl -IGlzIHRoZSBtYWluIGJvZHkiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+U3ViamVjdCAuPSAiOiBQ -bGFpbiArIFF1b3RlZC1wcmludGFibGUiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+RW5jb2Rpbmcg -PSAicXVvdGVkLXByaW50YWJsZSI7DQoNCiAgICAgICAgJHRoaXMtPkJ1aWxkQm9keSgpOw0KICAg -ICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5NYWlsLT5TZW5kKCksICR0aGlzLT5NYWlsLT5FcnJv -ckluZm8pOw0KICAgIH0NCg0KICAgIC8qKg0KICAgICAqIFRyeSBhIHBsYWluIG1lc3NhZ2UuDQog -ICAgICovDQogICAgZnVuY3Rpb24gdGVzdF9IdG1sKCkgew0KDQogICAgICAgICR0aGlzLT5NYWls -LT5Jc0hUTUwodHJ1ZSk7DQogICAgICAgICR0aGlzLT5NYWlsLT5TdWJqZWN0IC49ICI6IEhUTUwg -b25seSI7DQoNCiAgICAgICAgJHRoaXMtPk1haWwtPkJvZHkgPSAiVGhpcyBpcyBhIDxiPnRlc3Qg -bWVzc2FnZTwvYj4gd3JpdHRlbiBpbiBIVE1MLiA8L2JyPiIgLg0KICAgICAgICAgICAgICAgICAg -ICAgICAgICAgICJHbyB0byA8YSBocmVmPVwiaHR0cDovL3BocG1haWxlci5zb3VyY2Vmb3JnZS5u -ZXQvXCI+IiAuDQogICAgICAgICAgICAgICAgICAgICAgICAgICAgImh0dHA6Ly9waHBtYWlsZXIu -c291cmNlZm9yZ2UubmV0LzwvYT4gZm9yIG5ldyB2ZXJzaW9ucyBvZiAiIC4NCiAgICAgICAgICAg -ICAgICAgICAgICAgICAgICAicGhwbWFpbGVyLiAgPHAvPiBUaGFuayB5b3UhIjsNCg0KICAgICAg -ICAkdGhpcy0+QnVpbGRCb2R5KCk7DQogICAgICAgICR0aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwt -PlNlbmQoKSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQogICAgfQ0KDQogICAgLyoqDQogICAg -ICogU2ltcGxlIEhUTUwgYW5kIGF0dGFjaG1lbnQgdGVzdA0KICAgICAqLw0KICAgIGZ1bmN0aW9u -IHRlc3RfSFRNTF9BdHRhY2htZW50KCkgew0KDQogICAgICAgICR0aGlzLT5NYWlsLT5Cb2R5ID0g -IlRoaXMgaXMgdGhlIDxiPkhUTUw8L2I+IHBhcnQgb2YgdGhlIGVtYWlsLiI7DQogICAgICAgICR0 -aGlzLT5NYWlsLT5TdWJqZWN0IC49ICI6IEhUTUwgKyBBdHRhY2htZW50IjsNCiAgICAgICAgJHRo -aXMtPk1haWwtPklzSFRNTCh0cnVlKTsNCg0KICAgICAgICBpZighJHRoaXMtPk1haWwtPkFkZEF0 -dGFjaG1lbnQoInBocG1haWxlcl90ZXN0LnBocCIsICJ0ZXN0X2F0dGFjaC50eHQiKSkNCiAgICAg -ICAgew0KICAgICAgICAgICAgJHRoaXMtPmFzc2VydChmYWxzZSwgJHRoaXMtPk1haWwtPkVycm9y -SW5mbyk7DQogICAgICAgICAgICByZXR1cm47DQogICAgICAgIH0NCg0KICAgICAgICAkdGhpcy0+ -QnVpbGRCb2R5KCk7DQogICAgICAgICR0aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwtPlNlbmQoKSwg -JHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQogICAgfQ0KDQogICAgLyoqDQogICAgICogQW4gZW1i -ZWRkZWQgYXR0YWNobWVudCB0ZXN0Lg0KICAgICAqLw0KICAgIGZ1bmN0aW9uIHRlc3RfRW1iZWRk -ZWRfSW1hZ2UoKSB7DQoNCiAgICAgICAgJHRoaXMtPk1haWwtPkJvZHkgPSAiRW1iZWRkZWQgSW1h -Z2U6IDxpbWcgYWx0PVwicGhwbWFpbGVyXCIgc3JjPVwiY2lkOm15LWF0dGFjaFwiPiIgLg0KICAg -ICAgICAgICAgICAgICAgICAgIkhlcmUgaXMgYW4gaW1hZ2UhPC9hPiI7DQogICAgICAgICR0aGlz -LT5NYWlsLT5TdWJqZWN0IC49ICI6IEVtYmVkZGVkIEltYWdlIjsNCiAgICAgICAgJHRoaXMtPk1h -aWwtPklzSFRNTCh0cnVlKTsNCg0KICAgICAgICBpZighJHRoaXMtPk1haWwtPkFkZEVtYmVkZGVk -SW1hZ2UoInJvY2tzLnBuZyIsICJteS1hdHRhY2giLCAicm9ja3MucG5nIiwNCiAgICAgICAgICAg -ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJiYXNlNjQiLCAiaW1hZ2UvcG5nIikpDQog -ICAgICAgIHsNCiAgICAgICAgICAgICR0aGlzLT5hc3NlcnQoZmFsc2UsICR0aGlzLT5NYWlsLT5F -cnJvckluZm8pOw0KICAgICAgICAgICAgcmV0dXJuOw0KICAgICAgICB9DQoNCiAgICAgICAgJHRo -aXMtPkJ1aWxkQm9keSgpOw0KICAgICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5NYWlsLT5TZW5k -KCksICR0aGlzLT5NYWlsLT5FcnJvckluZm8pOw0KICAgIH0NCg0KICAgIC8qKg0KICAgICAqIEFu -IGVtYmVkZGVkIGF0dGFjaG1lbnQgdGVzdC4NCiAgICAgKi8NCiAgICBmdW5jdGlvbiB0ZXN0X011 -bHRpX0VtYmVkZGVkX0ltYWdlKCkgew0KDQogICAgICAgICR0aGlzLT5NYWlsLT5Cb2R5ID0gIkVt -YmVkZGVkIEltYWdlOiA8aW1nIGFsdD1cInBocG1haWxlclwiIHNyYz1cImNpZDpteS1hdHRhY2hc -Ij4iIC4NCiAgICAgICAgICAgICAgICAgICAgICJIZXJlIGlzIGFuIGltYWdlITwvYT4iOw0KICAg -ICAgICAkdGhpcy0+TWFpbC0+U3ViamVjdCAuPSAiOiBFbWJlZGRlZCBJbWFnZSArIEF0dGFjaG1l -bnQiOw0KICAgICAgICAkdGhpcy0+TWFpbC0+SXNIVE1MKHRydWUpOw0KDQogICAgICAgIGlmKCEk -dGhpcy0+TWFpbC0+QWRkRW1iZWRkZWRJbWFnZSgicm9ja3MucG5nIiwgIm15LWF0dGFjaCIsICJy -b2Nrcy5wbmciLA0KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgImJh -c2U2NCIsICJpbWFnZS9wbmciKSkNCiAgICAgICAgew0KICAgICAgICAgICAgJHRoaXMtPmFzc2Vy -dChmYWxzZSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQogICAgICAgICAgICByZXR1cm47DQog -ICAgICAgIH0NCg0KICAgICAgICBpZighJHRoaXMtPk1haWwtPkFkZEF0dGFjaG1lbnQoInBocG1h -aWxlcl90ZXN0LnBocCIsICJ0ZXN0LnR4dCIpKQ0KICAgICAgICB7DQogICAgICAgICAgICAkdGhp -cy0+YXNzZXJ0KGZhbHNlLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZvKTsNCiAgICAgICAgICAgIHJl -dHVybjsNCiAgICAgICAgfQ0KDQogICAgICAgICR0aGlzLT5CdWlsZEJvZHkoKTsNCiAgICAgICAg -JHRoaXMtPmFzc2VydCgkdGhpcy0+TWFpbC0+U2VuZCgpLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZv -KTsNCiAgICB9DQoNCiAgICAvKioNCiAgICAgKiBTaW1wbGUgbXVsdGlwYXJ0L2FsdGVybmF0aXZl -IHRlc3QuDQogICAgICovDQogICAgZnVuY3Rpb24gdGVzdF9BbHRCb2R5KCkgew0KDQogICAgICAg -ICR0aGlzLT5NYWlsLT5Cb2R5ID0gIlRoaXMgaXMgdGhlIDxiPkhUTUw8L2I+IHBhcnQgb2YgdGhl -IGVtYWlsLiI7DQogICAgICAgICR0aGlzLT5NYWlsLT5BbHRCb2R5ID0gIkhlcmUgaXMgdGhlIHRl -eHQgYm9keSBvZiB0aGlzIG1lc3NhZ2UuICAiIC4NCiAgICAgICAgICAgICAgICAgICAiSXQgc2hv -dWxkIGJlIHF1aXRlIGEgZmV3IGxpbmVzLiAgSXQgc2hvdWxkIGJlIHdyYXBwZWQgYXQgdGhlICIg -Lg0KICAgICAgICAgICAgICAgICAgICI0MCBjaGFyYWN0ZXJzLiAgTWFrZSBzdXJlIHRoYXQgaXQg -aXMuIjsNCiAgICAgICAgJHRoaXMtPk1haWwtPldvcmRXcmFwID0gNDA7DQogICAgICAgICR0aGlz -LT5BZGROb3RlKCJUaGlzIGlzIGEgbXVsaXBhcnQgYWx0ZXJuYXRpdmUgZW1haWwiKTsNCiAgICAg -ICAgJHRoaXMtPk1haWwtPlN1YmplY3QgLj0gIjogQWx0Qm9keSArIFdvcmQgV3JhcCI7DQoNCiAg -ICAgICAgJHRoaXMtPkJ1aWxkQm9keSgpOw0KICAgICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5N -YWlsLT5TZW5kKCksICR0aGlzLT5NYWlsLT5FcnJvckluZm8pOw0KICAgIH0NCg0KICAgIC8qKg0K -ICAgICAqIFNpbXBsZSBIVE1MIGFuZCBhdHRhY2htZW50IHRlc3QNCiAgICAgKi8NCiAgICBmdW5j -dGlvbiB0ZXN0X0FsdEJvZHlfQXR0YWNobWVudCgpIHsNCg0KICAgICAgICAkdGhpcy0+TWFpbC0+ -Qm9keSA9ICJUaGlzIGlzIHRoZSA8Yj5IVE1MPC9iPiBwYXJ0IG9mIHRoZSBlbWFpbC4iOw0KICAg -ICAgICAkdGhpcy0+TWFpbC0+QWx0Qm9keSA9ICJUaGlzIGlzIHRoZSB0ZXh0IHBhcnQgb2YgdGhl -IGVtYWlsLiI7DQogICAgICAgICR0aGlzLT5NYWlsLT5TdWJqZWN0IC49ICI6IEFsdEJvZHkgKyBB -dHRhY2htZW50IjsNCiAgICAgICAgJHRoaXMtPk1haWwtPklzSFRNTCh0cnVlKTsNCg0KICAgICAg -ICBpZighJHRoaXMtPk1haWwtPkFkZEF0dGFjaG1lbnQoInBocG1haWxlcl90ZXN0LnBocCIsICJ0 -ZXN0X2F0dGFjaC50eHQiKSkNCiAgICAgICAgew0KICAgICAgICAgICAgJHRoaXMtPmFzc2VydChm -YWxzZSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQogICAgICAgICAgICByZXR1cm47DQogICAg -ICAgIH0NCg0KICAgICAgICAkdGhpcy0+QnVpbGRCb2R5KCk7DQogICAgICAgICR0aGlzLT5hc3Nl -cnQoJHRoaXMtPk1haWwtPlNlbmQoKSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7DQoNCiAgICAg -ICAgJGZwID0gZm9wZW4oIm1lc3NhZ2UudHh0IiwgInciKTsNCiAgICAgICAgZndyaXRlKCRmcCwg -JHRoaXMtPk1haWwtPkNyZWF0ZUhlYWRlcigpIC4gJHRoaXMtPk1haWwtPkNyZWF0ZUJvZHkoKSk7 -DQogICAgICAgIGZjbG9zZSgkZnApOw0KICAgIH0NCg0KICAgIGZ1bmN0aW9uIHRlc3RfTXVsdGlw -bGVTZW5kKCkgew0KICAgICAgICAkdGhpcy0+TWFpbC0+Qm9keSA9ICJTZW5kaW5nIHR3byBtZXNz -YWdlcyB3aXRob3V0IGtlZXBhbGl2ZSI7DQogICAgICAgICR0aGlzLT5CdWlsZEJvZHkoKTsNCiAg -ICAgICAgJHN1YmplY3QgPSAkdGhpcy0+TWFpbC0+U3ViamVjdDsNCg0KICAgICAgICAkdGhpcy0+ -TWFpbC0+U3ViamVjdCA9ICRzdWJqZWN0IC4gIjogU01UUCAxIjsNCiAgICAgICAgJHRoaXMtPmFz -c2VydCgkdGhpcy0+TWFpbC0+U2VuZCgpLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZvKTsNCg0KICAg -ICAgICAkdGhpcy0+TWFpbC0+U3ViamVjdCA9ICRzdWJqZWN0IC4gIjogU01UUCAyIjsNCiAgICAg -ICAgJHRoaXMtPmFzc2VydCgkdGhpcy0+TWFpbC0+U2VuZCgpLCAkdGhpcy0+TWFpbC0+RXJyb3JJ -bmZvKTsNCiAgICB9DQoNCiAgICBmdW5jdGlvbiB0ZXN0X1NtdHBLZWVwQWxpdmUoKSB7DQogICAg -ICAgICR0aGlzLT5NYWlsLT5Cb2R5ID0gIlRoaXMgd2FzIGRvbmUgdXNpbmcgdGhlIFNNVFAga2Vl -cC1hbGl2ZS4iOw0KICAgICAgICAkdGhpcy0+QnVpbGRCb2R5KCk7DQogICAgICAgICRzdWJqZWN0 -ID0gJHRoaXMtPk1haWwtPlN1YmplY3Q7DQoNCiAgICAgICAgJHRoaXMtPk1haWwtPlNNVFBLZWVw -QWxpdmUgPSB0cnVlOw0KICAgICAgICAkdGhpcy0+TWFpbC0+U3ViamVjdCA9ICRzdWJqZWN0IC4g -IjogU01UUCBrZWVwLWFsaXZlIDEiOw0KICAgICAgICAkdGhpcy0+YXNzZXJ0KCR0aGlzLT5NYWls -LT5TZW5kKCksICR0aGlzLT5NYWlsLT5FcnJvckluZm8pOw0KDQogICAgICAgICR0aGlzLT5NYWls -LT5TdWJqZWN0ID0gJHN1YmplY3QgLiAiOiBTTVRQIGtlZXAtYWxpdmUgMiI7DQogICAgICAgICR0 -aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwtPlNlbmQoKSwgJHRoaXMtPk1haWwtPkVycm9ySW5mbyk7 -DQogICAgICAgICR0aGlzLT5NYWlsLT5TbXRwQ2xvc2UoKTsNCiAgICB9DQoNCiAgICBmdW5jdGlv -biB0ZXN0X0Vycm9yKCkgew0KICAgICAgICAkdGhpcy0+QnVpbGRCb2R5KCk7DQogICAgICAgICR0 -aGlzLT5NYWlsLT5TdWJqZWN0IC49ICI6IFRoaXMgc2hvdWxkIG5vdCBiZSBzZW50IjsNCiAgICAg -ICAgJHRoaXMtPk1haWwtPkNsZWFyQWxsUmVjaXBpZW50cygpOyAvLyBubyBhZGRyZXNzZXMgc2hv -dWxkIGNhdXNlIGFuIGVycm9yDQogICAgICAgICR0aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwtPklz -RXJyb3IoKSA9PSBmYWxzZSwgIkVycm9yIGZvdW5kIik7DQogICAgICAgICR0aGlzLT5hc3NlcnQo -JHRoaXMtPk1haWwtPlNlbmQoKSA9PSBmYWxzZSwgIlNlbmQgc3VjY2VlZGVkIik7DQogICAgICAg -ICR0aGlzLT5hc3NlcnQoJHRoaXMtPk1haWwtPklzRXJyb3IoKSwgIk5vIGVycm9yIGZvdW5kIik7 -DQogICAgICAgICR0aGlzLT5hc3NlcnRFcXVhbHMoJ1lvdSBtdXN0IHByb3ZpZGUgYXQgbGVhc3Qg -b25lICcgLg0KICAgICAgICAgICAgICAgICAgICAgICAgICAgICdyZWNpcGllbnQgZW1haWwgYWRk -cmVzcy4nLCAkdGhpcy0+TWFpbC0+RXJyb3JJbmZvKTsNCiAgICB9DQp9DQoNCi8qKg0KICogQ3Jl -YXRlIGFuZCBydW4gdGVzdCBpbnN0YW5jZS4NCiAqLw0KDQppZihpc3NldCgkSFRUUF9HRVRfVkFS -UykpDQogICAgJGdsb2JhbF92YXJzID0gJEhUVFBfR0VUX1ZBUlM7DQplbHNlDQogICAgJGdsb2Jh -bF92YXJzID0gJF9SRVFVRVNUOw0KDQppZihpc3NldCgkZ2xvYmFsX3ZhcnNbInN1Ym1pdHRlZCJd -KSkNCnsNCiAgICBlY2hvICJUZXN0IHJlc3VsdHM6PGJyPiI7DQogICAgJHN1aXRlID0gbmV3IFRl -c3RTdWl0ZSggInBocG1haWxlclRlc3QiICk7DQoNCiAgICAkdGVzdFJ1bm5lciA9IG5ldyBUZXN0 -UnVubmVyOw0KICAgICR0ZXN0UnVubmVyLT5ydW4oJHN1aXRlKTsNCiAgICBlY2hvICI8aHIgbm9z -aGFkZS8+IjsNCn0NCg0KZnVuY3Rpb24gZ2V0KCRzTmFtZSkgew0KICAgIGdsb2JhbCAkZ2xvYmFs -X3ZhcnM7DQogICAgaWYoaXNzZXQoJGdsb2JhbF92YXJzWyRzTmFtZV0pKQ0KICAgICAgICByZXR1 -cm4gJGdsb2JhbF92YXJzWyRzTmFtZV07DQogICAgZWxzZQ0KICAgICAgICByZXR1cm4gIiI7DQp9 -DQoNCj8+DQoNCjxodG1sPg0KPGJvZHk+DQo8aDM+cGhwbWFpbGVyIFVuaXQgVGVzdDwvaDM+DQpC -eSBlbnRlcmluZyBhIFNNVFAgaG9zdG5hbWUgaXQgd2lsbCBhdXRvbWF0aWNhbGx5IHBlcmZvcm0g -dGVzdHMgd2l0aCBTTVRQLg0KDQo8Zm9ybSBuYW1lPSJwaHBtYWlsZXJfdW5pdCIgYWN0aW9uPSJw -aHBtYWlsZXJfdGVzdC5waHAiIG1ldGhvZD0iZ2V0Ij4NCjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5h -bWU9InN1Ym1pdHRlZCIgdmFsdWU9IjEiLz4NClRvIEFkZHJlc3M6IDxpbnB1dCB0eXBlPSJ0ZXh0 -IiBzaXplPSI1MCIgbmFtZT0ibWFpbF90byIgdmFsdWU9Ijw/cGhwIGVjaG8gZ2V0KCJtYWlsX3Rv -Iik7ID8+Ii8+DQo8YnIvPg0KQ2MgQWRkcmVzczogPGlucHV0IHR5cGU9InRleHQiIHNpemU9IjUw -IiBuYW1lPSJtYWlsX2NjIiB2YWx1ZT0iPD9waHAgZWNobyBnZXQoIm1haWxfY2MiKTsgPz4iLz4N -Cjxici8+DQpTTVRQIEhvc3RuYW1lOiA8aW5wdXQgdHlwZT0idGV4dCIgc2l6ZT0iNTAiIG5hbWU9 -Im1haWxfaG9zdCIgdmFsdWU9Ijw/cGhwIGVjaG8gZ2V0KCJtYWlsX2hvc3QiKTsgPz4iLz4NCjxw -Lz4NCjxpbnB1dCB0eXBlPSJzdWJtaXQiIHZhbHVlPSJSdW4gVGVzdCIvPg0KDQo8L2Zvcm0+DQo8 -L2JvZHk+DQo8L2h0bWw+DQo= - - ---b1_a0169dc7929d1c609a827b4d1a0c3f74-- diff --git a/Class/test/phpmailer_test.php b/Class/test/phpmailer_test.php deleted file mode 100644 index 4264a4f..0000000 --- a/Class/test/phpmailer_test.php +++ /dev/null @@ -1,558 +0,0 @@ -TestCase( $name ); - } - - /** - * Run before each test is started. - */ - function setUp() { - global $global_vars; - global $INCLUDE_DIR; - - $this->Mail = new PHPMailer(); - - $this->Mail->Priority = 3; - $this->Mail->Encoding = "8bit"; - $this->Mail->CharSet = "iso-8859-1"; - $this->Mail->From = "unit_test@phpmailer.sf.net"; - $this->Mail->FromName = "Unit Tester"; - $this->Mail->Sender = ""; - $this->Mail->Subject = "Unit Test"; - $this->Mail->Body = ""; - $this->Mail->AltBody = ""; - $this->Mail->WordWrap = 0; - $this->Mail->Host = $global_vars["mail_host"]; - $this->Mail->Port = 25; - $this->Mail->Helo = "localhost.localdomain"; - $this->Mail->SMTPAuth = false; - $this->Mail->Username = ""; - $this->Mail->Password = ""; - $this->Mail->PluginDir = $INCLUDE_DIR; - $this->Mail->AddReplyTo("no_reply@phpmailer.sf.net", "Reply Guy"); - $this->Mail->Sender = "nobody@example.com"; - - if(strlen($this->Mail->Host) > 0) - $this->Mail->Mailer = "smtp"; - else - { - $this->Mail->Mailer = "mail"; - $this->Sender = "unit_test@phpmailer.sf.net"; - } - - global $global_vars; - $this->SetAddress($global_vars["mail_to"], "Test User"); - if(strlen($global_vars["mail_cc"]) > 0) - $this->SetAddress($global_vars["mail_cc"], "Carbon User", "cc"); - } - - /** - * Run after each test is completed. - */ - function tearDown() { - // Clean global variables - $this->Mail = NULL; - $this->ChangeLog = array(); - $this->NoteLog = array(); - } - - - /** - * Build the body of the message in the appropriate format. - * @private - * @returns void - */ - function BuildBody() { - $this->CheckChanges(); - - // Determine line endings for message - if($this->Mail->ContentType == "text/html" || strlen($this->Mail->AltBody) > 0) - { - $eol = "
"; - $bullet = "
  • "; - $bullet_start = "
      "; - $bullet_end = "
    "; - } - else - { - $eol = "\n"; - $bullet = " - "; - $bullet_start = ""; - $bullet_end = ""; - } - - $ReportBody = ""; - - $ReportBody .= "---------------------" . $eol; - $ReportBody .= "Unit Test Information" . $eol; - $ReportBody .= "---------------------" . $eol; - $ReportBody .= "phpmailer version: " . $this->Mail->Version . $eol; - $ReportBody .= "Content Type: " . $this->Mail->ContentType . $eol; - - if(strlen($this->Mail->Host) > 0) - $ReportBody .= "Host: " . $this->Mail->Host . $eol; - - // If attachments then create an attachment list - if(count($this->Mail->attachment) > 0) - { - $ReportBody .= "Attachments:" . $eol; - $ReportBody .= $bullet_start; - for($i = 0; $i < count($this->Mail->attachment); $i++) - { - $ReportBody .= $bullet . "Name: " . $this->Mail->attachment[$i][1] . ", "; - $ReportBody .= "Encoding: " . $this->Mail->attachment[$i][3] . ", "; - $ReportBody .= "Type: " . $this->Mail->attachment[$i][4] . $eol; - } - $ReportBody .= $bullet_end . $eol; - } - - // If there are changes then list them - if(count($this->ChangeLog) > 0) - { - $ReportBody .= "Changes" . $eol; - $ReportBody .= "-------" . $eol; - - $ReportBody .= $bullet_start; - for($i = 0; $i < count($this->ChangeLog); $i++) - { - $ReportBody .= $bullet . $this->ChangeLog[$i][0] . " was changed to [" . - $this->ChangeLog[$i][1] . "]" . $eol; - } - $ReportBody .= $bullet_end . $eol . $eol; - } - - // If there are notes then list them - if(count($this->NoteLog) > 0) - { - $ReportBody .= "Notes" . $eol; - $ReportBody .= "-----" . $eol; - - $ReportBody .= $bullet_start; - for($i = 0; $i < count($this->NoteLog); $i++) - { - $ReportBody .= $bullet . $this->NoteLog[$i] . $eol; - } - $ReportBody .= $bullet_end; - } - - // Re-attach the original body - $this->Mail->Body .= $eol . $eol . $ReportBody; - } - - /** - * Check which default settings have been changed for the report. - * @private - * @returns void - */ - function CheckChanges() { - if($this->Mail->Priority != 3) - $this->AddChange("Priority", $this->Mail->Priority); - if($this->Mail->Encoding != "8bit") - $this->AddChange("Encoding", $this->Mail->Encoding); - if($this->Mail->CharSet != "iso-8859-1") - $this->AddChange("CharSet", $this->Mail->CharSet); - if($this->Mail->Sender != "") - $this->AddChange("Sender", $this->Mail->Sender); - if($this->Mail->WordWrap != 0) - $this->AddChange("WordWrap", $this->Mail->WordWrap); - if($this->Mail->Mailer != "mail") - $this->AddChange("Mailer", $this->Mail->Mailer); - if($this->Mail->Port != 25) - $this->AddChange("Port", $this->Mail->Port); - if($this->Mail->Helo != "localhost.localdomain") - $this->AddChange("Helo", $this->Mail->Helo); - if($this->Mail->SMTPAuth) - $this->AddChange("SMTPAuth", "true"); - } - - /** - * Adds a change entry. - * @private - * @returns void - */ - function AddChange($sName, $sNewValue) { - $cur = count($this->ChangeLog); - $this->ChangeLog[$cur][0] = $sName; - $this->ChangeLog[$cur][1] = $sNewValue; - } - - /** - * Adds a simple note to the message. - * @public - * @returns void - */ - function AddNote($sValue) { - $this->NoteLog[] = $sValue; - } - - /** - * Adds all of the addresses - * @public - * @returns void - */ - function SetAddress($sAddress, $sName = "", $sType = "to") { - switch($sType) - { - case "to": - $this->Mail->AddAddress($sAddress, $sName); - break; - case "cc": - $this->Mail->AddCC($sAddress, $sName); - break; - case "bcc": - $this->Mail->AddBCC($sAddress, $sName); - break; - } - } - - ///////////////////////////////////////////////// - // UNIT TESTS - ///////////////////////////////////////////////// - - /** - * Try a plain message. - */ - function test_WordWrap() { - - $this->Mail->WordWrap = 40; - $my_body = "Here is the main body of this message. It should " . - "be quite a few lines. It should be wrapped at the " . - "40 characters. Make sure that it is."; - $nBodyLen = strlen($my_body); - $my_body .= "\n\nThis is the above body length: " . $nBodyLen; - - $this->Mail->Body = $my_body; - $this->Mail->Subject .= ": Wordwrap"; - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Try a plain message. - */ - function test_Low_Priority() { - - $this->Mail->Priority = 5; - $this->Mail->Body = "Here is the main body. There should be " . - "a reply to address in this message."; - $this->Mail->Subject .= ": Low Priority"; - $this->Mail->AddReplyTo("nobody@nobody.com", "Nobody (Unit Test)"); - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Simple plain file attachment test. - */ - function test_Multiple_Plain_FileAttachment() { - - $this->Mail->Body = "Here is the text body"; - $this->Mail->Subject .= ": Plain + Multiple FileAttachments"; - - if(!$this->Mail->AddAttachment("rocks.png")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - if(!$this->Mail->AddAttachment("phpmailer_test.php", "test.txt")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Simple plain string attachment test. - */ - function test_Plain_StringAttachment() { - - $this->Mail->Body = "Here is the text body"; - $this->Mail->Subject .= ": Plain + StringAttachment"; - - $sAttachment = "These characters are the content of the " . - "string attachment.\nThis might be taken from a ". - "database or some other such thing. "; - - $this->Mail->AddStringAttachment($sAttachment, "string_attach.txt"); - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Plain quoted-printable message. - */ - function test_Quoted_Printable() { - - $this->Mail->Body = "Here is the main body"; - $this->Mail->Subject .= ": Plain + Quoted-printable"; - $this->Mail->Encoding = "quoted-printable"; - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Try a plain message. - */ - function test_Html() { - - $this->Mail->IsHTML(true); - $this->Mail->Subject .= ": HTML only"; - - $this->Mail->Body = "This is a test message written in HTML.
    " . - "Go to " . - "http://phpmailer.sourceforge.net/ for new versions of " . - "phpmailer.

    Thank you!"; - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Simple HTML and attachment test - */ - function test_HTML_Attachment() { - - $this->Mail->Body = "This is the HTML part of the email."; - $this->Mail->Subject .= ": HTML + Attachment"; - $this->Mail->IsHTML(true); - - if(!$this->Mail->AddAttachment("phpmailer_test.php", "test_attach.txt")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * An embedded attachment test. - */ - function test_Embedded_Image() { - - $this->Mail->Body = "Embedded Image: \"phpmailer\"" . - "Here is an image!"; - $this->Mail->Subject .= ": Embedded Image"; - $this->Mail->IsHTML(true); - - if(!$this->Mail->AddEmbeddedImage("rocks.png", "my-attach", "rocks.png", - "base64", "image/png")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * An embedded attachment test. - */ - function test_Multi_Embedded_Image() { - - $this->Mail->Body = "Embedded Image: \"phpmailer\"" . - "Here is an image!"; - $this->Mail->Subject .= ": Embedded Image + Attachment"; - $this->Mail->IsHTML(true); - - if(!$this->Mail->AddEmbeddedImage("rocks.png", "my-attach", "rocks.png", - "base64", "image/png")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - if(!$this->Mail->AddAttachment("phpmailer_test.php", "test.txt")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Simple multipart/alternative test. - */ - function test_AltBody() { - - $this->Mail->Body = "This is the HTML part of the email."; - $this->Mail->AltBody = "Here is the text body of this message. " . - "It should be quite a few lines. It should be wrapped at the " . - "40 characters. Make sure that it is."; - $this->Mail->WordWrap = 40; - $this->AddNote("This is a mulipart alternative email"); - $this->Mail->Subject .= ": AltBody + Word Wrap"; - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - /** - * Simple HTML and attachment test - */ - function test_AltBody_Attachment() { - - $this->Mail->Body = "This is the HTML part of the email."; - $this->Mail->AltBody = "This is the text part of the email."; - $this->Mail->Subject .= ": AltBody + Attachment"; - $this->Mail->IsHTML(true); - - if(!$this->Mail->AddAttachment("phpmailer_test.php", "test_attach.txt")) - { - $this->assert(false, $this->Mail->ErrorInfo); - return; - } - - $this->BuildBody(); - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - - $fp = fopen("message.txt", "w"); - fwrite($fp, $this->Mail->CreateHeader() . $this->Mail->CreateBody()); - fclose($fp); - } - - function test_MultipleSend() { - $this->Mail->Body = "Sending two messages without keepalive"; - $this->BuildBody(); - $subject = $this->Mail->Subject; - - $this->Mail->Subject = $subject . ": SMTP 1"; - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - - $this->Mail->Subject = $subject . ": SMTP 2"; - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - } - - function test_SmtpKeepAlive() { - $this->Mail->Body = "This was done using the SMTP keep-alive."; - $this->BuildBody(); - $subject = $this->Mail->Subject; - - $this->Mail->SMTPKeepAlive = true; - $this->Mail->Subject = $subject . ": SMTP keep-alive 1"; - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - - $this->Mail->Subject = $subject . ": SMTP keep-alive 2"; - $this->assert($this->Mail->Send(), $this->Mail->ErrorInfo); - $this->Mail->SmtpClose(); - } - - function test_Error() { - $this->BuildBody(); - $this->Mail->Subject .= ": This should not be sent"; - $this->Mail->ClearAllRecipients(); // no addresses should cause an error - $this->assert($this->Mail->IsError() == false, "Error found"); - $this->assert($this->Mail->Send() == false, "Send succeeded"); - $this->assert($this->Mail->IsError(), "No error found"); - $this->assertEquals('You must provide at least one ' . - 'recipient email address.', $this->Mail->ErrorInfo); - } -} - -/** - * Create and run test instance. - */ - -if(isset($HTTP_GET_VARS)) - $global_vars = $HTTP_GET_VARS; -else - $global_vars = $_REQUEST; - -if(isset($global_vars["submitted"])) -{ - echo "Test results:
    "; - $suite = new TestSuite( "phpmailerTest" ); - - $testRunner = new TestRunner; - $testRunner->run($suite); - echo "


    "; -} - -function get($sName) { - global $global_vars; - if(isset($global_vars[$sName])) - return $global_vars[$sName]; - else - return ""; -} - -?> - - - -

    phpmailer Unit Test

    -By entering a SMTP hostname it will automatically perform tests with SMTP. - -
    - -To Address: "/> -
    -Cc Address: "/> -
    -SMTP Hostname: "/> -

    - - -

    - - diff --git a/Class/test/phpunit.php b/Class/test/phpunit.php deleted file mode 100644 index 45b1bf0..0000000 --- a/Class/test/phpunit.php +++ /dev/null @@ -1,376 +0,0 @@ - -// OntoSys, Inc -// -// $Id: phpunit.php,v 1.1 2002/03/30 19:32:17 bmatzelle Exp $ - -// Copyright (c) 2000 Fred Yankowski - -// Permission is hereby granted, free of charge, to any person -// obtaining a copy of this software and associated documentation -// files (the "Software"), to deal in the Software without -// restriction, including without limitation the rights to use, copy, -// modify, merge, publish, distribute, sublicense, and/or sell copies -// of the Software, and to permit persons to whom the Software is -// furnished to do so, subject to the following conditions: -// -// The above copyright notice and this permission notice shall be -// included in all copies or substantial portions of the Software. -// -// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS -// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN -// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -// SOFTWARE. -// -/*error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE | - E_CORE_ERROR | E_CORE_WARNING);*/ - -/* -interface Test { - function run(&$aTestResult); - function countTestCases(); -} -*/ - -function trace($msg) { - return; - print($msg); - flush(); -} - - -/*class Exception { - /* Emulate a Java exception, sort of... */ - /*var $message; - function Exception($message) { - $this->message = $message; - } - function getMessage() { - return $this->message; - } -}*/ - -class Assert { - function assert($boolean, $message=0) { - if (! $boolean) - $this->fail($message); - } - - function assertEquals($expected, $actual, $message=0) { - if ($expected != $actual) { - $this->failNotEquals($expected, $actual, "expected", $message); - } - } - - function assertRegexp($regexp, $actual, $message=false) { - if (! preg_match($regexp, $actual)) { - $this->failNotEquals($regexp, $actual, "pattern", $message); - } - } - - function failNotEquals($expected, $actual, $expected_label, $message=0) { - // Private function for reporting failure to match. - $str = $message ? ($message . ' ') : ''; - $str .= "($expected_label/actual)
    "; - $htmlExpected = htmlspecialchars($expected); - $htmlActual = htmlspecialchars($actual); - $str .= sprintf("
    %s\n--------\n%s
    ", - $htmlExpected, $htmlActual); - $this->fail($str); - } -} - -class TestCase extends Assert /* implements Test */ { - /* Defines context for running tests. Specific context -- such as - instance variables, global variables, global state -- is defined - by creating a subclass that specializes the setUp() and - tearDown() methods. A specific test is defined by a subclass - that specializes the runTest() method. */ - var $fName; - var $fResult; - var $fExceptions = array(); - - function TestCase($name) { - $this->fName = $name; - } - - function run($testResult=0) { - /* Run this single test, by calling the run() method of the - TestResult object which will in turn call the runBare() method - of this object. That complication allows the TestResult object - to do various kinds of progress reporting as it invokes each - test. Create/obtain a TestResult object if none was passed in. - Note that if a TestResult object was passed in, it must be by - reference. */ - if (! $testResult) - $testResult = $this->_createResult(); - $this->fResult = $testResult; - $testResult->run(&$this); - $this->fResult = 0; - return $testResult; - } - - function countTestCases() { - return 1; - } - - function runTest() { - $name = $this->name(); - // Since isset($this->$name) is false, no way to run defensive checks - $this->$name(); - } - - function setUp() /* expect override */ { - //print("TestCase::setUp()
    \n"); - } - - function tearDown() /* possible override */ { - //print("TestCase::tearDown()
    \n"); - } - - //////////////////////////////////////////////////////////////// - - - function _createResult() /* protected */ { - /* override this to use specialized subclass of TestResult */ - return new TestResult; - } - - function fail($message=0) { - //printf("TestCase::fail(%s)
    \n", ($message) ? $message : ''); - /* JUnit throws AssertionFailedError here. We just record the - failure and carry on */ - $this->fExceptions[] = new Exception(&$message); - } - - function error($message) { - /* report error that requires correction in the test script - itself, or (heaven forbid) in this testing infrastructure */ - printf('ERROR: ' . $message . '
    '); - $this->fResult->stop(); - } - - function failed() { - return count($this->fExceptions); - } - - function getExceptions() { - return $this->fExceptions; - } - - function name() { - return $this->fName; - } - - function runBare() { - $this->setup(); - $this->runTest(); - $this->tearDown(); - } -} - - -class TestSuite /* implements Test */ { - /* Compose a set of Tests (instances of TestCase or TestSuite), and - run them all. */ - var $fTests = array(); - - function TestSuite($classname=false) { - if ($classname) { - // Find all methods of the given class whose name starts with - // "test" and add them to the test suite. We are just _barely_ - // able to do this with PHP's limited introspection... Note - // that PHP seems to store method names in lower case, and we - // have to avoid the constructor function for the TestCase class - // superclass. This will fail when $classname starts with - // "Test" since that will have a constructor method that will - // get matched below and then treated (incorrectly) as a test - // method. So don't name any TestCase subclasses as "Test..."! - if (floor(phpversion()) >= 4) { - // PHP4 introspection, submitted by Dylan Kuhn - $names = get_class_methods($classname); - while (list($key, $method) = each($names)) { - if (preg_match('/^test/', $method) && $method != "testcase") { - $this->addTest(new $classname($method)); - } - } - } - else { - $dummy = new $classname("dummy"); - $names = (array) $dummy; - while (list($key, $value) = each($names)) { - $type = gettype($value); - if ($type == "user function" && preg_match('/^test/', $key) - && $key != "testcase") { - $this->addTest(new $classname($key)); - } - } - } - } - } - - function addTest($test) { - /* Add TestCase or TestSuite to this TestSuite */ - $this->fTests[] = $test; - } - - function run(&$testResult) { - /* Run all TestCases and TestSuites comprising this TestSuite, - accumulating results in the given TestResult object. */ - reset($this->fTests); - while (list($na, $test) = each($this->fTests)) { - if ($testResult->shouldStop()) - break; - $test->run(&$testResult); - } - } - - function countTestCases() { - /* Number of TestCases comprising this TestSuite (including those - in any constituent TestSuites) */ - $count = 0; - reset($fTests); - while (list($na, $test_case) = each($this->fTests)) { - $count += $test_case->countTestCases(); - } - return $count; - } -} - - -class TestFailure { - /* Record failure of a single TestCase, associating it with the - exception(s) that occurred */ - var $fFailedTestName; - var $fExceptions; - - function TestFailure(&$test, &$exceptions) { - $this->fFailedTestName = $test->name(); - $this->fExceptions = $exceptions; - } - - function getExceptions() { - return $this->fExceptions; - } - function getTestName() { - return $this->fFailedTestName; - } -} - - -class TestResult { - /* Collect the results of running a set of TestCases. */ - var $fFailures = array(); - var $fRunTests = 0; - var $fStop = false; - - function TestResult() { } - - function _endTest($test) /* protected */ { - /* specialize this for end-of-test action, such as progress - reports */ - } - - function getFailures() { - return $this->fFailures; - } - - function run($test) { - /* Run a single TestCase in the context of this TestResult */ - $this->_startTest($test); - $this->fRunTests++; - - $test->runBare(); - - /* this is where JUnit would catch AssertionFailedError */ - $exceptions = $test->getExceptions(); - if ($exceptions) - $this->fFailures[] = new TestFailure(&$test, &$exceptions); - $this->_endTest($test); - } - - function countTests() { - return $this->fRunTests; - } - - function shouldStop() { - return $this->fStop; - } - - function _startTest($test) /* protected */ { - /* specialize this for start-of-test actions */ - } - - function stop() { - /* set indication that the test sequence should halt */ - $fStop = true; - } - - function countFailures() { - return count($this->fFailures); - } -} - - -class TextTestResult extends TestResult { - /* Specialize TestResult to produce text/html report */ - function TextTestResult() { - $this->TestResult(); // call superclass constructor - } - - function report() { - /* report result of test run */ - $nRun = $this->countTests(); - $nFailures = $this->countFailures(); - printf("

    %s test%s run
    ", $nRun, ($nRun == 1) ? '' : 's'); - printf("%s failure%s.
    \n", $nFailures, ($nFailures == 1) ? '' : 's'); - if ($nFailures == 0) - return; - - print("

      \n"); - $failures = $this->getFailures(); - while (list($i, $failure) = each($failures)) { - $failedTestName = $failure->getTestName(); - printf("
    1. %s\n", $failedTestName); - - $exceptions = $failure->getExceptions(); - print("
        "); - while (list($na, $exception) = each($exceptions)) - printf("
      • %s\n", $exception->getMessage()); - print("
      "); - } - print("
    \n"); - } - - function _startTest($test) { - printf("%s ", $test->name()); - flush(); - } - - function _endTest($test) { - $outcome = $test->failed() - ? "FAIL" - : "ok"; - printf("$outcome
    \n"); - flush(); - } -} - - -class TestRunner { - /* Run a suite of tests and report results. */ - function run($suite) { - $result = new TextTestResult; - $suite->run($result); - $result->report(); - } -} - -?> diff --git a/Class/test/rocks.png b/Class/test/rocks.png deleted file mode 100644 index f1ad755..0000000 --- a/Class/test/rocks.png +++ /dev/null @@ -1 +0,0 @@ -‰PNG diff --git a/pages/lancer_flotte.php b/DELlancer_flotte.php similarity index 60% rename from pages/lancer_flotte.php rename to DELlancer_flotte.php index fb00a73..1935006 100644 --- a/pages/lancer_flotte.php +++ b/DELlancer_flotte.php @@ -1,21 +1,11 @@ Création * */ -$template->set_filenames(array('flotte' => 'flotte2.tpl')); +$template->set_filenames(array('contenu' => 'flotte2.tpl')); $_SESSION['FL_time'] = time(); $ACTIONSUPP =''; @@ -27,8 +17,9 @@ for ($i=1 ; $i<=12 ; $i++) { $_SESSION['FL_vaisseau'.$i] = $_POST['vaisseau'.$i]; $nombreVaisseau += $_POST['vaisseau'.$i]; } - if ($i == 5 && $_POST['vaisseau'.$i] >= 1) $ACTIONSUPP .= ''; - if ($i == 3 && $_POST['vaisseau'.$i] >= 1) $ACTIONSUPP .= ''; + if ($i == 5 && $_POST['vaisseau'.$i] >= 1) $ACTIONSUPP .= ''; + if ($i == 4 && $_POST['vaisseau'.$i] >= 1) $ACTIONSUPP .= ''; + if ($i == 3 && $_POST['vaisseau'.$i] >= 1) $ACTIONSUPP .= ''; } // On vérifie que l'utilisateur ait bien envoyé au moins un vaisseau @@ -69,17 +60,5 @@ $template->assign_vars(array('ACTIONSUPP' => $ACTIONSUPP, 'GALAXIE' => $galaxy, * */ -require('../connectBDD.php'); -$result = mysql_query("SELECT * FROM version ORDER BY temps DESC"); -$data = mysql_fetch_array($result); -$version = $data['version']; -mysql_close(); - -$template->set_filenames(array('base' => 'base.tpl')); -$template->assign_vars(array('PUB' => $PUB, 'VERSION' => $version, 'RES_IMAGE' => $RES_IMAGE, 'NOM_METAL' => strtolower($NOM_METAL), 'NOM_CRISTAL' => strtolower($NOM_CRISTAL), 'NOM_HYDROGENE' => strtolower($NOM_HYDROGENE), 'NOM_ENERGIE' => strtolower($NOM_ENERGIE), 'RES_METAL' => $RES_METAL, 'RES_CRISTAL' => $RES_CRISTAL, 'RES_HYDROGENE' => $RES_HYDROGENE, 'RES_ENERGIE' => $RES_ENERGIE, 'DATEHEURET' => date('/dm/ H:i'), 'COUNTHUMAINS' => '7500', 'COUNTCOVENANTS' => '4500', 'PSEUDO' => $pseudo)); -for ($i=0 ; $iassign_block_vars('planetes',array('RES_VALUE' => $Aplan_value[$i], 'RES_MORE' => $Aplan_more[$i], 'RES_IMG' => $Aplan_img[$i], 'RES_NOM' => $Aplan_nom[$i], 'RES_REF' => $Aplan_ref[$i])); -} -$template->assign_var_from_handle('CONTENU', 'flotte'); -$template->pparse('base'); +include('includes/footer.php'); ?> \ No newline at end of file diff --git a/Halo-Battle.PHPEditProject b/Halo-Battle.PHPEditProject deleted file mode 100644 index 3f0fa49..0000000 --- a/Halo-Battle.PHPEditProject +++ /dev/null @@ -1,3 +0,0 @@ - - - diff --git a/ab/sound.php b/ab/sound.php deleted file mode 100644 index 97fa504..0000000 --- a/ab/sound.php +++ /dev/null @@ -1,128 +0,0 @@ -nombre = $nombre.'r'.$nombre; - $strlen = strlen($this->nombre); - - $binary = ''; // Contiendra les donnees, juste les donnees. - - for($i = 0; $i < $strlen; $i++) - { - $binary .= $this->get_datas('../'.$this->nombre{$i}.'.wav'); - } - - $this->package($binary); - } - } - - public function analyse($wav,$arg = FALSE) - { - if(file_exists('../'.$wav)) - { - - $entete_unpack = 'a4file_type/Lfile_size/a4file_id/A4nom_zone1/Ltaille_zone1/SFormatTag/SChannels/LSamplesPerSec/LAvgBytesPerSec/SBlockAlign/SBitsPerSample/A4nom_data/Ltaille_data'; - - $fp = fopen('../'.$wav,'r'); - $file = fread($fp, 44 ); - - $entete = unpack($entete_unpack,$file); - fclose($fp); - - - if( ($entete['file_type'] !== chr(0x52).chr(0x49).chr(0x46).chr(0x46) ) OR ( $entete['file_id'] !== chr(0x57).chr(0x41).chr(0x56).chr(0x45) ) ) - { - trigger_error('Le fichier '.$wav.' n\'est pas un fichier wav',E_USER_ERROR); - } - - if(!$arg) - return $entete; - else - return $entete[$arg]; - } - else - { - - trigger_error('fonction analyse, le fichier '.$wav.' est neccessaire mais manquant', E_USER_ERROR); - return FALSE; - } - - } - - - private function get_datas($wav) - { - if(file_exists('../'.$wav)) - { - $fp = fopen('../'.$wav,'r'); - fseek($fp, 44 ); - - $datas = fread($fp, $this->analyse($wav, 'taille_data')); - - fclose($fp); - - return $datas; - } - else - { - trigger_error('fonction analyse, le fichier '.$wav.' est neccessaire mais manquant', E_USER_ERROR); - return FALSE; - } - } - - private function package($datas) - { - $entete_pack = 'a4La4A4LSSLLSSA4L'; - - $entete = $this->analyse('../'.$this->nombre{0}.'.wav'); - - for($i = 1;$inombre); $i ++) - { - $entete2 = $this->analyse('../'.$this->nombre{$i}.'.wav'); - if($entete !== $entete2) - { - if($entete['Channels'] !== $entete2['Channels']) - { - trigger_error('fonction package, un ou plusieurs fichiers wad n\'ont pas le même nombre de canaux',E_USER_ERROR); - } - - if($entete['BitsPerSample'] !== $entete2['BitsPerSample']) - { - trigger_error('fonction package, un ou plusieurs fichiers wad, n\'on pas le même nombres d\'échantillons par seconde', E_USER_ERROR); - } - - if($entete['SamplesPerSec'] !== $entete2['SamplesPerSec']) - { - trigger_error('fonction package, un ou plusieurs fichiers wad, n\'ont pas la même fréquence d\'échantillonage', E_USER_WARNING); - } - } - } - - /* On calcule la taille des donnees que l'on à creer selon la formule de soundeditor */ - $entete['taille_data'] = strlen($datas); - $entete['taille_data'] /= $entete['BlockAlign']; - $entete['taille_data'] *= $entete['BlockAlign']; - - $entete['file_size'] = 44 + strlen($datas); - - /* on "pack l entete et on y ajoute les donnees */ - $binary = pack($entete_pack, $entete['file_type'],$entete['file_size'],$entete['file_id'],$entete['nom_zone1'], - $entete['taille_zone1'],$entete['FormatTag'],$entete['Channels'],$entete['SamplesPerSec'],$entete['AvgBytesPerSec'], - $entete['BlockAlign'],$entete['BitsPerSample'],$entete['nom_data'],$entete['taille_data']); - $binary .= $datas; - - /* On transmet ou enregistre */ - header('Content-type: audio/x-wav'); - header('Content-Disposition: attachment; filename="code.wav"'); - echo $binary; - } - } - -$wav = new wave($_SESSION['aleat_nbr']); -?> \ No newline at end of file diff --git a/ab/un.ttf b/ab/un.ttf deleted file mode 100644 index 8fea13f..0000000 Binary files a/ab/un.ttf and /dev/null differ diff --git a/ab/wave/1.WAV b/ab/wave/1.WAV deleted file mode 100644 index 5e51a36..0000000 Binary files a/ab/wave/1.WAV and /dev/null differ diff --git a/ab/wave/2.WAV b/ab/wave/2.WAV deleted file mode 100644 index c2a3d6c..0000000 Binary files a/ab/wave/2.WAV and /dev/null differ diff --git a/ab/wave/3.WAV b/ab/wave/3.WAV deleted file mode 100644 index 7ea8460..0000000 Binary files a/ab/wave/3.WAV and /dev/null differ diff --git a/ab/wave/4.WAV b/ab/wave/4.WAV deleted file mode 100644 index a998fed..0000000 Binary files a/ab/wave/4.WAV and /dev/null differ diff --git a/ab/wave/5.wav b/ab/wave/5.wav deleted file mode 100644 index e2eb7e0..0000000 Binary files a/ab/wave/5.wav and /dev/null differ diff --git a/ab/wave/6.WAV b/ab/wave/6.WAV deleted file mode 100644 index d3a4ac1..0000000 Binary files a/ab/wave/6.WAV and /dev/null differ diff --git a/ab/wave/7.WAV b/ab/wave/7.WAV deleted file mode 100644 index a45eeb6..0000000 Binary files a/ab/wave/7.WAV and /dev/null differ diff --git a/ab/wave/8.WAV b/ab/wave/8.WAV deleted file mode 100644 index 76552e8..0000000 Binary files a/ab/wave/8.WAV and /dev/null differ diff --git a/ab/wave/9.WAV b/ab/wave/9.WAV deleted file mode 100644 index 6b9465b..0000000 Binary files a/ab/wave/9.WAV and /dev/null differ diff --git a/ab/wave/A.WAV b/ab/wave/A.WAV deleted file mode 100644 index 0b01dea..0000000 Binary files a/ab/wave/A.WAV and /dev/null differ diff --git a/ab/wave/B.WAV b/ab/wave/B.WAV deleted file mode 100644 index f4f3303..0000000 Binary files a/ab/wave/B.WAV and /dev/null differ diff --git a/ab/wave/C.WAV b/ab/wave/C.WAV deleted file mode 100644 index f51fcdc..0000000 Binary files a/ab/wave/C.WAV and /dev/null differ diff --git a/ab/wave/D.WAV b/ab/wave/D.WAV deleted file mode 100644 index 5892583..0000000 Binary files a/ab/wave/D.WAV and /dev/null differ diff --git a/ab/wave/E.WAV b/ab/wave/E.WAV deleted file mode 100644 index a0554e8..0000000 Binary files a/ab/wave/E.WAV and /dev/null differ diff --git a/ab/wave/F.WAV b/ab/wave/F.WAV deleted file mode 100644 index ce53a20..0000000 Binary files a/ab/wave/F.WAV and /dev/null differ diff --git a/ab/wave/G.WAV b/ab/wave/G.WAV deleted file mode 100644 index 785a247..0000000 Binary files a/ab/wave/G.WAV and /dev/null differ diff --git a/ab/wave/H.WAV b/ab/wave/H.WAV deleted file mode 100644 index 1663c7f..0000000 Binary files a/ab/wave/H.WAV and /dev/null differ diff --git a/ab/wave/I.WAV b/ab/wave/I.WAV deleted file mode 100644 index 149466d..0000000 Binary files a/ab/wave/I.WAV and /dev/null differ diff --git a/ab/wave/J.WAV b/ab/wave/J.WAV deleted file mode 100644 index 060e880..0000000 Binary files a/ab/wave/J.WAV and /dev/null differ diff --git a/ab/wave/K.WAV b/ab/wave/K.WAV deleted file mode 100644 index d436f42..0000000 Binary files a/ab/wave/K.WAV and /dev/null differ diff --git a/ab/wave/L.WAV b/ab/wave/L.WAV deleted file mode 100644 index c7c9b2a..0000000 Binary files a/ab/wave/L.WAV and /dev/null differ diff --git a/ab/wave/M.WAV b/ab/wave/M.WAV deleted file mode 100644 index dc7cc38..0000000 Binary files a/ab/wave/M.WAV and /dev/null differ diff --git a/ab/wave/N.WAV b/ab/wave/N.WAV deleted file mode 100644 index a302f0b..0000000 Binary files a/ab/wave/N.WAV and /dev/null differ diff --git a/ab/wave/O.WAV b/ab/wave/O.WAV deleted file mode 100644 index 1e6a0fb..0000000 Binary files a/ab/wave/O.WAV and /dev/null differ diff --git a/ab/wave/P.WAV b/ab/wave/P.WAV deleted file mode 100644 index 11dd155..0000000 Binary files a/ab/wave/P.WAV and /dev/null differ diff --git a/ab/wave/Q.WAV b/ab/wave/Q.WAV deleted file mode 100644 index ff71a43..0000000 Binary files a/ab/wave/Q.WAV and /dev/null differ diff --git a/ab/wave/R.WAV b/ab/wave/R.WAV deleted file mode 100644 index 02e430c..0000000 Binary files a/ab/wave/R.WAV and /dev/null differ diff --git a/ab/wave/S.WAV b/ab/wave/S.WAV deleted file mode 100644 index 1a25ba5..0000000 Binary files a/ab/wave/S.WAV and /dev/null differ diff --git a/ab/wave/T.WAV b/ab/wave/T.WAV deleted file mode 100644 index fc455eb..0000000 Binary files a/ab/wave/T.WAV and /dev/null differ diff --git a/ab/wave/U.WAV b/ab/wave/U.WAV deleted file mode 100644 index 4274e5e..0000000 Binary files a/ab/wave/U.WAV and /dev/null differ diff --git a/ab/wave/V.WAV b/ab/wave/V.WAV deleted file mode 100644 index b023b12..0000000 Binary files a/ab/wave/V.WAV and /dev/null differ diff --git a/ab/wave/W.WAV b/ab/wave/W.WAV deleted file mode 100644 index 526aa7a..0000000 Binary files a/ab/wave/W.WAV and /dev/null differ diff --git a/ab/wave/X.WAV b/ab/wave/X.WAV deleted file mode 100644 index 7732137..0000000 Binary files a/ab/wave/X.WAV and /dev/null differ diff --git a/ab/wave/Y.WAV b/ab/wave/Y.WAV deleted file mode 100644 index 6970acd..0000000 Binary files a/ab/wave/Y.WAV and /dev/null differ diff --git a/ab/wave/Z.WAV b/ab/wave/Z.WAV deleted file mode 100644 index a850310..0000000 Binary files a/ab/wave/Z.WAV and /dev/null differ diff --git a/admin.php b/admin.php new file mode 100644 index 0000000..6e092d7 --- /dev/null +++ b/admin.php @@ -0,0 +1,42 @@ +values['connected']) && $sess->values['connected'] && !empty($sess->values['id']) && isset($sess->values['auth_level']) && $sess->values['auth_level'] >= 3 && !empty($sess->values['idPlan'])) { + //Connexion à la base de données + $chapeau = new bdd(); + $chapeau->connexion(); + $chapeau->db(); + + //Passage des valeurs générales au template + $template->assign('version', VERSION); + $template->assign('page','admin'); + + $table = $config['db_prefix'].'user_inscriptions'; + $chapeau->unique_query("SELECT * FROM `$table` WHERE `race` = 'covenant'"); + $nbcovie = $chapeau->num_rows; + $table = $config['db_prefix'].'user_inscriptions'; + $chapeau->unique_query("SELECT * FROM `$table` WHERE `race` = 'humain'"); + $nbhumain = $chapeau->num_rows; + $template->assign('count',array('humains' => $nbhumain, 'covenants' => $nbcovie, 'serveurs' => 'cette')); + + $id_user = $sess->values['id']; + $table = $config['db_prefix'].'user'; + $queryUser = $chapeau->unique_query("SELECT * FROM `$table` WHERE `id` = '$id_user'"); + $race = $queryUser['race']; + $template->assign('race',$queryUser['race']); + //$template->assign('race','covenant'); + $template->assign('user',$queryUser); + $tpsdejeu = time() - $queryUser['last_visite']; + $heur = floor($tpsdejeu/3600); + $min = floor(($tpsdejeu - $heur*3600)/60); + if ($heur > 0) $min = $heur.' h '.$min; + $template->assign('tpsdejeu',$min.' min'); + + $pagea = 'vp'; + + $template->display('admin/'.$pagea.'.tpl'); +} +else header('Location: index.php'); +?> \ No newline at end of file diff --git a/ajax_flotte.php b/ajax_flotte.php new file mode 100644 index 0000000..5e41907 --- /dev/null +++ b/ajax_flotte.php @@ -0,0 +1,194 @@ +values['connected']) && $sess->values['connected'] && !empty($sess->values['id']) && isset($sess->values['auth_level']) && !empty($sess->values['idPlan'])) { + $json = new Services_JSON(); + + $chapeau = new bdd(); + $chapeau->connexion(); + $chapeau->db(); + $table = $config['db_prefix'].'planete'; + $idPlan = $sess->values['idPlan']; + $queryPlanete = $chapeau->unique_query("SELECT * FROM `$table` WHERE `id` = '$idPlan'"); + $start_galaxie = $queryPlanete['galaxie']; + $start_ss = $queryPlanete['ss']; + $start_position = $queryPlanete['position']; + + if (empty($sess->values['fltime']) || $sess->values['fltime'] + 600 < time() || empty($sess->values['flnbvais']) || empty($sess->values['flvitesse']) && isset($sess->values['auth_level'])) + $datas = array( + 'root' => array( + 'temps' => '-', + 'deblok' => 'Une erreur est survenue lors de la création de la flotte. Veuillez recommencer', + 'conso' => '-', + 'tactique' => '' + ) + ); + elseif (empty($_POST['nom']) || preg_replace('@[^a-zA-Z0-9_ ]@i', '', $_POST['nom']) != $_POST['nom']) + $datas = array( + 'root' => array( + 'temps' => '-', + 'deblok' => 'Nom de la flotte incorrect !', + 'conso' => '-', + 'tactique' => '' + ) + ); + elseif ($_POST['galaxie'] > MAX_AMAS || $_POST['ss'] > MAX_SYSTEME || $_POST['pos'] > MAX_PLANETE || $_POST['galaxie'] < 0 || $_POST['ss'] < 1 || $_POST['pos'] < 1 || ($_POST['galaxie'] < 1 && $sess->values['auth_level'] < 6)) + $datas = array( + 'root' => array( + 'temps' => 'Lieu inaccessible', + 'deblok' => 'Corrigez la destination !', + 'conso' => '-', + 'tactique' => '' + ) + ); + else { + $_POST['vitesse'] /= 100; + $temps = vais_tempsDeplacement($start_galaxie,$start_ss,$start_position,$_POST['galaxie'],$_POST['ss'],$_POST['pos'],$sess->values['flvitesse'],$_POST['vitesse'],$sess->values['flpreparation'],$sess->values['flchauffe']); + if ($temps <= 0) $temps = 454; + $conso = vais_conso($temps, $sess->values['flnbvais'])*($_POST['vitesse']*10); + $tactique = ''; + if ($_POST['mission'] == '1') { + $tactique = ' utiliser la tactique : '; + } + $cds = sha1('flotte'.$conso.'ß10'.time().'|HB;'.rand(10,99).$temps); + $sess->values['flcds'] = $cds; + $sess->put(); + $datas = array( + 'root' => array( + 'temps' => affTemp(floor($temps)), + 'deblok' => '', + 'conso' => separerNombres(ceil($conso*($_POST['vitesse']/100)*2)), + 'tactique' => $tactique + ) + ); + } + + $chapeau->deconnexion(); + header("X-JSON: ".$json->encode($datas)); +} +exit; + $json = new Services_JSON(); + + if (!isset($sess->values['fltime']) || $sess->values['fltime'] + 600 < time() || !isset($sess->values['flnbvais']) || !isset($sess->values['flvitesse']) || !isset($_POST['galaxie']) || !isset($_POST['ss']) || !isset($_POST['pos']) || !isset($_POST['vitesse']) || !is_numeric($_POST['galaxie']) || !is_numeric($_POST['ss']) || !is_numeric($_POST['pos']) || !is_numeric($_POST['vitesse'])) { + $datas = array( + 'root' => array( + 'temps' => '-', + 'deblok' => 'Complètez les champs ci-dessus', + 'conso' => '-', + 'tactique' => '' + ) + ); + } + elseif ($_POST['galaxie'] > 1 || $_POST['ss'] > 100 || $_POST['pos'] > 12 || $_POST['galaxie'] < 0 || $_POST['ss'] < 1 || $_POST['pos'] < 1 || ($_POST['galaxie'] < 1 && $auth_level < 6)) { + $datas = array( + 'root' => array( + 'temps' => 'Lieu inaccessible', + 'deblok' => 'Corrigez la destination !', + 'conso' => '-', + 'tactique' => '' + ) + ); + } + else { + $_POST['vitesse'] /= 100; + $temps = vais_tempsDeplacement($start_galaxie,$start_ss,$start_position,$_POST['galaxie'],$_POST['ss'],$_POST['pos'],$sess->values['flvitesse'],$_POST['vitesse'],$sess->values['flpreparation'],$sess->values['flchauffe']); + $conso = vais_conso($temps, $sess->values['FL_nbvais'])*($_POST['vitesse']*10); + + //On recherche si la flotte va faire un aller-retour ou un aller simple + if (isset($_POST['mission']) && is_numeric($_POST['mission']) && ($_POST['mission'] == '3')) $nbtrajet = 1; + else $nbtrajet = 2; + + if ($temps <= 0) $temps = 454; + if (preg_replace('@[^a-zA-Z0-9_ ]@i', '', $_POST['nom']) != $_POST['nom'] || empty($_POST['nom'])) + $datas = array( + 'root' => array( + 'temps' => affTemp(floor($temps)), + 'deblok' => 'Nom de la flotte incorrect !', + 'conso' => separerNombres(ceil($conso*($_POST['vitesse']/100)*$nbtrajet)), + 'tactique' => '' + ) + ); + /*elseif (empty($_POST['hyd']) || $_POST['hyd'] < $conso * 2) + $datas = array( + 'root' => array( + 'temps' => affTemp(floor($temps)), + 'deblok' => 'Vous n\'avez pas embarqué assez d\'hydrogène pour faire l\'aller-retour !', + 'conso' => separerNombres(floor($conso*($_POST['vitesse']/100)*$nbtrajet)) + ) + );*/ + else { + $tactique = ''; + $cds = sha1('flotte'.$conso.'ß10'.time().'|HB;'.rand(10,99).$temps); + $sess->values['flottecdsL'] = $cds; + if ($id == '46') setHistorique('Rapport Frederic PREP','Génération code : SESSION : '.$sess->values['flottecdsL'].' - cds : '.$cds); + if ($_POST['mission'] == '1') { + $tactique = ' :: utiliser la tactique : '; + } + $datas = array( + 'root' => array( + 'temps' => affTemp(floor($temps)), + 'deblok' => '', + 'conso' => separerNombres(ceil($conso*($_POST['vitesse']/100)*$nbtrajet)), + 'tactique' => $tactique + ) + ); + } + } + + $chapeau->deconnexion(); + header("X-JSON: ".$json->encode($datas)); +?> \ No newline at end of file diff --git a/b_index.php b/b_index.php deleted file mode 100644 index 1243fea..0000000 --- a/b_index.php +++ /dev/null @@ -1,37 +0,0 @@ -'; -elseif(!isset($_GET['v'])){ - if (isset($_SESSION['cdsconnect'])) { - $_SESSION['cdsconnect'] = null; - header('Location: index.php?erreur=6'); - exit; - } - $_SESSION['cdsconnect'] = rand(1234567890,9876543210)*rand(1234567890,98765432100)/rand(123567890,9876543210); - if ($_SESSION['race'] == 'humain' || $_SESSION['race'] == 'covenant') echo ''; - else echo ''; - echo ''; -} - -if(($_SESSION['race'] == 'humain' || $_SESSION['race'] == 'covenant') && ($_GET['v'] == sha1(time() + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 1 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 2 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 3 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 4 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 5 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 6 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 7 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 8 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 9 + $_SESSION['cdsconnect']) || $_GET['v'] == sha1(time() - 10 + $_SESSION['cdsconnect'])) && isset($_SESSION['charg']) && $_SESSION['charg'] == 1) { -$_SESSION['cdsconnect'] = null; -$_SESSION['authConnexion'] = true; -echo ' - - - - Halo-Battle - - - - - -'; -} -elseif(!isset($_SESSION['charg']) || $_SESSION['charg'] != 1) echo ''; -else echo ''; -?> \ No newline at end of file diff --git a/captcha/.htaccess b/captcha/.htaccess new file mode 100644 index 0000000..f2bc67f --- /dev/null +++ b/captcha/.htaccess @@ -0,0 +1,6 @@ +RewriteEngine on +RewriteRule ^accueil.html$ index.php [L] +php_flag register_globals Off +php_flag magic_quotes_gpc Off +php_flag magic_quotes_runtime Off +php_flag magic_quotes_sybase Off \ No newline at end of file diff --git a/ab/0.TTF b/captcha/0.TTF similarity index 100% rename from ab/0.TTF rename to captcha/0.TTF diff --git a/ab/1.TTF b/captcha/1.TTF similarity index 100% rename from ab/1.TTF rename to captcha/1.TTF diff --git a/ab/2.TTF b/captcha/2.TTF similarity index 100% rename from ab/2.TTF rename to captcha/2.TTF diff --git a/ab/fond_verif_img.gif b/captcha/fond_verif_img.gif similarity index 100% rename from ab/fond_verif_img.gif rename to captcha/fond_verif_img.gif diff --git a/ab/fond_verif_img.png b/captcha/fond_verif_img.png similarity index 100% rename from ab/fond_verif_img.png rename to captcha/fond_verif_img.png diff --git a/ab/ab.php b/captcha/image.php similarity index 91% rename from ab/ab.php rename to captcha/image.php index 51e8ded..bb0217f 100644 --- a/ab/ab.php +++ b/captcha/image.php @@ -1,6 +1,7 @@ values['aleatnbr'] = strtolower($nombre); +$sess->put(); + // On détruit les variables inutiles : unset($chiffre); unset($i); @@ -63,7 +67,7 @@ unset($chiffres); $fontfile = './2.TTF'; //imagestring($_img, 5, 18, 8, $nombre, $avant_plan); -if ($fontfile == '0.TTF') ImageTTFText($_img, 18, 2, 0, 23, $avant_plan, $fontfile, strtoupper($nombre)); +if ($fontfile == './0.TTF') ImageTTFText($_img, 18, 2, 0, 23, $avant_plan, $fontfile, strtoupper($nombre)); else ImageTTFText($_img, 18.5, 2, rand(0,6), 23, $avant_plan, $fontfile, $nombre); imagepng($_img); diff --git a/connectBDD.php b/connectBDD.php deleted file mode 100644 index bece8d0..0000000 --- a/connectBDD.php +++ /dev/null @@ -1,43 +0,0 @@ - \ No newline at end of file diff --git a/cron/classement.php b/cron/classement.php index db2e12e..7396e1b 100644 --- a/cron/classement.php +++ b/cron/classement.php @@ -1,17 +1,147 @@ connexion(); +$chapeau->db(); mysql_query("TRUNCATE TABLE `classement`"); -$req = mysql_query("SELECT id, pseudo, race FROM user"); $resultat = mysql_fetch_array($req); -while ($res = mysql_fetch_assoc($req)) { - $pts_rech = CalculPointRecherche($res['id']); - $pts_flotte = CalculPointflotte($res['id']); - $pts_bat = CalculPointBatiment($res['id']); - $pts_tt = $pts_rech + $pts_flotte + $pts_bat; +$sql_1 = mysql_query("SELECT `id`, `pseudo`, `race` FROM `user`"); +while($recup_id = mysql_fetch_array($sql_1)) { + + $id = $recup_id['id']; + $PSEUDO_USER = $recup_id['pseudo']; + $race = $recup_id['race']; + + $planete = mysql_query("SELECT `id`, `mine_m`, `mine_c`, `mine_h`, `centrale_s`, `centrale_f`, `radar`, `labo`, `chantier_terrestre`, `chantier_spatial`, `caserne`, `silo`, `centre_info`, `vaisseau_1`, `vaisseau_2`, `vaisseau_3`, `vaisseau_4`, `vaisseau_5`, `vaisseau_6`, `vaisseau_7`, `vaisseau_8`, `vaisseau_9`, `vaisseau_10`, `vaisseau_11`, `vaisseau_12`, `def_1`, `def_2`, `def_3`, `def_4`, `def_5` FROM `planete` WHERE `id_user` = " . $id)or die( mysql_error() ); + while ($donnees_planete = mysql_fetch_array($planete)) { + + // partie pts batiements ressources + $POINTS_BATIMENTS += batiment1($donnees_planete['mine_m'] ) + batiment2( $donnees_planete['mine_c'] ) + batiment3( $donnees_planete['mine_h'] ) + batiment4( $donnees_planete['centrale_s'] ) + batiment5( $donnees_planete['centrale_f'] ) + batiment6( $donnees_planete['radar'] ) + batiment7( $donnees_planete['labo'] ) + batiment8( $donnees_planete['chantier_terrestre'] ) + batiment9( $donnees_planete['chantier_spatial'] ) /* + batiment10( $donnees_planete['caserne'] )*/ + batiment11( $donnees_planete['silo'] ) + batiment11( $donnees_planete['centre_info'] ); + + // partie pts def ressources + + $metal_d += 500 * $donnees_planete['def_1']; + $cristal_d += 200 * $donnees_planete['def_1']; + + $metal_d += 4000 * $donnees_planete['def_2']; + $cristal_d += 2000 * $donnees_planete['def_2']; + + $metal_d += 4500 * $donnees_planete['def_3']; + $cristal_d += 800 * $donnees_planete['def_3']; + $hydrogene_d += 600 * $donnees_planete['def_3']; + + $metal_d += 12000 * $donnees_planete['def_4']; + $cristal_d += 10000 * $donnees_planete['def_4']; + $hydrogene_d += 1000 * $donnees_planete['def_4']; + + $metal_d += 15000 * $donnees_planete['def_5']; + $cristal_d += 9500 * $donnees_planete['def_5']; + $hydrogene_d += 1500 * $donnees_planete['def_5']; + + // partie pts vaiseaux + + $POINTS_VAISSEAUX += $donnees_planete['vaisseau_1'] + $donnees_planete['vaisseau_2'] + $donnees_planete['vaisseau_3'] + $donnees_planete['vaisseau_4'] + $donnees_planete['vaisseau_5'] + $donnees_planete['vaisseau_6'] + $donnees_planete['vaisseau_7'] + $donnees_planete['vaisseau_8'] + $donnees_planete['vaisseau_9'] + $donnees_planete['vaisseau_10'] + $donnees_planete['vaisseau_11']+ $donnees_planete['vaisseau_12']; + + // partie pts vaiseaux ressources + + // 'cargos de classe Parabola', 1 + $metal += ( $donnees_planete['vaisseau_1'] * 1000 ); + $cristal += ( $donnees_planete['vaisseau_1'] * 800 ); + + // 'cargos de classe Laden', 2 + $metal += ( $donnees_planete['vaisseau_2'] * 4000 ); + $cristal += ( $donnees_planete['vaisseau_2'] * 3000 ); + + // 'vaisseau(X) de colonisation de classe Odyssey', 3 + $metal += ( $donnees_planete['vaisseau_3'] * 9000 ); + $cristal += ( $donnees_planete['vaisseau_3'] * 9000 ); + $hydrogene += ( $donnees_planete['vaisseau_3'] * 1000 ); + + // 'drone(s) d\'espionnage de classe Clarion', 4 + $metal += ( $donnees_planete['vaisseau_4'] * 1000) ; + $cristal += ( $donnees_planete['vaisseau_4'] * 1200 ); + $hydrogene += ( $donnees_planete['vaisseau_4'] * 100 ); + + // 'recycleur(s) de classe Minotaur', 5 + $metal += ( $donnees_planete['vaisseau_5'] * 15000 ); + $cristal += ( $donnees_planete['vaisseau_5'] * 9000 ); + $hydrogene += ( $donnees_planete['vaisseau_5'] * 1000 ); + + // 'C709 Longsword Interceptor', 6 + $metal += ( $donnees_planete['vaisseau_6'] * 1700 ); + $cristal += ( $donnees_planete['vaisseau_6'] * 1220 ); + + // 'Frégates', 7 + $metal += ( $donnees_planete['vaisseau_7'] * 5800 ); + $cristal += ( $donnees_planete['vaisseau_7'] * 1400 ); + + // 'croiseur(s) de classe Halcyon', 8 + $metal += ( $donnees_planete['vaisseau_8'] * 20000 ); + $cristal += ( $donnees_planete['vaisseau_8'] * 16000 ); + $hydrogene += ( $donnees_planete['vaisseau_8'] * 1600 ); + + // 'croiseur(s) de classe Marathon', 9 + $metal += ( $donnees_planete['vaisseau_9'] * 26000 ); + $cristal += ( $donnees_planete['vaisseau_9'] * 16400 ); + $hydrogene += ( $donnees_planete['vaisseau_9'] * 1600 ); + + // 'porte vaisseaux', 10 + $metal += ( $donnees_planete['vaisseau_10'] * 60000 ); + $cristal += ( $donnees_planete['vaisseau_10'] * 40000 ); + $hydrogene += ( $nb_vaisseaux['vaisseau_10'] * 3000 ); + + $METAL_VAISSEAUX = $metal; + $CRISTAL_VAISSEAUX = $cristal; + $HYDROGENE_VAISSEAUX = $hydrogene; + $RESSOURCES_VAISSEAUX = $METAL_VAISSEAUX + $CRISTAL_VAISSEAUX + $HYDROGENE_VAISSEAUX; + + + } // boucle planetes --> + + // partie pts techno + $techno_db = mysql_query("SELECT `informatique`, `detection`, `armement`, `energie_t`, `reacteur`, `reacteur_f`, `reacteur_ff`, `medecine`, `tactique`, `spartan`, `blindage` FROM `user` WHERE `id` = ".$id)or die(mysql_error()); + while ($techno = mysql_fetch_array($techno_db)) { + + $POINTS_TECHNO = $techno['informatique'] + $techno['detection'] + $techno['armement'] + $techno['energie_t'] + $techno['reacteur'] + $techno['reacteur_f'] + $techno['reacteur_ff'] + $techno['medecine'] + $techno['tactique'] + $techno['spartan'] + $techno['blindage']; + + // partie pts techno ressources + $RESSOURCES_TECHNO = techno1( $techno['informatique'] ) + techno2( $techno['detection'] ) + techno3( $techno['armement'] ) + techno4( $techno['energie_t'] ) + techno5( $techno['reacteur'] ) + techno6( $techno['reacteur_f'] ) + techno7( $techno['reacteur_ff'] ) + techno8( $techno['medecine'] ) + techno9( $techno['tactique'] ) + techno10( $techno['spartan'] ) + techno11( $techno['blindage'] ); + } + + $PT_RESSOURCES = ( $RESSOURCES_VAISSEAUX + $RESSOURCES_TECHNO + $POINTS_BATIMENTS ) / 1000; + $POINTS_BATIMENTS = $POINTS_BATIMENTS / 1000; + + // points flottes terrestres recherches batiments + mysql_query("INSERT INTO `classement` VALUES (NULL, '$PSEUDO_USER', '$race', '$PT_RESSOURCES', '$POINTS_VAISSEAUX', '0', '$POINTS_TECHNO', '$POINTS_BATIMENTS')") or die (mysql_error()); + mysql_query("UPDATE `user` SET `flotte` = '" . $POINTS_VAISSEAUX . "', `recherches` = '" . $POINTS_TECHNO . "', `batiments` = '" . $POINTS_BATIMENTS . "', `points` = '" . $PT_RESSOURCES . "' WHERE `pseudo` = '" . $PSEUDO_USER . "'") or die (mysql_error()); + + $metal = 0; + $cristal = 0; + $hydrogene = 0; + $POINTS_VAISSEAUX = 0; + $POINTS_TECHNO = 0; + $PT_RESSOURCES = 0; + $METAL_VAISSEAUX = 0; + $CRISTAL_VAISSEAUX = 0; + $HYDROGENE_VAISSEAUX = 0; + $RESSOURCES_VAISSEAUX = 0; + $POINTS_BATIMENTS = 0; - mysql_query("INSERT INTO `classement` (`pseudo`,`race`,`points`,`flottes`,`recherches`,`batiments`) VALUES ('".$res['pseudo']."', '".$res['race']."', '$pts_tt', '$pts_flotte', '$pts_rech', '$pts_bat');"); } -mysql_close(); +$sql_2 = mysql_query("SELECT * FROM `classement` ORDER BY `classement`.`points` DESC") or die(mysql_error()); +$i=0; +while($resultat = mysql_fetch_array($sql_2)) { + $i++; + $nomuser = $resultat['pseudo']; + mysql_query("UPDATE `user` SET `place_points` = '$i' WHERE `pseudo` = '$nomuser'") or die (mysql_error()); +} + +$chapeau->deconnexion(); ?> \ No newline at end of file diff --git a/cron/optimize.php b/cron/optimize.php new file mode 100644 index 0000000..6244540 --- /dev/null +++ b/cron/optimize.php @@ -0,0 +1,22 @@ +connexion(); +$chapeau->db(); + +mysql_query("OPTIMIZE TABLE `flottes`; +OPTIMIZE TABLE `flottes`; +OPTIMIZE TABLE `flottes_combats`; +OPTIMIZE TABLE `mail`; +OPTIMIZE TABLE `planete`; +OPTIMIZE TABLE `sessions`; +TRUNCATE TABLE `registre_identification`; +TRUNCATE TABLE `securite_identification`; +"); + +$chapeau->deconnexion(); +?> \ No newline at end of file diff --git a/favicon.ico b/favicon.ico index 75dd35a..da2fd69 100644 Binary files a/favicon.ico and b/favicon.ico differ diff --git a/fonctions.php b/fonctions.php deleted file mode 100644 index fe92771..0000000 --- a/fonctions.php +++ /dev/null @@ -1,225 +0,0 @@ - $capacite) { - if ($capacite/3 > $metal && $capacite/3 > $cristal && $capacite/3 > $hydrogene) { - - } - } - else { - $ressources['metal'] = $metal; - $ressources['cristal'] = $cristal; - $ressources['hydrogene'] = $hydrogene; - } -} - -function txtmission($mission){ - if ($mission == 0) return 'Stationner'; - elseif ($mission == 1) return 'Attaquer'; - elseif ($mission == 2) return 'Transporter'; - elseif ($mission == 3) return 'Coloniser'; - elseif ($mission == 4) return 'Recycler'; - elseif ($mission == 5) return 'Espionner'; - else return 'Erreur'; -} - -function trouvNom($id_user){ - $req = mysql_query("SELECT pseudo FROM user WHERE `id` = '$id_user'"); - $resultat = mysql_fetch_array($req); - return $resultat['pseudo']; -} - -function trouvInfo($id_user, $info){ - $req = mysql_query("SELECT $info FROM user WHERE `id` = '$id_user'"); - $resultat = mysql_fetch_array($req); - return $resultat[$info]; -} - -function separerNombres($nombre) { - return number_format($nombre, 0, ',', ' '); -} - -function bbcode($text) { - $text = htmlentities($text); - - $text = nl2br($text); - - $text = str_replace("[b]", "", $text); - $text = str_replace("[/b]", "", $text); - - $text = str_replace("[u]", "", $text); - $text = str_replace("[/u]", "", $text); - - $text = str_replace("[i]", "", $text); - $text = str_replace("[/i]", "", $text); - - $text = str_replace("[center]", "
    ", $text); - $text = str_replace("[/center]", "
    ", $text); - - $text = str_replace(" ", "  ", $text); - - $patterns = array(); - $replacements = array(); - - $patterns[] = "#\[img\](.*?)\[/img\]#si"; - $replacements[] = ""; - - $patterns[] = "#\[quote=(.*?)\](.*?)\[/quote\]#si"; - $replacements[] = "
          \\1 à dit :
    \\2
    "; - - $patterns[] = "#\[color=(.*?)\](.*?)\[/color\]#si"; - $replacements[] = "\\2"; - - $patterns[] = "#\[quote\](.*?)\[/quote\]#si"; - $replacements[] = "
    \\1
    "; - - $patterns[] = "#\[url\]([a-z0-9]+?://){1}([\w\-]+\.([\w\-]+\.)*[\w]+(:[0-9]+)?(/[^ \"\n\r\t<]*)?)\[/url\]#is"; - $replacements[] = "\1\2"; - - $patterns[] = "#\[url\]((www|ftp)\.([\w\-]+\.)*[\w]+(:[0-9]+)?(/[^ \"\n\r\t<]*?)?)\[/url\]#si"; - $replacements[] = "\\1"; - - $patterns[] = "#\[url=([a-z0-9]+://)([\w\-]+\.([\w\-]+\.)*[\w]+(:[0-9]+)?(/[^ \"\n\r\t<]*?)?)\](.*?)\[/url\]#si"; - $replacements[] = "\\6"; - - $patterns[] = "#\[url=(([\w\-]+\.)*?[\w]+(:[0-9]+)?(/[^ \"\n\r\t<]*)?)\](.*?)\[/url\]#si"; - $replacements[] = "\\5"; - - $patterns[] = "#\[email\]([a-z0-9\-_.]+?@[\w\-]+\.([\w\-\.]+\.)?[\w]+)\[/email\]#si"; - $replacements[] = "\\1"; - - return preg_replace($patterns, $replacements, $text); -} - - -function CalculPointBatiment($id){ - - $query = mysql_query("SELECT user.id ,pseudo, ceil( ( - (ceil(exp(0.4*(SUM( mine_m ) ))*190)+ceil(exp(0.4*(SUM( mine_m ) ))*90) ) + (ceil(exp(0.43*(SUM( mine_c ) ))*205)+ceil(exp(0.43*(SUM( mine_c ) ))*110)) + (ceil(exp(0.445*(SUM( mine_h ) ))*235)+ceil(exp(0.445*(SUM( mine_h ) ))*150) ) + (ceil(exp(0.442*(SUM( centrale_s ) ))*165)+ceil(exp(0.442*(SUM( centrale_s ) ))*99) ) + ( ceil(pow(1.8,(SUM( centrale_f ) ))*300)+ceil(pow(1.82,(SUM( centrale_f ) ))*230)) + (ceil(pow(2,(SUM( radar)))*750)+ceil(pow(2,(SUM( radar)))*500)+ceil(pow(2,(SUM( radar)))*50)) + (ceil(pow(2,(SUM( labo)))*200)+ceil(pow(2,(SUM( labo)))*150)) + (ceil(pow(2,(SUM(chantier_terrestre)))*520)+ceil(pow(2,(SUM(chantier_terrestre)))*380)) + (ceil(pow(2,(SUM(chantier_spatial)))*600)+ceil(pow(2,(SUM(chantier_spatial)))*450)) + (ceil(pow(2,(SUM(caserne)))*200)+ceil(pow(2,(SUM(caserne)))*100)) + (ceil(pow(2,(SUM(silo)))*400)+ceil(pow(2,(SUM(silo)))*260))+ (ceil(pow(1.7,(SUM(centre_info)))*600)+ceil(pow(1.7,(SUM(centre_info)))*420)+ceil(pow(1.7,(SUM(centre_info)))*100)) )/100000 - ) AS points_bui - FROM user,planete - WHERE id_user=$id - GROUP BY user.id - ORDER BY points_bui DESC"); - - $resultat = mysql_fetch_array($query); - return $resultat['points_bui']; -} - -function CalculPointRecherche($id){ - - $query = mysql_query("SELECT user.id ,pseudo, ( - SUM( informatique ) + SUM( detection ) + SUM( armement ) + SUM( energie_t ) + SUM( reacteur ) + SUM( reacteur_f ) + SUM( reacteur_ff ) + SUM( medecine ) + SUM( tactique ) + SUM( spartan ) + SUM( blindage ) - ) AS points_res - FROM user,planete - WHERE id_user=$id - GROUP BY user.id - ORDER BY points_res DESC"); - - $resultat = mysql_fetch_array($query); - return $resultat['points_res']; -} - -function CalculPointflotte($id){ - - $query = mysql_query("SELECT id_user ,user.pseudo, user.id, ( - SUM(soldat1 ) + SUM( soldat2 ) + SUM( soldat3 ) + SUM( soldat4 ) + SUM( sniper ) + SUM( spartam ) + SUM( medecin ) + SUM( ingenieur) + SUM( soldat_lourd ) + SUM( vaisseau_1 ) + SUM( vaisseau_2 ) + SUM( vaisseau_3 ) + SUM( vaisseau_4 ) + SUM(vaisseau_4 ) + SUM(vaisseau_6 ) + SUM( vaisseau_7 ) + SUM( vaisseau_8) + SUM( vaisseau_9 ) + SUM( vaisseau_10 ) + SUM( vaisseau_11 ) + SUM( vaisseau_12 ) + SUM(vais_0 ) + SUM(vais_1 ) + SUM( vais_2 ) + SUM( vais_3) + SUM( vcl_1 ) + SUM( vcl_2 ) + SUM( vcl_3 ) + SUM( vcl_4) - ) AS points_flt - FROM user,planete - WHERE id_user=$id - GROUP BY id_user - ORDER BY points_flt DESC"); - - $resultat = mysql_fetch_array($query); - return $resultat['points_flt']; -} - - -function CalculPointGene($id){ - -$query = mysql_query("SELECT user.id ,pseudo, ceil( ( - (ceil(exp(0.4*(SUM( mine_m ) ))*190)+ceil(exp(0.4*(SUM( mine_m ) ))*90) ) + (ceil(exp(0.43*(SUM( mine_c ) ))*205)+ceil(exp(0.43*(SUM( mine_c ) ))*110)) + (ceil(exp(0.445*(SUM( mine_h ) ))*235)+ceil(exp(0.445*(SUM( mine_h ) ))*150) ) + (ceil(exp(0.442*(SUM( centrale_s ) ))*165)+ceil(exp(0.442*(SUM( centrale_s ) ))*99) ) + ( ceil(pow(1.8,(SUM( centrale_f ) ))*300)+ceil(pow(1.82,(SUM( centrale_f ) ))*230)) + (ceil(pow(2,(SUM( radar)))*750)+ceil(pow(2,(SUM( radar)))*500)+ceil(pow(2,(SUM( radar)))*50)) + (ceil(pow(2,(SUM( labo)))*200)+ceil(pow(2,(SUM( labo)))*150)) + (ceil(pow(2,(SUM(chantier_terrestre)))*520)+ceil(pow(2,(SUM(chantier_terrestre)))*380)) + (ceil(pow(2,(SUM(chantier_spatial)))*600)+ceil(pow(2,(SUM(chantier_spatial)))*450)) + (ceil(pow(2,(SUM(caserne)))*200)+ceil(pow(2,(SUM(caserne)))*100)) + (ceil(pow(2,(SUM(silo)))*400)+ceil(pow(2,(SUM(silo)))*260))+ (ceil(pow(1.7,(SUM(centre_info)))*600)+ceil(pow(1.7,(SUM(centre_info)))*420)+ceil(pow(1.7,(SUM(centre_info)))*100)) )/100000 - ) + - (SUM(soldat1 ) + SUM( soldat2 ) + SUM( soldat3 ) + SUM( soldat4 ) + SUM( sniper ) + SUM( spartam ) + SUM( medecin ) + SUM( ingenieur) + SUM( soldat_lourd ) + SUM( vaisseau_1 ) + SUM( vaisseau_2 ) + SUM( vaisseau_3 ) + SUM( vaisseau_4 ) + SUM(vaisseau_4 ) + SUM(vaisseau_6 ) + SUM( vaisseau_7 ) + SUM( vaisseau_8) + SUM( vaisseau_9 ) + SUM( vaisseau_10 ) + SUM( vaisseau_11 ) + SUM( vaisseau_12 ) + SUM(vais_0 ) + SUM(vais_1 ) + SUM( vais_2 ) + SUM( vais_3) + SUM( vcl_1 ) + SUM( vcl_2 ) + SUM( vcl_3 ) + SUM( vcl_4) - ) + -( - SUM( informatique ) + SUM( detection ) + SUM( armement ) + SUM( energie_t ) + SUM( reacteur ) + SUM( reacteur_f ) + SUM( reacteur_ff ) + SUM( medecine ) + SUM( tactique ) + SUM( spartan ) + SUM( blindage ) -) AS points_pts - - FROM user,planete - WHERE id_user=user.id AND planete.id_user=$id - GROUP BY user.id - ORDER BY points_pts DESC"); - - $resultat = mysql_fetch_array($query); - return $resultat['points_pts']; -} - -function pillage($metal, $cristal, $hydrogene, $vfm){ - $Qm = $metal / $vfm; - $Qc = $cristal / $vfm; - $Qh = $hydrogene / $vfm; - - $somme = $Qm + $Qc + $Qh; - - if ($somme < 2) { - $Fm = $metal / 2; - $Fc = $cristal / 2; - $Fh = $hydrogene / 2; - } - else { - $Fm = $Qm / $somme * $vfm; - $Fc = $Qc / $somme * $vfm; - $Fh = $Qh / $somme * $vfm; - } - - return array(floor($Fm), floor($Fc), floor($Fh)); -} - -function affTemp($secondes){ - $heures = intval($secondes/3600); - $minutes = intval($secondes/60-($heures*60)); - if ($minutes < 10) $minutes = '0'.$minutes; - $seconde = $secondes-($heures*3600)-($minutes*60); - if ($seconde < 10) $seconde = '0'.$seconde; - - return $heures.':'.$minutes.':'.$seconde; -} - -function dateFR($date){ - $date = str_replace('Sun','Dim',$date); - $date = str_replace('Mon','Lun',$date); - $date = str_replace('Tue','Mar',$date); - $date = str_replace('Wed','Mer',$date); - $date = str_replace('Thu','Jeu',$date); - $date = str_replace('Fri','Ven',$date); - $date = str_replace('Sat','Sam',$date); - - return $date; -} -?> \ No newline at end of file diff --git a/game/accueil.php b/game/accueil.php new file mode 100644 index 0000000..4483981 --- /dev/null +++ b/game/accueil.php @@ -0,0 +1,36 @@ +unique_query("SELECT COUNT(*) AS nbre FROM `$table` WHERE `destinataire` = '$pseudo' AND `vu` = '1';"); +$template->assign('mail',$queryMail); + +$req = mysql_query("SELECT `galaxie`,`ss`,`position`,`nom_planete` FROM `planete` WHERE `id_user` = '$id_user'"); +$attaquesRadar = array(); +while ($resultat = mysql_fetch_array($req)) { + $end_galaxie = $resultat['galaxie']; + $end_ss = $resultat['ss']; + $end_position = $resultat['position']; + $reqf = mysql_query("SELECT * FROM flottes WHERE `mission` = '1' AND end_galaxie='$end_galaxie' AND end_ss='$end_ss' AND end_position='$end_position'"); + while ($resultatf = mysql_fetch_array($reqf)) { + $start_galaxie = $resultatf['start_galaxie']; + $start_ss = $resultatf['start_ss']; + $start_position = $resultatf['start_position']; + if ($resultatf['start_time'] + $resultatf['end_time'] < time() + $queryUser['detection']*1800) { + $reqp = mysql_query("SELECT nom_planete FROM planete WHERE galaxie='$start_galaxie' AND ss='$start_ss' AND position='$start_position'"); + $resultatp = mysql_fetch_array($reqp); + $attaquesRadar[] = array($resultatp['nom_planete'],affTemp($resultatf['start_time']+$resultatf['end_time']-time()),$resultatf['start_galaxie'],$resultatf['start_ss'],$resultatf['start_position'],$resultat['nom_planete'],$resultatf['end_galaxie'],$resultatf['end_ss'],$resultatf['end_position'],$resultatf['start_time']+$resultatf['end_time']-time()); + } + } +} + +$diametre = separerNombres($queryPlanete['cases'] * 92); +$Classpoints = separerNombres($queryUser['points']); + +$template->assign('attaques',$attaquesRadar); +$template->assign('diametre',$diametre); +$template->assign('points',$Classpoints); +?> \ No newline at end of file diff --git a/game/alliances.php b/game/alliances.php new file mode 100644 index 0000000..819cecc --- /dev/null +++ b/game/alliances.php @@ -0,0 +1,388 @@ +unique_query("SELECT * FROM `$table_alliances` WHERE `id` = '".$queryUser['id_alliance']."';"); + + //On détermine les accès du joueur + if ($alliance['fondateur'] == $queryUser['id']) + $access = array( + 'fondateur' => 1, + 'chat' => 1, + 'grades' => 1, + 'membre' => 1, + 'ecriture' => 1, + 'alliance' => 1 + ); + elseif ($queryUser['id_grade_alliance'] != 0) { + $grade = $chapeau->unique_query("SELECT * FROM `$table_alliances_grade` WHERE `id` = '".$queryUser['id_grade_alliance']."';"); + $access = array( + 'fondateur' => 0, + 'chat' => $grade['gest_chat'], + 'grades' => $grade['gest_rang'], + 'membre' => $grade['gest_membre'], + 'ecriture' => $grade['gest_ecriture'], + 'alliance' => $grade['gest_admin'] + ); + } + else + $access = array( + 'fondateur' => 0, + 'chat' => 0, + 'grades' => 0, + 'membre' => 0, + 'ecriture' => 0, + 'alliance' => 0 + ); + $template->assign('access', $access); + + //Visionnage des pages de l'alliance + if (!isset($_GET['q'])) $_GET['q'] = ''; + //Pages d'administration + if ($_GET['q'] == 'adm_chat' && $access['chat']) { + if (!empty($_GET['i'])) { + $i = floor($_GET['i']); + $chapeau->query("DELETE FROM `$table_alliances_chat` WHERE `id` = '$i' AND `id_alliance` = '".$alliance['id']."';"); + header('Location: ?p=alliances&q=adm_chat#chat'); + exit; + } + $page = 'alliance_adm_chat'; + $chat = $chapeau->query("SELECT * FROM `$table_alliances_chat` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `id` DESC LIMIT 50;"); + for($i = 0; $i < $chapeau->num_rows ; $i++){ + $chat[$i]['emetteur'] = trouvNom($chat[$i]['emetteur']); + } + $template->assign('chat', $chat); + + } + elseif ($_GET['q'] == 'adm_grades' && $access['membre']) { + if (isset($_GET['a']) && $_GET['a'] = 'add') { + if (!empty($_POST['nom']) && isset($_POST['description'])) { + $nom = mysql_real_escape_string($_POST['nom']); + $description = mysql_real_escape_string($_POST['description']); + + @$chapeau->query("INSERT INTO `$table_alliances_grade` VALUES (NULL, '".$alliance['id']."', '$nom', '$description', '".ceil($_POST['gest_chat'])."', '".ceil($_POST['gest_rang'])."', '".ceil($_POST['gest_membre'])."', '".ceil($_POST['gest_ecriture'])."', '".ceil($_POST['gest_alliance'])."');"); + header('Location: ?p=alliances&q=adm_grades'); + exit; + } + $page = 'alliance_adm_grades_add'; + } + else { + $page = 'alliance_adm_grades'; + $grades = $chapeau->query("SELECT * FROM `$table_alliances_grade` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `nom` ASC;"); + $template->assign('grades', $grades); + } + } + elseif ($_GET['q'] == 'adm_ecrits' && $access['ecriture']) { + if (isset($_GET['t']) && $_GET['t'] == 'presentation') $mod = 'presentation'; + else $mod = 'interne'; + if (!empty($_POST['type']) && isset($_POST['textarea'])) { + $mod = mysql_real_escape_string($_POST['type']); + $chapeau->query("UPDATE `$table_alliances` SET `$mod` = '".mysql_real_escape_string($_POST['textarea'])."' WHERE `id` = '".$alliance['id']."'"); + header('Location: ?p=alliances&q=adm_ecrits&t='.$mod); + exit; + } + $page = 'alliance_adm_ecritures'; + $template->assign('alliance', $alliance); + $template->assign('mod', $mod); + } + elseif ($_GET['q'] == 'adm_alliance' && $access['alliance']) { + $recharg = false; + if (isset($_POST['defcon']) && isset($_POST['defcon_txt']) && isset($_POST['etat_inscription']) && isset($_POST['image']) && isset($_POST['url'])) { + $chapeau->query("UPDATE `$table_alliances` SET `defcon` = '".mysql_real_escape_string($_POST['defcon'])."', `defcon_txt` = '".mysql_real_escape_string($_POST['defcon_txt'])."', `etat_inscription` = '".mysql_real_escape_string($_POST['etat_inscription'])."', `image` = '".mysql_real_escape_string($_POST['image'])."', `url` = '".mysql_real_escape_string($_POST['url'])."' WHERE `id` = '".$alliance['id']."'"); + $recharg = true; + } + if (isset($_POST['fondateur']) && $alliance['fondateur'] == $id_user && isset($_POST['pswd_admin'])) { + if (!empty($_POST['pswd_admin']) && $queryUser['mdp'] == sha1(strtoupper($queryUser['pseudo']).':'.$_POST['pswd_admin']) && empty($sess->values['forcealli'])) { + $sess->values['forcealli'] = true; + $sess->put(); + $template->assign('message','Êtes-vous sûr de vouloir dissoudre cette alliance ?
    Pour confirmer la dissolution de l\'alliance, rechargez cette page.'); + $template->assign('couleur','orange'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (!empty($_POST['pswd_admin']) && $queryUser['mdp'] == sha1(strtoupper($queryUser['pseudo']).':'.$_POST['pswd_admin']) && isset($sess->values['forcealli']) && $sess->values['forcealli']) { + $chapeau->query("DELETE FROM `$table_alliances` WHERE `id` = '".$alliance['id']."';"); + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + for($i = 0; $i < $chapeau->num_rows; $i++){ + $chapeau->query("UPDATE `$table_user` SET `id_alliance` = '0', `id_grade_alliance` = '0' WHERE `id` = '".$membres[$i]['id']."' AND `id_alliance` = '".$alliance['id']."';"); + } + $template->assign('message','L\'alliance a été dissoute avec succès.'); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (!empty($_POST['pswd_admin']) && $queryUser['mdp'] != sha1(strtoupper($queryUser['pseudo']).':'.$_POST['pswd_admin'])) { + $template->assign('message','Impossible de dissoudre l\'alliance : mot de passe incorrect.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + $chapeau->query("UPDATE `$table_alliances` SET `fondateur` = '".mysql_real_escape_string($_POST['fondateur'])."' WHERE `id` = '".$alliance['id']."'"); + $recharg = true; + } + if ($recharg) { + header('Location: ?p=alliances&q=adm_alliance'); + exit; + } + $page = 'alliance_adm_admin'; + $niveaux = array('Niveau 1', 'Niveau 2', 'Niveau 3', 'Niveau 4', 'Niveau 5'); + $niveauxi = array('1', '2', '3', '4', '5'); + $template->assign('niveaux', $niveaux); + $template->assign('niveauxi', $niveauxi); + $etatinscript = array('Ouvertes', 'Fermées'); + $etatinscripti = array('1', '0'); + $template->assign('etatinscript', $etatinscript); + $template->assign('etatinscripti', $etatinscripti); + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + $membre = array(); + $membrei = array(); + for($i = 0; $i < $chapeau->num_rows; $i++){ + $membre[] = $membres[$i]['pseudo']; + $membrei[] = $membres[$i]['id']; + } + $template->assign('membres', $membre); + $template->assign('membresi', $membrei); + $template->assign('alliance', $alliance); + } + elseif ($_GET['q'] == 'adm_membres' && $access['membre']) { + if (!empty($_POST['user']) && isset($_POST['grade'])) { + $user = floor($_POST['user']); + $grade = floor($_POST['grade']); + $chapeau->query("UPDATE `$table_user` SET `id_grade_alliance` = '".$grade."' WHERE `id` = '".$user."' AND `id_alliance` = '".$alliance['id']."';"); + } + elseif (!empty($_GET['u'])) { + $user = floor($_GET['u']); + $chapeau->query("UPDATE `$table_user` SET `id_grade_alliance` = '0', `id_alliance` = '0' WHERE `id` = '".$user."' AND `id_alliance` = '".$alliance['id']."';"); +//TODO Envoyer un message au joueur renvoyé + } + elseif (!empty($_GET['accept'])) { + $user = floor($_GET['accept']); + $verif = $chapeau->unique_query("SELECT * FROM `$table_alliances_attente` WHERE `id_alliance` = '".$alliance['id']."' AND `id_membre` = '$user';"); + if ($verif) { + $chapeau->query("UPDATE `$table_user` SET `id_grade_alliance` = '0', `id_alliance` = '".$alliance['id']."' WHERE `id` = '".$user."' AND `id_alliance` = '0';"); + $chapeau->query("DELETE FROM `$table_alliances_attente` WHERE `id_membre` = '$user';"); +//TODO Envoyer un message au joueur renvoyé + } + } + elseif (!empty($_GET['refus'])) { + $user = floor($_GET['refus']); + $chapeau->query("DELETE FROM `$table_alliances_attente` WHERE `id_membre` = '$user' AND `id_alliance` = '".$alliance['id']."';"); +//TODO Envoyer un message au joueur renvoyé + } + $page = 'alliance_adm_membres'; + $grades = $chapeau->query("SELECT * FROM `$table_alliances_grade` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `nom` ASC;"); + $grade = array(); $gradei = array(); + for($i = 0; $i < $chapeau->num_rows ; $i++){ + $grade[] = $grades[$i]['nom']; + $gradei[] = $grades[$i]['id']; + } + $template->assign('grades', $grade); + $template->assign('gradei', $gradei); + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + $template->assign('membres', $membres); + $candidats = $chapeau->query("SELECT * FROM `$table_alliances_attente` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `timestamp` ASC;"); + $template->assign('candidats', $candidats); + $template->assign('alliance', $alliance); + } + elseif ($_GET['q'] == 'liste') { + $page = 'alliance_liste'; + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + $template->assign('membres', $membres); + } + elseif ($_GET['q'] == 'chat') { + if (isset($_POST['msg'])) { + $message = mysql_real_escape_string($_POST['msg']); + if (!empty($message)) $chapeau->query("INSERT INTO `$table_alliances_chat` VALUES (NULL, '".$alliance['id']."', '$id_user', '".time()."', '$message')"); + header('Location: ?p=alliances&q=chat#chat'); + exit; + } + $page = 'alliance_chat'; + //Chat + $chat = $chapeau->query("SELECT * FROM `$table_alliances_chat` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `id` DESC LIMIT 30"); + for($i = 0; $i < $chapeau->num_rows ; $i++){ + $chat[$i]['emetteur'] = trouvNom($chat[$i]['emetteur']); + } + $template->assign('chat', $chat); + } + else { + $page = 'alliance_accueil'; + $template->assign('alliance', $alliance); + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + $template->assign('nbmembre', $chapeau->num_rows); + if (!isset($grade)) $template->assign('grade', 0); + else $template->assign('grade', $grade); + + //Chat + $chat = $chapeau->query("SELECT * FROM `$table_alliances_chat` WHERE `id_alliance` = '".$alliance['id']."' ORDER BY `id` DESC LIMIT 30"); + for($i = 0; $i < $chapeau->num_rows ; $i++){ + $chat[$i]['emetteur'] = trouvNom($chat[$i]['emetteur']); + } + $template->assign('chat', $chat); + } +} +//Si le joueur n'est membre d'aucune alliance +else { + if (!isset($_GET['q'])) $_GET['q'] = ''; + if ($_GET['q'] == 'search' && !empty($_POST['by']) && isset($_POST['search'])) { + $page = 'alliance_nm_search'; + + $by = mysql_real_escape_string($_POST['by']); + $search = mysql_real_escape_string($_POST['search']); + + $recherche = $chapeau->query("SELECT * FROM `$table_alliances` WHERE `$by` LIKE '%$search%' ORDER BY `nom` ASC"); + $template->assign('recherches', $recherche); + } + elseif ($_GET['q'] == 'liste' && !empty($_GET['i'])) { + $page = 'alliance_liste'; + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".floor($_GET['i'])."';"); + $template->assign('membres', $membres); + } + elseif ($_GET['q'] == 'view' && !empty($_GET['i'])) { + $id = mysql_real_escape_string($_GET['i']); + $alliance = $chapeau->unique_query("SELECT * FROM `$table_alliances` WHERE `id` = '$id';"); + if ($alliance) { + $page = 'alliance_nm_view'; + $template->assign('alliance', $alliance); + $membres = $chapeau->query("SELECT * FROM `$table_user` WHERE `id_alliance` = '".$alliance['id']."';"); + $template->assign('nbmembre', $chapeau->num_rows); + } + else { + $template->assign('message','Impossible de trouver cette alliance !'); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + elseif ($_GET['q'] == 'postuler' && !empty($_GET['i'])) { + $id = mysql_real_escape_string($_GET['i']); + $alliance = $chapeau->unique_query("SELECT * FROM `$table_alliances` WHERE `id` = '$id';"); + if (!empty($_POST['message'])) { + $chapeau->query("INSERT INTO `$table_alliances_attente` VALUES (NULL, '".$alliance['id']."', '".$id_user."', '".$queryUser['pseudo']."', '".time()."', '".mysql_real_escape_string($_POST['message'])."');"); + $template->assign('message','Votre candidature a été envoyée avec succès à l\'alliance : '.$alliance['nom']); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + $template->assign('alliance', $alliance); + $page = 'alliance_nm_postuler'; + } + elseif ($_GET['q'] == 'signer' && !empty($_GET['i'])) { + $lien = mysql_real_escape_string($_GET['i']); + $alliance = $chapeau->unique_query("SELECT * FROM `$table_alliances_creation` WHERE `lien` = '$lien';"); + if ($alliance) { + $signataires = explode(';', $alliance['signatures']); + if ($alliance['fondateur'] == $id_user || in_array($id_user, $signataires)) { + $template->assign('message','Vous avez déjà signé pour cette alliance.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + //Si c'est la 4ème signature, on crée l'alliance + if (count($signataires) >= 3) { + $chapeau->query("INSERT INTO `$table_alliances` VALUES (NULL, '".$alliance['tag']."', '".$alliance['nom']."', '".$alliance['fondateur']."', 'A faire', 'A faire', '', '', 1, 1, '');"); + $chapeau->query("DELETE FROM `$table_alliances_creation` WHERE `lien` = '$lien';"); + + file_log("Création de l'alliance : ".$alliance['nom']." par ".$id_user." (fondateur : ".$alliance['fondateur'].") après validation de 4 signatures : ".implode(', ', $signataires).$id_user); + + //On envoie un message au fondateur de l'alliance + include_once('Class/class.rapport.php'); + $rapport = new Rapport(6, $alliance['fondateur'], 0, time()); + $rapport->send(); + + $nbsign = count($signataires); + for ($i=0 ; $i<$nbsign ; $i++) { + $chapeau->query("UPDATE `$table_user` SET `id_alliance` = '".$alliance['id']."' WHERE `id` = '".$signataires[$i]."'"); + } + $chapeau->query("UPDATE `$table_user` SET `id_alliance` = '".$alliance['id']."' WHERE `id` = '$id_user'"); + + $template->assign('message','Votre signature a bien été ajoutée à la déclaration de l\'alliance.
    L\'alliance a désormais désormais suffisament de signature pour être créée !'); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $signataires[] = $id_user; + $signataires = implode(';', $signataires); + $chapeau->query("UPDATE `$table_alliances_creation` SET `signatures` = '$signataires' WHERE `lien` = '$lien'"); + $chapeau->query("UPDATE `$table_user` SET `id_alliance` = 'c".$alliance['id']."' WHERE `id` = '$id_user'"); + $template->assign('message','Votre signature a bien été ajoutée à la déclaration de l\'alliance.'); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + } + } + else { + $template->assign('message','Impossible de trouver l\'alliance !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + elseif ($_GET['q'] == 'fonder') { + if (!empty($_POST['nom']) && !empty($_POST['tag'])) { + $nom = mysql_real_escape_string(htmlentities($_POST['nom'])); + $tag = mysql_real_escape_string(htmlentities($_POST['tag'])); + + if (strlen($nom) < 5) { + $template->assign('message','Le nom d\'alliance que vous avez choisit est trop court.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (strlen($nom) > 25) { + $template->assign('message','Le nom d\'alliance que vous avez choisit est trop long.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (strlen($tag) > 5) { + $template->assign('message','Le nom d\'alliance que vous avez choisit est trop long.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (strlen($tag) < 3) { + $template->assign('message','Le nom d\'alliance que vous avez choisit est trop court.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + $test = $chapeau->query("SELECT * FROM `alliances` WHERE `nom` = '$nom' AND `tag` = '$tag';"); + $test2 = $chapeau->query("SELECT * FROM `alliances_creation` WHERE `nom` = '$nom' AND `tag` = '$tag';"); + if ($test || $test2) { + $template->assign('message','Le nom ou le tag que vous avez choisit est déjà utilisé par une alliance.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $lien = sha1($tag.'Hb$'.$nom.'☺Ø'.$id_user.rand()); + $chapeau->query("INSERT INTO `alliances_creation` VALUES(NULL, '$lien' ,'$tag', '$nom', '$id_user', '');"); + + $template->assign('message','Votre alliance a bien été créée.
    Il ne vous reste plus qu\'à trouver au moins 4 signatures pour finir la création de votre alliance.

    Le lien permettant à vos quatres personnes de signer est ?p=alliances&q=signer&i='.$lien.''); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + } + $page = 'alliance_nm_fonder'; + } + else { + $page = 'alliance_nm_accueil'; + } +} +?> \ No newline at end of file diff --git a/game/arbre.php b/game/arbre.php new file mode 100644 index 0000000..8656a40 --- /dev/null +++ b/game/arbre.php @@ -0,0 +1,56 @@ +assign('defaut',$_GET['q']); + +$TEMP_batiments = array(); +$nb=count($batiment); +for ($id=0 ; $id<$nb ; $id++) { + if (!empty($batiment[$id])) $TEMP_batiments[] = array( + 'url' => 'id='.$id.'&type=batiment&lvl='.$queryPlanete[$batimentVAR[$id]], + 'nom' => $batiment[$id], + 'niveau' => $queryPlanete[$batimentVAR[$id]], + 'etat' => readDeblok($batimentTECH[$id], $queryPlanete, $queryUser) + ); +} +$template->assign('batiments',$TEMP_batiments); + +$TEMP_technologies = array(); +$nb=count($technolo); +for ($id=0 ; $id<$nb ; $id++) { + if (!empty($technolo[$id])) $TEMP_technologies[] = array( + 'url' => 'id='.$id.'&type=technologie&lvl='.$queryUser[$technoloVAR[$id]], + 'nom' => $technolo[$id], + 'niveau' => $queryUser[$technoloVAR[$id]], + 'etat' => readDeblok($technoloTECH[$id], $queryPlanete, $queryUser) + ); +} +$template->assign('technologies',$TEMP_technologies); + +$TEMP_terrestre = array(); +$nb=count($nomterrn); +for ($id=0 ; $id<$nb ; $id++) { + if (!empty($nomterrn[$id])) $TEMP_terrestre[] = array( + 'url' => 'id='.$id.'&type=unite&lvl='.$queryPlanete[$nomterrnVAR[$id]], + 'nom' => $nomterrn[$id], + 'niveau' => $queryPlanete[$nomterrnVAR[$id]], + 'etat' => readDeblok($nomterrnTECH[$id], $queryPlanete, $queryUser) + ); +} +$template->assign('unites',$TEMP_terrestre); + +$TEMP_vaisseaux = array(); +$nb=count($nomvaisn); +for ($id=0 ; $id<$nb ; $id++) { + if (!empty($nomvaisn[$id])) $TEMP_vaisseaux[] = array( + 'url' => 'id='.$id.'&type=unite&lvl='.$queryPlanete[$nomvaisnVAR[$id]], + 'nom' => $nomvaisn[$id], + 'niveau' => $queryPlanete[$nomvaisnVAR[$id]], + 'etat' => readDeblok($nomvaisnTECH[$id], $queryPlanete, $queryUser) + ); +} +$template->assign('vaisseaux',$TEMP_vaisseaux); +?> \ No newline at end of file diff --git a/game/batiments.php b/game/batiments.php new file mode 100644 index 0000000..76a6ae8 --- /dev/null +++ b/game/batiments.php @@ -0,0 +1,120 @@ +limite = $queryUser['prodfile']+2; + } + + //Lancement d'une nouvelle construction + if (isset($_GET['c']) && isset($batiment[$_GET['c']])) { + $i = $_GET['c']; + if(requestDeblok($batimentTECH[$i], $queryPlanete, $queryUser)) { + $n=($queryPlanete[$batimentVAR[$i]]+1); + eval($batimentCALC[$i][0]); $metal -= $a; + eval($batimentCALC[$i][1]); $cristal -= $b; + eval($batimentCALC[$i][2]); $hydrogene -= $c; + if ($caseRest <= 0) { + $template->assign('message','Vous n\'avez plus de place sur votre planète.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + if ($metal < 0 || $cristal < 0 || $hydrogene < 0) { + $template->assign('message','Vous n\'avez pas assez de ressources pour effectuer cette construction.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + eval($batimentCALC[$i][3]); + if ($file->addObjet($i, 1, ceil($sec))) { + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_bat` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + } + else { + $template->assign('message','Vous ne pouvez pas mettre plus de batiments en file d\'attente.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + header('Location: ?p=batiments'); + exit; + } + } + //Annulation d'une nouvelle construction + if (isset($_GET['a']) && isset($batiment[$_GET['a']])) { + $i = $_GET['a']; + if($file->existe($i)) { + $n=($queryPlanete[$batimentVAR[$i]]+1); + eval($batimentCALC[$i][0]); $metal += $a; + eval($batimentCALC[$i][1]); $cristal += $b; + eval($batimentCALC[$i][2]); $hydrogene += $c; + $file->delobjet($i); + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_bat` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + header('Location: ?p=batiments'); + exit; + } + } + //Règler la production à la châine +/* if (isset($_GET['r']) && ($_GET['r'] == 1 || $_GET['r'] == 0)) { + if($_GET['r']) $file->chaine = false; + else $file->chaine = true; + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_bat` = '$export' WHERE `id` = '$idPlan';"); + header('Location: ?p=batiments'); + exit; + }*/ + + for ($i=0 ; $i<$nbstop ; $i++) { + $tr = 0; $a = 0; $b = 0; $c = 0; $sec = 0; $enFile = false; + $nom_bdd = $batimentVAR[$i]; + if ($queryPlanete[$nom_bdd] > 0) $niveau = $queryPlanete[$nom_bdd]; else $niveau = 0; + $n=($queryPlanete[$nom_bdd]+1); eval($batimentCALC[$i][0]); eval($batimentCALC[$i][1]); eval($batimentCALC[$i][2]); eval($batimentCALC[$i][3]); + if ($file->existe($i)) $enFile = true; + if (!empty($batiment[$i]) && requestDeblok($batimentTECH[$i], $queryPlanete, $queryUser)) $TEMP_batiments[] = + array( + 'image' => $batimeni[$i], + 'nom' => $batiment[$i], + 'niveau' => $niveau, + 'description' => $batimede[$i], + 'descriptione' => addslashes($batimede[$i]), + 'nec_metal' => $a, + 'nec_cristal' => $b, + 'nec_hydrogene' => $c, + 'nec_metalS' => separerNombres($a), + 'nec_cristalS' => separerNombres($b), + 'nec_hydrogeneS' => separerNombres($c), + 'temps' => sec($sec), + 'num' => $i, + 'enfile' => $enFile, + 'maq_metal' => ceil($a-$metal), + 'maq_cristal' => ceil($b-$cristal), + 'maq_hydrogene' => ceil($c-$hydrogene) + ); + } + $template->assign('batiments',$TEMP_batiments); + $template->assign('chaine',$file->chaine); + $fileBat = $file->file; + $nbfile = count($fileBat); + + if ($nbfile == 1) $template->assign('Pchaine',true); + else $template->assign('Pchaine',false); + if ($nbfile == 0) $template->assign('Vchaine',true); + else $template->assign('Vchaine',false); + + for ($i=0 ; $i<$nbfile ; $i++) { + $fileBat[$i][3] = $batiment[$fileBat[$i][0]]; + if ($i == 0) $fileBat[$i][2] -= time() - $file->timestamp; + } + $template->assign('file',$fileBat); +?> \ No newline at end of file diff --git a/game/bugs.php b/game/bugs.php new file mode 100644 index 0000000..b4e8c94 --- /dev/null +++ b/game/bugs.php @@ -0,0 +1,23 @@ +query("INSERT INTO `bug` VALUES(NULL, '".$queryUser['pseudo']."', '".time()."', '$pages', '$description');"); + header('Location: ?p=bugs'); +} +elseif (isset($_GET['a']) && $_GET['a'] == 'del' && isset($_GET['i']) && $sess->values['auth_level'] > 2) { + $chapeau->query("DELETE FROM `bug` WHERE `id` = '".$_GET['i']."' LIMIT 1"); + header('Location: ?p=bugs'); +} + +$result = mysql_query("SELECT * FROM `bug` ORDER BY `id` DESC"); +$TEMP_bugs = array(); +while ($data = mysql_fetch_array($result)) { + $TEMP_bugs[] = array(''.$data['pseudo'].'', date("d/m/y", $data['temps']), $data['page'], nl2br($data['description']),$data['id'] ); +} +$template->assign('bugs', $TEMP_bugs); +?> \ No newline at end of file diff --git a/game/carte.php b/game/carte.php new file mode 100644 index 0000000..4662dd6 --- /dev/null +++ b/game/carte.php @@ -0,0 +1,55 @@ + 15) $g = 1; + +if (isset($_GET['ss'])) $s = floor($_GET['ss']); else $s = $queryPlanete['ss']; +if ($s < 1) $s = 1; +if ($s > 300) $s = 300; + +if ($s == 1 && $g > 1) { + $Gmu = $g - 1; + $Smu = 300; +} +elseif ($s == 1) { + $Gmu = 15; + $Smu = 300; +} +else { + $Gmu = $g; + $Smu = $s - 1; +} +if ($s == 300) { + $Gpu = $g + 1; + $Spu = 1; +} +else { + $Gpu = $g; + $Spu = $s + 1; +} + +$TEMP_carte = array(); +for ($i=1; $i<=12; $i++) { + $resultat = mysql_query("SELECT * FROM planete WHERE galaxie='$g' AND ss='$s' AND position='$i'"); + if(mysql_num_rows($resultat)>=1) { + $x = mysql_query("SELECT * FROM planete WHERE galaxie='$g' AND ss='$s'AND position='$i'"); + $d = mysql_fetch_array($x); + + $id_user = $d['id_user']; + $y = mysql_query("SELECT race FROM user WHERE id='$id_user'"); + $e = mysql_fetch_array($y); + if ($e['race'] == 'covenant') $ra='(c)'; + elseif (md5($e['race'] && $auth_level >= 6) == '34c19b21bd4a3dda389e767d32fe9779') $ra='(f)'; + else $ra='(h)'; + + $TEMP_carte[] = array($i, $d['nom_planete'], $d['debris_met'], $d['debris_cri'], $ra, trouvNom($d['id_user']), 'Message'); + } + else $TEMP_carte[] = array($i); +} +$template->assign('carte',$TEMP_carte); +$template->assign('position',array($g, $s, $Gpu, $Spu, $Gmu, $Smu)); +?> \ No newline at end of file diff --git a/game/chantierspatial.php b/game/chantierspatial.php new file mode 100644 index 0000000..ce8e379 --- /dev/null +++ b/game/chantierspatial.php @@ -0,0 +1,129 @@ +limite = $queryUser['prodfile']+2; + } + + if ($queryPlanete['chantier_spatial'] == 0) { + $template->assign('message','Vous devez d\'abord construire un '.strtolower($batiment[8])); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + //Lancement d'une nouvelle construction + if (isset($_GET['v']) && isset($nomvaisn[$_GET['v']]) && !empty($_POST['nombre'])) { + $i = $_GET['v']; + $nbv = floor($_POST['nombre']); + if(requestDeblok($nomvaisnTECH[$i], $queryPlanete, $queryUser) && $nbv > 0) { + $n=($queryPlanete[$nomvaisnVAR[$i]]+1); + $a = $nomvaisnCALC[$i][0]; $metal -= $a * $nbv; + $b = $nomvaisnCALC[$i][1]; $cristal -= $b * $nbv; + $c = $nomvaisnCALC[$i][2]; $hydrogene -= $c * $nbv; + if ($metal < 0 || $cristal < 0 || $hydrogene < 0) { + $template->assign('message','Vous n\'avez pas assez de ressources pour démarrer cette construction.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + eval($nomvaisnCALC[$i][3]); + if ($file->addObjet($i, $nbv, ceil($sec))) { + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_vais` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + } + else { + $template->assign('message','Vous ne pouvez pas mettre plus de vaisseaux en file d\'attente.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + header('Location: ?p=chantierspatial'); + exit; + } + } + //Annulation d'une nouvelle construction + if (isset($_GET['a']) && isset($nomvaisn[$_GET['a']])) { + $i = $_GET['a']; + if (!isset($_GET['n'])) $nbv = 1; + else $nbv = $_GET['n']; + + if($file->existe($i)) { + $n=($queryPlanete[$nomvaisnVAR[$i]]+1); + $a = $nomvaisnCALC[$i][0]; + $b = $nomvaisnCALC[$i][1]; + $c = $nomvaisnCALC[$i][2]; + $nbvr = $file->delobjet($i, $nbv); + + $metal += $a*$nbvr; + $cristal += $b*$nbvr; + $hydrogene += $c*$nbvr; + + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_vais` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + header('Location: ?p=chantierspatial'); + exit; + } + } + //Règler la production à la châine +/* if (isset($_GET['r']) && ($_GET['r'] == 1 || $_GET['r'] == 0)) { + if($_GET['r']) $file->chaine = false; + else $file->chaine = true; + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_vais` = '$export' WHERE `id` = '$idPlan';"); + header('Location: ?p=chantierspatial'); + exit; + }*/ + + for ($i=0 ; $i<$nbstop ; $i++) { + $tr = 0; $a = 0; $b = 0; $c = 0; $sec = 0; + $nom_bdd = $nomvaisnVAR[$i]; $a = $nomvaisnCALC[$i][0]; $b = $nomvaisnCALC[$i][1]; $c = $nomvaisnCALC[$i][2]; eval($nomvaisnCALC[$i][3]); + if ($queryPlanete[$nom_bdd] > 0) $nombre = $queryPlanete[$nom_bdd]; else $nombre = 0; + $n=($queryPlanete[$nom_bdd]+1); + if (!empty($nomvaisn[$i]) && requestDeblok($nomvaisnTECH[$i], $queryPlanete, $queryUser)) $TEMP_vaisseaux[] = + array( + 'image' => $nomvaisi[$i], + 'nom' => $nomvaisn[$i], + 'nombre' => $nombre, + 'description' => $nomvaisd[$i], + 'descriptione' => addslashes($nomvaisd[$i]), + 'nec_metal' => $a, + 'nec_cristal' => $b, + 'nec_hydrogene' => $c, + 'nec_metalS' => separerNombres($a), + 'nec_cristalS' => separerNombres($b), + 'nec_hydrogeneS' => separerNombres($c), + 'temps' => sec($sec), + 'num' => $i + ); + } + $template->assign('vaisseaux',$TEMP_vaisseaux); + $template->assign('chaine',$file->chaine); + $fileBat = $file->file; + $nbfile = count($fileBat); + + if ($nbfile == 1) $template->assign('Pchaine',true); + else $template->assign('Pchaine',false); + if ($nbfile == 0) $template->assign('Vchaine',true); + else $template->assign('Vchaine',false); + + for ($i=0 ; $i<$nbfile ; $i++) { + $fileBat[$i][3] = $nomvaisn[$fileBat[$i][0]]; + $fileBat[$i][4] = $fileBat[$i][2]*$fileBat[$i][1]; + if ($i == 0) { + $fileBat[$i][2] -= time() - $file->timestamp; + $fileBat[$i][4] -= time() - $file->timestamp; + } + } + $template->assign('file',$fileBat); +?> \ No newline at end of file diff --git a/game/classement.php b/game/classement.php new file mode 100644 index 0000000..b492b94 --- /dev/null +++ b/game/classement.php @@ -0,0 +1,41 @@ + 0) $pageClassement = $_GET['q']; +else $pageClassement = 1; + if (isset($_GET['e'])) { + if ($_GET['e'] == 'batiment') $export = 'batiments'; + elseif ($_GET['e'] == 'flotte') $export = 'flottes'; + elseif ($_GET['e'] == 'recherches') $export = 'recherches'; + else $export = 'points'; + } + else $export = 'points'; + +$nbppage = 100; +$pageClassementN = ($pageClassement-1) * $nbppage; + +$result = mysql_query("SELECT * FROM `classement`"); +$nbpages = ceil(mysql_num_rows($result)/$nbppage); +if ($pageClassement > $nbpages) $pageClassement = $nbpages; +$TEMP_pages = ''; +$template->assign('q', $TEMP_pages); +$result = mysql_query("SELECT * FROM `classement` ORDER BY `classement`.`$export` DESC LIMIT $pageClassementN, $nbppage"); + +$TEMP_classement = array(); +$i = ($pageClassement-1)*$nbppage; + +$template->assign('export', $export); + +while ($data = mysql_fetch_array($result)) { + $i++; + $TEMP_classement[] = array($i, $data['pseudo'], $data['race'], separerNombres($data[$export])); +} +$template->assign('places', $TEMP_classement); +?> \ No newline at end of file diff --git a/game/conditions.php b/game/conditions.php new file mode 100644 index 0000000..fedec43 --- /dev/null +++ b/game/conditions.php @@ -0,0 +1,159 @@ +assign('contenu',' +

    Conditions générales pour le site Halo-Battle.s-fr.com

    +
    +
    +Halo, Bungie et Microsoft sont des marques et logos déposés par Microsoft Corporation.
    +Tous droits réservés Copyright © 2006-2007
    +halo-battle.s-fr.com Tous droits reservés.
    +
    +Le site d\'halo-battle.s-fr.com demande à tous les utilisateurs du jeu de lire et d\'accepter les Conditions Générales énoncées ci-dessous avant de s\'inscrire.
    +
    +
    +Ces Conditions Générales d\'Utilisation ont été publiées le 23/04/2008 et sont applicables à partir du 30/04/2008.
    +
    +
    +I. Services
    +II. Adhésion
    +III. Protections des données
    +IV. Responsabilité
    +V. Contenu / responsabilité envers le contenu
    +VI. Actions prohibées
    +VII. Restrictions
    +VIII. Droits de société concernant les comptes
    +IX. Modification des Conditions Générales
    +X. Loi applicable
    +
    +

    I. Services


    +

    1 - Conditions de participation


    + +Pour participer à Halo-Battle, l\'utilisateur doit accepter les Conditions Générales. Ces Conditions Générales sont principalement, mais non exclusivement, portées sur les services proposés par la présence en ligne de Halo-Battle.s-fr.com
    + +

    2 - Responsabilité


    + +Halo-Battle.s-fr.com est toujours attentif au bon fonctionnement de toutes les prestations qu\'il propose. Néanmoins, certaines desdites prestations peuvent ne pas être disponibles pour des circonstances indépendantes de notre volonté. Pour cette raison, l\'utilisateur ne peut avoir de halo-battle.s-fr.com ne peut être tenu pour responsable du mauvais fonctionnement du serveur ou pour un défaut de programmation. Les exemples précités ne sont pas exclusifs d\'autres possibilités.
    + +

    II. Adhésion


    + +

    1 - Conditions d\'adhésion


    +L\'adhésion commence à partir de l\'enregistrement d\'un compte sur le jeu ou le forum. L\'adresse e-mail utilisée pour cet enregistrement doit être valide. halo-battle.s-fr.com se réserve le droit de vérifier cette validité à n\'importe quel moment.
    +Les utilisateurs reconnaissent disposer d\'une expérience suffisante en matière d\'utilisation d\'Internet et des fonctionnalités de communication électronique qui y sont liées.
    +Les utilisateurs du site de halo-battle.s-fr.com sont tenus de s\'assurer de la compatibilité de leur logiciel de navigation avec le site de Halo-Battle.s-fr.com.
    + +

    2 - Résiliation par l\'utilisateur


    +L\'adhésion peut être résiliée par l\'utilisateur par le biais de l\'effacement du compte. Cet effacement peut être retardé pour des questions d\'ordre technique. La gestion des informations concernant les données personnelles du compte est relatif au chapitre 3 des conditions générales d\'utilisation.
    + +

    3 - Résiliation par Halo-Battle.s-fr.com


    +L\'utilisateur ne peut participer à la gestion des services proposés par Halo-Battle.s-fr.com. A ce titre, l\'équipe du jeu se réserve le droit d\'effacer ou de bloquer le compte de l\'utilisateur, en cas de violation des Conditions Générales, sans que cela ne soit exclusif d\'autres possibilités.
    +L\'effacement du compte est décidé par l\'ensemble de l\'équipe. Les quelconques revendications concernant un effacement de compte peuvent être portées auprès de l\'équipe du jeu. Il ne peut y avoir de revendications légales concernant la clotûre du compte.
    + +

    III. Protections des données


    + +

    1 - Droit d\'accès aux données


    +Conformément à la loi du 7 janvier 1978, vous disposez d\'un droit d\'accès, de rectification, de vérification et de suppression relatif aux données vous concernant.
    +Il vous suffit pour ce faire d\'adresser une demande par e-mail à contact@halo-battle.s-fr.com, Halo-Battle.s-fr.com modifiera et mettra ses informations à jour en conséquent.
    + +

    2 - Stockage des données personnelles


    +Halo-Battle.s-fr.com se réserve le droit de stocker les données personnelles des utilisateurs dans le but de contrôler le respect des règles, des Conditions Générales et des dispositions législatives par lesdits utilisateurs. Les données personnelles concernées peuvent être les adresse IP par connexion, la méthode, l\'heure et les durées de connections, l\'adresse e-mail fournie lors de la création du compte ainsi que, le cas échéant, les données personnelles fournies volontairement par l\'utilisateur par le biais de son profil. Sur les forums, les données personnelles des profils des utilisateurs sont conservées.
    + +

    3 - Communication et utilisation des données


    +Halo-Battle.s-fr.com se réserve le droit, en conformité avec les dispositions du droit français concernant la protection des données personnelles et toutes dispositions législatives applicables, de divulguer les données personnelles aux autorités, qui les requièrent en vue de protéger les intérêts des sociétés ou les éventuels manquements aux dispositions légales concernant la protection des données. + +

    4 - Opposition


    +L\'utilisateur peut s\'opposer au stockage de ses données personnelles à tout moment. La participation aux jeux nécessitant le stockage de ces données personnelles, le(s) compte(s) de l\'utilisateur sera(ont) supprimé(s) le plus rapidement possible en fonction des contraintes techniques.
    + +

    IV. Responsabilité


    + +Halo-Battle.s-fr.com n\'est pas responsable pour les dommages, quelle qu\'en soit la gravité, causés par l\'utilisation du jeu Halo-Battle. halo-battle.s-fr.com rappelle aux joueurs que l\'utilisation excessive des jeux informatiques peut causer de sévères troubles physiques.
    + +

    V. Contenu / responsabilité envers le contenu


    + +

    1 - Utilisation de la plateforme des utilisateurs


    +Halo-Battle.s-fr.com fournit une plateforme qui permet à l\'utilisateur de communiquer avec chacun des autres utilisateurs. L\'utilisateur est responsable du contenu de ses propos : les propos pornographiques, xénophobes, insultants ou à contenu illégaux ne sont pas autorisés et relèvent de la responsabilité de leur auteur. En cas de violation, Halo-Battle.s-fr.com se réserve le droit d\'effacer ou de bloquer le compte de l\'utilisateur fautif et de l\'interdire d\'accès sur l\'ensemble des services proposés par l\'équipe. Ces sanctions ne sont pas exclusives d\'éventuelles poursuites judiciaires et/ou pénales.
    + +

    2 - Dommages internes au contenu


    +L\'utilisateur du site est conscient du fait qu\'Internet n\'est pas un média parfaitement protégé et qu\'une sécurité totale quant au respect de la vie privée ne peut être garantie. Par conséquent, halo-battle.s-fr.com ne sera en aucune manière responsable des dommages éventuels subis par l\'utilisateur du site à la suite de l\'introduction par ce dernier d\'informations confidentielles ou délicates.
    + +

    3 - Engagement de Halo-Battle.s-fr.com


    +halo-battle.s-fr.com s\'engage à mettre en oeuvre tous les moyens raisonnables à sa disposition en vue de permettre aux utilisateurs une utilisation optimale des services proposés. halo-battle.s-fr.com n\'est en conséquence tenue qu\'à une obligation de moyen, et en aucun cas à une obligation de résultat.
    + +halo-battle.s-fr.com ne peut être tenu pour responsable des conséquences de circonstances indépendantes de sa volonté telles que les grèves, lock-out, guerres, intempéries, etc., les défaillances des systèmes informatiques ou des moyens de communication, ou de tout autre événement constitutif d\'un cas de force majeure.
    + +

    4 - Mise à disposition des informations


    +halo-battle.s-fr.com assure la mise à disposition via ce site d\'informations correctes et actualisées et se réserve donc le droit de modifier à tout moment le contenu du site. Toutefois, halo-battle.s-fr.com n\'est en aucun cas responsable des dommages causés à la suite de données éventuellement incorrectes, non actualisées ou incomplètes communiquées via le site.
    + +Les utilisateurs du site de halo-battle.s-fr.com s\'engagent à avertir immédiatement l\'équipe de toute utilisation frauduleuse du site de halo-battle.s-fr.com et à ne pas chercher à nuire à l\'intégrité ou au fonctionnement du site.
    + +

    5 - Liens


    +halo-battle.s-fr.com n\'a aucun pouvoir de vérification et de contrôle quant à la création de liens vers des sites extérieurs et quant au contenu des dits sites, que ces sites soient marchands ou non.
    + +Les propriétaires des sites consultés à partir du site de Halo-Battle.s-fr.com sont, notamment, seuls responsables du respect de l\'ensemble des réglementations s\'appliquant dans le cadre des prestations offertes en ligne, et notamment, des lois et règlements relatifs à la vente à distance, la protection du consommateur, la publicité mensongère ou trompeuse, les prix, la conformité des produits, etc.
    + +Aussi, l\'utilisateur accepte que son choix d\'accéder à un autre site, par l\'intermédiaire d\'un lien hypertexte s\'effectue à ses risques et périls.
    + +En conséquence, tout préjudice direct ou indirect résultant de l\'accès à un site relié par un lien hypertexte ne peut engager la responsabilité de Halo-Battle.s-fr.com
    + +

    VI. Actions prohibées


    + +

    1 - Actions de manipulations


    +L\'utilisateur n\'a le droit d\'utiliser, un quelconque programme, mécanisme ou logiciel qui pourrait interférer avec les fonctions et/ou le développement du jeu. L\'utilisateur n\'a pas de le droit d\'effectuer une quelconque action qui causerait un ralentissement excessif des capacités techniques du site. L\'utilisateur n\'a pas le droit de bloquer, modifier ou reformuler le contenu créé par l\'équipe de dévellopement du projet.
    + +

    2 - Programmes prohibés


    +Il est interdit de visualiser une quelconque partie du jeu avec un autre programme que les navigateurs Internet prévus à cet effet. Sont visés, tous autres programmes, en particulier ceux connus sous la dénomination de bots (sans que cette appellation soit exclusive), ainsi que tous +outils permettant de simuler, remplacer ou de suppléer le navigateur +internet. De la même manière, sont visés les scripts et les programmes +partiellement ou totalement automatiques qui peuvent procurer un +avantage par rapport aux autres utilisateurs. Les fonctions de +rafraîchissement automatique ("auto-refresh") et autres mécanismes +intégrés dans les navigateurs Internet sont également visés en tant +qu\'actions automatiques. L\'intégralité de ces mécanismes, sans que cela +soit exclusif d\'autres possibilités, est interdit. Le fait de bloquer la +publicité soit intentionnellement soit par le biais d\'un bloqueur de +pop-up voire par le biais d\'un module intégré aux navigateurs Internet +est sans conséquence sur cette interdiction. Les seules exceptions +possibles nécessitent la permission expresse de l\'équipe de Halo-Battle.s-fr.com
    + +

    4 - Connexion directe


    +La connexion au compte de l\'utilisateur est uniquement permise par le +biais de la page d\'accueil du jeu. L\'ouverture automatique ou +automatisée, est interdite, que la page d\'accueil soit affichée ou non.
    + +

    VII. Restrictions


    + +

    1 - Nombre maximum de comptes


    +Chaque utilisateur n\'est autorisé qu\'à utiliser un compte par univers. +Sont dénommés "Multis" les utilisateurs qui n\'agissent pas en accord +avec cette règle. Les "Multis" sont susceptibles de voir leurs comptes +effacés ou bloqués sans avertissement préalable.
    + +

    2 - Règles


    +Les particularités sont visées par les règles du jeu. Tous les +utilisateurs sont soumis à ces dispositions.
    + +

    3 - Blocages


    +L\'utilisateur peut être bloqué de manière temporaire ou définitive. Le +blocage peut être valable sur une partie ou la totalité des services +proposés par Halo-Battle.s-fr.com
    + +

    VIII. Droits de société concernant les comptes


    + +

    1 - Généralités


    +L\'ensemble des comptes, incluant les ressources, unités, etc, sont des objets virtuels du jeu. L\'utilisateur n\'a pas la propriété ou tout autre type de droits sur le compte. L\'ensemble des droits sont de la propriété de Bungie et Microsoft Corporation. Aucun droit, en particulier ceux concernant l\'exploitation, ne peut être conféré à l\'utilisateur.
    + +

    2 - Interdiction d\'exploitation


    +Il est interdit de contracter avec une tierce partie un quelconque accord concernant le transfert, l\'utilisation ou le stockage des comptes ou des données personnelles. Il est particulièrement interdit de vendre les comptes ou les ressources, voire de faire un quelconque profit en quittant son compte ou ses ressources au profit d\'un tiers. Les mêmes interdictions sont valables pour les données personnelles et les droits d\'utilisation. La violation de ces règles ou de tout autre droit de Bungie et Microsoft Corporation, particulièrement celles concernant le copyright, sera transmise aux autorités et sanctionnée par des poursuites judiciaires et/ou pénales.
    + +

    3 - Exceptions


    +Il est permis de transférer les comptes de manière gratuite, ainsi que d\'échanger des ressources dans les limites permises par les règles du jeu.
    + +

    IX. Modification des Conditions Générales


    + +Halo-Battle.s-fr.com se réserve le droit de modifier ou d\'étendre les Conditions Générales et les autres dispositions à tout moment. Cette modification ou extension sera publiée au minimum deux semaines avant l\'effectivité des changements.
    + +

    X. Loi applicable


    +La législation française est appliquée en cas de recours légal.
    +
    '); +?> \ No newline at end of file diff --git a/game/defenses.php b/game/defenses.php new file mode 100644 index 0000000..e01afc8 --- /dev/null +++ b/game/defenses.php @@ -0,0 +1,130 @@ +limite = $queryUser['prodfile']+2; + } + + if ($queryPlanete['chantier_terrestre'] == 0) { + $template->assign('message','Vous devez d\'abord construire un '.strtolower($batiment[7])); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + //Lancement d'une nouvelle construction + if (isset($_GET['v']) && isset($nomterrn[$_GET['v']]) && !empty($_POST['nombre'])) { + $i = $_GET['v']; + $nbv = floor($_POST['nombre']); + if(requestDeblok($nomterrnTECH[$i], $queryPlanete, $queryUser) && $nbv > 0) { + $n=($queryPlanete[$nomterrnVAR[$i]]+1); + $a = $nomterrnCALC[$i][0]; $metal -= $a * $nbv; + $b = $nomterrnCALC[$i][1]; $cristal -= $b * $nbv; + $c = $nomterrnCALC[$i][2]; $hydrogene -= $c * $nbv; + if ($metal < 0 || $cristal < 0 || $hydrogene < 0) { + $template->assign('message','Vous n\'avez pas assez de ressources pour démarrer cette construction.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + eval($nomterrnCALC[$i][3]); + if ($file->addObjet($i, $nbv, ceil($sec))) { + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_ter` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + } + else { + $template->assign('message','Vous ne pouvez pas mettre plus de défenses en file d\'attente.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + header('Location: ?p=defenses'); + exit; + } + } + //Annulation d'une nouvelle construction + if (isset($_GET['a']) && isset($nomterrn[$_GET['a']])) { + $i = $_GET['a']; + if (!isset($_GET['n'])) $nbv = 1; + else $nbv = $_GET['n']; + + if($file->existe($i)) { + $n=($queryPlanete[$nomterrnVAR[$i]]+1); + $a = $nomterrnCALC[$i][0]; + $b = $nomterrnCALC[$i][1]; + $c = $nomterrnCALC[$i][2]; + $nbvr = $file->delobjet($i, $nbv); + + $metal += $a*$nbvr; + $cristal += $b*$nbvr; + $hydrogene += $c*$nbvr; + + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_ter` = '$export', `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id` = '$idPlan';"); + header('Location: ?p=defenses'); + exit; + } + } + //Règler la production à la châine +/* if (isset($_GET['r']) && ($_GET['r'] == 1 || $_GET['r'] == 0)) { + if($_GET['r']) $file->chaine = false; + else $file->chaine = true; + $export = mysql_real_escape_string(serialize($file)); + mysql_query("UPDATE `planete` SET `file_ter` = '$export' WHERE `id` = '$idPlan';"); + header('Location: ?p=defenses'); + exit; + }*/ + + for ($i=8 ; $i<$nbstop ; $i++) { + $tr = 0; $a = 0; $b = 0; $c = 0; $sec = 0; + $nom_bdd = $nomterrnVAR[$i]; $a = $nomterrnCALC[$i][0]; $b = $nomterrnCALC[$i][1]; $c = $nomterrnCALC[$i][2]; eval($nomterrnCALC[$i][3]); + if ($queryPlanete[$nom_bdd] > 0) $nombre = $queryPlanete[$nom_bdd]; else $nombre = 0; + $n=($queryPlanete[$nom_bdd]+1); + if (!empty($nomterrn[$i]) && requestDeblok($nomterrnTECH[$i], $queryPlanete, $queryUser)) $TEMP_defenses[] = + array( + 'image' => $nomterri[$i], + 'nom' => $nomterrn[$i], + 'nombre' => $nombre, + 'description' => $nomterde[$i], + 'descriptione' => addslashes($nomterde[$i]), + 'nec_metal' => $a, + 'nec_cristal' => $b, + 'nec_hydrogene' => $c, + 'nec_metalS' => separerNombres($a), + 'nec_cristalS' => separerNombres($b), + 'nec_hydrogeneS' => separerNombres($c), + 'temps' => sec($sec), + 'num' => $i + ); + } + $template->assign('defenses',$TEMP_defenses); + $template->assign('chaine',$file->chaine); + $fileBat = $file->file; + $nbfile = count($fileBat); + + if ($nbfile == 1) $template->assign('Pchaine',true); + else $template->assign('Pchaine',false); + if ($nbfile == 0) $template->assign('Vchaine',true); + else $template->assign('Vchaine',false); + + for ($i=0 ; $i<$nbfile ; $i++) { + $fileBat[$i][3] = $nomterrn[$fileBat[$i][0]]; + $fileBat[$i][4] = $fileBat[$i][2]*$fileBat[$i][1]; + if ($i == 0) { + $fileBat[$i][2] -= time() - $file->timestamp; + $fileBat[$i][4] -= time() - $file->timestamp; + } + } + $template->assign('file',$fileBat); +?> \ No newline at end of file diff --git a/game/envoyer.php b/game/envoyer.php new file mode 100644 index 0000000..986aeca --- /dev/null +++ b/game/envoyer.php @@ -0,0 +1,29 @@ +unique_query("SELECT `pseudo` FROM `user` WHERE `pseudo` = '$util'")) { + $message = mysql_real_escape_string(htmlspecialchars($_POST['message'])); + $objet = mysql_real_escape_string(htmlspecialchars($_POST['objet'])); + mysql_query("INSERT INTO mail VALUES('', '1', '$util', '".$queryUser["pseudo"]."', '$objet', '$message', '".time()."')"); + + $template->assign('message','Votre message a été envoyé avec succès.'); + $template->assign('script',''); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $template->assign('message','Impossible de trouver le destinataire du message.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } +} + +if (isset($_GET['d'])) $template->assign('destinataire',$_GET['d']); +?> \ No newline at end of file diff --git a/game/flotte.php b/game/flotte.php new file mode 100644 index 0000000..38a01aa --- /dev/null +++ b/game/flotte.php @@ -0,0 +1,393 @@ +query("SELECT * FROM `$table` WHERE `id_user` = '$id_user'"); + $nbr = $chapeau->num_rows; + + $end_galaxie = floor($_POST['amas']); + $end_ss = floor($_POST['ss']); + $end_pos = floor($_POST['pos']); + $mission = floor($_POST['mission']); + + //Vérification du code anti-bots + if ($_POST['cds'] != $sess->values['flcds']) { + $template->assign('message','Impossible d\'authentifier l\'envoie de la flotte.
    Si le problème perciste, contactez un administrateur.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //Si la mission est d'attaquer, on vérifie que les attaques ne soient pas désactivées + elseif ($_POST['mission'] == 1 && !ATTAQUES) { + $template->assign('message','Les attaques sont désactivées pour le moment. Pour plus d\'informations, consultez le forum.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //Vérification que la destination ne soit pas en dehors de la galaxie + elseif ($end_galaxie > MAX_AMAS || $end_ss > MAX_SYSTEME || $end_pos > MAX_PLANETE || $end_galaxie < 0 || $end_ss < 1 || $end_pos < 1 || ($end_galaxie < 1 && $sess->values['auth_level'] < 6)) { + $template->assign('message','La destination de la flotte n\'est pas correcte.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //Vérification que le nombre de slots ne soit pas dépassé + elseif ($nbr + 1 > $queryUser['informatique']) { + $template->assign('message','Vous n\'avez pas assez de slots disponibles.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie la mission + elseif ($mission < 1 || $mission > 5) { + $template->assign('message','Mission incorrecte !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //Si la mission est d'attaquer, on vérifie la tactique + elseif ($mission == 1 && $_POST['tactique'] > $queryUser['tactique']) { + $template->assign('message','Vous ne connaissez pas cette tactique de combat !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie la mission, si elle est d'espionner, il faut qu'il y ait des sondes + elseif ($mission == 5 && (!isset($sess->values['vais'][4]) || $sess->values['vais'][4] < 0)) { + $template->assign('message','Vous ne pouvez pas espionner sans sonde d\'espionnage !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie la mission, si elle est de coloniser, il faut qu'il y ait des vaisseaux de colonisation + elseif ($mission == 3 && (!isset($sess->values['vais'][3]) || $sess->values['vais'][3] < 0)) { + $template->assign('message','Vous ne pouvez pas coloniser sans vaisseau de colonisation !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie la mission, si elle est de recycler, il faut qu'il y ait des reclycleurs + elseif ($mission == 4 && (!isset($sess->values['vais'][5]) || $sess->values['vais'][5] < 0)) { + $template->assign('message','Vous ne pouvez pas coloniser sans vaisseau de colonisation !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie que l'on possède assez de ressources + elseif ((!empty($_POST['metal']) && !$_POST['metal'] > $queryPlanete['metal']) || (!empty($_POST['cristal']) && !$_POST['cristal'] > $queryPlanete['cristal']) || (!empty($_POST['hydrogene']) && !$_POST['hydrogene'] > $queryPlanete['hydrogene'])) { + $template->assign('message','Vous ne pouvez pas envoyer plus de ressources que vous n\'en posséder.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + //On vérifie la vitesse du vaisseau + elseif (!is_numeric($_POST['vitesse']) || $_POST['vitesse'] < 0 || $_POST['vitesse'] > 100) { + $template->assign('message','La vitesse de votre flotte est incorrecte !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $table = $config['db_prefix'].'planete'; + $resultat = $chapeau->unique_query("SELECT * FROM `$table` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_pos';"); + //Si la mission est d'attaquer, on vérifie que le joueur cible ne soit pas ne mode vacances + if ($mission == 1) { + //Récupération de l'ID du joueur cible + $rech_user = $resultat['id_user']; + $table = $config['db_prefix'].'user'; + $resultatu = $chapeau->unique_query("SELECT * FROM `$table` WHERE `id` = '$rech_user';"); + if ($resultatu['mv'] != 0) { + $template->assign('message','Le joueur que vous tentez d\'attaquer est actuellement en mode vacances, vous ne pouvez donc pas l\'attaquer avant son retour de vacances.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif ($resultatu['time_inscription'] + 604800 > time()) { + $template->assign('message','Le joueur que vous tentez d\'attaquer s\'est inscrit récemment, laissez-lui le temps de se préparer au combat !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif (!$resultat) { + $template->assign('message','La planète que vous tentez d\'attaquer est inhabitée.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif ($resultat['id_user'] == $id_user) { + $template->assign('message','La planète que vous tentez d\'attaquer vous appartient.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + elseif ($mission == 2 && !$resultat) { + $template->assign('message','Impossible de transporter des ressources vers la planète ['.$end_galaxie.':'.$end_ss.':'.$end_pos.'] car elle est inhabitée.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif ($mission == 3 && $resultat) { + $template->assign('message','La planète que vous voulez coloniser est déjà habitée.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif ($mission == 4 && ($resultat['debris_met'] <= 0 || $resultat['debris_cri'] <= 0) && empty($sess->values['forceFlotte'])) { + $sess->values['forceFlotte'] = true; + $sess->put(); + $template->assign('message','Il n\'y a rien à recycler sur la planète ['.$end_galaxie.':'.$end_ss.':'.$end_pos.'].
    Vous pouvez forcer le lancement de la flotte en rechargeant cette page.'); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + //Création de la flotte + $req = ''; + $reqb = ''; + $reqPlan = ''; + $nbVais = ''; + $nbI = count($nomvaisa); + for ($i=1 ; $i<=$nbI ; $i++) { + if (!empty($sess->values['vais'][$i])) { + if ($sess->values['vais'][$i] > $queryPlanete['vaisseau_'.$i]) { + $template->assign('message','Vous avez envoyé plus de vaisseaux que vous n\'en posséder sur cette planète.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $req .= "'".$sess->values['vais'][$i]."', "; + $reqb .= "`vaisseau_$i`, "; + if (!empty($reqPlan)) $reqPlan .= ', '; + $reqPlan .= "`vaisseau_$i` = `vaisseau_$i` - '".$sess->values['vais'][$i]."'"; + $nbVais += $sess->values['vais'][$i]; + } + } + } + if ($nbVais <= 0) { + $template->assign('message','Vous devez envoyer au moins un vaisseau pour former une flotte !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + elseif ($sess->values['flnbvais'] != $nbVais) { + $template->assign('message','Une erreur est survenue lors de la création de la flotte :

    Calcul du nombre de vaisseaux incorrect !

    Si le problème perciste, contactez un administrateur.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + //Envoie de la flotte + $nom = mysql_real_escape_string(htmlentities($_POST['nomflotte'])); + + $start_time = time(); + $start_galaxie = $queryPlanete['galaxie']; + $start_ss = $queryPlanete['ss']; + $start_pos = $queryPlanete['position']; + + $vitesse = floor($_POST['vitesse'])/100; + + $end_time = vais_tempsDeplacement($start_galaxie, $start_ss, $start_pos, $end_galaxie, $end_ss, $end_pos, $sess->values['flvitesse'], $vitesse, $sess->values['flpreparation'], $sess->values['flchauffe']); + if ($end_time <= 0) { + $end_time = 454; + } + + //On vérifie qu'il y a assez de place dans les cales des vaisseaux avant l'envoie + $conso = vais_conso($end_time, $sess->values['flnbvais'])*$vitesse*10; + $contenu_metal = $_POST['metal']; $plan_metal = $queryPlanete['metal'] - $_POST['metal']; + $contenu_cristal = $_POST['cristal']; $plan_cristal = $queryPlanete['cristal'] - $_POST['cristal']; + $contenu_hydrogene = $_POST['hydrogene']; $plan_hydrogene = $queryPlanete['hydrogene'] - $_POST['hydrogene'] - $conso; + $contenu_max = $sess->values['flcontenu']; + if ($contenu_metal + $contenu_cristal + $contenu_hydrogene + $conso > $contenu_max && ($contenu_metal + $contenu_cristal + $contenu_hydrogene != 0 || $mission != 5)) { + $template->assign('message','Vous ne pouvez pas embarquer autant de ressources, les cales débordent.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + if ($mission == 1) { + $tactiqueAT = $_POST['tactique']; + $tactiqueEN = $resultatu['tactique']; + } + else { + $tactiqueAT = 0; + $tactiqueEN = 0; + } + + $table = $config['db_prefix'].'flottes'; + $chapeau->query("INSERT INTO `$table` (`id_user`, `mission`, `start_time`, `start_galaxie`, `start_ss`, `start_position`, `end_time`, `end_galaxie`, `end_ss`, `end_position`, `vitesse`, `contenu_metal`, `contenu_cristal`, `contenu_hydrogene`, `contenu_max`, `nb_vais`, $reqb`tactiqueAT`, `tactiqueEN`, `nom`) VALUES ('$id_user', '$mission', '$start_time', '$start_galaxie', '$start_ss', '$start_pos', '$end_time', '$end_galaxie', '$end_ss', '$end_pos', '$vitesse', '$contenu_metal', '$contenu_cristal', '$contenu_hydrogene', '$contenu_max', '$nbVais', $req'$tactiqueAT', '$tactiqueEN', '$nom');"); + $table = $config['db_prefix'].'planete'; + $chapeau->query("UPDATE `$table` SET $reqPlan, `metal` = '$plan_metal', `cristal` = '$plan_cristal', `hydrogene` = '$plan_hydrogene' WHERE `id` = '$idPlan' LIMIT 1 ;"); + + unset($sess->values['vais']); + $sess->put(); + + $template->assign('message','Votre flotte a été envoyée avec succès.'); + $template->assign('couleur','green'); + $template->assign('script',''); + $template->display('game/erreur.tpl'); + exit; + } + } + } +} +elseif (!empty($_POST['v1']) || !empty($_POST['v2']) || !empty($_POST['v3']) || !empty($_POST['v4']) || !empty($_POST['v5']) || !empty($_POST['v6']) || !empty($_POST['v7']) || !empty($_POST['v8']) || !empty($_POST['v9']) || !empty($_POST['v10']) || !empty($_POST['v11']) || !empty($_POST['v12'])) { + $nombreVaisseau = 0; + for ($i=1 ; $i<=12 ; $i++) { + if (!isset($_POST['v'.$i]) || !is_numeric($_POST['v'.$i]) || $_POST['v'.$i] != abs(floor($_POST['v'.$i]))) $_POST['v'.$i] = 0; + if ($_POST['v'.$i] >= 0 && $i != 11) { + $sess->values['vais'][$i] = $_POST['v'.$i]; + $nombreVaisseau += $_POST['v'.$i]; + //Si on indique un nombre de vaisseaux supérieur au nombre présent sur la planète + if ($_POST['v'.$i] > $queryPlanete['vaisseau_'.$i]) { + $template->assign('message','Il ne vous reste plus assez de vaisseaux !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + } + $sess->values['flnbvais'] = $nombreVaisseau; + $sess->values['forceFlotte'] = false; + + //On vérifie que l'utilisateur a bien envoyé plus d'un vaisseau + if ($nombreVaisseau <= 0) { + $template->assign('message','Vous devez envoyer au moins un vaisseau.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + + //On ajoute des missions supplémentaire suivant les vaisseaux envoyés + $lvltactique = $queryUser['tactique']; + $actionsupp = ''; + if ($lvltactique >= 1) $actionsupp .= ''; + if ($_POST['v3'] >= 1) $actionsupp .= ''; + if ($_POST['v5'] >= 1) $actionsupp .= ''; + if ($_POST['v4'] >= 1) $actionsupp .= ''; + $template->assign('actionsupp', $actionsupp); + + // Définition des paramètres de la flotte + $AvaisType = array(); $AvaisVitesseC = array(); $AvaisVitesseL = array(); $AvaisPrepC = array(); $AvaisPrepL = array(); $AvaisChauffe = array(); $AvaisContenu = 0; + for ($i=1 ; $i<=12 ; $i++) { + $AvaisType[] = $i; + $AvaisVitesseC[] = $nomvais_dc[$i-1]; + $AvaisVitesseL[] = $nomvais_dl[$i-1]; + $AvaisContenu += $nomvais_rs[$i-1] * $_POST['v'.$i]; + $AvaisPrepC[] = $nomvais_pdc[$i-1].' '; + $AvaisPrepL[] = $nomvais_pdl[$i-1].' '; + $AvaisChauffe[] = $nomvais_cdl[$i-1].' '; + } + if(min($AvaisVitesseL) != 0) { + $sess->values['flvitesse'] = max($AvaisVitesseL); + $sess->values['flpreparation'] = max($AvaisPrepL); + $sess->values['flchauffe'] = max($AvaisChauffe); + } + else { + $sess->values['flvitesse'] = max($AvaisVitesseC); + $sess->values['flpreparation'] = max($AvaisPrepC); + $sess->values['flchauffe'] = 0; + } + $sess->values['fltime'] = time(); + $sess->values['flcontenu'] = $AvaisContenu; + + //On enregistre les modification de la session + $sess->put(); + + $page = 'flotte2'; + $template->assign('scripth', ''); + $template->assign('script', ''); + +} +elseif (!empty($_GET['n'])) { + $idN = mysql_real_escape_string(ceil($_GET['n'])); + $page = 'flotten'; + $table = $config['db_prefix'].'flottes'; + $resultat = $chapeau->unique_query("SELECT * FROM `$table` WHERE `id_user` = '$id_user' AND `id` = '$idN'"); + if ($chapeau->num_rows <= 0) { + $template->assign('message','Impossible de trouver cette flotte !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + if (!empty($_POST['nomflotte'])) { + $nom = mysql_real_escape_string(htmlentities($_POST['nomflotte'])); + $chapeau->unique_query("UPDATE `$table` SET `nom` = '$nom' WHERE `id` = '$idN' LIMIT 1 ;"); + $resultat['nom'] = $nom; + } + $template->assign('flotte', $resultat); + $template->assign('nomvais', $nomvaisa); + $template->assign('n', $idN); + } +} +else { + $page = 'flotte1'; + $table = $config['db_prefix'].'flottes'; + $resultat = $chapeau->query("SELECT * FROM `$table` WHERE `id_user` = '$id_user'"); + $nbr = $chapeau->num_rows; + $TEMP_flottesEC = array(); + for ($i=0 ; $i<$nbr ; $i++) { + if ($resultat[$i]['mission'] != 1 && ($resultat[$i]['mission'] != 3 || $resultat[$i]['effectue'] == '1' || $resultat[$i]['nb_vais'] >= 1) && $resultat[$i]['mission'] != 0) { + $retour = $resultat[$i]['start_galaxie'].':'.$resultat[$i]['start_ss'].':'.$resultat[$i]['start_position']; + $Hretour = date('d/m H:i:s',$resultat[$i]['start_time']+2*$resultat[$i]['end_time']); + } + elseif ($resultat[$i]['mission'] == 1) { + $retour = $resultat[$i]['start_galaxie'].':'.$resultat[$i]['start_ss'].':'.$resultat[$i]['start_position']; + if (empty($resultat[$i]['ret_time'])) $Hretour = '-'; + else $Hretour = date('d/m H:i:s',$resultat[$i]['ret_time']+$resultat[$i]['end_time']); + } + else { + $retour = '-'; + $Hretour = '-'; + } + $TEMP_flottesEC[] = array($resultat[$i]['id'], $resultat[$i]['nom'], txtmission($resultat[$i]['mission']), $resultat[$i]['nb_vais'], $resultat[$i]['end_galaxie'].':'.$resultat[$i]['end_ss'].':'.$resultat[$i]['end_position'], date('d/m H:i:s',$resultat[$i]['start_time']+$resultat[$i]['end_time']), $retour, $Hretour); + } + $template->assign('flottesEC', $TEMP_flottesEC); + + $TEMP_vaisseaux = array(); + $j=0; + for ($i=1 ; $i<=12 ; $i++) { + if ($queryPlanete['vaisseau_'.$i] > 0 && $i != 11) { + $j++; + $TEMP_vaisseaux[] = array($nomvaisa[$i-1], separerNombres($queryPlanete['vaisseau_'.$i]), $queryPlanete['vaisseau_'.$i], $i); + } + } + $template->assign('vaisseaux', $TEMP_vaisseaux); + + $trez = $queryUser["informatique"] + 1; + if ($nbr < $trez) $template->assign('action', ''); + else $template->assign('action', 'Nombre de flottes maximum simultaniées atteint'); + + $template->assign('nbflotte', $nbr); + $template->assign('nbflottemax', $trez); +} +?> diff --git a/game/inscription.php b/game/inscription.php new file mode 100644 index 0000000..e419c9f --- /dev/null +++ b/game/inscription.php @@ -0,0 +1,142 @@ +connexion(); + $base->db(); + + $pseudo = mysql_real_escape_string(htmlentities($_POST['HB_pseudo'])); + $mdp = $_POST['HB_mdp']; + $mdpconf = $_POST['HB_conf']; + $mail = mysql_real_escape_string(htmlentities($_POST['HB_mail'])); + if (!isset($_POST['race'])) $_POST['race'] = ''; + $race = mysql_real_escape_string(htmlentities($_POST['race'])); + $server = mysql_real_escape_string(htmlentities($_POST['servers'])); + $captcha = mysql_real_escape_string(htmlentities($_POST['HB_captcha'])); + $placement = mysql_real_escape_string(htmlentities($_POST['HB_placement'])); + if (!isset($_POST['regles'])) $_POST['regles'] = ''; + $regles = htmlentities($_POST['regles']); + + //Vérification relative au pseudo : caractéres utilisés + disponibilité + if (addslashes(preg_replace('@[^a-zA-Z0-9_]@i', '', $pseudo)) != $pseudo || $pseudo == '') { + $inscriptOk = false; + $erreurs .= '

    Le pseudo contient des caractères incorrects.
    Les caractères autorisés sont les lettres minuscules ou majuscules de A à Z sans les accents, ainsi que les chiffres et les caractères . _


    '; + } + else { + $result = mysql_query("SELECT `pseudo` FROM `user_inscriptions` WHERE pseudo = '$pseudo'"); + if(mysql_num_rows($result) >= 1) { + $inscriptOk = false; + $erreurs .= '

    Le pseudo est déjà utilisé par un joueur.
    Vous devez choisir un autre pseudo.


    '; + } + } + + //Vérification du mot de passe : + if ($mdp == '' || $mdp != $mdpconf) { + $inscriptOk = false; + $erreurs .= '

    Mots de passe différents ou ne comportant pas assez de caractères
    Vous devez impérativement choisir un mot de passe pour sécuriser votre compte. Si vous avez spécifié un mot de passe, il se peut que vous n\'ayez pas indiqué le même mot de passe dans la case de confirmation.


    '; + } + + //Vérification relative au mail : caractéres utilisés + disponibilité + if (!preg_match('#^[a-z0-9._-]+@[a-z0-9._-]{2,}\.[a-z]{2,4}$#i', $mail) || empty($mail)) { + $inscriptOk = false; + $erreurs .= '

    L\'adresse électronique n\'est pas valide.
    L\'adresse électronique que vous avez tappé est invalide ou contient des caractères interdits, recommencez.


    '; + } + else { + $result = mysql_query("SELECT mail FROM `user_inscriptions` WHERE mail='$mail'"); + if(mysql_num_rows($result) >= 1) { + $inscriptOk = false; + $erreurs .= '

    L\'adresse électronique que vous avez indiqué est déjà associée à un compte.
    Vous devez choisir une autre adresse électronique.


    '; + } + } + + //Vérification de la race choisie + if ($race != 'covenant' && $race != 'humain') { + $inscriptOk = false; + $erreurs .= '

    Aucune race choisie
    Vous devez choisir la race que vous désirez incarner dans le jeu.


    '; + } + + //Vérification du serveur + if (is_numeric($server) && $server > 1) { + $inscriptOk = false; + $erreurs .= '

    Galaxie incorrecte
    Vous devez choisir une galaxie (un serveur) dans la liste ci-dessous pour pouvoir jouer.


    '; + } + + //Vérification du partenaire + if (!empty($placement)) { + $result = mysql_query("SELECT `pseudo` FROM `user_inscriptions` WHERE pseudo = '$placement'"); + if(mysql_num_rows($result) == 0) { + $inscriptOk = false; + $erreurs .= '

    Impossible de trouver le joueur ami.
    Vous devez choisir un autre pseudo.


    '; + } + } + + //Vérification du captcha + if (empty($sess->values['aleatnbr']) && isset($_SESSION['aleat_nbr'])) { + $sess->values['aleatnbr'] = $_SESSION['aleat_nbr']; + } + if (empty($sess->values['aleatnbr']) || empty($captcha) || $sess->values['aleatnbr'] != strtolower($captcha)) { + $inscriptOk = false; + $erreurs .= '

    Code de vérification incorrect :
    Le texte que vous avez recopier ne correspondait pas au texte de l\'image, veuillez recommencer.


    '; + } + + //Vérification du captcha + if (empty($regles) || $regles != '1') { + $inscriptOk = false; + $erreurs .= '

    Vous devez accepter les conditions générales
    '; + } + + if ($inscriptOk) { + $time = time(); + $ip = $_SERVER["REMOTE_ADDR"]; + + // Activer la ligne suivante pour crypter les mots de passe dans la base de données + $mdp = sha1(strtoupper($pseudo).':'.$mdp); // Cryptage du mot de passe pour éviter le piratage de compte + + $id_activ = sha1('H'.rand().'/|\\'.rand().'B£'); + $Nmail = $mail; + + //On envoie le mail de confirmation + $mail = new PHPmailer(); + $mail->SetLanguage('fr', 'Class/'); + $mail->IsSMTP(); + $mail->IsHTML(true); + $mail->Host='s-fr.com'; + $mail->From='no-reply@halo-battle.s-fr.com'; + $mail->FromName='Halo-Battle'; + $mail->SMTPAuth=true; + $mail->Username='no-reply@halo-battle.s-fr.com'; + $mail->Password='hD3e2nXu'; + + $mail->AddAddress($Nmail); + $mail->AddReplyTo('no-reply@halo-battle.s-fr.com'); + $mail->Subject='Halo-Battle :: Activation de votre compte'; + //$mail->Subject='Halo-Battle :: Pre-Inscription'; + $mail->Body=htmlentities('Halo-Battle :: Activation de votre compte

    Bonjour '.$pseudo.',
    Vous recevez ce mail suite à votre demande d\'inscription sur le jeu Halo-Battle. Pour confirmer votre adresse mail et ainsi pouvoir accéder au jeu, cliquez sur le lien ci-après :
    http://halo-battle.s-fr.com/?p=validation&i='.$id_activ.'

    A bientôt dans Halo-Battle,
    Le staff

    '); + //$mail->Body='Halo-Battle :: Pré-Inscription

    Félicitations '.$pseudo.' !
    Votre compte vient d'être enregistré sur notre serveur. Un mail de confirmation vous sera envoyé lors de la sortie du jeu en ligne Halo-Battle. Si vous ne recevez pas l\'email de confirmation, contactez un administrateur.

    A très bientôt pour la sortie d'Halo-Battle !

    '; + + if(!$mail->Send()){ + $template->assign('message','Erreur lors de l\'envoie du courriel de confirmation !

    '.$mail->ErrorInfo.'

    Si le problème perciste, contactez un administrateur.'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + else{ + mysql_query("INSERT INTO `user_inscriptions` (`id_activ`, `pseudo`, `race`, `mdp`, `mail`, `last_ip`, `placement`, `time_inscription`, `last_visite`) VALUES ('$id_activ', '$pseudo', '$race', '$mdp', '$Nmail', '$ip', '$placement', '$time', '$time')") or die ('MYSQLERREUR'.mysql_error()); + $template->assign('message','Félécitations, votre compte vient d\'être créé sur le serveur '.$server.' de Halo-Battle.

    Un courriel de confirmation vient d\'être envoyé à votre adresse électronique afin de valider votre inscription au jeu en ligne Halo-Battle.

    N\'attendez-plus, commencez le combat dès à présent !'); + $template->assign('couleur','green'); + $template->display('cms/erreur.tpl'); + exit; + } + $mail->SmtpClose(); + unset($mail); + } + $base->deconnexion(); +} +$template->assign('erreurs',$erreurs); +?> \ No newline at end of file diff --git a/game/laboratoire.php b/game/laboratoire.php new file mode 100644 index 0000000..d278a5b --- /dev/null +++ b/game/laboratoire.php @@ -0,0 +1,119 @@ +limite = $queryUser['prodfile']+2; + } + + if ($queryPlanete['labo'] == 0) { + $template->assign('message','Vous devez d\'abord construire un '.strtolower($batiment[6])); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + //Lancement d'une nouvelle construction + if (isset($_GET['t']) && isset($technolo[$_GET['t']])) { + $i = $_GET['t']; + if(requestDeblok($technoloTECH[$i], $queryPlanete, $queryUser)) { + $n=($queryUser[$technoloVAR[$i]]+1); + eval($technoloCALC[$i][0]); $metal -= $a; + eval($technoloCALC[$i][1]); $cristal -= $b; + eval($technoloCALC[$i][2]); $hydrogene -= $c; + if ($metal < 0 || $cristal < 0 || $hydrogene < 0) { + $template->assign('message','Vous n\'avez pas assez de ressources pour effectuer cette recherche.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + eval($technoloCALC[$i][3]); + if ($fileT->addObjet($i, 1, ceil($sec))) { + $export = mysql_real_escape_string(serialize($fileT)); + mysql_query("UPDATE `planete` SET `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene', `file_tech` = '$export' WHERE `id` = '$idPlan';"); + } + else { + $template->assign('message','Vous ne pouvez pas mettre plus de recherche en file d\'attente.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + header('Location: ?p=laboratoire'); + exit; + } + } + //Annulation d'une nouvelle construction + if (isset($_GET['a']) && isset($technolo[$_GET['a']])) { + $i = $_GET['a']; + if($fileT->existe($i)) { + $n=($queryUser[$technoloVAR[$i]]+1); + eval($technoloCALC[$i][0]); $metal += $a; + eval($technoloCALC[$i][1]); $cristal += $b; + eval($technoloCALC[$i][2]); $hydrogene += $c; + $fileT->delobjet($i); + $export = mysql_real_escape_string(serialize($fileT)); + mysql_query("UPDATE `planete` SET `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene', `file_tech` = '$export' WHERE `id` = '$idPlan';"); + header('Location: ?p=laboratoire'); + exit; + } + } + //Règler la production à la châine +/* if (isset($_GET['r']) && ($_GET['r'] == 1 || $_GET['r'] == 0)) { + if($_GET['r']) $fileT->chaine = false; + else $fileT->chaine = true; + $export = mysql_real_escape_string(serialize($fileT)); + mysql_query("UPDATE `planete` SET `file_tech` = '$export' WHERE `id` = '$id_user';"); + header('Location: ?p=laboratoire'); + exit; + }*/ + + for ($i=0 ; $i<$nbstop ; $i++) { + $tr = 0; $a = 0; $b = 0; $c = 0; $sec = 0; + $nom_bdd = $technoloVAR[$i]; + if ($queryUser[$nom_bdd] > 0) $niveau = $queryUser[$nom_bdd]; else $niveau = 0; + $n=($queryUser[$nom_bdd]+1); eval($technoloCALC[$i][0]); eval($technoloCALC[$i][1]); eval($technoloCALC[$i][2]); eval($technoloCALC[$i][3]); + if (!empty($technolo[$i]) && requestDeblok($technoloTECH[$i], $queryPlanete, $queryUser)) $TEMP_recherches[] = + array( + 'image' => $technoli[$i], + 'nom' => $technolo[$i], + 'niveau' => $niveau, + 'description' => $technode[$i], + 'descriptione' => addslashes($technode[$i]), + 'nec_metal' => $a, + 'nec_cristal' => $b, + 'nec_hydrogene' => $c, + 'nec_metalS' => separerNombres($a), + 'nec_cristalS' => separerNombres($b), + 'nec_hydrogeneS' => separerNombres($c), + 'num' => $i, + 'temps' => sec($sec), + 'maq_metal' => ceil($a-$metal), + 'maq_cristal' => ceil($b-$cristal), + 'maq_hydrogene' => ceil($c-$hydrogene) + ); + } + $template->assign('recherches',$TEMP_recherches); + + $template->assign('chaine',$fileT->chaine); + $fileTech = $fileT->file; + $nbfile = count($fileTech); + + if ($nbfile == 1) $template->assign('Pchaine',true); + else $template->assign('Pchaine',false); + if ($nbfile == 0) $template->assign('Vchaine',true); + else $template->assign('Vchaine',false); + + for ($i=0 ; $i<$nbfile ; $i++) { + $fileTech[$i][3] = $technolo[$fileTech[$i][0]]; + if ($i == 0) $fileTech[$i][2] -= time() - $fileT->timestamp; + } + $template->assign('file',$fileTech); +?> \ No newline at end of file diff --git a/game/logout.php b/game/logout.php new file mode 100644 index 0000000..4123c01 --- /dev/null +++ b/game/logout.php @@ -0,0 +1,9 @@ +values['connected'] = FALSE; +$sess->put(); + +header('Location: ./'); +exit; +?> \ No newline at end of file diff --git a/game/messagerie.php b/game/messagerie.php new file mode 100644 index 0000000..e9f5d46 --- /dev/null +++ b/game/messagerie.php @@ -0,0 +1,54 @@ +assign('messages', $TEMP_messages); +$template->assign('IM', $i); + +$result = mysql_query("SELECT * FROM mail WHERE `destinataire` = '".$queryUser["pseudo"]."' AND `expediteur` = '' AND `vu` != 's' ORDER BY id DESC"); +$TEMP_rapport = array(); +$i=0; +while ($data = mysql_fetch_array($result)) { + $i++; + $TEMP_rapport[] = array($data['sujet'], date("d/m/y H:i:s", $data['temps']), 0, bbcode($data['contenu']), $i, $data['id']); +} +$template->assign('rapports', $TEMP_rapport); +$template->assign('IR', $i); +$template->assign('script', ''); + +mysql_query("UPDATE mail SET vu='0' WHERE `destinataire` = '".$queryUser["pseudo"]."' AND `vu` != 's'"); +?> \ No newline at end of file diff --git a/game/njoueur.php b/game/njoueur.php new file mode 100644 index 0000000..34bf242 --- /dev/null +++ b/game/njoueur.php @@ -0,0 +1,175 @@ +connexion(); + $base->db(); + + $pseudo = mysql_real_escape_string($_GET['nom']); + $mdp = mysql_real_escape_string($_GET['mdp']); + $race = mysql_real_escape_string($_GET['race']); + $mail = mysql_real_escape_string($_GET['mail']); + $ti = mysql_real_escape_string($_GET['ti']); + + $base->query("SELECT * FROM `user` WHERE `pseudo` = '$pseudo' ORDER BY `id` DESC;"); + if ($base->num_rows) { + $template->assign('message','Votre compte est déjà créé sur ce serveur !'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + + //Création de l'utilisateur + $base->query("INSERT INTO `user` (`pseudo`, `mdp`, `race`, `mail`, `last_ip`, `time_inscription`) VALUES ('$pseudo', '$mdp', '$race', '$mail', '".$_SERVER['REMOTE_ADDR']."', '".time()."');"); + + //Création des bases de la planète + $image = mt_rand(1,15); + $cases = mt_rand(150,250); + $queryUser = $base->query("SELECT * FROM `user` WHERE `pseudo` = '$pseudo' ORDER BY `id` DESC;"); + $id_user = $queryUser[0]['id']; + $time = time(); + + //Recherche d'une planète disponible + if (empty($_GET['placement'])) { + $planete_trouvee = false; + while (!$planete_trouvee) { + $galaxie = mt_rand(1, MAX_AMAS); + $ss = mt_rand(1, MAX_SYSTEME); + $pos = mt_rand(1, MAX_PLANETE); + + //Test pour savoir si la planète est déjà habitée + $base->query("SELECT id FROM `planete` WHERE galaxie='$galaxie' AND ss='$ss' AND position='$pos'"); + if($base->num_rows) $planete_trouvee = false; + else $planete_trouvee = true; + } + + $base->query("INSERT INTO `planete` (`id_user`, `nom_planete`, `galaxie`, `ss`, `position`, `image`, `cases`, `timestamp`, `metal`, `cristal`) VALUES ('$id_user', 'Planète mère', '$galaxie', '$ss', '$pos', '$image', '$cases', '$time', '1000', '700')"); + } + else { + $placement_joueur = $base->unique_query("SELECT * FROM `user` WHERE `pseudo` = '".mysql_real_escape_string($_GET["placement"])."'"); + if (!$placement_joueur && !isset($sess->values['forceInscript'])) { + $sess->values['forceInscript'] = true; + $sess->put(); + $template->assign('message','Le joueur à côté duquel vous souhaitez être placé n\'est pas encore ou plus inscrit sur ce serveur.

    Si vous ne souhaitez plus être placé à ses côtés, rechargez la page.'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + if (!isset($sess->values['forceInscript'])) { + $placement_planetes = $base->query("SELECT * FROM `planete` WHERE `id_user` = '".$placement_joueur["id"]."'"); + $planete_trouvee = false; + $decale = 0; + while (!$planete_trouvee) { + for($i = 0; $i < $base->num_rows ; $i++){ + $galaxie = $placement_planetes[$i]['galaxie']; + $ss = $placement_planetes[$i]['ss'] + $decale; + if ($ss >= MAX_SYSTEME) break; + for ($j = 1; $j <= MAX_PLANETE ; $j++) { + $base->query("SELECT * FROM `planete` WHERE galaxie='$galaxie' AND ss='$ss' AND position='$j'"); + if(!$base->num_rows) { + $planete_trouvee = true; + $blk_galaxie = $galaxie; + $blk_ss = $ss; + $blk_pos = $j; + break; + } + } + if ($planete_trouvee) break; + } + $decale++; + if ($ss >= MAX_SYSTEME) break; + } + + if (!$planete_trouvee) $impplac = true; + } + + if (!$planete_trouvee || ($planete_trouvee && !empty($sess->values['forceInscript']))) { + while (!$planete_trouvee) { + $blk_galaxie = mt_rand(1, MAX_AMAS); + $blk_ss = mt_rand(1, MAX_SYSTEME); + $blk_pos = mt_rand(1, MAX_PLANETE); + + //Test pour savoir si la planète est déjà habitée + $base->query("SELECT id FROM `planete` WHERE galaxie='$blk_galaxie' AND ss='$blk_ss' AND position='$blk_pos'"); + if($base->num_rows) $planete_trouvee = false; + else $planete_trouvee = true; + } + } + $base->query("INSERT INTO `planete` (`id_user`, `nom_planete`, `galaxie`, `ss`, `position`, `image`, `cases`, `timestamp`, `metal`, `cristal`) VALUES ('$id_user', 'Planète mère', '$blk_galaxie', '$blk_ss', '$blk_pos', '$image', '$cases', '$time', '1000', '700')"); + } + $base->deconnexion(); + + if (!empty($impplac)) { + $template->assign('message','Impossible de trouver une planète proche du joueur près duquel vous vouliez être placé.
    Vous avez été placé aléatoirement.'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + else { + $template->assign('message','Vous pouvez maintenant vous connectez sur ce serveur !'); + $template->assign('script',''); + $template->assign('couleur','green'); + $template->display('cms/erreur.tpl'); + exit; + } + } + else { + $template->assign('message','Impossible d\'authentifier votre inscription !

    Si le problème perciste, contactez un administrateur.'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + } + else { + $template->assign('message','Impossible de terminer votre inscription, il manque des données !

    Si le problème perciste, contactez un administrateur.'); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } +} +else header('Location: ./'); +exit; + $time = time(); + $ip = $_SERVER["REMOTE_ADDR"]; +// Activer la ligne suivante pour crypter les mots de passe dans la base de données + $mdp = sha1(strtoupper($pseudo).':'.$mdp); // Cryptage du mot de passe pour éviter le piratage de compte + + $planete_trouvee = false; + while ($planete_trouvee != true) { + $galaxie = 1; + //$galaxie = mt_rand(2,4); + $ss = mt_rand(1,100); + $pos = mt_rand(1,12); + + // Test pour savoir si la planète est déjà habitée + $result = mysql_query("SELECT id FROM planete WHERE galaxie='$galaxie' AND ss='$ss' AND position='$pos'"); + if(mysql_num_rows($result)>=1) $planete_trouvee = false; + else $planete_trouvee = true; + } + $image = mt_rand(1,15); + + mysql_query("INSERT INTO user (`pseudo`, `race`, `mdp`, `mail`, `last_ip`, `time_inscription`, `last_visite`) VALUES ('$pseudo', '$race', '$mdp', '$mail', '$ip', '$time', '$time')") or die ("erreur sql ".mysql_error()); + $req = mysql_query("SELECT id FROM user WHERE pseudo='$pseudo'"); + $resultat = mysql_fetch_array($req); + $id_user = $resultat['id']; + $cases = mt_rand(150,250); + mysql_query("INSERT INTO planete (`id_user`, `nom_planete`, `galaxie`, `ss`, `position`, `image`, `cases`, `timestamp`, `metal`, `cristal`) VALUES ('$id_user', 'Planète mère', '$galaxie', '$ss', '$pos', '$image', '$cases', '$time', '1000', '700')") or die ("erreur sql ".mysql_error()); + + include('template.php'); + $template = new Template('./'); + $template->set_filenames(array('index' => 'templates/index.tpl')); +$login = '
    + + + + +
    :: Pseudo :: 
    :: Mot de Passe :: 

    +
    +
    '; +$texte = '


    Votre inscription a bien été prise en compte.

    Vous pouvez dès maintenant utiliser le formulaire de connexion ci-contre pour accèdez à la béta de Halo-Battle.

    Bon jeu !'; + $template->assign_vars(array('TITRE' => 'Inscription validée','TEXTE' => $texte,'LOGIN' => $login)); + $template->pparse('index'); +?> \ No newline at end of file diff --git a/game/options.php b/game/options.php new file mode 100644 index 0000000..445aec9 --- /dev/null +++ b/game/options.php @@ -0,0 +1,207 @@ +assign('page',$page); + $template->assign('titre',$titre); + +$pseudo = $queryUser['pseudo']; +$mailUtil = $queryUser['mail']; +$mdp = $queryUser['mdp']; + +if (isset($_GET['a']) && $_GET['a'] == 'mv' && isset($_GET['n']) && $_GET['n'] == $sess->values['idvac']) { + $impossible = false; + include_once('Class/class.gerefile.php'); + $nbPlan = count($queryPlanetes); + for ($i=0 ; $i<$nbPlan ; $i++) { + $file = unserialize($queryPlanetes[$i]['file_bat']); + if (!empty($queryPlanetes[$i]['file_bat']) && count($file->file)) $impossible = true; + + $file = unserialize($queryPlanetes[$i]['file_tech']); + if (!empty($queryPlanetes[$i]['file_tech']) && count($file->file)) $impossible = true; + + $file = unserialize($queryPlanetes[$i]['file_cas']); + if (!empty($queryPlanetes[$i]['file_cas']) && count($file->file)) $impossible = true; + + $file = unserialize($queryPlanetes[$i]['file_vais']); + if (!empty($queryPlanetes[$i]['file_vais']) && count($file->file)) $impossible = true; + + $file = unserialize($queryPlanetes[$i]['file_ter']); + if (!empty($queryPlanetes[$i]['file_ter']) && count($file->file)) $impossible = true; + } + + if ($impossible) { + $template->assign('message','Impossible d\'activer le mode vacances.
    Toutes les files d\'attentes sur vos différentes planètes ne sont pas vides.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $chapeau->query("SELECT * FROM `flottes` WHERE `id_user` = '$id_user'"); + if ($chapeau->num_rows) { + $template->assign('message','Des flottes sont actuellement en mission, veuillez toutes les faire revenir à quai avant d\'activer le mode vacances.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + + $chapeau->query("UPDATE `user` SET `mv` = '1' WHERE `id` = '$id_user'"); + $sess->values['connected'] = FALSE; + $sess->put(); + + $template->assign('message','Le mode vacances est maintenant actif sur votre compte.

    Vous pourez vous reconnecter sur votre compte à partir de
    '.strftime("%A %d %B à %H:%M", $queryUser['last_visite']+259200).'

    Bonnes vacances !'); + $template->assign('script',''); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } +} +if (isset($_GET['chg']) && $_GET['chg'] == 'mdp') { + if (isset($_POST['mdp_anc']) && isset($_POST['mdp_nouv']) && isset($_POST['mdp_conf']) && !empty($_POST['mdp_anc']) && !empty($_POST['mdp_nouv']) && !empty($_POST['mdp_conf'])) { + if(sha1(strtoupper($pseudo).':'.$_POST['mdp_anc']) == $mdp) { + if ($_POST['mdp_nouv'] == $_POST['mdp_conf']) { + $password = htmlspecialchars(mysql_escape_string($_POST['mdp_nouv'])); + $password = sha1(strtoupper($pseudo).':'.$password); + $auth = sha1($password); + mysql_query("UPDATE `user` SET `mdpNOUV` = '$password' WHERE `id` = '$id_user'"); + + //On envoie le mail de confirmation + $mail = new PHPmailer(); + $mail->SetLanguage('fr', 'Class/'); + $mail->IsSMTP(); + $mail->IsHTML(true); + $mail->Host='s-fr.com'; + $mail->From='Halo-Battle '; + $mail->SMTPAuth=true; + $mail->Username='no-reply@halo-battle.s-fr.com'; + $mail->Password='hD3e2nXu'; + + $mail->AddAddress($mailUtil); + $mail->AddReplyTo('no-reply@halo-battle.s-fr.com'); + $mail->Subject='Halo-Battle :: Activation de votre nouveau mot de passe'; + $mail->Body='Halo-Battle :: Activation de votre nouveau mot de passe

    Bonjour '.trouvNom($id_user).',
    Vous recevez ce mail suite à votre demande de changement de mot de passe. Ce dernier entrera en vigueur une fois que vous aurez valider ce changement en cliquant via ce lien :
    http://battle.halo.fr/pages/options_validation.php?chg=activation&util='.$id_user.'&auth='.$auth.'
    Notez que pour que le mot de passe soit changé, il faut que vous soyer connecté sur votre compte.

    A bientôt dans Halo-Battle,
    Le staff

    '; + + if(!$mail->Send()){ //Teste si le return code est ok. + $template->assign('message','Erreur lors de l\'envoie du courriel de confirmation !

    '.$mail->ErrorInfo.'

    Si le problème perciste, contactez un administrateur.'); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else{ + $template->assign('message','Un courriel vient d\'être envoyé à '.$mailUtil.'. Le mot de passe ne sera modifié qu\'après avoir cliqué sur le lien d\'activation contenu dans ce courriel.'); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + $mail->SmtpClose(); + unset($mail); + } + else { + $template->assign('message','Le nouveau mot de passe que vous avez entré ne correspond pas à sa confirmation.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + else { + $template->assign('message','L\'ancien mot de passe que vous avez tapé n\'est pas correct.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + else { + $template->assign('message','Veuillez remplir tous les champs avant de valider le formulaire.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } +} +elseif (isset($_GET['chg']) && $_GET['chg'] == 'mail') { + if (isset($_POST['mail']) && !empty($_POST['mail'])) { + $Nmail = htmlspecialchars(mysql_escape_string($_POST['mail'])); + if (preg_match("#^[a-z0-9._-]+@[a-z0-9._-]{2,}\.[a-z]{2,4}$#", $Nmail)) { + $result = mysql_query("SELECT `mail` FROM `user` WHERE `mail` = '$Nmail'"); + if(mysql_num_rows($result) >= 1) { + header('Location: options.php?erreur=5'); + exit; + } + else { + $auth = sha1($Nmail); + mysql_query("UPDATE `user` SET `mailNOUV` = '$Nmail' WHERE `id` = '$id_user'"); + + //On envoie le mail de confirmation + $mail = new PHPmailer(); + $mail->SetLanguage('fr', 'Class/'); + $mail->IsSMTP(); + $mail->IsHTML(true); + $mail->Host='s-fr.com'; + $mail->From='Halo-Battle '; + $mail->SMTPAuth=true; + $mail->Username='no-reply@halo-battle.s-fr.com'; + $mail->Password='hD3e2nXu'; + + $mail->AddAddress($Nmail); + $mail->AddReplyTo('no-reply@halo-battle.s-fr.com'); + $mail->Subject='Halo-Battle :: Activation de votre nouvelle adresse électronique'; + $mail->Body='Halo-Battle :: Activation de votre nouvelle adresse électronique

    Bonjour,
    Vous recevez ce mail suite à votre demande de changement d\'adresse électronique. Cette dernière entrera en vigueur une fois que vous aurez valider ce changement en cliquant via ce lien :
    http://battle.halo.fr/pages/options_validation.php?chg=activation&util='.$id_user.'&auth='.$auth.'
    Notez que pour que l\'adresse soit changée, il faut que vous soyer connecté sur votre compte.

    A bientôt dans Halo-Battle,
    Le staff

    '; + + if(!$mail->Send()){ //Teste si le return code est ok. + $template->assign('message','Erreur lors de l\'envoie du courriel de confirmation !

    '.$mail->ErrorInfo.'

    Si le problème perciste, contactez un administrateur.'); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else{ + $template->assign('message','Un courriel vient d\'être envoyé à '.$Nmail.'. L\'adresse électronique ne sera modifié qu\'après avoir cliqué sur le lien d\'activation contenu dans ce courriel.'); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } + $mail->SmtpClose(); + unset($mail); + } + } + else { + $template->assign('message','L\'adresse électronique que vous avez tapée n\'est pas valide.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + } + else { + $template->assign('message','Veuillez remplir tous les champs avant de valider le formulaire.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } +} +elseif (isset($_GET['chg']) && $_GET['chg'] == 'activation' && isset($_GET['util']) && !empty($_GET['util']) && isset($_GET['auth']) && !empty($_GET['auth'])) { + if ($_GET['util'] == $id) { + if (!empty($donnees['mdpNOUV']) && sha1($donnees['mdpNOUV']) == $_GET['auth']) { + mysql_query("UPDATE `user` SET `mdp` = `mdpNOUV`, `mdpNOUV` = '', `mailNOUV` = '' WHERE ID='$id'"); + header('Location: options.php?erreur=8'); + exit; + } + elseif (!empty($donnees['mailNOUV']) && sha1($donnees['mailNOUV']) == $_GET['auth']) { + mysql_query("UPDATE `user` SET `mail` = `mailNOUV`, `mailNOUV` = '', `mdpNOUV` = '' WHERE ID='$id'"); + header('Location: options.php?erreur=9'); + exit; + } + } +} + +$sess->values['idvac'] = sha1(rand(123456789,9876543210).'ß‘}☻'.time()); +$sess->put(); + +$template->assign('mail',$queryUser['mail']); +$template->assign('idvac',$sess->values['idvac']); +?> \ No newline at end of file diff --git a/game/regles.php b/game/regles.php new file mode 100644 index 0000000..5246328 --- /dev/null +++ b/game/regles.php @@ -0,0 +1,123 @@ +assign('contenu','

    Règles de Halo-Battle

    +Préambule : tous les joueurs ayant créé un compte de jeu, et l'utilisant ou non, s'engagent à avoir lu et à respecter les règles de Halo-Battle dans leur intégralité. Si l'une des règles énoncées ci-dessous est transgressée, merci de vous référer au chapitre des infractions afin de connaître toutes les modalités relatives aux punitions encourues.
    +
    +Ce règlement peut être l'objet d'une modification, partielle ou totale, et il est du ressort du joueur de se tenir informé de toute modification quelle qu'elle soit. Toute modification sera publiée sur le forum avec sa date de mise en application, avant de se trouver effective au sein du jeu.
    +
    +Ces règles du jeu ont été publiées le 14/04/2008 et rentrent en vigueur à partir du 24/04/2008 +
    +
    Plan des règles : +
    +
    I. Comportement +
    II. Comptes +
    III. Commerce et ressources +
    IV. Mercenariat +
    V. Guerre +
    VI. Bash +
    VII. Alliances +
    VIII. Sanctions +


    +

    I. Comportement


    +

    1 - Comportement général


    + +- La convivialité et le respect des autres joueurs sont de rigueur. Par conséquent, les propos injurieux, racistes, xénophobes, pornographiques et antisémites sont prohibés. Tous les outils de communications utilisés pour et par Halo-Battle sont soumis à cette règle (jeu, forum et IRC).
    +- L'utilisation de pseudo et/ou nom de planète en rapport direct avec des propos racistes, xénophobes, pornographiques ou encore antisémites est totalement prohibé. Il en va de même pour toute revendication politique, religieuse ou ayant un rapport avec l'actualité (une certaine liberté peut être tolérée mais ceci reste à l'appréciation du staff).
    +- Les menaces sortant du cadre du jeu ne seront pas tolérées et lourdement sanctionnées par les opérateurs. Elles pourront de plus faire l'objet de poursuites judiciaires de la part de la personne concernée devant les juridictions compétentes.
    +- Utiliser le bouton Signaler pour signaler un message qui ne contient pas d'insultes ou qui n'enfreint pas les règles du jeu est interdit. Le signalement de message ne doit servir qu'à informer les opérateurs d'infractions aux règles du jeu et à rien d'autre.
    +- Le spam, les insultes et les messages à contenus offensants sont interdits, de même que tout contenu xénophobe, antisémite ou raciste.
    +- Toute manoeuvre visant à exploiter le règlement à son avantage, ou à le contourner sciemment, est interdite.
    + +

    2 - Bugusing


    + +- Tout bug trouvé doit être immédiatement signalé au staff de Halo-Battle.
    +- Il est totalement prohibé d'exploiter un bug à son avantage.
    +- Toute action visant à paralyser d'une quelconque manière le compte d'un autre joueur est absolument interdit.
    +- Ne pas signaler un bug découvert est passible de bannissement.
    + +

    II. Comptes


    + +

    1 - Les comptes de jeu


    + +- Les comptes restent la propriété de Halo-Battle ; par conséquent, ils ne peuvent faire l'objet d'une vente ou faire office de monnaie d'échange.
    +- Un compte ne peut être joué que par une seule et même personne physique dans une seule et même galaxie (sauf cas relatif à la surveillance de compte).
    +- La langue utilisée dans Halo-Battle est le français ; toutefois, seul l'anglais est toléré pour les personnes ne sachant pas ou peu le parler.
    + +

    2 - Multicomptes


    + +- Jouer plus d'un compte par galaxie est strictement interdit.
    +- Pour les joueurs jouant depuis un lieu commun (famille, collocation, écoles, lieux de travail...) il est impératif de prévenir l'opérateur de votre galaxie.
    +- Aucune interaction, directe ou non, entre comptes de joueurs se connectant régulièrement de lieux communs n'est autorisée.
    +- Pour les joueurs d'une même famille, faire partie d'une même alliance est toléré. Dans ce cas précit, merci d'en avertir l'opérateur de votre galaxie. Toute exploitation abusive de cette autorisation sera sévérement sanctionnée.
    +- La règle de la surveillance de compte et le partage de compte s'appliquent normalement : même connecté du même lieu, chaque joueur n'est autorisé à surveiller ou jouer que son propre compte.
    + +

    3 - Surveillance de compte


    + +- Toute surveillance de compte doit être obligatoirement signalée à l'opérateur de votre galaxie. Le propriétaire du-dit compte doit indiquer quel compte va être surveillé, donner la durée exacte de la surveillance, et donner le pseudonyme du surveillant. Il n'est pas nécessaire d'attendre une réponse de l'opérateur pour pouvoir commencer la surveillance du compte.
    +- Une seule et même personne ne peut surveiller qu'un seul compte à la fois. Aucun délais minimum n'est exigé entre la surveillance de deux comptes différents. Les surveillances de comptes ne peuvent faire l'objet d'aucune rémunération.
    +- Le surveillant ainsi que le joueur qui fait surveiller son compte sont responsables des actions faites via un compte durant une surveillance.
    +- Le surveillant peut effectuer n'importe quelle opération sur la ou les planètes du propriétaire durant la surveillance. Est néanmoins interdit le transfert de ressources vers des planètes appartenant à un joueur autre. L'activation du mode vacances est également autorisé.
    +- La surveillance du compte prend fin lorsque le propriétaire du compte se reconnecte à celui-ci, ou que le délai de surveillance a expiré. Dans ce cas précit, le surveillant est tenu de ne plus s'en occuper et de faire passer obligatoirement le compte en mode vacances.
    + +

    4 - Don de compte


    + +- Tout changement de compte doit être au préalable signalé à un opérateur. Tout changement sans l'intervention de l'opérateur sera sanctionné.
    +- Le propriétaire du mail permanent du compte est tenu d'envoyer un mail informatif aux opérateurs en précisant le pseudonyme du repreneur et le futur mail permanent du compte.
    +- L'opérateur modifiera lui-même le mail permanent du compte et informera le donneur et le repreneur que le compte est cédé.
    +- Le repreneur peut se connecter au compte dès qu'il en reçoit l'autorisation par l'opérateur, et peut alors changer l'adresse dynamique, le pseudonyme et le mot de passe du compte.
    +- Une fois que le repreneur s'est connecté sur le compte, il est strictement interdit au donneur de s'y reconnecter.
    +- La même règle s'applique dans le cas d'un échange de comptes entre deux joueurs d'une même galaxie.
    +- Aucun don de compte ne peut faire l'objet d'une transaction monétaire.
    + +

    III. Commerce et ressources


    + +- Les joueurs sont libres de commercer comme ils l'entendent, tant que leurs transactions ne se trouvent pas en infraction avec le réglement.
    +- Le commerce doit prendre la forme d'un arrangement entre les différents joueurs. Chaque joueur engage sa propre responsabilité lors de la transaction de ressources. Par conséquent, dans le cas de vols, d'arnaques ou de toute autre forme crapuleuse de négociation, il ne peut y avoir de recours auprès d'un opérateur.
    +- Il est interdit d'exercer une pression ou de s'acharner sur un joueur dans le but de lui soutirer ses ressources (sauf si les motifs sont valables, comme dans le cas d'une guerre déclarée).
    +- L'envoie de ressources à des joueurs plus haut classés que soi doit être motivé par des motifs valables. Si l'opérateur juge l'action outrancière, des réparations de dommages peuvent être demandées au joueur bénéficiaire des ressources.
    +- Les transactions de ressources ne peuvent faire l'objet d'une transaction monétaire réelle.
    + +

    IV. Mercenariat


    + +- Le mercenariat est autorisé. Ces contrats rétribuent un joueur ou une alliance en fonction de services rendus.
    +- Un contrat de mercenariat doit prendre la forme d'un arrangement entre les différents joueurs et ceux-ci y engagent leur responsabilité propre. Par conséquent, il ne peut y avoir de recours auprès d'un opérateur si, par exemple, le contrat n'est pas exécuté, ou n'est pas rémunéré.
    +- Toute mission de mercenariat est possible, tant qu'elle n'interfère pas avec le présent réglement.
    +- Un contrat de mercenariat ne peut être rémunéré par des unités monétaires réelles.
    + +

    V. Guerre


    + +- Une guerre ne peut être déclarée que contre une alliance ou un joueur sans alliance. Ainsi il est possible de déclarer la guerre à une alliance entière ou à joueur qui n'a pas d'alliance, mais pas à un seul joueur d'une alliance ou à quelques joueurs d'une alliance.
    +- Il n'est pas nécessaire de motiver la décision ou de prévenir l'alliance agressée pour déclarer une guerre.
    +- Il est obligatoire de déclarer officiellement une guerre sur le forum, dans la section appropriée, dans les 24 heures qui suivent l'agression. Les joueurs sont libres de formuler les objectifs et les conditions de fin de la guerre.
    +- Il est strictement interdit d'établir des objectifs portant atteinte aux libertés fondamentales dont disposent les joueurs, comme la suppression d'un compte, l'interdiction de jouer, suppression de colonies ou d'unités, etc...
    +- En cas de guerre, le bash n'est pas interdit.
    +- Les joueurs sont libres de mener leurs campagnes militaires comme ils l'entendent, pourvu que cela n'entre pas en conflit avec le règlement.
    +- Une guerre prend fin lorsque les belligérants trouvent un accord. Ils devront le signaler obligatoirement, comme pour la déclaration de guerre.
    + +

    VI. Bash


    + +- Le bash est relatif à l'attaque à outrance de planètes particulières. Attaquer une planète plus de quatre fois en 24 heures est par conséquent interdit.
    +- La règle du bash s'applique aux joueurs actifs et inactifs.
    +- En cas de guerre, le bash est autorisé.
    + +

    VII. Alliances


    + +- Toute alliance possède le privilège de se constituer comme elle l'entend.
    +- Toute alliance peut recruter autant de joueurs qu'elle le souhaite.
    +- Les alliances mixtes sont autorisées ; cependant, une race dominante doit y être représentée et les joueurs de la race opposée ne doivent pas s'y trouver en trop grand nombre sous peine de sanction.
    +- Toute alliance peut recruter autant de joueurs qu'elle le souhaite.
    +- Toute alliance peut signer autant de pactes qu'elle le souhaite.
    +- Toute alliance a le droit de se donner comme mission celle qu'elle entend.
    +- Il est strictement interdit de copier totalement ou en partie, les textes, images, etc, créés par les joueurs des différentes alliances déjà existantes. Les alliances fondées sur le principe du CSNU ou de l'Alliance ne sont pas concernées par la clause du plagiat de nom. Pour pouvoir recopier l'un des éléments se trouvant dans une alliance, il est nécessaire d'avoir une autorisation écrite de ou des auteurs vous autorisant à y procéder sous peine de sanctions.
    +- Tout recrutement dans les autres alliances déjà existantes est formellement interdit.
    + +

    VIII. Sanctions


    + +- En cas de non respect de ce règlement, les opérateurs du jeu infligeront un blocage pouvant aller de un jour, à un blocage définitif selon la gravité de la faute, ainsi qu'en cas de récidive.
    +- Chaque bannissement est mentionné dans le pilori du jeu. Par ailleurs, le staff de Halo-Battle se réserve le droit de prendre à l'encontre des joueurs toute autre sanction.
    +- En cas de réclamation, merci d'envoyer un mail à l'un des opérateurs en précisant votre pseudonyme ingame et votre galaxie.
    +- Toute manoeuvre visant à faire bloquer délibérément un adversaire est interdite et pourra être sanctionnée par l'opérateur.
    +
    '); +?> \ No newline at end of file diff --git a/game/rename.php b/game/rename.php new file mode 100644 index 0000000..dba2c2c --- /dev/null +++ b/game/rename.php @@ -0,0 +1,50 @@ +assign('message','Vous n\'avez indiqué aucun nom de planète.'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('game/erreur.tpl'); + exit; + } + else { + $table = $config['db_prefix'].'planete'; + $chapeau->unique_query("UPDATE `$table` SET `nom_planete` = '$nouvNom' WHERE `id_user` = '$id_user' AND `id` = '$id_plan'"); + $template->assign('message','Le nom de votre planète a été modifié avec succès.'); + $template->assign('script',''); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; + } +} +elseif(isset($_GET['a']) && $_GET['a'] == $sess->values['abandon']) { + $galaxie = $queryPlanete["galaxie"]; $ss = $queryPlanete["ss"]; $position = $queryPlanete["position"]; + mysql_query("DELETE FROM `planete` WHERE `id_user` = '$id_user' AND `id` = '$id_plan' LIMIT 1;"); + mysql_query("DELETE FROM `flottes` WHERE `id_user` = '$id_user' AND `start_galaxie` = '$galaxie' AND `start_ss` = '$ss' AND `start_position` = '$position';"); + + $table = $config['db_prefix'].'planete'; + $req = $chapeau->unique_query("SELECT * FROM `$table` WHERE `id_user` = '$id_user' LIMIT 1;"); + $sess->values['idPlan'] = $req['id']; + $sess->put(); + + $template->assign('message','Cette planète n\'est désormais plus sous votre contrôle.'); + $template->assign('script',''); + $template->assign('couleur','green'); + $template->display('game/erreur.tpl'); + exit; +} + +$table = $config['db_prefix'].'planete'; +$reqnb = $chapeau->query("SELECT * FROM `$table` WHERE `id_user` = '$id_user'"); + if (count($reqnb) > 1) $hashA = md5(rand(123456789,9876543210)); + else $hashA = false; +$sess->values['abandon'] = $hashA; +$sess->put(); +$template->assign('abandonH', $hashA); +?> \ No newline at end of file diff --git a/game/ressources.php b/game/ressources.php new file mode 100644 index 0000000..6305100 --- /dev/null +++ b/game/ressources.php @@ -0,0 +1,11 @@ +assign('nombat', $batiment); +$template->assign('ressources_prod', array(separerNombres(floor(ceil(pow(1.1,$mine_m)*35*$mine_m)*$coeff_mine_m)), separerNombres(floor(ceil(pow(1.1,$mine_c)*23*$mine_c)*$coeff_mine_c)), separerNombres(floor((ceil(pow(1.1,$mine_h)*14*($mine_h+0.7))) * $coeff_mine_h)), separerNombres(floor(ceil(exp(0.28*$centrale_s)*22)*$coeff_centrale_s)), separerNombres(floor(ceil(exp(0.297*$centrale_f)*25)*$coeff_centrale_f)))); +$template->assign('ressources_conso', array(separerNombres(ceil(exp(0.28*$mine_m)*10)*$coeff_mine_m), separerNombres(ceil(exp(0.28*$mine_c)*10)*$coeff_mine_c), separerNombres(ceil(exp(0.2849*$mine_h)*13)*$coeff_mine_h), floor(ceil(pow(1.34,($centrale_f-1))*9)*$coeff_centrale_f))); +$template->assign('ressources_toto', array(separerNombres(floor((ceil(pow(1.1,$mine_h)*14*($mine_h+0.7))) * $coeff_mine_h) - floor(ceil(pow(1.34,($centrale_f-1))*9)*$coeff_centrale_f))), $diffnrj); +$template->assign('ressources_coef', array(floor($coeff_mine_m*100), floor($coeff_mine_c*100), floor($coeff_mine_h*100), floor($coeff_centrale_s*100), floor($coeff_centrale_f*100))); +?> \ No newline at end of file diff --git a/game/templates.lnk b/game/templates.lnk new file mode 100644 index 0000000..ebd6967 Binary files /dev/null and b/game/templates.lnk differ diff --git a/game/validation.php b/game/validation.php new file mode 100644 index 0000000..b8a3e5f --- /dev/null +++ b/game/validation.php @@ -0,0 +1,40 @@ +connexion(); + $base->db(); + + $id = mysql_real_escape_string($_GET['i']); + + $res = $base->unique_query("SELECT * FROM `user_inscriptions` WHERE `id_activ` = '$id'"); + if ($res) { + switch($res['serveur']){ + case 0: + $url = "http://127.0.0.1/hbn/"; + break; + case 1: + $url = "http://battle.halo.fr/"; + break; + default: + $url = "http://battle.halo.fr/"; + } + + //On envoie la requête vers le serveur + $cds = sha1($res['pseudo'].'$'.$res['race'].'£'.$res['mdp'].'#'.$res['mail'].'ß'.$res['time_inscription'].'Ó'.$_SERVER['HTTP_USER_AGENT'].'♀☻'.$_SERVER['REMOTE_ADDR'].$res['placement']); + header('Location: '.$url.'?p=njoueur&nom='.$res['pseudo'].'&race='.$res['race'].'&mdp='.$res['mdp'].'&mail='.$res['mail'].'&ti='.$res['time_inscription'].'&placement='.$res['placement'].'&cds='.$cds); + exit; + } + else { + $template->assign('message','Le lien est expiré !'); + $template->assign('script',''); + $template->assign('couleur','red'); + $template->display('cms/erreur.tpl'); + exit; + } + + $base->deconnexion(); +} +else header('Location: ./'); +?> \ No newline at end of file diff --git a/game/version.php b/game/version.php new file mode 100644 index 0000000..1c31a77 --- /dev/null +++ b/game/version.php @@ -0,0 +1,13 @@ + $data['version'], 'date' => date("d/m/y", $data['temps']), 'description' => nl2br(str_replace('
    ', '', $data['contenu']))); +} +$template->assign('versions', $TEMP_versions); +?> \ No newline at end of file diff --git a/images/Thumbs.db b/images/Thumbs.db deleted file mode 100644 index 4099c59..0000000 Binary files a/images/Thumbs.db and /dev/null differ diff --git a/images/accueil/annonce.jpg b/images/accueil/annonce.jpg new file mode 100644 index 0000000..dbca89b Binary files /dev/null and b/images/accueil/annonce.jpg differ diff --git a/pages/images/missilearcheriz2.jpg b/images/accueil/dossier.jpg similarity index 57% rename from pages/images/missilearcheriz2.jpg rename to images/accueil/dossier.jpg index 81b6392..f269f44 100644 Binary files a/pages/images/missilearcheriz2.jpg and b/images/accueil/dossier.jpg differ diff --git a/images/accueil/news_img.jpg b/images/accueil/news_img.jpg new file mode 100644 index 0000000..feec1b7 Binary files /dev/null and b/images/accueil/news_img.jpg differ diff --git a/images/accueil/stat.png b/images/accueil/stat.png new file mode 100644 index 0000000..4eede88 Binary files /dev/null and b/images/accueil/stat.png differ diff --git a/images/background.jpg b/images/background.jpg deleted file mode 100644 index 156a18c..0000000 Binary files a/images/background.jpg and /dev/null differ diff --git a/pages/images/batiments/baseradardl3.jpg b/images/batiments/baseradardl3.jpg similarity index 100% rename from pages/images/batiments/baseradardl3.jpg rename to images/batiments/baseradardl3.jpg diff --git a/pages/images/batiments/caserncov0ry.jpg b/images/batiments/caserncov0ry.jpg similarity index 100% rename from pages/images/batiments/caserncov0ry.jpg rename to images/batiments/caserncov0ry.jpg diff --git a/pages/images/batiments/caserne.jpg b/images/batiments/caserne.jpg similarity index 100% rename from pages/images/batiments/caserne.jpg rename to images/batiments/caserne.jpg diff --git a/pages/images/batiments/centrale electrique.jpg b/images/batiments/centrale electrique.jpg similarity index 100% rename from pages/images/batiments/centrale electrique.jpg rename to images/batiments/centrale electrique.jpg diff --git a/pages/images/batiments/centrale solaire.jpg b/images/batiments/centrale solaire.jpg similarity index 100% rename from pages/images/batiments/centrale solaire.jpg rename to images/batiments/centrale solaire.jpg diff --git a/pages/images/batiments/centrale_f.png b/images/batiments/centrale_f.png similarity index 100% rename from pages/images/batiments/centrale_f.png rename to images/batiments/centrale_f.png diff --git a/pages/images/batiments/centrale_fusion.jpg b/images/batiments/centrale_fusion.jpg similarity index 100% rename from pages/images/batiments/centrale_fusion.jpg rename to images/batiments/centrale_fusion.jpg diff --git a/pages/images/batiments/centrale_s.JPG b/images/batiments/centrale_s.JPG similarity index 100% rename from pages/images/batiments/centrale_s.JPG rename to images/batiments/centrale_s.JPG diff --git a/pages/images/batiments/centrederecherchegu9.jpg b/images/batiments/centrederecherchegu9.jpg similarity index 100% rename from pages/images/batiments/centrederecherchegu9.jpg rename to images/batiments/centrederecherchegu9.jpg diff --git a/pages/images/batiments/chantier spatial.jpg b/images/batiments/chantier spatial.jpg similarity index 100% rename from pages/images/batiments/chantier spatial.jpg rename to images/batiments/chantier spatial.jpg diff --git a/pages/images/batiments/chantier-spatial.jpg b/images/batiments/chantier-spatial.jpg similarity index 100% rename from pages/images/batiments/chantier-spatial.jpg rename to images/batiments/chantier-spatial.jpg diff --git a/pages/images/batiments/chantier-terrestre.jpg b/images/batiments/chantier-terrestre.jpg similarity index 100% rename from pages/images/batiments/chantier-terrestre.jpg rename to images/batiments/chantier-terrestre.jpg diff --git a/pages/images/batiments/chantier_terrestre.jpg b/images/batiments/chantier_terrestre.jpg similarity index 100% rename from pages/images/batiments/chantier_terrestre.jpg rename to images/batiments/chantier_terrestre.jpg diff --git a/pages/images/batiments/chantier_terrestre.png b/images/batiments/chantier_terrestre.png similarity index 100% rename from pages/images/batiments/chantier_terrestre.png rename to images/batiments/chantier_terrestre.png diff --git a/pages/images/batiments/chantierspatialff8.jpg b/images/batiments/chantierspatialff8.jpg similarity index 100% rename from pages/images/batiments/chantierspatialff8.jpg rename to images/batiments/chantierspatialff8.jpg diff --git a/pages/images/batiments/chantierterrestrecopybj8.jpg b/images/batiments/chantierterrestrecopybj8.jpg similarity index 100% rename from pages/images/batiments/chantierterrestrecopybj8.jpg rename to images/batiments/chantierterrestrecopybj8.jpg diff --git a/pages/images/batiments/chantierterrestrehg1.jpg b/images/batiments/chantierterrestrehg1.jpg similarity index 100% rename from pages/images/batiments/chantierterrestrehg1.jpg rename to images/batiments/chantierterrestrehg1.jpg diff --git a/pages/images/batiments/chantierterrestrenz5.jpg b/images/batiments/chantierterrestrenz5.jpg similarity index 100% rename from pages/images/batiments/chantierterrestrenz5.jpg rename to images/batiments/chantierterrestrenz5.jpg diff --git a/pages/images/batiments/covbase25ro.jpg b/images/batiments/covbase25ro.jpg similarity index 100% rename from pages/images/batiments/covbase25ro.jpg rename to images/batiments/covbase25ro.jpg diff --git a/pages/images/batiments/covielabocn5.jpg b/images/batiments/covielabocn5.jpg similarity index 100% rename from pages/images/batiments/covielabocn5.jpg rename to images/batiments/covielabocn5.jpg diff --git a/pages/images/batiments/cristaloo3.png b/images/batiments/cristaloo3.png similarity index 100% rename from pages/images/batiments/cristaloo3.png rename to images/batiments/cristaloo3.png diff --git a/pages/images/batiments/ecole militaire.jpg b/images/batiments/ecole militaire.jpg similarity index 100% rename from pages/images/batiments/ecole militaire.jpg rename to images/batiments/ecole militaire.jpg diff --git a/pages/images/batiments/ecole_militaire.jpg b/images/batiments/ecole_militaire.jpg similarity index 100% rename from pages/images/batiments/ecole_militaire.jpg rename to images/batiments/ecole_militaire.jpg diff --git a/pages/images/batiments/entrepot.jpg b/images/batiments/entrepot.jpg similarity index 100% rename from pages/images/batiments/entrepot.jpg rename to images/batiments/entrepot.jpg diff --git a/pages/images/batiments/generateurafusiondb2.jpg b/images/batiments/generateurafusiondb2.jpg similarity index 100% rename from pages/images/batiments/generateurafusiondb2.jpg rename to images/batiments/generateurafusiondb2.jpg diff --git a/pages/images/batiments/generateurdecristalmh5.jpg b/images/batiments/generateurdecristalmh5.jpg similarity index 100% rename from pages/images/batiments/generateurdecristalmh5.jpg rename to images/batiments/generateurdecristalmh5.jpg diff --git a/pages/images/batiments/generateurdemetalsg0.jpg b/images/batiments/generateurdemetalsg0.jpg similarity index 100% rename from pages/images/batiments/generateurdemetalsg0.jpg rename to images/batiments/generateurdemetalsg0.jpg diff --git a/pages/images/batiments/generateurdenergievb7.jpg b/images/batiments/generateurdenergievb7.jpg similarity index 100% rename from pages/images/batiments/generateurdenergievb7.jpg rename to images/batiments/generateurdenergievb7.jpg diff --git a/pages/images/batiments/generateurdhydrognedh3.jpg b/images/batiments/generateurdhydrognedh3.jpg similarity index 100% rename from pages/images/batiments/generateurdhydrognedh3.jpg rename to images/batiments/generateurdhydrognedh3.jpg diff --git a/pages/images/batiments/informatique.jpg b/images/batiments/informatique.jpg similarity index 100% rename from pages/images/batiments/informatique.jpg rename to images/batiments/informatique.jpg diff --git a/pages/images/batiments/ionisateur.png b/images/batiments/ionisateur.png similarity index 100% rename from pages/images/batiments/ionisateur.png rename to images/batiments/ionisateur.png diff --git a/pages/images/batiments/ioniseurdn4.jpg b/images/batiments/ioniseurdn4.jpg similarity index 100% rename from pages/images/batiments/ioniseurdn4.jpg rename to images/batiments/ioniseurdn4.jpg diff --git a/images/batiments/mine_c.png b/images/batiments/mine_c.png new file mode 100644 index 0000000..5eb4c5c Binary files /dev/null and b/images/batiments/mine_c.png differ diff --git a/images/batiments/mine_m.jpg b/images/batiments/mine_m.jpg new file mode 100644 index 0000000..28da3ba Binary files /dev/null and b/images/batiments/mine_m.jpg differ diff --git a/images/batiments/mine_m.png b/images/batiments/mine_m.png new file mode 100644 index 0000000..385a1ff Binary files /dev/null and b/images/batiments/mine_m.png differ diff --git a/pages/images/batiments/nanw9.jpg b/images/batiments/nanw9.jpg similarity index 100% rename from pages/images/batiments/nanw9.jpg rename to images/batiments/nanw9.jpg diff --git a/pages/images/batiments/oeil.png b/images/batiments/oeil.png similarity index 100% rename from pages/images/batiments/oeil.png rename to images/batiments/oeil.png diff --git a/pages/images/batiments/oeilduprophetewj6.jpg b/images/batiments/oeilduprophetewj6.jpg similarity index 100% rename from pages/images/batiments/oeilduprophetewj6.jpg rename to images/batiments/oeilduprophetewj6.jpg diff --git a/pages/images/batiments/ordianteur_hologramme.jpg b/images/batiments/ordianteur_hologramme.jpg similarity index 100% rename from pages/images/batiments/ordianteur_hologramme.jpg rename to images/batiments/ordianteur_hologramme.jpg diff --git a/pages/images/batiments/purificateur_c.png b/images/batiments/purificateur_c.png similarity index 100% rename from pages/images/batiments/purificateur_c.png rename to images/batiments/purificateur_c.png diff --git a/pages/images/batiments/purificateur_m.png b/images/batiments/purificateur_m.png similarity index 100% rename from pages/images/batiments/purificateur_m.png rename to images/batiments/purificateur_m.png diff --git a/pages/images/batiments/purificateurdemtalhb3.jpg b/images/batiments/purificateurdemtalhb3.jpg similarity index 100% rename from pages/images/batiments/purificateurdemtalhb3.jpg rename to images/batiments/purificateurdemtalhb3.jpg diff --git a/pages/images/batiments/radar.jpg b/images/batiments/radar.jpg similarity index 100% rename from pages/images/batiments/radar.jpg rename to images/batiments/radar.jpg diff --git a/pages/images/batiments/recherches.jpg b/images/batiments/recherches.jpg similarity index 100% rename from pages/images/batiments/recherches.jpg rename to images/batiments/recherches.jpg diff --git a/pages/images/batiments/sanstitretruecolor09zn6.jpg b/images/batiments/sanstitretruecolor09zn6.jpg similarity index 100% rename from pages/images/batiments/sanstitretruecolor09zn6.jpg rename to images/batiments/sanstitretruecolor09zn6.jpg diff --git a/pages/images/batiments/sanstitrevi7.jpg b/images/batiments/sanstitrevi7.jpg similarity index 100% rename from pages/images/batiments/sanstitrevi7.jpg rename to images/batiments/sanstitrevi7.jpg diff --git a/pages/images/batiments/search0yp.jpg b/images/batiments/search0yp.jpg similarity index 100% rename from pages/images/batiments/search0yp.jpg rename to images/batiments/search0yp.jpg diff --git a/pages/images/batiments/silo.jpg b/images/batiments/silo.jpg similarity index 100% rename from pages/images/batiments/silo.jpg rename to images/batiments/silo.jpg diff --git a/pages/images/batiments/solaire.jpg b/images/batiments/solaire.jpg similarity index 100% rename from pages/images/batiments/solaire.jpg rename to images/batiments/solaire.jpg diff --git a/pages/images/batiments/stockage.jpg b/images/batiments/stockage.jpg similarity index 100% rename from pages/images/batiments/stockage.jpg rename to images/batiments/stockage.jpg diff --git a/pages/images/batiments/stockagebasement1cs10bl.jpg b/images/batiments/stockagebasement1cs10bl.jpg similarity index 100% rename from pages/images/batiments/stockagebasement1cs10bl.jpg rename to images/batiments/stockagebasement1cs10bl.jpg diff --git a/pages/images/batiments/synchroniseur.jpg b/images/batiments/synchroniseur.jpg similarity index 100% rename from pages/images/batiments/synchroniseur.jpg rename to images/batiments/synchroniseur.jpg diff --git a/pages/images/caserne/TCAO2.jpg b/images/caserne/TCAO2.jpg similarity index 100% rename from pages/images/caserne/TCAO2.jpg rename to images/caserne/TCAO2.jpg diff --git a/pages/images/caserne/brute.jpg b/images/caserne/brute.jpg similarity index 100% rename from pages/images/caserne/brute.jpg rename to images/caserne/brute.jpg diff --git a/pages/images/caserne/defenseurlegerhs8.jpg b/images/caserne/defenseurlegerhs8.jpg similarity index 100% rename from pages/images/caserne/defenseurlegerhs8.jpg rename to images/caserne/defenseurlegerhs8.jpg diff --git a/pages/images/caserne/defenseurlourdhr3.jpg b/images/caserne/defenseurlourdhr3.jpg similarity index 100% rename from pages/images/caserne/defenseurlourdhr3.jpg rename to images/caserne/defenseurlourdhr3.jpg diff --git a/pages/images/caserne/drone.jpg b/images/caserne/drone.jpg similarity index 100% rename from pages/images/caserne/drone.jpg rename to images/caserne/drone.jpg diff --git a/pages/images/caserne/elite.jpg b/images/caserne/elite.jpg similarity index 100% rename from pages/images/caserne/elite.jpg rename to images/caserne/elite.jpg diff --git a/pages/images/caserne/grenadier.jpg b/images/caserne/grenadier.jpg similarity index 100% rename from pages/images/caserne/grenadier.jpg rename to images/caserne/grenadier.jpg diff --git a/pages/images/caserne/grunt1.jpg b/images/caserne/grunt1.jpg similarity index 100% rename from pages/images/caserne/grunt1.jpg rename to images/caserne/grunt1.jpg diff --git a/pages/images/caserne/hunter1.jpg b/images/caserne/hunter1.jpg similarity index 100% rename from pages/images/caserne/hunter1.jpg rename to images/caserne/hunter1.jpg diff --git a/pages/images/caserne/ingenieur_c.jpg b/images/caserne/ingenieur_c.jpg similarity index 100% rename from pages/images/caserne/ingenieur_c.jpg rename to images/caserne/ingenieur_c.jpg diff --git a/pages/images/caserne/ingenieurs.jpg b/images/caserne/ingenieurs.jpg similarity index 100% rename from pages/images/caserne/ingenieurs.jpg rename to images/caserne/ingenieurs.jpg diff --git a/pages/images/caserne/jackal.jpg b/images/caserne/jackal.jpg similarity index 100% rename from pages/images/caserne/jackal.jpg rename to images/caserne/jackal.jpg diff --git a/pages/images/caserne/jackalsniper.jpg b/images/caserne/jackalsniper.jpg similarity index 100% rename from pages/images/caserne/jackalsniper.jpg rename to images/caserne/jackalsniper.jpg diff --git a/pages/images/caserne/marinehf0.jpg b/images/caserne/marinehf0.jpg similarity index 100% rename from pages/images/caserne/marinehf0.jpg rename to images/caserne/marinehf0.jpg diff --git a/pages/images/caserne/marines.jpg b/images/caserne/marines.jpg similarity index 100% rename from pages/images/caserne/marines.jpg rename to images/caserne/marines.jpg diff --git a/pages/images/caserne/medecin.jpg b/images/caserne/medecin.jpg similarity index 100% rename from pages/images/caserne/medecin.jpg rename to images/caserne/medecin.jpg diff --git a/pages/images/caserne/medecin_c.jpg b/images/caserne/medecin_c.jpg similarity index 100% rename from pages/images/caserne/medecin_c.jpg rename to images/caserne/medecin_c.jpg diff --git a/pages/images/caserne/scoutma3.jpg b/images/caserne/scoutma3.jpg similarity index 100% rename from pages/images/caserne/scoutma3.jpg rename to images/caserne/scoutma3.jpg diff --git a/pages/images/caserne/sentinellelegerecn4.jpg b/images/caserne/sentinellelegerecn4.jpg similarity index 100% rename from pages/images/caserne/sentinellelegerecn4.jpg rename to images/caserne/sentinellelegerecn4.jpg diff --git a/pages/images/caserne/sniper.jpg b/images/caserne/sniper.jpg similarity index 100% rename from pages/images/caserne/sniper.jpg rename to images/caserne/sniper.jpg diff --git a/pages/images/caserne/spartan.jpg b/images/caserne/spartan.jpg similarity index 100% rename from pages/images/caserne/spartan.jpg rename to images/caserne/spartan.jpg diff --git a/images/covenant_na.jpg b/images/covenant_na.jpg new file mode 100644 index 0000000..df78192 Binary files /dev/null and b/images/covenant_na.jpg differ diff --git a/pages/images/caserne/nanw9.jpg b/images/forerunner_na.jpg similarity index 100% rename from pages/images/caserne/nanw9.jpg rename to images/forerunner_na.jpg diff --git a/pages/images/caserne/img_na_ig.jpg b/images/humain_na.jpg similarity index 100% rename from pages/images/caserne/img_na_ig.jpg rename to images/humain_na.jpg diff --git a/pages/diz/descriptions/diz/planete/1.jpg b/images/planetes/1.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/1.jpg rename to images/planetes/1.jpg diff --git a/pages/diz/descriptions/diz/planete/10.jpg b/images/planetes/10.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/10.jpg rename to images/planetes/10.jpg diff --git a/pages/diz/descriptions/diz/planete/11.jpg b/images/planetes/11.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/11.jpg rename to images/planetes/11.jpg diff --git a/pages/diz/descriptions/diz/planete/12.jpg b/images/planetes/12.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/12.jpg rename to images/planetes/12.jpg diff --git a/pages/diz/descriptions/diz/planete/13.jpg b/images/planetes/13.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/13.jpg rename to images/planetes/13.jpg diff --git a/pages/diz/descriptions/diz/planete/14.jpg b/images/planetes/14.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/14.jpg rename to images/planetes/14.jpg diff --git a/pages/diz/descriptions/diz/planete/15.jpg b/images/planetes/15.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/15.jpg rename to images/planetes/15.jpg diff --git a/pages/diz/descriptions/diz/planete/2.jpg b/images/planetes/2.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/2.jpg rename to images/planetes/2.jpg diff --git a/pages/diz/descriptions/diz/planete/3.jpg b/images/planetes/3.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/3.jpg rename to images/planetes/3.jpg diff --git a/pages/diz/descriptions/diz/planete/4.jpg b/images/planetes/4.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/4.jpg rename to images/planetes/4.jpg diff --git a/pages/diz/descriptions/diz/planete/5.jpg b/images/planetes/5.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/5.jpg rename to images/planetes/5.jpg diff --git a/pages/diz/descriptions/diz/planete/6.jpg b/images/planetes/6.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/6.jpg rename to images/planetes/6.jpg diff --git a/pages/diz/descriptions/diz/planete/7.jpg b/images/planetes/7.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/7.jpg rename to images/planetes/7.jpg diff --git a/pages/diz/descriptions/diz/planete/8.jpg b/images/planetes/8.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/8.jpg rename to images/planetes/8.jpg diff --git a/pages/diz/descriptions/diz/planete/9.jpg b/images/planetes/9.jpg similarity index 100% rename from pages/diz/descriptions/diz/planete/9.jpg rename to images/planetes/9.jpg diff --git a/images/smiles/biggrin.gif b/images/smiles/biggrin.gif new file mode 100644 index 0000000..d352772 Binary files /dev/null and b/images/smiles/biggrin.gif differ diff --git a/images/smiles/confused.gif b/images/smiles/confused.gif new file mode 100644 index 0000000..0c49e06 Binary files /dev/null and b/images/smiles/confused.gif differ diff --git a/images/smiles/cool.gif b/images/smiles/cool.gif new file mode 100644 index 0000000..cead030 Binary files /dev/null and b/images/smiles/cool.gif differ diff --git a/images/smiles/eek.gif b/images/smiles/eek.gif new file mode 100644 index 0000000..5d39781 Binary files /dev/null and b/images/smiles/eek.gif differ diff --git a/images/smiles/evil.gif b/images/smiles/evil.gif new file mode 100644 index 0000000..ab1aa8e Binary files /dev/null and b/images/smiles/evil.gif differ diff --git a/images/smiles/lol.gif b/images/smiles/lol.gif new file mode 100644 index 0000000..374ba15 Binary files /dev/null and b/images/smiles/lol.gif differ diff --git a/images/smiles/mad.gif b/images/smiles/mad.gif new file mode 100644 index 0000000..1f6c3c2 Binary files /dev/null and b/images/smiles/mad.gif differ diff --git a/images/smiles/neutral.gif b/images/smiles/neutral.gif new file mode 100644 index 0000000..4f31156 Binary files /dev/null and b/images/smiles/neutral.gif differ diff --git a/images/smiles/razz.gif b/images/smiles/razz.gif new file mode 100644 index 0000000..29da2a2 Binary files /dev/null and b/images/smiles/razz.gif differ diff --git a/images/smiles/redface.gif b/images/smiles/redface.gif new file mode 100644 index 0000000..ad76283 Binary files /dev/null and b/images/smiles/redface.gif differ diff --git a/images/smiles/rolleyes.gif b/images/smiles/rolleyes.gif new file mode 100644 index 0000000..d7f5f2f Binary files /dev/null and b/images/smiles/rolleyes.gif differ diff --git a/images/smiles/sad.gif b/images/smiles/sad.gif new file mode 100644 index 0000000..d2ac78c Binary files /dev/null and b/images/smiles/sad.gif differ diff --git a/images/smiles/smile.gif b/images/smiles/smile.gif new file mode 100644 index 0000000..7b1f6d3 Binary files /dev/null and b/images/smiles/smile.gif differ diff --git a/images/smiles/surprised.gif b/images/smiles/surprised.gif new file mode 100644 index 0000000..cb21424 Binary files /dev/null and b/images/smiles/surprised.gif differ diff --git a/images/smiles/twisted.gif b/images/smiles/twisted.gif new file mode 100644 index 0000000..502fe24 Binary files /dev/null and b/images/smiles/twisted.gif differ diff --git a/images/smiles/wink.gif b/images/smiles/wink.gif new file mode 100644 index 0000000..d148288 Binary files /dev/null and b/images/smiles/wink.gif differ diff --git a/pages/images/technologies/IA4.jpg b/images/technologies/IA4.jpg similarity index 100% rename from pages/images/technologies/IA4.jpg rename to images/technologies/IA4.jpg diff --git a/pages/images/technologies/Mjolnir.jpg b/images/technologies/Mjolnir.jpg similarity index 100% rename from pages/images/technologies/Mjolnir.jpg rename to images/technologies/Mjolnir.jpg diff --git a/pages/images/technologies/arme.jpg b/images/technologies/arme.jpg similarity index 100% rename from pages/images/technologies/arme.jpg rename to images/technologies/arme.jpg diff --git a/images/technologies/arme.png b/images/technologies/arme.png new file mode 100644 index 0000000..89e0762 Binary files /dev/null and b/images/technologies/arme.png differ diff --git a/pages/images/technologies/armement.jpg b/images/technologies/armement.jpg similarity index 100% rename from pages/images/technologies/armement.jpg rename to images/technologies/armement.jpg diff --git a/pages/images/technologies/armuremc8ij.jpg b/images/technologies/armuremc8ij.jpg similarity index 100% rename from pages/images/technologies/armuremc8ij.jpg rename to images/technologies/armuremc8ij.jpg diff --git a/images/technologies/blindage.jpg b/images/technologies/blindage.jpg new file mode 100644 index 0000000..0dc1d6d Binary files /dev/null and b/images/technologies/blindage.jpg differ diff --git a/pages/images/technologies/boucliervaiseaucovenantey4.jpg b/images/technologies/boucliervaiseaucovenantey4.jpg similarity index 100% rename from pages/images/technologies/boucliervaiseaucovenantey4.jpg rename to images/technologies/boucliervaiseaucovenantey4.jpg diff --git a/pages/images/technologies/citydevlopment1px.jpg b/images/technologies/citydevlopment1px.jpg similarity index 100% rename from pages/images/technologies/citydevlopment1px.jpg rename to images/technologies/citydevlopment1px.jpg diff --git a/pages/images/technologies/commandement.jpg b/images/technologies/commandement.jpg similarity index 100% rename from pages/images/technologies/commandement.jpg rename to images/technologies/commandement.jpg diff --git a/pages/images/technologies/detection.jpg b/images/technologies/detection.jpg similarity index 100% rename from pages/images/technologies/detection.jpg rename to images/technologies/detection.jpg diff --git a/pages/images/technologies/developpement.jpg b/images/technologies/developpement.jpg similarity index 100% rename from pages/images/technologies/developpement.jpg rename to images/technologies/developpement.jpg diff --git a/pages/images/technologies/energie.jpg b/images/technologies/energie.jpg similarity index 100% rename from pages/images/technologies/energie.jpg rename to images/technologies/energie.jpg diff --git a/pages/images/technologies/hyperespace.jpg b/images/technologies/hyperespace.jpg similarity index 100% rename from pages/images/technologies/hyperespace.jpg rename to images/technologies/hyperespace.jpg diff --git a/pages/images/technologies/hyperespace2.jpg b/images/technologies/hyperespace2.jpg similarity index 100% rename from pages/images/technologies/hyperespace2.jpg rename to images/technologies/hyperespace2.jpg diff --git a/pages/images/technologies/informatique1.jpg b/images/technologies/informatique1.jpg similarity index 100% rename from pages/images/technologies/informatique1.jpg rename to images/technologies/informatique1.jpg diff --git a/pages/images/technologies/medecin1.jpg b/images/technologies/medecin1.jpg similarity index 100% rename from pages/images/technologies/medecin1.jpg rename to images/technologies/medecin1.jpg diff --git a/pages/images/technologies/medecine.JPG b/images/technologies/medecine.JPG similarity index 100% rename from pages/images/technologies/medecine.JPG rename to images/technologies/medecine.JPG diff --git a/pages/images/technologies/nucleartech9qm.jpg b/images/technologies/nucleartech9qm.jpg similarity index 100% rename from pages/images/technologies/nucleartech9qm.jpg rename to images/technologies/nucleartech9qm.jpg diff --git a/pages/images/technologies/plasma4yl.jpg b/images/technologies/plasma4yl.jpg similarity index 100% rename from pages/images/technologies/plasma4yl.jpg rename to images/technologies/plasma4yl.jpg diff --git a/pages/images/technologies/radar7zr.jpg b/images/technologies/radar7zr.jpg similarity index 100% rename from pages/images/technologies/radar7zr.jpg rename to images/technologies/radar7zr.jpg diff --git a/pages/images/technologies/reacteur_f.jpg b/images/technologies/reacteur_f.jpg similarity index 100% rename from pages/images/technologies/reacteur_f.jpg rename to images/technologies/reacteur_f.jpg diff --git a/pages/images/technologies/reacteuracombustion.jpg b/images/technologies/reacteuracombustion.jpg similarity index 100% rename from pages/images/technologies/reacteuracombustion.jpg rename to images/technologies/reacteuracombustion.jpg diff --git a/pages/images/technologies/reacteurantigravyd1.jpg b/images/technologies/reacteurantigravyd1.jpg similarity index 100% rename from pages/images/technologies/reacteurantigravyd1.jpg rename to images/technologies/reacteurantigravyd1.jpg diff --git a/pages/images/technologies/reacteurfusionforerunnewu0.jpg b/images/technologies/reacteurfusionforerunnewu0.jpg similarity index 100% rename from pages/images/technologies/reacteurfusionforerunnewu0.jpg rename to images/technologies/reacteurfusionforerunnewu0.jpg diff --git a/pages/images/technologies/reacteurfusiontype1al5.jpg b/images/technologies/reacteurfusiontype1al5.jpg similarity index 100% rename from pages/images/technologies/reacteurfusiontype1al5.jpg rename to images/technologies/reacteurfusiontype1al5.jpg diff --git a/pages/images/technologies/reacteurfusiontype2nn6.jpg b/images/technologies/reacteurfusiontype2nn6.jpg similarity index 100% rename from pages/images/technologies/reacteurfusiontype2nn6.jpg rename to images/technologies/reacteurfusiontype2nn6.jpg diff --git a/pages/images/technologies/sanstitretruecolor04no6.jpg b/images/technologies/sanstitretruecolor04no6.jpg similarity index 100% rename from pages/images/technologies/sanstitretruecolor04no6.jpg rename to images/technologies/sanstitretruecolor04no6.jpg diff --git a/pages/images/technologies/sousespacety4.jpg b/images/technologies/sousespacety4.jpg similarity index 100% rename from pages/images/technologies/sousespacety4.jpg rename to images/technologies/sousespacety4.jpg diff --git a/pages/images/technologies/tactique.jpg b/images/technologies/tactique.jpg similarity index 100% rename from pages/images/technologies/tactique.jpg rename to images/technologies/tactique.jpg diff --git a/pages/images/technologies/techarmes1jk1.jpg b/images/technologies/techarmes1jk1.jpg similarity index 100% rename from pages/images/technologies/techarmes1jk1.jpg rename to images/technologies/techarmes1jk1.jpg diff --git a/pages/images/terrestre/M12A1_LAAV_Warthog.jpg b/images/terrestre/M12A1_LAAV_Warthog.jpg similarity index 100% rename from pages/images/terrestre/M12A1_LAAV_Warthog.jpg rename to images/terrestre/M12A1_LAAV_Warthog.jpg diff --git a/pages/images/terrestre/M12G1_LAAV_Warthog.jpg b/images/terrestre/M12G1_LAAV_Warthog.jpg similarity index 100% rename from pages/images/terrestre/M12G1_LAAV_Warthog.jpg rename to images/terrestre/M12G1_LAAV_Warthog.jpg diff --git a/pages/images/terrestre/M12_LRV_Warthog.jpg b/images/terrestre/M12_LRV_Warthog.jpg similarity index 100% rename from pages/images/terrestre/M12_LRV_Warthog.jpg rename to images/terrestre/M12_LRV_Warthog.jpg diff --git a/pages/images/terrestre/albatross.jpg b/images/terrestre/albatross.jpg similarity index 100% rename from pages/images/terrestre/albatross.jpg rename to images/terrestre/albatross.jpg diff --git a/pages/images/terrestre/apparition.jpg b/images/terrestre/apparition.jpg similarity index 100% rename from pages/images/terrestre/apparition.jpg rename to images/terrestre/apparition.jpg diff --git a/pages/images/terrestre/bansheeqp0.jpg b/images/terrestre/bansheeqp0.jpg similarity index 100% rename from pages/images/terrestre/bansheeqp0.jpg rename to images/terrestre/bansheeqp0.jpg diff --git a/pages/images/terrestre/boardingcraft.jpg b/images/terrestre/boardingcraft.jpg similarity index 100% rename from pages/images/terrestre/boardingcraft.jpg rename to images/terrestre/boardingcraft.jpg diff --git a/pages/images/terrestre/csnulancemissileol5.jpg b/images/terrestre/csnulancemissileol5.jpg similarity index 100% rename from pages/images/terrestre/csnulancemissileol5.jpg rename to images/terrestre/csnulancemissileol5.jpg diff --git a/pages/images/terrestre/csnushortswordad3.jpg b/images/terrestre/csnushortswordad3.jpg similarity index 100% rename from pages/images/terrestre/csnushortswordad3.jpg rename to images/terrestre/csnushortswordad3.jpg diff --git a/pages/images/terrestre/csnusparrowhawkkp4.jpg b/images/terrestre/csnusparrowhawkkp4.jpg similarity index 100% rename from pages/images/terrestre/csnusparrowhawkkp4.jpg rename to images/terrestre/csnusparrowhawkkp4.jpg diff --git a/pages/diz/forerunner/images/dca_legere.jpg b/images/terrestre/dca_legere.jpg similarity index 100% rename from pages/diz/forerunner/images/dca_legere.jpg rename to images/terrestre/dca_legere.jpg diff --git a/images/terrestre/dca_lourde.jpg b/images/terrestre/dca_lourde.jpg new file mode 100644 index 0000000..38993dd Binary files /dev/null and b/images/terrestre/dca_lourde.jpg differ diff --git a/pages/images/terrestre/ghostic1.jpg b/images/terrestre/ghostic1.jpg similarity index 100% rename from pages/images/terrestre/ghostic1.jpg rename to images/terrestre/ghostic1.jpg diff --git a/pages/images/terrestre/lanceur_torpilles.jpg b/images/terrestre/lanceur_torpilles.jpg similarity index 100% rename from pages/images/terrestre/lanceur_torpilles.jpg rename to images/terrestre/lanceur_torpilles.jpg diff --git a/pages/images/terrestre/pelican.jpg b/images/terrestre/pelican.jpg similarity index 100% rename from pages/images/terrestre/pelican.jpg rename to images/terrestre/pelican.jpg diff --git a/pages/images/terrestre/pelican_armed.jpg b/images/terrestre/pelican_armed.jpg similarity index 100% rename from pages/images/terrestre/pelican_armed.jpg rename to images/terrestre/pelican_armed.jpg diff --git a/pages/images/terrestre/phantomfu2.jpg b/images/terrestre/phantomfu2.jpg similarity index 100% rename from pages/images/terrestre/phantomfu2.jpg rename to images/terrestre/phantomfu2.jpg diff --git a/pages/images/terrestre/scorpion.jpg b/images/terrestre/scorpion.jpg similarity index 100% rename from pages/images/terrestre/scorpion.jpg rename to images/terrestre/scorpion.jpg diff --git a/pages/images/terrestre/scorpionN.jpg b/images/terrestre/scorpionN.jpg similarity index 100% rename from pages/images/terrestre/scorpionN.jpg rename to images/terrestre/scorpionN.jpg diff --git a/pages/images/terrestre/shade.jpg b/images/terrestre/shade.jpg similarity index 100% rename from pages/images/terrestre/shade.jpg rename to images/terrestre/shade.jpg diff --git a/pages/images/terrestre/shadow.jpg b/images/terrestre/shadow.jpg similarity index 100% rename from pages/images/terrestre/shadow.jpg rename to images/terrestre/shadow.jpg diff --git a/pages/images/terrestre/spectre1.jpg b/images/terrestre/spectre1.jpg similarity index 100% rename from pages/images/terrestre/spectre1.jpg rename to images/terrestre/spectre1.jpg diff --git a/pages/images/terrestre/spirit1.jpg b/images/terrestre/spirit1.jpg similarity index 100% rename from pages/images/terrestre/spirit1.jpg rename to images/terrestre/spirit1.jpg diff --git a/pages/images/terrestre/stationdedefensent8.jpg b/images/terrestre/stationdedefensent8.jpg similarity index 100% rename from pages/images/terrestre/stationdedefensent8.jpg rename to images/terrestre/stationdedefensent8.jpg diff --git a/pages/images/terrestre/strongshade.jpg b/images/terrestre/strongshade.jpg similarity index 100% rename from pages/images/terrestre/strongshade.jpg rename to images/terrestre/strongshade.jpg diff --git a/pages/images/terrestre/tourelle.jpg b/images/terrestre/tourelle.jpg similarity index 100% rename from pages/images/terrestre/tourelle.jpg rename to images/terrestre/tourelle.jpg diff --git a/pages/diz/forerunner/images/tourelle_fixe.jpg b/images/terrestre/tourelle_fixe.jpg similarity index 100% rename from pages/diz/forerunner/images/tourelle_fixe.jpg rename to images/terrestre/tourelle_fixe.jpg diff --git a/pages/images/terrestre/tourelle_gauss.jpg b/images/terrestre/tourelle_gauss.jpg similarity index 100% rename from pages/images/terrestre/tourelle_gauss.jpg rename to images/terrestre/tourelle_gauss.jpg diff --git a/pages/images/terrestre/tourelle_plasma.jpg b/images/terrestre/tourelle_plasma.jpg similarity index 100% rename from pages/images/terrestre/tourelle_plasma.jpg rename to images/terrestre/tourelle_plasma.jpg diff --git a/pages/images/terrestre/tourellebarreau.jpg b/images/terrestre/tourellebarreau.jpg similarity index 100% rename from pages/images/terrestre/tourellebarreau.jpg rename to images/terrestre/tourellebarreau.jpg diff --git a/pages/images/terrestre/tourioniquegr6.jpg b/images/terrestre/tourioniquegr6.jpg similarity index 100% rename from pages/images/terrestre/tourioniquegr6.jpg rename to images/terrestre/tourioniquegr6.jpg diff --git a/pages/images/terrestre/tourplasmasl4.jpg b/images/terrestre/tourplasmasl4.jpg similarity index 100% rename from pages/images/terrestre/tourplasmasl4.jpg rename to images/terrestre/tourplasmasl4.jpg diff --git a/pages/images/terrestre/warthog-vrl.jpg b/images/terrestre/warthog-vrl.jpg similarity index 100% rename from pages/images/terrestre/warthog-vrl.jpg rename to images/terrestre/warthog-vrl.jpg diff --git a/pages/images/terrestre/wraith.jpg b/images/terrestre/wraith.jpg similarity index 100% rename from pages/images/terrestre/wraith.jpg rename to images/terrestre/wraith.jpg diff --git a/pages/images/vaisseaux/cargosladen.jpg b/images/vaisseaux/cargosladen.jpg similarity index 100% rename from pages/images/vaisseaux/cargosladen.jpg rename to images/vaisseaux/cargosladen.jpg diff --git a/pages/images/vaisseaux/cargosparabola.jpg b/images/vaisseaux/cargosparabola.jpg similarity index 100% rename from pages/images/vaisseaux/cargosparabola.jpg rename to images/vaisseaux/cargosparabola.jpg diff --git a/pages/images/vaisseaux/charognard.jpg b/images/vaisseaux/charognard.jpg similarity index 100% rename from pages/images/vaisseaux/charognard.jpg rename to images/vaisseaux/charognard.jpg diff --git a/pages/images/vaisseaux/chasseurlourd7id.jpg b/images/vaisseaux/chasseurlourd7id.jpg similarity index 100% rename from pages/images/vaisseaux/chasseurlourd7id.jpg rename to images/vaisseaux/chasseurlourd7id.jpg diff --git a/pages/images/vaisseaux/chasseurlourdfk8.jpg b/images/vaisseaux/chasseurlourdfk8.jpg similarity index 100% rename from pages/images/vaisseaux/chasseurlourdfk8.jpg rename to images/vaisseaux/chasseurlourdfk8.jpg diff --git a/pages/images/vaisseaux/citecovenant.jpg b/images/vaisseaux/citecovenant.jpg similarity index 100% rename from pages/images/vaisseaux/citecovenant.jpg rename to images/vaisseaux/citecovenant.jpg diff --git a/pages/images/vaisseaux/colonisation.jpg b/images/vaisseaux/colonisation.jpg similarity index 100% rename from pages/images/vaisseaux/colonisation.jpg rename to images/vaisseaux/colonisation.jpg diff --git a/pages/images/vaisseaux/coviecolobv3.jpg b/images/vaisseaux/coviecolobv3.jpg similarity index 100% rename from pages/images/vaisseaux/coviecolobv3.jpg rename to images/vaisseaux/coviecolobv3.jpg diff --git a/pages/images/vaisseaux/croiseur.jpg b/images/vaisseaux/croiseur.jpg similarity index 100% rename from pages/images/vaisseaux/croiseur.jpg rename to images/vaisseaux/croiseur.jpg diff --git a/pages/images/vaisseaux/croiseur8er.jpg b/images/vaisseaux/croiseur8er.jpg similarity index 100% rename from pages/images/vaisseaux/croiseur8er.jpg rename to images/vaisseaux/croiseur8er.jpg diff --git a/pages/images/vaisseaux/croiseurclassealcyon130om6.jpg b/images/vaisseaux/croiseurclassealcyon130om6.jpg similarity index 100% rename from pages/images/vaisseaux/croiseurclassealcyon130om6.jpg rename to images/vaisseaux/croiseurclassealcyon130om6.jpg diff --git a/pages/images/vaisseaux/croiseurclassemarathon1oc0.jpg b/images/vaisseaux/croiseurclassemarathon1oc0.jpg similarity index 100% rename from pages/images/vaisseaux/croiseurclassemarathon1oc0.jpg rename to images/vaisseaux/croiseurclassemarathon1oc0.jpg diff --git a/pages/images/vaisseaux/croiseurforrunerns4.jpg b/images/vaisseaux/croiseurforrunerns4.jpg similarity index 100% rename from pages/images/vaisseaux/croiseurforrunerns4.jpg rename to images/vaisseaux/croiseurforrunerns4.jpg diff --git a/pages/images/vaisseaux/croiseurmarathonke3.jpg b/images/vaisseaux/croiseurmarathonke3.jpg similarity index 100% rename from pages/images/vaisseaux/croiseurmarathonke3.jpg rename to images/vaisseaux/croiseurmarathonke3.jpg diff --git a/pages/images/vaisseaux/csnucargoladen2al8.jpg b/images/vaisseaux/csnucargoladen2al8.jpg similarity index 100% rename from pages/images/vaisseaux/csnucargoladen2al8.jpg rename to images/vaisseaux/csnucargoladen2al8.jpg diff --git a/pages/images/vaisseaux/csnucargoparabola2mc9.jpg b/images/vaisseaux/csnucargoparabola2mc9.jpg similarity index 100% rename from pages/images/vaisseaux/csnucargoparabola2mc9.jpg rename to images/vaisseaux/csnucargoparabola2mc9.jpg diff --git a/pages/images/vaisseaux/csnufregatedk7.jpg b/images/vaisseaux/csnufregatedk7.jpg similarity index 100% rename from pages/images/vaisseaux/csnufregatedk7.jpg rename to images/vaisseaux/csnufregatedk7.jpg diff --git a/pages/images/vaisseaux/csnuportevaisseauxgy3.jpg b/images/vaisseaux/csnuportevaisseauxgy3.jpg similarity index 100% rename from pages/images/vaisseaux/csnuportevaisseauxgy3.jpg rename to images/vaisseaux/csnuportevaisseauxgy3.jpg diff --git a/images/vaisseaux/csnusuperportevaisseauxrw4.jpg b/images/vaisseaux/csnusuperportevaisseauxrw4.jpg new file mode 100644 index 0000000..9f85ae5 Binary files /dev/null and b/images/vaisseaux/csnusuperportevaisseauxrw4.jpg differ diff --git a/pages/images/vaisseaux/destructeur2ci0.jpg b/images/vaisseaux/destructeur2ci0.jpg similarity index 100% rename from pages/images/vaisseaux/destructeur2ci0.jpg rename to images/vaisseaux/destructeur2ci0.jpg diff --git a/pages/images/vaisseaux/drone_clarion.jpg b/images/vaisseaux/drone_clarion.jpg similarity index 100% rename from pages/images/vaisseaux/drone_clarion.jpg rename to images/vaisseaux/drone_clarion.jpg diff --git a/pages/images/vaisseaux/fregate2ky.jpg b/images/vaisseaux/fregate2ky.jpg similarity index 100% rename from pages/images/vaisseaux/fregate2ky.jpg rename to images/vaisseaux/fregate2ky.jpg diff --git a/pages/images/vaisseaux/fregatewz5.jpg b/images/vaisseaux/fregatewz5.jpg similarity index 100% rename from pages/images/vaisseaux/fregatewz5.jpg rename to images/vaisseaux/fregatewz5.jpg diff --git a/pages/images/vaisseaux/longsword.jpg b/images/vaisseaux/longsword.jpg similarity index 100% rename from pages/images/vaisseaux/longsword.jpg rename to images/vaisseaux/longsword.jpg diff --git a/pages/images/terrestre/nanw9.jpg b/images/vaisseaux/nanw9.jpg similarity index 100% rename from pages/images/terrestre/nanw9.jpg rename to images/vaisseaux/nanw9.jpg diff --git a/images/vaisseaux/pv.jpg b/images/vaisseaux/pv.jpg new file mode 100644 index 0000000..163c2e9 Binary files /dev/null and b/images/vaisseaux/pv.jpg differ diff --git a/pages/images/vaisseaux/recycleur.jpg b/images/vaisseaux/recycleur.jpg similarity index 100% rename from pages/images/vaisseaux/recycleur.jpg rename to images/vaisseaux/recycleur.jpg diff --git a/pages/images/vaisseaux/sonde_despionnage1.jpg b/images/vaisseaux/sonde_despionnage1.jpg similarity index 100% rename from pages/images/vaisseaux/sonde_despionnage1.jpg rename to images/vaisseaux/sonde_despionnage1.jpg diff --git a/pages/images/vaisseaux/station.jpg b/images/vaisseaux/station.jpg similarity index 100% rename from pages/images/vaisseaux/station.jpg rename to images/vaisseaux/station.jpg diff --git a/images/vaisseaux/station1.jpg b/images/vaisseaux/station1.jpg new file mode 100644 index 0000000..f02345a Binary files /dev/null and b/images/vaisseaux/station1.jpg differ diff --git a/pages/images/vaisseaux/superdestroyerwa6.jpg b/images/vaisseaux/superdestroyerwa6.jpg similarity index 100% rename from pages/images/vaisseaux/superdestroyerwa6.jpg rename to images/vaisseaux/superdestroyerwa6.jpg diff --git a/pages/images/vaisseaux/vaisseau.jpg b/images/vaisseaux/vaisseau.jpg similarity index 100% rename from pages/images/vaisseaux/vaisseau.jpg rename to images/vaisseaux/vaisseau.jpg diff --git a/pages/images/vaisseaux/vaisseaucolonisationmm4.jpg b/images/vaisseaux/vaisseaucolonisationmm4.jpg similarity index 100% rename from pages/images/vaisseaux/vaisseaucolonisationmm4.jpg rename to images/vaisseaux/vaisseaucolonisationmm4.jpg diff --git a/pages/images/vaisseaux/vaisseaudebataille9na.jpg b/images/vaisseaux/vaisseaudebataille9na.jpg similarity index 100% rename from pages/images/vaisseaux/vaisseaudebataille9na.jpg rename to images/vaisseaux/vaisseaudebataille9na.jpg diff --git a/includes/classement/conf.php b/includes/classement/conf.php new file mode 100644 index 0000000..5432ecc --- /dev/null +++ b/includes/classement/conf.php @@ -0,0 +1,6 @@ + diff --git a/includes/classement/fonctions.php b/includes/classement/fonctions.php new file mode 100644 index 0000000..6cce2b7 --- /dev/null +++ b/includes/classement/fonctions.php @@ -0,0 +1,284 @@ + \ No newline at end of file diff --git a/includes/classement/footer.php b/includes/classement/footer.php new file mode 100644 index 0000000..11a09ca --- /dev/null +++ b/includes/classement/footer.php @@ -0,0 +1,3 @@ + + + diff --git a/includes/classement/header.php b/includes/classement/header.php new file mode 100644 index 0000000..3649767 --- /dev/null +++ b/includes/classement/header.php @@ -0,0 +1,8 @@ + + + + + Document sans titre + + + \ No newline at end of file diff --git a/includes/common.php b/includes/common.php new file mode 100644 index 0000000..aa9daa2 --- /dev/null +++ b/includes/common.php @@ -0,0 +1,60 @@ +load(); + +//On prépare le gestionnaire de templates +$template = new Smarty(); + +$template->template_dir = _FCORE.'templates/templates/'; +$template->compile_dir = _FCORE.'templates/templates_c/'; +$template->config_dir = _FCORE.'templates/configs/'; +$template->cache_dir = _FCORE.'templates/cache/'; + +$template->assign('date',strftime("%A %d %B %Y %H:%M")); +$template->assign('datehb',str_replace('.','',strftime("/%a %d %b %Y/%H%M %S"))); + +$link2 = array_map(create_function('$var','return(url($var,TRUE));'),$config['link']); +$link_menu = array_map(create_function('$var','return(url($var,TRUE));'),$config['menu']); +$link_menua = array_map(create_function('$var','return(url($var,TRUE));'),$config['menuadmin']); +$link['lastNewsn'] = "csnu"; +$link = array_map('url',$link); +$all_link = array_merge($link,$link2); + +$template->assign('link',$all_link); +$template->assign('menu',$link_menu); +$template->assign('menua',$link_menua); + +//$HEADER = '
    Attention : Mise à jour en cours, certaines pages risquent d\'être inactives ou buggées quelques temps
    '; +$HEADER = ''; + +$nanite = 0; + +$PUB = ' +
    '; +?> diff --git a/includes/constructions.php b/includes/constructions.php new file mode 100644 index 0000000..33a2d08 --- /dev/null +++ b/includes/constructions.php @@ -0,0 +1,83 @@ +pret(); + $nbc = count($cons); + $out = ""; + for($i=0 ; $i<$nbc ; $i++) { + $var = $batimentVAR[$cons[$i][0]]; + $nb = $queryPlanete[$var] + $cons[$i][1]; + if ($i != 0) $out .= ", "; + $out .= "`$var` = '$nb'"; + } + $export = mysql_real_escape_string(serialize($file)); + if (!empty($out)) { + $out .= ','; + mysql_query("UPDATE `planete` SET $out `file_bat` = '$export' WHERE `id` = '$idPlan';"); + } + + +//Technologies + if (empty($queryPlanete['file_tech'])) $file = new gererFile($queryUser['prodfile']+2); + else $file = unserialize($queryPlanete['file_tech']); + + $cons = $file->pret(); + $nbc = count($cons); + $out = ""; + for($i=0 ; $i<$nbc ; $i++) { + $var = $technoloVAR[$cons[$i][0]]; + $nb = $queryUser[$var] + $cons[$i][1]; + if ($i != 0) $out .= ", "; + $out .= "`$var` = '$nb'"; + } + $export = mysql_real_escape_string(serialize($file)); + if (!empty($out)) { + mysql_query("UPDATE `user` SET $out WHERE `id` = '$id_user';"); + mysql_query("UPDATE `planete` SET `file_tech` = '$export' WHERE `id` = '$idPlan';"); + } + + +//Vaisseaux + if (empty($queryPlanete['file_vais'])) $file = new gererFile($queryUser['prodfile']+2); + else $file = unserialize($queryPlanete['file_vais']); + + $cons = $file->pret(); + $nbc = count($cons); + $out = ""; + for($i=0 ; $i<$nbc ; $i++) { + $var = $nomvaisnVAR[$cons[$i][0]]; + $nb = $cons[$i][1]; + if ($i != 0) $out .= ", "; + $out .= "`$var` = `$var` + '$nb'"; + } + $export = mysql_real_escape_string(serialize($file)); + if (!empty($out)) { + $out .= ','; + mysql_query("UPDATE `planete` SET $out `file_vais` = '$export' WHERE `id` = '$idPlan';"); + } + + +//Terrestre & défenses + if (empty($queryPlanete['file_ter'])) $file = new gererFile($queryUser['prodfile']+2); + else $file = unserialize($queryPlanete['file_ter']); + + $cons = $file->pret(); + $nbc = count($cons); + $out = ""; + for($i=0 ; $i<$nbc ; $i++) { + $var = $nomterrnVAR[$cons[$i][0]]; + $nb = $cons[$i][1]; + if ($i != 0) $out .= ", "; + $out .= "`$var` = `$var` + '$nb'"; + } + $export = mysql_real_escape_string(serialize($file)); + if (!empty($out)) { + $out .= ','; + mysql_query("UPDATE `planete` SET $out `file_ter` = '$export' WHERE `id` = '$idPlan';"); + } +?> \ No newline at end of file diff --git a/fermerServeur.php b/includes/fermerServeur.php similarity index 92% rename from fermerServeur.php rename to includes/fermerServeur.php index 10c735d..90cee64 100644 --- a/fermerServeur.php +++ b/includes/fermerServeur.php @@ -58,4 +58,6 @@ if ($fermerServeur_timeE < time() && !empty($fermerServeur_timeE)) $fermerServeu if (!empty($durer)) $durer = '

    Durée de la phase de maintenance : '.$durer; $fermerServeur_Contenu = 'Une phase de maintenance du serveur va être effectuée exceptionnellement '.$ouvr.'.

    Pour plus d\'information sur les corrections et nouveautés apportés, nous vous conseillons de lire les annonces officielles sur le forum du jeu.'.$durer.'

    Merci de votre compréhension'; } + + $HEADER .= '
    Serveur en maintenance : Le serveur est actuellement dans une phase de mise à jour. Certaines pages risquent d\'être inactives ou buggées quelques temps Réouverture dans '.($fermerServeur_timeE-time()).' secondes
    '; ?> \ No newline at end of file diff --git a/includes/flottes.php b/includes/flottes.php new file mode 100644 index 0000000..f6d5432 --- /dev/null +++ b/includes/flottes.php @@ -0,0 +1,300 @@ +query("SELECT * FROM `$table` WHERE `id_user` = '$id_user' OR (`end_galaxie` = '$Hgalaxie' AND `end_ss` = '$Hss' AND `end_position` = '$Hposition')"); +for ($i=0 ; $i<$chapeau->num_rows ; $i++) { + $resultat = $req[$i]; + $id_flotte = $resultat['id']; + $mission = $resultat['mission']; + $end_galaxie = $resultat['end_galaxie']; + $end_ss = $resultat['end_ss']; + $end_position = $resultat['end_position']; + $temps = $resultat['start_time'] + $resultat['end_time']; + if ($resultat['effectue'] != 1 && time() >= $resultat['start_time'] + $resultat['end_time'] && !empty($resultat['end_time'])) { + + //Mission attaquer + if ($mission == 1) { + require_once('Class/class.combat.php'); + $table = $config['db_prefix'].'planete'; + $resultatT = $chapeau->unique_query("SELECT `debris_met`, `debris_cri` FROM `$table` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + + if ($resultat['effectue'] == 2) { + $table = $config['db_prefix'].'flottes_combats'; + $resultatC = $chapeau->unique_query("SELECT * FROM `$table` WHERE `refflotte` = '$id_flotte'"); + if (!$resultatC) die('Erreur dans le script de combat, contactez d\'urgence un administrateur !'); + if (time() >= $resultatC['timestamp']) { + //On récupère le combat + $combat = unserialize($resultatC['serialize']); + + //Mise à jour des tactiques + if (!empty($resultatC['tactiqueAT'])) $combat->changerTactiqueAT($resultatC['tactiqueAT']); + if (!empty($resultatC['tactiqueEN'])) $combat->changerTactiqueEN($resultatC['tactiqueEN']); + + while($combat->timestamp <= time()) { + //On passe le tour + $combat->Ntour++; + + //Détermine qui est le tour : attaquant ou défenseur + if (floor($combat->Ntour/2) == $combat->Ntour/2) { //Le tour est paire : tour attaquant + $arraytactique = tactique($combat->ATtactique); + if (@$combat->attaquerVais($combat->calcAttaque($arraytactique[2] + $combat->regenereBC($arraytactique[1], true, !$arraytactique[3]), true), true) == 0) { //Attaquant vainceur + mysql_query("DELETE FROM `flottes_combats` WHERE `refflotte` = '$id_flotte'"); + mysql_query("UPDATE `flottes` SET ".$combat->exportAT(true).", `effectue` = '1', `ret_time` = ".$combat->timestamp." WHERE `id` = '$id_flotte'"); + mysql_query("UPDATE `planete` SET ".$combat->exportEN()." WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $send = $combat->genRapport(true, true); + } + else $send = $combat->genRapport(false); + } + else { //Le tour est impaire : tour défenseur + $arraytactique = tactique($combat->ENtactique); + if (@$combat->attaquerVais($combat->calcAttaque($arraytactique[2] + $combat->regenereBC($arraytactique[1], false, !$arraytactique[3]), false), false) == 0) { //Défenseur vainceur + mysql_query("DELETE FROM `flottes_combats` WHERE `refflotte` = '$id_flotte'"); + mysql_query("DELETE FROM `flottes` WHERE `id` = '$id_flotte'"); + mysql_query("UPDATE `planete` SET ".$combat->exportEN()." WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $send = $combat->genRapport(true, false); + } + else $send = $combat->genRapport(false); + } + + //On envoie les rapports aux joueurs concernés + $temps = $combat->timestamp; + mysql_query("INSERT INTO `mail` VALUES(NULL, '1', '".trouvNom($send[2])."', '', 'Combat', '".$send[0]."', '$temps')") or die ("erreur sql ".mysql_error()); + mysql_query("INSERT INTO `mail` VALUES(NULL, '1', '".trouvNom($send[3])."', '', 'Combat', '".$send[1]."', '$temps')") or die ("erreur sql ".mysql_error()); + + //Prévision du prochain tour + $combat->timestamp += 300; + } + $timestamp_suite = $combat->timestamp; + + $debriM = $combat->debriM + $resultatT['debris_met']; + $debriC = $combat->debriC + $resultatT['debris_cri']; + + $combat->debriM = 0; + $combat->debriC = 0; + + //On sérialise la classe pour l'exporter + $serialise = serialize($combat); + + //On enregistre le combat dans la base de données + mysql_query("UPDATE `flottes_combats` SET `serialize` = '$serialise', `tactiqueAT` = '0', `tactiqueEN` = '0', `timestamp` = '$timestamp_suite' WHERE `refflotte` = '$id_flotte'"); + mysql_query("UPDATE `planete` SET `debris_met` = '$debriM', `debris_cri` = '$debriC' WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + } + } + else { + //On place la flotte en attente + $table = $config['db_prefix'].'flottes'; + $chapeau->query("UPDATE `$table` SET `effectue` = '2' WHERE `id` = '$id_flotte'"); + + //On trouve les variables nécessaire pour le combat : vaisseaux, défenses, ... + $table = $config['db_prefix'].'planete'; + $resultatDef = $chapeau->unique_query("SELECT * FROM `$table` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + + //On déclare le combat + $combat = new Combat($resultat, $resultatDef, $resultatDef); + + //Définition des tactiques par défaut pour les deux combatants + $table = $config['db_prefix'].'user'; + + $resultatU = $chapeau->unique_query("SELECT `combatAT_tactique` FROM `$table` WHERE `id` = '".$resultat['id_user']."'"); + if (empty($resultat['tactiqueAT'])) $combat->changerTactiqueAT($resultatU['combatAT_tactique']); + else $combat->changerTactiqueAT($resultat['tactiqueAT']); + + $resultatU = mysql_query("SELECT combatDE_tactique FROM `$table` WHERE `id` = '".$resultatDef['id_user']."'"); + if (empty($resultat['tactiqueEN'])) $combat->changerTactiqueEN($resultatU['combatDE_tactique']); + else $combat->changerTactiqueEN($resultat['tactiqueEN']); + + //Lancement de l'attaque + if (@$combat->attaquerVais($combat->calcAttaque(100,true),true) == 0) { //Attaquant vainceur + mysql_query("DELETE FROM `flottes_combats` WHERE `refflotte` = '$id_flotte'"); + mysql_query("UPDATE `flottes` SET ".$combat->exportAT(true).", `effectue` = '1', `ret_time` = ".$combat->timestamp." WHERE `id` = '$id_flotte'"); + mysql_query("UPDATE `planete` SET ".$combat->exportEN()." WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $send = $combat->genRapport(true, true); + } + else $send = $combat->genRapport(false); + + //On envoie les rapports aux joueurs concernés + $temps = $combat->timestamp; + mysql_query("INSERT INTO `mail` VALUES(NULL, '1', '".trouvNom($send[2])."', '', 'Combat', '".$send[0]."', '$temps')"); + mysql_query("INSERT INTO `mail` VALUES(NULL, '1', '".trouvNom($send[3])."', '', 'Combat', '".$send[1]."', '$temps')"); + + + //Prévision du prochain tour + $combat->timestamp += 300; + $timestamp_suite = $combat->timestamp; + + $debriM = $combat->debriM + $resultatT['debris_met']; + $debriC = $combat->debriC + $resultatT['debris_cri']; + + $combat->debriM = 0; + $combat->debriC = 0; + + //On sérialise la classe pour l'exporter + $serialise = serialize($combat); + + //On enregistre le combat dans la base de données + mysql_query("INSERT INTO `flottes_combats` VALUES(NULL, '".$resultat['id']."', '$timestamp_suite', '$serialise', '0', '0')"); + mysql_query("UPDATE `planete` SET `debris_met` = '$debriM', `debris_cri` = '$debriC' WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + } + } + //Mission Transporter + elseif ($mission == 2) { + $table = $config['db_prefix'].'planete'; + $resultatT = $chapeau->unique_query("SELECT `metal`, `cristal`, `hydrogene` FROM `$table` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $Cmetal = $resultat['contenu_metal'] + $resultatT['metal']; + $Ccristal = $resultat['contenu_cristal'] + $resultatT['cristal']; + $Chydrogene = $resultat['contenu_hydrogene'] + $resultatT['hydrogene']; + $table = $config['db_prefix'].'planete'; + $chapeau->query("UPDATE `$table` SET `metal` = '$Cmetal', `cristal` = '$Ccristal', `hydrogene` = '$Chydrogene' WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $table = $config['db_prefix'].'flottes'; + $chapeau->query("UPDATE `$table` SET `effectue` = '1', `contenu_metal` = '0', `contenu_cristal` = '0', `contenu_hydrogene` = '0' WHERE `id` = '$id_flotte'"); + + $message = mysql_real_escape_string('Vos vaisseaux ont déposés '.$resultat['contenu_metal'].' de métal, '.$resultat['contenu_cristal'].' de cristal et '.$resultat['contenu_hydrogene'].' d\'hydrogène aux coordonnées '.$end_galaxie.':'.$end_ss.':'.$end_position); + $chapeau->query("INSERT INTO mail VALUES('', '1', '".trouvNom($id_user)."', '', 'Transport', '$message', '$temps')"); + } + //Mission Coloniser + elseif ($mission == 3) { + $table = $config['db_prefix'].'planete'; + $chapeau->query("SELECT * FROM `$table` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + if (!$chapeau->num_rows > 0) { + $time = time(); + $cases = mt_rand(125,222); + $image = mt_rand(1,15); + $Cmetal = $resultat['contenu_metal'] + 1000; + $Ccristal = $resultat['contenu_cristal'] + 700; + $Chydrogene = $resultat['contenu_hydrogene']; + + //Calcul de l'isolement + $nbPlan = count($queryPlanetes); + switch($nbPlan){ + case 11: $tps = 2; break; + case 12: $tps = 4; break; + case 13: $tps = 6; break; + case 14: $tps = 8; break; + case 15: $tps = 12; break; + case 16: $tps = 16; break; + case 17: $tps = 20; break; + default: $tps = 24; + } + $debut = mktime(rand(0, 24-$tps), 0, 0, date('n'), date('j'), date('Y')); + $fin = $debut + $tps * 3600; + + $chapeau->query("INSERT INTO planete (`id_user`, `isolement`, `nom_planete`, `galaxie`, `ss`, `position`, `image`, `cases`, `timestamp`, `metal`, `cristal`, `hydrogene`) VALUES ('$id_user', '$debut $fin', 'Planète colonisée', '$end_galaxie', '$end_ss', '$end_position', '$image', '$cases', '$time', '$Cmetal', '$Ccristal', '$Chydrogene')"); + + if ($resultat['nb_vais'] == 1) { + $resultat['nb_vais'] = -1; + $chapeau->query("DELETE FROM `flottes` WHERE `id` = '$id_flotte'"); + } + else $chapeau->query("UPDATE `flottes` SET `effectue` = '1', `vaisseau_3` = `vaisseau_3` - 1, `nb_vais` = `nb_vais` - 1, `contenu_metal` = '0', `contenu_cristal` = '0', `contenu_hydrogene` = '0' WHERE `id` = '$id_flotte'"); + + $message = 'Votre vaisseau a atteint la planète ['.$end_galaxie.':'.$end_ss.':'.$end_position.'] et commence la colonisation'; + $chapeau->query("INSERT INTO `mail` VALUES('', '1', '".trouvNom($resultat['id_user'])."', '', 'Colonisation', '$message', '$temps')"); + } + else $chapeau->query("INSERT INTO `mail` VALUES('', '1', '".trouvNom($resultat['id_user'])."', '', 'Colonisation', 'Nous n''avons pas pu coloniser la planète [$end_galaxie:$end_ss:$end_position] car lorsque nous sommes arrivé sur place, elle était déjà colonisée.', '$temps')"); + } + //Mission Recycler + elseif ($mission == 4) { + $resultatT = $chapeau->unique_query("SELECT * FROM `planete` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + if ($resultatT) { + $resultat['contenu_max'] -= (vais_conso($resultat['end_time'], count($resultat['nb_vais']))*$resultat['vitesse']*5) + $resultat['contenu_metal'] + $resultat['contenu_cristal'] + $resultat['contenu_hydrogene']; + + $debris_met = $resultatT['debris_met']; + $debris_cri = $resultatT['debris_cri']; + $capacite = $resultat['contenu_max']; + if ($debris_met+$debris_cri > $capacite) { + $a = floor($capacite/2); + $b = floor($capacite/2); + if ($a > $debris_met && $b > $debris_cri) { + $a = $debris_met; + $b = $debris_cri; + } + else if ($a > $debris_met) { + $a = $debris_met; + $b = ($capacite - $a); + if ($b > $debris_cri) $b = $debris_cri; + } + else if ($b > $debris_cri) { + $b = $debris_cri; + $a = ($capacite - $b); + if ($a > $debris_met) $a = $debris_met; + } + } + else { + $a = $debris_met; + $b = $debris_cri; + } + $Cmetal = $a + $resultat['contenu_metal']; + $Ccristal = $b + $resultat['contenu_cristal']; + $debris_met -= $a; + $debris_cri -= $b; + + $chapeau->query("UPDATE `flottes` SET `effectue` = '1', `contenu_metal` = '$Cmetal', `contenu_cristal` = '$Ccristal' WHERE `id` = '$id_flotte'"); + $chapeau->query("UPDATE `planete` SET `debris_met` = '$debris_met', `debris_cri` = '$debris_cri' WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + + $message = 'Vos vaisseaux récoltent '.$a.' de métal et '.$b.' de cristal aux coordonnées '.$end_galaxie.':'.$end_ss.':'.$end_position; + $chapeau->query("INSERT INTO mail VALUES('', '1', '".trouvNom($resultat['id_user'])."', '', 'Recyclage', '$message', '$temps')"); + } + } + elseif ($mission == 5) { + $nbsondes = $resultat['vaisseau_3']; + $resultatT = $chapeau->unique_query("SELECT * FROM `planete` WHERE `galaxie` = '$end_galaxie' AND `ss` = '$end_ss' AND `position` = '$end_position'"); + $id_user = $resultatT['id_user']; + $id_att = $resultat['id_user']; + $resultatUD = $chapeau->unique_query("SELECT * FROM `user` WHERE `id` = '$id_user';"); + $resultatUA = $chapeau->unique_query("SELECT * FROM `user` WHERE `id` = '$id_att';"); + + $diffNiveau = $resultatUA['detection'] - $resultatUD['detection'] + floor($nbsondes/2); + $rapport = new Rapport($mission, $id_att, $id_user, $resultat['start_time'] + $resultat['end_time']); + if ($diffNiveau < 0) { + $rapport->addInfo($resultatT, 0); + $rapport->addInfo(false, 1); + } + if ($diffNiveau >= 0) $rapport->addInfo($resultatT, 0); + if ($diffNiveau >= 1) $rapport->addInfo(true, 1); + if ($diffNiveau >= 2) $rapport->addInfo(true, 2); + if ($diffNiveau >= 3) $rapport->addInfo(true, 3); + if ($diffNiveau >= 4) $rapport->addInfo($resultatUD, 4); + if ($diffNiveau >= 5) $rapport->addInfo(true, 5); + + $chapeau->query("UPDATE `flottes` SET `effectue` = '1' WHERE `id` = '$id_flotte'"); + $rapport->send(); + } + } + if ($resultat['nb_vais'] >= 0 && time() >= $resultat['start_time'] + $resultat['end_time'] * 2 && !empty($resultat['end_time']) && $resultat['mission'] != 0 && ($resultat['mission'] != 1 || (!empty($resultat['ret_time']) && time() >= $resultat['ret_time'] + $resultat['end_time']))) { + $start_galaxie = $resultat['start_galaxie']; + $start_ss = $resultat['start_ss']; + $start_position = $resultat['start_position']; + $id_flotte = $resultat['id']; + $reqP = mysql_query("SELECT * FROM planete WHERE `id_user` = '$id_user' AND `galaxie` = '$start_galaxie' AND `ss` = '$start_ss' AND `position` = '$start_position'") or die ("erreur sql ".mysql_error()); + $resultatP = mysql_fetch_array($reqP); + $metal = $resultat['contenu_metal'] + $resultatP['metal']; + $cristal = $resultat['contenu_cristal'] + $resultatP['cristal']; + $hydrogene = $resultat['contenu_hydrogene'] + $resultatP['hydrogene']; + for($i = 1; $i <= 12; $i++) { + ${'Pvaisseaux_'.$i} = $resultatP['vaisseau_'.$i] + $resultat['vaisseau_'.$i]; + mysql_query("UPDATE `planete` SET `vaisseau_$i` = '${'Pvaisseaux_'.$i}' WHERE `id_user` = '$id_user' AND `galaxie` = '$start_galaxie' AND `ss` = '$start_ss' AND `position` = '$start_position'"); + } + mysql_query("UPDATE `planete` SET `metal` = '$metal', `cristal` = '$cristal', `hydrogene` = '$hydrogene' WHERE `id_user` = '$id_user' AND `galaxie` = '$start_galaxie' AND `ss` = '$start_ss' AND `position` = '$start_position'"); + mysql_query("DELETE FROM `flottes` WHERE `id_user` = '$id_user' AND `id` = '$id_flotte'"); + } +} +?> \ No newline at end of file diff --git a/includes/function.php b/includes/function.php new file mode 100644 index 0000000..c931492 --- /dev/null +++ b/includes/function.php @@ -0,0 +1,180 @@ + '86400', 'heure' => '3600', 'minute' => '60', 'seconde' => '1'); + foreach ($tab as $key => $value) { + $compteur = 0; + while ($time > ($value-1)) { + $time = $time - $value; + $compteur++; + } + if ($compteur != 0) { + $output .= $compteur.' '.$key; + if ($compteur > 1) $output .= 's'; + if ($value != 1) $output .= ' '; + } + } + return $output; +} + +function readDeblok($tableau, $queryPlanete, $queryUser){ + if ($tableau == '0') return 'Débloqué'; + else { + $nbDeblok = count($tableau); + $return = ''; + for ($i=0 ; $i<$nbDeblok ; $i++) { + if (isset($queryPlanete[$tableau[$i][1]])) $return .= techno($tableau[$i][0], $queryPlanete[$tableau[$i][1]], $tableau[$i][2]).'
    '; + else $return .= techno($tableau[$i][0], $queryUser[$tableau[$i][1]], $tableau[$i][2]).'
    '; + } + return $return; + } +} + +function requestDeblok($tableau, $queryPlanete, $queryUser){ + if ($tableau == '0') return true; + else { + $nbDeblok = count($tableau); + $return = true; + for ($i=0 ; $i<$nbDeblok ; $i++) { + if (isset($queryPlanete[$tableau[$i][1]]) && $queryPlanete[$tableau[$i][1]] < $tableau[$i][2]) $return = false; + elseif (isset($queryUser[$tableau[$i][1]]) && $queryUser[$tableau[$i][1]] < $tableau[$i][2]) $return = false; + } + return $return; + } +} + +function techno($nom, $niveau, $niveau_ress) { + if (empty($niveau)) $niveau = 0; + if ($niveau < $niveau_ress) return ''.$nom.' '.$niveau_ress.' ('.$niveau.')'; + else return ''.$nom.' '.$niveau_ress.' ('.$niveau.')'; +} + +function txtmission($mission){ + if ($mission == 0) return 'Stationner'; + elseif ($mission == 1) return 'Attaquer'; + elseif ($mission == 2) return 'Transporter'; + elseif ($mission == 3) return 'Coloniser'; + elseif ($mission == 4) return 'Recycler'; + elseif ($mission == 5) return 'Espionner'; + else return 'Erreur'; +} + +function txtTactique($tactique){ + switch($tactique){ + case 1: return '1'; break; + case 2: return '2'; break; + case 3: return '3'; break; + case 4: return '4'; break; + case 5: return '5'; break; + case 6: return '6'; break; + case 7: return '7'; break; + case 8: return '8'; break; + case 9: return '9'; break; + case 10: return '10'; break; + case 11: return '11'; break; + case 12: return '12'; break; + case 13: return '13'; break; + case 14: return '14'; break; + case 15: return '15'; break; + case 16: return '16'; break; + case 17: return '17'; break; + case 18: return '18'; break; + case 19: return '19'; break; + case 20: return '20'; break; + case 21: return '21'; break; + default: return 'autre'; break; + } +} + +function tactique($tactique){ + switch($tactique){ + case 1: return array(1,0,100,false); break; + case 2: return array(2,88,12,false); break; + case 3: return array(3,75,25,false); break; + case 4: return array(4,63,37,false); break; + case 5: return array(5,50,50,false); break; + case 6: return array(6,37,63,false); break; + case 7: return array(7,25,75,false); break; + case 8: return array(8,12,88,false); break; + case 9: return array(9,12,88,true); break; + case 10: return array(10,25,75,true); break; + case 11: return array(11,37,63,true); break; + case 12: return array(12,50,50,true); break; + case 13: return array(13,63,37,true); break; + case 14: return array(14,75,25,true); break; + case 15: return array(15,75,26,true); break; + case 16: return array(16,75,27,true); break; + case 17: return array(17,75,28,true); break; + case 18: return array(18,75,29,true); break; + case 19: return array(19,75,30,true); break; + case 20: return array(20,75,31,true); break; + case 21: return array(21,75,32,true); break; + default: return array(1,0,100,false); break; + } +} + +function pillage($metal, $cristal, $hydrogene, $vfm){ + $Qm = $metal / $vfm; + $Qc = $cristal / $vfm; + $Qh = $hydrogene / $vfm; + + $somme = $Qm + $Qc + $Qh; + + if ($somme < 2) { + $Fm = $metal / 2; + $Fc = $cristal / 2; + $Fh = $hydrogene / 2; + } + else { + $Fm = $Qm / $somme * $vfm; + $Fc = $Qc / $somme * $vfm; + $Fh = $Qh / $somme * $vfm; + } + + return array(floor($Fm), floor($Fc), floor($Fh)); +} + +function vais_tempsDeplacement($start_galaxie,$start_ss,$start_position,$end_galaxie,$end_ss,$end_position,$vitesse,$coefvitesse = 1,$preparation = 0,$chauffe = 0) { + if ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0 && $end_position-$start_position == 0) $temps = 0; + elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0 && $chauffe == 0) $temps = $preparation+abs($end_position-$start_position)*$vitesse/12; + elseif ($end_galaxie-$start_galaxie == 0 && $chauffe == 0) $temps = $preparation+abs($end_ss-$start_ss)*$vitesse; + elseif ($chauffe == 0) $temps = $preparation+abs($end_galaxie-$start_galaxie)*$vitesse*300; + elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss == 0) $temps = $preparation+abs($end_position-$start_position)*($vitesse*2)/12+$preparation; + /*elseif ($end_galaxie-$start_galaxie == 0 && $end_ss-$start_ss <= $chauffe) $temps = abs($end_ss-$start_ss)*(($vitesse/$chauffe)*($chauffe-abs($end_ss-$start_ss))+$vitesse)+$preparation; + elseif ($end_galaxie-$start_galaxie == 0) $temps = $vitesse*abs($end_ss-$start_ss)+$vitesse*10+$preparation;*/ + elseif ($end_galaxie-$start_galaxie == 0) $temps = (abs($end_ss-$start_ss)*(($vitesse/$chauffe)*((abs($chauffe-abs($end_ss-$start_ss))+($chauffe-abs($end_ss-$start_ss)))/2)+$vitesse))+(20-(abs($chauffe-abs($end_ss-$start_ss))+($chauffe-abs($end_ss-$start_ss)))/2)*54+$preparation; + else $temps = (($vitesse/$chauffe)*($chauffe-abs($end_galaxie-$start_galaxie))+$vitesse)*300+108+$preparation; + + return $temps/$coefvitesse; +} + +function vais_conso($tempsDeplacement,$nbvais = 1){ + return intval($tempsDeplacement*$nbvais/20); +} +?> \ No newline at end of file diff --git a/pages/includes/noms.php b/includes/noms.php similarity index 62% rename from pages/includes/noms.php rename to includes/noms.php index 7bab568..9dbf63c 100644 --- a/pages/includes/noms.php +++ b/includes/noms.php @@ -1,82 +1,81 @@ values['auth_level']; if ($race == 'covenant') { $ressourc = array('Métal','Cristal','Ions','Energie'); $casernen = array('Grunt','Jackal','Drone','Elite','Sniper','Hunter','Médecin','Ingénieur','Brute'); $casernde = array( 'Formant l\'unité d\'infanterie de base des Covenants, les Grunt se révèlent dangereux en groupe, mais ne représentent individuellement qu\'une faible menace. Petits, trapus et relativement lents, ils paniquent souvent lorsqu\'ils affrontent des ennemis qui leurs sont supérieurs ; cependant, s\'ils sont menés par un Sangheili, ils se battront jusqu\'au bout.', 'Tireurs efficaces, les jackals sont généralement employés comme mercenaires, on les trouve souvent en positions défensives, se battant protégés par les boucliers à énergie qui les caractérisent. Un bouclier bien utilisé fait d\'un Jackal une cible difficile à atteindre, mais celui-ci doit l\'écarter pour faire feu, ce qui lui confère un point faible exploitable.', - 'Tout comme les Brutes, les Drones semblent avoir été intégrés depuis peu aux forces d\'assaut covenantes et sont déployés en masse. Apparemment d\'origine insectoïde, ce sont les gardes des vaisseaux covenants. Ils ont également la capacité - limitée - de voler et font d\'excellents tireurs, très intelligents.', + 'Tout comme les Brutes, les Drones semblent avoir été intégrés depuis peu aux forces d\'assaut covenantes et sont déployés en masse. Apparemment d\'origine insectoïde, ce sont les gardes des vaisseaux covenants. Ils ont également la capacité - limitée - de voler et font d\'excellents tireurs, très intelligents.', 'Les Elites constituent l\'ossature des armées covenantes. Excellents soldats, tacticiens émérites et disciplinés, combattants agressifs, ils représentent la principale force des covenants. Plus rapides, plus forts et plus résistants que les humains, ils combattent en groupes restreints et dirigent souvent des escouades de Grunts. La couleur de leur armure indique leur rang.', 'Le sniper est une classe des jackals. Excellents tireurs de nature, les Jackals qui se sont spécialisés dans ce domaine bénéficient d\'un rang plus élevé que leurs congénères. Ils sont très destructeurs de loin mais assez peu de près. Ils ne possèdent cependant pas de bouclier de protection comme leurs frères.', 'Les Hunters sont des ennemis incroyablement dangereux qui sont déployés plus comme du matériel que comme des soldats. Ils sont utilisés pour des tâches de démolitions ou de défense lourde et se battent toujours par deux. Ces créatures massives portent une armure quasiment impénétrable et une arme à combustible redoutable au combat.', - 'Les médecins sont sur le champ de bataille pour aider les soldats blessés par des tirs lors des affrontements. Ils peuvent réduire le nombre de morts lorsqu\'ils sont bien utilisés, et donc peuvent peut être changer l’issue de la bataille.', + 'Les médecins sont sur le champ de bataille pour aider les soldats blessés par des tirs lors des affrontements. Ils peuvent réduire le nombre de morts lorsqu\'ils sont bien utilisés, et donc peuvent peut être changer l’issue de la bataille.', 'Les ingénieurs, appelés Huragok en langage covenant, forment la seule unité non-combattante connue des forces covenantes. Celle-ci répare vos unités et véhicules sur le champ de bataille ; plus vous en recrutez, plus vos unités et véhicules au sol auront une chance de survivre.', - 'Moins bien connus que les Elites, les Brutes combattent en groupes et sont physiquement plus forts que leurs congénères. Les Brutes démontrent les mêmes aptitudes au combat que les Elites et leur nombre s\'est considérablement accru depuis le début du conflit. Ils portent une arme balistique explosive à laquelle est fixée une baïonnette.'); + 'Moins bien connus que les Elites, les Brutes combattent en groupes et sont physiquement plus forts que leurs congénères. Les Brutes démontrent les mêmes aptitudes au combat que les Elites et leur nombre s\'est considérablement accru depuis le début du conflit. Ils portent une arme balistique explosive à laquelle est fixée une baïonnette.'); $casernea = array('grunt(s)','jackal(s)','drone(s)','élite(s)','sniper(s)','hunter(s)','médecin(s)','ingénieur(s)','brute(s)'); $casernei = array('grunt1.jpg','jackal.jpg','drone.jpg','elite.jpg','jackalsniper.jpg','hunter1.jpg','medecin_c.jpg','ingenieur_c.jpg','brute.jpg'); $batimend = array('purificateur_m','purificateur_c','ionisateur','centrale_s','centrale_fusion','oeil','recherches','chantier_terrestre','???','caserne','silo','centre_info'); $batimeni = array('purificateurdemtalhb3.jpg','cristaloo3.png','ioniseurdn4.jpg','solaire.jpg','sanstitrevi7.jpg','oeilduprophetewj6.jpg','covielabocn5.jpg','chantierterrestrehg1.jpg','sanstitretruecolor09zn6.jpg','caserncov0ry.jpg','stockagebasement1cs10bl.jpg','ordianteur_hologramme.jpg'); - $batiment = array('Purificateur de métal','Purificateur de cristal','Ionisateur','Centrale solaire','Centrale de fusion','Oeil des prophètes','Centre de recherches','Chantier terrestre','Chantier spatial','Caserne','Entrepôt','Centrale informatique'); + $batiment = array('Purificateur de métal','Purificateur de cristal','Ionisateur','Centrale solaire','Centrale de fusion','Oeil des prophètes','Centre de recherches','Chantier terrestre','Chantier spatial',0/*'Caserne'*/,'Entrepôt','Centrale informatique'); $batimede = array( 'Le purificateur de métal vous fournie les matières premières pour la construction de vos infrastructures et de vos unités. Plus vous développerez vos purificateurs, plus ils produiront de ressources. Les purificateurs les plus développés ont aussi besoin de plus d\'énergie.', - 'Le purificateur de cristal vous fournie les ressources pour vos installations électroniques et pour les alliages. Le purificateur de cristal consomme deux fois plus d\'énergie que celui de métal. Tous les vaisseaux et bâtiments ont besoin de cristal pour leur bouclier ou encore leurs composants électroniques. La production augmente avec le développement de l’usine.', + 'Le purificateur de cristal vous fournie les ressources pour vos installations électroniques et pour les alliages. Le purificateur de cristal consomme deux fois plus d\'énergie que celui de métal. Tous les vaisseaux et bâtiments ont besoin de cristal pour leur bouclier ou encore leurs composants électroniques. La production augmente avec le développement de l’usine.', 'L\'ionisateur utilise des ions négatifs et positifs d\'hydrogène pour créer une source conventionnelle de courant stable, servant à alimenter les bâtiments covenants qui nécessitent une arrivée massive de cette "ressource" pour actionner les divers éléments matériels des contrôles. La centrale de fusion à besoin de beaucoup d\'hydrogène pour fonctionner.', - 'Pour assurer l\'approvisionnement des purificateurs, des centrales solaires sont nécessaires. Plus ces installations sont développées, plus vous obtiendrez d’énergie pour vos purificateurs. Les centrales solaires sont la base de l\'approvisionnement pour votre planète en énergie. Elles sont composées d’un recueilleur sur le haut de sa structure qui capte en grandes quantités l’énergie solaire.', - 'La centrale à fusion vous permet de créer l’énergie nécessaire à vos purificateurs. Elles est constitué d’un réacteur à fusion qui en tournant produit de l’énergie. Sa production reste nettement inférieure à celle d’une centrale solaire.', - 'Les grands prophètes ont partagé leur savoir pour construire ces structures qui permettent de repérer les éléments s’approchants de votre planète. Le système est constitué de deux grands arcs qui envoient des signaux électriques dans l’espace et captent ceux qui reviennent présageant ainsi l’arrivée d’un vaisseau.', - 'Le centre de recherches, l\'un des bâtiments les plus importants de votre colonie, vous permet de vous accaparer des technologies aliens aujourd’hui disparues ou des technologies en cours de développement dans d’autres factions. Le niveau du centre détermine la vitesse de la recherche. Chaque planète que vous coloniserez devra être équipée d’un centre d\'étude des artefacts et des technologies.', - 'Le centre de recherches, l\'un des bâtiments les plus importants de votre colonie, vous permet de vous accaparer des technologies aliens aujourd’hui disparues ou des technologies en cours de développement dans d’autres factions. Le niveau du centre détermine la vitesse de la recherche. Chaque planète que vous coloniserez devra être équipée d’un centre d\'étude des artefacts et des technologies.', - 'Le chantier terrestre vous permet de construire tous les véhicules atmosphériques du type ghosts, spectres ou autres. Il permet ainsi à vos armées d’accéder plus rapidement à un endroit et d’avoir un avantage avec l’armement de ces véhicules.', - 'Ce bâtiment permet la création de toutes vos unités spatiales ou volantes. La force des covenants a souvent été due à ses grandes avancées technologiques en matière d’aéronautique. Un grand chantier spatial permet de créer des unités de plus en plus fortes et de surcroît de les créer de plus en plus rapidement.', - 'Le Temple de la Guerre vous permet de créer l’élite des forces d’infanterie. Des soldats y sont fanatisés puis entraînés au maniement des armes et à la stratégie militaire. Plus vous développez le temple, plus la vitesse de production sera rapide.', - 'Les ressources qui ne sont pas encore traitées sont mises en stock dans ces entrepôts géants. Un entrepôt plus grand permet le stockage d\'une plus grande quantité de ressources. Lorsque l’entrepôt est plein, l\'extraction est stoppée. Il est grandement conseillé de développer ce genre d’infrastructure.', + 'Pour assurer l\'approvisionnement des purificateurs, des centrales solaires sont nécessaires. Plus ces installations sont développées, plus vous obtiendrez d’énergie pour vos purificateurs. Les centrales solaires sont la base de l\'approvisionnement pour votre planète en énergie. Elles sont composées d’un recueilleur sur le haut de sa structure qui capte en grandes quantités l’énergie solaire.', + 'La centrale à fusion vous permet de créer l’énergie nécessaire à vos purificateurs. Elles est constitué d’un réacteur à fusion qui en tournant produit de l’énergie. Sa production reste nettement inférieure à celle d’une centrale solaire.', + 'Les grands prophètes ont partagé leur savoir pour construire ces structures qui permettent de repérer les éléments s’approchants de votre planète. Le système est constitué de deux grands arcs qui envoient des signaux électriques dans l’espace et captent ceux qui reviennent présageant ainsi l’arrivée d’un vaisseau.', + 'Le centre de recherches, l\'un des bâtiments les plus importants de votre colonie, vous permet de vous accaparer des technologies aliens aujourd’hui disparues ou des technologies en cours de développement dans d’autres factions. Le niveau du centre détermine la vitesse de la recherche. Chaque planète que vous coloniserez devra être équipée d’un centre d\'étude des artefacts et des technologies.', + 'Le chantier terrestre vous permet de construire tous les véhicules atmosphériques du type ghosts, spectres ou autres. Il permet ainsi à vos armées d’accéder plus rapidement à un endroit et d’avoir un avantage avec l’armement de ces véhicules.', + 'Ce bâtiment permet la création de toutes vos unités spatiales ou volantes. La force des covenants a souvent été due à ses grandes avancées technologiques en matière d’aéronautique. Un grand chantier spatial permet de créer des unités de plus en plus fortes et de surcroît de les créer de plus en plus rapidement.', + 'Le Temple de la Guerre vous permet de créer l’élite des forces d’infanterie. Des soldats y sont fanatisés puis entraînés au maniement des armes et à la stratégie militaire. Plus vous développez le temple, plus la vitesse de production sera rapide.', + 'Les ressources qui ne sont pas encore traitées sont mises en stock dans ces entrepôts géants. Un entrepôt plus grand permet le stockage d\'une plus grande quantité de ressources. Lorsque l’entrepôt est plein, l\'extraction est stoppée. Il est grandement conseillé de développer ce genre d’infrastructure.', 'La centrale informatique est le coeur de votre planète, le cerveau de votre territoire, analysant chaque particule détectée avec grand soin. Plus votre centrale est améliorée, plus rapidement et aisément les données seront traitées.'); $technolo = array('Informatique','Detection','Armement','Bouclier','Maitrise de l\'énergie','Réacteur à antigravité','Réacteur à fusion','Réacteur à fusion Forerunner','Médecine','Commandement militaire',0); - $technode = array( 'L’informatique vous permet de traiter les informations de façon très rapide réduisant ainsi les temps de réactions qui dans les combats peuvent s’avérer fatales.', - 'La détection est cruciale pour préserver sa flotte et ses planètes. Développer cette technologie vous permet de construire une base « œil des prophètes » qui repèrera les vaisseaux s’approchant de votre planète.', + $technode = array( 'L’informatique vous permet de traiter les informations de façon très rapide réduisant ainsi les temps de réactions qui dans les combats peuvent s’avérer fatales.', + 'La détection est cruciale pour préserver sa flotte et ses planètes. Développer cette technologie vous permet de construire une base « Å“il des prophètes » qui repèrera les vaisseaux s’approchant de votre planète.', 'Un soldat n\'est rien sans son arme, et qu\'est-ce qu\'un soldat démuni face aux assauts féroces adverses ? Cette technologie vous permettra de rechercher de nouveaux systèmes d\'armements afin de rendre vos outils de guerre plus précis et mortels.', - 'Le bouclier est un champ de force qui entoure vos vaisseaux et les protège. Ainsi il permet à vos vaisseaux de tenir plus longtemps face aux missiles adverses, ceci s\'avérant peut être décisif dans l’issue de la bataille.', - 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et vaisseaux ; vos chercheurs vous permettront également d\'accéder à de nouveaux types d\'énergies, beaucoup plus intéressants.', + 'Le bouclier est un champ de force qui entoure vos vaisseaux et les protège. Ainsi il permet à vos vaisseaux de tenir plus longtemps face aux missiles adverses, ceci s\'avérant peut être décisif dans l’issue de la bataille.', + 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et vaisseaux ; vos chercheurs vous permettront également d\'accéder à de nouveaux types d\'énergies, beaucoup plus intéressants.', 'Les réacteurs à antigravité sont les moteurs basiques covenant. Ils utilisent une technologie complexe projetant des particules quantiques créant un champ gravitationnel inverse annulant ainsi la gravité présente. Le principe fonctionne également dans l\'espace puisque l\'absence de gravité dans l\'espace, sans compter les étoiles et les autres anomalies spatiales, permet une projection plus puissante du champ.', - 'Après la combustion, voici la fusion. Ce type de réacteur est beaucoup plus puissant que la combustion utilisée depuis déjà des centaines d\'années. Il génère une énergie cinétique de grande envergure. Aucun dirigeant politique désirant voyager dans le cosmos ne pourrait s’en passer.', - 'Les covenants ont découvert d’anciens réacteurs à fusion utilisant la technologie d’hyperpropulsion Forerunner. Cette technologie, beaucoup plus puissante que le réacteur conventionnel au Plasma, autorise des sauts dans le sous-espace ultra précis. Ce type de réacteur est le plus cher mais aussi le plus rapide et puissant de toute la flotte covenante.', - 'La médecine vous permet d’avoir moins de pertes au combat et ainsi d’avoir une force de frappe qui résiste plus longtemps. Au lieu de laisser mourir les soldats blessés, le médecin les soigne pour les remettre sur pied et les rendre de nouveau aptes au combat.', + 'Après la combustion, voici la fusion. Ce type de réacteur est beaucoup plus puissant que la combustion utilisée depuis déjà des centaines d\'années. Il génère une énergie cinétique de grande envergure. Aucun dirigeant politique désirant voyager dans le cosmos ne pourrait s’en passer.', + 'Les covenants ont découvert d’anciens réacteurs à fusion utilisant la technologie d’hyperpropulsion Forerunner. Cette technologie, beaucoup plus puissante que le réacteur conventionnel au Plasma, autorise des sauts dans le sous-espace ultra précis. Ce type de réacteur est le plus cher mais aussi le plus rapide et puissant de toute la flotte covenante.', + 'La médecine vous permet d’avoir moins de pertes au combat et ainsi d’avoir une force de frappe qui résiste plus longtemps. Au lieu de laisser mourir les soldats blessés, le médecin les soigne pour les remettre sur pied et les rendre de nouveau aptes au combat.', 'En tant que général, vous devez avoir un esprit fin pour gagner vos batailles terrestres aussi bien que les affrontements spatiaux. C\'est pourquoi il vous faudra toujours innover en matière de stratégie, vous montrer toujours plus rusé que votre impitoyable adversaire, aussi feriez-vous bien d\'étudier de nouvelles tactiques de combat pour vous assurer une franche victoire.'); $technoli = array('informatique1.jpg','detection.jpg','sanstitretruecolor04no6.jpg','boucliervaiseaucovenantey4.jpg','energie.jpg','reacteurantigravyd1.jpg','reacteur_f.jpg','reacteurfusionforerunnewu0.jpg','medecine.JPG','commandement.jpg'); $nomvaisa = array('cargos de classe Inquisitor','grand(s) transporteur(s)','vaisseau(x) de colonisation','sonde(s)','recycleur(s)','séraphin(s)','frégate(s)','croiseur(s) de classe CCS','croiseur(s) de classe Reverence','porte-vaisseaux','station(s) orbitale','super(s) porte-vaisseaux'); - $nomvaisi = array('cargosparabola.jpg','cargosladen.jpg','coviecolobv3.jpg','sonde_despionnage1.jpg','charognard.jpg','chasseurlourd7id.jpg','croiseur8er.jpg','fregate2ky.jpg','croiseur.jpg','pv.jpg','citecovenant.jpg','.jpg'); + $nomvaisi = array('cargosparabola.jpg','cargosladen.jpg','coviecolobv3.jpg','sonde_despionnage1.jpg','charognard.jpg','chasseurlourd7id.jpg','croiseur8er.jpg','fregate2ky.jpg','vaisseaudebataille9na.jpg','pv.jpg','station1.jpg','citecovenant.jpg'); $nomvaisn = array('Cargos de classe Inquisitor','Cargos de classe Interdictor','Vaisseau de colonisation de classe Returning','Sonde de reconnaissance de classe Perception','Charognard','Séraphin','Frégate','Croiseur de classe CCS','Croiseur de classe Reverence','Porte vaisseaux','Station orbitale covenant','Super porte vaisseaux'); $nomvaisd = array( 'Les cargos Inquisitor sont la base du transport de troupes et de ressources covenantes, capables de transporter un grand nombre de ressources sur une grande distance. Pratiquement sans armement, le cargo est sans défense et nécessite une défense rapprochée pour les trajets de grande distance.', - 'Les cargos Interdictor sont une évolution du transport de classe Inquisitor. Ayant une capacité de transport nettement supérieure à sa version précédente. Ce transport, quoique plus récent et disposant d\'un plus grand fret, dispose du même genre de défense que le modèle antérieur, une escorte est donc fortement recommandée lors de l\'utilisation de celui-ci.', - 'Tout comme les humains, les covenants ont besoins d\'espace pour étendre leur empire et c\'est pourquoi ces vaisseaux ont été pensés et conçus. Capable de transformer la nature même d\'une planète en très peu de temps, ce vaisseau est essentiel au développement de la société covenante.', + 'Les cargos Interdictor sont une évolution du transport de classe Inquisitor. Ayant une capacité de transport nettement supérieure à sa version précédente. Ce transport, quoique plus récent et disposant d\'un plus grand fret, dispose du même genre de défense que le modèle antérieur, une escorte est donc fortement recommandée lors de l\'utilisation de celui-ci.', + 'Tout comme les humains, les covenants ont besoins d\'espace pour étendre leur empire et c\'est pourquoi ces vaisseaux ont été pensés et conçus. Capable de transformer la nature même d\'une planète en très peu de temps, ce vaisseau est essentiel au développement de la société covenante.', 'Cette sonde de reconnaissance covenante est largement utilisée lorsqu\'il est trop dangereux d\'envoyer un vaisseau. Sa fonction consiste à rassembler des données sur les vaisseaux ou encore sur une planète dans un système planétaire.', - 'Chaque bataille amène des pertes des 2 côtés, et ce vaisseau est conçu pour en tirer tous les bénéfices. Le Charognard, en retrait de la flotte principale, ramasse ce qu\'il reste des vaisseaux détruits et les ramène à sa planète d\'origine où ces "déchets" pourront être utilisés pour produire des matières premières.', - 'Le plus puissant et probablement le plus craint de tous les vaisseaux Covenants. Le Séraphin est le principal vaisseau offensif dans l’espace et peut être employé comme bombardier aérien. Le Séraphin est d\'environ trois fois la taille d\'un Banshee, il possède plusieurs canons de plasma qu\'il utilise lors des engagements aériens pour éliminer des opposants de type LongsWord et Pélican.', - 'La frégate covenante est un vaisseau de tonnage moyen composant majoritairement les flottes habituelles. Équipée de lasers à impulsion et de lanceurs de torpilles au plasma latéraux, elle possède ainsi une puissance de feu raisonnable. Sa coque est aussi protégée par un bouclier énergétique la rendant beaucoup plus difficile à détruire.', + 'Chaque bataille amène des pertes des 2 côtés, et ce vaisseau est conçu pour en tirer tous les bénéfices. Le Charognard, en retrait de la flotte principale, ramasse ce qu\'il reste des vaisseaux détruits et les ramène à sa planète d\'origine où ces "déchets" pourront être utilisés pour produire des matières premières.', + 'Le plus puissant et probablement le plus craint de tous les vaisseaux Covenants. Le Séraphin est le principal vaisseau offensif dans l’espace et peut être employé comme bombardier aérien. Le Séraphin est d\'environ trois fois la taille d\'un Banshee, il possède plusieurs canons de plasma qu\'il utilise lors des engagements aériens pour éliminer des opposants de type LongsWord et Pélican.', + 'La frégate covenante est un vaisseau de tonnage moyen composant majoritairement les flottes habituelles. Équipée de lasers à impulsion et de lanceurs de torpilles au plasma latéraux, elle possède ainsi une puissance de feu raisonnable. Sa coque est aussi protégée par un bouclier énergétique la rendant beaucoup plus difficile à détruire.', 'Ce vaisseau redoutable et titanesque sème sans le moindre doute la terreur chez l\'ennemi. Armé d\'un bout à l\'autre de lasers à impulsion, de torpilles au plasma et de bien d\'autres armes, ce croiseur est une arme extraordinaire à ne jamais sous estimer.', - 'Un des plus grands vaisseaux de combat covenant, mesurant 3000 mètres. Équipé de deux canons à projection énergétique et de sept lanceurs de torpilles, il est d\'une puissance extraordinaire. Le seul problème résidant dans le fait que son équipement demande une capacité d\'énergie phénoménale.', + 'Un des plus grands vaisseaux de combat covenant, mesurant 3000 mètres. Équipé de deux canons à projection énergétique et de sept lanceurs de torpilles, il est d\'une puissance extraordinaire. Le seul problème résidant dans le fait que son équipement demande une capacité d\'énergie phénoménale.', 'Comme son nom l\'indique, son principal rôle est de transporter des chasseurs Seraphins, des Spirits ou d\'autres vaisseaux de taille similaire. Armé de quelques lasers à impulsion, le porte vaisseau reste un vaisseau de support plutôt qu\'un vaisseau de confrontation directe. Hypothétiquement parlant, sa capacité de tir est légèrement supérieure à celui d\'une corvette.', - 'La station spatiale covenante, construite a même un astéroide, possède un canon plasma d\'une centaine de mettre de long projetant une sphère de plasma atteignant une chaleur proche de celle du coeur d\'un soleil. Également équipé de tourelle automatique pour les chasseurs d\'efficacité moyenne, se poste orbital covenant est une arme défensive terrifiante pour toute adversaire de haut niveau ou non.', + 'La station spatiale covenante, construite a même un astéroide, possède un canon plasma d\'une centaine de mettre de long projetant une sphère de plasma atteignant une chaleur proche de celle du coeur d\'un soleil. Également équipé de tourelle automatique pour les chasseurs d\'efficacité moyenne, se poste orbital covenant est une arme défensive terrifiante pour toute adversaire de haut niveau ou non.', 'Le vaisseau ultime de la flotte covenante, long de plus de 5400 mètres. Ce vaisseau est capable de transporter des quantités de chasseurs hors du commun. Armé de projecteurs énergétique et de laser à impulsion, ce vaisseau est le plus puissant après la station spatiale.'); $nomterra = array('banshee(s)','spirit(s)','phantom','boarding craft','ghost(s)','shadow','spectre(s)','appartition(s)','shade','strong shade','tourelle(s) à barreau de combustible','canon(s) à plasma','lanceur(s) de torpilles plasma'); $nomterrn = array('Banshees', 'Spirit', 'Phantom', 'Boarding craft', 'Ghost', 'Shadow', 'Spectre', 'Appartition', 'Shade', 'Strong shade', 'Tourelle à barreau de combustible', 'Canon à plasma', 'Lanceur de torpilles plasma'); $nomterri = array('bansheeqp0.jpg', 'spirit1.jpg', 'phantomfu2.jpg', 'boardingcraft.jpg', 'ghostic1.jpg', 'shadow.jpg', 'spectre.jpg', 'wraith.jpg', 'shade.jpg', 'strongshade.jpg', 'tourellebarreau.jpg', 'tourelle.jpg', 'lanceur_torpilles.jpg'); $nomterde = array( 'Rapide et maniable, le Banshee est un formidable véhicule d\'assaut aérien, efficacement blindé contre les armes à feu légères mais ne résistant cependant pas aux armes plus lourdes. Le canon à combustible dont il est équipé en fait un bombardier dangereux tout autant qu\'un chasseur rapide. Le Banshee a la possibilité de faire des tonneaux et des vrilles, ce qui serait impossible pour des véhicules à l\'aérodynamique conventionnelle.', - 'Le spirit est une navette de transport de troupes terrestre. De capacité moyenne, il peut transporter un petit contingent armé dans les zones les plus repoussées des planètes. Le spirit est équipé d\'une tourelle de type shade de puissance moyenne, qui permet de maintenir les troupes ennemis à distance jusqu\'à ce que le largage des troupes soit effectué.
    Malheureusement, un manque d\'espace empêche l\'installation de générateur énergétique plus puissant qui pourrait supporter des boucliers standards ou même de faible intensité.', - 'Le Phantom est un vaisseau beaucoup plus fiable que le vaisseau de débarquement « Spirit ». Il possède trois tourelles plasma particulièrement puissantes et peut laisser tomber ses occupants à terre via un ascenseur gravitationnel sans devoir se poser. Le Phantom a un blindage beaucoup plus résistant que son prédécesseur, une puissance de feu accrue et peut transporter tout type d’équipage comme des hunters.
    Le Phantom est assez nouveau dans l\'arsenal Covenant mais est rapidement devenu une crainte car son bombardement de plasma peut éliminer un bon nombre de marines.', + 'Le spirit est une navette de transport de troupes terrestre. De capacité moyenne, il peut transporter un petit contingent armé dans les zones les plus repoussées des planètes. Le spirit est équipé d\'une tourelle de type shade de puissance moyenne, qui permet de maintenir les troupes ennemis à distance jusqu\'à ce que le largage des troupes soit effectué.
    Malheureusement, un manque d\'espace empêche l\'installation de générateur énergétique plus puissant qui pourrait supporter des boucliers standards ou même de faible intensité.', + 'Le Phantom est un vaisseau beaucoup plus fiable que le vaisseau de débarquement « Spirit ». Il possède trois tourelles plasma particulièrement puissantes et peut laisser tomber ses occupants à terre via un ascenseur gravitationnel sans devoir se poser. Le Phantom a un blindage beaucoup plus résistant que son prédécesseur, une puissance de feu accrue et peut transporter tout type d’équipage comme des hunters.
    Le Phantom est assez nouveau dans l\'arsenal Covenant mais est rapidement devenu une crainte car son bombardement de plasma peut éliminer un bon nombre de marines.', '~#DESCRIPTION MANQUANTE#~ Boarding craft', 'Le ghost est un véhicule de reconnaissance et d\'attaque rapide déployée par les Covenants dans tout combat terrestre. Cet engin, très souvent piloté par les Elites, est très maniable. Il est capable de tirer des doubles décharges de plasma surchauffées d\'une puissance de 100-250 kW. Le ghost peut également effectuer des pointes de vitesse soutenues.', 'Le Shadow est le principal moyen de transport terrestre des troupes covenantes. Ce véhicule peut accueillir un pilote, un artilleur et jusqu\'à huit passagers en fonction du type de Covenants qui monte à bord. Il est en outre équipé pour transporter des Elites, des Brutes, des Grunts ou des Jackals. Si le Shadow est équipé d\'un canon à plasma, sa vocation reste le déploiement de troupes.', - 'Le Spectre est un transport multi troupes blindé de petite taille. Quoique relativement lent, il est tout à fait maniable et se meut avec aisance dans les espaces confinés. Ses principales faiblesses étant son manque de vitesse et d\'accélération, ses occupants demeurent tout de même relativement exposés. Le canon à plasma monté à l\'arrière représente un grand danger pour l\'ennemi et le véhicule offre par ailleurs diverses positions de tir.', + 'Le Spectre est un transport multi troupes blindé de petite taille. Quoique relativement lent, il est tout à fait maniable et se meut avec aisance dans les espaces confinés. Ses principales faiblesses étant son manque de vitesse et d\'accélération, ses occupants demeurent tout de même relativement exposés. Le canon à plasma monté à l\'arrière représente un grand danger pour l\'ennemi et le véhicule offre par ailleurs diverses positions de tir.', 'Lent, massif et constituant une cible de taille, ce véhicule n\'en demeure pas moins le blindé covenant le plus destructeur. Ce géant de métal est bien protégé. Le tir de couverture qu\'il peut effectuer grâce à ses mortiers à plasma redoutables en fait un ennemi incroyablement dangereux. Le fait qu\'il soit piloté par une seule personne qui contrôle le véhicule et le système d\'armement limite quelque peu son champ de manoeuvre.', - 'Les tourelles shades sont des canons stationnaires énergétiques covenant composés de deux parties, la première étant une base stable à trois pieds pour la stabilité de l’appareil, la deuxième, un siège où le canon est fixé retenu par un champ gravitationnel artificiel. Ce canon lorsqu’il tire, envoie 3 « éclairs » relativement lents et d’efficacité moyenne.', - 'Cette tourelle est une version améliorée de la shade standard. Dans les modifications de la tourelle, le système d’accélération magnétique a été révisé pour le rendre plus performant, aboutissant à des rayons plus rapides. Également, un bouclier a été ajouté à l’avant, protégeant ainsi l’utilisateur des attaques aux armes à projectiles de petit et moyen calibre pendant une période de quelques secondes lors de feux nourris.', + 'Les tourelles shades sont des canons stationnaires énergétiques covenant composés de deux parties, la première étant une base stable à trois pieds pour la stabilité de l’appareil, la deuxième, un siège où le canon est fixé retenu par un champ gravitationnel artificiel. Ce canon lorsqu’il tire, envoie 3 « éclairs » relativement lents et d’efficacité moyenne.', + 'Cette tourelle est une version améliorée de la shade standard. Dans les modifications de la tourelle, le système d’accélération magnétique a été révisé pour le rendre plus performant, aboutissant à des rayons plus rapides. Également, un bouclier a été ajouté à l’avant, protégeant ainsi l’utilisateur des attaques aux armes à projectiles de petit et moyen calibre pendant une période de quelques secondes lors de feux nourris.', 'La tourelle à barreau de combustible est une version fixe de ceux des hunters avec un système de visé amélioré et de condensateur ionique permettent de tirer trois rafales à la suite sans surcharger les relais du générateur. De puissance moyenne, elle est capable de détruire facilement des warthogs et autres véhicules légers avec une facilité hors norme.', - 'Le canon à plasma n’a pas besoin de canonnier pour tirer puisque équipé d’un système de visée automatisé, il utilise une technologie d’intelligence artificielle rudimentaire pour ensuite envoyer un projectile de plasma surchauffé à haute vitesse carbonisant tout sur son passage.', + 'Le canon à plasma n’a pas besoin de canonnier pour tirer puisque équipé d’un système de visée automatisé, il utilise une technologie d’intelligence artificielle rudimentaire pour ensuite envoyer un projectile de plasma surchauffé à haute vitesse carbonisant tout sur son passage.', 'Utilisant un principe similaire de la tourelle à plasma, le lanceur de torpilles plasma utilise un condensateur de matière pour condenser le flux de plasma surchauffé en une masse de destruction pure. Ce système est le système de défense terrestre le plus évolué jamais construit. Son défaut majeur reste sa cadence de tire lente, limitant sa défense face à de multiples adversaires.'); } - elseif (md5($race) == '34c19b21bd4a3dda389e767d32fe9779' && $auth_level >= 6) { + elseif ($auth_level >= 6 && md5($race) == '34c19b21bd4a3dda389e767d32fe9779') { $ressourc = array('Métal','Cristal','Hydrogène','Energie'); $casernen = array('Constructor','Sentinelle Légère','Sentinelle Lourde','Enforcer Léger','Enforcer Lourd','Monitor','~#PAS DE NOM#~ Médecin','~#PAS DE NOM#~ Ingénieur','~#PAS DE NOM#~ Brute'); $casernde = array( 'Les Constructors sont des minis sentinelles capable d\'effectuer certaine reparation mineur, ils peuvent réparés les sentinelles endommager ainsi que les chasseurs légers.', @@ -96,25 +95,25 @@ if (!isset($auth_level)) $auth_level = $_SESSION['auth_level']; $batimede = array( 'Le générateur de métal vous fournie les matières premières pour la construction de vos infrastructures et de vos unités. Plus vous développerez vos générateurs, plus uls vous rapportera. Les générateurs plus développés ont aussi besoin de plus d\'énergie.', 'Le générateur de cristal vous fourni les ressources pour vos installations électroniques et pour les alliages. Le générateur consomme deux fois plus d\'énergie que celui du métal. Tous les vaisseaux et bâtiments ont besoin de cristal pour leur bouclier ou encore leur composant électronique. La production augmente avec le développement du générateur ainsi que sa consommation.', 'L\'hydrogène n\'est pas directement disponible dans la nature. On doit le produire : par electrolyse de l\'eau ce qui consiste à faire passer un courant électrique dans de l\'eau pour que les molécules se séparent et forme du dihydrogène. Mais cette technique utilise de trop grande quantitée d\'énergie.', - 'Pour assurer l\'approvisionnement des générateurs, des générateurs énergie géantes sont nécessaires. Plus ces installations sont développées, plus vous obtiendrez d’énergie pour vos générateurs. Les générateurs d\'énergies sont la base de l\'approvisionnement pour votre planète en énergie.', + 'Pour assurer l\'approvisionnement des générateurs, des générateurs énergie géantes sont nécessaires. Plus ces installations sont développées, plus vous obtiendrez d’énergie pour vos générateurs. Les générateurs d\'énergies sont la base de l\'approvisionnement pour votre planète en énergie.', 0, 0, - 'Le centre de recherche est nécessaire pour développer de nouvelles technologies. Le niveau du centre détermine la vitesse de la recherche. Chaque planète que vous coloniserez devra être équipée d’un centre de recherche.', + 'Le centre de recherche est nécessaire pour développer de nouvelles technologies. Le niveau du centre détermine la vitesse de la recherche. Chaque planète que vous coloniserez devra être équipée d’un centre de recherche.', '~#DESCRIPTION MANQUANTE#~ Chantier terrestre', - 'Le chantier spatial vous permet de construire des vaisseaux, de l’infanterie et vos installations de défense. Plus le chantier est grand, plus la construction de vaisseaux, le recrutement de l’infanterie et la création d’installations de défense est rapide.', + 'Le chantier spatial vous permet de construire des vaisseaux, de l’infanterie et vos installations de défense. Plus le chantier est grand, plus la construction de vaisseaux, le recrutement de l’infanterie et la création d’installations de défense est rapide.', 0, - 'Les ressources qui ne sont pas encore traitées sont mises en stock dans ces entrepôts géants. Un entrepôt plus grand permet le stockage d\'une plus grande quantité de ressources. Lorsque l’entrepôt est plein, l\'extraction est stoppée. Il est grandement conseillé de développer ce genre d’infrastructure.', + 'Les ressources qui ne sont pas encore traitées sont mises en stock dans ces entrepôts géants. Un entrepôt plus grand permet le stockage d\'une plus grande quantité de ressources. Lorsque l’entrepôt est plein, l\'extraction est stoppée. Il est grandement conseillé de développer ce genre d’infrastructure.', 0); $technolo = array('Informatique','Detection','Armement','Bouclier','Maitrise de l\'énergie','Réacteur à antigravité','Réacteur à fusion','Réacteur à fusion Forruner','Médecine','Commandement militaire',0); - $technode = array( 'L’informatique vous permet de traiter les informations de façon très rapide réduisant ainsi les temps de réactions qui dans les combats peuvent s’avérer fatales.', - 'La détection est cruciale pour préserver sa flotte et ses planètes. Développer cette technologie vous permet de construire une base « œil des prophètes » qui repèrera les vaisseaux s’approchant de votre planète.', + $technode = array( 'L’informatique vous permet de traiter les informations de façon très rapide réduisant ainsi les temps de réactions qui dans les combats peuvent s’avérer fatales.', + 'La détection est cruciale pour préserver sa flotte et ses planètes. Développer cette technologie vous permet de construire une base « Å“il des prophètes » qui repèrera les vaisseaux s’approchant de votre planète.', 'Un soldat n\'est rien sans son arme, et qu\'est-ce qu\'un soldat démuni face aux assauts féroces adverses ? Cette technologie vous permettra de rechercher de nouveaux systèmes d\'armements afin de rendre vos outils de guerre plus précis et mortels.', - 'Le bouclier est un champ de force qui entoure vos vaisseaux et les protège. Ainsi il permet à vos vaisseaux de tenir plus longtemps face aux missiles adverses, ceci s\'avérant peut être décisif dans l’issue de la bataille.', - 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et vaisseaux ; vos chercheurs vous permettront également d\'accéder à de nouveaux types d\'énergies, beaucoup plus intéressants.', + 'Le bouclier est un champ de force qui entoure vos vaisseaux et les protège. Ainsi il permet à vos vaisseaux de tenir plus longtemps face aux missiles adverses, ceci s\'avérant peut être décisif dans l’issue de la bataille.', + 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et vaisseaux ; vos chercheurs vous permettront également d\'accéder à de nouveaux types d\'énergies, beaucoup plus intéressants.', 'Les réacteurs à antigravité sont les moteurs basiques covenant. Ils utilisent une technologie complexe projetant des particules quantiques créant un champ gravitationnel inverse annulant ainsi la gravité présente. Le principe fonctionne également dans l\'espace puisque l\'absence de gravité dans l\'espace, sans compter les étoiles et les autres anomalies spatiales, permet une projection plus puissante du champ.', - 'Après la combustion, voici la fusion. Ce type de réacteur est beaucoup plus puissant que la combustion utilisée depuis déjà des centaines d\'années. Il génère une énergie cinétique de grande envergure. Aucun dirigeant politique désirant voyager dans le cosmos ne pourrait s’en passer.', - 'Les covenants ont découvert d’anciens réacteurs à fusion utilisant la technologie d’hyperpropulsion Forruner. Cette technologie, beaucoup plus puissante que le réacteur conventionnel au Plasma, autorise des sauts dans le sous-espace ultra précis. Ce type de réacteur est le plus cher mais aussi le plus rapide et puissant de toute la flotte covenante.', - 'La médecine vous permet d’avoir moins de pertes au combat et ainsi d’avoir une force de frappe qui résiste plus longtemps. Au lieu de laisser mourir les soldats blessés, le médecin les soigne pour les remettre sur pied et les rendre de nouveau aptes au combat.', + 'Après la combustion, voici la fusion. Ce type de réacteur est beaucoup plus puissant que la combustion utilisée depuis déjà des centaines d\'années. Il génère une énergie cinétique de grande envergure. Aucun dirigeant politique désirant voyager dans le cosmos ne pourrait s’en passer.', + 'Les covenants ont découvert d’anciens réacteurs à fusion utilisant la technologie d’hyperpropulsion Forruner. Cette technologie, beaucoup plus puissante que le réacteur conventionnel au Plasma, autorise des sauts dans le sous-espace ultra précis. Ce type de réacteur est le plus cher mais aussi le plus rapide et puissant de toute la flotte covenante.', + 'La médecine vous permet d’avoir moins de pertes au combat et ainsi d’avoir une force de frappe qui résiste plus longtemps. Au lieu de laisser mourir les soldats blessés, le médecin les soigne pour les remettre sur pied et les rendre de nouveau aptes au combat.', 'En tant que général, vous devez avoir un esprit fin pour gagner vos batailles terrestres aussi bien que les affrontements spatiaux. C\'est pourquoi il vous faudra toujours innover en matière de stratégie, vous montrer toujours plus rusé que votre impitoyable adversaire, aussi feriez-vous bien d\'étudier de nouvelles tactiques de combat pour vous assurer une franche victoire.'); $technoli = array('informatique1.jpg','detection.jpg','sanstitretruecolor04no6.jpg','boucliervaiseaucovenantey4.jpg','energie.jpg','reacteurantigravyd1.jpg','reacteur_f.jpg','reacteurfusionforerunnewu0.jpg','medecine.JPG','commandement.jpg'); $nomvaisa = array('cargos de classe Inquisitor','grand(s) transporteur(s)','vaisseau(x) de colonisation','sonde(s)','recycleur(s)','séraphin(s)','frégate(s)','croiseur(s) de classe CCS','croiseur(s) de classe Reverence','porte-vaisseaux','station(s) orbitale','super(s) porte-vaisseaux'); @@ -155,72 +154,72 @@ if (!isset($auth_level)) $auth_level = $_SESSION['auth_level']; $casernde = array( 'Les marines constituent l\'infanterie de base de vos forces militaires. De faible puissance et de résistance plutôt médiocre, ils rivalisent avec les unités covenants standard. Ils sont équipés d\'une armure de kevlar renforcée et d\'un MA5B.', 'Les fusillers sont équipés de fusils d\'assaut avec zoom intégré. Plus puissants que les marines standards, ils peuvent rivaliser avec des escouades entières de grunts dirigées par des élites hauts gradés.', 'Les grenadiers sont les spécialistes en explosifs du CSNU sur le terrain. Ils peuvent détruire les véhicules légers grâce à leurs grenades et leurs lances missiles.', - 'Les TCAO sont des soldats d\'assauts largués depuis l\'espace directement sur les champs de batailles grâce à des modules spéciaux. Ces soldats sont surentraînés et très chevronnés, risquant leur vie à chaque instant en raison des sauts orbitaux qui font atteindre une chaleur extrême dans le module.', + 'Les TCAO sont des soldats d\'assauts largués depuis l\'espace directement sur les champs de batailles grâce à des modules spéciaux. Ces soldats sont surentraînés et très chevronnés, risquant leur vie à chaque instant en raison des sauts orbitaux qui font atteindre une chaleur extrême dans le module.', 'Les snipers sont dotés de fusils de précision SA 2M capable de descendre un covenant à plusieurs centaines de mètres grâce à son zoom maximum de 10x. Grande portée de tir mais à courte portée, ils sont inutiles.', - 'Les spartans sont les unités d\'infanterie militaires les plus évoluées militairement du CSNU mais également des Covenants. Ils sont équipés d\'une armure de type Mjolnir améliorant leurs capacités de combat, déjà exceptionnelles grâce à leur entraînement militaire depuis leur plus jeune âge, ainsi qu\'à leurs implants cybernétiques, les rendants d\'une grande efficacité inégalée au sein de l\'infanterie.', - 'Les médecins sont sur le champ de bataille pour aider les soldats blessés par des tirs lors des affrontements. Ils peuvent réduire le nombre de morts lorsqu\'ils sont bien utilisés et ainsi peut être changer l’issue de la bataille.', + 'Les spartans sont les unités d\'infanterie militaires les plus évoluées militairement du CSNU mais également des Covenants. Ils sont équipés d\'une armure de type Mjolnir améliorant leurs capacités de combat, déjà exceptionnelles grâce à leur entraînement militaire depuis leur plus jeune âge, ainsi qu\'à leurs implants cybernétiques, les rendants d\'une grande efficacité inégalée au sein de l\'infanterie.', + 'Les médecins sont sur le champ de bataille pour aider les soldats blessés par des tirs lors des affrontements. Ils peuvent réduire le nombre de morts lorsqu\'ils sont bien utilisés et ainsi peut être changer l’issue de la bataille.', 'Les ingénieurs sont là pour réparer vos véhicules endommagés lors des affrontements. Ils peuvent réduire le nombre de vos pertes de véhicules lorsqu\'ils sont bien utilisés.', 'Les soldats exo squelettiques possèdent des armures de combat très résistantes et d\'une puissance énorme mais contre balancée par une faible autonomie d\'énergie, une mobilité faible et d\'une discrétion auditive aussi silencieuse qu\'un char d\'assaut dans un champs de mines lotus.'); $casernea = array('marine(s)','fusiller(s)','grenadier(s)','T.C.A.O.','sniper(s)','spartan(s)','médecin(s)','ingénieur(s)','soldat(s) exo squellette'); $casernei = array('marines.jpg','marinehf0.jpg','grenadier.jpg','TCAO2.jpg','sniper.jpg','spartan.jpg','medecin.jpg','ingenieurs.jpg','img_na_ig.jpg'); - $batiment = array('Usine de métallurgie','Usine de cristal','Synchronisateur d\'hydrogène','Centrale solaire','Centrale énergétique','Base radar','Centre de recherches','Chantier terrestre','Chantier spatial','Ecole militaire','Silo de stockage','Centrale informatique'); + $batiment = array('Usine de métallurgie','Usine de cristal','Synchronisateur d\'hydrogène','Centrale solaire','Centrale énergétique','Base radar','Centre de recherches','Chantier terrestre','Chantier spatial',0/*'Ecole militaire'*/,'Silo de stockage','Centrale informatique'); $batimede = array( 'Cette usine traite tous les métaux recueillis afin de produire du titanium-A ou différents types d\'alliages de qualité pour vos différentes constructions planétaires ou spatiales. Chaque niveau augmente la production de métal.', - 'L\'usine de cristal filtre les déchets récoltés avec les cristaux. Une fois séparés du reste ils sont classés par qualité par une quantité d\'appareils de haute technologie. Plus les cristaux sont purs plus ceux-ci peuvent être transformés en unités de stockage de données ou en conducteurs énergétiques de haute qualité. Plus ce bâtiment sera développé, plus vous pourrez traiter de cristaux rapidement.', - 'Ce bâtiment use de l\'eau pour la décomposer et en extraire l\'hydrogène, la base de toutes vos productions énergétiques, pour ensuite l\'acheminer dans des condensateurs ioniques afin de le rendre plus dense et par le fait même plus efficace. Chaque niveau augmente la production du synchronisateur.', - 'La centrale solaire produit l’énergie nécessaire au fonctionnement de vos usines. Elle fonctionne à partir d’une technologie Forruner qui consiste à envoyer un rayon à la verticale pour capter tous les rayons du soleil qui le croise.', - 'La centrale énergétique fonctionne avec un principe assez dépassé. En effet, l’énergie est produite par un réacteur à fusion qui en tournant produit de l’énergie comme le ferait une dynamo. Bien que ce principe fût révolutionnaire à l’époque, il fût rapidement dépassé par la centrale solaire qui permet de produire d’avantage d’énergie.', - 'Base radar', + 'L\'usine de cristal filtre les déchets récoltés avec les cristaux. Une fois séparés du reste ils sont classés par qualité par une quantité d\'appareils de haute technologie. Plus les cristaux sont purs plus ceux-ci peuvent être transformés en unités de stockage de données ou en conducteurs énergétiques de haute qualité. Plus ce bâtiment sera développé, plus vous pourrez traiter de cristaux rapidement.', + 'Ce bâtiment use de l\'eau pour la décomposer et en extraire l\'hydrogène, la base de toutes vos productions énergétiques, pour ensuite l\'acheminer dans des condensateurs ioniques afin de le rendre plus dense et par le fait même plus efficace. Chaque niveau augmente la production du synchronisateur.', + 'La centrale solaire produit l’énergie nécessaire au fonctionnement de vos usines. Elle fonctionne à partir d’une technologie Forruner qui consiste à envoyer un rayon à la verticale pour capter tous les rayons du soleil qui le croise.', + 'La centrale énergétique fonctionne avec un principe assez dépassé. En effet, l’énergie est produite par un réacteur à fusion qui en tournant produit de l’énergie comme le ferait une dynamo. Bien que ce principe fût révolutionnaire à l’époque, il fût rapidement dépassé par la centrale solaire qui permet de produire d’avantage d’énergie.', + 'Le centre de communication est un gigantesque relai de transmission envoyant des ondes entre les différents mondes connus et répertoriés de l\'univers. Grâce à lui, vous pourrez communiquer avec d\'autres administrateurs coloniaux afin de planifier ensemble des programmes d\'actions communs. Equipé d\'un radar, il vous permet de repérer les mouvements des flottes ennemies.', 'Le centre de recherches est certainement l\'une des bâtisses les plus importantes que vous puissiez construire dans votre colonie. Vos chercheurs travailleront sans relâche aucun afin de mettre au point de nouvelles technologies vous assurant suprématie et victoire sur les champs de bataille. Chaque niveau dévellopé augmente la vitesse de recherche de vos technologies.', - 'Le chantier terrestre vous permet de construire tous les véhicules atmosphérique du type warthog ou scorpion. Il permet ainsi à vos troupes d’accéder plus rapidement à un endroit et d’avoir un avantage avec l’armement de ces véhicules.', - 'Le chantier spatial permet de construire vôtre flotte de vaisseaux spatiaux. Généralement à la limite de l’atmosphère d’une planète il ne peut cependant se déplacer et doit impérativement rester en orbite. Le chantier spatial, bien que ressemblant à une station spatial, ne peut être détruit grâce à sa position qui lui confère un camouflage total.', - 'L\'académie militaire forme les meilleurs officiers et sous-officiers de la galaxie. Ces hommes expérimentés vous aideront à choisir de meilleures stratégies défensives ou offensives ou encore même économiques face aux différentes situations qui vous seront imposées. Plus vous augmenterez le niveau de cette structure plus vos officiers seront rapides et efficaces dans leurs tâches.', - 'Comme toutes choses, vos ressources ont besoin d\'espace pour être stockées ; c\'est pourquoi ces énormes silos vous seront d\'une aide précieuse afin d\'y renfermer une grande quantité de matières premières pour toutes vos productions. Plus le niveau du silo est haut, plus il pourra contenir de ressources supplémentaires.', + 'Le chantier terrestre vous permet de construire tous les véhicules atmosphérique du type warthog ou scorpion. Il permet ainsi à vos troupes d’accéder plus rapidement à un endroit et d’avoir un avantage avec l’armement de ces véhicules.', + 'Le chantier spatial permet de construire vôtre flotte de vaisseaux spatiaux. Généralement à la limite de l’atmosphère d’une planète il ne peut cependant se déplacer et doit impérativement rester en orbite. Le chantier spatial, bien que ressemblant à une station spatial, ne peut être détruit grâce à sa position qui lui confère un camouflage total.', + 'L\'académie militaire forme les meilleurs officiers et sous-officiers de la galaxie. Ces hommes expérimentés vous aideront à choisir de meilleures stratégies défensives ou offensives ou encore même économiques face aux différentes situations qui vous seront imposées. Plus vous augmenterez le niveau de cette structure plus vos officiers seront rapides et efficaces dans leurs tâches.', + 'Comme toutes choses, vos ressources ont besoin d\'espace pour être stockées ; c\'est pourquoi ces énormes silos vous seront d\'une aide précieuse afin d\'y renfermer une grande quantité de matières premières pour toutes vos productions. Plus le niveau du silo est haut, plus il pourra contenir de ressources supplémentaires.', 'La centrale informatique est le coeur de votre planète, le cerveau de votre territoire, analysant chaque particule détectée avec grand soin. Plus votre centrale est améliorée, plus rapidement et aisément les données seront traitées.'); $batimend = array('mine_m','mine_c','!!','centrale_s','centrale_f','radar','recherches','chantier_terrestre','???','ecole_militaire','silo','centre_info'); - $batimeni = array('mine_m.png','mine_c.png','synchroniseur.jpg','centrale solaire.jpg','centrale electrique.jpg','baseradardl3.jpg','recherches.jpg','chantierterrestrecopybj8.jpg','chantier spatial.jpg','ecole militaire.jpg','stockage.jpg','search0yp.jpg'); + $batimeni = array('mine_m.jpg','mine_c.png','synchroniseur.jpg','centrale solaire.jpg','centrale electrique.jpg','baseradardl3.jpg','recherches.jpg','chantierterrestrecopybj8.jpg','chantier spatial.jpg','ecole militaire.jpg','stockage.jpg','search0yp.jpg'); $technolo = array('IA','Radar','Armement','Blindage','Maitrise de l\'énergie','Réacteur à combustion','Réacteur à fusion','Réacteur à fusion de type II','Médecine','Tactiques de combats','Spartan'); $technode = array( 'Le résultat absolu de l\'informatique. L\'IA ou Intelligence Artificielle est le résultat d\'années de travail acharné pour pouvoir en arriver à cette grande performance technique. Les IA sont des entités non biologiques dotées du pouvoir de la pensée. Développer cette technologie vous permettra non seulement de disposer d\'Intelligences Artificielles, mais de les rendre de plus en plus complexes, créatives et réactives.', 'Ce système très ancien et usé par bien des militaires est utilisé pour la détection et l\'imagerie d\'objets faisant appel à des impulsions d\'ondes électromagnétiques à haute fréquence et sert à déterminer la position et la distance des vaisseaux. Pour chaque niveau, vous augmenterez la puissance de cette technologie et sa précision.', 'Un soldat n\'est rien sans son arme, et qu\'est-ce qu\'un soldat démuni face aux assauts féroces adverses ? Cette technologie vous permettra de rechercher de nouveaux systèmes d\'armements afin de rendre vos outils de guerre plus précis et mortels.', - 'La résistance de la coque de vos vaisseaux est plus que primordiale si vous tenez à remporter vos batailles, et encore plus avec les armes Covenantes capables de réduire en miettes même les plus résistants des vaisseaux spatiaux. C\'est la raison pour laquelle vos scientifiques, si vous leur en donnez l\'ordre, travailleront avec application à l\'élaboration de nouvelles formules pour créer des alliages métalliques les plus résistants.', - 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations tout simplement. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et les propulseurs de vos vaisseaux.', - 'Le plus simple de tout les réacteurs, aussi vieux que le monde lui-même ! Equipés sur presque tout vos vaisseaux de base, cette technologie, certes basique, vous aidera à explorer l\'univers mais aussi, se trouvant être bien évidemment la base de la propulsion, vous permettra de découvrir de nouvelles techniques de propulsion irrémédiablement toujours plus puissantes et efficaces.', - 'Bien plus efficaces que de simples réacteurs à combustion, la fusion nucléaire est un processus où deux noyaux atomiques s\'assemblent pour former un noyau plus lourd. La fusion de noyaux légers dégage d\'énormes quantités d\'énergie provenant de l\'attraction entre les nucléons due à une forte interaction. Personne ne pourrait se passer de ce type d\'énergie lors de ses voyages dans le cosmos.', + 'La résistance de la coque de vos vaisseaux est plus que primordiale si vous tenez à remporter vos batailles, et encore plus avec les armes Covenantes capables de réduire en miettes même les plus résistants des vaisseaux spatiaux. C\'est la raison pour laquelle vos scientifiques, si vous leur en donnez l\'ordre, travailleront avec application à l\'élaboration de nouvelles formules pour créer des alliages métalliques les plus résistants.', + 'L\'énergie est la base de tout. Sans énergie, pas de voyages stellaires ni même de quoi faire marcher vos installations tout simplement. C\'est pourquoi l\'étude de nouvelles façons de produire de l\'énergie est vitale pour vos planètes et les propulseurs de vos vaisseaux.', + 'Le plus simple de tout les réacteurs, aussi vieux que le monde lui-même ! Equipés sur presque tout vos vaisseaux de base, cette technologie, certes basique, vous aidera à explorer l\'univers mais aussi, se trouvant être bien évidemment la base de la propulsion, vous permettra de découvrir de nouvelles techniques de propulsion irrémédiablement toujours plus puissantes et efficaces.', + 'Bien plus efficaces que de simples réacteurs à combustion, la fusion nucléaire est un processus où deux noyaux atomiques s\'assemblent pour former un noyau plus lourd. La fusion de noyaux légers dégage d\'énormes quantités d\'énergie provenant de l\'attraction entre les nucléons due à une forte interaction. Personne ne pourrait se passer de ce type d\'énergie lors de ses voyages dans le cosmos.', 'Cette technologie basée sur les réacteurs Covenants utilise la force électromagnétique résultant de l\'interaction entre un courant électrique et un champ magnétique pour accélérer un gaz ionisé appelé plasma. Bien plus efficace que tous les moyens de propulsions possibles, cette technologie révolutionnaire, très coûteuse, est un moyen efficace de parcourir de grandes distances en peu de temps.', - 'Depuis l\'aube des temps, chaque être vivant et pensant n\'a jamais cessé de chercher de nouvelles solutions en dévellopant les sciences médicales pour tenter d\'échapper à la mort et aux épidémies qui s\'abbatent sur lui. Seulement, aujourd\'hui, ce ne sont plus les maladies qui importent, mais plutot les blessures de guerre. Plus votre médecine sera éclatante, plus vos hommes de soins connaîtront de choses pour soigner vos blessés.', + 'Depuis l\'aube des temps, chaque être vivant et pensant n\'a jamais cessé de chercher de nouvelles solutions en dévellopant les sciences médicales pour tenter d\'échapper à la mort et aux épidémies qui s\'abbatent sur lui. Seulement, aujourd\'hui, ce ne sont plus les maladies qui importent, mais plutot les blessures de guerre. Plus votre médecine sera éclatante, plus vos hommes de soins connaîtront de choses pour soigner vos blessés.', 'En tant que général, vous devez avoir un esprit fin pour gagner vos batailles terrestres aussi bien que les affrontements spatiaux. C\'est pourquoi il vous faudra toujours innover en matière de stratégie, vous montrer toujours plus rusé que votre impitoyable adversaire, aussi feriez-vous bien d\'étudier de nouvelles tactiques de combat pour vous assurer une franche victoire.', - 'Ces formidables combattants constituent l\'élite de vos forces terrestres. Entraînés au maniement des armes, aux tactiques militaires et au combat de groupe depuis la naissance, ils sont pratiquement invincibles sur les champs de bataille face aux troupes covenantes. Les Spartans ont également subis plusieurs séries de modifications biologiques afin d\'améliorer leurs capacités physiques.'); - $technoli = array('IA4.jpg','radar7zr.jpg','techarmes1jk1.jpg','blindage.jpg','plasma4yl.jpg','reacteuracombustion.jpg','reacteurfusiontype1al5.jpg','reacteurfusiontype2nn6.jpg','medecin1.jpg','tactique.jpg','armuremc8ij.jpg'); - $nomvaisn = array('Cargos de classe Parabola','Cargos de classe Laden','Vaisseaux de colonisation de classe Odyssey','Drones d’espionnage de classe Clarion','Recycleurs de classe Minotaur','C709 Longsword Interceptor','Frégate','Croiseurs de classe Halcyon','Croiseurs de classe Marathon','Porte vaisseaux','Station orbitale','Super porte-vaisseaux'); - $nomvaisd = array( 'Ces cargos de taille conséquente peuvent transporter assez de ressources et de nourriture pour nourrir une petite ville. Ils sont rapides, très manœuvrables mais peu résistants, ce qui est en fait des proies faciles pour les chasseurs ennemis.', - 'Ces cargos de taille massive permettent le transport d’une énorme quantité de ressources. Ils sont plus résistants que leurs homologues de classe Parabola, mais sont néanmoins les cibles prioritaires des chasseurs ennemis visant à faire le plus de pertes dans le camp adverse.', - 'Les vaisseaux de colonisation sont de vraies minis villes volantes ; ils contiennent la majeure partie des corps d’états de votre planète mère afin d’être le plus autonome lorsque que vous colonisez de nouvelles planètes.', - 'Drones extrêmement rapides et manœuvrables permettant la surveillance et l’espionnage des planètes alentours avec un risque moins élevé de repérage qu’avec un vaisseau furtif standard. Ils sont utilisés lors de l’espionnage de planètes ennemies et sont très fragiles, si bien que lorsqu’ils traversent un champ de débris, ils sont réduits en de vulgaires morceaux de métal.', + 'Ces formidables combattants constituent l\'élite de vos forces terrestres. Entraînés au maniement des armes, aux tactiques militaires et au combat de groupe depuis la naissance, ils sont pratiquement invincibles sur les champs de bataille face aux troupes covenantes. Les Spartans ont également subis plusieurs séries de modifications biologiques afin d\'améliorer leurs capacités physiques.'); + $technoli = array('IA4.jpg','radar7zr.jpg','arme.png','blindage.jpg','plasma4yl.jpg','reacteuracombustion.jpg','reacteurfusiontype1al5.jpg','reacteurfusiontype2nn6.jpg','medecin1.jpg','tactique.jpg','armuremc8ij.jpg'); + $nomvaisn = array('Cargos de classe Parabola','Cargos de classe Laden','Vaisseaux de colonisation de classe Odyssey','Drones d’espionnage de classe Clarion','Recycleurs de classe Minotaur','C709 Longsword Interceptor','Frégate','Croiseurs de classe Halcyon','Croiseurs de classe Marathon','Porte vaisseaux','Station orbitale','Super porte-vaisseaux'); + $nomvaisd = array( 'Ces cargos de taille conséquente peuvent transporter assez de ressources et de nourriture pour nourrir une petite ville. Ils sont rapides, très manÅ“uvrables mais peu résistants, ce qui est en fait des proies faciles pour les chasseurs ennemis.', + 'Ces cargos de taille massive permettent le transport d’une énorme quantité de ressources. Ils sont plus résistants que leurs homologues de classe Parabola, mais sont néanmoins les cibles prioritaires des chasseurs ennemis visant à faire le plus de pertes dans le camp adverse.', + 'Les vaisseaux de colonisation sont de vraies minis villes volantes ; ils contiennent la majeure partie des corps d’états de votre planète mère afin d’être le plus autonome lorsque que vous colonisez de nouvelles planètes.', + 'Drones extrêmement rapides et manÅ“uvrables permettant la surveillance et l’espionnage des planètes alentours avec un risque moins élevé de repérage qu’avec un vaisseau furtif standard. Ils sont utilisés lors de l’espionnage de planètes ennemies et sont très fragiles, si bien que lorsqu’ils traversent un champ de débris, ils sont réduits en de vulgaires morceaux de métal.', 'Les guerres sont de plus en plus nombreuses et les pertes de plus en plus grandes laissant à chaque fois des champs de débris immenses limitant les routes des voies commerciales. Des recycleurs ont donc été créés afin de déblayer ces zones et de vous faire profiter de ces ressources gratuites. Lors du voyage de retour, le recycleur transforme les débris pour vous les redonner sous forme de ressources primaires.', 'Vaisseau orbital et atmosphérique lourd, apte au combat spatial, atmosphérique, et au bombardement lourd sur des positions stratégiques. Ces vaisseaux sont capable de bombarder une vaste position adverse, grâce à leurs bombes au Napalm, mais sont aussi capables de cibler précisément leurs cibles et de les détruire grâce à leurs nombreux missiles air-air air-sol.', - 'Cette classe de vaisseau est la plus répandue dans le CSNU. Ces vaisseaux sont très manœuvrables du fait de leur petite taille, mais sont aussi très faibles, à cause de leur blindage et de leur armement moindre. Ces vaisseaux sont peu coûteux mais également peu efficaces et sont surtout utilisés pour des patrouilles. Ils forment les éléments principaux des différentes flottes du CSNU. ', - 'Ces croiseurs sont des vaisseaux d’attaque, dépassés technologiquement, très peu répandus, très coûteux mais résistants : leur architecture interne leur permet de résister à de nombreux tirs de plasma. Cette architecture complexe à produire et à maintenir en état, en font des vaisseaux extrêmement rares et chers. Ils ont été très récemment remis à neuf et améliorés, avec un tout nouvel armement.', - 'Ces grands vaisseaux (2 fois et demie la longueur d’une frégate), sont des descendants de la lignée des croiseurs Halcyon. Ces vaisseaux ont une très grande puissance de feu (1 CAM lourd), un fort blindage (5 mètres 50 de Titane-A), et sont très rapides. Ils sont assez peu communs, mais restent des vaisseaux d’attaque très redoutables : ils peuvent encaisser de nombreux tirs de plasma avant de succomber.', - 'Ces immenses vaisseaux sont capables de transporter bon nombre de Longswords, d’Albatross, et tout autres types d’unités. Ces vaisseaux leurs permettent de se défendre contre une éventuelle attaque de chasseurs ennemis, mais sont également très lourdement armés. Ils sont usités lors d’attaques massives de planètes nécessitant un fort appui aérien et une très grosse puissance de feu. ', - 'Les station orbitales humaines sont basées sur un même modèle : de multiples DCA légères et lourdes pour les chasseurs, des missiles ARCHERS et un CAM standard capable de pénétrer la plupart des boucliers stellaires. Cette base orbitale est très bien équipée et est considérée comme la défense principale des planètes du CSNU.', - 'Ces vaisseaux sont sont beaucoup plus chers du fait de leur meilleur armement, blindage et importante capacité de transport. Ces vaisseaux sont très peu vus sur le terrain, leur rôle principal est de déployer des Longswords afin de fournir aux vaisseaux alliés un appui orbital. Ils font partis des plus puissants vaisseaux du CSNU. Ils sont capables de transporter bon nombre d’unités terrestres et aériennes.'); + 'Cette classe de vaisseau est la plus répandue dans le CSNU. Ces vaisseaux sont très manÅ“uvrables du fait de leur petite taille, mais sont aussi très faibles, à cause de leur blindage et de leur armement moindre. Ces vaisseaux sont peu coûteux mais également peu efficaces et sont surtout utilisés pour des patrouilles. Ils forment les éléments principaux des différentes flottes du CSNU. ', + 'Ces croiseurs sont des vaisseaux d’attaque, dépassés technologiquement, très peu répandus, très coûteux mais résistants : leur architecture interne leur permet de résister à de nombreux tirs de plasma. Cette architecture complexe à produire et à maintenir en état, en font des vaisseaux extrêmement rares et chers. Ils ont été très récemment remis à neuf et améliorés, avec un tout nouvel armement.', + 'Ces grands vaisseaux (2 fois et demie la longueur d’une frégate), sont des descendants de la lignée des croiseurs Halcyon. Ces vaisseaux ont une très grande puissance de feu (1 CAM lourd), un fort blindage (5 mètres 50 de Titane-A), et sont très rapides. Ils sont assez peu communs, mais restent des vaisseaux d’attaque très redoutables : ils peuvent encaisser de nombreux tirs de plasma avant de succomber.', + 'Ces immenses vaisseaux sont capables de transporter bon nombre de Longswords, d’Albatross, et tout autres types d’unités. Ces vaisseaux leurs permettent de se défendre contre une éventuelle attaque de chasseurs ennemis, mais sont également très lourdement armés. Ils sont usités lors d’attaques massives de planètes nécessitant un fort appui aérien et une très grosse puissance de feu. ', + 'Les station orbitales humaines sont basées sur un même modèle : de multiples DCA légères et lourdes pour les chasseurs, des missiles ARCHERS et un CAM standard capable de pénétrer la plupart des boucliers stellaires. Cette base orbitale est très bien équipée et est considérée comme la défense principale des planètes du CSNU.', + 'Ces vaisseaux sont sont beaucoup plus chers du fait de leur meilleur armement, blindage et importante capacité de transport. Ces vaisseaux sont très peu vus sur le terrain, leur rôle principal est de déployer des Longswords afin de fournir aux vaisseaux alliés un appui orbital. Ils font partis des plus puissants vaisseaux du CSNU. Ils sont capables de transporter bon nombre d’unités terrestres et aériennes.'); $nomvaisa = array('cargos de classe Parabola','cargos de classe Laden','vaisseau(x) de colonisation de classe Odyssey','drone(s) d\'espionnage de classe Clarion','recycleur(s) de classe Minotaur','C709 Longsword Interceptor','Frégates','croiseur(s) de classe Halcyon','croiseur(s) de classe Marathon','porte vaisseaux','station(s) orbitale','super(s) porte-vaisseaux'); - $nomvaisi = array('csnucargoparabola2mc9.jpg','csnucargoladen2al8.jpg','vaisseaucolonisationmm4.jpg','drone_clarion.jpg','img_na_ig.jpg','longsword.jpg','fregatewz5.jpg','croiseurclassealcyon130om6.jpg','croiseurmarathonke3.jpg','csnuportevaisseauxgy3.jpg','station.jpg','.jpg'); + $nomvaisi = array('csnucargoparabola2mc9.jpg','csnucargoladen2al8.jpg','colonisation.jpg','drone_clarion.jpg','img_na_ig.jpg','longsword.jpg','fregatewz5.jpg','croiseurclassealcyon130om6.jpg','croiseurmarathonke3.jpg','csnuportevaisseauxgy3.jpg','station.jpg','csnusuperportevaisseauxrw4.jpg'); $nomterra = array('sparrowhawk','077-TC Pelican','C703 Shortsword Bomber','SHD Albatros','M12 LRV Warthogs','M12G1 LAAV Warthogs','M12A1 LAAV Warthogs','M808B Scorpions MBT','mitrailleuse(s) automatique M247 GP','DCA légère(s)','DCA lourde(s)','canon(s) Gauss','lanceur(s) de missiles'); $nomterrn = array('Sparrowhawk','077-TC Pelican','C703 Shortsword Bomber','SHD Albatros','M12 LRV Warthogs','M12G1 LAAV Warthogs','M12A1 LAAV Warthogs','M808B Scorpions MBT','Mitrailleuse automatique M247 GP','DCA légère','DCA lourde','Canon Gauss','Lanceur de missiles'); - $nomterde = array( 'Véhicule à propulsion verticale permettant des attaques extrêmement rapides et destructrices grâce à ses six tubes lance-missiles, ses deux mitrailleuses légères, et sa mitrailleuse lourde frontale. Ces vaisseaux d’assaut rapide sont de véritables broyeurs de tôle grâce à leurs 6 tubes lance-missiles et sont capables de détruire des véhicules et des positions fortement blindées.', - 'Véhicule aérien de transport léger permettant le transport rapide de troupes à des endroits stratégiques tel un warthog ou un scorpion. Ils sont la base des renforts terrestres et permettent l’acheminement de troupes et de munitions rapidement.', - 'Vaisseau suborbital très rapide apte tant au combat aérien rapproché qu’au bombardement ciblé. Ces bombardiers ont un pointeur laser qui leur permet de viser au mieux les cibles ennemies, qu\'elles soient au sol ou aériennes. Ils sont néanmoins capables de combattre en combat aérien rapproché grâce à leurs missiles thermo guidés et sont utilisés lors de bombardements de cibles mineures.', - 'Véhicule aérien de transport lourd permettant le transport en masse de troupes ou de véhicules tels que des warthogs ou bien une paire de scorpions vers des zones de largage. Ces véhicules de soutien aérien lourd sont surtout utilisés lors d’offensives nécessitant un déploiement en masse d’unités blindées et de munitions au plus près des lignes adverses.', - 'Véhicule d’attaque léger permettant des assauts rapides et efficaces, ainsi que le transport léger de troupes. Ces véhicules sont la base des véhicules terrestres du CSNU.', - 'Véhicule léger équipé d’un canon à accélération magnétique (CAM), très efficace contre du personnel, des véhicules moyennement blindés, ou bien contre des véhicules aériens légers. Les Warthog M12G1 sont très répandus et surtout utilisés lors d\'offensives sur des cibles disposant d’un appui aérien ou terrestre léger.', - 'Véhicule léger, armé d’un lance-missiles anti-véhicule permettant des assauts rapides contre des véhicules blindés ou contre des positions fortifiées. Ils sont surtout utilisés en cas d’attaques de postes avancés.', - 'Tank blindé anti-véhicules. Permet l’attaque de cibles fortifiées grâce à ses balles perforantes de gros calibre. Ces tanks sont utilisés lors d’assauts massifs sur des bases fortifiées et vitales à l’ennemi.', + $nomterde = array( 'Véhicule à propulsion verticale permettant des attaques extrêmement rapides et destructrices grâce à ses six tubes lance-missiles, ses deux mitrailleuses légères, et sa mitrailleuse lourde frontale. Ces vaisseaux d’assaut rapide sont de véritables broyeurs de tôle grâce à leurs 6 tubes lance-missiles et sont capables de détruire des véhicules et des positions fortement blindées.', + 'Véhicule aérien de transport léger permettant le transport rapide de troupes à des endroits stratégiques tel un warthog ou un scorpion. Ils sont la base des renforts terrestres et permettent l’acheminement de troupes et de munitions rapidement.', + 'Vaisseau suborbital très rapide apte tant au combat aérien rapproché qu’au bombardement ciblé. Ces bombardiers ont un pointeur laser qui leur permet de viser au mieux les cibles ennemies, qu\'elles soient au sol ou aériennes. Ils sont néanmoins capables de combattre en combat aérien rapproché grâce à leurs missiles thermo guidés et sont utilisés lors de bombardements de cibles mineures.', + 'Véhicule aérien de transport lourd permettant le transport en masse de troupes ou de véhicules tels que des warthogs ou bien une paire de scorpions vers des zones de largage. Ces véhicules de soutien aérien lourd sont surtout utilisés lors d’offensives nécessitant un déploiement en masse d’unités blindées et de munitions au plus près des lignes adverses.', + 'Véhicule d’attaque léger permettant des assauts rapides et efficaces, ainsi que le transport léger de troupes. Ces véhicules sont la base des véhicules terrestres du CSNU.', + 'Véhicule léger équipé d’un canon à accélération magnétique (CAM), très efficace contre du personnel, des véhicules moyennement blindés, ou bien contre des véhicules aériens légers. Les Warthog M12G1 sont très répandus et surtout utilisés lors d\'offensives sur des cibles disposant d’un appui aérien ou terrestre léger.', + 'Véhicule léger, armé d’un lance-missiles anti-véhicule permettant des assauts rapides contre des véhicules blindés ou contre des positions fortifiées. Ils sont surtout utilisés en cas d’attaques de postes avancés.', + 'Tank blindé anti-véhicules. Permet l’attaque de cibles fortifiées grâce à ses balles perforantes de gros calibre. Ces tanks sont utilisés lors d’assauts massifs sur des bases fortifiées et vitales à l’ennemi.', 'La mitrailleuse M247 est une arme de calibre moyen envoyant des balles de calibre 30 à une cadence de tir de 6 balles par seconde. Généralement positionnée dans des endroits fixes, cette tourelle, efficace contre l\'infanterie et les véhicules légers de petite taille est de précision moyenne suffisante pour éliminer une menace de quelques soldats covenants.', - 'Les DCA légères sont des canons anti-aérien de puissance moyenne mais de cadence de tir et de calibre de munitions à tête explosive élevée permettant de détruire la plupart des chasseurs légers avec aisance. Ce modèle est équipé d\'un emplacement spécial lui permettant de tirer également sur des cibles au sol.', - 'Les DCA lourdes sont quasi-similaires aux légères mais possèdent tout de même une différence au niveau du calibre des balles qui, plus élevé avec une tête explosif supérieure est comparable à une explosion de mine lotus. Il a en contre partie une capacité de tir plus limitée question cadence et une quantité de munitions moindre dans chaque chargeur.', + 'Les DCA légères sont des canons anti-aérien de puissance moyenne mais de cadence de tir et de calibre de munitions à tête explosive élevée permettant de détruire la plupart des chasseurs légers avec aisance. Ce modèle est équipé d\'un emplacement spécial lui permettant de tirer également sur des cibles au sol.', + 'Les DCA lourdes sont quasi-similaires aux légères mais possèdent tout de même une différence au niveau du calibre des balles qui, plus élevé avec une tête explosif supérieure est comparable à une explosion de mine lotus. Il a en contre partie une capacité de tir plus limitée question cadence et une quantité de munitions moindre dans chaque chargeur.', 'Le canon gauss est l\'équivalent du Super CAM mais en version miniature tirant des projectiles à haute densité et à grande vitesse sur ses cibles. Il est capable, en outre, de détruire des véhicules à blindage lourd tel des wraith\'s covenants, véritables chars d\'assaut à longue portée. Malheureusement, il est moins efficace contre l\'infanterie dû à sa cadence de tir plutôt faible et sa précision moindre.', - 'Les lance-missiles du CSNU sont équipés de missiles balistiques hautement explosifs capables de réduire aisément en miettes les chars covenants ou les chasseurs Séraphins. Ce lance-missiles, une fois ses salves tirées, nécessite plusieures minutes de réarmement pour être de nouveau opérationnel.'); + 'Les lance-missiles du CSNU sont équipés de missiles balistiques hautement explosifs capables de réduire aisément en miettes les chars covenants ou les chasseurs Séraphins. Ce lance-missiles, une fois ses salves tirées, nécessite plusieures minutes de réarmement pour être de nouveau opérationnel.'); $nomterri = array('csnusparrowhawkkp4.jpg','pelican.jpg','csnushortswordad3.jpg','albatross.jpg','warthog-vrl.jpg','M12G1_LAAV_Warthog.jpg','M12A1_LAAV_Warthog.jpg','scorpionN.jpg','tourelle_fixe.jpg','dca_legere.jpg','dca_lourde.jpg','tourelle_gauss.jpg','csnulancemissileol5.jpg'); } ?> \ No newline at end of file diff --git a/includes/onyx/access.php b/includes/onyx/access.php new file mode 100644 index 0000000..f0225a3 --- /dev/null +++ b/includes/onyx/access.php @@ -0,0 +1,12 @@ + diff --git a/includes/onyx/ban.xlist b/includes/onyx/ban.xlist new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/includes/onyx/ban.xlist @@ -0,0 +1 @@ + diff --git a/includes/onyx/bdd.class.php b/includes/onyx/bdd.class.php new file mode 100644 index 0000000..da851c4 --- /dev/null +++ b/includes/onyx/bdd.class.php @@ -0,0 +1,292 @@ +session) + { + $this->deconnexion(); + } + + global $var___mysql, $config; + + $u = empty($u)?$var___mysql['login']:$u; + + $p = empty($p)?$var___mysql['password']:$p; + + $h = empty($h)?$config['db_host']:$h; + + @$this->session = mysql_connect($h,$u,$p) or require('secours.php'); + + if (!$this->session) + { + die('Connexion a la base de donnée impossible.'); + } + + mysql_query('SET CHARACTER SET "utf8"',$this->session); + + if(!empty($db)) + { + $var = mysql_select_db($db,$this->session); + if($var) $this->database = $db; + } + } + + function deconnexion() + { + if($this->session) + { + @$var = mysql_close($this->session); + $this->session = FALSE; + return $var; + } + else return FALSE; + } + + function erreur($flag=TRUE) + { + if($this->session) + { + $var = mysql_error($this->session); + if($flag) echo $var; + return $var; + } + else return FALSE; + } + function db($db=NULL) + { + if($this->session) + { + global $config; + $db = empty($db)?$config['db_name']:$db; + + $var = mysql_select_db($db,$this->session); + if($var) $this->database = $db; + return $var; + } + else return FALSE; + } + + function escape(&$var) + { + if($this->session) + { + $var = mysql_real_escape_string($var,$this->session); + return $var; + } + else return FALSE; + } + + function query($q) + { + if($this->session) + { + $this->reponse = mysql_query($q,$this->session); + + if(!$this->reponse) + { + echo("Requete à la base de donnée invalide".mysql_error()); + return FALSE; + } + + $this->num_rows = @mysql_num_rows($this->reponse); + + if($this->num_rows == 0) + { + return NULL; + } + + elseif($this->num_rows >= 1) + { + for($i=0; $var = mysql_fetch_assoc($this->reponse); $i++) + { + $sortie[$i] = $var; + } + return $sortie; + } + + else return FALSE; + } + else return FALSE; + } + + function unique_query($q) + { + if($this->session) + { + $this->reponse = mysql_query($q,$this->session); + + if(!$this->reponse) + { + echo("Requete à la base de donnée invalide"); + return FALSE; + } + + $this->num_rows = @mysql_num_rows($this->reponse); + + if($this->num_rows == 0 || $this->num_rows > 1) + { + return NULL; + } + + elseif($this->num_rows == 1) + { + return mysql_fetch_assoc($this->reponse); + } + + else return FALSE; + } + else return FALSE; + } + + function affected() + { + if($this->session) + { + $affected = mysql_affected_rows($this->session); + if($affected == 0) + { + return NULL; + } + elseif($affected >= 1) + { + return $affected; + } + else return FALSE; + } + else return FALSE; + } + + function check($table,$cond) + { + if($this->session && !empty($this->database)) + { + $hashcheck = $this->unique_query("SELECT hash FROM $table WHERE $cond"); + + if($this->num_rows != 1) return FALSE; + + $hashcheck = $hashcheck['hash']; + + $columns = $this->query("SHOW COLUMNS FROM $table"); + + $i = 0; + $j = 0; + + foreach($columns as $key => $value) + { + if($value['Field'] == 'hash' || $value['Field'] == 'active') + { + $i++; + } + else + { + $array[$j] = $value['Field']; + $j++; + } + } + if($i != 2) return FALSE; + + $array = implode(",", $array); + + $var = $this->unique_query("SELECT $array FROM $table WHERE $cond"); + + if($this->num_rows == 1) + { + + $var = implode('',$var); + + $hash = hash_var($var); + + if($hashcheck === $hash) + { + return TRUE; + } + else; + { + $this->query("UPDATE $table SET active='0' WHERE $cond"); + return FALSE; + } + } + else return FALSE; + } + else return FALSE; + } + + function hash($table,$cond) + { + if($this->session && !empty($this->database)) + { + $columns = $this->query("SHOW COLUMNS FROM $table"); + + $i = 0; + $j = 0; + + foreach($columns as $key => $value) + { + if($value['Field'] == 'hash' || $value['Field'] == 'active') + { + $i++; + } + else + { + $array[$j] = $value['Field']; + $j++; + } + } + if($i != 2) return FALSE; + + $array = implode(",", $array); + + $var = $this->unique_query("SELECT $array FROM $table WHERE $cond"); + + if($this->num_rows == 1) + { + + $var = implode('',$var); + + $hash = hash_var($var); + + $r = $this->query("UPDATE $table SET active='1', hash='$hash' WHERE $cond"); + + return $this->affected(); + } + else return FALSE; + } + else return FALSE; + } + function control($table) + { + if($this->session && !empty($this->database)) + { + $xid = $this->query("SELECT xid FROM $table"); + if($this->num_rows != 0) + { + foreach($xid as $key => $value) + { + $vxid = $value['xid']; + $var = $this->check($table,"xid = '$vxid'"); + if(!$var) return FALSE; + } + return TRUE; + } + else return FALSE; + } + else return FALSE; + } + } +?> \ No newline at end of file diff --git a/includes/onyx/config.xconf b/includes/onyx/config.xconf new file mode 100644 index 0000000..e6218ac --- /dev/null +++ b/includes/onyx/config.xconf @@ -0,0 +1,75 @@ +actif: "1" +titre: "Halo-Battle" +bddactif: "1" +domaine: "localhost" +url_rewriting : "0" +url_masque[localhost_hbn] : "#^((m([1-9]|1[0-2])|csnu|covenants)?(-\d{1,4})?|\d{1,4})?$#" +url_replace[localhost_hbn] : "blog.php?e=$1" +chemin: "/var/www/virtual/halo-battle.s-fr.com/htdocs/" +session: "1" +session_time: "3600" +session_name: "hbservj1" +fuseau_horaire: "2" +locales: "fr_FR" +lang: "FRA" +db_host: "localhost" +db_name: "halo_battle" +db_prefix: "" +smiley_dir: "images/smiles/" +smiley[wink]: ":wink:" +smiley[biggrin]: ":D" +smiley[smile]: ":-)" +smiley[razz]: ":P" +smiley[eek]: ":shock:" +smiley[cool]: "8-)" +smiley[twisted]: ":twisted:" +smiley[evil]: ":evil:" +smiley[mad]: ":-x" +smiley[confused]: ":-?" +smiley[sad]: ":-(" +smiley[surprised]: ":-O" +smiley[neutral]: ":-|" +smiley[redface]: ":oops:" +smiley[rolleyes]: ":roll:" +smiley[lol]: ":lol:" +link[forum]: "/forum/index.php" +link[jeu]: "http://battle.halo.fr" +link[blog]: "ark/" +link[accueil]: "/accueil.html" +link[contact]: "/contact.html" +link[self]: "./" +link[inscription]: "?p=inscription" +menu[accueil]: "?p=accueil" +menu[batiments]: "?p=batiments" +menu[caserne]: "?p=prochainement" +menu[chantierspatial]: "?p=chantierspatial" +menu[chantierterrestre]: "?p=prochainement" +menu[defenses]: "?p=defenses" +menu[laboratoire]: "?p=laboratoire" +menu[arbre]: "?p=arbre" +menu[ressources]: "?p=ressources" +menu[gestion]: "?p=prochainement" +menu[flotte]: "?p=flotte" +menu[armee]: "?p=prochainement" +menu[carte]: "?p=carte" +menu[options]: "?p=options" +menu[messages]: "?p=messagerie" +menu[envoie]: "?p=envoyer" +menu[alliance]: "?p=alliances" +menu[classement]: "?p=classement" +menu[forums]: "http://halo-battle.s-fr.com/forum/" +menu[bugs]: "?p=bugs" +menu[faq]: "?p=prochainement" +menu[deconnexion]: "?p=deconnexion" +menuadmin[accueil]: "?p=accueil" +menuadmin[vip]: "?p=vip" +menuadmin[vflottes]: "?p=vflotte" +menuadmin[vplanetes]: "?p=vplanetes" +menuadmin[vjoueurs]: "?p=vjoueurs" +menuadmin[valliances]: "?p=valliances" +menuadmin[laboratoire]: "?p=laboratoire" +menuadmin[arbre]: "?p=arbre" +menuadmin[ressources]: "?p=ressources" +menuadmin[gestion]: "?p=prochainement" +menuadmin[flotte]: "?p=flotte" +menuadmin[deconnexion]: "?p=deconnexion" diff --git a/includes/onyx/kernel.php b/includes/onyx/kernel.php new file mode 100644 index 0000000..e52b4f0 --- /dev/null +++ b/includes/onyx/kernel.php @@ -0,0 +1,252 @@ +$2'; + + $pattern[] = '#\\[color=(aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|purple|red|silver|teal|white|yellow)\\](.+?)\\[/color\\]#u'; + $replace[] = '$2'; + + $pattern[] = '#\\[img\\]http://([a-zA-Z0-9_/.%*+~,\\#-]+)\\[/img\\]#u'; + $replace[] = '$1'; + + default: + case 0: + $pattern[] = '#\\[url=(?:http://)?([a-zA-Z0-9_/.%*+~,\\#-]+)\\](.+?)\\[/url\\]#u'; + $replace[] = '$2'; + + $pattern[] = '#\\[url\\](?:http://)?([a-zA-Z0-9_/.%*+~,\\#-]+)\\[/url\\]#u'; + $replace[] = '$1'; + + $pattern[] = '#\\[cite\\](.+?)\\[/cite\\]#u'; + $replace[] = '$1'; + + $pattern[] = '#\\[u\\](.+?)\\[/u\\]#u'; + $replace[] = '$1'; + + $pattern[] = '#\\[i\\](.+?)\\[/i\\]#u'; + $replace[] = '$1'; + + $pattern[] = '#\\[b\\](.+?)\\[/b\\]#u'; + $replace[] = '$1'; + + foreach($config['smiley'] as $keys => $values) + { + $pattern[] = '#'.preg_quote($values).'#u'; + $replace[] = ''.$keys.''; + } + } + + $pattern = array_reverse($pattern); + $replace = array_reverse($replace); + + $var = preg_replace($pattern,$replace,$var); + return $var; + } + + +define('SMARTY_DIR',_FCORE.'templates/libs/'); + +require_once(_FCORE."access.php"); + +require_once(SMARTY_DIR."Smarty.class.php"); + +require_once(_FCORE."bdd.class.php"); + +require_once(_FCORE."session.class.php"); + +header("Content-Type: text/html;charset=utf-8"); + +?> diff --git a/includes/onyx/logs/16-05-2008.log b/includes/onyx/logs/16-05-2008.log new file mode 100644 index 0000000..d6575ce --- /dev/null +++ b/includes/onyx/logs/16-05-2008.log @@ -0,0 +1 @@ +[00:25:38] MESSAGE : Création de l'alliance : les nouveaux poms par 8 (fondateur : 1) après validation de 4 signatures : 3, 5, 7 , [127.0.0.1] [GET] [/hbn/?p=alliances&q=signer&i=c9b76e336f77b1e724c0809d0fb366ed0084b85c] [Mozilla/5.0 (Windows; U; Windows NT 5.1; fr; rv:1.9b5) Gecko/2008032620 Firefox/3.0b5] [] diff --git a/includes/onyx/logs/16-05-2008.xlog b/includes/onyx/logs/16-05-2008.xlog new file mode 100644 index 0000000..b49480d --- /dev/null +++ b/includes/onyx/logs/16-05-2008.xlog @@ -0,0 +1 @@ +[23:15:22] MESSAGE : Création de l'alliance : les nouveaux poms par 8 (fondateur : 1) après validation de 4 signatures : 3, 2, 48 , [127.0.0.1] [GET] [/hbn/?p=alliances&q=signer&i=c9eb7a4fbfac8062bf83bf530d55024647484aae] [Mozilla/5.0 (Windows; U; Windows NT 5.1; fr; rv:1.9b5) Gecko/2008032620 Firefox/3.0b5] [http://127.0.0.1/hbn/?p=alliances&q=fonder] diff --git a/includes/onyx/logs/php.log b/includes/onyx/logs/php.log new file mode 100644 index 0000000..e69de29 diff --git a/includes/onyx/phpbb_functions.php b/includes/onyx/phpbb_functions.php new file mode 100644 index 0000000..0ae45a2 --- /dev/null +++ b/includes/onyx/phpbb_functions.php @@ -0,0 +1,111 @@ + 30) + { + return $output; + } + + $count = 1 << $count_log2; + $salt = substr($setting, 4, 8); + + if (strlen($salt) != 8) + { + return $output; + } + + /** + * We're kind of forced to use MD5 here since it's the only + * cryptographic primitive available in all versions of PHP + * currently in use. To implement our own low-level crypto + * in PHP would result in much worse performance and + * consequently in lower iteration counts and hashes that are + * quicker to crack (by non-PHP code). + */ + if (PHP_VERSION >= 5) + { + $hash = md5($salt . $password, true); + do + { + $hash = md5($hash . $password, true); + } + while (--$count); + } + else + { + $hash = pack('H*', md5($salt . $password)); + do + { + $hash = pack('H*', md5($hash . $password)); + } + while (--$count); + } + + $output = substr($setting, 0, 12); + $output .= _hash_encode64($hash, 16, $itoa64); + + return $output; + } + function _hash_encode64($input, $count, &$itoa64) + { + $output = ''; + $i = 0; + + do + { + $value = ord($input[$i++]); + $output .= $itoa64[$value & 0x3f]; + + if ($i < $count) + { + $value |= ord($input[$i]) << 8; + } + + $output .= $itoa64[($value >> 6) & 0x3f]; + + if ($i++ >= $count) + { + break; + } + + if ($i < $count) + { + $value |= ord($input[$i]) << 16; + } + + $output .= $itoa64[($value >> 12) & 0x3f]; + + if ($i++ >= $count) + { + break; + } + + $output .= $itoa64[($value >> 18) & 0x3f]; + } + while ($i < $count); + + return $output; + } + +?> \ No newline at end of file diff --git a/includes/onyx/session.class.php b/includes/onyx/session.class.php new file mode 100644 index 0000000..1a26b54 --- /dev/null +++ b/includes/onyx/session.class.php @@ -0,0 +1,122 @@ +connexion(); + $db->db(); + $db->control($config['db_prefix']."sessions"); + + $time = time()-$config['session_time']; + $table = $config['db_prefix']."sessions"; + $db->query("DELETE FROM $table WHERE time < $time AND active = '1'"); + + $db->deconnexion(); + } + } + + function new_cookie() + { + global $config; + + if($config['session']=='1') + { + $db = new bdd(); + $db->connexion(); + $db->db(); + + $time = time(); + $xid = random(); + $sess_cookie = random(); + $ip = encode_ip(); + $table = $config['db_prefix']."sessions"; + $db->query("INSERT INTO $table(xid,session,time,ip,var_session,level,hash,active) VALUES('$xid','$sess_cookie','$time','$ip','','1','','0') "); + $db->hash($table,"xid = '$xid'"); + + $this->xid = $xid; + + cookie($config['session_name'],$sess_cookie); + + $db->deconnexion(); + } + } + + function load() + { + $this->clean(); + + global $config; + + if($config['session']=='1') + { + + if($cookie = gpc($config['session_name'],'cookie')) + { + $db = new bdd(); + $db->connexion(); + $db->db(); + + $db->escape($cookie); + + $table = $config['db_prefix']."sessions"; + $query = $db->unique_query("SELECT * FROM $table WHERE session='$cookie' AND active='1'"); + + if($db->num_rows == 1 && $query['ip'] == encode_ip()) + { + $time = time(); + $xid = $query['xid']; + $db->query("UPDATE $table SET time='$time' WHERE xid='$xid'"); + + $this->xid = $xid; + $this->level = $query['level']; + $this->values = unserialize($query['var_session']); + + cookie($config['session_name'],gpc($config['session_name'],'cookie')); + } + else $this->new_cookie(); + + $db->deconnexion(); + } + else $this->new_cookie(); + } + } + + function put() + { + global $config; + + if($config['session']=='1') + { + $db = new bdd(); + $db->connexion(); + $db->db(); + + $time = time(); + + $var_session = serialize($this->values); + + $db->escape($var_session); + + $xid = $this->xid; + + $table = $config['db_prefix']."sessions"; + $db->query("UPDATE $table SET time='$time', var_session='$var_session' WHERE xid='$xid'"); + $db->hash($table,"xid = '$xid'"); + + $db->deconnexion(); + } + } +} +?> \ No newline at end of file diff --git a/includes/onyx/templates/libs/Config_File.class.php b/includes/onyx/templates/libs/Config_File.class.php new file mode 100644 index 0000000..e3c3ca2 --- /dev/null +++ b/includes/onyx/templates/libs/Config_File.class.php @@ -0,0 +1,389 @@ + + * @access public + * @package Smarty + */ + +/* $Id: Config_File.class.php 2702 2007-03-08 19:11:22Z mohrt $ */ + +/** + * Config file reading class + * @package Smarty + */ +class Config_File { + /**#@+ + * Options + * @var boolean + */ + /** + * Controls whether variables with the same name overwrite each other. + */ + var $overwrite = true; + + /** + * Controls whether config values of on/true/yes and off/false/no get + * converted to boolean values automatically. + */ + var $booleanize = true; + + /** + * Controls whether hidden config sections/vars are read from the file. + */ + var $read_hidden = true; + + /** + * Controls whether or not to fix mac or dos formatted newlines. + * If set to true, \r or \r\n will be changed to \n. + */ + var $fix_newlines = true; + /**#@-*/ + + /** @access private */ + var $_config_path = ""; + var $_config_data = array(); + /**#@-*/ + + /** + * Constructs a new config file class. + * + * @param string $config_path (optional) path to the config files + */ + function Config_File($config_path = NULL) + { + if (isset($config_path)) + $this->set_path($config_path); + } + + + /** + * Set the path where configuration files can be found. + * + * @param string $config_path path to the config files + */ + function set_path($config_path) + { + if (!empty($config_path)) { + if (!is_string($config_path) || !file_exists($config_path) || !is_dir($config_path)) { + $this->_trigger_error_msg("Bad config file path '$config_path'"); + return; + } + if(substr($config_path, -1) != DIRECTORY_SEPARATOR) { + $config_path .= DIRECTORY_SEPARATOR; + } + + $this->_config_path = $config_path; + } + } + + + /** + * Retrieves config info based on the file, section, and variable name. + * + * @param string $file_name config file to get info for + * @param string $section_name (optional) section to get info for + * @param string $var_name (optional) variable to get info for + * @return string|array a value or array of values + */ + function get($file_name, $section_name = NULL, $var_name = NULL) + { + if (empty($file_name)) { + $this->_trigger_error_msg('Empty config file name'); + return; + } else { + $file_name = $this->_config_path . $file_name; + if (!isset($this->_config_data[$file_name])) + $this->load_file($file_name, false); + } + + if (!empty($var_name)) { + if (empty($section_name)) { + return $this->_config_data[$file_name]["vars"][$var_name]; + } else { + if(isset($this->_config_data[$file_name]["sections"][$section_name]["vars"][$var_name])) + return $this->_config_data[$file_name]["sections"][$section_name]["vars"][$var_name]; + else + return array(); + } + } else { + if (empty($section_name)) { + return (array)$this->_config_data[$file_name]["vars"]; + } else { + if(isset($this->_config_data[$file_name]["sections"][$section_name]["vars"])) + return (array)$this->_config_data[$file_name]["sections"][$section_name]["vars"]; + else + return array(); + } + } + } + + + /** + * Retrieves config info based on the key. + * + * @param $file_name string config key (filename/section/var) + * @return string|array same as get() + * @uses get() retrieves information from config file and returns it + */ + function &get_key($config_key) + { + list($file_name, $section_name, $var_name) = explode('/', $config_key, 3); + $result = &$this->get($file_name, $section_name, $var_name); + return $result; + } + + /** + * Get all loaded config file names. + * + * @return array an array of loaded config file names + */ + function get_file_names() + { + return array_keys($this->_config_data); + } + + + /** + * Get all section names from a loaded file. + * + * @param string $file_name config file to get section names from + * @return array an array of section names from the specified file + */ + function get_section_names($file_name) + { + $file_name = $this->_config_path . $file_name; + if (!isset($this->_config_data[$file_name])) { + $this->_trigger_error_msg("Unknown config file '$file_name'"); + return; + } + + return array_keys($this->_config_data[$file_name]["sections"]); + } + + + /** + * Get all global or section variable names. + * + * @param string $file_name config file to get info for + * @param string $section_name (optional) section to get info for + * @return array an array of variables names from the specified file/section + */ + function get_var_names($file_name, $section = NULL) + { + if (empty($file_name)) { + $this->_trigger_error_msg('Empty config file name'); + return; + } else if (!isset($this->_config_data[$file_name])) { + $this->_trigger_error_msg("Unknown config file '$file_name'"); + return; + } + + if (empty($section)) + return array_keys($this->_config_data[$file_name]["vars"]); + else + return array_keys($this->_config_data[$file_name]["sections"][$section]["vars"]); + } + + + /** + * Clear loaded config data for a certain file or all files. + * + * @param string $file_name file to clear config data for + */ + function clear($file_name = NULL) + { + if ($file_name === NULL) + $this->_config_data = array(); + else if (isset($this->_config_data[$file_name])) + $this->_config_data[$file_name] = array(); + } + + + /** + * Load a configuration file manually. + * + * @param string $file_name file name to load + * @param boolean $prepend_path whether current config path should be + * prepended to the filename + */ + function load_file($file_name, $prepend_path = true) + { + if ($prepend_path && $this->_config_path != "") + $config_file = $this->_config_path . $file_name; + else + $config_file = $file_name; + + ini_set('track_errors', true); + $fp = @fopen($config_file, "r"); + if (!is_resource($fp)) { + $this->_trigger_error_msg("Could not open config file '$config_file'"); + return false; + } + + $contents = ($size = filesize($config_file)) ? fread($fp, $size) : ''; + fclose($fp); + + $this->_config_data[$config_file] = $this->parse_contents($contents); + return true; + } + + /** + * Store the contents of a file manually. + * + * @param string $config_file file name of the related contents + * @param string $contents the file-contents to parse + */ + function set_file_contents($config_file, $contents) + { + $this->_config_data[$config_file] = $this->parse_contents($contents); + return true; + } + + /** + * parse the source of a configuration file manually. + * + * @param string $contents the file-contents to parse + */ + function parse_contents($contents) + { + if($this->fix_newlines) { + // fix mac/dos formatted newlines + $contents = preg_replace('!\r\n?!', "\n", $contents); + } + + $config_data = array(); + $config_data['sections'] = array(); + $config_data['vars'] = array(); + + /* reference to fill with data */ + $vars =& $config_data['vars']; + + /* parse file line by line */ + preg_match_all('!^.*\r?\n?!m', $contents, $match); + $lines = $match[0]; + for ($i=0, $count=count($lines); $i<$count; $i++) { + $line = $lines[$i]; + if (empty($line)) continue; + + if ( substr($line, 0, 1) == '[' && preg_match('!^\[(.*?)\]!', $line, $match) ) { + /* section found */ + if (substr($match[1], 0, 1) == '.') { + /* hidden section */ + if ($this->read_hidden) { + $section_name = substr($match[1], 1); + } else { + /* break reference to $vars to ignore hidden section */ + unset($vars); + $vars = array(); + continue; + } + } else { + $section_name = $match[1]; + } + if (!isset($config_data['sections'][$section_name])) + $config_data['sections'][$section_name] = array('vars' => array()); + $vars =& $config_data['sections'][$section_name]['vars']; + continue; + } + + if (preg_match('/^\s*(\.?\w+)\s*=\s*(.*)/s', $line, $match)) { + /* variable found */ + $var_name = rtrim($match[1]); + if (strpos($match[2], '"""') === 0) { + /* handle multiline-value */ + $lines[$i] = substr($match[2], 3); + $var_value = ''; + while ($i<$count) { + if (($pos = strpos($lines[$i], '"""')) === false) { + $var_value .= $lines[$i++]; + } else { + /* end of multiline-value */ + $var_value .= substr($lines[$i], 0, $pos); + break; + } + } + $booleanize = false; + + } else { + /* handle simple value */ + $var_value = preg_replace('/^([\'"])(.*)\1$/', '\2', rtrim($match[2])); + $booleanize = $this->booleanize; + + } + $this->_set_config_var($vars, $var_name, $var_value, $booleanize); + } + /* else unparsable line / means it is a comment / means ignore it */ + } + return $config_data; + } + + /**#@+ @access private */ + /** + * @param array &$container + * @param string $var_name + * @param mixed $var_value + * @param boolean $booleanize determines whether $var_value is converted to + * to true/false + */ + function _set_config_var(&$container, $var_name, $var_value, $booleanize) + { + if (substr($var_name, 0, 1) == '.') { + if (!$this->read_hidden) + return; + else + $var_name = substr($var_name, 1); + } + + if (!preg_match("/^[a-zA-Z_]\w*$/", $var_name)) { + $this->_trigger_error_msg("Bad variable name '$var_name'"); + return; + } + + if ($booleanize) { + if (preg_match("/^(on|true|yes)$/i", $var_value)) + $var_value = true; + else if (preg_match("/^(off|false|no)$/i", $var_value)) + $var_value = false; + } + + if (!isset($container[$var_name]) || $this->overwrite) + $container[$var_name] = $var_value; + else { + settype($container[$var_name], 'array'); + $container[$var_name][] = $var_value; + } + } + + /** + * @uses trigger_error() creates a PHP warning/error + * @param string $error_msg + * @param integer $error_type one of + */ + function _trigger_error_msg($error_msg, $error_type = E_USER_WARNING) + { + trigger_error("Config_File error: $error_msg", $error_type); + } + /**#@-*/ +} + +?> diff --git a/includes/onyx/templates/libs/Smarty.class.php b/includes/onyx/templates/libs/Smarty.class.php new file mode 100644 index 0000000..5eda787 --- /dev/null +++ b/includes/onyx/templates/libs/Smarty.class.php @@ -0,0 +1,1960 @@ + + * @author Andrei Zmievski + * @package Smarty + * @version 2.6.19 + */ + +/* $Id: Smarty.class.php 2722 2007-06-18 14:29:00Z danilo $ */ + +/** + * DIR_SEP isn't used anymore, but third party apps might + */ +if(!defined('DIR_SEP')) { + define('DIR_SEP', DIRECTORY_SEPARATOR); +} + +/** + * set SMARTY_DIR to absolute path to Smarty library files. + * if not defined, include_path will be used. Sets SMARTY_DIR only if user + * application has not already defined it. + */ + +if (!defined('SMARTY_DIR')) { + define('SMARTY_DIR', dirname(__FILE__) . DIRECTORY_SEPARATOR); +} + +if (!defined('SMARTY_CORE_DIR')) { + define('SMARTY_CORE_DIR', SMARTY_DIR . 'internals' . DIRECTORY_SEPARATOR); +} + +define('SMARTY_PHP_PASSTHRU', 0); +define('SMARTY_PHP_QUOTE', 1); +define('SMARTY_PHP_REMOVE', 2); +define('SMARTY_PHP_ALLOW', 3); + +/** + * @package Smarty + */ +class Smarty +{ + /**#@+ + * Smarty Configuration Section + */ + + /** + * The name of the directory where templates are located. + * + * @var string + */ + var $template_dir = 'templates'; + + /** + * The directory where compiled templates are located. + * + * @var string + */ + var $compile_dir = 'templates_c'; + + /** + * The directory where config files are located. + * + * @var string + */ + var $config_dir = 'configs'; + + /** + * An array of directories searched for plugins. + * + * @var array + */ + var $plugins_dir = array('plugins'); + + /** + * If debugging is enabled, a debug console window will display + * when the page loads (make sure your browser allows unrequested + * popup windows) + * + * @var boolean + */ + var $debugging = false; + + /** + * When set, smarty does uses this value as error_reporting-level. + * + * @var boolean + */ + var $error_reporting = null; + + /** + * This is the path to the debug console template. If not set, + * the default one will be used. + * + * @var string + */ + var $debug_tpl = ''; + + /** + * This determines if debugging is enable-able from the browser. + *
      + *
    • NONE => no debugging control allowed
    • + *
    • URL => enable debugging when SMARTY_DEBUG is found in the URL.
    • + *
    + * @link http://www.foo.dom/index.php?SMARTY_DEBUG + * @var string + */ + var $debugging_ctrl = 'NONE'; + + /** + * This tells Smarty whether to check for recompiling or not. Recompiling + * does not need to happen unless a template or config file is changed. + * Typically you enable this during development, and disable for + * production. + * + * @var boolean + */ + var $compile_check = true; + + /** + * This forces templates to compile every time. Useful for development + * or debugging. + * + * @var boolean + */ + var $force_compile = false; + + /** + * This enables template caching. + *
      + *
    • 0 = no caching
    • + *
    • 1 = use class cache_lifetime value
    • + *
    • 2 = use cache_lifetime in cache file
    • + *
    + * @var integer + */ + var $caching = 0; + + /** + * The name of the directory for cache files. + * + * @var string + */ + var $cache_dir = 'cache'; + + /** + * This is the number of seconds cached content will persist. + *
      + *
    • 0 = always regenerate cache
    • + *
    • -1 = never expires
    • + *
    + * + * @var integer + */ + var $cache_lifetime = 3600; + + /** + * Only used when $caching is enabled. If true, then If-Modified-Since headers + * are respected with cached content, and appropriate HTTP headers are sent. + * This way repeated hits to a cached page do not send the entire page to the + * client every time. + * + * @var boolean + */ + var $cache_modified_check = false; + + /** + * This determines how Smarty handles "" tags in templates. + * possible values: + *
      + *
    • SMARTY_PHP_PASSTHRU -> print tags as plain text
    • + *
    • SMARTY_PHP_QUOTE -> escape tags as entities
    • + *
    • SMARTY_PHP_REMOVE -> remove php tags
    • + *
    • SMARTY_PHP_ALLOW -> execute php tags
    • + *
    + * + * @var integer + */ + var $php_handling = SMARTY_PHP_PASSTHRU; + + /** + * This enables template security. When enabled, many things are restricted + * in the templates that normally would go unchecked. This is useful when + * untrusted parties are editing templates and you want a reasonable level + * of security. (no direct execution of PHP in templates for example) + * + * @var boolean + */ + var $security = false; + + /** + * This is the list of template directories that are considered secure. This + * is used only if {@link $security} is enabled. One directory per array + * element. {@link $template_dir} is in this list implicitly. + * + * @var array + */ + var $secure_dir = array(); + + /** + * These are the security settings for Smarty. They are used only when + * {@link $security} is enabled. + * + * @var array + */ + var $security_settings = array( + 'PHP_HANDLING' => false, + 'IF_FUNCS' => array('array', 'list', + 'isset', 'empty', + 'count', 'sizeof', + 'in_array', 'is_array', + 'true', 'false', 'null'), + 'INCLUDE_ANY' => false, + 'PHP_TAGS' => false, + 'MODIFIER_FUNCS' => array('count'), + 'ALLOW_CONSTANTS' => false + ); + + /** + * This is an array of directories where trusted php scripts reside. + * {@link $security} is disabled during their inclusion/execution. + * + * @var array + */ + var $trusted_dir = array(); + + /** + * The left delimiter used for the template tags. + * + * @var string + */ + var $left_delimiter = '{'; + + /** + * The right delimiter used for the template tags. + * + * @var string + */ + var $right_delimiter = '}'; + + /** + * The order in which request variables are registered, similar to + * variables_order in php.ini E = Environment, G = GET, P = POST, + * C = Cookies, S = Server + * + * @var string + */ + var $request_vars_order = 'EGPCS'; + + /** + * Indicates wether $HTTP_*_VARS[] (request_use_auto_globals=false) + * are uses as request-vars or $_*[]-vars. note: if + * request_use_auto_globals is true, then $request_vars_order has + * no effect, but the php-ini-value "gpc_order" + * + * @var boolean + */ + var $request_use_auto_globals = true; + + /** + * Set this if you want different sets of compiled files for the same + * templates. This is useful for things like different languages. + * Instead of creating separate sets of templates per language, you + * set different compile_ids like 'en' and 'de'. + * + * @var string + */ + var $compile_id = null; + + /** + * This tells Smarty whether or not to use sub dirs in the cache/ and + * templates_c/ directories. sub directories better organized, but + * may not work well with PHP safe mode enabled. + * + * @var boolean + * + */ + var $use_sub_dirs = false; + + /** + * This is a list of the modifiers to apply to all template variables. + * Put each modifier in a separate array element in the order you want + * them applied. example: array('escape:"htmlall"'); + * + * @var array + */ + var $default_modifiers = array(); + + /** + * This is the resource type to be used when not specified + * at the beginning of the resource path. examples: + * $smarty->display('file:index.tpl'); + * $smarty->display('db:index.tpl'); + * $smarty->display('index.tpl'); // will use default resource type + * {include file="file:index.tpl"} + * {include file="db:index.tpl"} + * {include file="index.tpl"} {* will use default resource type *} + * + * @var array + */ + var $default_resource_type = 'file'; + + /** + * The function used for cache file handling. If not set, built-in caching is used. + * + * @var null|string function name + */ + var $cache_handler_func = null; + + /** + * This indicates which filters are automatically loaded into Smarty. + * + * @var array array of filter names + */ + var $autoload_filters = array(); + + /**#@+ + * @var boolean + */ + /** + * This tells if config file vars of the same name overwrite each other or not. + * if disabled, same name variables are accumulated in an array. + */ + var $config_overwrite = true; + + /** + * This tells whether or not to automatically booleanize config file variables. + * If enabled, then the strings "on", "true", and "yes" are treated as boolean + * true, and "off", "false" and "no" are treated as boolean false. + */ + var $config_booleanize = true; + + /** + * This tells whether hidden sections [.foobar] are readable from the + * tempalates or not. Normally you would never allow this since that is + * the point behind hidden sections: the application can access them, but + * the templates cannot. + */ + var $config_read_hidden = false; + + /** + * This tells whether or not automatically fix newlines in config files. + * It basically converts \r (mac) or \r\n (dos) to \n + */ + var $config_fix_newlines = true; + /**#@-*/ + + /** + * If a template cannot be found, this PHP function will be executed. + * Useful for creating templates on-the-fly or other special action. + * + * @var string function name + */ + var $default_template_handler_func = ''; + + /** + * The file that contains the compiler class. This can a full + * pathname, or relative to the php_include path. + * + * @var string + */ + var $compiler_file = 'Smarty_Compiler.class.php'; + + /** + * The class used for compiling templates. + * + * @var string + */ + var $compiler_class = 'Smarty_Compiler'; + + /** + * The class used to load config vars. + * + * @var string + */ + var $config_class = 'Config_File'; + +/**#@+ + * END Smarty Configuration Section + * There should be no need to touch anything below this line. + * @access private + */ + /** + * where assigned template vars are kept + * + * @var array + */ + var $_tpl_vars = array(); + + /** + * stores run-time $smarty.* vars + * + * @var null|array + */ + var $_smarty_vars = null; + + /** + * keeps track of sections + * + * @var array + */ + var $_sections = array(); + + /** + * keeps track of foreach blocks + * + * @var array + */ + var $_foreach = array(); + + /** + * keeps track of tag hierarchy + * + * @var array + */ + var $_tag_stack = array(); + + /** + * configuration object + * + * @var Config_file + */ + var $_conf_obj = null; + + /** + * loaded configuration settings + * + * @var array + */ + var $_config = array(array('vars' => array(), 'files' => array())); + + /** + * md5 checksum of the string 'Smarty' + * + * @var string + */ + var $_smarty_md5 = 'f8d698aea36fcbead2b9d5359ffca76f'; + + /** + * Smarty version number + * + * @var string + */ + var $_version = '2.6.19'; + + /** + * current template inclusion depth + * + * @var integer + */ + var $_inclusion_depth = 0; + + /** + * for different compiled templates + * + * @var string + */ + var $_compile_id = null; + + /** + * text in URL to enable debug mode + * + * @var string + */ + var $_smarty_debug_id = 'SMARTY_DEBUG'; + + /** + * debugging information for debug console + * + * @var array + */ + var $_smarty_debug_info = array(); + + /** + * info that makes up a cache file + * + * @var array + */ + var $_cache_info = array(); + + /** + * default file permissions + * + * @var integer + */ + var $_file_perms = 0644; + + /** + * default dir permissions + * + * @var integer + */ + var $_dir_perms = 0771; + + /** + * registered objects + * + * @var array + */ + var $_reg_objects = array(); + + /** + * table keeping track of plugins + * + * @var array + */ + var $_plugins = array( + 'modifier' => array(), + 'function' => array(), + 'block' => array(), + 'compiler' => array(), + 'prefilter' => array(), + 'postfilter' => array(), + 'outputfilter' => array(), + 'resource' => array(), + 'insert' => array()); + + + /** + * cache serials + * + * @var array + */ + var $_cache_serials = array(); + + /** + * name of optional cache include file + * + * @var string + */ + var $_cache_include = null; + + /** + * indicate if the current code is used in a compiled + * include + * + * @var string + */ + var $_cache_including = false; + + /**#@-*/ + /** + * The class constructor. + */ + function Smarty() + { + $this->assign('SCRIPT_NAME', isset($_SERVER['SCRIPT_NAME']) ? $_SERVER['SCRIPT_NAME'] + : @$GLOBALS['HTTP_SERVER_VARS']['SCRIPT_NAME']); + } + + /** + * assigns values to template variables + * + * @param array|string $tpl_var the template variable name(s) + * @param mixed $value the value to assign + */ + function assign($tpl_var, $value = null) + { + if (is_array($tpl_var)){ + foreach ($tpl_var as $key => $val) { + if ($key != '') { + $this->_tpl_vars[$key] = $val; + } + } + } else { + if ($tpl_var != '') + $this->_tpl_vars[$tpl_var] = $value; + } + } + + /** + * assigns values to template variables by reference + * + * @param string $tpl_var the template variable name + * @param mixed $value the referenced value to assign + */ + function assign_by_ref($tpl_var, &$value) + { + if ($tpl_var != '') + $this->_tpl_vars[$tpl_var] = &$value; + } + + /** + * appends values to template variables + * + * @param array|string $tpl_var the template variable name(s) + * @param mixed $value the value to append + */ + function append($tpl_var, $value=null, $merge=false) + { + if (is_array($tpl_var)) { + // $tpl_var is an array, ignore $value + foreach ($tpl_var as $_key => $_val) { + if ($_key != '') { + if(!@is_array($this->_tpl_vars[$_key])) { + settype($this->_tpl_vars[$_key],'array'); + } + if($merge && is_array($_val)) { + foreach($_val as $_mkey => $_mval) { + $this->_tpl_vars[$_key][$_mkey] = $_mval; + } + } else { + $this->_tpl_vars[$_key][] = $_val; + } + } + } + } else { + if ($tpl_var != '' && isset($value)) { + if(!@is_array($this->_tpl_vars[$tpl_var])) { + settype($this->_tpl_vars[$tpl_var],'array'); + } + if($merge && is_array($value)) { + foreach($value as $_mkey => $_mval) { + $this->_tpl_vars[$tpl_var][$_mkey] = $_mval; + } + } else { + $this->_tpl_vars[$tpl_var][] = $value; + } + } + } + } + + /** + * appends values to template variables by reference + * + * @param string $tpl_var the template variable name + * @param mixed $value the referenced value to append + */ + function append_by_ref($tpl_var, &$value, $merge=false) + { + if ($tpl_var != '' && isset($value)) { + if(!@is_array($this->_tpl_vars[$tpl_var])) { + settype($this->_tpl_vars[$tpl_var],'array'); + } + if ($merge && is_array($value)) { + foreach($value as $_key => $_val) { + $this->_tpl_vars[$tpl_var][$_key] = &$value[$_key]; + } + } else { + $this->_tpl_vars[$tpl_var][] = &$value; + } + } + } + + + /** + * clear the given assigned template variable. + * + * @param string $tpl_var the template variable to clear + */ + function clear_assign($tpl_var) + { + if (is_array($tpl_var)) + foreach ($tpl_var as $curr_var) + unset($this->_tpl_vars[$curr_var]); + else + unset($this->_tpl_vars[$tpl_var]); + } + + + /** + * Registers custom function to be used in templates + * + * @param string $function the name of the template function + * @param string $function_impl the name of the PHP function to register + */ + function register_function($function, $function_impl, $cacheable=true, $cache_attrs=null) + { + $this->_plugins['function'][$function] = + array($function_impl, null, null, false, $cacheable, $cache_attrs); + + } + + /** + * Unregisters custom function + * + * @param string $function name of template function + */ + function unregister_function($function) + { + unset($this->_plugins['function'][$function]); + } + + /** + * Registers object to be used in templates + * + * @param string $object name of template object + * @param object &$object_impl the referenced PHP object to register + * @param null|array $allowed list of allowed methods (empty = all) + * @param boolean $smarty_args smarty argument format, else traditional + * @param null|array $block_functs list of methods that are block format + */ + function register_object($object, &$object_impl, $allowed = array(), $smarty_args = true, $block_methods = array()) + { + settype($allowed, 'array'); + settype($smarty_args, 'boolean'); + $this->_reg_objects[$object] = + array(&$object_impl, $allowed, $smarty_args, $block_methods); + } + + /** + * Unregisters object + * + * @param string $object name of template object + */ + function unregister_object($object) + { + unset($this->_reg_objects[$object]); + } + + + /** + * Registers block function to be used in templates + * + * @param string $block name of template block + * @param string $block_impl PHP function to register + */ + function register_block($block, $block_impl, $cacheable=true, $cache_attrs=null) + { + $this->_plugins['block'][$block] = + array($block_impl, null, null, false, $cacheable, $cache_attrs); + } + + /** + * Unregisters block function + * + * @param string $block name of template function + */ + function unregister_block($block) + { + unset($this->_plugins['block'][$block]); + } + + /** + * Registers compiler function + * + * @param string $function name of template function + * @param string $function_impl name of PHP function to register + */ + function register_compiler_function($function, $function_impl, $cacheable=true) + { + $this->_plugins['compiler'][$function] = + array($function_impl, null, null, false, $cacheable); + } + + /** + * Unregisters compiler function + * + * @param string $function name of template function + */ + function unregister_compiler_function($function) + { + unset($this->_plugins['compiler'][$function]); + } + + /** + * Registers modifier to be used in templates + * + * @param string $modifier name of template modifier + * @param string $modifier_impl name of PHP function to register + */ + function register_modifier($modifier, $modifier_impl) + { + $this->_plugins['modifier'][$modifier] = + array($modifier_impl, null, null, false); + } + + /** + * Unregisters modifier + * + * @param string $modifier name of template modifier + */ + function unregister_modifier($modifier) + { + unset($this->_plugins['modifier'][$modifier]); + } + + /** + * Registers a resource to fetch a template + * + * @param string $type name of resource + * @param array $functions array of functions to handle resource + */ + function register_resource($type, $functions) + { + if (count($functions)==4) { + $this->_plugins['resource'][$type] = + array($functions, false); + + } elseif (count($functions)==5) { + $this->_plugins['resource'][$type] = + array(array(array(&$functions[0], $functions[1]) + ,array(&$functions[0], $functions[2]) + ,array(&$functions[0], $functions[3]) + ,array(&$functions[0], $functions[4])) + ,false); + + } else { + $this->trigger_error("malformed function-list for '$type' in register_resource"); + + } + } + + /** + * Unregisters a resource + * + * @param string $type name of resource + */ + function unregister_resource($type) + { + unset($this->_plugins['resource'][$type]); + } + + /** + * Registers a prefilter function to apply + * to a template before compiling + * + * @param callback $function + */ + function register_prefilter($function) + { + $this->_plugins['prefilter'][$this->_get_filter_name($function)] + = array($function, null, null, false); + } + + /** + * Unregisters a prefilter function + * + * @param callback $function + */ + function unregister_prefilter($function) + { + unset($this->_plugins['prefilter'][$this->_get_filter_name($function)]); + } + + /** + * Registers a postfilter function to apply + * to a compiled template after compilation + * + * @param callback $function + */ + function register_postfilter($function) + { + $this->_plugins['postfilter'][$this->_get_filter_name($function)] + = array($function, null, null, false); + } + + /** + * Unregisters a postfilter function + * + * @param callback $function + */ + function unregister_postfilter($function) + { + unset($this->_plugins['postfilter'][$this->_get_filter_name($function)]); + } + + /** + * Registers an output filter function to apply + * to a template output + * + * @param callback $function + */ + function register_outputfilter($function) + { + $this->_plugins['outputfilter'][$this->_get_filter_name($function)] + = array($function, null, null, false); + } + + /** + * Unregisters an outputfilter function + * + * @param callback $function + */ + function unregister_outputfilter($function) + { + unset($this->_plugins['outputfilter'][$this->_get_filter_name($function)]); + } + + /** + * load a filter of specified type and name + * + * @param string $type filter type + * @param string $name filter name + */ + function load_filter($type, $name) + { + switch ($type) { + case 'output': + $_params = array('plugins' => array(array($type . 'filter', $name, null, null, false))); + require_once(SMARTY_CORE_DIR . 'core.load_plugins.php'); + smarty_core_load_plugins($_params, $this); + break; + + case 'pre': + case 'post': + if (!isset($this->_plugins[$type . 'filter'][$name])) + $this->_plugins[$type . 'filter'][$name] = false; + break; + } + } + + /** + * clear cached content for the given template and cache id + * + * @param string $tpl_file name of template file + * @param string $cache_id name of cache_id + * @param string $compile_id name of compile_id + * @param string $exp_time expiration time + * @return boolean + */ + function clear_cache($tpl_file = null, $cache_id = null, $compile_id = null, $exp_time = null) + { + + if (!isset($compile_id)) + $compile_id = $this->compile_id; + + if (!isset($tpl_file)) + $compile_id = null; + + $_auto_id = $this->_get_auto_id($cache_id, $compile_id); + + if (!empty($this->cache_handler_func)) { + return call_user_func_array($this->cache_handler_func, + array('clear', &$this, &$dummy, $tpl_file, $cache_id, $compile_id, $exp_time)); + } else { + $_params = array('auto_base' => $this->cache_dir, + 'auto_source' => $tpl_file, + 'auto_id' => $_auto_id, + 'exp_time' => $exp_time); + require_once(SMARTY_CORE_DIR . 'core.rm_auto.php'); + return smarty_core_rm_auto($_params, $this); + } + + } + + + /** + * clear the entire contents of cache (all templates) + * + * @param string $exp_time expire time + * @return boolean results of {@link smarty_core_rm_auto()} + */ + function clear_all_cache($exp_time = null) + { + return $this->clear_cache(null, null, null, $exp_time); + } + + + /** + * test to see if valid cache exists for this template + * + * @param string $tpl_file name of template file + * @param string $cache_id + * @param string $compile_id + * @return string|false results of {@link _read_cache_file()} + */ + function is_cached($tpl_file, $cache_id = null, $compile_id = null) + { + if (!$this->caching) + return false; + + if (!isset($compile_id)) + $compile_id = $this->compile_id; + + $_params = array( + 'tpl_file' => $tpl_file, + 'cache_id' => $cache_id, + 'compile_id' => $compile_id + ); + require_once(SMARTY_CORE_DIR . 'core.read_cache_file.php'); + return smarty_core_read_cache_file($_params, $this); + } + + + /** + * clear all the assigned template variables. + * + */ + function clear_all_assign() + { + $this->_tpl_vars = array(); + } + + /** + * clears compiled version of specified template resource, + * or all compiled template files if one is not specified. + * This function is for advanced use only, not normally needed. + * + * @param string $tpl_file + * @param string $compile_id + * @param string $exp_time + * @return boolean results of {@link smarty_core_rm_auto()} + */ + function clear_compiled_tpl($tpl_file = null, $compile_id = null, $exp_time = null) + { + if (!isset($compile_id)) { + $compile_id = $this->compile_id; + } + $_params = array('auto_base' => $this->compile_dir, + 'auto_source' => $tpl_file, + 'auto_id' => $compile_id, + 'exp_time' => $exp_time, + 'extensions' => array('.inc', '.php')); + require_once(SMARTY_CORE_DIR . 'core.rm_auto.php'); + return smarty_core_rm_auto($_params, $this); + } + + /** + * Checks whether requested template exists. + * + * @param string $tpl_file + * @return boolean + */ + function template_exists($tpl_file) + { + $_params = array('resource_name' => $tpl_file, 'quiet'=>true, 'get_source'=>false); + return $this->_fetch_resource_info($_params); + } + + /** + * Returns an array containing template variables + * + * @param string $name + * @param string $type + * @return array + */ + function &get_template_vars($name=null) + { + if(!isset($name)) { + return $this->_tpl_vars; + } elseif(isset($this->_tpl_vars[$name])) { + return $this->_tpl_vars[$name]; + } else { + // var non-existant, return valid reference + $_tmp = null; + return $_tmp; + } + } + + /** + * Returns an array containing config variables + * + * @param string $name + * @param string $type + * @return array + */ + function &get_config_vars($name=null) + { + if(!isset($name) && is_array($this->_config[0])) { + return $this->_config[0]['vars']; + } else if(isset($this->_config[0]['vars'][$name])) { + return $this->_config[0]['vars'][$name]; + } else { + // var non-existant, return valid reference + $_tmp = null; + return $_tmp; + } + } + + /** + * trigger Smarty error + * + * @param string $error_msg + * @param integer $error_type + */ + function trigger_error($error_msg, $error_type = E_USER_WARNING) + { + trigger_error("Smarty error: $error_msg", $error_type); + } + + + /** + * executes & displays the template results + * + * @param string $resource_name + * @param string $cache_id + * @param string $compile_id + */ + function display($resource_name, $cache_id = null, $compile_id = null) + { + $this->fetch($resource_name, $cache_id, $compile_id, true); + } + + /** + * executes & returns or displays the template results + * + * @param string $resource_name + * @param string $cache_id + * @param string $compile_id + * @param boolean $display + */ + function fetch($resource_name, $cache_id = null, $compile_id = null, $display = false) + { + static $_cache_info = array(); + + $_smarty_old_error_level = $this->debugging ? error_reporting() : error_reporting(isset($this->error_reporting) + ? $this->error_reporting : error_reporting() & ~E_NOTICE); + + if (!$this->debugging && $this->debugging_ctrl == 'URL') { + $_query_string = $this->request_use_auto_globals ? $_SERVER['QUERY_STRING'] : $GLOBALS['HTTP_SERVER_VARS']['QUERY_STRING']; + if (@strstr($_query_string, $this->_smarty_debug_id)) { + if (@strstr($_query_string, $this->_smarty_debug_id . '=on')) { + // enable debugging for this browser session + @setcookie('SMARTY_DEBUG', true); + $this->debugging = true; + } elseif (@strstr($_query_string, $this->_smarty_debug_id . '=off')) { + // disable debugging for this browser session + @setcookie('SMARTY_DEBUG', false); + $this->debugging = false; + } else { + // enable debugging for this page + $this->debugging = true; + } + } else { + $this->debugging = (bool)($this->request_use_auto_globals ? @$_COOKIE['SMARTY_DEBUG'] : @$GLOBALS['HTTP_COOKIE_VARS']['SMARTY_DEBUG']); + } + } + + if ($this->debugging) { + // capture time for debugging info + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $_debug_start_time = smarty_core_get_microtime($_params, $this); + $this->_smarty_debug_info[] = array('type' => 'template', + 'filename' => $resource_name, + 'depth' => 0); + $_included_tpls_idx = count($this->_smarty_debug_info) - 1; + } + + if (!isset($compile_id)) { + $compile_id = $this->compile_id; + } + + $this->_compile_id = $compile_id; + $this->_inclusion_depth = 0; + + if ($this->caching) { + // save old cache_info, initialize cache_info + array_push($_cache_info, $this->_cache_info); + $this->_cache_info = array(); + $_params = array( + 'tpl_file' => $resource_name, + 'cache_id' => $cache_id, + 'compile_id' => $compile_id, + 'results' => null + ); + require_once(SMARTY_CORE_DIR . 'core.read_cache_file.php'); + if (smarty_core_read_cache_file($_params, $this)) { + $_smarty_results = $_params['results']; + if (!empty($this->_cache_info['insert_tags'])) { + $_params = array('plugins' => $this->_cache_info['insert_tags']); + require_once(SMARTY_CORE_DIR . 'core.load_plugins.php'); + smarty_core_load_plugins($_params, $this); + $_params = array('results' => $_smarty_results); + require_once(SMARTY_CORE_DIR . 'core.process_cached_inserts.php'); + $_smarty_results = smarty_core_process_cached_inserts($_params, $this); + } + if (!empty($this->_cache_info['cache_serials'])) { + $_params = array('results' => $_smarty_results); + require_once(SMARTY_CORE_DIR . 'core.process_compiled_include.php'); + $_smarty_results = smarty_core_process_compiled_include($_params, $this); + } + + + if ($display) { + if ($this->debugging) + { + // capture time for debugging info + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $this->_smarty_debug_info[$_included_tpls_idx]['exec_time'] = smarty_core_get_microtime($_params, $this) - $_debug_start_time; + require_once(SMARTY_CORE_DIR . 'core.display_debug_console.php'); + $_smarty_results .= smarty_core_display_debug_console($_params, $this); + } + if ($this->cache_modified_check) { + $_server_vars = ($this->request_use_auto_globals) ? $_SERVER : $GLOBALS['HTTP_SERVER_VARS']; + $_last_modified_date = @substr($_server_vars['HTTP_IF_MODIFIED_SINCE'], 0, strpos($_server_vars['HTTP_IF_MODIFIED_SINCE'], 'GMT') + 3); + $_gmt_mtime = gmdate('D, d M Y H:i:s', $this->_cache_info['timestamp']).' GMT'; + if (@count($this->_cache_info['insert_tags']) == 0 + && !$this->_cache_serials + && $_gmt_mtime == $_last_modified_date) { + if (php_sapi_name()=='cgi') + header('Status: 304 Not Modified'); + else + header('HTTP/1.1 304 Not Modified'); + + } else { + header('Last-Modified: '.$_gmt_mtime); + echo $_smarty_results; + } + } else { + echo $_smarty_results; + } + error_reporting($_smarty_old_error_level); + // restore initial cache_info + $this->_cache_info = array_pop($_cache_info); + return true; + } else { + error_reporting($_smarty_old_error_level); + // restore initial cache_info + $this->_cache_info = array_pop($_cache_info); + return $_smarty_results; + } + } else { + $this->_cache_info['template'][$resource_name] = true; + if ($this->cache_modified_check && $display) { + header('Last-Modified: '.gmdate('D, d M Y H:i:s', time()).' GMT'); + } + } + } + + // load filters that are marked as autoload + if (count($this->autoload_filters)) { + foreach ($this->autoload_filters as $_filter_type => $_filters) { + foreach ($_filters as $_filter) { + $this->load_filter($_filter_type, $_filter); + } + } + } + + $_smarty_compile_path = $this->_get_compile_path($resource_name); + + // if we just need to display the results, don't perform output + // buffering - for speed + $_cache_including = $this->_cache_including; + $this->_cache_including = false; + if ($display && !$this->caching && count($this->_plugins['outputfilter']) == 0) { + if ($this->_is_compiled($resource_name, $_smarty_compile_path) + || $this->_compile_resource($resource_name, $_smarty_compile_path)) + { + include($_smarty_compile_path); + } + } else { + ob_start(); + if ($this->_is_compiled($resource_name, $_smarty_compile_path) + || $this->_compile_resource($resource_name, $_smarty_compile_path)) + { + include($_smarty_compile_path); + } + $_smarty_results = ob_get_contents(); + ob_end_clean(); + + foreach ((array)$this->_plugins['outputfilter'] as $_output_filter) { + $_smarty_results = call_user_func_array($_output_filter[0], array($_smarty_results, &$this)); + } + } + + if ($this->caching) { + $_params = array('tpl_file' => $resource_name, + 'cache_id' => $cache_id, + 'compile_id' => $compile_id, + 'results' => $_smarty_results); + require_once(SMARTY_CORE_DIR . 'core.write_cache_file.php'); + smarty_core_write_cache_file($_params, $this); + require_once(SMARTY_CORE_DIR . 'core.process_cached_inserts.php'); + $_smarty_results = smarty_core_process_cached_inserts($_params, $this); + + if ($this->_cache_serials) { + // strip nocache-tags from output + $_smarty_results = preg_replace('!(\{/?nocache\:[0-9a-f]{32}#\d+\})!s' + ,'' + ,$_smarty_results); + } + // restore initial cache_info + $this->_cache_info = array_pop($_cache_info); + } + $this->_cache_including = $_cache_including; + + if ($display) { + if (isset($_smarty_results)) { echo $_smarty_results; } + if ($this->debugging) { + // capture time for debugging info + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $this->_smarty_debug_info[$_included_tpls_idx]['exec_time'] = (smarty_core_get_microtime($_params, $this) - $_debug_start_time); + require_once(SMARTY_CORE_DIR . 'core.display_debug_console.php'); + echo smarty_core_display_debug_console($_params, $this); + } + error_reporting($_smarty_old_error_level); + return; + } else { + error_reporting($_smarty_old_error_level); + if (isset($_smarty_results)) { return $_smarty_results; } + } + } + + /** + * load configuration values + * + * @param string $file + * @param string $section + * @param string $scope + */ + function config_load($file, $section = null, $scope = 'global') + { + require_once($this->_get_plugin_filepath('function', 'config_load')); + smarty_function_config_load(array('file' => $file, 'section' => $section, 'scope' => $scope), $this); + } + + /** + * return a reference to a registered object + * + * @param string $name + * @return object + */ + function &get_registered_object($name) { + if (!isset($this->_reg_objects[$name])) + $this->_trigger_fatal_error("'$name' is not a registered object"); + + if (!is_object($this->_reg_objects[$name][0])) + $this->_trigger_fatal_error("registered '$name' is not an object"); + + return $this->_reg_objects[$name][0]; + } + + /** + * clear configuration values + * + * @param string $var + */ + function clear_config($var = null) + { + if(!isset($var)) { + // clear all values + $this->_config = array(array('vars' => array(), + 'files' => array())); + } else { + unset($this->_config[0]['vars'][$var]); + } + } + + /** + * get filepath of requested plugin + * + * @param string $type + * @param string $name + * @return string|false + */ + function _get_plugin_filepath($type, $name) + { + $_params = array('type' => $type, 'name' => $name); + require_once(SMARTY_CORE_DIR . 'core.assemble_plugin_filepath.php'); + return smarty_core_assemble_plugin_filepath($_params, $this); + } + + /** + * test if resource needs compiling + * + * @param string $resource_name + * @param string $compile_path + * @return boolean + */ + function _is_compiled($resource_name, $compile_path) + { + if (!$this->force_compile && file_exists($compile_path)) { + if (!$this->compile_check) { + // no need to check compiled file + return true; + } else { + // get file source and timestamp + $_params = array('resource_name' => $resource_name, 'get_source'=>false); + if (!$this->_fetch_resource_info($_params)) { + return false; + } + if ($_params['resource_timestamp'] <= filemtime($compile_path)) { + // template not expired, no recompile + return true; + } else { + // compile template + return false; + } + } + } else { + // compiled template does not exist, or forced compile + return false; + } + } + + /** + * compile the template + * + * @param string $resource_name + * @param string $compile_path + * @return boolean + */ + function _compile_resource($resource_name, $compile_path) + { + + $_params = array('resource_name' => $resource_name); + if (!$this->_fetch_resource_info($_params)) { + return false; + } + + $_source_content = $_params['source_content']; + $_cache_include = substr($compile_path, 0, -4).'.inc'; + + if ($this->_compile_source($resource_name, $_source_content, $_compiled_content, $_cache_include)) { + // if a _cache_serial was set, we also have to write an include-file: + if ($this->_cache_include_info) { + require_once(SMARTY_CORE_DIR . 'core.write_compiled_include.php'); + smarty_core_write_compiled_include(array_merge($this->_cache_include_info, array('compiled_content'=>$_compiled_content, 'resource_name'=>$resource_name)), $this); + } + + $_params = array('compile_path'=>$compile_path, 'compiled_content' => $_compiled_content); + require_once(SMARTY_CORE_DIR . 'core.write_compiled_resource.php'); + smarty_core_write_compiled_resource($_params, $this); + + return true; + } else { + return false; + } + + } + + /** + * compile the given source + * + * @param string $resource_name + * @param string $source_content + * @param string $compiled_content + * @return boolean + */ + function _compile_source($resource_name, &$source_content, &$compiled_content, $cache_include_path=null) + { + if (file_exists(SMARTY_DIR . $this->compiler_file)) { + require_once(SMARTY_DIR . $this->compiler_file); + } else { + // use include_path + require_once($this->compiler_file); + } + + + $smarty_compiler = new $this->compiler_class; + + $smarty_compiler->template_dir = $this->template_dir; + $smarty_compiler->compile_dir = $this->compile_dir; + $smarty_compiler->plugins_dir = $this->plugins_dir; + $smarty_compiler->config_dir = $this->config_dir; + $smarty_compiler->force_compile = $this->force_compile; + $smarty_compiler->caching = $this->caching; + $smarty_compiler->php_handling = $this->php_handling; + $smarty_compiler->left_delimiter = $this->left_delimiter; + $smarty_compiler->right_delimiter = $this->right_delimiter; + $smarty_compiler->_version = $this->_version; + $smarty_compiler->security = $this->security; + $smarty_compiler->secure_dir = $this->secure_dir; + $smarty_compiler->security_settings = $this->security_settings; + $smarty_compiler->trusted_dir = $this->trusted_dir; + $smarty_compiler->use_sub_dirs = $this->use_sub_dirs; + $smarty_compiler->_reg_objects = &$this->_reg_objects; + $smarty_compiler->_plugins = &$this->_plugins; + $smarty_compiler->_tpl_vars = &$this->_tpl_vars; + $smarty_compiler->default_modifiers = $this->default_modifiers; + $smarty_compiler->compile_id = $this->_compile_id; + $smarty_compiler->_config = $this->_config; + $smarty_compiler->request_use_auto_globals = $this->request_use_auto_globals; + + if (isset($cache_include_path) && isset($this->_cache_serials[$cache_include_path])) { + $smarty_compiler->_cache_serial = $this->_cache_serials[$cache_include_path]; + } + $smarty_compiler->_cache_include = $cache_include_path; + + + $_results = $smarty_compiler->_compile_file($resource_name, $source_content, $compiled_content); + + if ($smarty_compiler->_cache_serial) { + $this->_cache_include_info = array( + 'cache_serial'=>$smarty_compiler->_cache_serial + ,'plugins_code'=>$smarty_compiler->_plugins_code + ,'include_file_path' => $cache_include_path); + + } else { + $this->_cache_include_info = null; + + } + + return $_results; + } + + /** + * Get the compile path for this resource + * + * @param string $resource_name + * @return string results of {@link _get_auto_filename()} + */ + function _get_compile_path($resource_name) + { + return $this->_get_auto_filename($this->compile_dir, $resource_name, + $this->_compile_id) . '.php'; + } + + /** + * fetch the template info. Gets timestamp, and source + * if get_source is true + * + * sets $source_content to the source of the template, and + * $resource_timestamp to its time stamp + * @param string $resource_name + * @param string $source_content + * @param integer $resource_timestamp + * @param boolean $get_source + * @param boolean $quiet + * @return boolean + */ + + function _fetch_resource_info(&$params) + { + if(!isset($params['get_source'])) { $params['get_source'] = true; } + if(!isset($params['quiet'])) { $params['quiet'] = false; } + + $_return = false; + $_params = array('resource_name' => $params['resource_name']) ; + if (isset($params['resource_base_path'])) + $_params['resource_base_path'] = $params['resource_base_path']; + else + $_params['resource_base_path'] = $this->template_dir; + + if ($this->_parse_resource_name($_params)) { + $_resource_type = $_params['resource_type']; + $_resource_name = $_params['resource_name']; + switch ($_resource_type) { + case 'file': + if ($params['get_source']) { + $params['source_content'] = $this->_read_file($_resource_name); + } + $params['resource_timestamp'] = filemtime($_resource_name); + $_return = is_file($_resource_name); + break; + + default: + // call resource functions to fetch the template source and timestamp + if ($params['get_source']) { + $_source_return = isset($this->_plugins['resource'][$_resource_type]) && + call_user_func_array($this->_plugins['resource'][$_resource_type][0][0], + array($_resource_name, &$params['source_content'], &$this)); + } else { + $_source_return = true; + } + + $_timestamp_return = isset($this->_plugins['resource'][$_resource_type]) && + call_user_func_array($this->_plugins['resource'][$_resource_type][0][1], + array($_resource_name, &$params['resource_timestamp'], &$this)); + + $_return = $_source_return && $_timestamp_return; + break; + } + } + + if (!$_return) { + // see if we can get a template with the default template handler + if (!empty($this->default_template_handler_func)) { + if (!is_callable($this->default_template_handler_func)) { + $this->trigger_error("default template handler function \"$this->default_template_handler_func\" doesn't exist."); + } else { + $_return = call_user_func_array( + $this->default_template_handler_func, + array($_params['resource_type'], $_params['resource_name'], &$params['source_content'], &$params['resource_timestamp'], &$this)); + } + } + } + + if (!$_return) { + if (!$params['quiet']) { + $this->trigger_error('unable to read resource: "' . $params['resource_name'] . '"'); + } + } else if ($_return && $this->security) { + require_once(SMARTY_CORE_DIR . 'core.is_secure.php'); + if (!smarty_core_is_secure($_params, $this)) { + if (!$params['quiet']) + $this->trigger_error('(secure mode) accessing "' . $params['resource_name'] . '" is not allowed'); + $params['source_content'] = null; + $params['resource_timestamp'] = null; + return false; + } + } + return $_return; + } + + + /** + * parse out the type and name from the resource + * + * @param string $resource_base_path + * @param string $resource_name + * @param string $resource_type + * @param string $resource_name + * @return boolean + */ + + function _parse_resource_name(&$params) + { + + // split tpl_path by the first colon + $_resource_name_parts = explode(':', $params['resource_name'], 2); + + if (count($_resource_name_parts) == 1) { + // no resource type given + $params['resource_type'] = $this->default_resource_type; + $params['resource_name'] = $_resource_name_parts[0]; + } else { + if(strlen($_resource_name_parts[0]) == 1) { + // 1 char is not resource type, but part of filepath + $params['resource_type'] = $this->default_resource_type; + $params['resource_name'] = $params['resource_name']; + } else { + $params['resource_type'] = $_resource_name_parts[0]; + $params['resource_name'] = $_resource_name_parts[1]; + } + } + + if ($params['resource_type'] == 'file') { + if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $params['resource_name'])) { + // relative pathname to $params['resource_base_path'] + // use the first directory where the file is found + foreach ((array)$params['resource_base_path'] as $_curr_path) { + $_fullpath = $_curr_path . DIRECTORY_SEPARATOR . $params['resource_name']; + if (file_exists($_fullpath) && is_file($_fullpath)) { + $params['resource_name'] = $_fullpath; + return true; + } + // didn't find the file, try include_path + $_params = array('file_path' => $_fullpath); + require_once(SMARTY_CORE_DIR . 'core.get_include_path.php'); + if(smarty_core_get_include_path($_params, $this)) { + $params['resource_name'] = $_params['new_file_path']; + return true; + } + } + return false; + } else { + /* absolute path */ + return file_exists($params['resource_name']); + } + } elseif (empty($this->_plugins['resource'][$params['resource_type']])) { + $_params = array('type' => $params['resource_type']); + require_once(SMARTY_CORE_DIR . 'core.load_resource_plugin.php'); + smarty_core_load_resource_plugin($_params, $this); + } + + return true; + } + + + /** + * Handle modifiers + * + * @param string|null $modifier_name + * @param array|null $map_array + * @return string result of modifiers + */ + function _run_mod_handler() + { + $_args = func_get_args(); + list($_modifier_name, $_map_array) = array_splice($_args, 0, 2); + list($_func_name, $_tpl_file, $_tpl_line) = + $this->_plugins['modifier'][$_modifier_name]; + + $_var = $_args[0]; + foreach ($_var as $_key => $_val) { + $_args[0] = $_val; + $_var[$_key] = call_user_func_array($_func_name, $_args); + } + return $_var; + } + + /** + * Remove starting and ending quotes from the string + * + * @param string $string + * @return string + */ + function _dequote($string) + { + if ((substr($string, 0, 1) == "'" || substr($string, 0, 1) == '"') && + substr($string, -1) == substr($string, 0, 1)) + return substr($string, 1, -1); + else + return $string; + } + + + /** + * read in a file + * + * @param string $filename + * @return string + */ + function _read_file($filename) + { + if ( file_exists($filename) && ($fd = @fopen($filename, 'rb')) ) { + $contents = ''; + while (!feof($fd)) { + $contents .= fread($fd, 8192); + } + fclose($fd); + return $contents; + } else { + return false; + } + } + + /** + * get a concrete filename for automagically created content + * + * @param string $auto_base + * @param string $auto_source + * @param string $auto_id + * @return string + * @staticvar string|null + * @staticvar string|null + */ + function _get_auto_filename($auto_base, $auto_source = null, $auto_id = null) + { + $_compile_dir_sep = $this->use_sub_dirs ? DIRECTORY_SEPARATOR : '^'; + $_return = $auto_base . DIRECTORY_SEPARATOR; + + if(isset($auto_id)) { + // make auto_id safe for directory names + $auto_id = str_replace('%7C',$_compile_dir_sep,(urlencode($auto_id))); + // split into separate directories + $_return .= $auto_id . $_compile_dir_sep; + } + + if(isset($auto_source)) { + // make source name safe for filename + $_filename = urlencode(basename($auto_source)); + $_crc32 = sprintf('%08X', crc32($auto_source)); + // prepend %% to avoid name conflicts with + // with $params['auto_id'] names + $_crc32 = substr($_crc32, 0, 2) . $_compile_dir_sep . + substr($_crc32, 0, 3) . $_compile_dir_sep . $_crc32; + $_return .= '%%' . $_crc32 . '%%' . $_filename; + } + + return $_return; + } + + /** + * unlink a file, possibly using expiration time + * + * @param string $resource + * @param integer $exp_time + */ + function _unlink($resource, $exp_time = null) + { + if(isset($exp_time)) { + if(time() - @filemtime($resource) >= $exp_time) { + return @unlink($resource); + } + } else { + return @unlink($resource); + } + } + + /** + * returns an auto_id for auto-file-functions + * + * @param string $cache_id + * @param string $compile_id + * @return string|null + */ + function _get_auto_id($cache_id=null, $compile_id=null) { + if (isset($cache_id)) + return (isset($compile_id)) ? $cache_id . '|' . $compile_id : $cache_id; + elseif(isset($compile_id)) + return $compile_id; + else + return null; + } + + /** + * trigger Smarty plugin error + * + * @param string $error_msg + * @param string $tpl_file + * @param integer $tpl_line + * @param string $file + * @param integer $line + * @param integer $error_type + */ + function _trigger_fatal_error($error_msg, $tpl_file = null, $tpl_line = null, + $file = null, $line = null, $error_type = E_USER_ERROR) + { + if(isset($file) && isset($line)) { + $info = ' ('.basename($file).", line $line)"; + } else { + $info = ''; + } + if (isset($tpl_line) && isset($tpl_file)) { + $this->trigger_error('[in ' . $tpl_file . ' line ' . $tpl_line . "]: $error_msg$info", $error_type); + } else { + $this->trigger_error($error_msg . $info, $error_type); + } + } + + + /** + * callback function for preg_replace, to call a non-cacheable block + * @return string + */ + function _process_compiled_include_callback($match) { + $_func = '_smarty_tplfunc_'.$match[2].'_'.$match[3]; + ob_start(); + $_func($this); + $_ret = ob_get_contents(); + ob_end_clean(); + return $_ret; + } + + + /** + * called for included templates + * + * @param string $_smarty_include_tpl_file + * @param string $_smarty_include_vars + */ + + // $_smarty_include_tpl_file, $_smarty_include_vars + + function _smarty_include($params) + { + if ($this->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $debug_start_time = smarty_core_get_microtime($_params, $this); + $this->_smarty_debug_info[] = array('type' => 'template', + 'filename' => $params['smarty_include_tpl_file'], + 'depth' => ++$this->_inclusion_depth); + $included_tpls_idx = count($this->_smarty_debug_info) - 1; + } + + $this->_tpl_vars = array_merge($this->_tpl_vars, $params['smarty_include_vars']); + + // config vars are treated as local, so push a copy of the + // current ones onto the front of the stack + array_unshift($this->_config, $this->_config[0]); + + $_smarty_compile_path = $this->_get_compile_path($params['smarty_include_tpl_file']); + + + if ($this->_is_compiled($params['smarty_include_tpl_file'], $_smarty_compile_path) + || $this->_compile_resource($params['smarty_include_tpl_file'], $_smarty_compile_path)) + { + include($_smarty_compile_path); + } + + // pop the local vars off the front of the stack + array_shift($this->_config); + + $this->_inclusion_depth--; + + if ($this->debugging) { + // capture time for debugging info + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $this->_smarty_debug_info[$included_tpls_idx]['exec_time'] = smarty_core_get_microtime($_params, $this) - $debug_start_time; + } + + if ($this->caching) { + $this->_cache_info['template'][$params['smarty_include_tpl_file']] = true; + } + } + + + /** + * get or set an array of cached attributes for function that is + * not cacheable + * @return array + */ + function &_smarty_cache_attrs($cache_serial, $count) { + $_cache_attrs =& $this->_cache_info['cache_attrs'][$cache_serial][$count]; + + if ($this->_cache_including) { + /* return next set of cache_attrs */ + $_return = current($_cache_attrs); + next($_cache_attrs); + return $_return; + + } else { + /* add a reference to a new set of cache_attrs */ + $_cache_attrs[] = array(); + return $_cache_attrs[count($_cache_attrs)-1]; + + } + + } + + + /** + * wrapper for include() retaining $this + * @return mixed + */ + function _include($filename, $once=false, $params=null) + { + if ($once) { + return include_once($filename); + } else { + return include($filename); + } + } + + + /** + * wrapper for eval() retaining $this + * @return mixed + */ + function _eval($code, $params=null) + { + return eval($code); + } + + /** + * Extracts the filter name from the given callback + * + * @param callback $function + * @return string + */ + function _get_filter_name($function) + { + if (is_array($function)) { + $_class_name = (is_object($function[0]) ? + get_class($function[0]) : $function[0]); + return $_class_name . '_' . $function[1]; + } + else { + return $function; + } + } + + /**#@-*/ + +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/Smarty_Compiler.class.php b/includes/onyx/templates/libs/Smarty_Compiler.class.php new file mode 100644 index 0000000..52466d3 --- /dev/null +++ b/includes/onyx/templates/libs/Smarty_Compiler.class.php @@ -0,0 +1,2325 @@ + + * @author Andrei Zmievski + * @version 2.6.19 + * @copyright 2001-2005 New Digital Group, Inc. + * @package Smarty + */ + +/* $Id: Smarty_Compiler.class.php 2736 2007-09-16 14:47:53Z mohrt $ */ + +/** + * Template compiling class + * @package Smarty + */ +class Smarty_Compiler extends Smarty { + + // internal vars + /**#@+ + * @access private + */ + var $_folded_blocks = array(); // keeps folded template blocks + var $_current_file = null; // the current template being compiled + var $_current_line_no = 1; // line number for error messages + var $_capture_stack = array(); // keeps track of nested capture buffers + var $_plugin_info = array(); // keeps track of plugins to load + var $_init_smarty_vars = false; + var $_permitted_tokens = array('true','false','yes','no','on','off','null'); + var $_db_qstr_regexp = null; // regexps are setup in the constructor + var $_si_qstr_regexp = null; + var $_qstr_regexp = null; + var $_func_regexp = null; + var $_reg_obj_regexp = null; + var $_var_bracket_regexp = null; + var $_num_const_regexp = null; + var $_dvar_guts_regexp = null; + var $_dvar_regexp = null; + var $_cvar_regexp = null; + var $_svar_regexp = null; + var $_avar_regexp = null; + var $_mod_regexp = null; + var $_var_regexp = null; + var $_parenth_param_regexp = null; + var $_func_call_regexp = null; + var $_obj_ext_regexp = null; + var $_obj_start_regexp = null; + var $_obj_params_regexp = null; + var $_obj_call_regexp = null; + var $_cacheable_state = 0; + var $_cache_attrs_count = 0; + var $_nocache_count = 0; + var $_cache_serial = null; + var $_cache_include = null; + + var $_strip_depth = 0; + var $_additional_newline = "\n"; + + /**#@-*/ + /** + * The class constructor. + */ + function Smarty_Compiler() + { + // matches double quoted strings: + // "foobar" + // "foo\"bar" + $this->_db_qstr_regexp = '"[^"\\\\]*(?:\\\\.[^"\\\\]*)*"'; + + // matches single quoted strings: + // 'foobar' + // 'foo\'bar' + $this->_si_qstr_regexp = '\'[^\'\\\\]*(?:\\\\.[^\'\\\\]*)*\''; + + // matches single or double quoted strings + $this->_qstr_regexp = '(?:' . $this->_db_qstr_regexp . '|' . $this->_si_qstr_regexp . ')'; + + // matches bracket portion of vars + // [0] + // [foo] + // [$bar] + $this->_var_bracket_regexp = '\[\$?[\w\.]+\]'; + + // matches numerical constants + // 30 + // -12 + // 13.22 + $this->_num_const_regexp = '(?:\-?\d+(?:\.\d+)?)'; + + // matches $ vars (not objects): + // $foo + // $foo.bar + // $foo.bar.foobar + // $foo[0] + // $foo[$bar] + // $foo[5][blah] + // $foo[5].bar[$foobar][4] + $this->_dvar_math_regexp = '(?:[\+\*\/\%]|(?:-(?!>)))'; + $this->_dvar_math_var_regexp = '[\$\w\.\+\-\*\/\%\d\>\[\]]'; + $this->_dvar_guts_regexp = '\w+(?:' . $this->_var_bracket_regexp + . ')*(?:\.\$?\w+(?:' . $this->_var_bracket_regexp . ')*)*(?:' . $this->_dvar_math_regexp . '(?:' . $this->_num_const_regexp . '|' . $this->_dvar_math_var_regexp . ')*)?'; + $this->_dvar_regexp = '\$' . $this->_dvar_guts_regexp; + + // matches config vars: + // #foo# + // #foobar123_foo# + $this->_cvar_regexp = '\#\w+\#'; + + // matches section vars: + // %foo.bar% + $this->_svar_regexp = '\%\w+\.\w+\%'; + + // matches all valid variables (no quotes, no modifiers) + $this->_avar_regexp = '(?:' . $this->_dvar_regexp . '|' + . $this->_cvar_regexp . '|' . $this->_svar_regexp . ')'; + + // matches valid variable syntax: + // $foo + // $foo + // #foo# + // #foo# + // "text" + // "text" + $this->_var_regexp = '(?:' . $this->_avar_regexp . '|' . $this->_qstr_regexp . ')'; + + // matches valid object call (one level of object nesting allowed in parameters): + // $foo->bar + // $foo->bar() + // $foo->bar("text") + // $foo->bar($foo, $bar, "text") + // $foo->bar($foo, "foo") + // $foo->bar->foo() + // $foo->bar->foo->bar() + // $foo->bar($foo->bar) + // $foo->bar($foo->bar()) + // $foo->bar($foo->bar($blah,$foo,44,"foo",$foo[0].bar)) + $this->_obj_ext_regexp = '\->(?:\$?' . $this->_dvar_guts_regexp . ')'; + $this->_obj_restricted_param_regexp = '(?:' + . '(?:' . $this->_var_regexp . '|' . $this->_num_const_regexp . ')(?:' . $this->_obj_ext_regexp . '(?:\((?:(?:' . $this->_var_regexp . '|' . $this->_num_const_regexp . ')' + . '(?:\s*,\s*(?:' . $this->_var_regexp . '|' . $this->_num_const_regexp . '))*)?\))?)*)'; + $this->_obj_single_param_regexp = '(?:\w+|' . $this->_obj_restricted_param_regexp . '(?:\s*,\s*(?:(?:\w+|' + . $this->_var_regexp . $this->_obj_restricted_param_regexp . ')))*)'; + $this->_obj_params_regexp = '\((?:' . $this->_obj_single_param_regexp + . '(?:\s*,\s*' . $this->_obj_single_param_regexp . ')*)?\)'; + $this->_obj_start_regexp = '(?:' . $this->_dvar_regexp . '(?:' . $this->_obj_ext_regexp . ')+)'; + $this->_obj_call_regexp = '(?:' . $this->_obj_start_regexp . '(?:' . $this->_obj_params_regexp . ')?(?:' . $this->_dvar_math_regexp . '(?:' . $this->_num_const_regexp . '|' . $this->_dvar_math_var_regexp . ')*)?)'; + + // matches valid modifier syntax: + // |foo + // |@foo + // |foo:"bar" + // |foo:$bar + // |foo:"bar":$foobar + // |foo|bar + // |foo:$foo->bar + $this->_mod_regexp = '(?:\|@?\w+(?::(?:\w+|' . $this->_num_const_regexp . '|' + . $this->_obj_call_regexp . '|' . $this->_avar_regexp . '|' . $this->_qstr_regexp .'))*)'; + + // matches valid function name: + // foo123 + // _foo_bar + $this->_func_regexp = '[a-zA-Z_]\w*'; + + // matches valid registered object: + // foo->bar + $this->_reg_obj_regexp = '[a-zA-Z_]\w*->[a-zA-Z_]\w*'; + + // matches valid parameter values: + // true + // $foo + // $foo|bar + // #foo# + // #foo#|bar + // "text" + // "text"|bar + // $foo->bar + $this->_param_regexp = '(?:\s*(?:' . $this->_obj_call_regexp . '|' + . $this->_var_regexp . '|' . $this->_num_const_regexp . '|\w+)(?>' . $this->_mod_regexp . '*)\s*)'; + + // matches valid parenthesised function parameters: + // + // "text" + // $foo, $bar, "text" + // $foo|bar, "foo"|bar, $foo->bar($foo)|bar + $this->_parenth_param_regexp = '(?:\((?:\w+|' + . $this->_param_regexp . '(?:\s*,\s*(?:(?:\w+|' + . $this->_param_regexp . ')))*)?\))'; + + // matches valid function call: + // foo() + // foo_bar($foo) + // _foo_bar($foo,"bar") + // foo123($foo,$foo->bar(),"foo") + $this->_func_call_regexp = '(?:' . $this->_func_regexp . '\s*(?:' + . $this->_parenth_param_regexp . '))'; + } + + /** + * compile a resource + * + * sets $compiled_content to the compiled source + * @param string $resource_name + * @param string $source_content + * @param string $compiled_content + * @return true + */ + function _compile_file($resource_name, $source_content, &$compiled_content) + { + + if ($this->security) { + // do not allow php syntax to be executed unless specified + if ($this->php_handling == SMARTY_PHP_ALLOW && + !$this->security_settings['PHP_HANDLING']) { + $this->php_handling = SMARTY_PHP_PASSTHRU; + } + } + + $this->_load_filters(); + + $this->_current_file = $resource_name; + $this->_current_line_no = 1; + $ldq = preg_quote($this->left_delimiter, '~'); + $rdq = preg_quote($this->right_delimiter, '~'); + + // run template source through prefilter functions + if (count($this->_plugins['prefilter']) > 0) { + foreach ($this->_plugins['prefilter'] as $filter_name => $prefilter) { + if ($prefilter === false) continue; + if ($prefilter[3] || is_callable($prefilter[0])) { + $source_content = call_user_func_array($prefilter[0], + array($source_content, &$this)); + $this->_plugins['prefilter'][$filter_name][3] = true; + } else { + $this->_trigger_fatal_error("[plugin] prefilter '$filter_name' is not implemented"); + } + } + } + + /* fetch all special blocks */ + $search = "~{$ldq}\*(.*?)\*{$rdq}|{$ldq}\s*literal\s*{$rdq}(.*?){$ldq}\s*/literal\s*{$rdq}|{$ldq}\s*php\s*{$rdq}(.*?){$ldq}\s*/php\s*{$rdq}~s"; + + preg_match_all($search, $source_content, $match, PREG_SET_ORDER); + $this->_folded_blocks = $match; + reset($this->_folded_blocks); + + /* replace special blocks by "{php}" */ + $source_content = preg_replace($search.'e', "'" + . $this->_quote_replace($this->left_delimiter) . 'php' + . "' . str_repeat(\"\n\", substr_count('\\0', \"\n\")) .'" + . $this->_quote_replace($this->right_delimiter) + . "'" + , $source_content); + + /* Gather all template tags. */ + preg_match_all("~{$ldq}\s*(.*?)\s*{$rdq}~s", $source_content, $_match); + $template_tags = $_match[1]; + /* Split content by template tags to obtain non-template content. */ + $text_blocks = preg_split("~{$ldq}.*?{$rdq}~s", $source_content); + + /* loop through text blocks */ + for ($curr_tb = 0, $for_max = count($text_blocks); $curr_tb < $for_max; $curr_tb++) { + /* match anything resembling php tags */ + if (preg_match_all('~(<\?(?:\w+|=)?|\?>|language\s*=\s*[\"\']?\s*php\s*[\"\']?)~is', $text_blocks[$curr_tb], $sp_match)) { + /* replace tags with placeholders to prevent recursive replacements */ + $sp_match[1] = array_unique($sp_match[1]); + usort($sp_match[1], '_smarty_sort_length'); + for ($curr_sp = 0, $for_max2 = count($sp_match[1]); $curr_sp < $for_max2; $curr_sp++) { + $text_blocks[$curr_tb] = str_replace($sp_match[1][$curr_sp],'%%%SMARTYSP'.$curr_sp.'%%%',$text_blocks[$curr_tb]); + } + /* process each one */ + for ($curr_sp = 0, $for_max2 = count($sp_match[1]); $curr_sp < $for_max2; $curr_sp++) { + if ($this->php_handling == SMARTY_PHP_PASSTHRU) { + /* echo php contents */ + $text_blocks[$curr_tb] = str_replace('%%%SMARTYSP'.$curr_sp.'%%%', ''."\n", $text_blocks[$curr_tb]); + } else if ($this->php_handling == SMARTY_PHP_QUOTE) { + /* quote php tags */ + $text_blocks[$curr_tb] = str_replace('%%%SMARTYSP'.$curr_sp.'%%%', htmlspecialchars($sp_match[1][$curr_sp]), $text_blocks[$curr_tb]); + } else if ($this->php_handling == SMARTY_PHP_REMOVE) { + /* remove php tags */ + $text_blocks[$curr_tb] = str_replace('%%%SMARTYSP'.$curr_sp.'%%%', '', $text_blocks[$curr_tb]); + } else { + /* SMARTY_PHP_ALLOW, but echo non php starting tags */ + $sp_match[1][$curr_sp] = preg_replace('~(<\?(?!php|=|$))~i', ''."\n", $sp_match[1][$curr_sp]); + $text_blocks[$curr_tb] = str_replace('%%%SMARTYSP'.$curr_sp.'%%%', $sp_match[1][$curr_sp], $text_blocks[$curr_tb]); + } + } + } + } + + /* Compile the template tags into PHP code. */ + $compiled_tags = array(); + for ($i = 0, $for_max = count($template_tags); $i < $for_max; $i++) { + $this->_current_line_no += substr_count($text_blocks[$i], "\n"); + $compiled_tags[] = $this->_compile_tag($template_tags[$i]); + $this->_current_line_no += substr_count($template_tags[$i], "\n"); + } + if (count($this->_tag_stack)>0) { + list($_open_tag, $_line_no) = end($this->_tag_stack); + $this->_syntax_error("unclosed tag \{$_open_tag} (opened line $_line_no).", E_USER_ERROR, __FILE__, __LINE__); + return; + } + + /* Reformat $text_blocks between 'strip' and '/strip' tags, + removing spaces, tabs and newlines. */ + $strip = false; + for ($i = 0, $for_max = count($compiled_tags); $i < $for_max; $i++) { + if ($compiled_tags[$i] == '{strip}') { + $compiled_tags[$i] = ''; + $strip = true; + /* remove leading whitespaces */ + $text_blocks[$i + 1] = ltrim($text_blocks[$i + 1]); + } + if ($strip) { + /* strip all $text_blocks before the next '/strip' */ + for ($j = $i + 1; $j < $for_max; $j++) { + /* remove leading and trailing whitespaces of each line */ + $text_blocks[$j] = preg_replace('![\t ]*[\r\n]+[\t ]*!', '', $text_blocks[$j]); + if ($compiled_tags[$j] == '{/strip}') { + /* remove trailing whitespaces from the last text_block */ + $text_blocks[$j] = rtrim($text_blocks[$j]); + } + $text_blocks[$j] = ""\'", "\\"=>"\\\\")) . "'; ?>"; + if ($compiled_tags[$j] == '{/strip}') { + $compiled_tags[$j] = "\n"; /* slurped by php, but necessary + if a newline is following the closing strip-tag */ + $strip = false; + $i = $j; + break; + } + } + } + } + $compiled_content = ''; + + $tag_guard = '%%%SMARTYOTG' . md5(uniqid(rand(), true)) . '%%%'; + + /* Interleave the compiled contents and text blocks to get the final result. */ + for ($i = 0, $for_max = count($compiled_tags); $i < $for_max; $i++) { + if ($compiled_tags[$i] == '') { + // tag result empty, remove first newline from following text block + $text_blocks[$i+1] = preg_replace('~^(\r\n|\r|\n)~', '', $text_blocks[$i+1]); + } + // replace legit PHP tags with placeholder + $text_blocks[$i] = str_replace('\n", $compiled_content); + $compiled_content = preg_replace("~(?\n", $compiled_content); + + // recover legit tags + $compiled_content = str_replace($tag_guard, '_cache_serial)) { + $compiled_content = "_cache_serials['".$this->_cache_include."'] = '".$this->_cache_serial."'; ?>" . $compiled_content; + } + + // run compiled template through postfilter functions + if (count($this->_plugins['postfilter']) > 0) { + foreach ($this->_plugins['postfilter'] as $filter_name => $postfilter) { + if ($postfilter === false) continue; + if ($postfilter[3] || is_callable($postfilter[0])) { + $compiled_content = call_user_func_array($postfilter[0], + array($compiled_content, &$this)); + $this->_plugins['postfilter'][$filter_name][3] = true; + } else { + $this->_trigger_fatal_error("Smarty plugin error: postfilter '$filter_name' is not implemented"); + } + } + } + + // put header at the top of the compiled template + $template_header = "_version.", created on ".strftime("%Y-%m-%d %H:%M:%S")."\n"; + $template_header .= " compiled from ".strtr(urlencode($resource_name), array('%2F'=>'/', '%3A'=>':'))." */ ?>\n"; + + /* Emit code to load needed plugins. */ + $this->_plugins_code = ''; + if (count($this->_plugin_info)) { + $_plugins_params = "array('plugins' => array("; + foreach ($this->_plugin_info as $plugin_type => $plugins) { + foreach ($plugins as $plugin_name => $plugin_info) { + $_plugins_params .= "array('$plugin_type', '$plugin_name', '" . strtr($plugin_info[0], array("'" => "\\'", "\\" => "\\\\")) . "', $plugin_info[1], "; + $_plugins_params .= $plugin_info[2] ? 'true),' : 'false),'; + } + } + $_plugins_params .= '))'; + $plugins_code = "\n"; + $template_header .= $plugins_code; + $this->_plugin_info = array(); + $this->_plugins_code = $plugins_code; + } + + if ($this->_init_smarty_vars) { + $template_header .= "\n"; + $this->_init_smarty_vars = false; + } + + $compiled_content = $template_header . $compiled_content; + return true; + } + + /** + * Compile a template tag + * + * @param string $template_tag + * @return string + */ + function _compile_tag($template_tag) + { + /* Matched comment. */ + if (substr($template_tag, 0, 1) == '*' && substr($template_tag, -1) == '*') + return ''; + + /* Split tag into two three parts: command, command modifiers and the arguments. */ + if(! preg_match('~^(?:(' . $this->_num_const_regexp . '|' . $this->_obj_call_regexp . '|' . $this->_var_regexp + . '|\/?' . $this->_reg_obj_regexp . '|\/?' . $this->_func_regexp . ')(' . $this->_mod_regexp . '*)) + (?:\s+(.*))?$ + ~xs', $template_tag, $match)) { + $this->_syntax_error("unrecognized tag: $template_tag", E_USER_ERROR, __FILE__, __LINE__); + } + + $tag_command = $match[1]; + $tag_modifier = isset($match[2]) ? $match[2] : null; + $tag_args = isset($match[3]) ? $match[3] : null; + + if (preg_match('~^' . $this->_num_const_regexp . '|' . $this->_obj_call_regexp . '|' . $this->_var_regexp . '$~', $tag_command)) { + /* tag name is a variable or object */ + $_return = $this->_parse_var_props($tag_command . $tag_modifier); + return "" . $this->_additional_newline; + } + + /* If the tag name is a registered object, we process it. */ + if (preg_match('~^\/?' . $this->_reg_obj_regexp . '$~', $tag_command)) { + return $this->_compile_registered_object_tag($tag_command, $this->_parse_attrs($tag_args), $tag_modifier); + } + + switch ($tag_command) { + case 'include': + return $this->_compile_include_tag($tag_args); + + case 'include_php': + return $this->_compile_include_php_tag($tag_args); + + case 'if': + $this->_push_tag('if'); + return $this->_compile_if_tag($tag_args); + + case 'else': + list($_open_tag) = end($this->_tag_stack); + if ($_open_tag != 'if' && $_open_tag != 'elseif') + $this->_syntax_error('unexpected {else}', E_USER_ERROR, __FILE__, __LINE__); + else + $this->_push_tag('else'); + return ''; + + case 'elseif': + list($_open_tag) = end($this->_tag_stack); + if ($_open_tag != 'if' && $_open_tag != 'elseif') + $this->_syntax_error('unexpected {elseif}', E_USER_ERROR, __FILE__, __LINE__); + if ($_open_tag == 'if') + $this->_push_tag('elseif'); + return $this->_compile_if_tag($tag_args, true); + + case '/if': + $this->_pop_tag('if'); + return ''; + + case 'capture': + return $this->_compile_capture_tag(true, $tag_args); + + case '/capture': + return $this->_compile_capture_tag(false); + + case 'ldelim': + return $this->left_delimiter; + + case 'rdelim': + return $this->right_delimiter; + + case 'section': + $this->_push_tag('section'); + return $this->_compile_section_start($tag_args); + + case 'sectionelse': + $this->_push_tag('sectionelse'); + return ""; + break; + + case '/section': + $_open_tag = $this->_pop_tag('section'); + if ($_open_tag == 'sectionelse') + return ""; + else + return ""; + + case 'foreach': + $this->_push_tag('foreach'); + return $this->_compile_foreach_start($tag_args); + break; + + case 'foreachelse': + $this->_push_tag('foreachelse'); + return ""; + + case '/foreach': + $_open_tag = $this->_pop_tag('foreach'); + if ($_open_tag == 'foreachelse') + return ""; + else + return ""; + break; + + case 'strip': + case '/strip': + if (substr($tag_command, 0, 1)=='/') { + $this->_pop_tag('strip'); + if (--$this->_strip_depth==0) { /* outermost closing {/strip} */ + $this->_additional_newline = "\n"; + return '{' . $tag_command . '}'; + } + } else { + $this->_push_tag('strip'); + if ($this->_strip_depth++==0) { /* outermost opening {strip} */ + $this->_additional_newline = ""; + return '{' . $tag_command . '}'; + } + } + return ''; + + case 'php': + /* handle folded tags replaced by {php} */ + list(, $block) = each($this->_folded_blocks); + $this->_current_line_no += substr_count($block[0], "\n"); + /* the number of matched elements in the regexp in _compile_file() + determins the type of folded tag that was found */ + switch (count($block)) { + case 2: /* comment */ + return ''; + + case 3: /* literal */ + return ""\'", "\\"=>"\\\\")) . "'; ?>" . $this->_additional_newline; + + case 4: /* php */ + if ($this->security && !$this->security_settings['PHP_TAGS']) { + $this->_syntax_error("(secure mode) php tags not permitted", E_USER_WARNING, __FILE__, __LINE__); + return; + } + return ''; + } + break; + + case 'insert': + return $this->_compile_insert_tag($tag_args); + + default: + if ($this->_compile_compiler_tag($tag_command, $tag_args, $output)) { + return $output; + } else if ($this->_compile_block_tag($tag_command, $tag_args, $tag_modifier, $output)) { + return $output; + } else if ($this->_compile_custom_tag($tag_command, $tag_args, $tag_modifier, $output)) { + return $output; + } else { + $this->_syntax_error("unrecognized tag '$tag_command'", E_USER_ERROR, __FILE__, __LINE__); + } + + } + } + + + /** + * compile the custom compiler tag + * + * sets $output to the compiled custom compiler tag + * @param string $tag_command + * @param string $tag_args + * @param string $output + * @return boolean + */ + function _compile_compiler_tag($tag_command, $tag_args, &$output) + { + $found = false; + $have_function = true; + + /* + * First we check if the compiler function has already been registered + * or loaded from a plugin file. + */ + if (isset($this->_plugins['compiler'][$tag_command])) { + $found = true; + $plugin_func = $this->_plugins['compiler'][$tag_command][0]; + if (!is_callable($plugin_func)) { + $message = "compiler function '$tag_command' is not implemented"; + $have_function = false; + } + } + /* + * Otherwise we need to load plugin file and look for the function + * inside it. + */ + else if ($plugin_file = $this->_get_plugin_filepath('compiler', $tag_command)) { + $found = true; + + include_once $plugin_file; + + $plugin_func = 'smarty_compiler_' . $tag_command; + if (!is_callable($plugin_func)) { + $message = "plugin function $plugin_func() not found in $plugin_file\n"; + $have_function = false; + } else { + $this->_plugins['compiler'][$tag_command] = array($plugin_func, null, null, null, true); + } + } + + /* + * True return value means that we either found a plugin or a + * dynamically registered function. False means that we didn't and the + * compiler should now emit code to load custom function plugin for this + * tag. + */ + if ($found) { + if ($have_function) { + $output = call_user_func_array($plugin_func, array($tag_args, &$this)); + if($output != '') { + $output = '_push_cacheable_state('compiler', $tag_command) + . $output + . $this->_pop_cacheable_state('compiler', $tag_command) . ' ?>'; + } + } else { + $this->_syntax_error($message, E_USER_WARNING, __FILE__, __LINE__); + } + return true; + } else { + return false; + } + } + + + /** + * compile block function tag + * + * sets $output to compiled block function tag + * @param string $tag_command + * @param string $tag_args + * @param string $tag_modifier + * @param string $output + * @return boolean + */ + function _compile_block_tag($tag_command, $tag_args, $tag_modifier, &$output) + { + if (substr($tag_command, 0, 1) == '/') { + $start_tag = false; + $tag_command = substr($tag_command, 1); + } else + $start_tag = true; + + $found = false; + $have_function = true; + + /* + * First we check if the block function has already been registered + * or loaded from a plugin file. + */ + if (isset($this->_plugins['block'][$tag_command])) { + $found = true; + $plugin_func = $this->_plugins['block'][$tag_command][0]; + if (!is_callable($plugin_func)) { + $message = "block function '$tag_command' is not implemented"; + $have_function = false; + } + } + /* + * Otherwise we need to load plugin file and look for the function + * inside it. + */ + else if ($plugin_file = $this->_get_plugin_filepath('block', $tag_command)) { + $found = true; + + include_once $plugin_file; + + $plugin_func = 'smarty_block_' . $tag_command; + if (!function_exists($plugin_func)) { + $message = "plugin function $plugin_func() not found in $plugin_file\n"; + $have_function = false; + } else { + $this->_plugins['block'][$tag_command] = array($plugin_func, null, null, null, true); + + } + } + + if (!$found) { + return false; + } else if (!$have_function) { + $this->_syntax_error($message, E_USER_WARNING, __FILE__, __LINE__); + return true; + } + + /* + * Even though we've located the plugin function, compilation + * happens only once, so the plugin will still need to be loaded + * at runtime for future requests. + */ + $this->_add_plugin('block', $tag_command); + + if ($start_tag) + $this->_push_tag($tag_command); + else + $this->_pop_tag($tag_command); + + if ($start_tag) { + $output = '_push_cacheable_state('block', $tag_command); + $attrs = $this->_parse_attrs($tag_args); + $_cache_attrs=''; + $arg_list = $this->_compile_arg_list('block', $tag_command, $attrs, $_cache_attrs); + $output .= "$_cache_attrs\$this->_tag_stack[] = array('$tag_command', array(".implode(',', $arg_list).')); '; + $output .= '$_block_repeat=true;' . $this->_compile_plugin_call('block', $tag_command).'($this->_tag_stack[count($this->_tag_stack)-1][1], null, $this, $_block_repeat);'; + $output .= 'while ($_block_repeat) { ob_start(); ?>'; + } else { + $output = '_compile_plugin_call('block', $tag_command).'($this->_tag_stack[count($this->_tag_stack)-1][1], $_block_content, $this, $_block_repeat)'; + if ($tag_modifier != '') { + $this->_parse_modifiers($_out_tag_text, $tag_modifier); + } + $output .= '$_block_repeat=false;echo ' . $_out_tag_text . '; } '; + $output .= " array_pop(\$this->_tag_stack); " . $this->_pop_cacheable_state('block', $tag_command) . '?>'; + } + + return true; + } + + + /** + * compile custom function tag + * + * @param string $tag_command + * @param string $tag_args + * @param string $tag_modifier + * @return string + */ + function _compile_custom_tag($tag_command, $tag_args, $tag_modifier, &$output) + { + $found = false; + $have_function = true; + + /* + * First we check if the custom function has already been registered + * or loaded from a plugin file. + */ + if (isset($this->_plugins['function'][$tag_command])) { + $found = true; + $plugin_func = $this->_plugins['function'][$tag_command][0]; + if (!is_callable($plugin_func)) { + $message = "custom function '$tag_command' is not implemented"; + $have_function = false; + } + } + /* + * Otherwise we need to load plugin file and look for the function + * inside it. + */ + else if ($plugin_file = $this->_get_plugin_filepath('function', $tag_command)) { + $found = true; + + include_once $plugin_file; + + $plugin_func = 'smarty_function_' . $tag_command; + if (!function_exists($plugin_func)) { + $message = "plugin function $plugin_func() not found in $plugin_file\n"; + $have_function = false; + } else { + $this->_plugins['function'][$tag_command] = array($plugin_func, null, null, null, true); + + } + } + + if (!$found) { + return false; + } else if (!$have_function) { + $this->_syntax_error($message, E_USER_WARNING, __FILE__, __LINE__); + return true; + } + + /* declare plugin to be loaded on display of the template that + we compile right now */ + $this->_add_plugin('function', $tag_command); + + $_cacheable_state = $this->_push_cacheable_state('function', $tag_command); + $attrs = $this->_parse_attrs($tag_args); + $_cache_attrs = ''; + $arg_list = $this->_compile_arg_list('function', $tag_command, $attrs, $_cache_attrs); + + $output = $this->_compile_plugin_call('function', $tag_command).'(array('.implode(',', $arg_list)."), \$this)"; + if($tag_modifier != '') { + $this->_parse_modifiers($output, $tag_modifier); + } + + if($output != '') { + $output = '_pop_cacheable_state('function', $tag_command) . "?>" . $this->_additional_newline; + } + + return true; + } + + /** + * compile a registered object tag + * + * @param string $tag_command + * @param array $attrs + * @param string $tag_modifier + * @return string + */ + function _compile_registered_object_tag($tag_command, $attrs, $tag_modifier) + { + if (substr($tag_command, 0, 1) == '/') { + $start_tag = false; + $tag_command = substr($tag_command, 1); + } else { + $start_tag = true; + } + + list($object, $obj_comp) = explode('->', $tag_command); + + $arg_list = array(); + if(count($attrs)) { + $_assign_var = false; + foreach ($attrs as $arg_name => $arg_value) { + if($arg_name == 'assign') { + $_assign_var = $arg_value; + unset($attrs['assign']); + continue; + } + if (is_bool($arg_value)) + $arg_value = $arg_value ? 'true' : 'false'; + $arg_list[] = "'$arg_name' => $arg_value"; + } + } + + if($this->_reg_objects[$object][2]) { + // smarty object argument format + $args = "array(".implode(',', (array)$arg_list)."), \$this"; + } else { + // traditional argument format + $args = implode(',', array_values($attrs)); + if (empty($args)) { + $args = ''; + } + } + + $prefix = ''; + $postfix = ''; + $newline = ''; + if(!is_object($this->_reg_objects[$object][0])) { + $this->_trigger_fatal_error("registered '$object' is not an object" , $this->_current_file, $this->_current_line_no, __FILE__, __LINE__); + } elseif(!empty($this->_reg_objects[$object][1]) && !in_array($obj_comp, $this->_reg_objects[$object][1])) { + $this->_trigger_fatal_error("'$obj_comp' is not a registered component of object '$object'", $this->_current_file, $this->_current_line_no, __FILE__, __LINE__); + } elseif(method_exists($this->_reg_objects[$object][0], $obj_comp)) { + // method + if(in_array($obj_comp, $this->_reg_objects[$object][3])) { + // block method + if ($start_tag) { + $prefix = "\$this->_tag_stack[] = array('$obj_comp', $args); "; + $prefix .= "\$_block_repeat=true; \$this->_reg_objects['$object'][0]->$obj_comp(\$this->_tag_stack[count(\$this->_tag_stack)-1][1], null, \$this, \$_block_repeat); "; + $prefix .= "while (\$_block_repeat) { ob_start();"; + $return = null; + $postfix = ''; + } else { + $prefix = "\$_obj_block_content = ob_get_contents(); ob_end_clean(); \$_block_repeat=false;"; + $return = "\$this->_reg_objects['$object'][0]->$obj_comp(\$this->_tag_stack[count(\$this->_tag_stack)-1][1], \$_obj_block_content, \$this, \$_block_repeat)"; + $postfix = "} array_pop(\$this->_tag_stack);"; + } + } else { + // non-block method + $return = "\$this->_reg_objects['$object'][0]->$obj_comp($args)"; + } + } else { + // property + $return = "\$this->_reg_objects['$object'][0]->$obj_comp"; + } + + if($return != null) { + if($tag_modifier != '') { + $this->_parse_modifiers($return, $tag_modifier); + } + + if(!empty($_assign_var)) { + $output = "\$this->assign('" . $this->_dequote($_assign_var) ."', $return);"; + } else { + $output = 'echo ' . $return . ';'; + $newline = $this->_additional_newline; + } + } else { + $output = ''; + } + + return '" . $newline; + } + + /** + * Compile {insert ...} tag + * + * @param string $tag_args + * @return string + */ + function _compile_insert_tag($tag_args) + { + $attrs = $this->_parse_attrs($tag_args); + $name = $this->_dequote($attrs['name']); + + if (empty($name)) { + return $this->_syntax_error("missing insert name", E_USER_ERROR, __FILE__, __LINE__); + } + + if (!preg_match('~^\w+$~', $name)) { + return $this->_syntax_error("'insert: 'name' must be an insert function name", E_USER_ERROR, __FILE__, __LINE__); + } + + if (!empty($attrs['script'])) { + $delayed_loading = true; + } else { + $delayed_loading = false; + } + + foreach ($attrs as $arg_name => $arg_value) { + if (is_bool($arg_value)) + $arg_value = $arg_value ? 'true' : 'false'; + $arg_list[] = "'$arg_name' => $arg_value"; + } + + $this->_add_plugin('insert', $name, $delayed_loading); + + $_params = "array('args' => array(".implode(', ', (array)$arg_list)."))"; + + return "" . $this->_additional_newline; + } + + /** + * Compile {include ...} tag + * + * @param string $tag_args + * @return string + */ + function _compile_include_tag($tag_args) + { + $attrs = $this->_parse_attrs($tag_args); + $arg_list = array(); + + if (empty($attrs['file'])) { + $this->_syntax_error("missing 'file' attribute in include tag", E_USER_ERROR, __FILE__, __LINE__); + } + + foreach ($attrs as $arg_name => $arg_value) { + if ($arg_name == 'file') { + $include_file = $arg_value; + continue; + } else if ($arg_name == 'assign') { + $assign_var = $arg_value; + continue; + } + if (is_bool($arg_value)) + $arg_value = $arg_value ? 'true' : 'false'; + $arg_list[] = "'$arg_name' => $arg_value"; + } + + $output = '_tpl_vars;\n"; + + + $_params = "array('smarty_include_tpl_file' => " . $include_file . ", 'smarty_include_vars' => array(".implode(',', (array)$arg_list)."))"; + $output .= "\$this->_smarty_include($_params);\n" . + "\$this->_tpl_vars = \$_smarty_tpl_vars;\n" . + "unset(\$_smarty_tpl_vars);\n"; + + if (isset($assign_var)) { + $output .= "\$this->assign(" . $assign_var . ", ob_get_contents()); ob_end_clean();\n"; + } + + $output .= ' ?>'; + + return $output; + + } + + /** + * Compile {include ...} tag + * + * @param string $tag_args + * @return string + */ + function _compile_include_php_tag($tag_args) + { + $attrs = $this->_parse_attrs($tag_args); + + if (empty($attrs['file'])) { + $this->_syntax_error("missing 'file' attribute in include_php tag", E_USER_ERROR, __FILE__, __LINE__); + } + + $assign_var = (empty($attrs['assign'])) ? '' : $this->_dequote($attrs['assign']); + $once_var = (empty($attrs['once']) || $attrs['once']=='false') ? 'false' : 'true'; + + $arg_list = array(); + foreach($attrs as $arg_name => $arg_value) { + if($arg_name != 'file' AND $arg_name != 'once' AND $arg_name != 'assign') { + if(is_bool($arg_value)) + $arg_value = $arg_value ? 'true' : 'false'; + $arg_list[] = "'$arg_name' => $arg_value"; + } + } + + $_params = "array('smarty_file' => " . $attrs['file'] . ", 'smarty_assign' => '$assign_var', 'smarty_once' => $once_var, 'smarty_include_vars' => array(".implode(',', $arg_list)."))"; + + return "" . $this->_additional_newline; + } + + + /** + * Compile {section ...} tag + * + * @param string $tag_args + * @return string + */ + function _compile_section_start($tag_args) + { + $attrs = $this->_parse_attrs($tag_args); + $arg_list = array(); + + $output = '_syntax_error("missing section name", E_USER_ERROR, __FILE__, __LINE__); + } + + $output .= "unset(\$this->_sections[$section_name]);\n"; + $section_props = "\$this->_sections[$section_name]"; + + foreach ($attrs as $attr_name => $attr_value) { + switch ($attr_name) { + case 'loop': + $output .= "{$section_props}['loop'] = is_array(\$_loop=$attr_value) ? count(\$_loop) : max(0, (int)\$_loop); unset(\$_loop);\n"; + break; + + case 'show': + if (is_bool($attr_value)) + $show_attr_value = $attr_value ? 'true' : 'false'; + else + $show_attr_value = "(bool)$attr_value"; + $output .= "{$section_props}['show'] = $show_attr_value;\n"; + break; + + case 'name': + $output .= "{$section_props}['$attr_name'] = $attr_value;\n"; + break; + + case 'max': + case 'start': + $output .= "{$section_props}['$attr_name'] = (int)$attr_value;\n"; + break; + + case 'step': + $output .= "{$section_props}['$attr_name'] = ((int)$attr_value) == 0 ? 1 : (int)$attr_value;\n"; + break; + + default: + $this->_syntax_error("unknown section attribute - '$attr_name'", E_USER_ERROR, __FILE__, __LINE__); + break; + } + } + + if (!isset($attrs['show'])) + $output .= "{$section_props}['show'] = true;\n"; + + if (!isset($attrs['loop'])) + $output .= "{$section_props}['loop'] = 1;\n"; + + if (!isset($attrs['max'])) + $output .= "{$section_props}['max'] = {$section_props}['loop'];\n"; + else + $output .= "if ({$section_props}['max'] < 0)\n" . + " {$section_props}['max'] = {$section_props}['loop'];\n"; + + if (!isset($attrs['step'])) + $output .= "{$section_props}['step'] = 1;\n"; + + if (!isset($attrs['start'])) + $output .= "{$section_props}['start'] = {$section_props}['step'] > 0 ? 0 : {$section_props}['loop']-1;\n"; + else { + $output .= "if ({$section_props}['start'] < 0)\n" . + " {$section_props}['start'] = max({$section_props}['step'] > 0 ? 0 : -1, {$section_props}['loop'] + {$section_props}['start']);\n" . + "else\n" . + " {$section_props}['start'] = min({$section_props}['start'], {$section_props}['step'] > 0 ? {$section_props}['loop'] : {$section_props}['loop']-1);\n"; + } + + $output .= "if ({$section_props}['show']) {\n"; + if (!isset($attrs['start']) && !isset($attrs['step']) && !isset($attrs['max'])) { + $output .= " {$section_props}['total'] = {$section_props}['loop'];\n"; + } else { + $output .= " {$section_props}['total'] = min(ceil(({$section_props}['step'] > 0 ? {$section_props}['loop'] - {$section_props}['start'] : {$section_props}['start']+1)/abs({$section_props}['step'])), {$section_props}['max']);\n"; + } + $output .= " if ({$section_props}['total'] == 0)\n" . + " {$section_props}['show'] = false;\n" . + "} else\n" . + " {$section_props}['total'] = 0;\n"; + + $output .= "if ({$section_props}['show']):\n"; + $output .= " + for ({$section_props}['index'] = {$section_props}['start'], {$section_props}['iteration'] = 1; + {$section_props}['iteration'] <= {$section_props}['total']; + {$section_props}['index'] += {$section_props}['step'], {$section_props}['iteration']++):\n"; + $output .= "{$section_props}['rownum'] = {$section_props}['iteration'];\n"; + $output .= "{$section_props}['index_prev'] = {$section_props}['index'] - {$section_props}['step'];\n"; + $output .= "{$section_props}['index_next'] = {$section_props}['index'] + {$section_props}['step'];\n"; + $output .= "{$section_props}['first'] = ({$section_props}['iteration'] == 1);\n"; + $output .= "{$section_props}['last'] = ({$section_props}['iteration'] == {$section_props}['total']);\n"; + + $output .= "?>"; + + return $output; + } + + + /** + * Compile {foreach ...} tag. + * + * @param string $tag_args + * @return string + */ + function _compile_foreach_start($tag_args) + { + $attrs = $this->_parse_attrs($tag_args); + $arg_list = array(); + + if (empty($attrs['from'])) { + return $this->_syntax_error("foreach: missing 'from' attribute", E_USER_ERROR, __FILE__, __LINE__); + } + $from = $attrs['from']; + + if (empty($attrs['item'])) { + return $this->_syntax_error("foreach: missing 'item' attribute", E_USER_ERROR, __FILE__, __LINE__); + } + $item = $this->_dequote($attrs['item']); + if (!preg_match('~^\w+$~', $item)) { + return $this->_syntax_error("foreach: 'item' must be a variable name (literal string)", E_USER_ERROR, __FILE__, __LINE__); + } + + if (isset($attrs['key'])) { + $key = $this->_dequote($attrs['key']); + if (!preg_match('~^\w+$~', $key)) { + return $this->_syntax_error("foreach: 'key' must to be a variable name (literal string)", E_USER_ERROR, __FILE__, __LINE__); + } + $key_part = "\$this->_tpl_vars['$key'] => "; + } else { + $key = null; + $key_part = ''; + } + + if (isset($attrs['name'])) { + $name = $attrs['name']; + } else { + $name = null; + } + + $output = '_foreach[$name]"; + $output .= "{$foreach_props} = array('total' => count(\$_from), 'iteration' => 0);\n"; + $output .= "if ({$foreach_props}['total'] > 0):\n"; + $output .= " foreach (\$_from as $key_part\$this->_tpl_vars['$item']):\n"; + $output .= " {$foreach_props}['iteration']++;\n"; + } else { + $output .= "if (count(\$_from)):\n"; + $output .= " foreach (\$_from as $key_part\$this->_tpl_vars['$item']):\n"; + } + $output .= '?>'; + + return $output; + } + + + /** + * Compile {capture} .. {/capture} tags + * + * @param boolean $start true if this is the {capture} tag + * @param string $tag_args + * @return string + */ + + function _compile_capture_tag($start, $tag_args = '') + { + $attrs = $this->_parse_attrs($tag_args); + + if ($start) { + $buffer = isset($attrs['name']) ? $attrs['name'] : "'default'"; + $assign = isset($attrs['assign']) ? $attrs['assign'] : null; + $append = isset($attrs['append']) ? $attrs['append'] : null; + + $output = ""; + $this->_capture_stack[] = array($buffer, $assign, $append); + } else { + list($buffer, $assign, $append) = array_pop($this->_capture_stack); + $output = "_smarty_vars['capture'][$buffer] = ob_get_contents(); "; + if (isset($assign)) { + $output .= " \$this->assign($assign, ob_get_contents());"; + } + if (isset($append)) { + $output .= " \$this->append($append, ob_get_contents());"; + } + $output .= "ob_end_clean(); ?>"; + } + + return $output; + } + + /** + * Compile {if ...} tag + * + * @param string $tag_args + * @param boolean $elseif if true, uses elseif instead of if + * @return string + */ + function _compile_if_tag($tag_args, $elseif = false) + { + + /* Tokenize args for 'if' tag. */ + preg_match_all('~(?> + ' . $this->_obj_call_regexp . '(?:' . $this->_mod_regexp . '*)? | # valid object call + ' . $this->_var_regexp . '(?:' . $this->_mod_regexp . '*)? | # var or quoted string + \-?0[xX][0-9a-fA-F]+|\-?\d+(?:\.\d+)?|\.\d+|!==|===|==|!=|<>|<<|>>|<=|>=|\&\&|\|\||\(|\)|,|\!|\^|=|\&|\~|<|>|\||\%|\+|\-|\/|\*|\@ | # valid non-word token + \b\w+\b | # valid word token + \S+ # anything else + )~x', $tag_args, $match); + + $tokens = $match[0]; + + if(empty($tokens)) { + $_error_msg = $elseif ? "'elseif'" : "'if'"; + $_error_msg .= ' statement requires arguments'; + $this->_syntax_error($_error_msg, E_USER_ERROR, __FILE__, __LINE__); + } + + + // make sure we have balanced parenthesis + $token_count = array_count_values($tokens); + if(isset($token_count['(']) && $token_count['('] != $token_count[')']) { + $this->_syntax_error("unbalanced parenthesis in if statement", E_USER_ERROR, __FILE__, __LINE__); + } + + $is_arg_stack = array(); + + for ($i = 0; $i < count($tokens); $i++) { + + $token = &$tokens[$i]; + + switch (strtolower($token)) { + case '!': + case '%': + case '!==': + case '==': + case '===': + case '>': + case '<': + case '!=': + case '<>': + case '<<': + case '>>': + case '<=': + case '>=': + case '&&': + case '||': + case '|': + case '^': + case '&': + case '~': + case ')': + case ',': + case '+': + case '-': + case '*': + case '/': + case '@': + break; + + case 'eq': + $token = '=='; + break; + + case 'ne': + case 'neq': + $token = '!='; + break; + + case 'lt': + $token = '<'; + break; + + case 'le': + case 'lte': + $token = '<='; + break; + + case 'gt': + $token = '>'; + break; + + case 'ge': + case 'gte': + $token = '>='; + break; + + case 'and': + $token = '&&'; + break; + + case 'or': + $token = '||'; + break; + + case 'not': + $token = '!'; + break; + + case 'mod': + $token = '%'; + break; + + case '(': + array_push($is_arg_stack, $i); + break; + + case 'is': + /* If last token was a ')', we operate on the parenthesized + expression. The start of the expression is on the stack. + Otherwise, we operate on the last encountered token. */ + if ($tokens[$i-1] == ')') + $is_arg_start = array_pop($is_arg_stack); + else + $is_arg_start = $i-1; + /* Construct the argument for 'is' expression, so it knows + what to operate on. */ + $is_arg = implode(' ', array_slice($tokens, $is_arg_start, $i - $is_arg_start)); + + /* Pass all tokens from next one until the end to the + 'is' expression parsing function. The function will + return modified tokens, where the first one is the result + of the 'is' expression and the rest are the tokens it + didn't touch. */ + $new_tokens = $this->_parse_is_expr($is_arg, array_slice($tokens, $i+1)); + + /* Replace the old tokens with the new ones. */ + array_splice($tokens, $is_arg_start, count($tokens), $new_tokens); + + /* Adjust argument start so that it won't change from the + current position for the next iteration. */ + $i = $is_arg_start; + break; + + default: + if(preg_match('~^' . $this->_func_regexp . '$~', $token) ) { + // function call + if($this->security && + !in_array($token, $this->security_settings['IF_FUNCS'])) { + $this->_syntax_error("(secure mode) '$token' not allowed in if statement", E_USER_ERROR, __FILE__, __LINE__); + } + } elseif(preg_match('~^' . $this->_var_regexp . '$~', $token) && (strpos('+-*/^%&|', substr($token, -1)) === false) && isset($tokens[$i+1]) && $tokens[$i+1] == '(') { + // variable function call + $this->_syntax_error("variable function call '$token' not allowed in if statement", E_USER_ERROR, __FILE__, __LINE__); + } elseif(preg_match('~^' . $this->_obj_call_regexp . '|' . $this->_var_regexp . '(?:' . $this->_mod_regexp . '*)$~', $token)) { + // object or variable + $token = $this->_parse_var_props($token); + } elseif(is_numeric($token)) { + // number, skip it + } else { + $this->_syntax_error("unidentified token '$token'", E_USER_ERROR, __FILE__, __LINE__); + } + break; + } + } + + if ($elseif) + return ''; + else + return ''; + } + + + function _compile_arg_list($type, $name, $attrs, &$cache_code) { + $arg_list = array(); + + if (isset($type) && isset($name) + && isset($this->_plugins[$type]) + && isset($this->_plugins[$type][$name]) + && empty($this->_plugins[$type][$name][4]) + && is_array($this->_plugins[$type][$name][5]) + ) { + /* we have a list of parameters that should be cached */ + $_cache_attrs = $this->_plugins[$type][$name][5]; + $_count = $this->_cache_attrs_count++; + $cache_code = "\$_cache_attrs =& \$this->_smarty_cache_attrs('$this->_cache_serial','$_count');"; + + } else { + /* no parameters are cached */ + $_cache_attrs = null; + } + + foreach ($attrs as $arg_name => $arg_value) { + if (is_bool($arg_value)) + $arg_value = $arg_value ? 'true' : 'false'; + if (is_null($arg_value)) + $arg_value = 'null'; + if ($_cache_attrs && in_array($arg_name, $_cache_attrs)) { + $arg_list[] = "'$arg_name' => (\$this->_cache_including) ? \$_cache_attrs['$arg_name'] : (\$_cache_attrs['$arg_name']=$arg_value)"; + } else { + $arg_list[] = "'$arg_name' => $arg_value"; + } + } + return $arg_list; + } + + /** + * Parse is expression + * + * @param string $is_arg + * @param array $tokens + * @return array + */ + function _parse_is_expr($is_arg, $tokens) + { + $expr_end = 0; + $negate_expr = false; + + if (($first_token = array_shift($tokens)) == 'not') { + $negate_expr = true; + $expr_type = array_shift($tokens); + } else + $expr_type = $first_token; + + switch ($expr_type) { + case 'even': + if (isset($tokens[$expr_end]) && $tokens[$expr_end] == 'by') { + $expr_end++; + $expr_arg = $tokens[$expr_end++]; + $expr = "!(1 & ($is_arg / " . $this->_parse_var_props($expr_arg) . "))"; + } else + $expr = "!(1 & $is_arg)"; + break; + + case 'odd': + if (isset($tokens[$expr_end]) && $tokens[$expr_end] == 'by') { + $expr_end++; + $expr_arg = $tokens[$expr_end++]; + $expr = "(1 & ($is_arg / " . $this->_parse_var_props($expr_arg) . "))"; + } else + $expr = "(1 & $is_arg)"; + break; + + case 'div': + if (@$tokens[$expr_end] == 'by') { + $expr_end++; + $expr_arg = $tokens[$expr_end++]; + $expr = "!($is_arg % " . $this->_parse_var_props($expr_arg) . ")"; + } else { + $this->_syntax_error("expecting 'by' after 'div'", E_USER_ERROR, __FILE__, __LINE__); + } + break; + + default: + $this->_syntax_error("unknown 'is' expression - '$expr_type'", E_USER_ERROR, __FILE__, __LINE__); + break; + } + + if ($negate_expr) { + $expr = "!($expr)"; + } + + array_splice($tokens, 0, $expr_end, $expr); + + return $tokens; + } + + + /** + * Parse attribute string + * + * @param string $tag_args + * @return array + */ + function _parse_attrs($tag_args) + { + + /* Tokenize tag attributes. */ + preg_match_all('~(?:' . $this->_obj_call_regexp . '|' . $this->_qstr_regexp . ' | (?>[^"\'=\s]+) + )+ | + [=] + ~x', $tag_args, $match); + $tokens = $match[0]; + + $attrs = array(); + /* Parse state: + 0 - expecting attribute name + 1 - expecting '=' + 2 - expecting attribute value (not '=') */ + $state = 0; + + foreach ($tokens as $token) { + switch ($state) { + case 0: + /* If the token is a valid identifier, we set attribute name + and go to state 1. */ + if (preg_match('~^\w+$~', $token)) { + $attr_name = $token; + $state = 1; + } else + $this->_syntax_error("invalid attribute name: '$token'", E_USER_ERROR, __FILE__, __LINE__); + break; + + case 1: + /* If the token is '=', then we go to state 2. */ + if ($token == '=') { + $state = 2; + } else + $this->_syntax_error("expecting '=' after attribute name '$last_token'", E_USER_ERROR, __FILE__, __LINE__); + break; + + case 2: + /* If token is not '=', we set the attribute value and go to + state 0. */ + if ($token != '=') { + /* We booleanize the token if it's a non-quoted possible + boolean value. */ + if (preg_match('~^(on|yes|true)$~', $token)) { + $token = 'true'; + } else if (preg_match('~^(off|no|false)$~', $token)) { + $token = 'false'; + } else if ($token == 'null') { + $token = 'null'; + } else if (preg_match('~^' . $this->_num_const_regexp . '|0[xX][0-9a-fA-F]+$~', $token)) { + /* treat integer literally */ + } else if (!preg_match('~^' . $this->_obj_call_regexp . '|' . $this->_var_regexp . '(?:' . $this->_mod_regexp . ')*$~', $token)) { + /* treat as a string, double-quote it escaping quotes */ + $token = '"'.addslashes($token).'"'; + } + + $attrs[$attr_name] = $token; + $state = 0; + } else + $this->_syntax_error("'=' cannot be an attribute value", E_USER_ERROR, __FILE__, __LINE__); + break; + } + $last_token = $token; + } + + if($state != 0) { + if($state == 1) { + $this->_syntax_error("expecting '=' after attribute name '$last_token'", E_USER_ERROR, __FILE__, __LINE__); + } else { + $this->_syntax_error("missing attribute value", E_USER_ERROR, __FILE__, __LINE__); + } + } + + $this->_parse_vars_props($attrs); + + return $attrs; + } + + /** + * compile multiple variables and section properties tokens into + * PHP code + * + * @param array $tokens + */ + function _parse_vars_props(&$tokens) + { + foreach($tokens as $key => $val) { + $tokens[$key] = $this->_parse_var_props($val); + } + } + + /** + * compile single variable and section properties token into + * PHP code + * + * @param string $val + * @param string $tag_attrs + * @return string + */ + function _parse_var_props($val) + { + $val = trim($val); + + if(preg_match('~^(' . $this->_obj_call_regexp . '|' . $this->_dvar_regexp . ')(' . $this->_mod_regexp . '*)$~', $val, $match)) { + // $ variable or object + $return = $this->_parse_var($match[1]); + $modifiers = $match[2]; + if (!empty($this->default_modifiers) && !preg_match('~(^|\|)smarty:nodefaults($|\|)~',$modifiers)) { + $_default_mod_string = implode('|',(array)$this->default_modifiers); + $modifiers = empty($modifiers) ? $_default_mod_string : $_default_mod_string . '|' . $modifiers; + } + $this->_parse_modifiers($return, $modifiers); + return $return; + } elseif (preg_match('~^' . $this->_db_qstr_regexp . '(?:' . $this->_mod_regexp . '*)$~', $val)) { + // double quoted text + preg_match('~^(' . $this->_db_qstr_regexp . ')('. $this->_mod_regexp . '*)$~', $val, $match); + $return = $this->_expand_quoted_text($match[1]); + if($match[2] != '') { + $this->_parse_modifiers($return, $match[2]); + } + return $return; + } + elseif(preg_match('~^' . $this->_num_const_regexp . '(?:' . $this->_mod_regexp . '*)$~', $val)) { + // numerical constant + preg_match('~^(' . $this->_num_const_regexp . ')('. $this->_mod_regexp . '*)$~', $val, $match); + if($match[2] != '') { + $this->_parse_modifiers($match[1], $match[2]); + return $match[1]; + } + } + elseif(preg_match('~^' . $this->_si_qstr_regexp . '(?:' . $this->_mod_regexp . '*)$~', $val)) { + // single quoted text + preg_match('~^(' . $this->_si_qstr_regexp . ')('. $this->_mod_regexp . '*)$~', $val, $match); + if($match[2] != '') { + $this->_parse_modifiers($match[1], $match[2]); + return $match[1]; + } + } + elseif(preg_match('~^' . $this->_cvar_regexp . '(?:' . $this->_mod_regexp . '*)$~', $val)) { + // config var + return $this->_parse_conf_var($val); + } + elseif(preg_match('~^' . $this->_svar_regexp . '(?:' . $this->_mod_regexp . '*)$~', $val)) { + // section var + return $this->_parse_section_prop($val); + } + elseif(!in_array($val, $this->_permitted_tokens) && !is_numeric($val)) { + // literal string + return $this->_expand_quoted_text('"' . strtr($val, array('\\' => '\\\\', '"' => '\\"')) .'"'); + } + return $val; + } + + /** + * expand quoted text with embedded variables + * + * @param string $var_expr + * @return string + */ + function _expand_quoted_text($var_expr) + { + // if contains unescaped $, expand it + if(preg_match_all('~(?:\`(?_dvar_guts_regexp . '(?:' . $this->_obj_ext_regexp . ')*\`)|(?:(?_parse_var(str_replace('`','',$_var)) . ')."'; + } + $var_expr = strtr($var_expr, $_replace); + $_return = preg_replace('~\.""|(?_dvar_math_regexp.'|'.$this->_qstr_regexp.')~', $var_expr, -1, PREG_SPLIT_DELIM_CAPTURE); + + if(count($_math_vars) > 1) { + $_first_var = ""; + $_complete_var = ""; + $_output = ""; + // simple check if there is any math, to stop recursion (due to modifiers with "xx % yy" as parameter) + foreach($_math_vars as $_k => $_math_var) { + $_math_var = $_math_vars[$_k]; + + if(!empty($_math_var) || is_numeric($_math_var)) { + // hit a math operator, so process the stuff which came before it + if(preg_match('~^' . $this->_dvar_math_regexp . '$~', $_math_var)) { + $_has_math = true; + if(!empty($_complete_var) || is_numeric($_complete_var)) { + $_output .= $this->_parse_var($_complete_var); + } + + // just output the math operator to php + $_output .= $_math_var; + + if(empty($_first_var)) + $_first_var = $_complete_var; + + $_complete_var = ""; + } else { + $_complete_var .= $_math_var; + } + } + } + if($_has_math) { + if(!empty($_complete_var) || is_numeric($_complete_var)) + $_output .= $this->_parse_var($_complete_var); + + // get the modifiers working (only the last var from math + modifier is left) + $var_expr = $_complete_var; + } + } + + // prevent cutting of first digit in the number (we _definitly_ got a number if the first char is a digit) + if(is_numeric(substr($var_expr, 0, 1))) + $_var_ref = $var_expr; + else + $_var_ref = substr($var_expr, 1); + + if(!$_has_math) { + + // get [foo] and .foo and ->foo and (...) pieces + preg_match_all('~(?:^\w+)|' . $this->_obj_params_regexp . '|(?:' . $this->_var_bracket_regexp . ')|->\$?\w+|\.\$?\w+|\S+~', $_var_ref, $match); + + $_indexes = $match[0]; + $_var_name = array_shift($_indexes); + + /* Handle $smarty.* variable references as a special case. */ + if ($_var_name == 'smarty') { + /* + * If the reference could be compiled, use the compiled output; + * otherwise, fall back on the $smarty variable generated at + * run-time. + */ + if (($smarty_ref = $this->_compile_smarty_ref($_indexes)) !== null) { + $_output = $smarty_ref; + } else { + $_var_name = substr(array_shift($_indexes), 1); + $_output = "\$this->_smarty_vars['$_var_name']"; + } + } elseif(is_numeric($_var_name) && is_numeric(substr($var_expr, 0, 1))) { + // because . is the operator for accessing arrays thru inidizes we need to put it together again for floating point numbers + if(count($_indexes) > 0) + { + $_var_name .= implode("", $_indexes); + $_indexes = array(); + } + $_output = $_var_name; + } else { + $_output = "\$this->_tpl_vars['$_var_name']"; + } + + foreach ($_indexes as $_index) { + if (substr($_index, 0, 1) == '[') { + $_index = substr($_index, 1, -1); + if (is_numeric($_index)) { + $_output .= "[$_index]"; + } elseif (substr($_index, 0, 1) == '$') { + if (strpos($_index, '.') !== false) { + $_output .= '[' . $this->_parse_var($_index) . ']'; + } else { + $_output .= "[\$this->_tpl_vars['" . substr($_index, 1) . "']]"; + } + } else { + $_var_parts = explode('.', $_index); + $_var_section = $_var_parts[0]; + $_var_section_prop = isset($_var_parts[1]) ? $_var_parts[1] : 'index'; + $_output .= "[\$this->_sections['$_var_section']['$_var_section_prop']]"; + } + } else if (substr($_index, 0, 1) == '.') { + if (substr($_index, 1, 1) == '$') + $_output .= "[\$this->_tpl_vars['" . substr($_index, 2) . "']]"; + else + $_output .= "['" . substr($_index, 1) . "']"; + } else if (substr($_index,0,2) == '->') { + if(substr($_index,2,2) == '__') { + $this->_syntax_error('call to internal object members is not allowed', E_USER_ERROR, __FILE__, __LINE__); + } elseif($this->security && substr($_index, 2, 1) == '_') { + $this->_syntax_error('(secure) call to private object member is not allowed', E_USER_ERROR, __FILE__, __LINE__); + } elseif (substr($_index, 2, 1) == '$') { + if ($this->security) { + $this->_syntax_error('(secure) call to dynamic object member is not allowed', E_USER_ERROR, __FILE__, __LINE__); + } else { + $_output .= '->{(($_var=$this->_tpl_vars[\''.substr($_index,3).'\']) && substr($_var,0,2)!=\'__\') ? $_var : $this->trigger_error("cannot access property \\"$_var\\"")}'; + } + } else { + $_output .= $_index; + } + } elseif (substr($_index, 0, 1) == '(') { + $_index = $this->_parse_parenth_args($_index); + $_output .= $_index; + } else { + $_output .= $_index; + } + } + } + + return $_output; + } + + /** + * parse arguments in function call parenthesis + * + * @param string $parenth_args + * @return string + */ + function _parse_parenth_args($parenth_args) + { + preg_match_all('~' . $this->_param_regexp . '~',$parenth_args, $match); + $orig_vals = $match = $match[0]; + $this->_parse_vars_props($match); + $replace = array(); + for ($i = 0, $count = count($match); $i < $count; $i++) { + $replace[$orig_vals[$i]] = $match[$i]; + } + return strtr($parenth_args, $replace); + } + + /** + * parse configuration variable expression into PHP code + * + * @param string $conf_var_expr + */ + function _parse_conf_var($conf_var_expr) + { + $parts = explode('|', $conf_var_expr, 2); + $var_ref = $parts[0]; + $modifiers = isset($parts[1]) ? $parts[1] : ''; + + $var_name = substr($var_ref, 1, -1); + + $output = "\$this->_config[0]['vars']['$var_name']"; + + $this->_parse_modifiers($output, $modifiers); + + return $output; + } + + /** + * parse section property expression into PHP code + * + * @param string $section_prop_expr + * @return string + */ + function _parse_section_prop($section_prop_expr) + { + $parts = explode('|', $section_prop_expr, 2); + $var_ref = $parts[0]; + $modifiers = isset($parts[1]) ? $parts[1] : ''; + + preg_match('!%(\w+)\.(\w+)%!', $var_ref, $match); + $section_name = $match[1]; + $prop_name = $match[2]; + + $output = "\$this->_sections['$section_name']['$prop_name']"; + + $this->_parse_modifiers($output, $modifiers); + + return $output; + } + + + /** + * parse modifier chain into PHP code + * + * sets $output to parsed modified chain + * @param string $output + * @param string $modifier_string + */ + function _parse_modifiers(&$output, $modifier_string) + { + preg_match_all('~\|(@?\w+)((?>:(?:'. $this->_qstr_regexp . '|[^|]+))*)~', '|' . $modifier_string, $_match); + list(, $_modifiers, $modifier_arg_strings) = $_match; + + for ($_i = 0, $_for_max = count($_modifiers); $_i < $_for_max; $_i++) { + $_modifier_name = $_modifiers[$_i]; + + if($_modifier_name == 'smarty') { + // skip smarty modifier + continue; + } + + preg_match_all('~:(' . $this->_qstr_regexp . '|[^:]+)~', $modifier_arg_strings[$_i], $_match); + $_modifier_args = $_match[1]; + + if (substr($_modifier_name, 0, 1) == '@') { + $_map_array = false; + $_modifier_name = substr($_modifier_name, 1); + } else { + $_map_array = true; + } + + if (empty($this->_plugins['modifier'][$_modifier_name]) + && !$this->_get_plugin_filepath('modifier', $_modifier_name) + && function_exists($_modifier_name)) { + if ($this->security && !in_array($_modifier_name, $this->security_settings['MODIFIER_FUNCS'])) { + $this->_trigger_fatal_error("[plugin] (secure mode) modifier '$_modifier_name' is not allowed" , $this->_current_file, $this->_current_line_no, __FILE__, __LINE__); + } else { + $this->_plugins['modifier'][$_modifier_name] = array($_modifier_name, null, null, false); + } + } + $this->_add_plugin('modifier', $_modifier_name); + + $this->_parse_vars_props($_modifier_args); + + if($_modifier_name == 'default') { + // supress notifications of default modifier vars and args + if(substr($output, 0, 1) == '$') { + $output = '@' . $output; + } + if(isset($_modifier_args[0]) && substr($_modifier_args[0], 0, 1) == '$') { + $_modifier_args[0] = '@' . $_modifier_args[0]; + } + } + if (count($_modifier_args) > 0) + $_modifier_args = ', '.implode(', ', $_modifier_args); + else + $_modifier_args = ''; + + if ($_map_array) { + $output = "((is_array(\$_tmp=$output)) ? \$this->_run_mod_handler('$_modifier_name', true, \$_tmp$_modifier_args) : " . $this->_compile_plugin_call('modifier', $_modifier_name) . "(\$_tmp$_modifier_args))"; + + } else { + + $output = $this->_compile_plugin_call('modifier', $_modifier_name)."($output$_modifier_args)"; + + } + } + } + + + /** + * add plugin + * + * @param string $type + * @param string $name + * @param boolean? $delayed_loading + */ + function _add_plugin($type, $name, $delayed_loading = null) + { + if (!isset($this->_plugin_info[$type])) { + $this->_plugin_info[$type] = array(); + } + if (!isset($this->_plugin_info[$type][$name])) { + $this->_plugin_info[$type][$name] = array($this->_current_file, + $this->_current_line_no, + $delayed_loading); + } + } + + + /** + * Compiles references of type $smarty.foo + * + * @param string $indexes + * @return string + */ + function _compile_smarty_ref(&$indexes) + { + /* Extract the reference name. */ + $_ref = substr($indexes[0], 1); + foreach($indexes as $_index_no=>$_index) { + if (substr($_index, 0, 1) != '.' && $_index_no<2 || !preg_match('~^(\.|\[|->)~', $_index)) { + $this->_syntax_error('$smarty' . implode('', array_slice($indexes, 0, 2)) . ' is an invalid reference', E_USER_ERROR, __FILE__, __LINE__); + } + } + + switch ($_ref) { + case 'now': + $compiled_ref = 'time()'; + $_max_index = 1; + break; + + case 'foreach': + array_shift($indexes); + $_var = $this->_parse_var_props(substr($indexes[0], 1)); + $_propname = substr($indexes[1], 1); + $_max_index = 1; + switch ($_propname) { + case 'index': + array_shift($indexes); + $compiled_ref = "(\$this->_foreach[$_var]['iteration']-1)"; + break; + + case 'first': + array_shift($indexes); + $compiled_ref = "(\$this->_foreach[$_var]['iteration'] <= 1)"; + break; + + case 'last': + array_shift($indexes); + $compiled_ref = "(\$this->_foreach[$_var]['iteration'] == \$this->_foreach[$_var]['total'])"; + break; + + case 'show': + array_shift($indexes); + $compiled_ref = "(\$this->_foreach[$_var]['total'] > 0)"; + break; + + default: + unset($_max_index); + $compiled_ref = "\$this->_foreach[$_var]"; + } + break; + + case 'section': + array_shift($indexes); + $_var = $this->_parse_var_props(substr($indexes[0], 1)); + $compiled_ref = "\$this->_sections[$_var]"; + break; + + case 'get': + $compiled_ref = ($this->request_use_auto_globals) ? '$_GET' : "\$GLOBALS['HTTP_GET_VARS']"; + break; + + case 'post': + $compiled_ref = ($this->request_use_auto_globals) ? '$_POST' : "\$GLOBALS['HTTP_POST_VARS']"; + break; + + case 'cookies': + $compiled_ref = ($this->request_use_auto_globals) ? '$_COOKIE' : "\$GLOBALS['HTTP_COOKIE_VARS']"; + break; + + case 'env': + $compiled_ref = ($this->request_use_auto_globals) ? '$_ENV' : "\$GLOBALS['HTTP_ENV_VARS']"; + break; + + case 'server': + $compiled_ref = ($this->request_use_auto_globals) ? '$_SERVER' : "\$GLOBALS['HTTP_SERVER_VARS']"; + break; + + case 'session': + $compiled_ref = ($this->request_use_auto_globals) ? '$_SESSION' : "\$GLOBALS['HTTP_SESSION_VARS']"; + break; + + /* + * These cases are handled either at run-time or elsewhere in the + * compiler. + */ + case 'request': + if ($this->request_use_auto_globals) { + $compiled_ref = '$_REQUEST'; + break; + } else { + $this->_init_smarty_vars = true; + } + return null; + + case 'capture': + return null; + + case 'template': + $compiled_ref = "'$this->_current_file'"; + $_max_index = 1; + break; + + case 'version': + $compiled_ref = "'$this->_version'"; + $_max_index = 1; + break; + + case 'const': + if ($this->security && !$this->security_settings['ALLOW_CONSTANTS']) { + $this->_syntax_error("(secure mode) constants not permitted", + E_USER_WARNING, __FILE__, __LINE__); + return; + } + array_shift($indexes); + if (preg_match('!^\.\w+$!', $indexes[0])) { + $compiled_ref = '@' . substr($indexes[0], 1); + } else { + $_val = $this->_parse_var_props(substr($indexes[0], 1)); + $compiled_ref = '@constant(' . $_val . ')'; + } + $_max_index = 1; + break; + + case 'config': + $compiled_ref = "\$this->_config[0]['vars']"; + $_max_index = 3; + break; + + case 'ldelim': + $compiled_ref = "'$this->left_delimiter'"; + break; + + case 'rdelim': + $compiled_ref = "'$this->right_delimiter'"; + break; + + default: + $this->_syntax_error('$smarty.' . $_ref . ' is an unknown reference', E_USER_ERROR, __FILE__, __LINE__); + break; + } + + if (isset($_max_index) && count($indexes) > $_max_index) { + $this->_syntax_error('$smarty' . implode('', $indexes) .' is an invalid reference', E_USER_ERROR, __FILE__, __LINE__); + } + + array_shift($indexes); + return $compiled_ref; + } + + /** + * compiles call to plugin of type $type with name $name + * returns a string containing the function-name or method call + * without the paramter-list that would have follow to make the + * call valid php-syntax + * + * @param string $type + * @param string $name + * @return string + */ + function _compile_plugin_call($type, $name) { + if (isset($this->_plugins[$type][$name])) { + /* plugin loaded */ + if (is_array($this->_plugins[$type][$name][0])) { + return ((is_object($this->_plugins[$type][$name][0][0])) ? + "\$this->_plugins['$type']['$name'][0][0]->" /* method callback */ + : (string)($this->_plugins[$type][$name][0][0]).'::' /* class callback */ + ). $this->_plugins[$type][$name][0][1]; + + } else { + /* function callback */ + return $this->_plugins[$type][$name][0]; + + } + } else { + /* plugin not loaded -> auto-loadable-plugin */ + return 'smarty_'.$type.'_'.$name; + + } + } + + /** + * load pre- and post-filters + */ + function _load_filters() + { + if (count($this->_plugins['prefilter']) > 0) { + foreach ($this->_plugins['prefilter'] as $filter_name => $prefilter) { + if ($prefilter === false) { + unset($this->_plugins['prefilter'][$filter_name]); + $_params = array('plugins' => array(array('prefilter', $filter_name, null, null, false))); + require_once(SMARTY_CORE_DIR . 'core.load_plugins.php'); + smarty_core_load_plugins($_params, $this); + } + } + } + if (count($this->_plugins['postfilter']) > 0) { + foreach ($this->_plugins['postfilter'] as $filter_name => $postfilter) { + if ($postfilter === false) { + unset($this->_plugins['postfilter'][$filter_name]); + $_params = array('plugins' => array(array('postfilter', $filter_name, null, null, false))); + require_once(SMARTY_CORE_DIR . 'core.load_plugins.php'); + smarty_core_load_plugins($_params, $this); + } + } + } + } + + + /** + * Quote subpattern references + * + * @param string $string + * @return string + */ + function _quote_replace($string) + { + return strtr($string, array('\\' => '\\\\', '$' => '\\$')); + } + + /** + * display Smarty syntax error + * + * @param string $error_msg + * @param integer $error_type + * @param string $file + * @param integer $line + */ + function _syntax_error($error_msg, $error_type = E_USER_ERROR, $file=null, $line=null) + { + $this->_trigger_fatal_error("syntax error: $error_msg", $this->_current_file, $this->_current_line_no, $file, $line, $error_type); + } + + + /** + * check if the compilation changes from cacheable to + * non-cacheable state with the beginning of the current + * plugin. return php-code to reflect the transition. + * @return string + */ + function _push_cacheable_state($type, $name) { + $_cacheable = !isset($this->_plugins[$type][$name]) || $this->_plugins[$type][$name][4]; + if ($_cacheable + || 0<$this->_cacheable_state++) return ''; + if (!isset($this->_cache_serial)) $this->_cache_serial = md5(uniqid('Smarty')); + $_ret = 'if ($this->caching && !$this->_cache_including): echo \'{nocache:' + . $this->_cache_serial . '#' . $this->_nocache_count + . '}\'; endif;'; + return $_ret; + } + + + /** + * check if the compilation changes from non-cacheable to + * cacheable state with the end of the current plugin return + * php-code to reflect the transition. + * @return string + */ + function _pop_cacheable_state($type, $name) { + $_cacheable = !isset($this->_plugins[$type][$name]) || $this->_plugins[$type][$name][4]; + if ($_cacheable + || --$this->_cacheable_state>0) return ''; + return 'if ($this->caching && !$this->_cache_including): echo \'{/nocache:' + . $this->_cache_serial . '#' . ($this->_nocache_count++) + . '}\'; endif;'; + } + + + /** + * push opening tag-name, file-name and line-number on the tag-stack + * @param string the opening tag's name + */ + function _push_tag($open_tag) + { + array_push($this->_tag_stack, array($open_tag, $this->_current_line_no)); + } + + /** + * pop closing tag-name + * raise an error if this stack-top doesn't match with the closing tag + * @param string the closing tag's name + * @return string the opening tag's name + */ + function _pop_tag($close_tag) + { + $message = ''; + if (count($this->_tag_stack)>0) { + list($_open_tag, $_line_no) = array_pop($this->_tag_stack); + if ($close_tag == $_open_tag) { + return $_open_tag; + } + if ($close_tag == 'if' && ($_open_tag == 'else' || $_open_tag == 'elseif' )) { + return $this->_pop_tag($close_tag); + } + if ($close_tag == 'section' && $_open_tag == 'sectionelse') { + $this->_pop_tag($close_tag); + return $_open_tag; + } + if ($close_tag == 'foreach' && $_open_tag == 'foreachelse') { + $this->_pop_tag($close_tag); + return $_open_tag; + } + if ($_open_tag == 'else' || $_open_tag == 'elseif') { + $_open_tag = 'if'; + } elseif ($_open_tag == 'sectionelse') { + $_open_tag = 'section'; + } elseif ($_open_tag == 'foreachelse') { + $_open_tag = 'foreach'; + } + $message = " expected {/$_open_tag} (opened line $_line_no)."; + } + $this->_syntax_error("mismatched tag {/$close_tag}.$message", + E_USER_ERROR, __FILE__, __LINE__); + } + +} + +/** + * compare to values by their string length + * + * @access private + * @param string $a + * @param string $b + * @return 0|-1|1 + */ +function _smarty_sort_length($a, $b) +{ + if($a == $b) + return 0; + + if(strlen($a) == strlen($b)) + return ($a > $b) ? -1 : 1; + + return (strlen($a) > strlen($b)) ? -1 : 1; +} + + +/* vim: set et: */ + +?> diff --git a/includes/onyx/templates/libs/debug.tpl b/includes/onyx/templates/libs/debug.tpl new file mode 100644 index 0000000..c05ef5d --- /dev/null +++ b/includes/onyx/templates/libs/debug.tpl @@ -0,0 +1,157 @@ +{* Smarty *} +{* debug.tpl, last updated version 2.1.0 *} +{assign_debug_info} +{capture assign=debug_output} + + + + Smarty Debug Console +{literal} + +{/literal} + + + +

    Smarty Debug Console

    + +

    included templates & config files (load time in seconds)

    + +
    +{section name=templates loop=$_debug_tpls} + {section name=indent loop=$_debug_tpls[templates].depth}   {/section} + + {$_debug_tpls[templates].filename|escape:html} + {if isset($_debug_tpls[templates].exec_time)} + + ({$_debug_tpls[templates].exec_time|string_format:"%.5f"}) + {if %templates.index% eq 0}(total){/if} + + {/if} +
    +{sectionelse} +

    no templates included

    +{/section} +
    + +

    assigned template variables

    + + + {section name=vars loop=$_debug_keys} + + + + {sectionelse} + + {/section} +
    {ldelim}${$_debug_keys[vars]|escape:'html'}{rdelim}{$_debug_vals[vars]|@debug_print_var}

    no template variables assigned

    + +

    assigned config file variables (outer template scope)

    + + + {section name=config_vars loop=$_debug_config_keys} + + + + {sectionelse} + + {/section} +
    {ldelim}#{$_debug_config_keys[config_vars]|escape:'html'}#{rdelim}{$_debug_config_vals[config_vars]|@debug_print_var}

    no config vars assigned

    + + +{/capture} +{if isset($_smarty_debug_output) and $_smarty_debug_output eq "html"} + {$debug_output} +{else} + +{/if} \ No newline at end of file diff --git a/includes/onyx/templates/libs/internals/core.assemble_plugin_filepath.php b/includes/onyx/templates/libs/internals/core.assemble_plugin_filepath.php new file mode 100644 index 0000000..690d3dd --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.assemble_plugin_filepath.php @@ -0,0 +1,67 @@ +plugins_dir as $_plugin_dir) { + + $_plugin_filepath = $_plugin_dir . DIRECTORY_SEPARATOR . $_plugin_filename; + + // see if path is relative + if (!preg_match("/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/", $_plugin_dir)) { + $_relative_paths[] = $_plugin_dir; + // relative path, see if it is in the SMARTY_DIR + if (@is_readable(SMARTY_DIR . $_plugin_filepath)) { + $_return = SMARTY_DIR . $_plugin_filepath; + break; + } + } + // try relative to cwd (or absolute) + if (@is_readable($_plugin_filepath)) { + $_return = $_plugin_filepath; + break; + } + } + + if($_return === false) { + // still not found, try PHP include_path + if(isset($_relative_paths)) { + foreach ((array)$_relative_paths as $_plugin_dir) { + + $_plugin_filepath = $_plugin_dir . DIRECTORY_SEPARATOR . $_plugin_filename; + + $_params = array('file_path' => $_plugin_filepath); + require_once(SMARTY_CORE_DIR . 'core.get_include_path.php'); + if(smarty_core_get_include_path($_params, $smarty)) { + $_return = $_params['new_file_path']; + break; + } + } + } + } + $_filepaths_cache[$_plugin_filename] = $_return; + return $_return; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.assign_smarty_interface.php b/includes/onyx/templates/libs/internals/core.assign_smarty_interface.php new file mode 100644 index 0000000..7e65a73 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.assign_smarty_interface.php @@ -0,0 +1,43 @@ + + * Name: assign_smarty_interface
    + * Purpose: assign the $smarty interface variable + * @param array Format: null + * @param Smarty + */ +function smarty_core_assign_smarty_interface($params, &$smarty) +{ + if (isset($smarty->_smarty_vars) && isset($smarty->_smarty_vars['request'])) { + return; + } + + $_globals_map = array('g' => 'HTTP_GET_VARS', + 'p' => 'HTTP_POST_VARS', + 'c' => 'HTTP_COOKIE_VARS', + 's' => 'HTTP_SERVER_VARS', + 'e' => 'HTTP_ENV_VARS'); + + $_smarty_vars_request = array(); + + foreach (preg_split('!!', strtolower($smarty->request_vars_order)) as $_c) { + if (isset($_globals_map[$_c])) { + $_smarty_vars_request = array_merge($_smarty_vars_request, $GLOBALS[$_globals_map[$_c]]); + } + } + $_smarty_vars_request = @array_merge($_smarty_vars_request, $GLOBALS['HTTP_SESSION_VARS']); + + $smarty->_smarty_vars['request'] = $_smarty_vars_request; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.create_dir_structure.php b/includes/onyx/templates/libs/internals/core.create_dir_structure.php new file mode 100644 index 0000000..3eecc49 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.create_dir_structure.php @@ -0,0 +1,79 @@ +_dir_perms) && !is_dir($_new_dir)) { + $smarty->trigger_error("problem creating directory '" . $_new_dir . "'"); + return false; + } + $_new_dir .= '/'; + } + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.display_debug_console.php b/includes/onyx/templates/libs/internals/core.display_debug_console.php new file mode 100644 index 0000000..1a80f39 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.display_debug_console.php @@ -0,0 +1,61 @@ + + * Name: display_debug_console
    + * Purpose: display the javascript debug console window + * @param array Format: null + * @param Smarty + */ +function smarty_core_display_debug_console($params, &$smarty) +{ + // we must force compile the debug template in case the environment + // changed between separate applications. + + if(empty($smarty->debug_tpl)) { + // set path to debug template from SMARTY_DIR + $smarty->debug_tpl = SMARTY_DIR . 'debug.tpl'; + if($smarty->security && is_file($smarty->debug_tpl)) { + $smarty->secure_dir[] = realpath($smarty->debug_tpl); + } + $smarty->debug_tpl = 'file:' . SMARTY_DIR . 'debug.tpl'; + } + + $_ldelim_orig = $smarty->left_delimiter; + $_rdelim_orig = $smarty->right_delimiter; + + $smarty->left_delimiter = '{'; + $smarty->right_delimiter = '}'; + + $_compile_id_orig = $smarty->_compile_id; + $smarty->_compile_id = null; + + $_compile_path = $smarty->_get_compile_path($smarty->debug_tpl); + if ($smarty->_compile_resource($smarty->debug_tpl, $_compile_path)) + { + ob_start(); + $smarty->_include($_compile_path); + $_results = ob_get_contents(); + ob_end_clean(); + } else { + $_results = ''; + } + + $smarty->_compile_id = $_compile_id_orig; + + $smarty->left_delimiter = $_ldelim_orig; + $smarty->right_delimiter = $_rdelim_orig; + + return $_results; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.get_include_path.php b/includes/onyx/templates/libs/internals/core.get_include_path.php new file mode 100644 index 0000000..4343241 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.get_include_path.php @@ -0,0 +1,44 @@ + diff --git a/includes/onyx/templates/libs/internals/core.get_microtime.php b/includes/onyx/templates/libs/internals/core.get_microtime.php new file mode 100644 index 0000000..f1a28e0 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.get_microtime.php @@ -0,0 +1,23 @@ + diff --git a/includes/onyx/templates/libs/internals/core.get_php_resource.php b/includes/onyx/templates/libs/internals/core.get_php_resource.php new file mode 100644 index 0000000..786d4e7 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.get_php_resource.php @@ -0,0 +1,80 @@ +trusted_dir; + $smarty->_parse_resource_name($params, $smarty); + + /* + * Find out if the resource exists. + */ + + if ($params['resource_type'] == 'file') { + $_readable = false; + if(file_exists($params['resource_name']) && is_readable($params['resource_name'])) { + $_readable = true; + } else { + // test for file in include_path + $_params = array('file_path' => $params['resource_name']); + require_once(SMARTY_CORE_DIR . 'core.get_include_path.php'); + if(smarty_core_get_include_path($_params, $smarty)) { + $_include_path = $_params['new_file_path']; + $_readable = true; + } + } + } else if ($params['resource_type'] != 'file') { + $_template_source = null; + $_readable = is_callable($smarty->_plugins['resource'][$params['resource_type']][0][0]) + && call_user_func_array($smarty->_plugins['resource'][$params['resource_type']][0][0], + array($params['resource_name'], &$_template_source, &$smarty)); + } + + /* + * Set the error function, depending on which class calls us. + */ + if (method_exists($smarty, '_syntax_error')) { + $_error_funcc = '_syntax_error'; + } else { + $_error_funcc = 'trigger_error'; + } + + if ($_readable) { + if ($smarty->security) { + require_once(SMARTY_CORE_DIR . 'core.is_trusted.php'); + if (!smarty_core_is_trusted($params, $smarty)) { + $smarty->$_error_funcc('(secure mode) ' . $params['resource_type'] . ':' . $params['resource_name'] . ' is not trusted'); + return false; + } + } + } else { + $smarty->$_error_funcc($params['resource_type'] . ':' . $params['resource_name'] . ' is not readable'); + return false; + } + + if ($params['resource_type'] == 'file') { + $params['php_resource'] = $params['resource_name']; + } else { + $params['php_resource'] = $_template_source; + } + return true; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.is_secure.php b/includes/onyx/templates/libs/internals/core.is_secure.php new file mode 100644 index 0000000..d54abd4 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.is_secure.php @@ -0,0 +1,59 @@ +security || $smarty->security_settings['INCLUDE_ANY']) { + return true; + } + + if ($params['resource_type'] == 'file') { + $_rp = realpath($params['resource_name']); + if (isset($params['resource_base_path'])) { + foreach ((array)$params['resource_base_path'] as $curr_dir) { + if ( ($_cd = realpath($curr_dir)) !== false && + strncmp($_rp, $_cd, strlen($_cd)) == 0 && + substr($_rp, strlen($_cd), 1) == DIRECTORY_SEPARATOR ) { + return true; + } + } + } + if (!empty($smarty->secure_dir)) { + foreach ((array)$smarty->secure_dir as $curr_dir) { + if ( ($_cd = realpath($curr_dir)) !== false) { + if($_cd == $_rp) { + return true; + } elseif (strncmp($_rp, $_cd, strlen($_cd)) == 0 && + substr($_rp, strlen($_cd), 1) == DIRECTORY_SEPARATOR) { + return true; + } + } + } + } + } else { + // resource is not on local file system + return call_user_func_array( + $smarty->_plugins['resource'][$params['resource_type']][0][2], + array($params['resource_name'], &$smarty)); + } + + return false; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.is_trusted.php b/includes/onyx/templates/libs/internals/core.is_trusted.php new file mode 100644 index 0000000..4299731 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.is_trusted.php @@ -0,0 +1,47 @@ +trusted_dir)) { + $_rp = realpath($params['resource_name']); + foreach ((array)$smarty->trusted_dir as $curr_dir) { + if (!empty($curr_dir) && is_readable ($curr_dir)) { + $_cd = realpath($curr_dir); + if (strncmp($_rp, $_cd, strlen($_cd)) == 0 + && substr($_rp, strlen($_cd), 1) == DIRECTORY_SEPARATOR ) { + $_smarty_trusted = true; + break; + } + } + } + } + + } else { + // resource is not on local file system + $_smarty_trusted = call_user_func_array($smarty->_plugins['resource'][$params['resource_type']][0][3], + array($params['resource_name'], $smarty)); + } + + return $_smarty_trusted; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.load_plugins.php b/includes/onyx/templates/libs/internals/core.load_plugins.php new file mode 100644 index 0000000..6db1dc5 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.load_plugins.php @@ -0,0 +1,125 @@ +_plugins[$_type][$_name]; + + /* + * We do not load plugin more than once for each instance of Smarty. + * The following code checks for that. The plugin can also be + * registered dynamically at runtime, in which case template file + * and line number will be unknown, so we fill them in. + * + * The final element of the info array is a flag that indicates + * whether the dynamically registered plugin function has been + * checked for existence yet or not. + */ + if (isset($_plugin)) { + if (empty($_plugin[3])) { + if (!is_callable($_plugin[0])) { + $smarty->_trigger_fatal_error("[plugin] $_type '$_name' is not implemented", $_tpl_file, $_tpl_line, __FILE__, __LINE__); + } else { + $_plugin[1] = $_tpl_file; + $_plugin[2] = $_tpl_line; + $_plugin[3] = true; + if (!isset($_plugin[4])) $_plugin[4] = true; /* cacheable */ + } + } + continue; + } else if ($_type == 'insert') { + /* + * For backwards compatibility, we check for insert functions in + * the symbol table before trying to load them as a plugin. + */ + $_plugin_func = 'insert_' . $_name; + if (function_exists($_plugin_func)) { + $_plugin = array($_plugin_func, $_tpl_file, $_tpl_line, true, false); + continue; + } + } + + $_plugin_file = $smarty->_get_plugin_filepath($_type, $_name); + + if (! $_found = ($_plugin_file != false)) { + $_message = "could not load plugin file '$_type.$_name.php'\n"; + } + + /* + * If plugin file is found, it -must- provide the properly named + * plugin function. In case it doesn't, simply output the error and + * do not fall back on any other method. + */ + if ($_found) { + include_once $_plugin_file; + + $_plugin_func = 'smarty_' . $_type . '_' . $_name; + if (!function_exists($_plugin_func)) { + $smarty->_trigger_fatal_error("[plugin] function $_plugin_func() not found in $_plugin_file", $_tpl_file, $_tpl_line, __FILE__, __LINE__); + continue; + } + } + /* + * In case of insert plugins, their code may be loaded later via + * 'script' attribute. + */ + else if ($_type == 'insert' && $_delayed_loading) { + $_plugin_func = 'smarty_' . $_type . '_' . $_name; + $_found = true; + } + + /* + * Plugin specific processing and error checking. + */ + if (!$_found) { + if ($_type == 'modifier') { + /* + * In case modifier falls back on using PHP functions + * directly, we only allow those specified in the security + * context. + */ + if ($smarty->security && !in_array($_name, $smarty->security_settings['MODIFIER_FUNCS'])) { + $_message = "(secure mode) modifier '$_name' is not allowed"; + } else { + if (!function_exists($_name)) { + $_message = "modifier '$_name' is not implemented"; + } else { + $_plugin_func = $_name; + $_found = true; + } + } + } else if ($_type == 'function') { + /* + * This is a catch-all situation. + */ + $_message = "unknown tag - '$_name'"; + } + } + + if ($_found) { + $smarty->_plugins[$_type][$_name] = array($_plugin_func, $_tpl_file, $_tpl_line, true, true); + } else { + // output error + $smarty->_trigger_fatal_error('[plugin] ' . $_message, $_tpl_file, $_tpl_line, __FILE__, __LINE__); + } + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.load_resource_plugin.php b/includes/onyx/templates/libs/internals/core.load_resource_plugin.php new file mode 100644 index 0000000..a7d37d1 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.load_resource_plugin.php @@ -0,0 +1,74 @@ +_plugins['resource'][$params['type']]; + if (isset($_plugin)) { + if (!$_plugin[1] && count($_plugin[0])) { + $_plugin[1] = true; + foreach ($_plugin[0] as $_plugin_func) { + if (!is_callable($_plugin_func)) { + $_plugin[1] = false; + break; + } + } + } + + if (!$_plugin[1]) { + $smarty->_trigger_fatal_error("[plugin] resource '" . $params['type'] . "' is not implemented", null, null, __FILE__, __LINE__); + } + + return; + } + + $_plugin_file = $smarty->_get_plugin_filepath('resource', $params['type']); + $_found = ($_plugin_file != false); + + if ($_found) { /* + * If the plugin file is found, it -must- provide the properly named + * plugin functions. + */ + include_once($_plugin_file); + + /* + * Locate functions that we require the plugin to provide. + */ + $_resource_ops = array('source', 'timestamp', 'secure', 'trusted'); + $_resource_funcs = array(); + foreach ($_resource_ops as $_op) { + $_plugin_func = 'smarty_resource_' . $params['type'] . '_' . $_op; + if (!function_exists($_plugin_func)) { + $smarty->_trigger_fatal_error("[plugin] function $_plugin_func() not found in $_plugin_file", null, null, __FILE__, __LINE__); + return; + } else { + $_resource_funcs[] = $_plugin_func; + } + } + + $smarty->_plugins['resource'][$params['type']] = array($_resource_funcs, true); + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.process_cached_inserts.php b/includes/onyx/templates/libs/internals/core.process_cached_inserts.php new file mode 100644 index 0000000..1d78edd --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.process_cached_inserts.php @@ -0,0 +1,71 @@ +_smarty_md5.'{insert_cache (.*)}'.$smarty->_smarty_md5.'!Uis', + $params['results'], $match); + list($cached_inserts, $insert_args) = $match; + + for ($i = 0, $for_max = count($cached_inserts); $i < $for_max; $i++) { + if ($smarty->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $debug_start_time = smarty_core_get_microtime($_params, $smarty); + } + + $args = unserialize($insert_args[$i]); + $name = $args['name']; + + if (isset($args['script'])) { + $_params = array('resource_name' => $smarty->_dequote($args['script'])); + require_once(SMARTY_CORE_DIR . 'core.get_php_resource.php'); + if(!smarty_core_get_php_resource($_params, $smarty)) { + return false; + } + $resource_type = $_params['resource_type']; + $php_resource = $_params['php_resource']; + + + if ($resource_type == 'file') { + $smarty->_include($php_resource, true); + } else { + $smarty->_eval($php_resource); + } + } + + $function_name = $smarty->_plugins['insert'][$name][0]; + if (empty($args['assign'])) { + $replace = $function_name($args, $smarty); + } else { + $smarty->assign($args['assign'], $function_name($args, $smarty)); + $replace = ''; + } + + $params['results'] = substr_replace($params['results'], $replace, strpos($params['results'], $cached_inserts[$i]), strlen($cached_inserts[$i])); + if ($smarty->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $smarty->_smarty_debug_info[] = array('type' => 'insert', + 'filename' => 'insert_'.$name, + 'depth' => $smarty->_inclusion_depth, + 'exec_time' => smarty_core_get_microtime($_params, $smarty) - $debug_start_time); + } + } + + return $params['results']; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.process_compiled_include.php b/includes/onyx/templates/libs/internals/core.process_compiled_include.php new file mode 100644 index 0000000..d539423 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.process_compiled_include.php @@ -0,0 +1,37 @@ +_cache_including; + $smarty->_cache_including = true; + + $_return = $params['results']; + + foreach ($smarty->_cache_info['cache_serials'] as $_include_file_path=>$_cache_serial) { + $smarty->_include($_include_file_path, true); + } + + foreach ($smarty->_cache_serials as $_include_file_path=>$_cache_serial) { + $_return = preg_replace_callback('!(\{nocache\:('.$_cache_serial.')#(\d+)\})!s', + array(&$smarty, '_process_compiled_include_callback'), + $_return); + } + $smarty->_cache_including = $_cache_including; + return $_return; +} + +?> diff --git a/includes/onyx/templates/libs/internals/core.read_cache_file.php b/includes/onyx/templates/libs/internals/core.read_cache_file.php new file mode 100644 index 0000000..c60e113 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.read_cache_file.php @@ -0,0 +1,101 @@ +force_compile) { + // force compile enabled, always regenerate + return false; + } + + if (isset($content_cache[$params['tpl_file'].','.$params['cache_id'].','.$params['compile_id']])) { + list($params['results'], $smarty->_cache_info) = $content_cache[$params['tpl_file'].','.$params['cache_id'].','.$params['compile_id']]; + return true; + } + + if (!empty($smarty->cache_handler_func)) { + // use cache_handler function + call_user_func_array($smarty->cache_handler_func, + array('read', &$smarty, &$params['results'], $params['tpl_file'], $params['cache_id'], $params['compile_id'], null)); + } else { + // use local cache file + $_auto_id = $smarty->_get_auto_id($params['cache_id'], $params['compile_id']); + $_cache_file = $smarty->_get_auto_filename($smarty->cache_dir, $params['tpl_file'], $_auto_id); + $params['results'] = $smarty->_read_file($_cache_file); + } + + if (empty($params['results'])) { + // nothing to parse (error?), regenerate cache + return false; + } + + $_contents = $params['results']; + $_info_start = strpos($_contents, "\n") + 1; + $_info_len = (int)substr($_contents, 0, $_info_start - 1); + $_cache_info = unserialize(substr($_contents, $_info_start, $_info_len)); + $params['results'] = substr($_contents, $_info_start + $_info_len); + + if ($smarty->caching == 2 && isset ($_cache_info['expires'])){ + // caching by expiration time + if ($_cache_info['expires'] > -1 && (time() > $_cache_info['expires'])) { + // cache expired, regenerate + return false; + } + } else { + // caching by lifetime + if ($smarty->cache_lifetime > -1 && (time() - $_cache_info['timestamp'] > $smarty->cache_lifetime)) { + // cache expired, regenerate + return false; + } + } + + if ($smarty->compile_check) { + $_params = array('get_source' => false, 'quiet'=>true); + foreach (array_keys($_cache_info['template']) as $_template_dep) { + $_params['resource_name'] = $_template_dep; + if (!$smarty->_fetch_resource_info($_params) || $_cache_info['timestamp'] < $_params['resource_timestamp']) { + // template file has changed, regenerate cache + return false; + } + } + + if (isset($_cache_info['config'])) { + $_params = array('resource_base_path' => $smarty->config_dir, 'get_source' => false, 'quiet'=>true); + foreach (array_keys($_cache_info['config']) as $_config_dep) { + $_params['resource_name'] = $_config_dep; + if (!$smarty->_fetch_resource_info($_params) || $_cache_info['timestamp'] < $_params['resource_timestamp']) { + // config file has changed, regenerate cache + return false; + } + } + } + } + + $content_cache[$params['tpl_file'].','.$params['cache_id'].','.$params['compile_id']] = array($params['results'], $_cache_info); + + $smarty->_cache_info = $_cache_info; + return true; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.rm_auto.php b/includes/onyx/templates/libs/internals/core.rm_auto.php new file mode 100644 index 0000000..b251f64 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.rm_auto.php @@ -0,0 +1,71 @@ + $params['auto_base'], + 'level' => 0, + 'exp_time' => $params['exp_time'] + ); + require_once(SMARTY_CORE_DIR . 'core.rmdir.php'); + $_res = smarty_core_rmdir($_params, $smarty); + } else { + $_tname = $smarty->_get_auto_filename($params['auto_base'], $params['auto_source'], $params['auto_id']); + + if(isset($params['auto_source'])) { + if (isset($params['extensions'])) { + $_res = false; + foreach ((array)$params['extensions'] as $_extension) + $_res |= $smarty->_unlink($_tname.$_extension, $params['exp_time']); + } else { + $_res = $smarty->_unlink($_tname, $params['exp_time']); + } + } elseif ($smarty->use_sub_dirs) { + $_params = array( + 'dirname' => $_tname, + 'level' => 1, + 'exp_time' => $params['exp_time'] + ); + require_once(SMARTY_CORE_DIR . 'core.rmdir.php'); + $_res = smarty_core_rmdir($_params, $smarty); + } else { + // remove matching file names + $_handle = opendir($params['auto_base']); + $_res = true; + while (false !== ($_filename = readdir($_handle))) { + if($_filename == '.' || $_filename == '..') { + continue; + } elseif (substr($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, 0, strlen($_tname)) == $_tname) { + $_res &= (bool)$smarty->_unlink($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, $params['exp_time']); + } + } + } + } + + return $_res; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.rmdir.php b/includes/onyx/templates/libs/internals/core.rmdir.php new file mode 100644 index 0000000..2166c44 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.rmdir.php @@ -0,0 +1,54 @@ + keep root) + * WARNING: no tests, it will try to remove what you tell it! + * + * @param string $dirname + * @param integer $level + * @param integer $exp_time + * @return boolean + */ + +// $dirname, $level = 1, $exp_time = null + +function smarty_core_rmdir($params, &$smarty) +{ + if(!isset($params['level'])) { $params['level'] = 1; } + if(!isset($params['exp_time'])) { $params['exp_time'] = null; } + + if($_handle = @opendir($params['dirname'])) { + + while (false !== ($_entry = readdir($_handle))) { + if ($_entry != '.' && $_entry != '..') { + if (@is_dir($params['dirname'] . DIRECTORY_SEPARATOR . $_entry)) { + $_params = array( + 'dirname' => $params['dirname'] . DIRECTORY_SEPARATOR . $_entry, + 'level' => $params['level'] + 1, + 'exp_time' => $params['exp_time'] + ); + smarty_core_rmdir($_params, $smarty); + } + else { + $smarty->_unlink($params['dirname'] . DIRECTORY_SEPARATOR . $_entry, $params['exp_time']); + } + } + } + closedir($_handle); + } + + if ($params['level']) { + return @rmdir($params['dirname']); + } + return (bool)$_handle; + +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.run_insert_handler.php b/includes/onyx/templates/libs/internals/core.run_insert_handler.php new file mode 100644 index 0000000..71c3845 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.run_insert_handler.php @@ -0,0 +1,71 @@ +debugging) { + $_params = array(); + $_debug_start_time = smarty_core_get_microtime($_params, $smarty); + } + + if ($smarty->caching) { + $_arg_string = serialize($params['args']); + $_name = $params['args']['name']; + if (!isset($smarty->_cache_info['insert_tags'][$_name])) { + $smarty->_cache_info['insert_tags'][$_name] = array('insert', + $_name, + $smarty->_plugins['insert'][$_name][1], + $smarty->_plugins['insert'][$_name][2], + !empty($params['args']['script']) ? true : false); + } + return $smarty->_smarty_md5."{insert_cache $_arg_string}".$smarty->_smarty_md5; + } else { + if (isset($params['args']['script'])) { + $_params = array('resource_name' => $smarty->_dequote($params['args']['script'])); + require_once(SMARTY_CORE_DIR . 'core.get_php_resource.php'); + if(!smarty_core_get_php_resource($_params, $smarty)) { + return false; + } + + if ($_params['resource_type'] == 'file') { + $smarty->_include($_params['php_resource'], true); + } else { + $smarty->_eval($_params['php_resource']); + } + unset($params['args']['script']); + } + + $_funcname = $smarty->_plugins['insert'][$params['args']['name']][0]; + $_content = $_funcname($params['args'], $smarty); + if ($smarty->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $smarty->_smarty_debug_info[] = array('type' => 'insert', + 'filename' => 'insert_'.$params['args']['name'], + 'depth' => $smarty->_inclusion_depth, + 'exec_time' => smarty_core_get_microtime($_params, $smarty) - $_debug_start_time); + } + + if (!empty($params['args']["assign"])) { + $smarty->assign($params['args']["assign"], $_content); + } else { + return $_content; + } + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.smarty_include_php.php b/includes/onyx/templates/libs/internals/core.smarty_include_php.php new file mode 100644 index 0000000..30c6e76 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.smarty_include_php.php @@ -0,0 +1,50 @@ + $params['smarty_file']); + require_once(SMARTY_CORE_DIR . 'core.get_php_resource.php'); + smarty_core_get_php_resource($_params, $smarty); + $_smarty_resource_type = $_params['resource_type']; + $_smarty_php_resource = $_params['php_resource']; + + if (!empty($params['smarty_assign'])) { + ob_start(); + if ($_smarty_resource_type == 'file') { + $smarty->_include($_smarty_php_resource, $params['smarty_once'], $params['smarty_include_vars']); + } else { + $smarty->_eval($_smarty_php_resource, $params['smarty_include_vars']); + } + $smarty->assign($params['smarty_assign'], ob_get_contents()); + ob_end_clean(); + } else { + if ($_smarty_resource_type == 'file') { + $smarty->_include($_smarty_php_resource, $params['smarty_once'], $params['smarty_include_vars']); + } else { + $smarty->_eval($_smarty_php_resource, $params['smarty_include_vars']); + } + } +} + + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.write_cache_file.php b/includes/onyx/templates/libs/internals/core.write_cache_file.php new file mode 100644 index 0000000..72f785b --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.write_cache_file.php @@ -0,0 +1,96 @@ +_cache_info['timestamp'] = time(); + if ($smarty->cache_lifetime > -1){ + // expiration set + $smarty->_cache_info['expires'] = $smarty->_cache_info['timestamp'] + $smarty->cache_lifetime; + } else { + // cache will never expire + $smarty->_cache_info['expires'] = -1; + } + + // collapse nocache.../nocache-tags + if (preg_match_all('!\{(/?)nocache\:[0-9a-f]{32}#\d+\}!', $params['results'], $match, PREG_PATTERN_ORDER)) { + // remove everything between every pair of outermost noache.../nocache-tags + // and replace it by a single nocache-tag + // this new nocache-tag will be replaced by dynamic contents in + // smarty_core_process_compiled_includes() on a cache-read + + $match_count = count($match[0]); + $results = preg_split('!(\{/?nocache\:[0-9a-f]{32}#\d+\})!', $params['results'], -1, PREG_SPLIT_DELIM_CAPTURE); + + $level = 0; + $j = 0; + for ($i=0, $results_count = count($results); $i < $results_count && $j < $match_count; $i++) { + if ($results[$i] == $match[0][$j]) { + // nocache tag + if ($match[1][$j]) { // closing tag + $level--; + unset($results[$i]); + } else { // opening tag + if ($level++ > 0) unset($results[$i]); + } + $j++; + } elseif ($level > 0) { + unset($results[$i]); + } + } + $params['results'] = implode('', $results); + } + $smarty->_cache_info['cache_serials'] = $smarty->_cache_serials; + + // prepend the cache header info into cache file + $_cache_info = serialize($smarty->_cache_info); + $params['results'] = strlen($_cache_info) . "\n" . $_cache_info . $params['results']; + + if (!empty($smarty->cache_handler_func)) { + // use cache_handler function + call_user_func_array($smarty->cache_handler_func, + array('write', &$smarty, &$params['results'], $params['tpl_file'], $params['cache_id'], $params['compile_id'], null)); + } else { + // use local cache file + + if(!@is_writable($smarty->cache_dir)) { + // cache_dir not writable, see if it exists + if(!@is_dir($smarty->cache_dir)) { + $smarty->trigger_error('the $cache_dir \'' . $smarty->cache_dir . '\' does not exist, or is not a directory.', E_USER_ERROR); + return false; + } + $smarty->trigger_error('unable to write to $cache_dir \'' . realpath($smarty->cache_dir) . '\'. Be sure $cache_dir is writable by the web server user.', E_USER_ERROR); + return false; + } + + $_auto_id = $smarty->_get_auto_id($params['cache_id'], $params['compile_id']); + $_cache_file = $smarty->_get_auto_filename($smarty->cache_dir, $params['tpl_file'], $_auto_id); + $_params = array('filename' => $_cache_file, 'contents' => $params['results'], 'create_dirs' => true); + require_once(SMARTY_CORE_DIR . 'core.write_file.php'); + smarty_core_write_file($_params, $smarty); + return true; + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.write_compiled_include.php b/includes/onyx/templates/libs/internals/core.write_compiled_include.php new file mode 100644 index 0000000..c14adb5 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.write_compiled_include.php @@ -0,0 +1,91 @@ +caching && \!\$this->_cache_including\)\: echo \'\{nocache\:('.$params['cache_serial'].')#(\d+)\}\'; endif;'; + $_tag_end = 'if \(\$this->caching && \!\$this->_cache_including\)\: echo \'\{/nocache\:(\\2)#(\\3)\}\'; endif;'; + + preg_match_all('!('.$_tag_start.'(.*)'.$_tag_end.')!Us', + $params['compiled_content'], $_match_source, PREG_SET_ORDER); + + // no nocache-parts found: done + if (count($_match_source)==0) return; + + // convert the matched php-code to functions + $_include_compiled = "_version.", created on ".strftime("%Y-%m-%d %H:%M:%S")."\n"; + $_include_compiled .= " compiled from " . strtr(urlencode($params['resource_name']), array('%2F'=>'/', '%3A'=>':')) . " */\n\n"; + + $_compile_path = $params['include_file_path']; + + $smarty->_cache_serials[$_compile_path] = $params['cache_serial']; + $_include_compiled .= "\$this->_cache_serials['".$_compile_path."'] = '".$params['cache_serial']."';\n\n?>"; + + $_include_compiled .= $params['plugins_code']; + $_include_compiled .= "= 5.0) ? '_smarty' : 'this'; + for ($_i = 0, $_for_max = count($_match_source); $_i < $_for_max; $_i++) { + $_match =& $_match_source[$_i]; + $source = $_match[4]; + if ($this_varname == '_smarty') { + /* rename $this to $_smarty in the sourcecode */ + $tokens = token_get_all('\n"; + + $_params = array('filename' => $_compile_path, + 'contents' => $_include_compiled, 'create_dirs' => true); + + require_once(SMARTY_CORE_DIR . 'core.write_file.php'); + smarty_core_write_file($_params, $smarty); + return true; +} + + +?> diff --git a/includes/onyx/templates/libs/internals/core.write_compiled_resource.php b/includes/onyx/templates/libs/internals/core.write_compiled_resource.php new file mode 100644 index 0000000..b902eff --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.write_compiled_resource.php @@ -0,0 +1,35 @@ +compile_dir)) { + // compile_dir not writable, see if it exists + if(!@is_dir($smarty->compile_dir)) { + $smarty->trigger_error('the $compile_dir \'' . $smarty->compile_dir . '\' does not exist, or is not a directory.', E_USER_ERROR); + return false; + } + $smarty->trigger_error('unable to write to $compile_dir \'' . realpath($smarty->compile_dir) . '\'. Be sure $compile_dir is writable by the web server user.', E_USER_ERROR); + return false; + } + + $_params = array('filename' => $params['compile_path'], 'contents' => $params['compiled_content'], 'create_dirs' => true); + require_once(SMARTY_CORE_DIR . 'core.write_file.php'); + smarty_core_write_file($_params, $smarty); + return true; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/internals/core.write_file.php b/includes/onyx/templates/libs/internals/core.write_file.php new file mode 100644 index 0000000..8a3a3b3 --- /dev/null +++ b/includes/onyx/templates/libs/internals/core.write_file.php @@ -0,0 +1,54 @@ + $_dirname); + require_once(SMARTY_CORE_DIR . 'core.create_dir_structure.php'); + smarty_core_create_dir_structure($_params, $smarty); + } + + // write to tmp file, then rename it to avoid file locking race condition + $_tmp_file = tempnam($_dirname, 'wrt'); + + if (!($fd = @fopen($_tmp_file, 'wb'))) { + $_tmp_file = $_dirname . DIRECTORY_SEPARATOR . uniqid('wrt'); + if (!($fd = @fopen($_tmp_file, 'wb'))) { + $smarty->trigger_error("problem writing temporary file '$_tmp_file'"); + return false; + } + } + + fwrite($fd, $params['contents']); + fclose($fd); + + if (DIRECTORY_SEPARATOR == '\\' || !@rename($_tmp_file, $params['filename'])) { + // On platforms and filesystems that cannot overwrite with rename() + // delete the file before renaming it -- because windows always suffers + // this, it is short-circuited to avoid the initial rename() attempt + @unlink($params['filename']); + @rename($_tmp_file, $params['filename']); + } + @chmod($params['filename'], $smarty->_file_perms); + + return true; +} + +/* vim: set expandtab: */ + +?> \ No newline at end of file diff --git a/includes/onyx/templates/libs/plugins/block.textformat.php b/includes/onyx/templates/libs/plugins/block.textformat.php new file mode 100644 index 0000000..8cd010a --- /dev/null +++ b/includes/onyx/templates/libs/plugins/block.textformat.php @@ -0,0 +1,103 @@ + + * Name: textformat
    + * Purpose: format text a certain way with preset styles + * or custom wrap/indent settings
    + * @link http://smarty.php.net/manual/en/language.function.textformat.php {textformat} + * (Smarty online manual) + * @param array + *
    + * Params:   style: string (email)
    + *           indent: integer (0)
    + *           wrap: integer (80)
    + *           wrap_char string ("\n")
    + *           indent_char: string (" ")
    + *           wrap_boundary: boolean (true)
    + * 
    + * @author Monte Ohrt + * @param string contents of the block + * @param Smarty clever simulation of a method + * @return string string $content re-formatted + */ +function smarty_block_textformat($params, $content, &$smarty) +{ + if (is_null($content)) { + return; + } + + $style = null; + $indent = 0; + $indent_first = 0; + $indent_char = ' '; + $wrap = 80; + $wrap_char = "\n"; + $wrap_cut = false; + $assign = null; + + foreach ($params as $_key => $_val) { + switch ($_key) { + case 'style': + case 'indent_char': + case 'wrap_char': + case 'assign': + $$_key = (string)$_val; + break; + + case 'indent': + case 'indent_first': + case 'wrap': + $$_key = (int)$_val; + break; + + case 'wrap_cut': + $$_key = (bool)$_val; + break; + + default: + $smarty->trigger_error("textformat: unknown attribute '$_key'"); + } + } + + if ($style == 'email') { + $wrap = 72; + } + + // split into paragraphs + $_paragraphs = preg_split('![\r\n][\r\n]!',$content); + $_output = ''; + + for($_x = 0, $_y = count($_paragraphs); $_x < $_y; $_x++) { + if ($_paragraphs[$_x] == '') { + continue; + } + // convert mult. spaces & special chars to single space + $_paragraphs[$_x] = preg_replace(array('!\s+!','!(^\s+)|(\s+$)!'), array(' ',''), $_paragraphs[$_x]); + // indent first line + if($indent_first > 0) { + $_paragraphs[$_x] = str_repeat($indent_char, $indent_first) . $_paragraphs[$_x]; + } + // wordwrap sentences + $_paragraphs[$_x] = wordwrap($_paragraphs[$_x], $wrap - $indent, $wrap_char, $wrap_cut); + // indent lines + if($indent > 0) { + $_paragraphs[$_x] = preg_replace('!^!m', str_repeat($indent_char, $indent), $_paragraphs[$_x]); + } + } + $_output = implode($wrap_char . $wrap_char, $_paragraphs); + + return $assign ? $smarty->assign($assign, $_output) : $_output; + +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/compiler.assign.php b/includes/onyx/templates/libs/plugins/compiler.assign.php new file mode 100644 index 0000000..abef377 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/compiler.assign.php @@ -0,0 +1,40 @@ + + * Name: assign
    + * Purpose: assign a value to a template variable + * @link http://smarty.php.net/manual/en/language.custom.functions.php#LANGUAGE.FUNCTION.ASSIGN {assign} + * (Smarty online manual) + * @author Monte Ohrt (initial author) + * @author messju mohr (conversion to compiler function) + * @param string containing var-attribute and value-attribute + * @param Smarty_Compiler + */ +function smarty_compiler_assign($tag_attrs, &$compiler) +{ + $_params = $compiler->_parse_attrs($tag_attrs); + + if (!isset($_params['var'])) { + $compiler->_syntax_error("assign: missing 'var' parameter", E_USER_WARNING); + return; + } + + if (!isset($_params['value'])) { + $compiler->_syntax_error("assign: missing 'value' parameter", E_USER_WARNING); + return; + } + + return "\$this->assign({$_params['var']}, {$_params['value']});"; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.assign_debug_info.php b/includes/onyx/templates/libs/plugins/function.assign_debug_info.php new file mode 100644 index 0000000..6540498 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.assign_debug_info.php @@ -0,0 +1,40 @@ + + * Name: assign_debug_info
    + * Purpose: assign debug info to the template
    + * @author Monte Ohrt + * @param array unused in this plugin, this plugin uses {@link Smarty::$_config}, + * {@link Smarty::$_tpl_vars} and {@link Smarty::$_smarty_debug_info} + * @param Smarty + */ +function smarty_function_assign_debug_info($params, &$smarty) +{ + $assigned_vars = $smarty->_tpl_vars; + ksort($assigned_vars); + if (@is_array($smarty->_config[0])) { + $config_vars = $smarty->_config[0]; + ksort($config_vars); + $smarty->assign("_debug_config_keys", array_keys($config_vars)); + $smarty->assign("_debug_config_vals", array_values($config_vars)); + } + + $included_templates = $smarty->_smarty_debug_info; + + $smarty->assign("_debug_keys", array_keys($assigned_vars)); + $smarty->assign("_debug_vals", array_values($assigned_vars)); + + $smarty->assign("_debug_tpls", $included_templates); +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.config_load.php b/includes/onyx/templates/libs/plugins/function.config_load.php new file mode 100644 index 0000000..db89f63 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.config_load.php @@ -0,0 +1,142 @@ + + * Name: config_load
    + * Purpose: load config file vars + * @link http://smarty.php.net/manual/en/language.function.config.load.php {config_load} + * (Smarty online manual) + * @author Monte Ohrt + * @author messju mohr (added use of resources) + * @param array Format: + *
    + * array('file' => required config file name,
    + *       'section' => optional config file section to load
    + *       'scope' => local/parent/global
    + *       'global' => overrides scope, setting to parent if true)
    + * 
    + * @param Smarty + */ +function smarty_function_config_load($params, &$smarty) +{ + if ($smarty->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $_debug_start_time = smarty_core_get_microtime($_params, $smarty); + } + + $_file = isset($params['file']) ? $smarty->_dequote($params['file']) : null; + $_section = isset($params['section']) ? $smarty->_dequote($params['section']) : null; + $_scope = isset($params['scope']) ? $smarty->_dequote($params['scope']) : 'global'; + $_global = isset($params['global']) ? $smarty->_dequote($params['global']) : false; + + if (!isset($_file) || strlen($_file) == 0) { + $smarty->trigger_error("missing 'file' attribute in config_load tag", E_USER_ERROR, __FILE__, __LINE__); + } + + if (isset($_scope)) { + if ($_scope != 'local' && + $_scope != 'parent' && + $_scope != 'global') { + $smarty->trigger_error("invalid 'scope' attribute value", E_USER_ERROR, __FILE__, __LINE__); + } + } else { + if ($_global) { + $_scope = 'parent'; + } else { + $_scope = 'local'; + } + } + + $_params = array('resource_name' => $_file, + 'resource_base_path' => $smarty->config_dir, + 'get_source' => false); + $smarty->_parse_resource_name($_params); + $_file_path = $_params['resource_type'] . ':' . $_params['resource_name']; + if (isset($_section)) + $_compile_file = $smarty->_get_compile_path($_file_path.'|'.$_section); + else + $_compile_file = $smarty->_get_compile_path($_file_path); + + if($smarty->force_compile || !file_exists($_compile_file)) { + $_compile = true; + } elseif ($smarty->compile_check) { + $_params = array('resource_name' => $_file, + 'resource_base_path' => $smarty->config_dir, + 'get_source' => false); + $_compile = $smarty->_fetch_resource_info($_params) && + $_params['resource_timestamp'] > filemtime($_compile_file); + } else { + $_compile = false; + } + + if($_compile) { + // compile config file + if(!is_object($smarty->_conf_obj)) { + require_once SMARTY_DIR . $smarty->config_class . '.class.php'; + $smarty->_conf_obj = new $smarty->config_class(); + $smarty->_conf_obj->overwrite = $smarty->config_overwrite; + $smarty->_conf_obj->booleanize = $smarty->config_booleanize; + $smarty->_conf_obj->read_hidden = $smarty->config_read_hidden; + $smarty->_conf_obj->fix_newlines = $smarty->config_fix_newlines; + } + + $_params = array('resource_name' => $_file, + 'resource_base_path' => $smarty->config_dir, + $_params['get_source'] = true); + if (!$smarty->_fetch_resource_info($_params)) { + return; + } + $smarty->_conf_obj->set_file_contents($_file, $_params['source_content']); + $_config_vars = array_merge($smarty->_conf_obj->get($_file), + $smarty->_conf_obj->get($_file, $_section)); + if(function_exists('var_export')) { + $_output = ''; + } else { + $_output = ''\\\'', '\\'=>'\\\\')) . '\'); ?>'; + } + $_params = (array('compile_path' => $_compile_file, 'compiled_content' => $_output, 'resource_timestamp' => $_params['resource_timestamp'])); + require_once(SMARTY_CORE_DIR . 'core.write_compiled_resource.php'); + smarty_core_write_compiled_resource($_params, $smarty); + } else { + include($_compile_file); + } + + if ($smarty->caching) { + $smarty->_cache_info['config'][$_file] = true; + } + + $smarty->_config[0]['vars'] = @array_merge($smarty->_config[0]['vars'], $_config_vars); + $smarty->_config[0]['files'][$_file] = true; + + if ($_scope == 'parent') { + $smarty->_config[1]['vars'] = @array_merge($smarty->_config[1]['vars'], $_config_vars); + $smarty->_config[1]['files'][$_file] = true; + } else if ($_scope == 'global') { + for ($i = 1, $for_max = count($smarty->_config); $i < $for_max; $i++) { + $smarty->_config[$i]['vars'] = @array_merge($smarty->_config[$i]['vars'], $_config_vars); + $smarty->_config[$i]['files'][$_file] = true; + } + } + + if ($smarty->debugging) { + $_params = array(); + require_once(SMARTY_CORE_DIR . 'core.get_microtime.php'); + $smarty->_smarty_debug_info[] = array('type' => 'config', + 'filename' => $_file.' ['.$_section.'] '.$_scope, + 'depth' => $smarty->_inclusion_depth, + 'exec_time' => smarty_core_get_microtime($_params, $smarty) - $_debug_start_time); + } + +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.counter.php b/includes/onyx/templates/libs/plugins/function.counter.php new file mode 100644 index 0000000..1f26db5 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.counter.php @@ -0,0 +1,80 @@ + + * Name: counter
    + * Purpose: print out a counter value + * @author Monte Ohrt + * @link http://smarty.php.net/manual/en/language.function.counter.php {counter} + * (Smarty online manual) + * @param array parameters + * @param Smarty + * @return string|null + */ +function smarty_function_counter($params, &$smarty) +{ + static $counters = array(); + + $name = (isset($params['name'])) ? $params['name'] : 'default'; + if (!isset($counters[$name])) { + $counters[$name] = array( + 'start'=>1, + 'skip'=>1, + 'direction'=>'up', + 'count'=>1 + ); + } + $counter =& $counters[$name]; + + if (isset($params['start'])) { + $counter['start'] = $counter['count'] = (int)$params['start']; + } + + if (!empty($params['assign'])) { + $counter['assign'] = $params['assign']; + } + + if (isset($counter['assign'])) { + $smarty->assign($counter['assign'], $counter['count']); + } + + if (isset($params['print'])) { + $print = (bool)$params['print']; + } else { + $print = empty($counter['assign']); + } + + if ($print) { + $retval = $counter['count']; + } else { + $retval = null; + } + + if (isset($params['skip'])) { + $counter['skip'] = $params['skip']; + } + + if (isset($params['direction'])) { + $counter['direction'] = $params['direction']; + } + + if ($counter['direction'] == "down") + $counter['count'] -= $counter['skip']; + else + $counter['count'] += $counter['skip']; + + return $retval; + +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.cycle.php b/includes/onyx/templates/libs/plugins/function.cycle.php new file mode 100644 index 0000000..fe78bb8 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.cycle.php @@ -0,0 +1,102 @@ + + * Name: cycle
    + * Date: May 3, 2002
    + * Purpose: cycle through given values
    + * Input: + * - name = name of cycle (optional) + * - values = comma separated list of values to cycle, + * or an array of values to cycle + * (this can be left out for subsequent calls) + * - reset = boolean - resets given var to true + * - print = boolean - print var or not. default is true + * - advance = boolean - whether or not to advance the cycle + * - delimiter = the value delimiter, default is "," + * - assign = boolean, assigns to template var instead of + * printed. + * + * Examples:
    + *
    + * {cycle values="#eeeeee,#d0d0d0d"}
    + * {cycle name=row values="one,two,three" reset=true}
    + * {cycle name=row}
    + * 
    + * @link http://smarty.php.net/manual/en/language.function.cycle.php {cycle} + * (Smarty online manual) + * @author Monte Ohrt + * @author credit to Mark Priatel + * @author credit to Gerard + * @author credit to Jason Sweat + * @version 1.3 + * @param array + * @param Smarty + * @return string|null + */ +function smarty_function_cycle($params, &$smarty) +{ + static $cycle_vars; + + $name = (empty($params['name'])) ? 'default' : $params['name']; + $print = (isset($params['print'])) ? (bool)$params['print'] : true; + $advance = (isset($params['advance'])) ? (bool)$params['advance'] : true; + $reset = (isset($params['reset'])) ? (bool)$params['reset'] : false; + + if (!in_array('values', array_keys($params))) { + if(!isset($cycle_vars[$name]['values'])) { + $smarty->trigger_error("cycle: missing 'values' parameter"); + return; + } + } else { + if(isset($cycle_vars[$name]['values']) + && $cycle_vars[$name]['values'] != $params['values'] ) { + $cycle_vars[$name]['index'] = 0; + } + $cycle_vars[$name]['values'] = $params['values']; + } + + $cycle_vars[$name]['delimiter'] = (isset($params['delimiter'])) ? $params['delimiter'] : ','; + + if(is_array($cycle_vars[$name]['values'])) { + $cycle_array = $cycle_vars[$name]['values']; + } else { + $cycle_array = explode($cycle_vars[$name]['delimiter'],$cycle_vars[$name]['values']); + } + + if(!isset($cycle_vars[$name]['index']) || $reset ) { + $cycle_vars[$name]['index'] = 0; + } + + if (isset($params['assign'])) { + $print = false; + $smarty->assign($params['assign'], $cycle_array[$cycle_vars[$name]['index']]); + } + + if($print) { + $retval = $cycle_array[$cycle_vars[$name]['index']]; + } else { + $retval = null; + } + + if($advance) { + if ( $cycle_vars[$name]['index'] >= count($cycle_array) -1 ) { + $cycle_vars[$name]['index'] = 0; + } else { + $cycle_vars[$name]['index']++; + } + } + + return $retval; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.debug.php b/includes/onyx/templates/libs/plugins/function.debug.php new file mode 100644 index 0000000..4345230 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.debug.php @@ -0,0 +1,35 @@ + + * Name: debug
    + * Date: July 1, 2002
    + * Purpose: popup debug window + * @link http://smarty.php.net/manual/en/language.function.debug.php {debug} + * (Smarty online manual) + * @author Monte Ohrt + * @version 1.0 + * @param array + * @param Smarty + * @return string output from {@link Smarty::_generate_debug_output()} + */ +function smarty_function_debug($params, &$smarty) +{ + if (isset($params['output'])) { + $smarty->assign('_smarty_debug_output', $params['output']); + } + require_once(SMARTY_CORE_DIR . 'core.display_debug_console.php'); + return smarty_core_display_debug_console(null, $smarty); +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.eval.php b/includes/onyx/templates/libs/plugins/function.eval.php new file mode 100644 index 0000000..ff0472d --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.eval.php @@ -0,0 +1,49 @@ + + * Name: eval
    + * Purpose: evaluate a template variable as a template
    + * @link http://smarty.php.net/manual/en/language.function.eval.php {eval} + * (Smarty online manual) + * @author Monte Ohrt + * @param array + * @param Smarty + */ +function smarty_function_eval($params, &$smarty) +{ + + if (!isset($params['var'])) { + $smarty->trigger_error("eval: missing 'var' parameter"); + return; + } + + if($params['var'] == '') { + return; + } + + $smarty->_compile_source('evaluated template', $params['var'], $_var_compiled); + + ob_start(); + $smarty->_eval('?>' . $_var_compiled); + $_contents = ob_get_contents(); + ob_end_clean(); + + if (!empty($params['assign'])) { + $smarty->assign($params['assign'], $_contents); + } else { + return $_contents; + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.fetch.php b/includes/onyx/templates/libs/plugins/function.fetch.php new file mode 100644 index 0000000..81b1bfc --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.fetch.php @@ -0,0 +1,221 @@ + + * Name: fetch
    + * Purpose: fetch file, web or ftp data and display results + * @link http://smarty.php.net/manual/en/language.function.fetch.php {fetch} + * (Smarty online manual) + * @author Monte Ohrt + * @param array + * @param Smarty + * @return string|null if the assign parameter is passed, Smarty assigns the + * result to a template variable + */ +function smarty_function_fetch($params, &$smarty) +{ + if (empty($params['file'])) { + $smarty->_trigger_fatal_error("[plugin] parameter 'file' cannot be empty"); + return; + } + + $content = ''; + if ($smarty->security && !preg_match('!^(http|ftp)://!i', $params['file'])) { + $_params = array('resource_type' => 'file', 'resource_name' => $params['file']); + require_once(SMARTY_CORE_DIR . 'core.is_secure.php'); + if(!smarty_core_is_secure($_params, $smarty)) { + $smarty->_trigger_fatal_error('[plugin] (secure mode) fetch \'' . $params['file'] . '\' is not allowed'); + return; + } + + // fetch the file + if($fp = @fopen($params['file'],'r')) { + while(!feof($fp)) { + $content .= fgets ($fp,4096); + } + fclose($fp); + } else { + $smarty->_trigger_fatal_error('[plugin] fetch cannot read file \'' . $params['file'] . '\''); + return; + } + } else { + // not a local file + if(preg_match('!^http://!i',$params['file'])) { + // http fetch + if($uri_parts = parse_url($params['file'])) { + // set defaults + $host = $server_name = $uri_parts['host']; + $timeout = 30; + $accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*"; + $agent = "Smarty Template Engine ".$smarty->_version; + $referer = ""; + $uri = !empty($uri_parts['path']) ? $uri_parts['path'] : '/'; + $uri .= !empty($uri_parts['query']) ? '?' . $uri_parts['query'] : ''; + $_is_proxy = false; + if(empty($uri_parts['port'])) { + $port = 80; + } else { + $port = $uri_parts['port']; + } + if(!empty($uri_parts['user'])) { + $user = $uri_parts['user']; + } + if(!empty($uri_parts['pass'])) { + $pass = $uri_parts['pass']; + } + // loop through parameters, setup headers + foreach($params as $param_key => $param_value) { + switch($param_key) { + case "file": + case "assign": + case "assign_headers": + break; + case "user": + if(!empty($param_value)) { + $user = $param_value; + } + break; + case "pass": + if(!empty($param_value)) { + $pass = $param_value; + } + break; + case "accept": + if(!empty($param_value)) { + $accept = $param_value; + } + break; + case "header": + if(!empty($param_value)) { + if(!preg_match('![\w\d-]+: .+!',$param_value)) { + $smarty->_trigger_fatal_error("[plugin] invalid header format '".$param_value."'"); + return; + } else { + $extra_headers[] = $param_value; + } + } + break; + case "proxy_host": + if(!empty($param_value)) { + $proxy_host = $param_value; + } + break; + case "proxy_port": + if(!preg_match('!\D!', $param_value)) { + $proxy_port = (int) $param_value; + } else { + $smarty->_trigger_fatal_error("[plugin] invalid value for attribute '".$param_key."'"); + return; + } + break; + case "agent": + if(!empty($param_value)) { + $agent = $param_value; + } + break; + case "referer": + if(!empty($param_value)) { + $referer = $param_value; + } + break; + case "timeout": + if(!preg_match('!\D!', $param_value)) { + $timeout = (int) $param_value; + } else { + $smarty->_trigger_fatal_error("[plugin] invalid value for attribute '".$param_key."'"); + return; + } + break; + default: + $smarty->_trigger_fatal_error("[plugin] unrecognized attribute '".$param_key."'"); + return; + } + } + if(!empty($proxy_host) && !empty($proxy_port)) { + $_is_proxy = true; + $fp = fsockopen($proxy_host,$proxy_port,$errno,$errstr,$timeout); + } else { + $fp = fsockopen($server_name,$port,$errno,$errstr,$timeout); + } + + if(!$fp) { + $smarty->_trigger_fatal_error("[plugin] unable to fetch: $errstr ($errno)"); + return; + } else { + if($_is_proxy) { + fputs($fp, 'GET ' . $params['file'] . " HTTP/1.0\r\n"); + } else { + fputs($fp, "GET $uri HTTP/1.0\r\n"); + } + if(!empty($host)) { + fputs($fp, "Host: $host\r\n"); + } + if(!empty($accept)) { + fputs($fp, "Accept: $accept\r\n"); + } + if(!empty($agent)) { + fputs($fp, "User-Agent: $agent\r\n"); + } + if(!empty($referer)) { + fputs($fp, "Referer: $referer\r\n"); + } + if(isset($extra_headers) && is_array($extra_headers)) { + foreach($extra_headers as $curr_header) { + fputs($fp, $curr_header."\r\n"); + } + } + if(!empty($user) && !empty($pass)) { + fputs($fp, "Authorization: BASIC ".base64_encode("$user:$pass")."\r\n"); + } + + fputs($fp, "\r\n"); + while(!feof($fp)) { + $content .= fgets($fp,4096); + } + fclose($fp); + $csplit = split("\r\n\r\n",$content,2); + + $content = $csplit[1]; + + if(!empty($params['assign_headers'])) { + $smarty->assign($params['assign_headers'],split("\r\n",$csplit[0])); + } + } + } else { + $smarty->_trigger_fatal_error("[plugin] unable to parse URL, check syntax"); + return; + } + } else { + // ftp fetch + if($fp = @fopen($params['file'],'r')) { + while(!feof($fp)) { + $content .= fgets ($fp,4096); + } + fclose($fp); + } else { + $smarty->_trigger_fatal_error('[plugin] fetch cannot read file \'' . $params['file'] .'\''); + return; + } + } + + } + + + if (!empty($params['assign'])) { + $smarty->assign($params['assign'],$content); + } else { + return $content; + } +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.html_checkboxes.php b/includes/onyx/templates/libs/plugins/function.html_checkboxes.php new file mode 100644 index 0000000..ed8ad7f --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.html_checkboxes.php @@ -0,0 +1,143 @@ + + * Type: function
    + * Name: html_checkboxes
    + * Date: 24.Feb.2003
    + * Purpose: Prints out a list of checkbox input types
    + * Input:
    + * - name (optional) - string default "checkbox" + * - values (required) - array + * - options (optional) - associative array + * - checked (optional) - array default not set + * - separator (optional) - ie
    or   + * - output (optional) - the output next to each checkbox + * - assign (optional) - assign the output as an array to this variable + * Examples: + *
    + * {html_checkboxes values=$ids output=$names}
    + * {html_checkboxes values=$ids name='box' separator='
    ' output=$names} + * {html_checkboxes values=$ids checked=$checked separator='
    ' output=$names} + *
    + * @link http://smarty.php.net/manual/en/language.function.html.checkboxes.php {html_checkboxes} + * (Smarty online manual) + * @author Christopher Kvarme + * @author credits to Monte Ohrt + * @version 1.0 + * @param array + * @param Smarty + * @return string + * @uses smarty_function_escape_special_chars() + */ +function smarty_function_html_checkboxes($params, &$smarty) +{ + require_once $smarty->_get_plugin_filepath('shared','escape_special_chars'); + + $name = 'checkbox'; + $values = null; + $options = null; + $selected = null; + $separator = ''; + $labels = true; + $output = null; + + $extra = ''; + + foreach($params as $_key => $_val) { + switch($_key) { + case 'name': + case 'separator': + $$_key = $_val; + break; + + case 'labels': + $$_key = (bool)$_val; + break; + + case 'options': + $$_key = (array)$_val; + break; + + case 'values': + case 'output': + $$_key = array_values((array)$_val); + break; + + case 'checked': + case 'selected': + $selected = array_map('strval', array_values((array)$_val)); + break; + + case 'checkboxes': + $smarty->trigger_error('html_checkboxes: the use of the "checkboxes" attribute is deprecated, use "options" instead', E_USER_WARNING); + $options = (array)$_val; + break; + + case 'assign': + break; + + default: + if(!is_array($_val)) { + $extra .= ' '.$_key.'="'.smarty_function_escape_special_chars($_val).'"'; + } else { + $smarty->trigger_error("html_checkboxes: extra attribute '$_key' cannot be an array", E_USER_NOTICE); + } + break; + } + } + + if (!isset($options) && !isset($values)) + return ''; /* raise error here? */ + + settype($selected, 'array'); + $_html_result = array(); + + if (isset($options)) { + + foreach ($options as $_key=>$_val) + $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels); + + + } else { + foreach ($values as $_i=>$_key) { + $_val = isset($output[$_i]) ? $output[$_i] : ''; + $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels); + } + + } + + if(!empty($params['assign'])) { + $smarty->assign($params['assign'], $_html_result); + } else { + return implode("\n",$_html_result); + } + +} + +function smarty_function_html_checkboxes_output($name, $value, $output, $selected, $extra, $separator, $labels) { + $_output = ''; + if ($labels) $_output .= ''; + $_output .= $separator; + + return $_output; +} + +?> diff --git a/includes/onyx/templates/libs/plugins/function.html_image.php b/includes/onyx/templates/libs/plugins/function.html_image.php new file mode 100644 index 0000000..9abae72 --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.html_image.php @@ -0,0 +1,142 @@ + + * Name: html_image
    + * Date: Feb 24, 2003
    + * Purpose: format HTML tags for the image
    + * Input:
    + * - file = file (and path) of image (required) + * - height = image height (optional, default actual height) + * - width = image width (optional, default actual width) + * - basedir = base directory for absolute paths, default + * is environment variable DOCUMENT_ROOT + * - path_prefix = prefix for path output (optional, default empty) + * + * Examples: {html_image file="/images/masthead.gif"} + * Output: + * @link http://smarty.php.net/manual/en/language.function.html.image.php {html_image} + * (Smarty online manual) + * @author Monte Ohrt + * @author credits to Duda - wrote first image function + * in repository, helped with lots of functionality + * @version 1.0 + * @param array + * @param Smarty + * @return string + * @uses smarty_function_escape_special_chars() + */ +function smarty_function_html_image($params, &$smarty) +{ + require_once $smarty->_get_plugin_filepath('shared','escape_special_chars'); + + $alt = ''; + $file = ''; + $height = ''; + $width = ''; + $extra = ''; + $prefix = ''; + $suffix = ''; + $path_prefix = ''; + $server_vars = ($smarty->request_use_auto_globals) ? $_SERVER : $GLOBALS['HTTP_SERVER_VARS']; + $basedir = isset($server_vars['DOCUMENT_ROOT']) ? $server_vars['DOCUMENT_ROOT'] : ''; + foreach($params as $_key => $_val) { + switch($_key) { + case 'file': + case 'height': + case 'width': + case 'dpi': + case 'path_prefix': + case 'basedir': + $$_key = $_val; + break; + + case 'alt': + if(!is_array($_val)) { + $$_key = smarty_function_escape_special_chars($_val); + } else { + $smarty->trigger_error("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE); + } + break; + + case 'link': + case 'href': + $prefix = ''; + $suffix = ''; + break; + + default: + if(!is_array($_val)) { + $extra .= ' '.$_key.'="'.smarty_function_escape_special_chars($_val).'"'; + } else { + $smarty->trigger_error("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE); + } + break; + } + } + + if (empty($file)) { + $smarty->trigger_error("html_image: missing 'file' parameter", E_USER_NOTICE); + return; + } + + if (substr($file,0,1) == '/') { + $_image_path = $basedir . $file; + } else { + $_image_path = $file; + } + + if(!isset($params['width']) || !isset($params['height'])) { + if(!$_image_data = @getimagesize($_image_path)) { + if(!file_exists($_image_path)) { + $smarty->trigger_error("html_image: unable to find '$_image_path'", E_USER_NOTICE); + return; + } else if(!is_readable($_image_path)) { + $smarty->trigger_error("html_image: unable to read '$_image_path'", E_USER_NOTICE); + return; + } else { + $smarty->trigger_error("html_image: '$_image_path' is not a valid image file", E_USER_NOTICE); + return; + } + } + if ($smarty->security && + ($_params = array('resource_type' => 'file', 'resource_name' => $_image_path)) && + (require_once(SMARTY_CORE_DIR . 'core.is_secure.php')) && + (!smarty_core_is_secure($_params, $smarty)) ) { + $smarty->trigger_error("html_image: (secure) '$_image_path' not in secure directory", E_USER_NOTICE); + } + + if(!isset($params['width'])) { + $width = $_image_data[0]; + } + if(!isset($params['height'])) { + $height = $_image_data[1]; + } + + } + + if(isset($params['dpi'])) { + if(strstr($server_vars['HTTP_USER_AGENT'], 'Mac')) { + $dpi_default = 72; + } else { + $dpi_default = 96; + } + $_resize = $dpi_default/$params['dpi']; + $width = round($width * $_resize); + $height = round($height * $_resize); + } + + return $prefix . ''.$alt.'' . $suffix; +} + +/* vim: set expandtab: */ + +?> diff --git a/includes/onyx/templates/libs/plugins/function.html_options.php b/includes/onyx/templates/libs/plugins/function.html_options.php new file mode 100644 index 0000000..cebadde --- /dev/null +++ b/includes/onyx/templates/libs/plugins/function.html_options.php @@ -0,0 +1,122 @@ + + * Name: html_options
    + * Input:
    + * - name (optional) - string default "select" + * - values (required if no options supplied) - array + * - options (required if no values supplied) - associative array + * - selected (optional) - string default not set + * - output (required if not options supplied) - array + * Purpose: Prints the list of