API REST basées sur un script
La fonctionnalité d’API REST scriptée permet aux développeurs d’applications de créer des API de service Web personnalisées.
Vous pouvez définir des points de terminaison de service, des paramètres de requête et des en-têtes pour une API REST scriptée, ainsi que des scripts pour gérer la demande et la réponse.
Les API REST basées sur un script suivent généralement l’architecture REST, mais vous pouvez les personnaliser pour utiliser différentes conventions. Vous définissez des API REST scriptées à l’aide du formulaire Service REST scripté disponible sous Services Web scriptés → API REST basées sur un script.
URI d’API REST scriptées
Les URI d’API REST scriptées ont le format suivant :
https://<instance.service-now.com>/api/<name_space>/<version>/<api_id>/<relative_path>
- <instance.service-now.com>: chemin d’accès à l’instance où les ServiceNow utilisateurs accèdent à l’API REST scriptée.
- <name_space>: pour les services Web dans le périmètre global, l’espace de noms est la valeur de la propriété glide.appcreator.company.code. Pour les services Web d’une application incluse dans le périmètre, l’espace de noms est le nom du périmètre, par exemple x_company_appname. Pour plus d’informations sur les espaces de noms, consultez Périmètre de l’application.
- <version>:Optionnel. Version du point de terminaison à laquelle accéder si l’API utilise la gestion des versions, telle que v1. Vous pouvez accéder à la version par défaut d’une API versionnée en spécifiant l’URI sans numéro de version.
- <api_id>: valeur du champ ID d’API sur le formulaire de service REST scripté. Par défaut, cette valeur est basée sur le nom du service.
- <relative_path>: chemin d’accès relatif défini pour la ressource dans le formulaire de service REST scripté. La spécification d’un chemin de ressource relatif vous permet d’avoir plusieurs ressources à l’aide de la même méthode HTTP, telle que GET, dans un seul service Web. Par exemple, une ressource peut spécifier le chemin
d’accès /{id}lorsque le service web n’a qu’une seule ressource GET, ou/user/{id}et/message/{id}lorsque le service web a des ressources différentes pour demander des enregistrements d’utilisateurs et de messages.
Gestion des versions de l’API REST scriptée
Les URI de l’API REST scriptées peuvent inclure un numéro de version, tel que /api/management/v1/table/{tableName}. Les numéros de version identifient la version du point de terminaison à laquelle un URI accède. En spécifiant un numéro de version dans vos URI, vous pouvez tester et déployer des changements sans impact sur les intégrations existantes.
Version d’API par défaut
Une version peut être marquée comme valeur par défaut. La spécification d’une version par défaut permet aux utilisateurs d’accéder à cette version à l’aide d’un point de terminaison REST scripté sans numéro de version. Si aucune version n’est marquée comme valeur par défaut, la version la plus récente est utilisée comme version par défaut.
Ressources d’API REST scriptées
Une ressource d’API REST scriptée équivaut à un point de terminaison REST. Il définit la méthode HTTP à exécuter, le script de traitement et tous les paramètres de remplacement de l’API parent. Vous pouvez définir une ou plusieurs ressources par API.
Paramètres de requête de l’API REST scriptés
Les paramètres de requête définissent les valeurs que les utilisateurs demandeurs peuvent transmettre dans une demande. Lors de la création d’une API REST scriptée, vous pouvez spécifier les paramètres disponibles et ceux obligatoires pour chaque demande. Vous pouvez également associer un paramètre de requête à plusieurs ressources.
Accédez aux paramètres de demande dans des scripts à l’aide du champ queryParams de l’objet de demande.
Rôles de l’API REST scriptés
Formats de demande et de réponse
Par défaut, toutes les ressources d'une API prennent en charge les formats de demande et de réponse suivants : application/json, application/xml et texte/xml. Vous pouvez remplacer les formats par défaut au niveau de l’API. Les nouveaux formats s’appliquent à toutes les ressources appartenant à l’API, sauf si une ressource individuelle remplace les paramètres par défaut.
Sécurité de l’API REST scriptée
Vous pouvez configurer vos API REST scriptées avec le niveau de sécurité nécessaire. Des API/points de terminaison publics qui ne nécessitent aucune sécurité aux API/points de terminaison hautement sécurisés qui nécessitent une authentification utilisateur avec un contrôle d’accès strict à toutes les ressources.
Utilisez la fonctionnalité de politique d’accès API pour contrôler la méthode d’authentification des API. Pour plus d'informations, consultez API access policy.
Contrôles d’accès de l’API REST scriptés
Les listes de contrôle d’accès (ACL) définissent des critères, tels que les rôles nécessaires et les conditions qu’un utilisateur doit remplir pour accéder à une API REST ou à un point de terminaison scripté. Un utilisateur demandeur doit satisfaire au moins une des ACL. Il n’est pas nécessaire de satisfaire à toutes les ACL sélectionnées. Vous pouvez définir une seule ACL pour toute une API REST ou pour un point de terminaison individuel.
Lors de la définition d’une ACL d’API REST scriptée, elle doit avoir la valeur TypeREST_Endpoint.
Pour plus d’informations sur les ACL, consultez Règles de liste de contrôle d’accès et Configurer une ressource d’API REST scriptée pour exiger une ACL.
Matrice de sécurité de l’API REST scriptée
Il existe plusieurs configurations de sécurité possibles pour les API REST basées sur un script. Utilisez cette table pour identifier la configuration de sécurité de l’API REST scriptée qui correspond le mieux à vos besoins et les valeurs de champ pour implémenter cette configuration.
| Configuration | API REST scriptée | Ressource REST scriptée | ||
|---|---|---|---|---|
| ACL par défaut | Requiert une authentification | Requiert une autorisation d'ACL | ACL | |
| La ressource est publique. Aucune authentification ou ACL n’est requise. | N’importe quelle valeur | Faux | N’importe quelle valeur | N’importe quelle valeur |
| La ressource nécessite uniquement une authentification de base. Aucune ACL n’est requise. | N’importe quelle valeur | Vrai | Faux | N’importe quelle valeur |
| La ressource nécessite uniquement une authentification de base. ACL est obligatoire. | Aucune ACL sélectionnée | Vrai | Vrai | Aucune ACL sélectionnée |
| Une ACL sélectionnée dans l’enregistrement de ressource est requise. | N’importe quelle valeur | Vrai | Vrai | Une ou plusieurs ACL sélectionnées |
| Un ACL sélectionné dans l’enregistrement scripté de l’API REST est requis. | Une ou plusieurs ACL sélectionnées | Vrai | Vrai | Aucune ACL sélectionnée |
Objets d’erreur de l’API REST scriptés
Les API REST basées sur un script incluent des objets d’erreur qui vous permettent de répondre à une requête avec un message d’erreur HTTP standard lorsqu’une erreur se produit pendant le traitement de la requête. Vous pouvez utiliser des objets d’erreur dans les ressources d’API REST scriptées pour alerter les clients demandeurs des erreurs. Utilisez des objets d’erreur pour répondre aux demandes entrantes, et non pour intercepter les erreurs dans votre code côté serveur.
Format de réponse d’erreur
Le type de contenu de la réponse dépend de l’en-tête Accepter de la demande. Si l’en-tête Accepter spécifie un format non pris en charge, tel que image/jpeg, la réponse d’erreur utilise JSON.
{
"error": {
"message": "My error message",
"detail": "My details"
},
"status": "failure"
}Le code d’état numérique, tel que 404, est inclus dans l’en-tête du code d’état de la réponse, et non dans le corps de la réponse.Prise en charge d'Automated Test Framework
Framework de tests automatisés (ATF) prend en charge les étapes de test REST entrantes. Vous pouvez créer des tests automatisés pour les API REST entrantes personnalisées que vous créez. La création de tests pour vos REST APIs personnalisées simplifie les tests de mise à niveau et permet de vérifier la rétrocompatibilité des modifications apportées à une REST API. Consultez Administration des configurations d’étape de test REST et Configurations d’étape de test REST ATF.
Formation pour les développeurs
Dans , ServiceNow® Site Developervous trouverez une formation pour les API REST basées sur un script.