| 416 |
aurelien |
1 |
<?php
|
| 922 |
aurelien |
2 |
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
|
|
|
3 |
/**
|
|
|
4 |
* PHP Version 5
|
|
|
5 |
*
|
|
|
6 |
* @category PHP
|
| 923 |
aurelien |
7 |
* @package jrest
|
| 922 |
aurelien |
8 |
* @author David Delon <david@tela-botanica.org>
|
|
|
9 |
* @author Aurelien Peronnet <aurelien@tela-botanica.org>
|
|
|
10 |
* @copyright 2010 Tela-Botanica
|
|
|
11 |
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
|
|
|
12 |
* @version SVN: <svn_id>
|
|
|
13 |
* @link /doc/jrest/
|
|
|
14 |
*/
|
| 416 |
aurelien |
15 |
|
| 922 |
aurelien |
16 |
/**
|
|
|
17 |
* CRUD observation
|
|
|
18 |
*
|
|
|
19 |
* in=utf8
|
|
|
20 |
* out=utf8
|
|
|
21 |
*
|
|
|
22 |
**/
|
|
|
23 |
class Inventory extends Cel {
|
|
|
24 |
|
| 983 |
aurelien |
25 |
// TODO: faire un descriptif du service
|
| 922 |
aurelien |
26 |
function getRessource(){
|
| 416 |
aurelien |
27 |
|
|
|
28 |
}
|
|
|
29 |
|
|
|
30 |
function getElement($uid){
|
|
|
31 |
|
| 922 |
aurelien |
32 |
// Controle detournement utilisateur
|
|
|
33 |
$this->controleUtilisateur($uid[0]);
|
| 416 |
aurelien |
34 |
|
| 922 |
aurelien |
35 |
$value=array();
|
| 416 |
aurelien |
36 |
|
| 922 |
aurelien |
37 |
if(!isset($uid[0])) {
|
|
|
38 |
return;
|
|
|
39 |
}
|
|
|
40 |
|
|
|
41 |
$parametres_recherche = array(array('ce_utilisateur',$uid[0]),array('ordre',$uid[1]));
|
|
|
42 |
|
|
|
43 |
$chercheur_observations = new RechercheObservation($this->config);
|
| 1631 |
raphael |
44 |
$retour_recherche = $chercheur_observations->rechercherObservations($uid[0], $parametres_recherche, 0, 1)->get();
|
| 922 |
aurelien |
45 |
|
|
|
46 |
$observation = array();
|
|
|
47 |
if(is_array($retour_recherche) && count($retour_recherche) > 0) {
|
|
|
48 |
$observation = $retour_recherche[0];
|
|
|
49 |
}
|
|
|
50 |
|
| 1598 |
raphael |
51 |
$observation = $this->formaterObservationVersTableauSequentiel($observation);
|
| 922 |
aurelien |
52 |
$output = json_encode($observation);
|
|
|
53 |
|
| 1014 |
aurelien |
54 |
$this->envoyerJson($output);
|
|
|
55 |
return true;
|
| 416 |
aurelien |
56 |
}
|
| 922 |
aurelien |
57 |
|
| 1598 |
raphael |
58 |
private function formaterObservationVersTableauSequentiel(&$observation) {
|
| 922 |
aurelien |
59 |
|
|
|
60 |
if ($observation['date_observation']!="0000-00-00 00:00:00") {
|
| 996 |
aurelien |
61 |
list($year,$month,$day)= explode('-',$observation['date_observation']);
|
|
|
62 |
list($day)= explode(' ',$day);
|
| 922 |
aurelien |
63 |
$observation['date_observation']=$day."/".$month."/".$year;
|
|
|
64 |
}
|
| 416 |
aurelien |
65 |
|
| 922 |
aurelien |
66 |
$observation = array($observation['nom_sel'], $observation['nom_sel_nn'],
|
|
|
67 |
$observation['nom_ret'], $observation['nom_ret_nn'],
|
|
|
68 |
$observation['nt'], $observation['famille'], $observation['zone_geo'],
|
|
|
69 |
$observation['ce_zone_geo'], $observation['ordre'],
|
|
|
70 |
$observation['date_observation'], $observation['lieudit'],
|
|
|
71 |
$observation['station'], $observation['milieu'],
|
|
|
72 |
$observation['commentaire'], $observation['latitude'],
|
|
|
73 |
$observation['longitude']);
|
|
|
74 |
|
|
|
75 |
return $observation;
|
| 416 |
aurelien |
76 |
}
|
|
|
77 |
|
|
|
78 |
function updateElement($uid,$pairs) {
|
|
|
79 |
|
| 922 |
aurelien |
80 |
// Controle detournement utilisateur
|
|
|
81 |
$this->controleUtilisateur($uid[0]);
|
| 416 |
aurelien |
82 |
|
| 922 |
aurelien |
83 |
if (!isset($uid[1])) {
|
|
|
84 |
//TODO: envoyer un message d'erreur
|
|
|
85 |
return;
|
|
|
86 |
}
|
|
|
87 |
|
|
|
88 |
$uid[1] = rtrim($uid[1],',');
|
|
|
89 |
|
| 1590 |
aurelien |
90 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
| 1571 |
aurelien |
91 |
unset($pairs['obs_etendue']);
|
| 1628 |
raphael |
92 |
|
| 1681 |
raphael |
93 |
if(isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
| 1653 |
aurelien |
94 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
|
|
95 |
if(!$time || $time > time()) {
|
|
|
96 |
throw new Exception('Date invalide');
|
|
|
97 |
}
|
| 1628 |
raphael |
98 |
}
|
| 1548 |
aurelien |
99 |
|
| 922 |
aurelien |
100 |
$gestionnaire_observation = new GestionObservation($this->config);
|
|
|
101 |
$modification_observation = $gestionnaire_observation->modifierObservation($uid[0],$uid[1],$pairs);
|
| 1548 |
aurelien |
102 |
|
|
|
103 |
if($champs_etendus != null) {
|
|
|
104 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
|
|
105 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
| 1571 |
aurelien |
106 |
foreach($champs_etendus as &$champ_etendu) {
|
|
|
107 |
$objet_champ_etendu = new ChampEtendu();
|
|
|
108 |
$objet_champ_etendu->id = $id_obs;
|
|
|
109 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
|
|
110 |
$objet_champ_etendu->label = $champ_etendu['label'];
|
|
|
111 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
|
|
112 |
$champ_etendu = $objet_champ_etendu;
|
|
|
113 |
}
|
|
|
114 |
// ajouterParLots modifie les champs et ajoute ceux qui existent déjà
|
|
|
115 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
| 1548 |
aurelien |
116 |
}
|
| 1571 |
aurelien |
117 |
|
| 922 |
aurelien |
118 |
return true;
|
| 416 |
aurelien |
119 |
}
|
|
|
120 |
|
| 1548 |
aurelien |
121 |
function createElement($pairs) {
|
| 922 |
aurelien |
122 |
// Controle detournement utilisateur
|
|
|
123 |
$this->controleUtilisateur($pairs['ce_utilisateur']);
|
|
|
124 |
|
| 1590 |
aurelien |
125 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
| 1571 |
aurelien |
126 |
unset($pairs['obs_etendue']);
|
| 1628 |
raphael |
127 |
|
| 1681 |
raphael |
128 |
if(isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
|
|
129 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
|
|
130 |
if(!$time || $time > time()) {
|
|
|
131 |
throw new Exception('Date invalide');
|
|
|
132 |
}
|
| 1628 |
raphael |
133 |
}
|
| 1548 |
aurelien |
134 |
|
| 922 |
aurelien |
135 |
$gestionnaire_observation = new GestionObservation($this->config);
|
| 1548 |
aurelien |
136 |
$id_nouvelle_obs = $gestionnaire_observation->ajouterObservation($pairs['ce_utilisateur'], $pairs);
|
| 416 |
aurelien |
137 |
|
| 1548 |
aurelien |
138 |
if($champs_etendus != null) {
|
|
|
139 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
| 1571 |
aurelien |
140 |
foreach($champs_etendus as &$champ_etendu) {
|
|
|
141 |
$objet_champ_etendu = new ChampEtendu();
|
|
|
142 |
$objet_champ_etendu->id = $id_nouvelle_obs;
|
|
|
143 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
|
|
144 |
$objet_champ_etendu->label = $champ_etendu['label'];
|
|
|
145 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
|
|
146 |
$champ_etendu = $objet_champ_etendu;
|
|
|
147 |
}
|
|
|
148 |
|
|
|
149 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
| 1548 |
aurelien |
150 |
}
|
|
|
151 |
|
| 416 |
aurelien |
152 |
return true;
|
|
|
153 |
}
|
| 1548 |
aurelien |
154 |
|
| 922 |
aurelien |
155 |
/**
|
|
|
156 |
* Supprime une observation
|
|
|
157 |
*
|
|
|
158 |
* uid[0] : utilisateur obligatoire
|
|
|
159 |
* uid[1] : ordres de l'observation à supprimer
|
|
|
160 |
*/
|
|
|
161 |
function deleteElement($uid){
|
| 416 |
aurelien |
162 |
|
| 922 |
aurelien |
163 |
// Controle detournement utilisateur
|
|
|
164 |
$this->controleUtilisateur($uid[0]);
|
| 738 |
aurelien |
165 |
|
| 922 |
aurelien |
166 |
if (!isset($uid[1])) {
|
|
|
167 |
//TODO: envoyer un message d'erreur
|
|
|
168 |
return;
|
|
|
169 |
}
|
| 738 |
aurelien |
170 |
|
| 922 |
aurelien |
171 |
$uid[1] = rtrim($uid[1],',');
|
| 1548 |
aurelien |
172 |
|
| 922 |
aurelien |
173 |
$gestionnaire_observation = new GestionObservation($this->config);
|
| 1653 |
aurelien |
174 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
| 922 |
aurelien |
175 |
$suppression_observation = $gestionnaire_observation->supprimerObservation($uid[0],$uid[1]);
|
| 738 |
aurelien |
176 |
|
| 1548 |
aurelien |
177 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
| 1571 |
aurelien |
178 |
$champs_supp = $gestion_champs_etendus->vider($id_obs);
|
| 1548 |
aurelien |
179 |
|
| 922 |
aurelien |
180 |
if ($suppression_observation) {
|
|
|
181 |
echo "OK";
|
| 738 |
aurelien |
182 |
}
|
| 922 |
aurelien |
183 |
|
|
|
184 |
exit() ;
|
| 738 |
aurelien |
185 |
}
|
| 416 |
aurelien |
186 |
}
|
|
|
187 |
/* +--Fin du code ---------------------------------------------------------------------------------------+
|
|
|
188 |
* $Log$
|
|
|
189 |
* Revision 1.11 2008-11-13 11:29:12 ddelon
|
|
|
190 |
* Reecriture gwt-ext
|
|
|
191 |
*
|
|
|
192 |
* Revision 1.10 2008-01-30 08:57:28 ddelon
|
|
|
193 |
* fin mise en place mygwt
|
|
|
194 |
*
|
|
|
195 |
* Revision 1.9 2007-05-22 12:54:09 ddelon
|
|
|
196 |
* Securisation acces utilisateur
|
|
|
197 |
*
|
|
|
198 |
*/
|
| 922 |
aurelien |
199 |
?>
|