PHPIndex

This page lists files in the current directory. You can view content, get download/execute commands for Wget, Curl, or PowerShell, or filter the list using wildcards (e.g., `*.sh`).

lang
config_upload.inc
wget 'https://lists2.roe3.org/guppy/admin/editors/upload/config_upload.inc'
View Content
<?php
/*******************************************************************************
 *   Upload config réalisé par Djchouix - Licence CeCILL
 *   Web site = http://lebrikabrak.free.fr/
 *   e-mail   = lebrikabrak@free.fr
 *******************************************************************************
 *   GuppY PHP Script - version 6
 *   CeCILL Copyright (C) 2004-2022 by Laurent Duveau
 *   Initiated by Laurent Duveau and Nicolas Alves
 *   Web site = http://www.freeguppy.org/
 *   e-mail   = guppy@freeguppy.org
 *   V5 developed by Lud Bienaimé
 *      with the participation of the GuppY Team
 *******************************************************************************
 *   Latest Changes :
 * v6.00.17 (January 23, 2024) : add avif type and control Php version
 ******************************************************************************/

if (stristr($_SERVER["SCRIPT_NAME"], "default_config_upload.inc")) {
	header("location:../index.php");
	die();
}
$pathRepUpload ='admin/editors/';  //chemin relatif du répertoire Upload ( à modifier si vous voulez placer ce répertoire ailleurs)
	
$allowedUpload = true;  //Autorisation (TRUE) ou NON (FALSE) pour Upload
$allowedCreateRep = true;  //Autorisation (TRUE) ou NON (FALSE) pour la Création de Répertoire
$allowedRenameRepFile = true;  //Autorisation (TRUE) ou NON (FALSE) pour Renommer des Répertoires ou des Fichiers
$allowedDeleteRepFile = true;  //Autorisation (TRUE) ou NON (FALSE) pour la Suppression des Répertoires ou des Fichiers

$allowedExtFileUpload = array();  //Extensions des fichiers UNIQUEMENT autorisés à être uploadés (laisser vide pour autoriser toutes les extensions)
$deniedExtFileUpload = array();  //Extensions des fichiers NON autorisés à être uploadés (laisser vide pour autoriser toutes les extensions)

$accessRepUpload = array('file','img','photo','pages'); //Nom des répertoires à la racine de Guppy accessibles pour le fichier Upload	(création si nécessaire) 
                                                        //Attention: pour les noms de répertoire, seuls les caractères alphanumériques (a-z A-Z 0-9) ainsi que les caractères (-  _)	sont autorisés et vous ne devez pas mettre d'espace.	
$accessRepUploadImage = array('img','photo','skins'); //Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion d'Images.(accès avec variable $uptype='Image')
                                                      //Attention: vous devez choisir les répertoires uniquement parmi la liste des répertoires contenus dans la variable $accessRepUpload ci-dessus
$accessRepUploadLink = array('file','img','photo','pages'); //Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion de Liens (accès avec variable $uptype='Link')
                                                            //Attention: vous devez choisir les répertoires uniquement parmi la liste des répertoires contenus dans la variable $accessRepUpload ci-dessus
$accessRepUploadMedia = array('img'); //Accès aux répertoires à la racine de Guppy pour les fichiers Audio et Video (accès avec variable $uptype='Media')
                                      //Attention: vous devez choisir les répertoires uniquement parmi la liste des répertoires contenus dans la variable $accessRepUpload ci-dessus

if (version_compare(PHP_VERSION, '8.1.0') >= 0 && version_compare(PHP_VERSION, '8.2.0') < 0) {
	$allowedExtImage = array('.jpg','.gif','.png','.bmp','.jpeg','.JPG','.GIF','.PNG','.BMP','.JPEG');  //Extensions UNIQUEMENT autorisées pour récupérer URL des Images (accès avec variable $uptype='Image')
}
else
	$allowedExtImage = array('.jpg','.gif','.png','.bmp','.jpeg','.JPG','.GIF','.PNG','.BMP','.JPEG','.webp','.avif');  //Extensions UNIQUEMENT autorisées pour récupérer URL des Images (accès avec variable $uptype='Image')

$deniedExtLink = array();  //Extensions NON autorisées pour récupérer URL des Liens (laisser vide pour autoriser toutes les extensions) (accès avec variable $uptype='Link')
$allowedExtMedia = array('.avi','.mp3','.AVI','.MP3'); //Extensions UNIQUEMENT autorisées pour récupérer URL des fichiers Audio et Video (accès avec variable $uptype='Media')

//STYLE CSS DE LA POPUP UPLOAD
$colorTextTitre = '#000000';  //couleur du titre
$colorFondTitre = '#7F7F7F';  //couleur de fond du titre
$styleBordureTitre = '1px solid #7F7F7F';  //bordure du titre
$colorTextCorp = '#000000';   //couleur du texte
$colorFondCorp = '#000000';   //couleur du fond de page
$styleBordureCorp = '1px solid #7F7F7F';  //bordure du corps
$colorBodyUpload = '#EFEFEF';  //couleur de fond de page (popup upload)
$colorFondFileUpload = '#EFEFEF'; //couleur du fond du tableau (popup upload)
$colorFondFileUploadOver = '#E7E1EF';  //couleur de fond des fichiers lors du survol de la souris (popup upload)
$colorFileUploadOff = '#000000';  //couleur des liens off (popup upload)
$colorFileUploadOn = '#FF0000';  //couleur des liens on (popup upload)
?>
functions_upload.inc
wget 'https://lists2.roe3.org/guppy/admin/editors/upload/functions_upload.inc'
View Content
<?php
/*******************************************************************************
 *   MinieditorTextarea réalisé par Djchouix - Licence CeCILL
 *   Web site = http://lebrikabrak.free.fr/
 *   e-mail   = lebrikabrak@free.fr
 *******************************************************************************
 *   GuppY PHP Script - version 6
 *   CeCILL Copyright (C) 2004-2020 by Laurent Duveau
 *   Initiated by Laurent Duveau and Nicolas Alves
 *   Web site = http://www.freeguppy.org/
 *   e-mail   = guppy@freeguppy.org
 *   V5 developed by Lud Bienaimé
 *      with the participation of the GuppY Team
 *******************************************************************************
 *   Latest Changes :
 * v6.00.06 (January 13, 2022) : update ckeditor
 ******************************************************************************/

if (stristr($_SERVER["SCRIPT_NAME"], "functions_upload.inc")) {
	header("location:../index.php");
	die();
}

//Fonction pour contrôler et corriger le nom d'un répertoire ou d'un fichier
function cleanName($name,$up=false) {
	$nameclean = trim($name);
	$nameclean = str_replace(' ','_',$nameclean);
	$nameclean = str_replace('à','a',$nameclean);
	$nameclean = preg_replace('![éèê]!','e',$nameclean);
	$nameclean = preg_replace('![îï]!','i',$nameclean);
	$nameclean =($up)? preg_replace('![^-a-zA-Z0-9_\.]!','',$nameclean) : preg_replace('![^-a-zA-Z0-9_]!','',$nameclean);
	return $nameclean;
}

//Fonction pour créer un répertoire accessible à l'upload s'il n'existe pas
function createNewRep($newrep) {
    MakeDir(CHEMIN.$newrep);
	SetChmod(CHEMIN.$newrep);
	@copy(CHEMIN."admin/inc/index.php", CHEMIN.$newrep."/index.php");
	SetChmod(CHEMIN.$newrep."/index.php");
};

