publik-infra/architecture-3.md

2.3 KiB
Raw Blame History

API Publik

Description générale

LAPI des webservices Publik permet aux briques déchanger des données. La plupart ont trait à léchange de données autour dun usager.

Fournisseurs dAPI :

  • w.c.s. est la brique qui propose le plus de webservices autour des demandes dun usager (http://doc.entrouvert.org/wcs/dev/#api) ;
  • Passerelle met en place des connecteurs donc la plupart ont pour objectif de remonter les informations dun système tiers concernant un usager ;
  • Passerelle est aussi utilisé pour remonter des informations de type « référentiels » depuis des systèmes tiers ;
  • Authentic propose des API permettant la gestion des rôles, des usagers (attributs et rôles).

Consommateurs dAPI :

  • Combo est un consommateur de ces API afin de présenter à lusager lensemble des données que Publik connaît le concernant ;
  • w.c.s. utilise les API de passerelle pour présenter des référentiels dans les formulaires ;
  • w.c.s. utilise les API dAuthentic dans ses actions de workflow afin de pouvoir gérer les rôles dun usager qui a fait une certaine demande ;
  • w.c.s. peut également faire appel à tout webservice de Passerelle afin dintervenir sur un système tiers, toujours lors daction de workflow (typiquement pour injecter des données dans un système tiers).

Logo Publik

Exemple dun dialogue Combo / w.c.s.

Objectif : lorsque lusager se connecte sur son portail usager, une cellule de la page affiche la liste de ses demandes en cours. Pour cela, combo va faire appel à différents webservices de w.c.s. qui lui retourneront les informations nécessaires à afficher dans les cellules de la page.

Logo Publik

Messagerie pour provisioning

Le système de provisioning des utilisateurs et des rôles opère via un diffuseur de message AMQP (RabbitMQ). Lorsquune modification est effectuée sur la brique authentic, celle-ci diffuse un message à lattention de toutes les instances des autres briques concernées. Le message est reçu par tous les agents de toutes les machines de linfrastructure, et est diffusé aux briques concernées, qui se chargent de modifier les utilisateurs des instances cibles.

Logo Publik