1 |
<?php
|
1 |
<?php
|
2 |
// declare(encoding='UTF-8');
|
2 |
// declare(encoding='UTF-8');
|
3 |
/**
|
3 |
/**
|
4 |
* Service CRUD sur une observation.
|
4 |
* Service CRUD sur une observation.
|
5 |
*
|
5 |
*
|
6 |
* @internal Mininum PHP version : 5.2
|
6 |
* @internal Mininum PHP version : 5.2
|
7 |
* @category CEL
|
7 |
* @category CEL
|
8 |
* @package Services
|
8 |
* @package Services
|
9 |
* @subpackage Observations
|
9 |
* @subpackage Observations
|
10 |
* @version 0.1
|
10 |
* @version 0.1
|
11 |
* @author Mathias CHOUET <mathias@tela-botanica.org>
|
11 |
* @author Mathias CHOUET <mathias@tela-botanica.org>
|
12 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
12 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
13 |
* @author Aurelien PERONNET <aurelien@tela-botanica.org>
|
13 |
* @author Aurelien PERONNET <aurelien@tela-botanica.org>
|
14 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
14 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
15 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
15 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
16 |
* @copyright 1999-2014 Tela Botanica <accueil@tela-botanica.org>
|
16 |
* @copyright 1999-2014 Tela Botanica <accueil@tela-botanica.org>
|
17 |
*/
|
17 |
*/
|
18 |
class Inventory extends Cel {
|
18 |
class Inventory extends Cel {
|
19 |
|
19 |
|
20 |
public function getRessource() {
|
20 |
public function getRessource() {
|
21 |
|
21 |
|
22 |
}
|
22 |
}
|
23 |
|
23 |
|
24 |
public function getElement($uid){
|
24 |
public function getElement($uid){
|
25 |
// Controle detournement utilisateur
|
25 |
// Controle detournement utilisateur
|
26 |
$this->controleUtilisateur($uid[0]);
|
26 |
$this->controleUtilisateur($uid[0]);
|
27 |
if (!isset($uid[0])) {
|
27 |
if (!isset($uid[0])) {
|
28 |
return;
|
28 |
return;
|
29 |
}
|
29 |
}
|
30 |
|
30 |
|
31 |
$parametres_recherche = array(array('ce_utilisateur',$uid[0]),array('ordre',$uid[1]));
|
31 |
$parametres_recherche = array(array('ce_utilisateur',$uid[0]),array('ordre',$uid[1]));
|
32 |
|
32 |
|
33 |
$chercheur_observations = new RechercheObservation($this->config);
|
33 |
$chercheur_observations = new RechercheObservation($this->config);
|
34 |
$retour_recherche = $chercheur_observations->rechercherObservations($uid[0], $parametres_recherche, 0, 1)->get();
|
34 |
$retour_recherche = $chercheur_observations->rechercherObservations($uid[0], $parametres_recherche, 0, 1)->get();
|
35 |
|
35 |
|
36 |
$observation = array();
|
36 |
$observation = array();
|
37 |
if (is_array($retour_recherche) && count($retour_recherche) > 0) {
|
37 |
if (is_array($retour_recherche) && count($retour_recherche) > 0) {
|
38 |
$observation = $retour_recherche[0];
|
38 |
$observation = $retour_recherche[0];
|
39 |
}
|
39 |
}
|
40 |
$observation = $this->formaterObservationVersTableauSequentiel($observation);
|
40 |
$observation = $this->formaterObservationVersTableauSequentiel($observation);
|
41 |
$sortie = json_encode($observation);
|
41 |
$sortie = json_encode($observation);
|
42 |
$this->envoyerJson($sortie);
|
42 |
$this->envoyerJson($sortie);
|
43 |
return true;
|
43 |
return true;
|
44 |
}
|
44 |
}
|
45 |
|
45 |
|
46 |
private function formaterObservationVersTableauSequentiel(&$observation) {
|
46 |
private function formaterObservationVersTableauSequentiel(&$observation) {
|
47 |
if ($observation['date_observation']!="0000-00-00 00:00:00") {
|
47 |
if ($observation['date_observation']!="0000-00-00 00:00:00") {
|
48 |
list($year,$month,$day)= explode('-',$observation['date_observation']);
|
48 |
list($year,$month,$day)= explode('-',$observation['date_observation']);
|
49 |
list($day)= explode(' ',$day);
|
49 |
list($day)= explode(' ',$day);
|
50 |
$observation['date_observation']=$day."/".$month."/".$year;
|
50 |
$observation['date_observation']=$day."/".$month."/".$year;
|
51 |
}
|
51 |
}
|
52 |
|
52 |
|
53 |
$observation = array($observation['nom_sel'], $observation['nom_sel_nn'],
|
53 |
$observation = array($observation['nom_sel'], $observation['nom_sel_nn'],
|
54 |
$observation['nom_ret'], $observation['nom_ret_nn'],
|
54 |
$observation['nom_ret'], $observation['nom_ret_nn'],
|
55 |
$observation['nt'], $observation['famille'], $observation['zone_geo'],
|
55 |
$observation['nt'], $observation['famille'], $observation['zone_geo'],
|
56 |
$observation['ce_zone_geo'], $observation['ordre'],
|
56 |
$observation['ce_zone_geo'], $observation['ordre'],
|
57 |
$observation['date_observation'], $observation['lieudit'],
|
57 |
$observation['date_observation'], $observation['lieudit'],
|
58 |
$observation['station'], $observation['milieu'],
|
58 |
$observation['station'], $observation['milieu'],
|
59 |
$observation['commentaire'], $observation['latitude'],
|
59 |
$observation['commentaire'], $observation['latitude'],
|
60 |
$observation['longitude']);
|
60 |
$observation['longitude']);
|
61 |
return $observation;
|
61 |
return $observation;
|
62 |
}
|
62 |
}
|
63 |
|
63 |
|
64 |
public function updateElement($uid,$pairs) {
|
64 |
public function updateElement($uid,$pairs) {
|
65 |
// Controle detournement utilisateur
|
65 |
// Controle detournement utilisateur
|
66 |
$this->controleUtilisateur($uid[0]);
|
66 |
$this->controleUtilisateur($uid[0]);
|
67 |
|
67 |
|
68 |
if (!isset($uid[1])) {
|
68 |
if (!isset($uid[1])) {
|
69 |
//TODO: envoyer un message d'erreur
|
69 |
//TODO: envoyer un message d'erreur
|
70 |
return;
|
70 |
return;
|
71 |
}
|
71 |
}
|
72 |
|
72 |
|
73 |
$uid[1] = rtrim($uid[1],',');
|
73 |
$uid[1] = rtrim($uid[1],',');
|
74 |
|
74 |
|
75 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
75 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
76 |
unset($pairs['obs_etendue']);
|
76 |
unset($pairs['obs_etendue']);
|
77 |
|
77 |
|
78 |
if (isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
78 |
if (isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
79 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
79 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
80 |
if(!$time || $time > time()) {
|
80 |
if(!$time || $time > time()) {
|
81 |
throw new Exception('Date invalide');
|
81 |
throw new Exception('Date invalide');
|
82 |
}
|
82 |
}
|
83 |
}
|
83 |
}
|
84 |
// un nom de bdtfxr est en fait un nom de bdtfx, de même pour les sous-référentiels d'afrique
|
84 |
// un nom de bdtfxr est en fait un nom de bdtfx, de même pour les sous-référentiels d'afrique
|
85 |
if ($pairs['nom_referentiel'] == 'bdtfxr') {
|
85 |
if ($pairs['nom_referentiel'] == 'bdtfxr') {
|
86 |
$pairs['nom_referentiel'] = 'bdtfx';
|
86 |
$pairs['nom_referentiel'] = 'bdtfx';
|
87 |
} /* elseif (in_array($pairs['nom_referentiel'], array('apdfna', 'apdfta', 'apdfsa'))) {
|
87 |
} /* elseif (in_array($pairs['nom_referentiel'], array('apdfna', 'apdfta', 'apdfsa'))) {
|
88 |
$pairs['nom_referentiel'] == 'apd';
|
88 |
$pairs['nom_referentiel'] == 'apd';
|
89 |
} */
|
89 |
} */
|
90 |
$gestionnaire_observation = new GestionObservation($this->config);
|
90 |
$gestionnaire_observation = new GestionObservation($this->config);
|
91 |
$modification_observation = $gestionnaire_observation->modifierObservation($uid[0],$uid[1],$pairs);
|
91 |
$modification_observation = $gestionnaire_observation->modifierObservation($uid[0],$uid[1],$pairs);
|
92 |
|
92 |
|
93 |
if ($champs_etendus != null) {
|
93 |
if ($champs_etendus != null) {
|
94 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
94 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
95 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
95 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
96 |
foreach($champs_etendus as &$champ_etendu) {
|
96 |
foreach($champs_etendus as &$champ_etendu) {
|
97 |
$objet_champ_etendu = new ChampEtendu();
|
97 |
$objet_champ_etendu = new ObsEtendue();
|
98 |
$objet_champ_etendu->id = $id_obs;
|
98 |
$objet_champ_etendu->id = $id_obs;
|
99 |
if($this->doitGenererCleChampEtendu($champ_etendu)) {
|
99 |
if($this->doitGenererCleChampEtendu($champ_etendu)) {
|
100 |
$champ_etendu['cle'] = $gestion_champs_etendus->transformerLabelEnCle($champ_etendu['label']);
|
100 |
$champ_etendu['cle'] = $gestion_champs_etendus->transformerLabelEnCle($champ_etendu['label']);
|
101 |
}
|
101 |
}
|
102 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
102 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
103 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
103 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
104 |
$champ_etendu = $objet_champ_etendu;
|
104 |
$champ_etendu = $objet_champ_etendu;
|
105 |
}
|
105 |
}
|
106 |
// ajouterParLots modifie les champs et ajoute ceux qui existent déjà
|
106 |
// ajouterParLots modifie les champs et ajoute ceux qui existent déjà
|
107 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
107 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
108 |
}
|
108 |
}
|
109 |
return true;
|
109 |
return true;
|
110 |
}
|
110 |
}
|
111 |
|
111 |
|
112 |
public function createElement($pairs) {
|
112 |
public function createElement($pairs) {
|
113 |
// Controle detournement utilisateur
|
113 |
// Controle detournement utilisateur
|
114 |
$this->controleUtilisateur($pairs['ce_utilisateur']);
|
114 |
$this->controleUtilisateur($pairs['ce_utilisateur']);
|
115 |
|
115 |
|
116 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
116 |
$champs_etendus = isset($pairs['obs_etendue']) ? json_decode(stripslashes($pairs['obs_etendue']),true) : null;
|
117 |
unset($pairs['obs_etendue']);
|
117 |
unset($pairs['obs_etendue']);
|
118 |
|
118 |
|
119 |
if (isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
119 |
if (isset($pairs['date_observation']) && !empty($pairs['date_observation'])) {
|
120 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
120 |
$time = strtotime(str_replace("/", "-", $pairs['date_observation']));
|
121 |
if(!$time || $time > time()) {
|
121 |
if(!$time || $time > time()) {
|
122 |
throw new Exception('Date invalide');
|
122 |
throw new Exception('Date invalide');
|
123 |
}
|
123 |
}
|
124 |
}
|
124 |
}
|
125 |
|
125 |
|
126 |
// un nom de bdtfxr est en fait un nom de bdtfx, de même pour les sous-référentiels d'afrique
|
126 |
// un nom de bdtfxr est en fait un nom de bdtfx, de même pour les sous-référentiels d'afrique
|
127 |
if ($pairs['nom_referentiel'] == 'bdtfxr') {
|
127 |
if ($pairs['nom_referentiel'] == 'bdtfxr') {
|
128 |
$pairs['nom_referentiel'] = 'bdtfx';
|
128 |
$pairs['nom_referentiel'] = 'bdtfx';
|
129 |
} elseif (in_array($pairs['nom_referentiel'], array('apdfna', 'apdfta', 'apdfsa'))) {
|
129 |
} elseif (in_array($pairs['nom_referentiel'], array('apdfna', 'apdfta', 'apdfsa'))) {
|
130 |
$pairs['nom_referentiel'] == 'apd';
|
130 |
$pairs['nom_referentiel'] == 'apd';
|
131 |
}
|
131 |
}
|
132 |
|
132 |
|
133 |
$gestionnaire_observation = new GestionObservation($this->config);
|
133 |
$gestionnaire_observation = new GestionObservation($this->config);
|
134 |
$id_nouvelle_obs = $gestionnaire_observation->ajouterObservation($pairs['ce_utilisateur'], $pairs);
|
134 |
$id_nouvelle_obs = $gestionnaire_observation->ajouterObservation($pairs['ce_utilisateur'], $pairs);
|
135 |
|
135 |
|
136 |
if ($champs_etendus != null) {
|
136 |
if ($champs_etendus != null) {
|
137 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
137 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
138 |
foreach($champs_etendus as &$champ_etendu) {
|
138 |
foreach($champs_etendus as &$champ_etendu) {
|
139 |
$objet_champ_etendu = new ChampEtendu();
|
139 |
$objet_champ_etendu = new ObsEtendue();
|
140 |
$objet_champ_etendu->id = $id_nouvelle_obs;
|
140 |
$objet_champ_etendu->id = $id_nouvelle_obs;
|
141 |
if($this->doitGenererCleChampEtendu($champ_etendu)) {
|
141 |
if($this->doitGenererCleChampEtendu($champ_etendu)) {
|
142 |
$champ_etendu['cle'] = $gestion_champs_etendus->transformerLabelEnCle($champ_etendu['label']);
|
142 |
$champ_etendu['cle'] = $gestion_champs_etendus->transformerLabelEnCle($champ_etendu['label']);
|
143 |
}
|
143 |
}
|
144 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
144 |
$objet_champ_etendu->cle = $champ_etendu['cle'];
|
145 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
145 |
$objet_champ_etendu->valeur = $champ_etendu['valeur'];
|
146 |
$champ_etendu = $objet_champ_etendu;
|
146 |
$champ_etendu = $objet_champ_etendu;
|
147 |
}
|
147 |
}
|
148 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
148 |
$champs_supp = $gestion_champs_etendus->ajouterParLots($champs_etendus);
|
149 |
}
|
149 |
}
|
150 |
return true;
|
150 |
return true;
|
151 |
}
|
151 |
}
|
152 |
|
152 |
|
153 |
/**
|
153 |
/**
|
154 |
* Supprime une observation
|
154 |
* Supprime une observation
|
155 |
*
|
155 |
*
|
156 |
* uid[0] : utilisateur obligatoire
|
156 |
* uid[0] : utilisateur obligatoire
|
157 |
* uid[1] : ordres de l'observation à supprimer
|
157 |
* uid[1] : ordres de l'observation à supprimer
|
158 |
*/
|
158 |
*/
|
159 |
public function deleteElement($uid){
|
159 |
public function deleteElement($uid){
|
160 |
// Controle detournement utilisateur
|
160 |
// Controle detournement utilisateur
|
161 |
$this->controleUtilisateur($uid[0]);
|
161 |
$this->controleUtilisateur($uid[0]);
|
162 |
|
162 |
|
163 |
if (!isset($uid[1])) {
|
163 |
if (!isset($uid[1])) {
|
164 |
//TODO: envoyer un message d'erreur
|
164 |
//TODO: envoyer un message d'erreur
|
165 |
return;
|
165 |
return;
|
166 |
}
|
166 |
}
|
167 |
|
167 |
|
168 |
$uid[1] = rtrim($uid[1],',');
|
168 |
$uid[1] = rtrim($uid[1],',');
|
169 |
|
169 |
|
170 |
$gestionnaire_observation = new GestionObservation($this->config);
|
170 |
$gestionnaire_observation = new GestionObservation($this->config);
|
171 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
171 |
$id_obs = $gestionnaire_observation->renvoyerIdPourOrdre($uid[0],$uid[1]);
|
172 |
$suppression_observation = $gestionnaire_observation->supprimerObservation($uid[0],$uid[1]);
|
172 |
$suppression_observation = $gestionnaire_observation->supprimerObservation($uid[0],$uid[1]);
|
173 |
|
173 |
|
174 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
174 |
$gestion_champs_etendus = new GestionChampsEtendus($this->config, 'obs');
|
175 |
$champs_supp = $gestion_champs_etendus->vider($id_obs);
|
175 |
$champs_supp = $gestion_champs_etendus->vider($id_obs);
|
176 |
|
176 |
|
177 |
$gestionnaire_images = new GestionImage($this->config);
|
177 |
$gestionnaire_images = new GestionImage($this->config);
|
178 |
$gestionnaire_images->modifierTransmissionParObs($id_obs, false);
|
178 |
$gestionnaire_images->modifierTransmissionParObs($id_obs, false);
|
179 |
|
179 |
|
180 |
if ($suppression_observation) {
|
180 |
if ($suppression_observation) {
|
181 |
echo "OK";
|
181 |
echo "OK";
|
182 |
}
|
182 |
}
|
183 |
exit();
|
183 |
exit();
|
184 |
}
|
184 |
}
|
185 |
|
185 |
|
186 |
private function doitGenererCleChampEtendu($champ_etendu) {
|
186 |
private function doitGenererCleChampEtendu($champ_etendu) {
|
187 |
return !isset($champ_etendu['cle']) ||
|
187 |
return !isset($champ_etendu['cle']) ||
|
188 |
trim($champ_etendu['cle'] == "" ||
|
188 |
trim($champ_etendu['cle'] == "" ||
|
189 |
strpos($champ_etendu['cle'],'tempid_') !== false);
|
189 |
strpos($champ_etendu['cle'],'tempid_') !== false);
|
190 |
}
|
190 |
}
|
191 |
}
|
191 |
}
|