//Fonction pour controler la validité des répertoires accessible à l'upload
function controlNameRepUpload($nameRepUp) {
	$nbRepUp = count($nameRepUp);
	for ($i=0; $i<$nbRepUp; $i++) {
		if($nameRepUp[$i] == '' || !preg_match('!^[-a-z0-9_]+$!i',$nameRepUp[$i]) ) {
			unset($nameRepUp[$i]);
		} else {
			if ($nameRepUp[$i] == "0" ) {$nameRepUp[$i] = "0_";}
			if(!is_dir(CHEMIN.$nameRepUp[$i])) createNewRep($nameRepUp[$i]);
		}
	}
	if(count($nameRepUp) > 0) {
		$nameRepUp = array_values($nameRepUp);
		return $nameRepUp;
	} else {
		return die('Erreur dans la variable $accessRepUpload..Veuillez vérifier qu\'elle n\'est pas vide ou que les noms des répertoires sont écrits correctement.');
	}
}
/*
$accessRepUpload = array('file','img','photo','pages','skins');	//Nom des répertoires à la racine de Guppy accessibles pour le fichier Upload	(création si nécessaire) 
                                                                //Attention: pour les noms de répertoire, seuls les caractères alphanumériques (a-z A-Z 0-9) ainsi que les caractères (-  _)	sont autorisés et vous ne devez pas mettre d'espace.	
$accessRepUploadImage = array('img','photo','skins'); //Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion d'Images.(accès avec variable $uptype='Image')
                                                      //Attention: vous devez choisir les répertoires uniquement parmi la liste des répertoires contenus dans la variable $accessRepUpload ci-dessus
$accessRepUploadLink = array('file','img','photo','pages');	//Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion de Liens (accès avec variable $uptype='Link')
                                                            //Attention: vous devez choisir les répertoires uniquement parmi la liste des répertoires contenus dans la variable $accessRepUpload ci-dessus
$accessRepUploadMedia = array('img','photo'); //Accès aux répertoires à la racine de Guppy pour les fichiers Audio et Video (accès avec variable $uptype='Media')
                 
$accessRepUpload = controlNameRepUpload($accessRepUpload);
$accessRepUploadImage = controlAccessRepUpload($accessRepUploadImage,$accessRepUpload,'Image');
$accessRepUploadLink = controlAccessRepUpload($accessRepUploadLink,$accessRepUpload,'Link');
$accessRepUploadMedia = controlAccessRepUpload($accessRepUploadMedia,$accessRepUpload,'Media');
*/
//Fonction pour controler la validité des répertoires accessible à l'upload
function controlAccessRepUpload($accessRepUploadType,$accessRepUpload,$type) {
	$nbRepUp = count($accessRepUploadType);
	for ($i=0; $i<$nbRepUp; $i++) {
		if ($accessRepUploadType[$i] == "0" ) {$accessRepUploadType[$i] = "0_";}
		if(!in_array($accessRepUploadType[$i],$accessRepUpload) || $accessRepUploadType[$i] == '' || !preg_match('!^[-a-z0-9_]+$!i',$accessRepUploadType[$i]) ) unset($accessRepUploadType[$i]);
	}
	if(count($accessRepUploadType) > 0) {
		$accessRepUploadType = array_values($accessRepUploadType);
		return $accessRepUploadType;
	} else {
		return die('Erreur dans la variable $accessRepUpload'.$type.'.Veuillez vérifier qu\'elle n\'est pas vide ou que les noms des répertoires sont écrits correctement.');
	}
}

//Fonction qui permet de supprimer des sous-répertoires
function DelSubRep($sous_dossier) { 
	$d = opendir($sous_dossier); 
	while ($f = readdir($d)) {
        if(is_file($sous_dossier.$f)) {
            @unlink($sous_dossier.$f);
		}	
        if($f != '.' && $f != '..' && is_dir($sous_dossier.$f)) {
		    DelSubRep($sous_dossier.$f.'/');
            @rmdir($sous_dossier.$f);			 
		}
	}
	closedir($d);
}

?>
style_upload.css
wget 'https://lists2.roe3.org/guppy/admin/editors/upload/style_upload.css'
View Content
/*******************************************************************************
 *   MinieditorTextarea réalisé par Djchouix - Licence CeCILL
 *   Web site = http://lebrikabrak.free.fr/
 *   e-mail   = lebrikabrak@free.fr
 *******************************************************************************
 *   GuppY PHP Script - version 6.0
 *   CeCILL Copyright (C) 2004-2020 by Laurent Duveau
 *   Initiated by Laurent Duveau and Nicolas Alves
 *   Web site = https://www.freeguppy.org/
 *   e-mail   = guppy@freeguppy.org
 *   V6 developed by Lud Bienaimé
 *      with the participation of the GuppY Team
 *******************************************************************************
 *   Latest Changes :
 * v6.00.00 (December 15, 2019) : initial release
 ******************************************************************************/

body {
 font-size: 16px;
 font-family: "Times New Roman" , Arial, sans-serif;
 color: #000000; 
 background-color: #EFEFEF;
 margin:1px;
 padding-top:15px;
 padding-right:10px;
 padding-left:10px;
}

div.help {
 text-align:center;
 display:none;
 border:1px solid #E3E3C7;
 background-color:#FFFFFF;
 color:#000000;
 width:auto;
 margin:10px;
 font-weight:normal;
}

div.corpsFileScroll {
 margin-right:auto;
 margin-left:auto;
 max-width:630px;
 height:341px;
 border:1px solid #C7C78F;
 overflow:auto;
}

div.corpsFilenoScroll {
 margin-right:auto;
 margin-left:auto;
 max-width:630px;
 height:341px;
 border:1px solid #C7C78F;
 color: #000000;
 background-color: #FFFFFF;
}

div.labelupload {
 text-align:center;
 font-weight:bold;
 vertical-align:middle;
}

div.upload {
 text-align:center;
 font-weight:bold;
 vertical-align:middle;
 margin-top:10px;  
 margin-bottom:10px;
}

input.bouton {
 margin-left:10px;
 font-size: 12px;
 font-family: Arial, Helvetica, sans-serif;
}
 
a {
 color: #737357;
 background-color: transparent;
 text-decoration: none;
 cursor:pointer;
}

a:hover {
 color: #FF1010;
 text-decoration: underline;
 background-color: transparent;
 cursor:pointer;
}

/* style général du tableau */
table {
 font-size: 12px;
 font-family: Arial, Helvetica, sans-serif;
 font-weight:normal;
 color: #000000;
 background-color: #FFFFFF;
}

div.corpsFilenoScroll table {
 max-width:630px;
} 

div.corpsFileScroll table {
 width:100% !important;
 max-width:613px;
 margin: 0 auto;
}

td {
 padding:5px;
 text-align:center;
}

/*  style des titres du tableau (ligne 1 du tableau)  */
tr.forum {
 background-color: #C7C78F;
 color: #737357;
 text-align: center;
 font-weight: bold;
}
td#forumName {
 border:1px solid #FFFFFF;
}

td#forumSize {
 border-top:1px solid #FFFFFF;
 border-bottom:1px solid #FFFFFF;
}

td#forumAction {
 border:1px solid #FFFFFF;
}

/*  style des lignes et des cellules du corps du tableau   */
tr.quest {
}

tr.rep {
}

td.fileName {
 text-align:left;
 border-left:1px solid #FFFFFF;
 border-bottom:1px solid #FFFFFF;
}

td.fileSize {
 border-bottom:1px solid #FFFFFF;
}

td.fileAction {
 border-right:1px solid #FFFFFF;
 border-bottom:1px solid #FFFFFF;
}

/* style des images */
img {
 vertical-align:middle;
 margin-right:10px;
 margin-bottom:2px;
}
/* style des images dans le tableau */
img.imgName{
 vertical-align:middle;
 margin-right:10px;
 cursor:pointer;
}

a.imgName:hover{
 text-decoration:none;
}

img.imgAction {
vertical-align:middle;
cursor:pointer;
border:2px solid #FFFFFF;
margin-right:0px;
}

img.imgAction2 {
vertical-align:middle;
cursor:pointer;
margin-left:5px;
margin-right:5px;
border:2px solid #FFFFFF;
}

/*  style lors du survol de la souris sur l'élément */
tr#trsurvol {
 background-color: #E3E3C7;
 color: #000000;
}

tr#trsurvol img.imgAction {
 border:2px solid #E3E3C7;
 background-color: #E3E3C7;
 color: #000000;
}

