Subversion Repositories eFlore/Applications.cel

Rev

Rev 1889 | Rev 1924 | Go to most recent revision | Details | Compare with Previous | 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
	protected $projet = '';
18
 
19
	public function createElement($donnees) {
20
		$image = array_shift($donnees); // dangereux!
21
		if (isset($_GET['projet'])) {
22
			$this->projet = $_GET['projet'];
23
		}
24
		$retour = $this->enregistrerImageTemporaire($image);
1919 mathias 25
		$this->formaterRetourAvecSquelette($retour);
1888 mathias 26
	}
27
 
28
	private function formaterRetourAvecSquelette($retour) {
1919 mathias 29
		$codeRetour = true;
1888 mathias 30
		if (is_array($retour)) {
31
			$squelette = 'services/squelettes/image_temp.tpl.xml';
32
			$contenu = $this->traiterSquelettePhp($squelette, $retour);
33
			$mime = 'text/xml';
34
		} else {
35
			$contenu = 'Un problème est survenu : '.print_r($retour['message'], true);
36
			$codeRetour = false;
37
		}
1919 mathias 38
		if ($codeRetour) {
39
			$this->envoyer($contenu, $mime);
40
			exit; // pour éviter que JRest renvoie des headers après le contenu - supporté par agathis (nginx) mais pas apache (sequoia)
41
		} else {
42
			return false;
43
		}
1888 mathias 44
	}
45
 
46
	// enregistre l'image envoyée dans le chemin de stockage temporaire, puis
47
	// renvoie le XML attendu par le widget de saisie du CEL
48
	public function enregistrerImageTemporaire($image) {
49
		$retour = array(
50
			'urlMiniature' => '',
51
			'imageNom' => '',
52
			'message' => '',
53
			'debogage' => '');
54
		$message = '';
55
		$debogage = '';
56
		if ($image['error'] == UPLOAD_ERR_OK) {
57
			if (is_uploaded_file($image['tmp_name'])) {
58
				if ($this->verifierFormatJpeg($image['tmp_name'])) {
1889 mathias 59
					$dossierStockage = $this->config['cel']['chemin_stockage_temp'];
1888 mathias 60
 
61
					$nomFichierOriginal = preg_replace('/[.](jpeg|jpg)$/i', '.jpg', strtolower($image['name']));
1889 mathias 62
					$originalChemin = $dossierStockage.'/'.$nomFichierOriginal;
1888 mathias 63
					$deplacementOk = move_uploaded_file($image['tmp_name'], $originalChemin);
64
 
65
					if ($deplacementOk === true) {
66
						$miniatureFichier = str_replace('.jpg', '_min.jpg', $nomFichierOriginal);
1889 mathias 67
						$miniatureChemin = $dossierStockage.'/'.$miniatureFichier;
1888 mathias 68
 
69
						// Parametres
70
						$largeurIdeale = 100;
71
						$hauteurIdeale = 100;
72
						$qualite = 85;
73
 
74
						// Calcul de la hauteur et de la largeur optimale de la miniature
75
						$taillesImgOriginale = getimagesize($originalChemin);
76
						$largeurOrigine = $taillesImgOriginale[0];
77
						$hauteurOrigine = $taillesImgOriginale[1];
78
 
79
						$largeurMin = $largeurIdeale;
80
						$hauteurMin = (int) ($hauteurOrigine * ($largeurIdeale / $largeurOrigine));
81
						if ($hauteurMin > $hauteurIdeale) {
82
							$hauteurMin = $hauteurIdeale;
83
							$largeurMin = (int)($largeurOrigine * ($hauteurMin / $hauteurOrigine));
84
						}
85
 
86
						// Création de la miniature
87
						$imageOriginale = imagecreatefromjpeg($originalChemin);
88
						$imageMiniature = imagecreatetruecolor($largeurMin, $hauteurMin);
89
						$couleurFond = imagecolorallocate($imageMiniature, 255, 255, 255);
90
						imagefill($imageMiniature, 0, 0, $couleurFond);
91
						imagecopyresized($imageMiniature, $imageOriginale, 0, 0, 0, 0, $largeurMin, $hauteurMin, $largeurOrigine, $hauteurOrigine);
92
						imagejpeg($imageMiniature, $miniatureChemin, $qualite);
93
						imagedestroy($imageMiniature);
94
						imagedestroy($imageOriginale);
95
 
96
						// Retour des infos
97
						$retour['urlMiniature'] = sprintf($this->config['cel']['images_temp_url'], $miniatureFichier);
98
						$retour['imageNom'] = $nomFichierOriginal;
99
					} else {
100
						$message = "L'image n'a pu être déplacé sur le serveur.";
101
					}
102
				} else {
103
					$message = "L'image n'est pas au format JPEG.";
104
				}
105
			} else {
106
				$message = "L'image n'a pu être téléversée.";
107
				$debogage = $message.print_r($image, true);
108
			}
109
		} else {
110
			if ($image['error'] == UPLOAD_ERR_FORM_SIZE) {
111
				$message = "L'image téléversée excède la taille maximum autorisée.".
112
						"Veuillez modifier votre image avant de la téléverser à nouveau.";
113
			} else {
114
				$message = "Une erreur de transfert a eu lieu (téléversement interrompu).";
115
			}
116
			$debogage = "Code erreur : {$image['error']}. ".
117
					"Voir : http://php.net/manual/fr/features.file-upload.errors.php";
118
		}
119
		// Retour des infos
120
		$retour['message'] = $message;
121
		$retour['debogage'] = $debogage;
122
		return $retour;
123
	}
124
 
125
	// Il ne faut pas utiliser l'index type du tableau files pour tester
126
	// si une image est en jpeg car le type renvoyé par les navigateurs
127
	// peut varier (ex. sous ie qui renvoie image/pjpeg
128
	private function verifierFormatJpeg($chemin) {
129
		// get imagesize renvoie un résultat consistant par contre
130
		$infos = getimagesize($chemin, $infos);
131
		return (isset($infos['mime']) && $infos['mime'] == 'image/jpeg');
132
	}
133
}
134
?>