Subversion Repositories Sites.obs-saisons.fr

Rev

Rev 31 | Rev 46 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
31 aurelien 1
<?php
2
 
3
class OdsEvenement 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
     * Méthode appelée pour ajouter un élément.
33
     */
34
    public function createElement($params) {
35
        // Identification de l'utilisateur
36
        list($id_utilisateur, $id_session) = $this->getIdentification($params);
37
 
38
        // Contrôle du non détournement de l'utilisateur
39
        if ($this->etreAutorise($id_utilisateur)) {
40
            try {
41
 
42
            } catch (PDOException $e) {
43
                $this->messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
44
            }
45
        }
46
        $this->envoyer((string) $id_personne);
47
    }
48
 
49
    /**
50
     * Méthode appelée pour mettre à jour un élément
51
     */
52
    public function updateElement($uid, $params)    {
53
        //Mise à jour de la personne
54
        // Identification de l'utilisateur
55
        list($id_utilisateur, $id_session) = $this->getIdentification($params);
56
 
57
        // Contrôle du non détournement de l'utilisateur
58
        if ($this->etreAutorise($id_utilisateur)) {
59
            try {
60
 
61
            } catch (PDOException $e) {
62
                $messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
63
            }
64
        }
65
 
66
        $this->envoyer();
67
    }
68
 
69
    /**
70
     * Méthode appelée pour supprimer un élément
71
     */
72
    public function deleteElement($uid) {
73
        // Vérification de la présence des id passés par l'url
74
        if (!isset($uid[0]) || !isset($uid[1])) {
75
            $this->messages[] = "Identifiant d'utilisateur ou de personne manquant. Vous ne devriez pas avoir accès à ce service.";
76
        } else {
77
            list($id_utilisateur, $id_session) = $this->getIdentification($uid[0]);
78
 
79
            // Contrôle du non détournement de l'utilisateur
80
            if ($this->etreAutorise($id_utilisateur)) {
81
                // Récupération des id passés par l'url
82
                $identifiants = explode(',', rtrim($uid[1], ','));
83
                if (count($identifiants) == 0) {
84
                    $this->messages[] = "Aucun enregistrement n'a été supprimé.";
85
                } else {
86
                    foreach ($identifiants as $id_personne) {
87
                        try {
88
                        } catch (PDOException $e) {
89
                            $this->messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
90
                        }
91
                    }
92
                }
93
            }
94
        }
95
 
96
        // Envoie sur la sortie standard
97
        $this->envoyer();
98
    }
99
 
100
   	private function getElementParDefaut($param) {
101
 
102
   	}
103
 
41 aurelien 104
    private function getEvenementsPourEspece($params) {
105
 
106
    	$id_espece = $params[0];
107
 
108
    	$requete_evenements_pour_espece = 'SELECT oe_ce_evenements FROM ods_especes '.
109
										   'WHERE oe_id_espece = '.$this->proteger($id_espece);
110
 
111
    	$evenements_pour_espece = $this->executerRequete($requete_evenements_pour_espece);
112
    	$evenements_pour_espece = $evenements_pour_espece[0]['oe_ce_evenements'];
113
 
114
    	$tableau_evenements_espece = split(',',$evenements_pour_espece);
115
    	foreach($tableau_evenements_espece as &$evenement_espece) {
116
    		$evenement_espece = $this->proteger($evenement_espece);
117
    	}
118
 
119
    	$evenements_espece_chaine_bdd = implode(',',$tableau_evenements_espece);
120
 
121
    	$requete_liste_evenements_pour_espece = 'SELECT * FROM ods_triples '.
122
										   		'WHERE ot_id_triple IN '.
123
										   		'('.$evenements_espece_chaine_bdd.')';
124
 
125
    	$liste_evenements_pour_espece = $this->executerRequete($requete_liste_evenements_pour_espece);
126
 
127
	    $liste_evenements_pour_espece_formatee = $this->formaterTableauEvenementPourEnvoi($liste_evenements_pour_espece);
128
 
129
		return $liste_evenements_pour_espece_formatee;
31 aurelien 130
    }
41 aurelien 131
 
132
    private function formaterTableauEvenementPourEnvoi($liste_evenements) {
133
 
134
		$tableau_evenements_formate = array();
135
 
136
	    foreach($liste_evenements as $evenement) {
137
 
138
	   			$stade_observation_complet = $evenement['ot_cle'];
139
 
140
	   			$infos_stades = split('_',$stade_observation_complet);
141
 
142
	   			$titre_stade = $infos_stades[1];
143
	   			$numero_stade = $infos_stades[3];
144
 
145
	   			$tableau_evenements_formate[$titre_stade]['id'] = $evenement['ot_id_triple'];
146
	   			$tableau_evenements_formate[$titre_stade]['nom'] = $titre_stade;
147
	   			$tableau_evenements_formate[$titre_stade]['stades'][] = $numero_stade;
148
 
149
	   	}
150
 
151
	   	return $tableau_evenements_formate;
152
    }
31 aurelien 153
}
154
?>