Subversion Repositories Sites.obs-saisons.fr

Rev

Rev 301 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
104 aurelien 1
<?php
2
 
3
class OdsCommune extends JRestService {
4
 
5
        const PREFIXE = 'get';
6
 
7
        /**
8
     * Méthode appelée avec une requête de type GET.
9
     *
10
     */
11
    function getElement($param = array()) {
12
 
13
        $type = $param[0];
14
 
15
        if ($type == '*' || is_numeric($type)) {
16
            $info = $this->getElementParDefaut($param);
17
        } else {
18
            $methode = self::PREFIXE.$type;
19
            if (method_exists($this, $methode)) {
20
                array_shift($param);
21
                $info = $this->$methode($param);
22
            } else {
23
                $this->messages[] = "Le type d'information demandé '$type' n'est pas disponible.";
24
            }
25
        }
26
 
27
        // Envoi sur la sortie standard
28
        $this->envoyer($info);
29
    }
30
 
31
 
32
/** ======================= Methodes privées d'accès aux informations ================================ */  
33
 
34
    private function getElementParDefaut() {
35
        return $this->getInformationsPourCoordonnees();
36
    }
37
 
301 aurelien 38
    private function getInformationsPourCoordonnees($params) {
104 aurelien 39
 
40
        $lat = $_GET['lat'];
41
        $lon = $_GET['lon'];
42
 
297 aurelien 43
        // les erreurs sont mises sous silence car le cas où file_get_contents ne retourne rien
44
        // correspond à un cas valide où l'on a pas de données sur ses coordonnées
45
        // (ce cas est traité dans formaterTableauInformationsCoordsPourEnvoi)
46
        $url_atitude = "http://api.tela-botanica.org/service:eflore:0.1/nasa-srtm/altitude?lon=".urlencode($lon)."&lat=".urlencode($lat);
47
        $infos_altitude_json = @file_get_contents($url_atitude);
171 aurelien 48
 
297 aurelien 49
                $url_commune = "http://api.tela-botanica.org/service:eflore:0.1/osm/nom-commune?lon=".urlencode($lon)."&lat=".urlencode($lat);
50
        $infos_commune_json = @file_get_contents($url_commune);
104 aurelien 51
 
297 aurelien 52
 
104 aurelien 53
                $infos_localites = $this->formaterTableauInformationsCoordsPourEnvoi($infos_altitude_json, $infos_commune_json);        
54
 
55
        return $infos_localites;
56
    }
57
 
58
    private function getInformationsPourCommune($params) {
59
 
60
        $commune = $_GET['commune'];
61
 
62
        $commune = $this->remplacerNomCommunePourRecherche($commune);
63
 
171 aurelien 64
        $requete_infos_communes = 'SELECT * FROM ods_communes WHERE oc_nom LIKE '.$this->proteger($commune).' ORDER BY oc_nom LIMIT 0,10';
104 aurelien 65
        $infos_communes = $this->executerRequete($requete_infos_communes);
297 aurelien 66
 
104 aurelien 67
                $infos_communes_formatees = $this->formaterTableauInformationsCommunePourEnvoi($infos_communes);        
68
 
69
        return $infos_communes_formatees;
70
    }
71
 
207 aurelien 72
    private function getEstUneCommunePhenoclim() {
73
        return $this->estUneCommunePhenoclim($_GET);
74
    }
75
 
76
    private function estUneCommunePhenoclim($params) {
77
 
78
        $code_insee = null;
79
        $code_postal = null;
80
 
81
        if(!isset($params['code_postal']) && !isset($params['code_insee'])) {
82
                return false;
83
        }
84
 
85
        if(isset($params['code_postal'])) {
86
                $code_postal = $params['code_postal'];
87
        }
88
 
89
        if(isset($params['code_insee'])) {
90
                $code_insee = $params['code_insee'];
91
        }
92
 
93
        if($code_postal != null) {
94
                $requete_commune_phenoclim = 'SELECT occ_code_insee FROM ods_communes_crea WHERE occ_code_postal = '.$this->proteger($code_postal);
95
        } else {
96
                $requete_commune_phenoclim = 'SELECT occ_code_insee FROM ods_communes_crea WHERE occ_code_insee = '.$this->proteger($code_insee);
97
        }
98
 
99
        $resultat_requete_phenoclim = $this->executerRequete($requete_commune_phenoclim);
100
 
101
        if(!empty($resultat_requete_phenoclim)) {
102
                return true;
103
        }
104
 
105
        return false;
106
    }
107
 
104 aurelien 108
    private function remplacerNomCommunePourRecherche($nom) {
109
        $nom = str_replace(' ','_',$nom);
110
        $nom = str_replace('-','_',$nom);
111
        $nom .= '%';
112
 
113
        return $nom;
114
    }
115
 
116
    private function formaterTableauInformationsCoordsPourEnvoi($infos_altitude_json, $infos_commune_json) {
117
 
118
        $infos_altitude = json_decode($infos_altitude_json);
119
        $infos_commune = json_decode($infos_commune_json);
120
 
297 aurelien 121
        $altitude = "";
122
        $dpt = "";
123
        $lat = "";
124
        $lon = "";
125
        $altitude = "";
126
        $code_insee = "";
127
        $commune = "";
128
        $commune_phenoclim = false;
104 aurelien 129
 
130
 
297 aurelien 131
        if(is_object($infos_altitude)) {               
132
                $altitude = $infos_altitude->altitude;
133
                $altitude = number_format($altitude, 0, '', '');
134
                $lat = $infos_altitude->latitude;
135
                $lon = $infos_altitude->longitude;
136
        }
193 aurelien 137
 
297 aurelien 138
        if(is_object($infos_commune)) {
139
                $commune = $infos_commune->nom;
140
                $dpt = $infos_commune->codeINSEE;
141
 
142
                $cp_recherche = $dpt;
143
                        if(strlen($cp_recherche) == 4) {
144
                                $cp_recherche = '0'.$cp_recherche;
145
                        }
146
 
344 killian 147
                        $commune_phenoclim = $this->estUneCommunePhenoclim(array('code_insee' => $cp_recherche));
297 aurelien 148
 
149
                        $cp_recherche = substr($cp_recherche,0,2);
150
 
151
                        $code_insee = '';
152
                        if($commune != null) {
153
                        $code_insee = $this->obtenirCodeInseeCommune($commune, $cp_recherche);
154
                        }
155
        }
193 aurelien 156
 
207 aurelien 157
        $infos_communes = array(
104 aurelien 158
            'commune' => $commune,
159
                'dpt' => $dpt,
160
            'lat' => $lat,
161
            'lon' => $lon,
193 aurelien 162
            'alt' => $altitude,
207 aurelien 163
                'code_insee' => $code_insee,
164
                'commune_phenoclim' => $commune_phenoclim
104 aurelien 165
        );
207 aurelien 166
 
167
        return $infos_communes;
104 aurelien 168
 
169
    }
170
 
171
        private function formaterTableauInformationsCommunePourEnvoi($infos_communes) {
172
 
173
                $infos_formatees = array();
174
 
175
                foreach($infos_communes as $commune) {
176
 
171 aurelien 177
                        $cp = $commune['oc_code_insee'];
178
                        $limite = 2;
179
                        if(strlen($cp) == 4) {
180
                                $limite = 1;
181
                        }
182
 
183
                        $dpt = substr($cp,0,$limite);
184
 
185
                        if($limite == 1) {
186
                                $dpt = '0'.$dpt;
187
                        }
188
 
207 aurelien 189
                        $commune_phenoclim = $this->estUneCommunePhenoclim(array('code_insee' => $commune['oc_code_insee']));
190
 
104 aurelien 191
                        $infos_formatees[] = array(
171 aurelien 192
                        'commune' => $commune['oc_nom'],
193
                        'dpt' => $dpt,
194
                        'lat' => $commune['oc_latitude'],
207 aurelien 195
                                'lon' => $commune['oc_longitude'],
196
                            'alt' => $commune['oc_altitude'],
197
                                'code_insee' => $commune['oc_code_insee'],
198
                                'commune_phenoclim' => $commune_phenoclim
104 aurelien 199
                );
200
                }
297 aurelien 201
 
104 aurelien 202
        return $infos_formatees;
203
    }
193 aurelien 204
 
207 aurelien 205
        public function obtenirNomCommuneParCodeInsee($code_insee_commune) {
206
 
207
                if(!is_numeric($code_insee_commune)) {
208
                        return '';
209
                }
210
 
211
        $requete_infos_commune = 'SELECT * FROM ods_communes WHERE oc_code_insee = '.$this->proteger($code_insee_commune);
212
        $infos_commune = $this->executerRequete($requete_infos_commune);
213
                return $infos_commune[0]['oc_nom'];
214
    }
215
 
210 aurelien 216
        public function obtenirTableauNomsCommunesParTableauCodesInsee($tableau_codes_insee_communes) {
217
 
280 aurelien 218
                $noms_communes = array();
219
 
220
                if(!empty($tableau_codes_insee_communes)) {
221
                        $tableau_codes_insee_communes = array_unique($tableau_codes_insee_communes);
222
                        $chaine_codes_insee = implode($tableau_codes_insee_communes,',');
223
 
224
                $requete_infos_communes = 'SELECT * FROM ods_communes WHERE oc_code_insee IN ('.$chaine_codes_insee.')';
225
                $infos_commune = $this->executerRequete($requete_infos_communes);
226
 
227
                foreach($infos_commune as $commune) {
228
                        $code_insee = $commune['oc_code_insee'];
229
                        $noms_communes[$code_insee] = $commune['oc_nom'];
230
                }
231
                }
210 aurelien 232
 
233
                return $noms_communes;
234
    }
235
 
193 aurelien 236
    private function obtenirCodeInseeCommune($commune, $cp) {
237
 
238
        $commune = $this->remplacerNomCommunePourRecherche($commune);
239
        $requete_code_insee = 'SELECT oc_code_insee FROM ods_communes '.
240
                                                        'WHERE oc_nom LIKE "'.$commune.'" '.
241
                                                        'AND oc_code_insee LIKE "'.$cp.'%"';
242
 
243
        $resultat_requete = $this->executerRequete($requete_code_insee);
244
 
245
        if($resultat_requete) {
246
                return $resultat_requete[0]['oc_code_insee'];
247
        } else {
248
                return '';
249
        }
250
    }
270 aurelien 251
 
252
    public function obtenirCommunesLieesAStationIndexeesCodeInsee() {
253
        $communes = $this->obtenirCommunesLieesAStation();
254
        $communes_assoc = array();
255
 
256
        foreach($communes as $commune) {
257
                $communes_assoc[$commune['oc_code_insee']] = $commune;
258
        }
259
 
260
        return $communes_assoc;
261
    }
262
 
263
    private function obtenirCommunesLieesAStation() {
264
 
265
        $requete = 'SELECT * FROM ods_communes '.
266
                   'INNER JOIN ods_stations '.
267
                   'ON oc_code_insee = os_ce_commune ';
268
 
269
        $resultat_requete = $this->executerRequete($requete);
270
 
271
                return $resultat_requete;
272
    }
104 aurelien 273
}
344 killian 274
?>