Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
Appelez des API tierces
Une tâche HTTP est un type d'État de la tâcheétat qui vous permet d'appeler n'importe quelle API publique tierce, telle que Salesforce et Stripe, dans vos flux de travail. Pour appeler une API tierce, utilisez l'état de la tâche avec la arn:aws:states:::http:invoke
ressource. Fournissez ensuite les détails de configuration du point de terminaison de l'API, tels que l'URL de l'API, la méthode que vous souhaitez utiliser et les détails d'authentification.
Si vous utilisez Workflow Studio pour créer votre machine d'état contenant une tâche HTTP, Workflow Studio génère automatiquement un rôle d'exécution avec des IAM politiques pour la tâche HTTP. Pour plus d’informations, consultez Rôle pour tester les tâches HTTP dans Workflow Studio.
Rubriques
- Définition de tâche HTTP
- Champs de tâches HTTP
- Authentification pour une tâche HTTP
- Fusion des données de définition de EventBridge connexion et de tâche HTTP
- Appliquer le codage d'URL sur le corps de la demande
- Autorisations IAM pour exécuter une tâche HTTP
- Exemple de tâche HTTP
- Test d'une tâche HTTP
- Réponses aux tâches HTTP non prises en charge
Définition de tâche HTTP
La définition ASL représente une tâche HTTP avec http:invoke
ressource. La définition de tâche HTTP suivante invoque une API Stripe qui renvoie une liste de tous les clients.
"Call third-party API": {
"Type": "Task",
"Resource": "arn:aws:states:::http:invoke",
"Parameters": {
"ApiEndpoint": "https://api.stripe.com/v1/customers",
"Authentication": {
"ConnectionArn": "arn:aws:events:us-east-2
:123456789012
:connection/Stripe/81210c42-8af1-456b-9c4a-6ff02fc664ac"
},
"Method": "GET"
},
"End": true
}
Champs de tâches HTTP
Une tâche HTTP inclut les champs suivants dans sa définition.
Resource
(Obligatoire)-
Pour spécifier un type de tâche, indiquez son ARN dans le
Resource
champ. Pour une tâche HTTP, vous devez spécifier leResource
champ comme suit."Resource": "arn:aws:states:::http:invoke"
Parameters
(Obligatoire)-
Contient les
ConnectionArn
champsApiEndpoint
Method
, et qui fournissent des informations sur l'API tierce que vous souhaitez appeler.Parameters
contient également des champs facultatifs, tels queHeaders
etQueryParameters
.Vous pouvez spécifier une combinaison de JSON statique et de JsonPath
syntaxe comme Parameters
dans leParameters
champ. Pour plus d’informations, consultez Transmettre des paramètres à une API de service.ApiEndpoint
(Obligatoire)-
Spécifie l'URL de l'API tierce que vous souhaitez appeler. Pour ajouter des paramètres de requête à l'URL, utilisez le champ.
QueryParameters
L'exemple suivant montre comment vous pouvez appeler une API Stripe pour récupérer la liste de tous les clients."ApiEndpoint":"https://api.stripe.com/v1/customers"
Vous pouvez également spécifier un chemin de référence à l'aide de la JsonPath
syntaxe permettant de sélectionner le nœud JSON contenant l'URL de l'API tierce. Supposons, par exemple, que vous souhaitiez appeler l'une des API de Stripe à l'aide d'un identifiant client spécifique. Imaginez que vous avez fourni l'entrée d'état suivante. { "customer_id": "1234567890", "name": "John Doe" }
Pour récupérer les détails de cet identifiant client à l'aide d'une API Stripe, spécifiez le
ApiEndpoint
comme indiqué dans l'exemple suivant. Cet exemple utilise une fonction intrinsèque et un chemin de référence."ApiEndpoint.$":"States.Format('https://api.stripe.com/v1/customers/{}', $.customer_id)"
Au moment de l'exécution, Step Functions résout la valeur de la manière
ApiEndpoint
suivante.https://api.stripe.com/v1/customers/
1234567890
Method
(Obligatoire)-
Spécifie la méthode HTTP que vous souhaitez utiliser pour appeler une API tierce. Vous pouvez spécifier l'une des méthodes suivantes dans votre tâche HTTP : GET, POST, PUT, DELETE, PATCH, OPTIONS ou HEAD.
Par exemple, pour utiliser la méthode GET, spécifiez le
Method
champ comme suit."Method": "GET"
Vous pouvez également utiliser un chemin de référence pour spécifier la méthode lors de l'exécution. Par exemple,
"Method.$": "$.myHTTPMethod"
. Authentication
(Obligatoire)-
Contient le
ConnectionArn
champ qui indique comment authentifier un appel d'API tiers. Step Functionsprend en charge l'authentification pour un élément spécifiéApiEndpoint
à l'aide de la ressource de connexion deAmazon EventBridge.ConnectionArn
(Obligatoire)-
Spécifie l'ARN de EventBridge connexion.
Une tâche HTTP nécessite une EventBridge connexion qui gère de manière sécurisée les informations d'authentification d'un fournisseur d'API. Une connexion indique le type d'autorisation et les informations d'identification à utiliser pour autoriser une API tierce. L'utilisation d'une connexion vous permet d'éviter de coder en dur des secrets, tels que des clés d'API, dans la définition de votre machine à états. Dans une connexion, vous pouvez également spécifier
Headers
QueryParameters
, et desRequestBody
paramètres.Lorsque vous créez une EventBridge connexion, vous fournissez vos informations d'authentification. Pour plus d'informations sur le fonctionnement de l'authentification pour une tâche HTTP, consultezAuthentification pour une tâche HTTP.
L'exemple suivant montre comment vous pouvez spécifier le
Authentication
champ dans votre définition de tâche HTTP."Authentication": { "ConnectionArn": "arn:aws:events:us-east-2:
123456789012
:connection/Stripe/81210c42-8af1-456b-9c4a-6ff02fc664ac" } Headers
(facultatif)-
Fournit un contexte et des métadonnées supplémentaires au point de terminaison de l'API. Vous pouvez spécifier les en-têtes sous forme de chaîne ou de tableau JSON.
Vous pouvez spécifier des en-têtes dans la EventBridge connexion et dans le
Headers
champ d'une tâche HTTP. Nous vous recommandons de ne pas inclure les informations d'authentification de vos fournisseurs d'APIHeaders
sur le terrain. Nous vous recommandons d'inclure ces informations dans votre EventBridge connexion.Step Functionsajoute les en-têtes que vous spécifiez dans la EventBridge connexion aux en-têtes que vous spécifiez dans la définition de la tâche HTTP. Si les mêmes clés d'en-tête sont présentes dans la définition et la connexion, Step Functions utilise les valeurs correspondantes spécifiées dans la EventBridge connexion pour ces en-têtes. Pour plus d'informations sur le Step Functions mode de fusion des données, consultezFusion des données de définition de EventBridge connexion et de tâche HTTP.
L'exemple suivant spécifie un en-tête qui sera inclus dans un appel d'API tiers :
content-type
."Headers": { "content-type": "application/json" }
Vous pouvez également utiliser un chemin de référence pour spécifier les en-têtes lors de l'exécution. Par exemple,
"Headers.$": "$.myHTTPHeaders"
.Step Functionsdéfinit les
Host
en-têtesUser-Agent
Range
, et. Step Functionsdéfinit la valeur de l'Host
en-tête en fonction de l'API que vous appelez. Voici un exemple de ces en-têtes.User-Agent: Amazon|StepFunctions|HttpInvoke|
us-east-1
, Range: bytes=0-262144, Host: api.stripe.comVous ne pouvez pas utiliser les en-têtes suivants dans votre définition de tâche HTTP. Si vous utilisez ces en-têtes, la tâche HTTP échoue avec l'
States.Runtime
erreur.-
A-IM
-
Accept-Charset
-
Accept-Datetime
-
Accept-Encoding
-
Cache-Control
-
Connexion
-
Encodage-Contenu
-
Content-MD5
-
Date
-
Expect
-
Forwarded
-
De
-
Host (Hôte)
-
HTTP2-Settings
-
If-Match
-
If-Modified-Since
-
If-None-Match
-
If-Range
-
If-Unmodified-Since
-
Max-Forwards
-
Origin
-
Pragma
-
Proxy-Authorization
-
Référent
-
Serveur
-
TE
-
Trailer
-
Transfer-Encoding
-
Upgrade
-
Via
-
Avertissement
-
X-Forwarded-*
-
x-amz-*
-
x-amzn-*
-
QueryParameters
(facultatif)-
Insère des paires clé-valeur à la fin d'une URL d'API. Vous pouvez spécifier les paramètres de requête sous forme de chaîne, de tableau JSON ou d'objet JSON. Step Functionsencode automatiquement les paramètres de requête en URL lorsqu'il appelle une API tierce.
Supposons, par exemple, que vous souhaitiez appeler l'API Stripe pour rechercher des clients qui effectuent leurs transactions en dollars américains (USD). Imaginez que vous avez fourni ce qui suit
QueryParameters
comme entrée d'état."QueryParameters": { "currency": "usd" }
Lors de l'exécution, Step Functions ajoute l'URL
QueryParameters
à l'API comme suit.https://api.stripe.com/v1/customers/search?currency=usd
Vous pouvez également utiliser un chemin de référence pour spécifier les paramètres de requête lors de l'exécution. Par exemple,
"QueryParameters.$": "$.myQueryParameters"
.Si vous avez spécifié des paramètres de requête dans votre EventBridge connexion, Step Functions ajoutez ces paramètres de requête aux paramètres de requête que vous spécifiez dans la définition de la tâche HTTP. Si les mêmes clés de paramètres de requête sont présentes dans la définition et la connexion, Step Functions utilise les valeurs correspondantes spécifiées dans la EventBridge connexion pour ces en-têtes. Pour plus d'informations sur le Step Functions mode de fusion des données, consultezFusion des données de définition de EventBridge connexion et de tâche HTTP.
Transform
(facultatif)-
Contient les
RequestEncodingOptions
champsRequestBodyEncoding
et. Par défaut, Step Functions envoie le corps de la requête sous forme de données JSON à un point de terminaison d'API.Si votre fournisseur d'API accepte les corps de
form-urlencoded
requête, utilisez leTransform
champ pour spécifier le codage URL des corps de requête. Vous devez également spécifier l'content-type
en-tête sous la formeapplication/x-www-form-urlencoded
. Step Functionspuis encode automatiquement l'URL du corps de votre demande.RequestBodyEncoding
-
Spécifie le codage URL du corps de votre demande. Vous pouvez spécifier l'une des valeurs suivantes :
NONE
ouURL_ENCODED
.-
NONE
— Le corps de la requête HTTP sera le JSON sérialisé duRequestBody
champ. C’est la valeur par défaut. -
URL_ENCODED
— Le corps de la requête HTTP sera constitué des données de formulaire codées en URL duRequestBody
champ.
-
RequestEncodingOptions
-
Détermine l'option de codage à utiliser pour les tableaux dans le corps de votre demande si vous définissez sur
RequestBodyEncoding
.URL_ENCODED
Step Functionsprend en charge les options de codage de tableau suivantes. Pour plus d'informations sur ces options et leurs exemples, consultezAppliquer le codage d'URL sur le corps de la demande.
-
INDICES
— Encode les tableaux en utilisant la valeur d'index des éléments du tableau. Step FunctionsUtilise cette option de codage par défaut. -
REPEAT
— Répète une clé pour chaque élément d'un tableau. -
COMMAS
— Encode toutes les valeurs d'une clé sous forme de liste de valeurs séparées par des virgules. -
BRACKETS
— Répète une clé pour chaque élément d'un tableau et ajoute un crochet, [], à la clé pour indiquer qu'il s'agit d'un tableau.
-
L'exemple suivant définit le codage URL pour les données du corps de la demande. Il indique également d'utiliser l'option d'
COMMAS
encodage pour les tableaux dans le corps de la requête."Transform": { "RequestBodyEncoding": "URL_ENCODED", "RequestEncodingOptions": { "ArrayFormat": "COMMAS" } }
RequestBody
(facultatif)-
Accepte les données JSON que vous fournissez dans l'entrée d'état. Dans
RequestBody
, vous pouvez spécifier une combinaison de JSON statique et de JsonPathsyntaxe. Supposons, par exemple, que vous fournissiez l'entrée d'état suivante : { "CardNumber": "1234567890", "ExpiryDate": "09/25" }
Pour utiliser ces valeurs de
CardNumber
etExpiryDate
dans le corps de votre demande lors de l'exécution, vous pouvez spécifier les données JSON suivantes dans le corps de votre demande."RequestBody": { "Card": { "Number.$": "$.CardNumber", "Expiry.$": "$.ExpiryDate", "Name": "John Doe", "Address": "123 Any Street, Any Town, USA" } }
Si l'API tierce que vous souhaitez appeler nécessite des corps de
form-urlencoded
requête, vous devez spécifier le codage URL pour les données du corps de votre demande. Pour plus d’informations, consultez Appliquer le codage d'URL sur le corps de la demande.
Authentification pour une tâche HTTP
Une tâche HTTP nécessite une EventBridge connexion qui gère de manière sécurisée les informations d'authentification d'un fournisseur d'API. Une connexion indique le type d'autorisation et les informations d'identification à utiliser pour autoriser une API tierce. L'utilisation d'une connexion vous permet d'éviter de coder en dur des secrets, tels que des clés d'API, dans la définition de votre machine à états. Une EventBridge connexion prend en charge les schémas d'autorisation Basic, OAuth et API Key.
Lorsque vous créez une EventBridge connexion, vous fournissez vos informations d'authentification. Vous pouvez également inclure les paramètres d'en-tête, de corps et de requête requis pour l'autorisation auprès d'une API. Vous devez inclure l'ARN de connexion dans toute tâche HTTP qui appelle une API tierce.
Lorsque vous créez une connexion et que vous ajoutez des paramètres d'autorisation, EventBridge crée un secret dans AWS Secrets Manager. Dans ce secret, EventBridge stocke les paramètres de connexion et d'autorisation sous une forme cryptée. Pour créer ou mettre à jour correctement une connexion, vous devez utiliser une Compte AWS personne autorisée à utiliser Secrets Manager. Pour plus d'informations sur les IAM autorisations dont votre machine d'état a besoin pour accéder à une EventBridge connexion, consultezAutorisations IAM pour exécuter une tâche HTTP.
L'image suivante montre comment Step Functions gère l'authentification pour les appels d'API tiers à l'aide d'une EventBridge connexion.
![Le processus Step Functions utilise une EventBridge connexion qui gère les informations d'authentification d'un fournisseur d'API tiers. EventBridgecrée un secret Secrets Manager pour stocker les paramètres de connexion et d'autorisation sous une forme cryptée.](images/http-task-how-auth-works.png)
Fusion des données de définition de EventBridge connexion et de tâche HTTP
Lorsque vous appelez une tâche HTTP, vous pouvez spécifier des données dans votre EventBridge connexion et dans votre définition de tâche HTTP. Ces données incluent Headers
QueryParameters
, et les RequestBody
paramètres. Avant d'appeler une API tierce, Step Functions fusionne le corps de la requête avec les paramètres du corps de connexion dans tous les cas, sauf si le corps de votre demande est une chaîne et que les paramètres du corps de connexion ne sont pas vides. Dans ce cas, la tâche HTTP échoue avec l'States.Runtime
erreur.
Si des clés dupliquées sont spécifiées dans la définition de la tâche HTTP et dans la EventBridge connexionStep Functions, les valeurs de la tâche HTTP sont remplacées par celles de la connexion.
La liste suivante décrit comment Step Functions fusionner les données avant d'appeler une API tierce :
-
En-têtes : Step Functions ajoute tous les en-têtes que vous avez spécifiés dans la connexion aux en-têtes du
Headers
champ de la tâche HTTP. En cas de conflit entre les clés d'en-tête, Step Functions utilise les valeurs spécifiées dans la connexion pour ces en-têtes. Par exemple, si vous avez spécifié l'content-type
en-tête dans la définition de la tâche HTTP et dans la EventBridge connexion, Step Functions utilise la valeurcontent-type
d'en-tête spécifiée dans la connexion. -
Paramètres de requête : Step Functions ajoute tous les paramètres de requête que vous avez spécifiés dans la connexion aux paramètres de requête dans le
QueryParameters
champ de la tâche HTTP. En cas de conflit entre les clés des paramètres de requête, Step Functions utilise les valeurs spécifiées dans la connexion pour ces paramètres de requête. Par exemple, si vous avez spécifié le paramètre demaxItems
requête à la fois dans la définition de la tâche HTTP et dans la EventBridge connexion, Step Functions utilise la valeur du paramètre demaxItems
requête spécifiée dans la connexion. -
Paramètres de corps
-
Step Functionsajoute toutes les valeurs du corps de requête spécifiées dans la connexion au corps de la demande dans le
RequestBody
champ de la tâche HTTP. En cas de conflit entre les clés du corps de la demande, Step Functions utilise les valeurs spécifiées dans la connexion pour le corps de la demande. Supposons, par exemple, que vous ayez spécifié unMode
champ dans la définitionRequestBody
de la tâche HTTP et dans la EventBridge connexion. Step Functionsutilise la valeur duMode
champ que vous avez spécifiée dans la connexion. -
Si vous spécifiez le corps de la demande sous forme de chaîne au lieu d'un objet JSON et que la EventBridge connexion contient également le corps de la demande, Step Functions vous ne pouvez pas fusionner le corps de demande spécifié à ces deux endroits. La tâche HTTP échoue avec l'
States.Runtime
erreur.
Step Functionsapplique toutes les transformations et sérialise le corps de la demande une fois la fusion terminée.
-
L'exemple suivant définit les RequestBody
champs Headers
QueryParameters
, et dans la tâche HTTP et dans la EventBridge connexion.
Définition de tâche HTTP
{ "Comment": "Data merging example for HTTP Task and EventBridge connection", "StartAt": "ListCustomers", "States": { "ListCustomers": { "Type": "Task", "Resource": "arn:aws:states:::http:invoke", "Parameters": { "Authentication": { "ConnectionArn": "arn:aws:events:us-east-1:
123456789012
:connection/Example/81210c42-8af1-456b-9c4a-6ff02fc664ac
" }, "ApiEndpoint": "https:/example.com/path
", "Method": "GET", "Headers": {"Request-Id": "my_request_id", "Header-Param": "state_machine_header_param"
}, "RequestBody": {"Job": "Software Engineer", "Company": "AnyCompany", "BodyParam": "state_machine_body_param"
}, "QueryParameters": {"QueryParam": "state_machine_query_param"
} } } } }
Connexion EventBridge
{ "AuthorizationType": "
API_KEY
", "AuthParameters": { "ApiKeyAuthParameters": { "ApiKeyName": "ApiKey
", "ApiKeyValue": "key_value
" }, "InvocationHttpParameters": { "BodyParameters": [ {"Key": "BodyParam", "Value": "connection_body_param"
} ], "HeaderParameters": [ {"Key": "Header-Param", "Value": "connection_header_param"
} ], "QueryStringParameters": [ {"Key": "QueryParam", "Value": "connection_query_param"
} ] } } }
Dans cet exemple, les clés dupliquées sont spécifiées dans la tâche et la EventBridge connexion HTTP. Par conséquent, Step Functions remplace les valeurs de la tâche HTTP par celles de la connexion. L'extrait de code suivant montre la requête HTTP envoyée à Step Functions l'API tierce.
POST /path?QueryParam=connection_query_param HTTP/1.1
Apikey: key_value
Content-Length: 79
Content-Type: application/json; charset=UTF-8
Header-Param: connection_header_param
Host: example.com
Range: bytes=0-262144
Request-Id: my_request_id
User-Agent: Amazon|StepFunctions|HttpInvoke|us-east-1
{"Job":"Software Engineer","Company":"AnyCompany","BodyParam":"connection_body_param"}
Appliquer le codage d'URL sur le corps de la demande
Par défaut, Step Functions envoie le corps de la requête sous forme de données JSON à un point de terminaison d'API. Si votre fournisseur d'API tiers a besoin de corps de form-urlencoded
requête, vous devez spécifier le codage URL pour les corps de requête. Step Functionsencode ensuite automatiquement le corps de la demande en fonction de l'option de codage d'URL que vous avez sélectionnée.
Vous spécifiez le codage des URL à l'aide du Transform
champ. Ce champ contient le RequestBodyEncoding
champ qui indique si vous souhaitez ou non appliquer un codage URL aux corps de vos demandes. Lorsque vous spécifiez le RequestBodyEncoding
champ, Step Functions convertit le corps de votre demande JSON en corps de form-urlencoded
demande avant d'appeler l'API tierce. Vous devez également spécifier l'content-type
en-tête, application/x-www-form-urlencoded
car les API qui acceptent les données codées en URL attendent l'content-type
en-tête.
Pour coder des tableaux dans le corps de votre requête, Step Functions fournit les options de codage des tableaux suivantes.
-
INDICES
— Répète une clé pour chaque élément d'un tableau et ajoute un crochet, [], à la clé pour indiquer qu'il s'agit d'un tableau. Ce crochet contient l'index de l'élément du tableau. L'ajout de l'index permet de définir l'ordre des éléments du tableau. Step FunctionsUtilise cette option de codage par défaut.Par exemple, si le corps de votre requête contient le tableau suivant.
{"array": ["a","b","c","d"]}
Step Functionscode ce tableau dans la chaîne suivante.
array[0]=a&array[1]=b&array[2]=c&array[3]=d
-
REPEAT
— Répète une clé pour chaque élément d'un tableau.Par exemple, si le corps de votre requête contient le tableau suivant.
{"array": ["a","b","c","d"]}
Step Functionscode ce tableau dans la chaîne suivante.
array=a&array=b&array=c&array=d
-
COMMAS
— Encode toutes les valeurs d'une clé sous forme de liste de valeurs séparées par des virgules.Par exemple, si le corps de votre requête contient le tableau suivant.
{"array": ["a","b","c","d"]}
Step Functionscode ce tableau dans la chaîne suivante.
array=a,b,c,d
-
BRACKETS
— Répète une clé pour chaque élément d'un tableau et ajoute un crochet, [], à la clé pour indiquer qu'il s'agit d'un tableau.Par exemple, si le corps de votre requête contient le tableau suivant.
{"array": ["a","b","c","d"]}
Step Functionscode ce tableau dans la chaîne suivante.
array[]=a&array[]=b&array[]=c&array[]=d
Autorisations IAM pour exécuter une tâche HTTP
Votre rôle d'exécution de machine à états doit disposer des secretsmanager:DescribeSecret
autorisations states:InvokeHTTPEndpoint
events:RetrieveConnectionCredentials
secretsmanager:GetSecretValue
,, et pour qu'une tâche HTTP appelle une API tierce. L'exemple de politique IAM suivant accorde le minimum de privilèges requis à votre rôle de machine d'état pour appeler les API Stripe. Cette politique IAM autorise également le rôle de machine d'état à accéder à une EventBridge connexion spécifique, y compris le secret de cette connexion qui est stocké dans Secrets Manager.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "Statement1", "Effect": "Allow", "Action": "states:InvokeHTTPEndpoint", "Resource": "arn:aws:states:us-east-2:
123456789012
:stateMachine:myStateMachine
", "Condition": { "StringEquals": { "states:HTTPMethod": "GET" }, "StringLike": { "states:HTTPEndpoint": "https://api.stripe.com/*" } } }, { "Sid": "Statement2", "Effect": "Allow", "Action": [ "events:RetrieveConnectionCredentials", ], "Resource": "arn:aws:events:us-east-2:123456789012
:connection/oauth_connection/aeabd89e-d39c-4181-9486-9fe03e6f286a
" }, { "Sid": "Statement3", "Effect": "Allow", "Action": [ "secretsmanager:GetSecretValue", "secretsmanager:DescribeSecret" ], "Resource": "arn:aws:secretsmanager:*:*:secret:events!connection/*" } ] }
Exemple de tâche HTTP
La définition de machine à états suivante montre une tâche HTTP qui inclut les RequestBody
paramètres Headers
QueryParameters
Transform
,, et. La tâche HTTP appelle une API Stripe, https://api.stripe.com/v1/invoices, pour générer une facture. La tâche HTTP spécifie également le codage URL pour le corps de la requête à l'aide de l'option d'INDICES
encodage.
Assurez-vous d'avoir créé une EventBridge connexion. L'exemple suivant montre une connexion créée à l'aide du type d'authentification BASIC.
{
"Type": "BASIC",
"AuthParameters": {
"BasicAuthParameters": {
"Password": "myPassword",
"Username": "myUsername"
},
}
}
N'oubliez pas de remplacer le texte en italique
par les informations spécifiques à votre ressource.
{ "Comment": "A state machine that uses HTTP Task", "StartAt": "CreateInvoiceAPI", "States": { "CreateInvoiceAPI": { "Type": "Task", "Resource": "arn:aws:states:::http:invoke", "Parameters": { "ApiEndpoint": "https://api.stripe.com/v1/invoices", "Method": "POST", "Authentication": { "ConnectionArn": ""arn:aws:events:
us-east-2
:123456789012
:connection/Stripe/81210c42-8af1-456b-9c4a-6ff02fc664ac" }, "Headers": { "Content-Type": "application/x-www-form-urlencoded" }, "RequestBody": { "customer.$": "$.customer_id", "description": "Monthly subscription", "metadata": { "order_details": "monthly report data" } }, "Transform": { "RequestBodyEncoding": "URL_ENCODED", "RequestEncodingOptions": { "ArrayFormat": "INDICES" } } }, "Retry": [ { "ErrorEquals": [ "States.Http.StatusCode.429", "States.Http.StatusCode.503", "States.Http.StatusCode.504", "States.Http.StatusCode.502" ], "BackoffRate": 2, "IntervalSeconds": 1, "MaxAttempts": 3, "JitterStrategy": "FULL" } ], "Catch": [ { "ErrorEquals": [ "States.Http.StatusCode.404", "States.Http.StatusCode.400", "States.Http.StatusCode.401", "States.Http.StatusCode.409", "States.Http.StatusCode.500" ], "Comment": "Handle all non 200 ", "Next": "HandleInvoiceFailure" } ], "End": true } } }
Pour exécuter cette machine d'état, entrez l'ID client comme entrée, comme indiqué dans l'exemple suivant :
{
"customer_id": "1234567890"
}
L'exemple suivant montre la requête HTTP envoyée Step Functions à l'API Stripe.
POST /v1/invoices HTTP/1.1
Authorization: Basic <base64 of username and password>
Content-Type: application/x-www-form-urlencoded
Host: api.stripe.com
Range: bytes=0-262144
Transfer-Encoding: chunked
User-Agent: Amazon|StepFunctions|HttpInvoke|us-east-1
description=Monthly%20subscription&metadata%5Border_details%5D=monthly%20report%20data&customer=1234567890
Test d'une tâche HTTP
Vous pouvez utiliser l'TestStateAPI via la console, le SDK ou le AWS CLI pour tester une tâche HTTP. La procédure suivante décrit comment utiliser l' TestState API dans la Step Functions console. Vous pouvez tester de manière itérative les détails de la demande, de la réponse et de l'authentification de l'API jusqu'à ce que votre tâche HTTP fonctionne comme prévu.
Tester l'état d'une tâche HTTP dans Step Functions la console
-
Ouvrez la console Step Functions
. -
Choisissez Créer une machine à états pour commencer à créer une machine à états ou choisissez une machine à états existante contenant une tâche HTTP.
Reportez-vous à l'étape 4 si vous testez la tâche sur une machine à états existante.
-
Dans Workflow Studio, configurez visuellement une tâche HTTP. Mode de conception Vous pouvez également choisir le mode Code pour copier-coller la définition de la machine à états depuis votre environnement de développement local.
-
En mode Design, choisissez Test state dans le Inspector panneau de Workflow Studio.
-
Dans la boîte de dialogue État du test, procédez comme suit :
-
Pour Rôle d'exécution, choisissez un rôle d'exécution pour tester l'état. Si vous ne disposez pas d'un rôle doté d'autorisations suffisantes pour une tâche HTTP, consultez la section Rôle pour tester les tâches HTTP dans Workflow Studio pour créer un rôle.
-
(Facultatif) Fournissez toute entrée JSON dont l'état sélectionné a besoin pour le test.
-
Pour le niveau d'inspection, conservez la sélection par défaut INFO. Ce niveau indique le statut de l'appel d'API et l'état de sortie. Cela est utile pour vérifier rapidement la réponse de l'API.
-
Choisissez Démarrer le test.
-
Si le test réussit, la sortie d'état apparaît sur le côté droit de la boîte de dialogue État du test. Si le test échoue, une erreur apparaît.
Dans l'onglet Détails de l'état de la boîte de dialogue, vous pouvez voir la définition de l'état et un lien vers votre EventBridgeconnexion.
-
Changez le niveau d'inspection en TRACE. Ce niveau affiche la requête et la réponse HTTP brutes et est utile pour vérifier les en-têtes, les paramètres de requête et d'autres détails spécifiques à l'API.
-
Cochez la case Révéler les secrets. Associé à TRACE, ce paramètre vous permet de voir les données sensibles insérées par la EventBridge connexion, telles que les clés d'API. L'identité IAM utilisateur que vous utilisez pour accéder à la console doit être autorisée à effectuer l'
states:RevealSecrets
action. Sans cette autorisation, Step Functions génère une erreur de refus d'accès lorsque vous démarrez le test. Pour un exemple de IAM politique définissant l'states:RevealSecrets
autorisation, consultezIAMautorisations d'utilisation de l' TestState API.L'image suivante montre un test de réussite d'une tâche HTTP. Le niveau d'inspection pour cet état est défini sur TRACE. L'onglet Requête et réponse HTTP de l'image suivante montre le résultat de l'appel d'API tiers.
-
Choisissez Démarrer le test.
-
Si le test réussit, vous pouvez voir les détails de votre protocole HTTP sous l'onglet Requête et réponse HTTP.
-
Réponses aux tâches HTTP non prises en charge
Une tâche HTTP échoue avec l'States.Runtime
erreur si l'une des conditions suivantes est vraie pour la réponse renvoyée :
-
La réponse contient un en-tête de type contenu
application/octet-stream
,image/*
video/*
, ou.audio/*
-
La réponse ne peut pas être lue comme une chaîne valide. Par exemple, des données binaires ou d'image.