Bonjour à tous,
je suis confronté à un problème au niveau de l'architecture que je souhaite implémenter pour mon futur projet.
Je dois définir des "contextes d'execution" pour l'application, et c'est vraiment la galère !
Je m'explique :
Les utilisateurs de mon application seront rattachés à une ou plusieurs régions.
Exemple : L'utilisateur Robert est à rattaché à Bretagne et Rhône-alpes, l'utilisateur Julien est rattaché à seulement Rhône-alpes.
Les régions contiennent des laboratoires, et l'utilisateur n'a pas forcément accès à tous les laboratoires des régions auquel il est rattaché.
Exemple : En Bretagne, nous avons les laboratoires Labo1, Labo2 et Labo3. Robert n'est rattaché qu'aux laboratoires Labo1 et Labo2.
Le contexte d'execution de Robert dans l'application sera donc :
- Il est rattaché aux régions Bretagne et Rhône-alpes, il a accès aux laboratoires Labo1 et Labo2 de la Bretagne, et à tous les laboratoires de Rhône-Alpes.
Partant de ce constat, toutes les données en provenance de la BDD devront être filtrées exclusivement sur ces régions et laboratoires pour le contexte de Robert.
Sachant que nous avons 5 régions, que d'autres pourront voir le jour (mais on en aura jamais plus de 10), j'ai tenté d'organiser ma BDD en schémas, où chaque schéma représente une région.
Un schéma supplémentaire nommé "App" contient les informations générales de l'application comme la table Utilisateur, Roles.
Les schémas des régions sont strictement identiques au niveau de leurs tables , seules les données qu'elles contiennent varient. (Par exemple dans la région Rhônes-alpes, on a la table Contentieux qui contient tous les contentieux relatifs aux laboratoires qui sont dans la région Rhône-Alpes, cette table contentieux présente dans tous les schémas de région, et contient les données relatives aux laboratoires de la région).
Au final, comment organiser ma base, ma/mes connexions à celle-ci afin de définir un contexte d'execution après que l'utilisateur soit logué ? Je me retourne le cerveau depuis une bonne semaine sans trouver de solution adéquate.
Le framework PHP que j'utilise (Laravel 4) permet de se connecter à la BDD directement sur un schéma (par défaut je me connecterais donc sur le schéma "App" afin d'avoir les informations de login des utilisateurs). Mais une fois logué, je devrais pouvoir lire le contexte de l'utilisateur
Exemple : Robert s'est logué, il est associé à la région Rhône-Alpes et Bretagne mais ne voit pas tous les laboratoires de Rhône-Alpes.
Quand Robert va consulter la page des contentieux, il ne devra voir que ceux de la Bretagne et de Rhône-Alpes(mais pas le laboratoire Labo3 de Rhône-Alpes).
Je cherche une solution qui me permettrait de ne pas surcharger toutes les requêtes de mon application par des "WHERE idRegion = x OR idRegion = y AND idLabo != z OR idLabo != w" mais de simplement lancer "SELECT * FROM contentieux" et ramener les contentieux qui matchent le contexte de Robert !
Ce n'est pas forcément évident à expliquer, en espérant que vous me comprendrez.
Partager