Subversion Repositories Applications.referentiel

Rev

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

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