Appelez HTTPS APIs dans les flux de travail Step Functions - AWS Step Functions

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 HTTPS APIs dans les flux de travail Step Functions

Une tâche HTTP est un type d'État du flux de travail des tâchesétat qui vous permet d'appeler une API HTTPS dans vos flux de travail. L'API peut être publique, comme les applications SaaS tierces telles que Stripe ou Salesforce. Vous pouvez également appeler une API privée, telle que des applications basées sur HTTPS dans un Amazon Virtual Private Cloud.

Pour l'autorisation et la connectivité réseau, une tâche HTTP nécessite une EventBridge connexion.

Pour appeler une API HTTPS, 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 de connexion.

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 IAM politiques pour la tâche HTTP. Pour de plus amples informations, veuillez consulter Rôle pour tester les tâches HTTP dans Workflow Studio.

Note

La tâche HTTP ne prend actuellement en charge que les noms de domaine public dotés de certificats approuvés publiquement pour les points de terminaison HTTPS lors de l'utilisation du mode privé APIs. La tâche HTTP ne prend pas en charge le protocole TLS mutuel (MTL).

Connectivité pour une tâche HTTP

Une tâche HTTP nécessite une EventBridgeconnexion qui gère de manière sécurisée les informations d'authentification d'un fournisseur d'API. Une connexion définit la méthode d'autorisation et les informations d'identification à utiliser pour se connecter à une API donnée. Si vous vous connectez à une API privée, telle qu'une API privée dans un Amazon Virtual Private Cloud (Amazon VPC), vous pouvez également utiliser cette connexion pour définir une connectivité point-to-point réseau sécurisée. 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 OAuth d'autorisation Basic et API Key.

Lorsque vous créez une EventBridge connexion, vous fournissez vos informations d'autorisation et de connectivité réseau. 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 HTTPS.

Lorsque vous créez une connexion, 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 le IAM autorisations dont votre machine d'état a besoin pour accéder à une EventBridge connexion, voirAutorisations IAM pour exécuter une tâche HTTP.

L'image suivante montre comment Step Functions gère l'autorisation pour les appels d'API HTTPS à l'aide d'un EventBridge connexion. Le EventBridge La connexion gère les informations d'identification d'un fournisseur d'API HTTPS. EventBridge crée un secret dans Secrets Manager pour stocker les paramètres de connexion et d'autorisation sous forme cryptée. Dans le cas du mode privé APIs, stocke EventBridge également les configurations de connectivité réseau.

Délais d'attente pour les connexions

Les demandes de tâches HTTP expireront au bout de 60 secondes.

Step Functions utilise l'autorisation et la configuration réseau dans EventBridge les connexions pour les appels aux points de terminaison HTTPS.

Définition de la 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 publique qui renvoie une liste de tous les clients.

"Call HTTPS 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 le Resource champ comme suit.

"Resource": "arn:aws:states:::http:invoke"
Parameters (Obligatoire)

Contient les ConnectionArn champs ApiEndpointMethod, et qui fournissent des informations sur l'API HTTPS que vous souhaitez appeler. Parameterscontient également des champs facultatifs, tels que Headers etQueryParameters.

Vous pouvez spécifier une combinaison de JSON statique et de JsonPathsyntaxe comme Parameters dans le Parameters champ. Pour de plus amples informations, veuillez consulter Transmission de paramètres à une API de service dans Step Functions.

Pour spécifier la EventBridge connexion, utilisez le InvocationConfig champ Authentication ou.

ApiEndpoint(Obligatoire)

Spécifie l'URL de l'API HTTPS que vous souhaitez appeler. Pour ajouter des paramètres de requête à l'URL, utilisez le QueryParameters champ. 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 JsonPathsyntaxe permettant de sélectionner le nœud JSON contenant l'URL de l'API HTTPS. Supposons, par exemple, que vous souhaitiez appeler l'un des Stripe APIs en utilisant 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 HTTPS. 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(Conditionnel)

Vous devez spécifier l'un Authentication ou l'autreInvocationConfig.

Contient le ConnectionArn champ qui indique comment authentifier un appel d'API HTTPS public. Step Functions prend en charge l'authentification pour un élément spécifié ApiEndpoint à l'aide de la ressource de connexion de Amazon EventBridge.

ConnectionArn(Obligatoire)

Spécifie le EventBridge ARN de connexion.

Une tâche HTTP nécessite une EventBridge connexion qui gère de manière sécurisée les informations d'autorisation d'un fournisseur d'API. Une connexion indique le type d'autorisation et les informations d'identification à utiliser pour autoriser une API HTTPS. 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 HeadersQueryParameters, et des RequestBody paramètres.

