Subversion Repositories Applications.referentiel

Rev

Rev 24 | Rev 30 | 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
	/**
24 jpm 26
	 * Retourne l'ensemble des traitements en instance.
27
	 *
26 jpm 28
	 * @param string le code du projet de référentiel.
29
	 * @return array un tableau contenant les informations sur les traitements en cours ou en attente.
24 jpm 30
	 */
26 jpm 31
	public function getTraitementsEnCours($code_projet) {
32
		$url = $this->url."/EnCours/$code_projet";
24 jpm 33
 
34
		$json = $this->envoyerRequeteConsultation($url);
35
		$traitements = json_decode($json, true);
36
		return $traitements;
37
	}
38
 
39
	/**
26 jpm 40
	 * Retourne les ids de l'ensemble des traitements obsolètes.
23 jpm 41
	 *
26 jpm 42
	 * @param string le code du projet de référentiel.
43
	 * @return array un tableau contenant les ids des traitements obsolètes.
44
	 */
45
	public function getTraitementsObsoletes($code_projet) {
46
		$url = $this->url."/Obsolete/$code_projet";
47
 
48
		$json = $this->envoyerRequeteConsultation($url);
49
		$traitements = json_decode($json, true);
50
		return $traitements;
51
	}
52
 
53
	/**
54
	 * Retourne le dernier traitement demandé et non traité pour un projet donné.
55
	 *
56
	 * @param string le code du projet de référentiel.
57
	 * @return array un tableau contenant les informations sur le dernier traitement demandé et non traité.
58
	 */
59
	public function getDernierTraitement($code_projet) {
60
		$url = $this->url."/DerniereDemande/$code_projet";
61
 
62
		$json = $this->envoyerRequeteConsultation($url);
63
		$traitements = json_decode($json, true);
64
		return $traitements;
65
	}
66
 
67
	/**
68
	 * Ajoute une demande de traitement pour une référentiel donné.
69
	 *
23 jpm 70
	 * @param string le code du référentiel.
71
	 * @return mixed l'id du traitement ou false en cas d'échec.
72
	 */
73
	public function ajouterTraitement($code_projet) {
26 jpm 74
		// Préparation des données à passer par POST
23 jpm 75
		$donnees['referentiel_code'] = $code_projet;
76
 
77
		// Envoie des données et récupération du retour
26 jpm 78
		$json = $this->envoyerRequeteAjout($this->url, $donnees);
23 jpm 79
		$id = json_decode($json, true);
80
		return $id;
81
	}
26 jpm 82
 
83
	/**
84
	 * Modifie un traitement pour indiquer qu'il est débuté.
85
	 *
86
	 * @param integer l'id du traitement
87
	 * @return boolean true en cas de succés sinon false.
88
	 */
89
	public function debuterTraitement($id_traitement) {
90
		$url = $this->url."/$id_traitement";
91
		$donnees['action'] = 'Debuter';
92
 
93
		// Envoie des données et récupération du retour
94
		$json = $this->envoyerRequeteModif($url, $donnees);
95
		$ok = json_decode($json, true);
96
		return $ok;
97
	}
98
 
99
	/**
100
	 * Supprime des traitments en fonction de leur id.
101
	 *
102
	 * @param array le tableau des id des traitements à supprimer
103
	 * @return boolean true en cas de succès ou false en cas d'échec.
104
	 */
105
	public function supprimer(Array $ids) {
106
		// Préparation de l'url
107
		$url = $this->url.'/'.implode(',', $ids);
108
 
109
		// Envoie des données et récupération du retour
110
		$json = $this->envoyerRequeteSuppression($url);
111
		$ok = json_decode($json, true);
112
		return $ok;
113
	}
23 jpm 114
}
115
?>