Subversion Repositories eFlore/Applications.coel-consultation

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
15 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Modèle d'accès à la base de données des Collections pour le module Personnes.
5
 *
6
 * @package		Collection
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		SVN: $Id: PersonneDao.php 117 2010-06-28 10:27:53Z jpm $
13
 *
14
 */
15
class PersonneDao extends ColModele {
19 jpm 16
	const SERVICE_PERSONNE = 'CoelPersonne';
55 jpm 17
	const SERVICE_PERSONNE_A_PUBLICATION = 'CoelPublicationAPersonne';
117 jpm 18
	const SERVICE_PERSONNE_A_COLLECTION = 'CoelCollectionAPersonne';
15 jpm 19
 
20
	/**
21
	 * Retourne l'ensemble des information d'une personne.
22
	 *
23
	 * @param integer l'id de la personne.
24
	 * @return array un tableau contenant les informations sur la personne.
25
	 */
26
	public function getPersonne($id) {
62 jpm 27
		$donnees = array();
28
		if (is_numeric($id)) {
29
			$url = $this->url_jrest.self::SERVICE_PERSONNE."/$id";
30
			$json = file_get_contents($url);
31
			$donnees = json_decode($json, true);
32
			if ($donnees['nbElements'] == 1) {
33
				$donnees = $donnees['personnes'][0];
34
			}
55 jpm 35
		}
15 jpm 36
		return $donnees;
37
	}
38
 
55 jpm 39
	/**
40
	 * Retourne l'ensemble des publications liées à une personne.
41
	 *
42
	 * @param integer l'id de la personne.
43
	 * @return array un tableau contenant les informations sur les publications liées à la personne.
44
	 */
45
	public function getPersonneAPublication($id_personne) {
46
		$url = $this->url_jrest.self::SERVICE_PERSONNE_A_PUBLICATION."/*/$id_personne/2361,2362,2363";
47
		$json = file_get_contents($url);
48
		$donnees = json_decode($json, true);
67 jpm 49
		return $donnees['publicationsAPersonne'];
55 jpm 50
	}
51
 
117 jpm 52
	/**
53
	 * Retourne l'ensemble des collections liées à une personne.
54
	 *
55
	 * @param integer l'id de la personne.
56
	 * @return array un tableau contenant les informations sur les collections liées à la personne.
57
	 */
58
	public function getPersonneACollection($id_personne) {
59
		$url = $this->url_jrest.self::SERVICE_PERSONNE_A_COLLECTION."/*/*/$id_personne";
60
		$url .= '?orderby='.urlencode("cc_nom ASC");
61
		$json = file_get_contents($url);
62
		$donnees = json_decode($json, true);
63
		return $donnees['collectionsAPersonne'];
64
	}
65
 
15 jpm 66
	public function getPersonneNomComplet($id) {
55 jpm 67
		$nom_complet = '';
15 jpm 68
		$donnees = $this->getPersonne($id);
55 jpm 69
		if (isset($donnees['nbElements']) && $donnees['nbElements'] >= 1) {
70
			$nom_complet = $donnees['personnes'][0]['cp_fmt_nom_complet'];
71
		} else if (isset($donnees['cp_fmt_nom_complet'])) {
72
			$nom_complet = $donnees['cp_fmt_nom_complet'];
73
		}
15 jpm 74
		return $nom_complet;
75
	}
93 jpm 76
 
77
	public function getPersonneCourriels($id) {
78
		$courriels = '';
79
		$donnees = $this->getPersonne($id);
80
		if (isset($donnees['nbElements']) && $donnees['nbElements'] >= 1) {
81
			$courriels = $donnees['personnes'][0]['cp_truk_courriel'];
82
		} else if (isset($donnees['cp_truk_courriel'])) {
83
			$courriels = $donnees['cp_truk_courriel'];
84
		}
85
		return $courriels;
86
	}
15 jpm 87
}
88
?>