Partager via


Vue d’ensemble des portails Web API

L’API web des portails offre une expérience utilisateur plus riche dans les sites Power Pages. Vous pouvez utiliser l’API Web pour effectuer des opérations de création, de lecture, de mise à jour et de suppression dans toutes les tables Microsoft Dataverse à partir de vos pages web. Par exemple, vous pouvez créer un compte, mettre à jour un contact, sans utiliser de formulaire ou formulaire en plusieurs étapes en à l’aide de l’API Web des portails.

Important

  • La version de votre site Power Pages doit être 9.3.3.x ou une version ultérieure pour que cette fonctionnalité soit opérationnelle.
  • L’API web des portails est conçue pour créer une expérience utilisateur riche dans les pages de portails. Elle n’est pas optimisée pour les services tiers ou l’intégration d’application. L’utilisation de l’API Web des portails pour l’intégration avec d’autres sites Power Pages n’est pas non plus prise en charge.
  • Les opérations de l’API Web des portails sont limitées aux tables liées aux données, par exemple, des comptes, des contacts ou vos tableaux personnalisés. Configuration des métadonnées de table ou des données de table de configuration de portail, par exemple, configurer des tables de portails telles que adx_entitylist n’est pas pris en charge avec l’API Web des portails. Pour une liste complète, rendez-vous sur Tables de configuration non prises en charge, plus loin dans cet article.
  • L’API Web des portails bénéficie de mise en cache côté serveur, les appels suivants à l’API Web sont donc plus rapides que les appels initiaux. La suppression du cache côté serveur du portail entraîne une dégradation temporaire des performances.
  • Les opérations de l’API Web des portails nécessitent une licence Power Pages. Par exemple, les appels d’API Web effectués par des utilisateurs anonymes sont comptabilisés dans la capacité d’utilisateur anonyme. Les appels d’API web effectués par des utilisateurs authentifiés (internes ou externes) ne sont pas comptabilisés dans les vues de page, mais nécessitent des licences de capacité d’utilisateur authentifié applicables. Pour plus d’informations : FAQ sur les licences Power Pages

Opérations de l’API Web

L’API web des portails offre un sous-ensemble de fonctionnalités pour les opérations Dataverse que vous pouvez effectuer en utilisant l’API Dataverse. Nous avons gardé le format de l’API aussi similaire que possible, pour réduire la courbe d’apprentissage.

Note

Les opérations de l’API Web respectent la casse.

Opérations d’API Web disponibles dans Power Pages

Note

L’appel d’actions et de fonctions à l’aide de l’API web des portails n’est pas pris en charge.

Paramètres du site pour l’API web

Vous devez activer le paramètre du site pour activer l’API web des portails pour votre portail. Vous pouvez également configurer l’API Web au niveau du champ qui détermine les champs de table qui peuvent ou non être modifiés avec l’API Web des portails.

Note

Utilisez le nom logique de la table pour ces paramètres (par exemple account).

Nom du paramètre du site Description
Webapi/<nom de la table>/enabled Active ou désactive l’API web pour <table name>.
Valeur par défaut :False
Valeurs valides :True, False
Webapi/<nom de la table>/fields Définit la liste des attributs séparés par des virgules qui peuvent être modifiés avec l’API web.
Valeurs possibles :
- Tous les attributs :*
- Attributs spécifiques :attr1,attr2,attr3
Remarque : la valeur doit être soit un astérisque (*) soit une liste de noms de champs séparés par des virgules.
Important : ce paramètre est un paramètre de site obligatoire. Lorsque ce paramètre est manquant, l’erreur « Aucun champ défini pour cette entité » s’affiche.
Webapi/error/innererror Active ou désactive InnerError.
Valeur par défaut :False
Valeurs valides :True, False
Webapi/<nom de la table>/disableodatafilter Active ou désactive le filtre OData.
Valeur par défaut :False
Valeurs valides :True, False Voir Problèmes connus pour en savoir plus. Le paramétrage du site est disponible dans la version 9.4.10.74 ou ultérieure du portail.

Note

Les paramètres du site doivent être définis sur Actif pour que les modifications prennent effet.

Par exemple, pour exposer l’API Web pour la table Incident où les utilisateurs authentifiés sont autorisés à effectuer des opérations de création, de mise à jour et de suppression sur cette entité, les paramètres du site sont indiqués dans le tableau suivant.

