79,14 → 79,12 |
} else { |
|
$donnees = array_merge( $_POST, $this->traiterDonneesFiles() ); |
// var_dump($donnees); |
$json = $this->getDao()->ajouter( $this->cel_url_tpl, $donnees ); |
$mode = $this->parametres['mode'] = 'modification'; |
} |
} |
|
|
|
|
$methode = $this->traiterNomMethodeExecuter( $mode ); |
if ( method_exists( $this, $methode ) ) { |
|
221,38 → 219,68 |
} |
|
private function traiterDonneesFiles() { |
$files_descriptions = array( |
'info', |
'logo', |
'fond' |
); |
$return = array(); |
$dossier_url = dirname(__FILE__) . '/squelettes/img/images_projets/' . $_POST['projet'] . '/'; |
$dossier_url = __DIR__ . '/squelettes/img/images_projets/' . $_POST['projet'] . '/'; |
$transmettre_donnees = false; |
$files_names = array(); |
$help_files_names = array(); |
$error = |
"<div class=\"message-echec container\">Echec du téléchargement : ". |
"L\'extention de l\'image pour " . $nom . " n\'est pas bonne". |
", formats acceptés : png, gif, jpg, jpeg, ou csv.". |
"</div>"; |
|
foreach ( array_keys( $_FILES ) as $file ) { |
|
if ( $_FILES[$file]['name'] !== '' ) { |
$extension = $this->obtenirExtension( $_FILES[$file] ); |
|
if ( $extension ) { |
|
$transmettre_donnees = true; |
$is_help_file = strstr( $file, 'help-'); |
|
if ( $file === 'especes' ) { |
switch ( $file ) { |
case 'fond': |
$return['image_font'] = $_FILES['fond']['type']; |
$files_names['image_font'] = 'fond.' . $extension; |
break; |
|
$return['especes']['name'] = 'especes.csv'; |
$return['especes']['type'] = $_FILES['especes']['type']; |
} elseif ( in_array( $file, $files_descriptions ) ) { |
case 'especes': |
$return['especes'] = $_FILES['especes']['type']; |
$files_names['especes'] = 'especes.' . $extension; |
break; |
|
$return['images_description'][$file]['type'] = $_FILES[$file]['type']; |
$return['images_description'][$file]['name'] = $file . strrchr( $_FILES[$file]['name'], '.' ); |
case 'logo': |
$return['logo'] = $_FILES['logo']['type']; |
$files_names['logo'] = 'logo.' . $extension; |
break; |
|
} elseif ( $is_help_file ) { |
case 'info': |
$return['info'] = $_FILES['info']['type']; |
$files_names['info'] = 'info.' . $extension; |
break; |
|
default: |
if ( $is_help_file ) { |
// Pas besoin de $return : |
// Type déjà transmis dans le json des champs supp |
$real_file_key = str_replace( 'help-', '', $file ); |
$return['images_aide'][$real_file_key]['type'] = $_FILES[$file]['type']; |
$return['images_aide'][$real_file_key]['name'] = $real_file_key . strrchr( $_FILES[$file]['name'], '.' ); |
$help_files_names[$real_file_key] = $real_file_key . '.' . $extension; |
} |
break; |
} |
} else { |
echo ( |
"<div class=\"message-echec container\">Echec du téléchargement : ". |
"L\'extention de l\'image pour " . $nom . " n\'est pas bonne". |
", formats acceptés : png, gif, jpg, jpeg, ou csv.". |
"</div>" |
); |
} |
} |
} |
|
if ( $transmettre_donnees ) { |
if( !is_dir( $dossier_url ) ) { |
|
259,77 → 287,112 |
mkdir( $dossier_url, 0755 ); |
} |
|
if ( count( $return['especes'] ) > 0 ) { |
$this->televerser( 'especes', $return['especes']['name'], $dossier_url ); |
// Téléversements |
if ( count( $files_names ) > 0 ) { |
foreach ( array_keys( $files_names ) as $file ) { |
$this->televerser( $file, $files_names[ $file ], $dossier_url ); |
} |
|
foreach ( array_keys( $return['images_description'] ) as $file ) { |
$this->televerser( $file, $return['images_description'][ $file ]['name'], $dossier_url ); |
} |
|
foreach ( array_keys( $return['images_aide'] ) as $file ) { |
$this->televerser( 'help-' . $file, $return['images_aide'][ $file ]['name'], $dossier_url ); |
if ( count( $help_files_names ) > 0 ) { |
foreach ( array_keys( $help_files_names ) as $file ) { |
$this->televerser( 'help-' . $file, $help_files_names[ $file ], $dossier_url ); |
} |
|
|
} |
} |
|
return $return; |
} |
|
private function televerser( $file, $new_file_name, $dossier_url ) { |
|
$fichier = $new_file_name; |
private function televerser( $file, $full_name, $dossier_url ) { |
$taille_maxi = 5242880; |
$taille = filesize( $_FILES[$file]['tmp_name'] ); |
$extension = strrchr( $_FILES[$file]['name'], '.' ); |
$extensions = array( '.png', '.gif', '.jpg', '.jpeg', '.csv' ); |
$extension = $this->obtenirExtension( $_FILES[$file] ); |
$file_name = str_replace( $extension, '', $full_name ); |
|
//Début des vérifications de sécurité... |
if ( file_exists( $dossier_url . $new_file_name ) ) { |
if ( file_exists( $dossier_url . $full_name ) ) { |
|
if ( $_POST['mode'] === 'modification' ) { |
|
// Le fichier existe déjà, c'est normal si on est en mode modification |
unlink ( $dossier_url . $new_file_name ); |
unlink ( $dossier_url . $full_name ); |
} else { |
|
$erreur = |
"<p class=\"message\" style=\"background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem\"> Echec du téléchargement : ". |
"Un fichier image pour \"" . str_replace( $extension, '', $new_file_name ) . "\", dans un projet \"" . $_POST['projet'] . "\".</p>"; |
"<div class=\"message-echec container\">Echec du téléchargement : ". |
"Un fichier pour \"" . $file_name. |
"\", existe déjà dans un projet nommé \"" . $_POST['projet'] . "\".". |
"<br>Vérifiez que le nom du projet n'est pas déjà pris, ". |
"ou qu'un fichier \"" . $full_name . "\" n'ait pas déjà été téléchargé pour ce projet.". |
"</div>"; |
} |
} |
|
if ( !in_array( $extension, $extensions ) ) { |
if ( !$extension ) { |
|
//Si le format n'est pas bon |
$erreur = '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement, formats acceptés : png, gif, jpg, jpeg, ou csv</p>'; |
$erreur = |
"<div class=\"message-echec container\">". |
"Echec du téléchargement pour ". |
"\"" . $file_name . "\" ". |
", formats acceptés : png, gif, jpg, jpeg, ou csv". |
"</div>"; |
} |
|
if ( $taille > $taille_maxi ) { |
|
$erreur = '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement : Max 5Mo</p>'; |
$erreur = |
"<div class=\"message-echec container\">". |
"Echec du téléchargement pour ". |
"\"" . $file_name . "\" ". |
": Max 5Mo". |
"</div>"; |
} |
|
if ( !isset( $erreur ) ) { |
if ( isset( $erreur ) ) { |
|
// Formatage du nom du fichier |
$fichier = $this->remove_accents( $fichier ); |
$fichier = preg_replace( '/([^.a-z0-9]+)/i', '-', $fichier ); |
echo $erreur; |
} else { |
|
//////////// C'est ici que ça merde à priori /////////////////////////////////////////////////// |
var_dump($dossier_url . $fichier); |
if ( move_uploaded_file( $_FILES[$file]['tmp_name'], $dossier_url . $fichier ) ) { |
if ( !move_uploaded_file( $_FILES[$file]['tmp_name'], $dossier_url . $this->remove_accents( $full_name ) ) ) { |
// move_uploaded_file() renvoie false si l'upload a échoué |
echo |
"<div class=\"message-echec container\">". |
"Erreur du téléchargement pour ". |
"\"" . $file_name . "\"". |
"</div>"; |
} |
} |
} |
|
echo 'Téléchargement effectué avec succès'; |
} else { |
private function obtenirExtension( $files ) { |
$type = exif_imagetype( $files['tmp_name'] ); |
//une vérif pas mal pour les types image |
if ( $type == ( IMAGETYPE_PNG || IMAGETYPE_JPEG || IMAGETYPE_GIF ) ) { |
|
echo '<p class="message" style="background-color: #f9e2d7;border-color: #eca27e;color: #9c4217;fill: #9c4217;border: 0.1rem solid;border-radius: 0.4rem;padding: 0.5rem; display: inline-block;margin: 1rem"> Echec du téléchargement</p>'; |
switch ( $type ) { |
case '1' : |
$format = 'gif'; |
break; |
case '2' : |
$format = 'jpg'; |
break; |
case '3' : |
$format = 'png'; |
break; |
default : |
break; |
} |
} elseif ( str_replace( '.csv' , '', $files['name'] ) && substr( strrchr($files['type'], '/' ), 1 ) === 'csv' ) { |
// Pas trouvé mieux pour csv : |
// Les fonctions qui pourraient utiliser $_FILES[file]["tmp_path"] me répondent "text/plain"... |
|
$format = 'csv'; |
} else { |
|
echo $erreur; |
return false; |
} |
return $format; |
} |
|
private function remove_accents( $string ) { |
437,8 → 500,6 |
|
$string = strtr( $string, $chars ); |
|
return $string; |
return preg_replace( '/([^.a-z0-9]+)/i', '-', $string ); |
} |
|
} |
|