Subversion Repositories Applications.referentiel

Rev

Rev 23 | Rev 26 | 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
/**
3
 * Service permettant d'enregistrer une demande de traitement ou de consulter les infos sur les traitements.
4
 * Encodage en entrée : utf8
5
 * Encodage en sortie : utf8
6
 *
7
 * @category	Php 5.2
8
 * @package		Referentiel
9
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
10
 * @license		GPL v3 <http://www.gnu.org/licenses/gpl.txt>
11
 * @license		CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
12
 * @copyright	2010 Tela-Botanica
13
 * @version		$Id$
14
 */
15
class Traitement extends Ref {
24 jpm 16
 
23 jpm 17
	/**
18
	 * Méthode principale appelée avec une requête de type GET.
19
	 */
20
	public function getElement($param = array()) {
21
		// Initialisation des variables
22
		$info = array();
23
 
24
		// Nour recherchons le type de requête demandé
25
		$p = $this->traiterParametresUrl(array('type', 'projet'), $param, false);
26
 
27
		$type = $p['type'];
28
		$projet = $p['projet'];
29
 
30
		if (!is_null($type)) {
31
			if (!is_null($projet)) {
32
				$methode = 'getElement'.$type;
33
				if (method_exists($this, $methode)) {
34
					//array_shift($param);
35
					$info = $this->$methode($projet);
36
				} else {
37
					$this->messages[] = "Le type d'information demandé '$type' n'est pas disponible.";
38
				}
39
 
40
			} else {
41
				$this->messages[] = "Veuillez préciser le nom de code du projet comme premier paramêtre (ex. : bdnff).";
42
			}
43
		} else {
44
			$this->messages[] = "Veuillez préciser le type de requête.";
45
		}
46
 
47
		// Envoie sur la sortie standard
48
		$this->envoyer($info);
49
	}
50
 
51
	/**
24 jpm 52
	 * Retourne les infos sur les traitements en cours ou en attentes.
53
	 */
54
	public function getElementEnCours($projet) {
55
		$projet = $this->bdd->quote($projet);
56
		$requete =	($this->distinct ? 'SELECT DISTINCT' : 'SELECT').' * '.
57
					'FROM ref_traitement '.
58
					"WHERE referentiel_code = $projet ".
59
					'	AND date_fin IS NULL '.
60
					'ORDER BY '.((!is_null($this->orderby)) ? $this->orderby  : 'meta_date_creation  DESC').' ';
61
		$this->debug[] = $requete;
62
 
63
		// Récupération des résultats
64
		try {
65
			$donnees = $this->bdd->query($requete)->fetchAll(PDO::FETCH_ASSOC);
66
			if ($donnees === false) {
67
				$this->messages[] = "La requête a retourné aucun résultat.";
68
			}
69
		} catch (PDOException $e) {
70
			$this->messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage());
71
		}
72
		return $donnees;
73
	}
74
 
75
	/**
23 jpm 76
	 * Méthode appelée pour ajouter un traitement.
77
	 * Retour l'id du nouvel enregistrement ou false!
78
	 */
79
	public function createElement($params) {
80
		$params_proteges = $this->traiterParametresPost(array('referentiel_code'), $params);
81
		$meta_date_creation = date ("Y-m-d H:i:s");
82
		$nom = $this->bdd->quote("Traitement {$params['referentiel_code']} - $meta_date_creation");
83
		$meta_date_creation = $this->bdd->quote($meta_date_creation);
84
 
85
		try {
86
			$requete = 	"INSERT INTO ref_traitement ".
87
   						' (referentiel_code, nom, meta_date_creation) '.
88
						" VALUES ({$params_proteges['referentiel_code']}, $nom, $meta_date_creation) ";
89
			$resultat = $this->bdd->exec($requete);
90
			if ($resultat === false) {
91
				$id = false;
92
				$this->debug[] = "Traitement NON ajouté.";
93
			} else {
94
				$id = $this->bdd->lastInsertId();
95
			}
96
		} catch (PDOException $e) {
97
			$this->messages[] = sprintf($this->getTxt('sql_erreur'), $e->getFile(), $e->getLine(), $e->getMessage(), $requete);
98
		}
99
 
100
	   	$this->envoyer($id);
101
	}
102
}
103
?>