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 basées sur un script à l’aide du formulaire Service REST scripté disponible sous Services Web basés sur un script → API REST basées sur un script.
URI d’API REST scriptés
Les URI d’API REST scriptés 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 ServiceNow où les utilisateurs accèdent à l’API REST scriptée.
- <name_space>: pour les services Web dans le champ d’application global, l’espace de noms est la valeur de la propriété glide.appcreator.company.code. Pour les services Web dans une application incluse dans le périmètre, l’espace de noms est le nom du périmètre, tel que 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 avec version en spécifiant l’URI sans numéro de version.
- <api_id>: valeur du champ ID d’API sur le formulaire 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 Service REST scripté. Spécifier un chemin d’accès de ressource relative vous permet d’avoir plusieurs ressources utilisant la même méthode HTTP, telle que GET, dans un service Web. Par exemple, une ressource peut spécifier le chemin
/{id}lorsque le service Web n’a qu’une seule ressource GET, ou/user/{id}et/message/{id}lorsque le service Web dispose de ressources différentes pour demander des enregistrements d’utilisateur et de message.
Gestion des versions de l’API REST scriptée
Les URI d’API REST scriptés peuvent inclure un numéro de version, par exemple /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 les changements sans impact sur les intégrations existantes.
Version de l’API par défaut
Une version peut être marquée comme valeur par défaut. Spécifier 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 est équivalente à 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 parente. Vous pouvez définir une ou plusieurs ressources par API.
Paramètres de requêtes 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 obligatoires pour chaque demande. Vous pouvez également associer un paramètre de requête à plusieurs ressources.
Accédez aux paramètres de demande dans les 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 valeurs 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 d’API pour contrôler la méthode d’authentification des API. Pour plus d'informations, consultez API access policy.
Contrôles d’accès à l’API REST scriptés
Les listes de contrôle d’accès (ACL) définissent des critères, tels que les rôles requis 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 tous les ACL sélectionnés. Vous pouvez définir une seule ACL pour une API REST entière 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, reportez-vous aux rubriques 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 scriptées. Utilisez cette table pour identifier la configuration de sécurité de l’API REST scriptée qui convient le mieux à vos besoins, ainsi que 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. L’ACL est requise. | 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 |
| Une ACL sélectionnée dans l’enregistrement d’API REST scripté est requise. | 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 demande avec un message d’erreur HTTP standard lorsqu’une erreur se produit pendant le traitement de la demande. Vous pouvez utiliser des objets d’erreur dans les ressources d’API REST scriptées pour alerter les clients demandeurs d’erreurs. Utilisez des objets d’erreur pour répondre aux demandes entrantes, et non pour détecter 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 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
Infrastructure 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. Reportez-vous à la section Administration des configurations d’étapes de test REST et des configurations d’étapesde test REST ATF.
Formation pour les développeurs
Dans le , vous ServiceNow® Site Developertrouverez une formation pour les API REST scriptées.