tr#trsurvol img.imgAction2 {
 border:2px solid #E3E3C7;
 background-color: #E3E3C7;
 color: #000000;
}

tr#trsurvol img#imgsurvol {
 border:2px solid #FF1010;
 background-color: #E3E3C7;
 color: #000000;
}
upload.php
wget 'https://lists2.roe3.org/guppy/admin/editors/upload/upload.php'
View Content
<?php
/*******************************************************************************
 *   Upload réalisé par Djchouix - Licence CeCILL
 *******************************************************************************
 *   GuppY PHP Script - version 6
 *   CeCILL Copyright (C) 2004-2022 by Laurent Duveau
 *   Initiated by Laurent Duveau and Nicolas Alves
 *   Web site = https://www.freeguppy.org/
 *   e-mail   = guppy@freeguppy.org
 *   V6 developed by Lud Bienaimé
 *      with the participation of the GuppY Team
 *******************************************************************************
 *   Latest Changes :
 * v6.00.19 (August 20, 2024) : add functionnalities for redac folder
 ******************************************************************************/

header('Pragma: no-cache');
define('CHEMIN', '../../../');
include CHEMIN."admin/includes.inc";

//PROTECTION CONTRE LES PETITS CURIEUX
include CHEMIN.'admin/editors/action.php';
if ($wri == "admin") {
    $mdp    = $userprefs[1] == '' ? md5('pass') : $userprefs[7];
    $fctwri = 'admin';
} else {
    if (FileDBExist(CHEMIN.'admin/'.REDACREP.$wri.INCEXT)) {
        include(CHEMIN.'admin/'.REDACREP.$wri.INCEXT);
        $mdp    = $drtuser[38];
        $fctwri = $drtuser[42];
    } else {
        $mdp = "bad";
    }
}
$ctrlmdp = abs(crc32($mdp));

if (empty($_COOKIE[ADMP_COOKIE])) {
    $admcookie  = $ctrlmdp.'-img-file-img-3-1-1-web-web';
    $adminprefs = explode('-', $admcookie);
    $admdata    = '';
    for ($i = 0; $i < count($adminprefs); $i++) {
        $strlen   = sprintf("%02d", strlen($adminprefs[$i]));
        $admdata .= $strlen.$adminprefs[$i];
    }
    setcookie(ADMP_COOKIE, $admdata);
}

$admcookie = isset($_COOKIE[ADMP_COOKIE]) ? $_COOKIE[ADMP_COOKIE] : '';

