Subversion Repositories eFlore/Applications.cel

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1888 mathias 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Service permettant d'enregistrer dans le répertoire temporaire les images envoyées depuis le widget Saisie
5
 *
6
 * Cas d'utilisation :
7
 * POST /CelWidgetUploadImageTemp : écriture d'une image dans le répertoire temporaire
8
 *
9
 * @author Mathias Chouet <mathias@tela-botanica.org>
10
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
11
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
12
 * @version $Id$
13
 * @copyright © 2013, Tela-Botanica
14
 */
15
class CelWidgetUploadImageTemp extends Cel  {
16
 
17
	public function createElement($donnees) {
1924 mathias 18
		$image = $_FILES['fichier']; // chaudrépare
1888 mathias 19
		$retour = $this->enregistrerImageTemporaire($image);
1919 mathias 20
		$this->formaterRetourAvecSquelette($retour);
1888 mathias 21
	}
22
 
23
	private function formaterRetourAvecSquelette($retour) {
1919 mathias 24
		$codeRetour = true;
1888 mathias 25
		if (is_array($retour)) {
26
			$squelette = 'services/squelettes/image_temp.tpl.xml';
27
			$contenu = $this->traiterSquelettePhp($squelette, $retour);
28
			$mime = 'text/xml';
29
		} else {
30
			$contenu = 'Un problème est survenu : '.print_r($retour['message'], true);
31
			$codeRetour = false;
32
		}
1919 mathias 33
		if ($codeRetour) {
34
			$this->envoyer($contenu, $mime);
35
			exit; // pour éviter que JRest renvoie des headers après le contenu - supporté par agathis (nginx) mais pas apache (sequoia)
36
		} else {
37
			return false;
38
		}
1888 mathias 39
	}
40
 
41
	// enregistre l'image envoyée dans le chemin de stockage temporaire, puis
42
	// renvoie le XML attendu par le widget de saisie du CEL
43
	public function enregistrerImageTemporaire($image) {
44
		$retour = array(
45
			'urlMiniature' => '',
46
			'imageNom' => '',
47
			'message' => '',
48
			'debogage' => '');
49
		$message = '';
50
		$debogage = '';
51
		if ($image['error'] == UPLOAD_ERR_OK) {
52
			if (is_uploaded_file($image['tmp_name'])) {
53
				if ($this->verifierFormatJpeg($image['tmp_name'])) {
1889 mathias 54
					$dossierStockage = $this->config['cel']['chemin_stockage_temp'];
1888 mathias 55
 
56
					$nomFichierOriginal = preg_replace('/[.](jpeg|jpg)$/i', '.jpg', strtolower($image['name']));
1889 mathias 57
					$originalChemin = $dossierStockage.'/'.$nomFichierOriginal;
1888 mathias 58
					$deplacementOk = move_uploaded_file($image['tmp_name'], $originalChemin);
59
 
60
					if ($deplacementOk === true) {
61
						$miniatureFichier = str_replace('.jpg', '_min.jpg', $nomFichierOriginal);
1889 mathias 62
						$miniatureChemin = $dossierStockage.'/'.$miniatureFichier;
1888 mathias 63
 
64
						// Parametres
65
						$largeurIdeale = 100;
66
						$hauteurIdeale = 100;
67
						$qualite = 85;
68
 
69
						// Calcul de la hauteur et de la largeur optimale de la miniature
70
						$taillesImgOriginale = getimagesize($originalChemin);
71
						$largeurOrigine = $taillesImgOriginale[0];
72
						$hauteurOrigine = $taillesImgOriginale[1];
73
 
74
						$largeurMin = $largeurIdeale;
75
						$hauteurMin = (int) ($hauteurOrigine * ($largeurIdeale / $largeurOrigine));
76
						if ($hauteurMin > $hauteurIdeale) {
77
							$hauteurMin = $hauteurIdeale;
78
							$largeurMin = (int)($largeurOrigine * ($hauteurMin / $hauteurOrigine));
79
						}
80
 
81
						// Création de la miniature
82
						$imageOriginale = imagecreatefromjpeg($originalChemin);
83
						$imageMiniature = imagecreatetruecolor($largeurMin, $hauteurMin);
84
						$couleurFond = imagecolorallocate($imageMiniature, 255, 255, 255);
85
						imagefill($imageMiniature, 0, 0, $couleurFond);
86
						imagecopyresized($imageMiniature, $imageOriginale, 0, 0, 0, 0, $largeurMin, $hauteurMin, $largeurOrigine, $hauteurOrigine);
87
						imagejpeg($imageMiniature, $miniatureChemin, $qualite);
88
						imagedestroy($imageMiniature);
89
						imagedestroy($imageOriginale);
90
 
91
						// Retour des infos
92
						$retour['urlMiniature'] = sprintf($this->config['cel']['images_temp_url'], $miniatureFichier);
93
						$retour['imageNom'] = $nomFichierOriginal;
94
					} else {
95
						$message = "L'image n'a pu être déplacé sur le serveur.";
96
					}
97
				} else {
98
					$message = "L'image n'est pas au format JPEG.";
99
				}
100
			} else {
101
				$message = "L'image n'a pu être téléversée.";
102
				$debogage = $message.print_r($image, true);
103
			}
104
		} else {
105
			if ($image['error'] == UPLOAD_ERR_FORM_SIZE) {
106
				$message = "L'image téléversée excède la taille maximum autorisée.".
107
						"Veuillez modifier votre image avant de la téléverser à nouveau.";
108
			} else {
109
				$message = "Une erreur de transfert a eu lieu (téléversement interrompu).";
110
			}
111
			$debogage = "Code erreur : {$image['error']}. ".
112
					"Voir : http://php.net/manual/fr/features.file-upload.errors.php";
113
		}
114
		// Retour des infos
115
		$retour['message'] = $message;
116
		$retour['debogage'] = $debogage;
117
		return $retour;
118
	}
119
 
120
	// Il ne faut pas utiliser l'index type du tableau files pour tester
121
	// si une image est en jpeg car le type renvoyé par les navigateurs
122
	// peut varier (ex. sous ie qui renvoie image/pjpeg
123
	private function verifierFormatJpeg($chemin) {
124
		// get imagesize renvoie un résultat consistant par contre
125
		$infos = getimagesize($chemin, $infos);
126
		return (isset($infos['mime']) && $infos['mime'] == 'image/jpeg');
127
	}
128
}
129
?>