Subversion Repositories Applications.referentiel

Rev

Rev 30 | Rev 38 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 30 Rev 33
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * DAO des traitements à réaliser sur les référentiels.
4
 * DAO des traitements à réaliser sur les référentiels.
5
 *
5
 *
6
 * @package		Referentiel
6
 * @package		Referentiel
7
 * @category	Php 5.2
7
 * @category	Php 5.2
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		$Id$
12
 * @version		$Id$
13
 *
13
 *
14
 */
14
 */
15
class TraitementDao extends Dao {
15
class TraitementDao extends Dao {
16
	const SERVICE = 'Traitement';
16
	const SERVICE = 'Traitement';
17
	
17
	
18
	private $url = null;
18
	private $url = null;
19
	
19
	
20
	public function __construct() {
20
	public function __construct() {
21
		parent::__construct();
21
		parent::__construct();
22
		$this->url = $this->url_jrest.self::SERVICE;
22
		$this->url = $this->url_jrest.self::SERVICE;
23
	}
23
	}
24
	
24
	
25
	/**
25
	/**
-
 
26
	 * Retourne les infos d'un traitement enregistré dans la bdd pour un id donné.
-
 
27
	 * 
-
 
28
	 * @param integer l'id du traitement.
-
 
29
	 * @return array le tableau d'infos ou false en cas d'échec.
-
 
30
	 */
-
 
31
	public function getInfos($id_traitement) {
-
 
32
		$url = $this->url."/Info/$id_traitement";
-
 
33
		
-
 
34
		$json = $this->envoyerRequeteConsultation($url);
-
 
35
		$infos = json_decode($json, true);
-
 
36
		return $infos;
-
 
37
	}
-
 
38
	
-
 
39
	/**
26
	 * Retourne l'ensemble des traitements en cours.
40
	 * Retourne l'ensemble des traitements en cours.
27
	 * 
41
	 * 
28
	 * @param string le code du projet de référentiel.
42
	 * @param string le code du projet de référentiel.
29
	 * @return mixed un tableau contenant les informations sur les traitements en cours ou false en cas d'échec.
43
	 * @return mixed un tableau contenant les informations sur les traitements en cours ou false en cas d'échec.
30
	 */
44
	 */
31
	public function getTraitementsEnCours($code_projet) {
45
	public function getTraitementsEnCours($code_projet) {
32
		$url = $this->url."/EnCours/$code_projet";
46
		$url = $this->url."/EnCours/$code_projet";
33
		
47
		
34
		$json = $this->envoyerRequeteConsultation($url);
48
		$json = $this->envoyerRequeteConsultation($url);
35
		$traitements = json_decode($json, true);
49
		$traitements = json_decode($json, true);
36
		return $traitements;
50
		return $traitements;
37
	}
51
	}
38
	
52
	
39
	/**
53
	/**
40
	 * Retourne les ids de l'ensemble des traitements obsolètes.
54
	 * Retourne les ids de l'ensemble des traitements obsolètes.
41
	 * 
55
	 * 
42
	 * @param string le code du projet de référentiel.
56
	 * @param string le code du projet de référentiel.
43
	 * @return mixed un tableau contenant les ids des traitements obsolètes ou false en cas d'échec.
57
	 * @return mixed un tableau contenant les ids des traitements obsolètes ou false en cas d'échec.
44
	 */
58
	 */
45
	public function getTraitementsObsoletes($code_projet) {
59
	public function getTraitementsObsoletes($code_projet) {
46
		$url = $this->url."/Obsolete/$code_projet";
60
		$url = $this->url."/Obsolete/$code_projet";
47
		
61
		
48
		$json = $this->envoyerRequeteConsultation($url);
62
		$json = $this->envoyerRequeteConsultation($url);
49
		$traitements = json_decode($json, true);
63
		$traitements = json_decode($json, true);
50
		return $traitements;
64
		return $traitements;
51
	}
65
	}
52
	
66
	
53
	/**
67
	/**
54
	 * Retourne le dernier traitement demandé et non traité pour un projet donné.
68
	 * Retourne le dernier traitement demandé et non traité pour un projet donné.
55
	 * 
69
	 * 
56
	 * @param string le code du projet de référentiel.
70
	 * @param string le code du projet de référentiel.
57
	 * @return mixed un tableau contenant les informations sur le dernier traitement demandé et non traité ou false en cas d'échec.
71
	 * @return mixed un tableau contenant les informations sur le dernier traitement demandé et non traité ou false en cas d'échec.
58
	 */
72
	 */
59
	public function getDernierTraitement($code_projet) {
73
	public function getDernierTraitement($code_projet) {
60
		$url = $this->url."/DerniereDemande/$code_projet";
74
		$url = $this->url."/DerniereDemande/$code_projet";
61
		
75
		
62
		$json = $this->envoyerRequeteConsultation($url);
76
		$json = $this->envoyerRequeteConsultation($url);
63
		$traitements = json_decode($json, true);
77
		$traitements = json_decode($json, true);
64
		return $traitements;
78
		return $traitements;
65
	}
79
	}
66
	
80
	
67
	/**
81
	/**
68
	 * Retourne l'ensemble des traitements terminés.
82
	 * Retourne l'ensemble des traitements terminés.
69
	 * 
83
	 * 
70
	 * @param string le code du projet de référentiel.
84
	 * @param string le code du projet de référentiel.
71
	 * @return mixed un tableau contenant les informations sur les traitements terminés ou false en cas d'échec.
85
	 * @return mixed un tableau contenant les informations sur les traitements terminés ou false en cas d'échec.
72
	 */
86
	 */
73
	public function getTraitementsTermines($code_projet) {
87
	public function getTraitementsTermines($code_projet) {
74
		$url = $this->url."/Termines/$code_projet";
88
		$url = $this->url."/Termines/$code_projet";
75
		
89
		
76
		$json = $this->envoyerRequeteConsultation($url);
90
		$json = $this->envoyerRequeteConsultation($url);
77
		$traitements = json_decode($json, true);
91
		$traitements = json_decode($json, true);
78
		return $traitements;
92
		return $traitements;
79
	}
93
	}
80
	
94
	
81
	/**
95
	/**
82
	 * Ajoute une demande de traitement pour une référentiel donné.
96
	 * Ajoute une demande de traitement pour une référentiel donné.
83
	 * 
97
	 * 
84
	 * @param string le code du référentiel.
98
	 * @param string le code du référentiel.
85
	 * @return mixed l'id du traitement ou false en cas d'échec.
99
	 * @return mixed l'id du traitement ou false en cas d'échec.
86
	 */
100
	 */
87
	public function ajouterTraitement($code_projet) {
101
	public function ajouterTraitement($code_projet) {
88
		// Préparation des données à passer par POST
102
		// Préparation des données à passer par POST
89
		$donnees['referentiel_code'] = $code_projet;
103
		$donnees['referentiel_code'] = $code_projet;
90
		
104
		
91
		// Envoie des données et récupération du retour
105
		// Envoie des données et récupération du retour
92
		$json = $this->envoyerRequeteAjout($this->url, $donnees);
106
		$json = $this->envoyerRequeteAjout($this->url, $donnees);
93
		$id = json_decode($json, true);
107
		$id = json_decode($json, true);
94
		return $id;
108
		return $id;
95
	}
109
	}
96
	
110
	
97
	/**
111
	/**
98
	 * Modifie un traitement pour indiquer qu'il est débuté.
112
	 * Modifie un traitement pour indiquer qu'il est débuté.
99
	 * 
113
	 * 
100
	 * @param integer l'id du traitement
114
	 * @param integer l'id du traitement
101
	 * @return boolean true en cas de succés sinon false.
115
	 * @return boolean true en cas de succés sinon false.
102
	 */
116
	 */
103
	public function debuterTraitement($id_traitement) {
117
	public function debuterTraitement($id_traitement) {
104
		$url = $this->url."/$id_traitement";
118
		$url = $this->url."/$id_traitement";
105
		$donnees['action'] = 'Debuter';
119
		$donnees['action'] = 'Debuter';
106
		
120
		
107
		// Envoie des données et récupération du retour
121
		// Envoie des données et récupération du retour
108
		$json = $this->envoyerRequeteModif($url, $donnees);
122
		$json = $this->envoyerRequeteModif($url, $donnees);
109
		$ok = json_decode($json, true);
123
		$ok = json_decode($json, true);
110
		return $ok;
124
		return $ok;
111
	}
125
	}
112
	
126
	
113
	/**
127
	/**
114
	 * Modifie un traitement pour indiquer qu'il est terminé.
128
	 * Modifie un traitement pour indiquer qu'il est terminé.
115
	 * 
129
	 * 
116
	 * @param integer l'id du traitement
130
	 * @param integer l'id du traitement
117
	 * @return boolean true en cas de succés sinon false.
131
	 * @return boolean true en cas de succés sinon false.
118
	 */
132
	 */
119
	public function terminerTraitement($id_traitement) {
133
	public function terminerTraitement($id_traitement) {
120
		$url = $this->url."/$id_traitement";
134
		$url = $this->url."/$id_traitement";
121
		$donnees['action'] = 'Terminer';
135
		$donnees['action'] = 'Terminer';
122
		
136
		
123
		// Envoie des données et récupération du retour
137
		// Envoie des données et récupération du retour
124
		$json = $this->envoyerRequeteModif($url, $donnees);
138
		$json = $this->envoyerRequeteModif($url, $donnees);
125
		$ok = json_decode($json, true);
139
		$ok = json_decode($json, true);
126
		return $ok;
140
		return $ok;
127
	}
141
	}
128
	
142
	
129
	/**
143
	/**
130
	 * Supprime des traitments en fonction de leur id.
144
	 * Supprime des traitments en fonction de leur id.
131
	 * 
145
	 * 
132
	 * @param array le tableau des id des traitements à supprimer
146
	 * @param array le tableau des id des traitements à supprimer
133
	 * @return boolean true en cas de succès ou false en cas d'échec.
147
	 * @return boolean true en cas de succès ou false en cas d'échec.
134
	 */
148
	 */
135
	public function supprimer(Array $ids) {
149
	public function supprimer(Array $ids) {
136
		// Préparation de l'url
150
		// Préparation de l'url
137
		$url = $this->url.'/'.implode(',', $ids);
151
		$url = $this->url.'/'.implode(',', $ids);
138
		
152
		
139
		// Envoie des données et récupération du retour
153
		// Envoie des données et récupération du retour
140
		$json = $this->envoyerRequeteSuppression($url);
154
		$json = $this->envoyerRequeteSuppression($url);
141
		$ok = json_decode($json, true);
155
		$ok = json_decode($json, true);
142
		return $ok;
156
		return $ok;
143
	}
157
	}
144
}
158
}
145
?>
159
?>