Nom du paramètre du site Valeur du paramètre du site
Webapi/incident/enabled vrai
Webapi/incident/fields attr1, attr2, attr3

Sécurité avec l’API web des portails

Vous pouvez configurer la sécurité basée sur les enregistrements pour des enregistrements individuels dans les portails en utilisant les autorisations de table. L’API Web des portails accède aux enregistrements de table et suit les autorisations de table accordées aux utilisateurs via les rôles Web associés.

Vous pouvez configurer les autorisations de colonne pour définir plus en détail les privilèges des colonnes individuelles d’une table au moment de l’utilisation de l’API Web des portails.

Authentification des requêtes de l’API Web des portails

Il n’est pas nécessaire d’inclure un code d’authentification, car la session de l’application gère l’authentification et l’autorisation. Tous les appels d’API web doivent inclure un jeton de falsification de requête intersites (CSRF).

Utiliser EntitySetName

Lorsque vous faites référence aux tables Dataverse en utilisant l’API web des portails dans votre code, vous devez utiliser EntitySetName, par exemple, pour accéder à la table de compte, la syntaxe du code utilise l’EntitySetName des comptes ; /_api/accounts().

Note

Utilisez le nom logique de la table pour les paramètres du site (par exemple account).

Vous pouvez déterminer le nom EntitySetName de tables spécifiques en suivant ces étapes :

  1. Accéder à https://make.powerapps.com

  2. Sélectionnez l’onglet Dataverse dans le panneau latéral et sélectionnez la table.

  3. Sélectionnez ... (option Commandes), puis choisissez Avancé, Outils et Copier le nom de l’ensemble pour copier le EntitySetName de la table dans votre presse-papiers.

    Comment localiser EntitySetName d’une table Dataverse.

Lois et réglementations sur la confidentialité

Tous les en-têtes de demande utilisent un ID de contact transmis à des fins d’audit. Pour un utilisateur anonyme, cette valeur est transmise comme null.

Si la journalisation d’audit est activée, un utilisateur peut afficher tous les événements d’audit dans le journal d’audit Office 365.

Capture d’écran du journal d’audit Office 365.

Pour plus d’informations :
Activer et utiliser la journalisation des activités
Exporter, configurer et afficher les enregistrements du journal d’audit

Tables de configuration non prises en charge

L’API Web des portails ne peut pas être utilisée pour les tables de configuration suivantes :

adx_contentaccesslevel

adx_contentsnippet

adx_entityform

adx_entityformmetadata

adx_entitylist

adx_entitypermission

adx_entitypermission_webrole

adx_externalidentity

adx_pagealert

adx_pagenotification

adx_pagetag

adx_pagetag_webpage

adx_pagetemplate

adx_portallanguage

adx_publishingstate

adx_publishingstatetransitionrule

adx_publishingstatetransitionrule_webrole

adx_redirect

adx_setting

adx_shortcut

adx_sitemarker

adx_sitesetting

adx_urlhistory

adx_webfile

adx_webfilelog

adx_webform

adx_webformmetadata

adx_webformsession

adx_webformstep

adx_weblink

adx_weblinkset

adx_webnotificationentity

adx_webnotificationurl

adx_webpage

adx_webpage_tag

adx_webpageaccesscontrolrule

adx_webpageaccesscontrolrule_webrole

adx_webpagehistory

adx_webpagelog

adx_webrole_systemuser

adx_website

adx_website_list

adx_website_sponsor

adx_websiteaccess

adx_websiteaccess_webrole

adx_websitebinding

adx_websitelanguage

adx_webtemplate

Problèmes connus

Les utilisateurs obtiennent une erreur CDS s’ils appellent une requête d’API web GET pour des tables qui ont plusieurs niveaux d’autorisations de table1 à plusieurs ou plusieurs à plusieurs lorsque les étendues Parental, **Contact ou Compte ajoutent des conditions supplémentaires à la requête.

Pour résoudre ce problème, la solution recommandée consiste à utiliser FetchXML dans la requête OData.

Vous pouvez également définir le paramètre du site Webapi/<table name>/disableodatafilter sur True.

Important

La modification du paramètre de site Webapi/<nom de la table>/disableodatafilter sur True peut entraîner une baisse des performances pour les appels d’API web GET.

Le paramétrage du site est disponible dans la version 9.4.10.74 ou ultérieure du portail.

Étape suivante

Interroger les données à l’aide de l’API web des portails