Subversion Repositories eFlore/Applications.cel

Rev

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