Pour de plus amples informations, veuillez consulter Connectivité 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" }
InvocationConfig(Conditionnel)

Vous devez spécifier l'un Authentication ou l'autreInvocationConfig.

Contient la configuration d'autorisation et de connectivité réseau pour un appel d'API HTTPS privé. Step Functions prend en charge la connexion pour un élément spécifié ApiEndpoint à l'aide de la ressource de connexion de Amazon EventBridge. Pour plus d'informations, consultez la section Connexion au mode privé APIs dans le guide de EventBridge l'utilisateur Amazon.

ConnectionArn(Obligatoire)

Spécifie le EventBridge ARN de connexion.

Une tâche HTTP nécessite une EventBridge connexion qui gère de manière sécurisée les informations d'autorisation d'un fournisseur d'API. Une connexion indique le type d'autorisation et les informations d'identification à utiliser pour autoriser une API HTTPS. Pour le mode privé APIs, la connexion définit également une connectivité point-to-point réseau sécurisée. 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 HeadersQueryParameters, et des RequestBody paramètres.

Pour de plus amples informations, veuillez consulter Connectivité pour une tâche HTTP.

L'exemple suivant montre comment vous pouvez spécifier un InvocationConfig champ dans votre définition de tâche HTTP.

"InvocationConfig": { "ConnectionArn": "arn:aws:events:us-east-2:123456789012:connection/connection-id" }
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 EventBridge connexion et Headers champ dans une tâche HTTP. Nous vous recommandons de ne pas inclure les informations d'authentification de vos fournisseurs d'API Headers sur le terrain. Nous vous recommandons d'inclure ces informations dans votre EventBridge connexion.

Step Functions ajoute les en-têtes que vous spécifiez dans 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 le EventBridge connexion pour ces en-têtes. Pour plus d'informations sur la façon dont Step Functions effectue la fusion des données, voirFusion EventBridge données de connexion et de définition des tâches HTTP.

L'exemple suivant indique un en-tête qui sera inclus dans un appel d'API HTTPS : 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 Functions définit les Host en-têtes User-AgentRange, et. Step Functions définit la valeur de l'Hosten-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.com

Vous 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.Runtimeerreur.

  • A-IM

  • Accept-Charset

  • Accept-Datetime

  • Accept-Encoding

  • Cache-Control

  • Connexion

  • Encodage-Contenu

  • Contenu- MD5

  • Date

  • Expect

  • Forwarded

  • De

  • Host (Hôte)

  • HTTP2-Réglages

  • 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 Functions encode automatiquement les paramètres de requête en URL lorsqu'il appelle une API HTTPS.

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" }

Au moment 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 ajoute 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 le EventBridge connexion pour ces en-têtes. Pour plus d'informations sur la façon dont Step Functions effectue la fusion des données, voirFusion EventBridge données de connexion et de définition des tâches HTTP.

Transform (facultatif)

Contient les RequestEncodingOptions champs RequestBodyEncoding 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 le Transform champ pour spécifier le codage URL des corps de requête. Vous devez également spécifier l'content-typeen-tête sous la formeapplication/x-www-form-urlencoded. Step Functions puis 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é du RequestBody 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 du RequestBody champ.

RequestEncodingOptions

Détermine l'option de codage à utiliser pour les tableaux dans le corps de votre requête si vous définissez surRequestBodyEncoding. URL_ENCODED

Step Functions prend 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. Par défaut, Step Functions utilise cette option de codage.

  • 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'COMMASencodage 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. DansRequestBody, 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 et ExpiryDate 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 HTTPS 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 de plus amples informations, veuillez consulter Appliquer le codage d'URL sur le corps de la demande.

Fusion EventBridge données de connexion et de définition des tâches HTTP

Lorsque vous invoquez une tâche HTTP, vous pouvez spécifier des données dans votre EventBridge connexion et votre définition de tâche HTTP. Ces données incluent HeadersQueryParameters, et les RequestBody paramètres. Avant d'appeler une API HTTPS, 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.Runtimeerreur.

Si des clés dupliquées sont spécifiées dans la définition de la tâche HTTP et dans EventBridge connexion, Step Functions remplace les valeurs de la tâche HTTP par celles de la connexion.