if (empty($admcookie)) {
    die('Une erreur d\'identification est survenue. Veuillez contacter l\'administrateur du site.');
} else {
//FIN PROTECTION

//RECUPERATION ET CONTROL DES VARIABLES PASSEES EN PARAMETRE
$pathRepUploadConfig = isset($_POST['pathconfig']) ? $_POST['pathconfig'] : (isset($_GET['pathconfig']) ? $_GET['pathconfig'] : '');
if(!preg_match("!^[a-z]{2,3}$!i",$lng) || ($pathRepUploadConfig != '' && !preg_match("!^[-a-z0-9_]{1}[-a-z0-9_\/]*\/$!i",$pathRepUploadConfig))) die('Erreur dans la valeur des variables. Veuillez contacter le webmaster du site.');
$uptype = isset($_POST['uptype']) ? $_POST['uptype'] : (isset($_GET['uptype']) ? $_GET['uptype'] : 'Image');
if ($uptype != 'Link' && $uptype != 'Image' && $uptype != 'Flash' && $uptype != 'Media') die('Erreur dans la valeur de la variable uptype.Veuillez contacter le webmaster du site.');
$nameRepUploadConfig = isset($_POST['namerepconfig']) ? $_POST['namerepconfig'] : (isset($_GET['namerepconfig']) ? $_GET['namerepconfig'] : NULL);
if (!preg_match('!^[-a-z0-9_\/]+$!i',$nameRepUploadConfig)) die('Erreur dans le nom du répertoire qui contient les fichiers de configuration (variable $namerepconfig).Vous devez utiliser uniquement des lettres et/ou de chiffres et/ou les caractères(-_).Veuillez corriger');
$upvalid = isset($_POST['upvalid']) ? $_POST['upvalid'] : NULL;
if ($upvalid != NULL && $upvalid != 'ok' ) die('Erreur dans la valeur de la variable upvalid.Veuillez contacter l\'administrateur du site.');
$creatrep = isset($_POST['creatrep']) ? strip_tags($_POST['creatrep']) : NULL;	     
$fnewname = isset($_GET['fnewname']) ? strip_tags($_GET['fnewname']) : NULL;	     
$foldname = isset($_GET['foldname']) ? strip_tags($_GET['foldname']) : NULL;	     
$del = isset($_GET['del']) ? strip_tags($_GET['del']) : NULL;

//INITIALISATION DES VARIABLES DE CONFIGURATION POUR UPLOAD (A NE SURTOUT PAS MODIFIER !!)
$pathRepUpload = 'admin/editors/';
$allowedUpload = false;
$allowedCreateRep = false;
$allowedRenameRepFile = false;
$allowedDeleteRepFile = false;
$allowedExtFileUpload = array();
$accessRepUpload = array('img','photo','file','pages');
$accessRepUploadImage = array('img','photo');
$accessRepUploadLink = array('file','img','photo','pages');
$accessRepUploadMedia = array('img','photo');
if (version_compare(PHP_VERSION, '8.1.0') >= 0 && version_compare(PHP_VERSION, '8.2.0') < 0) {
	$allowedExtImage = array('.jpg','.webp','.avif','.gif','.png','.bmp','.jpeg','.JPG','.GIF','.PNG','.BMP','.JPEG');
	$imgTypes = array('bmp', 'gif', 'png', 'jpeg', 'jpg', 'webp', 'avif');
}
else
{
	$allowedExtImage = array('.jpg','.webp','.gif','.png','.bmp','.jpeg','.JPG','.GIF','.PNG','.BMP','.JPEG');
	$imgTypes = array('bmp', 'gif', 'png', 'jpeg', 'jpg', 'webp');
}

$ListdeniedExtFileUpload = array('.php','.inc','.cmd','.sh','.ini','.dat','.bat','.txt','.css','.js', '.html', '.htm', '.xml','.phtml');
$deniedExtLink = array();
$allowedExtMedia = array('.avi','.mp3','.mp4','.AVI','.MP3','.MP4');
$colorTextTitre = '#FFFFFF';  //couleur du titre
$colorFondTitre = '#7F7F7F';  //couleur de fond du titre
$styleBordureTitre = '1px solid #7F7F7F';  //bordure du titre
$colorTextCorp = '#000000';   //couleur du texte
$colorFondCorp = '#EFEFEF';   //couleur du fond de page
$styleBordureCorp = '1px solid #7F7F7F';  //bordure du corps
$colorBodyUpload = '#EFEFEF';  //couleur de fond de page (popup upload)
$colorFondFileUpload = '#EFEFEF'; //couleur du fond du tableau (popup upload)
$colorFondFileUploadOver = '#E7E1EF';  //couleur de fond des fichiers lors du survol de la souris (popup upload)
$colorFileUploadOff = '#000000';  //couleur des liens off (popup upload)
$colorFileUploadOn = '#FF0000';  //couleur des liens on (popup upload)
$pagerror = 0;
$image_size = array(0, 0);

//RECUPERATION DE LA CONFIGURATION DES VARIABLES DE L'UPLOAD SI ELLE EXISTE
if($pathRepUploadConfig !='' && file_exists(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/config_upload.inc')) {  
	include(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/config_upload.inc');  //CONFIGURATION UPLOAD PLUGIN
}
if (!isset($drtuser[42])) $drtuser[42] = 'admin';
$droit42wri = $drtuser[42];
if ($droitaccegroupredac == 'on')
{
	if ($drtuser[42] == "redac1" || $drtuser[42] == "redac2")
		{
		   if (FileDBExist(CHEMIN.'admin/'.REDACREP.'redacaccessdossier/accessdossier'.$wri.INCEXT)) 
		   {
				include(CHEMIN.'admin/'.REDACREP.'redacaccessdossier/accessdossier'.$wri.INCEXT);
				$accessRepUpload = explode(',',$drtaccessRepUpload);       //Nom des répertoires à la racine de Guppy accessibles pour le fichier Upload
				$accessRepUploadImage = explode(',',$drtaccessRepUploadImage);  //Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion d'Images.(accès avec variable uptype='Image')
				$accessRepUploadLink = explode(',',$drtaccessRepUploadLink);  //Nom des répertoires à la racine de Guppy accessibles via le menu pour l'insertion de Liens (accès avec variable uptype='Link')
				$accessRepUploadMedia = explode(',',$drtaccessRepUploadMedia);					
		   }
		}
}
// RECUPERATION DES FICHIER DE LANGUE
if(file_exists(CHEMIN.$pathRepUpload.'upload/lang/'.$lng.'_upload.inc')) {
	include(CHEMIN.$pathRepUpload.'upload/lang/'.$lng.'_upload.inc');
} else {
	include(CHEMIN.$pathRepUpload.'upload/lang/en_upload.inc'); // FICHIER PAR DEFAUT
}
//FONCTIONS UTILISEES DANS LE SCRIPT
include(CHEMIN.$pathRepUpload.'upload/functions_upload.inc');

//CONTROLE DES REPERTOIRES ECRITS DANS LES VARIABLES $accessRepUpload $accessRepUploadImage $accessRepUploadLink et $accessRepUploadFlash
$accessRepUpload = controlNameRepUpload($accessRepUpload);
$accessRepUploadImage = controlAccessRepUpload($accessRepUploadImage,$accessRepUpload,'Image');
$accessRepUploadLink = controlAccessRepUpload($accessRepUploadLink,$accessRepUpload,'Link');
$accessRepUploadMedia = controlAccessRepUpload($accessRepUploadMedia,$accessRepUpload,'Media');

//RECUPERATION ET AFFICHAGE DU REPERTOIRE PAR DEFAUT
$admcookie = isset($_COOKIE[ADMP_COOKIE]) ? $_COOKIE[ADMP_COOKIE] : '00';
$positem   = 0;
for ($i = 0; $i < 9; $i++) {
    $posdata        = $positem + 2;
    $lendata        = intval(substr($admcookie, $positem, 2));
    $adminprefs[$i] = substr($admcookie, $posdata, $lendata);
    $positem        = $posdata + $lendata;
}
	
switch($uptype) {
	case 'Image':
		if ($wri != 'admin')
		{
			if ($droit42wri == 'redac1' || $droit42wri == 'redac2')
			{
			  if (!empty($accessRepUploadImage[0])) 
				$repdefault = $accessRepUploadImage[0];
			}
			else $repdefault = $adminprefs[1];
		}
		else		
			$repdefault = $adminprefs[1];
		break;
	case 'Link':
		if ($wri != 'admin')
		{
			if ($dtruser[42] == 'redac1' || $dtruser[42] == 'redac2')
			{
			  if (!empty($accessRepUploadLink[0])) 
				$repdefault = $accessRepUploadLink[0];
			}
				else $repdefault = $adminprefs[2];
		}
		else $repdefault = $adminprefs[2];
		break;
	case 'Media':
		if ($wri != 'admin')
		{
			if ($dtruser[42] == 'redac1' || $dtruser[42] == 'redac2')
			{
			  if (!empty($accessRepUploadMedia[0])) 
				$repdefault = $accessRepUploadMedia[0];
			}
			else $repdefault = $adminprefs[3];
		}
		else $repdefault = $adminprefs[3];
		break;
	default :
		if ($dtruser[42] != 'redac1' && $dtruser[42] != 'redac2' )
		{
			$repdefault = 'img';

		}
}
$rep = isset($_POST['rep']) ? strip_tags($_POST['rep']) : (isset($_GET['rep']) ? strip_tags($_GET['rep']) : $repdefault);

switch($uptype) {
	case 'Image':
		$adminprefs[1] = $rep;
	break;
	case 'Link':
		$adminprefs[2] = $rep;
	break;
	case 'Media':
		$adminprefs[3] = $rep;
	break;
}
$admdata = '';
for ($i = 0; $i < count($adminprefs); $i++) {
    $strlen   = sprintf("%02d", strlen($adminprefs[$i]));
    $admdata .= $strlen.$adminprefs[$i];
}
setcookie(ADMP_COOKIE, $admdata);

//CREATION D'UN SOUS-REPERTOIRE
$allowedCreateRep = $fctwri != 'admin' ? false : $allowedCreateRep;
if ($drtuser[42] == 'redac1' || $drtuser[42] == 'redac2' )
		$allowedUpload = $allowedCreateRep = true;
if($allowedCreateRep == true) {  //AUTORISATION
	if (isset($creatrep) && trim($creatrep) != "") {
		$creatrep = cleanName($creatrep);
    	if ($creatrep == "0" ) {$creatrep = "0_";}
	
        if (stristr($creatrep, 'script') !== false) {
            echo '
<script type="text/javascript">
    alert("Nom de répertoire interdit - Forbidden directory name !!!");
    history.back();
</script>';
        } else {
    		if(is_dir(CHEMIN.$rep.'/'.$creatrep)){
    	    	$pagerror = 1;
    			$erreur = $lang_upload[1];
        	} else {
    			createNewRep($rep.'/'.$creatrep);
    	  	}
	  	}
	}
}
//RENOMMER UN FICHIER OU UN REPERTOIRE			
$allowedRenameRepFile = $fctwri != 'admin' ? false : $allowedRenameRepFile;
if($allowedRenameRepFile == true) { //AUTORISATION
	if (isset($fnewname) && trim($fnewname) != "") {
		$fnewname = cleanName($fnewname);
	
		$fext = strrchr($foldname,'.');
		if(is_file(CHEMIN.$rep.'/'.$foldname)) {	    
	    	if (file_exists(CHEMIN.$rep.'/'.$fnewname.$fext)){
	  	   		$pagerror = 1; 
		   		$erreur = $lang_upload[2];
	    	} else {	      
              	@rename(CHEMIN.$rep.'/'.$foldname , CHEMIN.$rep.'/'.$fnewname.$fext);
			  	SetChmod(CHEMIN.$rep.'/'.$fnewname.$fext);
	      	}
		} else if(is_dir(CHEMIN.$rep.'/'.$foldname)) {
	    	if ($fnewname == "0" ){$fnewname = "0_";}	    
	    	if (is_dir(CHEMIN.$rep.'/'.$fnewname)){
	  	   		$pagerror = 1; 
		   		$erreur = $lang_upload[3];
	    	} else {	                
	          	@rename(CHEMIN.$rep.'/'.$foldname , CHEMIN.$rep.'/'.$fnewname);
			  	SetChmod(CHEMIN.$rep.'/'.$fnewname);
	       	}	
      	}
	}
}
//SUPPRIMER UN FICHIER OU UN REPERTOIRE
$allowedDeleteRepFile = $fctwri != 'admin' ? false : $allowedDeleteRepFile;
if($allowedDeleteRepFile == true) { //AUTORISATION
	if (isset($del) && trim($del) != "") {
  		if(is_file(CHEMIN.$rep."/".$del)) {
      		@unlink(CHEMIN.$rep."/".$del);
  		}
  		if(is_dir(CHEMIN.$rep."/".$del)) {
      		DelSubRep(CHEMIN.$rep."/".$del."/");
	  		if(rmdir(CHEMIN.$rep."/".$del) == false) {
	  	 		$pagerror = 1;
		 		$erreur = $lang_upload[4]; 
	  		}
  		}      	  
	}
}
//UPLOAD DES FICHIERS
$allowedUpload = $fctwri != 'admin' ? false : $allowedUpload;
if ($drtuser[42] == 'redac1' || $drtuser[42] == 'redac2' )
		$allowedUpload = $allowedCreateRep = true;	

if($allowedUpload == true) { //AUTORISATION
	if (isset($_FILES['ficup']['name']) && trim($_FILES['ficup']['name']) != "" && $upvalid == "ok") {
    	$pagerror = 0;
		$_FILES['ficup']['name'] = strip_tags($_FILES['ficup']['name']);
		$_FILES['ficup']['name'] = cleanName($_FILES['ficup']['name'],true);

		if (!preg_match('!^([-a-zA-Z0-9_]+)(\.)([a-zA-Z0-9]{2,4})$!i',$_FILES['ficup']['name'])){ //CONTROL SI NOM FICHIER VALIDE
	     	$pagerror = 1;
		 	$erreur = $lang_upload[5]; 
		}
		if (file_exists(CHEMIN.$rep.'/'.$_FILES['ficup']['name'])){ //CONTROL SI NOM DU FICHIER DEJA PRESENT
	     	$pagerror = 1; 
		 	$erreur = $lang_upload[6];
		}
		if((count($allowedExtFileUpload) > 0 && !in_array(strrchr($_FILES['ficup']['name'],'.'),$allowedExtFileUpload)) || (count($ListdeniedExtFileUpload) > 0 && in_array(strrchr($_FILES['ficup']['name'],'.'),$ListdeniedExtFileUpload))) { //AUTORISATION EXTENSION DU FICHIER
	     	$pagerror = 1; 
		 	$erreur = $admin[1104];	
		}
		if($pagerror != 1) {	//UPLOAD	
    		if (move_uploaded_file($_FILES['ficup']['tmp_name'], CHEMIN.$rep.'/'.$_FILES['ficup']['name'])) {
	   			SetChmod(CHEMIN.$rep.'/'.$_FILES['ficup']['name']);
    		}
		}
	}
}
//CREATION DE L'INDEX DES FICHIERS

function ExtClass($extn){
    switch(strtolower($extn)) {
    case 'bmp'  :
    case 'gif'  : return 'fas fa-image text-secondary';
    case 'png'  : return 'far fa-image text-success';
	case 'webp' : 
	case 'avif' :
    case 'jpeg' :
    case 'jpg'  : return 'far fa-file-image text-primary';
    case 'bat'  :
    case 'com'  :
    case 'exe'  : return 'fas fa-code text-muted';
    case 'inc'  :
    case 'php'  :
    case 'js'   : return 'far fa-file-code text-secondary';
    case 'css'  : return 'fab fa-css3 text-success';
    case 'htm'  :
    case 'html' : return 'fas fa-file-code text-muted';
    case 'pdf'  : return 'far fa-file-pdf text-muted';
    case 'ods'  :
    case 'xls'  : return 'far fa-file-excel text-muted';
    case 'csv'  : return 'fas fa-file-csv text-muted';
    case 'doc'  : 
    case 'docx' : 
    case 'odf'  : return 'far fa-file-word text-info';
    case 'ppt'  : return 'far fa-file-powerpoint text-info';
    case 'dtb'  :
    case 'ini'  :
    case 'txt'  : return 'far fa-file-alt text-dark';
    case 'avi'  :
    case 'mpeg' :
    case 'mpg'  :
    case 'mov'  : return 'far fa-file-video text-warning';
    case 'mp3'  : 
    case 'mp4'  : 
    case 'wav'  : return 'far fa-file-audio text-info';
    case 'ace'  :
    case 'cab'  :
    case 'gz'   :
    case 'rar'  :
    case 'tar'  :
    case 'tgz'  :
    case 'zip'  : return 'far fa-file-archive text-success';
    default     : return 'fas fa-question text-danger';
    }
}
$dbdir    = array();
$dbfiles  = array();
$i        = 0;
$dossier = opendir(CHEMIN.$rep);
while ($fichier = readdir($dossier)) {
    if($fichier != '.' && $fichier != '..' && is_dir(CHEMIN.$rep.'/'.$fichier)) {
    	$dbdir[$i][0] = $fichier;
      	$dbdir[$i][1] = 'fas fa-folder-open text-warning';
      	$dbdir[$i][2] = 'dir';
      	$dbdir[$i][3] = 'dir';
	} else if (is_file(CHEMIN.$rep.'/'.$fichier) && $fichier != 'index.php') {
      	$dbfiles[$i][0] = $fichier;
		$path_parts = strtolower(substr(strrchr($fichier,'.'), 1));
        $dbfiles[$i][1] = ExtClass($path_parts);
	  	$filesize = filesize(CHEMIN.$rep.'/'.$fichier);
	  	$dbfiles[$i][2] = number_format($filesize,0,',',' ');
        $dbfiles[$i][3] = in_array($path_parts, $imgTypes);
  	}
	$i++;
}
closedir($dossier);
if(count($dbdir) > 0) sort($dbdir);
if(count($dbfiles) > 0) sort($dbfiles);
$dbfiles = array_merge($dbdir, $dbfiles);

//PAGE HTML
echo '
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>'.$lang_upload[13].'</title>
<meta http-equiv="Content-Type" content="text/html; charset='.$charset.'" />
<meta http-equiv="Content-Style-Type" content="text/css" />
';
//INSERTION STYLE CSS
if (file_exists(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/style_upload.css')) {
    echo '
<link type="text/css" rel="stylesheet" href="'.CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/style_upload.css" />';
}
elseif (file_exists(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/style_upload.inc')) {
    echo '
<style type="text/css">';
	include(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/style_upload.inc');
	echo '
</style>';
} 
else {
    echo '
<link type="text/css" rel="stylesheet" href="'.CHEMIN.$pathRepUpload.'upload/style_upload.css" />';  //STYLE PAR DEFAUT
}
echo '
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.6.0/css/all.min.css" 
   />
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.6.2/css/bootstrap.min.css" 
  integrity="sha512-rt/SrQ4UNIaGfDyEXZtNcyWvQeOq0QLygHluFQcSjaGB04IxWhal71tKuzP6K8eYXYB6vJV4pHkXcmFGGQ1/0w==" crossorigin="anonymous" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js" 
  integrity="sha512-bLT0Qm9VnAYZDflyKcBaQ2gg0hSYNQrJ8RilYldYQ1FxQYoCLtUjuuRuZo+fjqhx/qtq/1itJ0C2ejDxltZVFg==" crossorigin="anonymous">
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.6.2/js/bootstrap.bundle.min.js" 
  integrity="sha512-sha512-KgffulL3mxrOsDicgQWA11O6q6oKeWcV00VxgfJw4TcM8XRQT8Df9EsrYxDf7tpVpfl3qcYD96BpyPvA4d1FDQ==" crossorigin="anonymous">
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-migrate/3.5.2/jquery-migrate.min.js" 
  integrity="sha512-BzvgYEoHXuphX+g7B/laemJGYFdrq4fTKEo+B3PurSxstMZtwu28FHkPKXu6dSBCzbUWqz/rMv755nUwhjQypw==" crossorigin="anonymous">
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-easing/1.4.1/jquery.easing.min.js" 
  integrity="sha512-0QbL0ph8Tc8g5bLhfVzSqxe9GERORsKhIn1IrpxDAgUsbBGz/V7iSav2zzW325XGd1OMLdL4UiqRJj702IeqnQ==" crossorigin="anonymous">
</script>
';
//INSERTION FONCTIONS JAVASCRIPT
?>
<style>
.hover_img a { position:relative; }
.hover_img a span { background: #FFF; position:absolute; left:80px; display:none; z-index:99; border: 1px solid #000; padding: 10px 0px 10px 10px; }
.hover_img a:hover span { display:block; }
.hover_img img { max-width: 468px; height: auto; color:#000}/*si pas d'image (noscreen) le texte du tag alt sera en noir*/
.hover_img img::after  { content: url(inc/img/files/noscreen.jpg); } /*affichage de cette image si le lien n'est pas une image*/
</style>

<script type="text/javascript">
//REDIMENSIONNEMENT POPUP UPLOAD
function popupUploadSize() {
    var wscr = 700;
<?php
	if(!$allowedUpload && !$allowedCreateRep) {
		echo '
    var hscr = 460;';
	} elseif(!$allowedUpload || !$allowedCreateRep){
		echo '
    var hscr = 490;';
	} else {
		echo '
    var hscr = 680;';
	}
	echo '
	window.resizeTo(wscr, hscr);
	window.moveTo((window.screen.width-wscr)/2, (window.screen.height-hscr)/2);
	';
?>
}
//AFFICHAGE FICHIER IMAGE DANS POPUP
function popupImgUp(chemin) {
    var hauteurScreen= window.screen.height;
    var largeurScreen= window.screen.width;		
	
    FenImg = window.open("","","directories=0, menubar=0, status=0, resizable=1, scrollbars=0,location=0");
	FenImg.document.open();	
	
	var html = '<html><head><title><?php echo $lang_upload[22]; ?><\/title>'
		html = html+'<script type="text\/javascript">';
		html = html+'function ajustsize()  {';
		html = html+'var hauteurImg = document.images[0].height; var largeurImg = document.images[0].width; var top = ('+hauteurScreen+'- hauteurImg)/2; var left = ('+largeurScreen+'- largeurImg)/2; ';
		html = html+' if (document.images[0].complete) {  window.resizeTo(largeurImg+40,hauteurImg+70); window.moveTo(left,top); window.focus();} else { setTimeout("ajustsize();",500) } }<\/script>';
        html = html+'<\/head><body onload="ajustsize();"><div style="text-align:center; vertical-align:middle;"><img src="'+chemin+'" alt="" onclick="window.close();" /><\/div><\/body><\/html>';

	FenImg.document.write(html);
	FenImg.document.close();
	}	
//AFFICHAGE FICHIER AUTRE QUE IMAGE DANS POPUP
function popupFileUp(chemin) {
    var hauteur = 500;
    var largeur = 700;
    var top=(screen.height-hauteur)/2;
    var left=(screen.width-largeur)/2;
    window.open(chemin, '', 'top='+top+', left='+left+', width='+largeur+', height='+hauteur+', resizable=yes,menubar=no,location=no,directories=no,status=no,copyhistory=no,toolbar=no,scrollbars=yes');
}
<?php
//RENOMMER UN FICHIER OU UN REPERTOIRE
if($allowedRenameRepFile == true) { //AUTORISATION
?>
function renameFile(rep,file,type) {
    if (type == 'file') {
	    message = '<?php echo $lang_upload[27]; ?> "'+file+'".\n';
		message2 = "<?php echo $lang_upload[28]; ?>";
	}
    if (type == 'dir') {
	    message = '<?php echo $lang_upload[29]; ?> "'+file+'".\n';
		message2 = '<?php echo $lang_upload[30]; ?>';
	}
	message = message + '<?php echo $lang_upload[31]; ?>';
	x = null;
    x = window.prompt(message,message2);
	//control de la variable
	erreur = false;
	if(x.search(/^[-a-zA-Z0-9_]+$/gi) == -1) erreur = true;
	if (x != null && erreur == false) {
	   window.location = "upload.php?lng=<?php echo $lng; ?>&uptype=<?php echo $uptype; ?>&namerepconfig=<?php echo $nameRepUploadConfig; ?>&pathconfig=<?php echo $pathRepUploadConfig; ?>&rep="+rep+"&foldname="+file+"&fnewname="+x;
	} else {
		  alert('<?php echo $lang_upload[31]; ?>');
	      return false;
	 }
}
<?php
}
//SUPPRIMER UN FICHIER OU UN REPERTOIRE	
if($allowedDeleteRepFile == true) { //AUTORISATION
?>
function confirmDelFile(rep,file,type) {
    if (type == 'file') message = '<?php echo $lang_upload[23]; ?> " '+file+' ".\n';
    if (type == 'dir') message = '<?php echo $lang_upload[24]; ?> " '+file+' " <?php echo $lang_upload[25]; ?>\n';
	message = message + " <?php echo $lang_upload[26]; ?>";
	x = false;
    x = window.confirm(message);
	if (x == true) {
	   window.location = "upload.php?lng=<?php echo $lng; ?>&uptype=<?php echo $uptype; ?>&namerepconfig=<?php echo $nameRepUploadConfig; ?>&pathconfig=<?php echo $pathRepUploadConfig; ?>&rep="+rep+"&del="+file;
	} else {
	      return false;
	}
}
<?php
}
?>
//RETOUR AU REPERTOIRE PARENT
function RepParent(directory) {
	  dir = directory.split("/");
	  dir.length--;
      directory = dir.join("/");
	  x = document.forms["changedir"].elements["rep"].selectedIndex;
	  document.forms["changedir"].elements["rep"].options[x].value = directory;
	  document.forms["changedir"].submit();
}
//RECUPERATION DE L'URL
<?php
if(file_exists(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/jscript_upload.inc')) {
	include(CHEMIN.$pathRepUploadConfig.$nameRepUploadConfig.'/jscript_upload.inc');
} else {
	echo 'function openURL(url,type,alt,width,height) {window.close();}'."\n";
}
?>
//AFFICHER/MASQUER AIDE
function OpenCloseHelp() {
   if (document.getElementById('helpClose') == null) {
    document.getElementById('help').style.display = 'block';
	document.getElementById('helpOpen').value = "<?php echo $lang_upload[12]; ?>";	
	document.getElementById('helpOpen').id = 'helpClose';	
	} else {
    document.getElementById('help').style.display = 'none';
	document.getElementById('helpClose').value = "<?php echo $lang_upload[11]; ?>";	
	document.getElementById('helpClose').id = 'helpOpen';	
	}
}
//AFFICHER ELEMENT SURVOLE
function MouseOverFile(y,x,z) {
    if (y == 'yes') {
        document.getElementById(x).id = z;
	} else {
        document.getElementById(z).id = x;
	}
}
//VERIFICATION AVANT SOUMISSION POUR UPLOAD
function UploadValid(h,champ) {
	erreur = false;
	msg_erreur = '';
	if(h.elements[champ].value == "") {
	 	erreur = true;
	 	msg_erreur += "<?php echo $lang_upload[20]; ?>\n";
	}
	if(champ == 'ficup') {
		if(h.elements[champ].value.search(/(\\|\/)?([-a-zA-Z0-9_]+)(\.)([a-zA-Z0-9]{2,4})$/gi) == -1) {
	 		erreur = true;
	 		msg_erreur += "<?php echo $lang_upload[31]; ?>";
		}
	} else {
		if(h.elements[champ].value.search(/^[-a-zA-Z0-9_]+$/gi) == -1) {
	 		erreur = true;
	 		msg_erreur += "<?php echo $lang_upload[31]; ?>";
		}	
	}
    if (erreur == false) {
	   return true;
	} else {
	   alert(msg_erreur);
	   return false;
	}
}
</script>
</head>
<body onload="popupUploadSize();">
<?php
switch ($pagerror) {
    case "1" :
        echo '
<form name="pbupload" action="upload.php?lng='.$lng.'" method="post" style="margin:0px;">
  <input type="hidden" name="pg" value="upload" />
  <input type="hidden" name="rep" value="'.$rep.'" />
  <input type="hidden" name="uptype" value="'.$uptype.'" />
  <input type="hidden" name="pathconfig" value="'.$pathRepUploadConfig.'" />
  <input type="hidden" name="namerepconfig" value="'.$nameRepUploadConfig.'" />
  <div style="text-align:center; font-weight:bold; margin-top:15px;">'.$erreur.'</div>
  <div style="text-align:center; margin-top:15px; margin-bottom:15px;">
    <input type="submit" class="btn- btn-info bouton" id="retour" name="retour" value="'.$lang_upload[33].'" />
  </div>
</form>';
        break;
    default :
        echo '
<div id="help" class="help">'.$lang_upload[7].$lang_upload[19].'</div>
<form name="changedir" action="upload.php?lng='.$lng.'" method="post">
  <input type="hidden" name="uptype" value="'.$uptype.'" />
  <input type="hidden" name="pathconfig" value="'.$pathRepUploadConfig.'" />
  <input type="hidden" name="namerepconfig" value="'.$nameRepUploadConfig.'" />
  <div class="upload">
    <div class="d-inline-block">
      <i class="fas fa-folder text-warning" style="font-size: 1.4rem;" title="'.$lang_upload[14].'"></i>&nbsp;'.$lang_upload[14].'&nbsp;:&nbsp;
    </div>
    <div class="d-inline-block">
      <select class="form-control" name="rep" onchange="document.changedir.submit();">';
		switch($uptype) {
			case 'Image' :
				foreach($accessRepUploadImage as $nameRepUploadImage) {
					$repselected = Selected($rep == $nameRepUploadImage);
					echo '
        <option value="'.$nameRepUploadImage.'"'.$repselected.'>'.$nameRepUploadImage.'</option>';
				}
			break;
			case 'Link' :
				foreach($accessRepUploadLink as $nameRepUploadLink) {
					$repselected = Selected($rep == $nameRepUploadLink);
					echo '
        <option value="'.$nameRepUploadLink.'"'.$repselected.'>'.$nameRepUploadLink.'</option>';
				}
			break;
			case 'Media':
				foreach($accessRepUploadMedia as $nameRepUploadMedia) {
					$repselected = Selected($rep == $nameRepUploadMedia);
					echo '
        <option value="'.$nameRepUploadMedia.'"'.$repselected.'>'.$nameRepUploadMedia.'</option>';
				}
			break;
			default :
				die("Erreur 202");
		}          
		if (!in_array($rep, $accessRepUpload)) echo  '
        <option value="" selected="selected">'.$rep.'</option>';
        echo '
      </select>
    </div>
    <div class="d-inline-block">
      <input id="helpOpen" class="btn btn-info bouton mb-1" style="font-size: 1rem;" type="button" value="'.$lang_upload[11].'" onclick="OpenCloseHelp()" />	    
    </div>
  </div>
  <div style="text-align:center;" style="z-index: 0;">
    <div class="table-responsive-md '.(count($dbfiles) > 8 ? 'corpsFileScroll' : 'corpsFilenoScroll').'"> 
      <table class="table table-borderless" style="z-index: 0;">
        <tr class="forum">
          <td id="forumName" nowrap="nowrap">'.$lang_upload[15].'</td>
          <td id="forumSize" nowrap="nowrap" width="15%">'.$lang_upload[16].'</td>
          <td id="forumAction" nowrap="nowrap" width="15%">'.$lang_upload[17].'</td>
        </tr>';
        if (!in_array($rep, $accessRepUpload)) {
            echo '
        <tr class="quest" id="trdir" onmouseover="MouseOverFile(\'yes\',\'trdir\',\'trsurvol\');" onmouseout="MouseOverFile(\'no\',\'trdir\',\'trsurvol\');" >
          <td class="fileName">            
            <a href="javascript:RepParent(\''.$rep.'\');" title="'.$lang_upload[32].'">
              <i class="fas fa-folder-open text-warning" style="cursor: pointer; font-size: 1.1rem;" 
                onclick="RepParent(\''.$rep.'\');" title="'.$lang_upload[34].'"></i>
              <strong>...</strong>
            </a>
          </td>
          <td class="fileSize"><i class="far fa-folder" style="font-size: 1.1rem;"></i></td>
          <td class="fileAction">
            <i class="fas fa-search-location" style="cursor: pointer; font-size: 1.1rem;" title="'.$lang_upload[32].'"
              onclick="RepParent(\''.$rep.'\');" onmouseover="MouseOverFile(\'yes\',\'on\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'on\',\'imgsurvol\');"></i>
          </td>
        </tr>';
        }
        for ($i = 0; $i < count($dbfiles); $i++) {
			$n = ($i/2);
		    if (is_integer($n)) {
				echo '
        <tr class="rep" id="tr'.$i.'" 
          onmouseover="MouseOverFile(\'yes\',\'tr'.$i.'\',\'trsurvol\');" 
          onmouseout="MouseOverFile(\'no\',\'tr'.$i.'\',\'trsurvol\');">';
			} 
            else {
			    echo '
        <tr class="quest" id="tr'.$i.'" 
          onmouseover="MouseOverFile(\'yes\',\'tr'.$i.'\',\'trsurvol\');" 
          onmouseout="MouseOverFile(\'no\',\'tr'.$i.'\',\'trsurvol\');">';
			}
            if ($dbfiles[$i][2] == 'dir') {
				echo '
          <td class="fileName">
            <a href="upload.php?lng='.$lng.'&amp;rep='.$rep.'/'.$dbfiles[$i][0].'&amp;uptype='.$uptype.'&amp;pathconfig='.$pathRepUploadConfig.
                '&amp;namerepconfig='.$nameRepUploadConfig.'" class="imgName">
              <i class="'.$dbfiles[$i][1].' mr-2" style="cursor: pointer; font-size: 1.1rem;"></i>
            </a>
            <a href="upload.php?lng='.$lng.'&amp;rep='.$rep.'/'.$dbfiles[$i][0].'&amp;uptype='.$uptype.'&amp;pathconfig='.$pathRepUploadConfig.
                '&amp;namerepconfig='.$nameRepUploadConfig.'" title="'.$lang_upload[32].'">
              <span style="font-size: 1rem;">'.$dbfiles[$i][0].'</span>
            </a>
          </td>
          <td class="fileSize"><i class="far fa-folder" style="font-size: 1.1rem;"></i></td>
          <td class="fileAction">
            <a href="upload.php?lng='.$lng.'&amp;rep='.$rep.'/'.$dbfiles[$i][0].'&amp;uptype='.$uptype.
                '&amp;pathconfig='.$pathRepUploadConfig.'&amp;namerepconfig='.$nameRepUploadConfig.'">
              <i class="fas fa-search-location align-middle ml-n2" style="cursor: pointer; font-size: 1.1rem;" title="'.$lang_upload[32].'" 
                onmouseover="MouseOverFile(\'yes\',\'on'.$i.'\',\'imgsurvol\');" 
                onmouseout="MouseOverFile(\'no\',\'on'.$i.'\',\'imgsurvol\');"></i>
            </a>';
				if($allowedRenameRepFile == true) { //AUTORISATION RENOMMER
					echo '
            <i class="fas fa-edit align-middle ml-2" style="cursor: pointer; font-size: 1rem;" title="'.$lang_upload[36].'" 
              onclick=\'renameFile("'.$rep.'","'.$dbfiles[$i][0].'","dir");\' 
              onmouseover="MouseOverFile(\'yes\',\'nom'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'nom'.$i.'\',\'imgsurvol\');"</i>';
				} //FIN AUTORISATION
				if($allowedDeleteRepFile == true) { //AUTORISATION SUPPRESSION
					echo '
            <i class="fas fa-times text-danger align-middle ml-2" style="cursor: pointer; font-size: 1rem;" title="'.$lang_upload[37].'" 
              onclick=\'confirmDelFile("'.$rep.'","'.$dbfiles[$i][0].'","dir");\' 
              onmouseover="MouseOverFile(\'yes\',\'sup'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'sup'.$i.'\',\'imgsurvol\');"></i>';
				} //FIN AUTORISATION
				echo '
          </td>';
			} else {
				$ext = strrchr($dbfiles[$i][0], '.');
				echo '
          <td class="fileName">';
 				switch ($uptype) {
					case 'Image' :
					    if (count($allowedExtImage) > 0 && in_array($ext, $allowedExtImage)) {
						    $image_size = getimagesize(CHEMIN.$rep.'/'.$dbfiles[$i][0]);
                            echo '
            <div class="hover_img">
              <a name="file'.$i.'" title="'.$lang_upload[38].'" href="#file'.$i.'" style="font-size: 1rem;"
                onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","img","'.$dbfiles[$i][0].'","'.$image_size[0].'","'.$image_size[1].'");\' >
                <i class="'.$dbfiles[$i][1].' align-middle mr-2" style="font-size: 1.2rem;" title="'.$rep.'/'.$dbfiles[$i][0].'"
                  onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","img","'.$dbfiles[$i][0].'","'.$image_size[0].'","'.$image_size[1].'");\'></i>
                '.$dbfiles[$i][0].'
                <span'.($dbfiles[$i][3] ? '' : ' class="d-none"').' style="z-index: 9999;">
                  <img src="'.$site[3].$rep.'/'.$dbfiles[$i][0].'">
                </span>
              </a>
            </div>';						
				 		} else {
							echo '
            <i class="'.$dbfiles[$i][1].' align-middle mr-2" style="font-size: 1.1rem;" title="'.$rep.'/'.$dbfiles[$i][0].'"></i>
            <span style="font-size: 1rem;">'.$dbfiles[$i][0].'</span>';
						}
					break;
					case 'Link' :
						if(count($deniedExtLink) > 0 && in_array($ext, $deniedExtLink)) {
							echo '
            <i class="fas fa-unlink text-danger align-middle mr-2" title="'.$rep.'/'.$dbfiles[$i][0].'"></i>
            <span style="font-size: 1rem;">'.$dbfiles[$i][0].'</span>';
						} else {
							echo '
            <i class="fas fa-link text-info align-middle mr-2" title="'.$rep.'/'.$dbfiles[$i][0].'" 
               onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","file","'.$dbfiles[$i][0].'","","");\'></i>
            <a style="font-size: 1rem;" name="file'.$i.'" title="'.$lang_upload[38].'" href="#file'.$i.'" 
                onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","file","'.$dbfiles[$i][0].'","","");\' >
              '.$dbfiles[$i][0].'
            </a>';
						}
					break;
					case 'Media' :
					    if (count($allowedExtMedia) > 0 && in_array($ext, $allowedExtMedia)) {
							echo '
            <i class="far fa-file-audio text-info align-middle mr-2" title="'.$rep.'/'.$dbfiles[$i][0].'"
              onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","media","'.$dbfiles[$i][0].'","","");\'></i>
            <a style="font-size: 1rem;" name="file'.$i.'" title="'.$lang_upload[38].'" href="#file'.$i.'" 
                onclick=\'openURL("'.$site[3].$rep.'/'.$dbfiles[$i][0].'","media","'.$dbfiles[$i][0].'","","");\' >
              '.$dbfiles[$i][0].'
            </a>';
						} else {
							echo '
            <i class="'.$dbfiles[$i][1].' align-middle mr-2" title="'.$rep.'/'.$dbfiles[$i][0].'"></i>
            <span style="font-size: 1rem;">'.$dbfiles[$i][0].'</span>';
						}
					break;
					default :
						echo '
            <i class="'.$dbfiles[$i][1].' align-middle mr-2" style="font-size: 1.1rem;" title="'.$rep.'/'.$dbfiles[$i][0].'"></i>
            '.$dbfiles[$i][0];						    
				}				
				echo '
          </td>
          <td class="fileSize"><span style="font-size: 1rem;">'.$dbfiles[$i][2].'</span></td>';
				if (in_array($ext, $allowedExtImage)) {
                	echo '
          <td class="fileAction">
            <i class="far fa-eye text-info align-middle ml-n2"  title="'.$lang_upload[35].'" style="cursor: pointer; font-size: 1rem;" 
              onclick=\'popupImgUp("'.CHEMIN.$rep.'/'.$dbfiles[$i][0].'");\' 
              onmouseover="MouseOverFile(\'yes\',\'on'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'on'.$i.'\',\'imgsurvol\');"></i>';
				} else{
                    echo '
          <td class="fileAction">
            <i class="far fa-eye text-info align-middle ml-n2"  title="'.$lang_upload[35].'" style="cursor: pointer; font-size: 1rem;" 
              onclick=\'popupFileUp("'.CHEMIN.$rep.'/'.$dbfiles[$i][0].'");\' 
              onmouseover="MouseOverFile(\'yes\',\'on'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'on'.$i.'\',\'imgsurvol\');"></i>';
				}
				if($allowedRenameRepFile == true) { //AUTORISATION RENOMMER
					echo '
            <i class="fas fa-edit align-middle ml-2" title="'.$lang_upload[36].'" style="cursor: pointer; font-size: 1rem;"  
              onclick=\'renameFile("'.$rep.'","'.$dbfiles[$i][0].'","file");\' 
              onmouseover="MouseOverFile(\'yes\',\'nom'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'nom'.$i.'\',\'imgsurvol\');"></i>';											
				}  //FIN AUTORISATION
				if($allowedDeleteRepFile == true) { //AUTORISATION SUPPRESSION
					echo '
            <i class="fas fa-times text-danger align-middle ml-2" title="'.$lang_upload[37].'" style="cursor: pointer; font-size: 1rem;"  
              onclick=\'confirmDelFile("'.$rep.'","'.$dbfiles[$i][0].'","file");\' 
              onmouseover="MouseOverFile(\'yes\',\'sup'.$i.'\',\'imgsurvol\');" 
              onmouseout="MouseOverFile(\'no\',\'sup'.$i.'\',\'imgsurvol\');"></i>';
				} //FIN AUTORISATION
				echo '
          </td>';
			}			
            echo '
        </tr>';
        }
        echo '
      </table>
    </div>
  </div>
</form>';
		//UPLOAD DES FICHIERS

		if($allowedUpload == true) {  //AUTORISATION		
        	echo '
<form name="uploadit" enctype="multipart/form-data" action="upload.php?lng='.$lng.'" method="post" onsubmit="return UploadValid(this,\'ficup\');" >
  <input type="hidden" name="rep" value="'.$rep.'" />
  <input type="hidden" name="upvalid" value="ok" />
  <input type="hidden" name="uptype" value="'.$uptype.'" />
  <input type="hidden" name="pathconfig" value="'.$pathRepUploadConfig.'" />
  <input type="hidden" name="namerepconfig" value="'.$nameRepUploadConfig.'" />
  <div class="labelupload mt-3">
    <i class="fas fa-file-upload text-info mr-2" style="font-size: 1.2rem;" title="'.$lang_upload[13].'"></i>
    '.$lang_upload[13].'
  </div>
  <div class="upload">
    <div class="d-inline-block"><input class="form-control" type="file" name="ficup" size="27" /></div>
    <div class="d-inline-block"><input class="btn btn-info bouton mb-1" style="font-size: 1rem;" type="submit" value="'.$lang_upload[18].'" /></div>
  </div>
</form>';
		}
		//CREATION D'UN SOUS-REPERTOIRE	
		if($allowedCreateRep == true) {  //AUTORISATION	
			echo '
<form name="createdit"  action="upload.php?lng='.$lng.'" method="post" onsubmit="return UploadValid(this,\'creatrep\');">
  <input type="hidden" name="rep" value="'.$rep.'" />
  <input type="hidden" name="uptype" value="'.$uptype.'" />
  <input type="hidden" name="pathconfig" value="'.$pathRepUploadConfig.'" />
  <input type="hidden" name="namerepconfig" value="'.$nameRepUploadConfig.'" />
  <div class="labelupload">
    <i class="fas fa-folder-open text-warning mr-2" style="font-size: 1.2rem;" title="'.$lang_upload[8].'"></i>'.$lang_upload[8].'
  </div>
  <div class="upload">
    <div class="d-inline-block">'.$lang_upload[9].'&nbsp;:&nbsp;</div>
    <div class="d-inline-block"><input class="form-control" type="text" name="creatrep" size="30" value="" /></div>
    <div class="d-inline-block"><input class="btn btn-info bouton mb-1" style="font-size: 1rem;" type="submit" value="'.$lang_upload[10].'" /></div>
  </div>
</form>';
		}
}		
echo '
</body>
</html>';
}