[[TOC]]
Toute la configuration de l'environnement se fait à partir du namespace. Par exemple, pour définir un utilisateur sur l'environnement du Ministère de l'Intérieur il faut utiliser LibMelanie\Api\Mi\User
alors que pour un utilisateur de l'environnement Ministère de la Transition Écologique ce sera LibMelanie\Api\Mel\User
(Mel = nom de la messagerie du MTE).
Un namespace peut être défini au début du fichier php,
use LibMelanie\Api\Mel\User;
Ou bien utilisé a chaque appel d'une classe
$user = new LibMelanie\Api\Mel\User();
L'inconvénient de ces deux usages est qu'ils sont statiques. Il n'est donc pas possible de configurer l'environnement du ministère de destination via cette méthode. Il faut donc passer par l'utilisation de namespaces dynamiques.
Une façon simple de le faire est de passer par une variable.
$namespace = 'LibMelanie\Api\Mel';
$class = $namespace . '\User'
$user = new $class();
Cela permet d'avoir une valeur dynamique en fonction de l'environnement
if ($environnement == 'mi') {
$namespace = 'LibMelanie\Api\Mi';
}
else if ($environnement == 'mte') {
$namespace = 'LibMelanie\Api\Mel';
}
$class = $namespace . '\User'
$user = new $class();
Pour aller un peu plus loin et avoir une instanciation dynamique des objets en fonction d'une configuration du namespace, il est possible d'utiliser la réflection. Par exemple ce code peut être intégré dans une class pour générer les bons objets, la méthode Class->user()
permettant alors d'instancier un objet User en fonction d'un namespace.
/**
* Generate an object from the ORM with the right Namespace
*
* @param string $objectName Object name (add sub namespace if needed, ex : Event, Users\Type)
* @param array $params [Optionnal] parameters of the constructor
*
* @return staticClass object of the choosen type
*/
protected function object($objectName, $params = []) {
$class = new \ReflectionClass(static::$_objectsNS . $objectName);
return $class->newInstanceArgs($params);
}
/**
* Generate user object from the ORM with the right Namespace
*
* @param array $params [Optionnal] parameters of the constructor
*
* @return \LibMelanie\Api\Defaut\User
*/
public function user($params = []) {
return $this->object('User', $params);
}
Même chose pour la récupération d'une constante de classe, il est possible d'utiliser la lecture dynamique pour récupérer sa valeur en fonction du namespace.
/**
* Return constantName value from objectName and NS
*
* @param string $objectName Name of the object
* @param string $constantName Name of the constant
*
* @return mixed constant value
*/
public static function const($objectName, $constantName) {
return constant(static::$_objectsNS . $objectName . '::' . $constantName);
}
Puis ensuite de récupérer la valeur de la constante de classe.
$value = \myclass::const('User', 'RIGHT_SEND')
Permet de récupérer la valeur de la constante User::RIGHT_SEND
avec User qui dépend du namespace configuré.
Pour récupérer les informations d'un utilisateur, il faut utiliser une clé, qui est en général son uid, puis le charger.
Par exemple,
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$user->load();
load()
retourne un booléen il est donc possible de tester si l'utilisateur existe dans son annuaire en faisant
if ($user->load()) {
}
En principe, il est également possible de charger un utilisateur depuis son email
$user = new LibMelanie\Api\Mce\User();
$user->email = '[email protected]';
$user->load();
Ou depuis son DN
$user = new LibMelanie\Api\Mce\User();
$user->dn = 'uid=thomas.test1,ou=example,ou=com';
$user->load();
A noter : ces possibilités peuvent dépendre des environnements des ministères.
Une fois qu'un utilisateur est chargé, il est possible de lire ses informations.
Comme son nom,
$name = $user->name;
ou son email,
$mail = $user->email;
Voici la liste des attributs de base pour un utilisateur
* @property string $dn DN de l'utilisateur dans l'annuaire
* @property string $uid Identifiant unique de l'utilisateur
* @property string $fullname Nom complet de l'utilisateur
* @property string $name Nom de l'utilisateur
* @property string $type Type de boite (voir Mce\Users\Type::*)
* @property string $email Adresse email principale de l'utilisateur
* @property array $email_list Liste de toutes les adresses email de l'utilisateur
* @property string $email_send Adresse email d'émission principale de l'utilisateur
* @property array $email_send_list Liste de toutes les adresses email d'émission de l'utilisateur
* @property Share[] $shares Liste des partages de la boite
* @property string $street Adresse - Rue de l'utilisateur
* @property string $postalcode Adresse - Code postal de l'utilisateur
* @property string $locality Adresse - Ville de l'utilisateur
* @property string $title Titre de l'utilisateur
En fonction de l'environnement certains attributs supplémentaire peuvent être disponibles, il faut se référer à la documentation d'API de l'ORM pour avoir plus d'informations par namespace.
Depuis un objet User il est possible de récupérer les boites partagées auxquelles il a accès. Pour cela plusieurs méthodes existent :
- Pour récupérer toutes les boites partagées auxquelles un utilisateur accède :
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$objects = $user->getObjectsShared();
- Pour récupérer les boites partagées auxquelles un utilisateur accède avec les droits d'émission :
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$objects = $user->getObjectsSharedEmission();
- Pour récupérer les boites partagées auxquelles un utilisateur accède avec les droits de gestionnaire :
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$objects = $user->getObjectsSharedGestionnaire();
A noter : Ce qui est récupéré ce sont des objets de partage (ObjectShare) et non pas les boites (User), il faut donc un léger traitement si on souhaite récupérer les informations de la boite et non pas de l'objet de partage (voir ci-dessous).
A noter 2 : La boite individuelle de l'utilisateur ne fait pas parti de la liste des boites récupérées par ces trois méthodes, car elle n'est pas partagé. Pour ajouter la boite individuelle de l'utilisateur il suffit d'utiliser l'objet User chargé (load()
).
Pour récupérer ensuite les informations depuis ces objets :
foreach ($objects as $object) {
$object_uid = $object->uid;
$mailbox_uid = $object->mailbox->uid;
}
A noter : en faisant $object->uid
on récupère l'uid de l'objet de partage, alors qu'en faisant $object->mailbox->uid
on récupère l'uid de la boite mail.
Depuis l'objet User, il est possible de récupérer le calendrier par défaut de l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$calendar = $user->getDefaultCalendar();
Il est également possible de récupérer la liste des calendriers appartenants à l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$calendars = $user->getUserCalendars();
Et enfin, il est possible de récupérer tous les calendriers sur lesquels l'utilisateur à un accès (partagés ou non)
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$calendars = $user->getSharedCalendars();
Depuis l'objet User, il est possible de récupérer le carnet par défaut de l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$addressbook = $user->getDefaultAddressbook();
Il est également possible de récupérer la liste des carnets appartenants à l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$addressbooks = $user->getUserAddressbooks();
Et enfin, il est possible de récupérer tous les carnets sur lesquels l'utilisateur à un accès (partagés ou non)
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$addressbooks = $user->getSharedAddressbooks();
Depuis l'objet User, il est possible de récupérer la liste de tâches par defaut de l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$taskslist = $user->getDefaultTaskslist();
Il est également possible de récupérer la liste des listes de tâches appartenants à l'utilisateur
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$taskslists = $user->getUserTaskslists();
Et enfin, il est possible de récupérer toutes les listes de tâches sur lesquels l'utilisateur à un accès (partagés ou non)
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$taskslists = $user->getSharedTaskslists();
Un calendrier individuel peut se charger depuis son identifiant
$calendar = new LibMelanie\Api\Mce\Calendar();
$calendar->id = 'thomas.test1';
$calendar->load();
ou depuis son identifiant et son propriétaire via un objet User
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$calendar = new LibMelanie\Api\Mce\Calendar($user);
$calendar->id = 'thomas.test1';
$calendar->load();
Depuis un calendrier il est possible de récupérer tous les événements associés
$events = $calendar->getAllEvents();
Ou bien seulement les événements contenus entre des dates
$events = $calendar->getRangeEvents('2022-09-01', '2022-09-07');
Plusieurs possibilités de filtres existent dans la méthode getRangeEvents()
, voir la définition pour plus d'informations
Un carnet individuel peut se charger depuis son identifiant
$addressbook = new LibMelanie\Api\Mce\Addressbook();
$addressbook->id = 'thomas.test1';
$addressbook->load();
ou depuis son identifiant et son propriétaire via un objet User
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$addressbook = new LibMelanie\Api\Mce\Addressbook($user);
$addressbook->id = 'thomas.test1';
$addressbook->load();
Depuis un carnet il est possible de récupérer tous les contacts associés
$contacts = $addressbook->getAllContacts();
Une liste de tâches individuelle peut se charger depuis son identifiant
$takslist = new LibMelanie\Api\Mce\Taskslist();
$takslist->id = 'thomas.test1';
$takslist->load();
ou depuis son identifiant et son propriétaire via un objet User
$user = new LibMelanie\Api\Mce\User();
$user->uid = 'thomas.test1';
$takslist = new LibMelanie\Api\Mce\Taskslist($user);
$takslist->id = 'thomas.test1';
$takslist->load();
Depuis une liste de tâches il est possible de récupérer toutes les tâches associées
$tasks = $taskslist->getAllTasks();
Un post se récupère à partir de son uid
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
// Code à exécuter
}
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
$post->creator = $creator;
$post->title = $title;
$post->summary = $summary;
$post->content = $content;
$post->workspace = $workspace_uid;
$ret = $post->save();
if (!is_null($ret)) {
// Code à exécuter
}
La fonction save() retourne une valeur null en cas d'erreur.
Les propriétés created et modified ne nécessite pas d'être positionnés à la création car elles sont automatiquement alimentées par la base de données lors de l'insert.
La génération de l'uid du Post peut passer par une fonction de génération aléatoire, par exemple :
function generateRandomString($length = 10) {
$characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$charactersLength = strlen($characters);
$randomString = '';
for ($i = 0; $i < $length; $i++) {
$randomString .= $characters[random_int(0, $charactersLength - 1)];
}
return $randomString;
}
$post->uid = generateRandomString(24);
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
$post->title = $newtitle;
$post->modified = date('Y-m-d H:i:s');
$ret = $post->save();
if (!is_null($ret)) {
// Code à exécuter
}
}
Dans le cas d'une mise à jour il faut bien penser à alimenter le champ modified.
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->delete()) {
// Code à exécuter
}
L'ORM ne gère pas les droits, que ce soit pour la création, modification ou suppression. Il faut donc bien s'assurer que l'utilisateur qui fait appelle à delete() est autorisé à le faire avant le lancement de la fonction.
La fonction listPosts() permet de lister tous les Post d'un espace de travail. Elle permet également de rechercher, trier et paginer. Tous les critères (recherche, tri, pagination) peuvent se combiner.
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->workspace = $workspace_uid;
$posts = $post->listPosts();
$posts = $post->listPosts("test");
$posts = $post->listPosts("creator:thomas.test1");
$posts = $post->listPosts("creator:thomas.test1 article");
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = "Blog";
$tag->workspace = $workspace_uid;
if ($tag->load()) {
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->workspace = $workspace_uid;
$posts = $post->listPosts(null, [$tag]);
}
$posts = $post->listPosts(null, [], 'comments', false);
Lister tous les Post de l'espace, triés par nombre de réactions (décroissant), en affichant la 2eme page avec 10 posts par page
$posts = $post->listPosts(null, [], 'reactions', false, 10, 10);
Cette donnée est automatiquement chargée au moment du listPosts(), sinon elle sera récupérée depuis la base
$post->countReactions();
Cette donnée est automatiquement chargée au moment du listPosts(), sinon elle sera récupérée depuis la base
$post->countComments();
Pour gérer le markdown, les images sont stockées dans une autre table de la base de données. Elles sont également associées à un uid pour les retrouver plus facilement.
$image = new LibMelanie\Api\Defaut\Posts\Image();
$image->uid = $uid;
if ($image->load()) {
// Code à exécuter
}
$image = new LibMelanie\Api\Defaut\Posts\Image();
$image->uid = generateRandomString(24);
$image->post = $post->id;
$image->data = $data;
$ret = $image->save();
if (!is_null($ret)) {
// Code à exécuter
}
$image = new LibMelanie\Api\Defaut\Posts\Image();
$image->uid = $uid;
if ($image->delete()) {
// Code à exécuter
}
Les tags sont gérés par espace de travail. Chaque espace a sa propre liste de tags. Ensuite un ou plusieurs tags peuvent être associés à un post. Cela se fait donc en deux temps (création du tag > association du tag au post)
Le chargement d'un tag se fait à partir de l'espace de travail et se son nom
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = $name;
$tag->workspace = $workspace_uid;
if ($tag->load()) {
// Code à exécuter
}
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = $name;
$tag->workspace = $workspace_uid;
$ret = $tag->save();
if (!is_null($ret)) {
// Code à exécuter
}
Pour modifier un tag, il faut donc dans un premier temps le charger avec son ancien nom, pour ensuite le modifier avec le nouveau
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = $name;
$tag->workspace = $workspace_uid;
if ($tag->load()) {
$tag->name = $newname;
$ret = $tag->save();
if (!is_null($ret)) {
// Code à exécuter
}
}
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = $name;
$tag->workspace = $workspace_uid;
if ($tag->delete()) {
// Code à exécuter
}
Un tag doit être chargé (soit via un load() soit via une liste existante) pour être associé à un post (qui doit lui aussi être chargé).
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->name = $name;
$tag->workspace = $workspace_uid;
if ($tag->load()) {
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
if ($post->addTag($tag)) {
// Code à exécuter
}
}
}
if ($post->removeTag($tag)) {
// Code à exécuter
}
Lister tous les tags associés à un espace de travail :
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->workspace = $workspace_uid;
$tags = $tag->listTags();
Rechercher les tags associés à un espace de travail, par exemple rechercher ici les tags avec le mot "réponse" :
$tag = new LibMelanie\Api\Defaut\Posts\Tag();
$tag->workspace = $workspace_uid;
$tags = $tag->listTags('réponse');
Lister tous les tags associés à un post
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
$tags = $post->listTags();
}
Le chargement d'une réaction se fait à partir du post, du type de réaction et du createur
$reaction = new LibMelanie\Api\Defaut\Posts\Reaction();
$reaction->post = $post->id;
$reaction->creator = $creator;
$reaction->type = $type;
if ($reaction->load()) {
// Code à exécuter
}
$reaction = new LibMelanie\Api\Defaut\Posts\Reaction();
$reaction->post = $post->id;
$reaction->creator = $creator;
$reaction->type = $type;
$ret = $reaction->save();
if (!is_null($ret)) {
// Code à exécuter
}
La modification d'une réaction n'est pas vraiment prévue, il semble préférable de passer par la suppression puis la création d'une nouvelle réaction.
$reaction = new LibMelanie\Api\Defaut\Posts\Reaction();
$reaction->post = $post->id;
$reaction->creator = $creator;
$reaction->type = $type;
if ($reaction->delete()) {
// Code à exécuter
}
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
$reactions = $post->listReactions();
}
Le chargement d'un commentaire se fait à partir de son uid
$comment = new LibMelanie\Api\Defaut\Posts\Comment();
$comment->uid = $uid;
if ($comment->load()) {
// Code à exécuter
}
$comment = new LibMelanie\Api\Defaut\Posts\Comment();
$comment->uid = generateRandomString(24);
$comment->creator = $creator;
$comment->content = $content;
$comment->post = $post->id;
$comment->parent = 6;
$ret = $comment->save();
if (!is_null($ret)) {
// Code à exécuter
}
Pour créer un commentaire enfant d'un commentaire existant, il faut ajouter
$comment->parent = $comment_parent->id;
Pour modifier un tag, il faut donc dans un premier temps le charger avec son ancien nom, pour ensuite le modifier avec le nouveau
$comment = new LibMelanie\Api\Defaut\Posts\Comment();
$comment->uid = $uid;
if ($comment->load()) {
$comment->content = $content;
$comment->modified = date('Y-m-d H:i:s');
$ret = $comment->save();
if (!is_null($ret)) {
// Code à exécuter
}
}
$comment = new LibMelanie\Api\Defaut\Posts\Comment();
$comment->uid = $uid;
if ($comment->load()) {
// Code à exécuter
}
Un Post chargé peut directement charger les commentaires avec la méthode listComments()
$post = new LibMelanie\Api\Defaut\Posts\Post();
$post->uid = $uid;
if ($post->load()) {
$comments = $post->listComments();
}
Comme pour la méthode listPosts() la méthode listComments() prend plusieurs paramètres pour combiner les recherches.
Pour ne lister que les commentaires au niveau racine :
$comments = $post->listComments(true);
Pour chercher des commentaires qui contiennent le mot "test" :
$comments = $post->listComments(false, "test");
Pour chercher les commentaires créés par thomas.test1 :
$comments = $post->listComments(false, "creator:thomas.test1");
Pour trier les commentaires par nombre de likes :
$comments = $post->listComments(true, null, 'likes', false);
Pour trier les commentaires par nombre d'enfants :
$comments = $post->listComments(false, null, 'children');
Les likes se positionnent sur les commentaires
Le chargement d'un like se fait à partir du commentaire, du créateur et de son type.
$like = new LibMelanie\Api\Defaut\Posts\Comments\Like();
$like->comment = $comment->id;
$like->creator = $creator;
$like->type = $type;
if ($like->load()) {
// Code à exécuter
}
$like = new LibMelanie\Api\Defaut\Posts\Comments\Like();
$like->comment = $comment->id;
$like->creator = $creator;
$like->type = $type;
$ret = $like->save();
if (!is_null($ret)) {
// Code à exécuter
}
Comme pour les réactions, la modification d'un Like n'est pas prévue. Il faut passer par la suppression puis création si besoin.
$like = new LibMelanie\Api\Defaut\Posts\Comments\Like();
$like->comment = $comment->id;
$like->creator = $creator;
$like->type = $type;
if ($like->delete()) {
// Code à exécuter
}