La liste suivante décrit comment Step Functions fusionne les données avant d'appeler une API HTTPS :

  • 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-typeen-tête dans la définition de la tâche HTTP et EventBridge connexion, Step Functions utilise la valeur content-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 de maxItems requête dans la définition de la tâche HTTP et EventBridge connexion, Step Functions utilise la valeur du paramètre de maxItems requête spécifiée dans la connexion.

  • Paramètres de corps

    • Step Functions ajoute 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é un Mode champ dans la définition RequestBody de la tâche HTTP et EventBridge connexion. Step Functions utilise la valeur du Mode 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 EventBridge la connexion contient également le corps de la requête, Step Functions Impossible de fusionner le corps de la demande spécifié à ces deux endroits. Il échoue à la tâche HTTP avec l'States.Runtimeerreur.

    Step Functions applique toutes les transformations et sérialise le corps de la demande une fois la fusion du corps de la demande terminée.

L'exemple suivant définit les RequestBody champs HeadersQueryParameters, et dans la tâche HTTP et EventBridge connexion.

Définition de la 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" } } } } }

EventBridge connexion

{ "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 HTTP et EventBridge connexion. 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 qui Step Functions envoie à l'API HTTPS.

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 HTTPS nécessite des corps de form-urlencoded requête, vous devez spécifier le codage URL pour les corps de requête. Step Functions encode 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 requête JSON en corps de form-urlencoded requête avant d'appeler l'API HTTPS. Vous devez également spécifier l'content-typeen-tête, application/x-www-form-urlencoded car ceux APIs qui acceptent les données codées en URL attendent l'content-typeen-tête.

Pour coder des tableaux dans le corps de votre requête, Step Functions fournit les options de codage de tableau 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. Par défaut, Step Functions utilise cette option de codage.

    Par exemple, si le corps de votre requête contient le tableau suivant.

    {"array": ["a","b","c","d"]}

    Step Functions code 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 Functions code 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 Functions code 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 Functions code 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 autorisations suivantes pour qu'une tâche HTTP puisse appeler une API HTTPS :

  • states:InvokeHTTPEndpoint

  • events:RetrieveConnectionCredentials

  • secretsmanager:GetSecretValue

  • secretsmanager:DescribeSecret

L'exemple de politique IAM suivant accorde le minimum de privilèges requis à votre rôle de machine d'État pour appeler Stripe APIs. 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 QueryParametersTransform,, et. La tâche HTTP appelle une API Stripe, https://api.stripe.com/v1/ les factures, 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'INDICESencodage.

Assurez-vous d'avoir créé un 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 italicized texte 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 qui Step Functions envoie à 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 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 console
  1. Ouvrez la console Step Functions.

  2. 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.

  3. 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.

  4. En mode Design, choisissez Test state dans le Panneau Inspector panneau de Workflow Studio.

  5. Dans la boîte de dialogue État du test, procédez comme suit :

    1. 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.

    2. (Facultatif) Fournissez toute entrée JSON dont l'état sélectionné a besoin pour le test.

    3. 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.

    4. Choisissez Démarrer le test.

    5. 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 EventBridge connexion.

    6. 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.

    7. Cochez la case Révéler les secrets. Associé à TRACE, ce paramètre vous permet de voir les données sensibles que EventBridge des inserts de connexion, tels que des clés d'API. Le IAM l'identité utilisateur que vous utilisez pour accéder à la console doit être autorisée à effectuer l'states:RevealSecretsaction. Sans cette autorisation, Step Functions génère une erreur de refus d'accès lorsque vous lancez le test. Pour un exemple de IAM politique qui définit l'states:RevealSecretsautorisation, voirIAM autorisations 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 HTTPS.

      Sortie d'un état sélectionné qui réussit le test pour le niveau TRACE.
    8. Choisissez Démarrer le test.

    9. 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.Runtimeerreur si l'une des conditions suivantes est vraie pour la réponse renvoyée :

  • La réponse contient un en-tête de type contenuapplication/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.

Erreurs de connexion

Si vous EventBridge rencontrez un problème lors de la connexion à l'API spécifiée pendant l'exécution du flux de travail, Step Functions génère l'erreur dans votre flux de travail. Les erreurs de connexion sont préfixées parEvents.ConnectionResource..

Ces erreurs incluent :

  • Events.ConnectionResource.InvalidConnectionState

  • Events.ConnectionResource.InvalidPrivateConnectionState

  • Events.ConnectionResource.AccessDenied

  • Events.ConnectionResource.ResourceNotFound

  • Events.ConnectionResource.AuthInProgress

  • Events.ConnectionResource.ConcurrentModification

  • Events.ConnectionResource.InternalError