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.
Création et gestion de commandes
Utilisez AWS IoT Device Management les commandes pour configurer des actions à distance réutilisables ou pour envoyer des instructions immédiates aux appareils. Créez et gérez des commandes depuis la AWS IoT console ou à l'aide du AWS CLI.
Création et gestion des opérations de commande
Création d'une ressource de commande
Fournissez les informations suivantes lors de la création d'une commande :
-
Informations générales
Fournissez un ID de commande unique pour identifier la commande lorsque vous l'exécutez sur des machines cibles. Spécifiez éventuellement un nom d'affichage, une description et des balises pour la gestion.
-
Charge utile
Pour les commandes statiques, fournissez une charge utile définissant les actions de l'appareil. Spécifiez le type de format de charge utile pour une interprétation correcte de l'appareil.
Pour les commandes dynamiques, consultez l'attribut du modèle de charge utile.
-
Modèle de charge utile
Pour les commandes dynamiques, fournissez un PayloadTemplate avec des espaces réservés et des paramètres. Fournissez
defaultValueet conditionnez éventuellement. AWS IoT Device Management Les commandes remplacent les espaces réservés lors de l'exécution. Les paramètres manquants utilisent leur DefaultValue. Toutes les valeurs doivent satisfaire à des conditions définies.Les types d'espaces réservés distinguant majuscules et minuscules suivants sont pris en charge :
-
${aws:iot:commandexecution::parameter:— Un espace réservé pour la valeur d'un paramètre portant le nomparameter1}parameter1. -
${aws:iot:commandexecution::executionTimeoutSec}— Un espace réservé pour le paramètre de délai d'exécution de la commande fourni lors de l'exécution.
-
Commandes réservées Les rubriques utilisent un format basé sur le type de format de charge utile.
-
Pour
application/jsonnos types deapplication/cborcontenu, utilisez ce sujet de demande :$aws/commands/<devices>/<DeviceID>/executions/+/request/<PayloadFormat> -
Pour d'autres types de contenu ou un format non spécifié, utilisez cette rubrique de demande. Le format Payload apparaît dans l'en-tête du message MQTT.
$aws/commands/<devices>/<DeviceID>/executions/+/request
La rubrique de réponse aux commandes utilise json ou met en cbor forme quel que soit le type de charge utile. <PayloadFormat>doit être json ou cbor :
$aws/commands/<devices>/<DeviceID>/executions/<ExecutionId>/response/<PayloadFormat>
Les sections suivantes décrivent les considérations relatives au format de charge utile et la création de commandes depuis la console.
Rubriques
Format de charge utile des commandes statiques
La charge utile prend en charge tous les formats jusqu'à 32 Ko. Spécifiez le type de format de charge utile pour une interprétation sûre et correcte de l'appareil.
Spécifiez le type de format de charge utile en utilisant le type/subtype format (par exemple, application/json ouapplication/cbor). Valeur par défaut : application/octet-stream. Consultez la section Types MIME courants
Format de charge utile des commandes dynamiques
Le PayloadTemplate doit être un JSON valide avec au moins un espace réservé, jusqu'à 32 Ko.
Pour le AwsJsonSubstitution préprocesseur, AWS IoT Device Management Commands envoie des notifications au format JSON ou CBOR en fonction de la configuration du préprocesseur.
Comment créer une commande (console)
Pour créer une commande depuis la console, accédez au Command Hub
-
Choisissez Créer une commande.
-
Spécifiez un ID de commande unique.
-
(Facultatif) Spécifiez le nom d'affichage, la description et les balises.
-
Téléchargez le fichier de charge utile contenant les actions de l'appareil. Spécifiez le type de format de charge utile pour une interprétation correcte de l'appareil.
-
(Facultatif) Pour les modèles de charge utile JSON avec espaces réservés, les paramètres sont préremplis dans le tableau intégré pour être modifiés.
-
(Facultatif) Configurez le type de valeur du paramètre (obligatoire), la valeur par défaut et les conditions.
-
Choisissez Créer une commande.
Utilisez l'CreateCommandAPI ou la commande create-commandCLI pour créer une commande.
Rubriques
Charge utile de commande
Fournissez une charge utile ou un modèle de charge utile statique. Les charges utiles statiques sont codées en base64. Pour les modèles de charge utile, la charge utile finale est générée au moment de l'exécution à l'aide de valeurs de paramètres. Les appareils traitent la charge utile et exécutent les actions spécifiées. Spécifiez le type de contenu de charge utile pour une réception correcte de l'appareil.
Note
Les charges utiles ne peuvent pas être modifiées après la création de la commande. Créez une nouvelle commande pour modifier la charge utile.
Exemple de politique IAM
Avant d'utiliser cette opération d'API, assurez-vous que votre politique IAM vous autorise à effectuer cette action sur l'appareil. L'exemple suivant montre une politique IAM qui autorise l'utilisateur à effectuer l'CreateCommandaction.
Dans cet exemple, remplacez :
-
avec votre Région AWS, par exempleregion.us-east-1 -
avec votre Compte AWS numéro, par exempleaccount-id.123456789012 -
avec un identifiant unique pour votre identifiant de AWS IoT commande, tel quecommand-id. Si vous souhaitez envoyer plusieurs commandes, vous pouvez les spécifier dans la section Ressource de la stratégie IAM.LockDoor
-
{ "Version":"2012-10-17", "Statement": { "Action": "iot:CreateCommand", "Effect": "Allow", "Resource": "arn:aws:iot:us-east-1:123456789012:command/command-id" } }
Exemple de création de commande statique
L'exemple suivant montre comment créer une commande statique. En fonction de votre application, remplacez :
-
avec un identifiant unique pour la commande. Par exemple, pour verrouiller la porte de votre maison, vous pouvez spécifier<command-id>. Nous vous recommandons d'utiliser l'UUID. Vous pouvez également utiliser des caractères alphanumériques, « - » et « _ ».LockDoor -
(Facultatif)
et<display-name>qui sont des champs facultatifs que vous pouvez utiliser pour fournir un nom convivial et une description significative à la commande, tels que<description>.Lock the doors of my home -
namespace, que vous pouvez utiliser pour spécifier l'espace de noms de la commande. Ça doit l'êtreAWS-IoT. Pour plus d'informations sur l'utilisation de cette fonctionnalité pour AWS IoT FleetWise, voir Commandes à distance -
payloadcontient des informations sur la charge utile que vous souhaitez utiliser lors de l'exécution de la commande et son type de contenu.
aws iot create-command \ --command-id<command-id>\ --display-name\ --description<display-name><description>\ --namespace AWS-IoT \ --payload '{"content":"eyAibWVzc2FnZSI6ICJIZWxsbyBJb1QiIH0=","contentType":"application/json"}'
L'exécution de cette commande génère une réponse contenant l'ID et l'ARN (nom de ressource Amazon) de la commande. Par exemple, si vous avez spécifié la commande lors de sa création, voici un exemple de sortie d'exécution de la commande.LockDoor
{ "commandId": "LockDoor", "commandArn": "arn:aws:iot:us-east-1:123456789012:command/LockDoor" }
Exemple de création de commande dynamique
L'exemple suivant montre comment créer une commande dynamique. En fonction de votre application, remplacez :
-
avec un identifiant unique pour la commande. Par exemple, pour définir l'état de puissance de la lampe, vous pouvez spécifier<command-id>. Nous vous recommandons d'utiliser l'UUID. Vous pouvez également utiliser des caractères alphanumériques, « - » et « _ ».Light_Power_Status -
(Facultatif)
et<display-name>qui sont des champs facultatifs que vous pouvez utiliser pour fournir un nom convivial et une description significative à la commande, tels que<description>.Turn a light ON or OFF -
namespace, que vous pouvez utiliser pour spécifier l'espace de noms de la commande. Ça doit l'êtreAWS-IoT. Pour plus d'informations sur l'utilisation de cette fonctionnalité pour AWS IoT FleetWise, voir Commandes à distance -
payloadTemplatecontient le modèle de charge de jeu au format JSON avec des espaces réservés. -
preprocessorcontient la configuration du préprocesseur qui détermine la manière dont le PayloadTemplate doit être traité. -
mandatoryParametercontient les paramètres correspondant aux espaces réservés du PayloadTemplate, leur type, leurs valeurs par défaut et leurs conditions.
aws iot create-command \ --command-idLight_Power_Status\ --description"Turn a light ON or OFF"\ --namespace AWS-IoT \ --payload-template'{"powerStatus":"${aws:iot:commandexecution::parameter:powerStatus}"}'\ --preprocessorawsJsonSubstitution={outputFormat=JSON}\ --mandatory-parameters"name=powerStatus, defaultValue={S=OFF}, valueConditions=[{comparisonOperator=IN_SET, operand={strings=['ON','OFF']}}]"
L'exécution de cette commande génère une réponse contenant l'ID et l'ARN (nom de ressource Amazon) de la commande. Par exemple, si vous avez spécifié la commande lors de sa création, voici un exemple de sortie d'exécution de la commande.Light_Power_Status
{ "commandId": "Light_Power_Status", "commandArn": "arn:aws:iot:us-east-1:123456789012:command/Light_Power_Status" }
Récupérer les informations relatives à une commande
Après avoir créé une commande, vous pouvez récupérer des informations la concernant depuis la AWS IoT console et en utilisant le AWS CLI. Vous pouvez obtenir les informations suivantes.
-
L'ID de commande, le nom de la ressource Amazon (ARN), tout nom d'affichage et toute description que vous avez spécifiés pour la commande.
-
L'état de la commande, qui indique si une commande est disponible pour être exécutée sur le périphérique cible, ou si elle est obsolète ou supprimée.
-
La charge utile ou le modèle de charge utile que vous avez fourni.
-
Le préprocesseur que vous avez fourni.
-
Les paramètres obligatoires que vous avez fournis.
-
Heure à laquelle la commande a été créée et mise à jour pour la dernière fois.
Pour récupérer une commande depuis la console, accédez au hub de commande
Outre les détails de la commande, vous pouvez consulter l'historique des commandes, qui fournit des informations sur l'exécution de la commande sur le périphérique cible. Après avoir exécuté cette commande sur l'appareil, vous trouverez des informations sur les exécutions dans cet onglet.
Utilisez l'opération API du plan de contrôle GetCommandHTTP ou la get-command AWS CLI commande pour récupérer des informations sur une ressource de commande. Vous devez déjà avoir créé la commande à l'aide de la demande CreateCommand d'API ou de la create-command CLI.
Exemple de politique IAM
Avant d'utiliser cette opération d'API, assurez-vous que votre politique IAM vous autorise à effectuer cette action sur l'appareil. L'exemple suivant montre une politique IAM qui autorise l'utilisateur à effectuer l'GetCommandaction.
Dans cet exemple, remplacez :
-
avec votre Région AWS, par exempleregionus-east-1. -
avec votre Compte AWS numéro, par exempleaccount-id.123456789023 -
avec votre identifiant de commande AWS IoT unique, tel quecommand-idouLockDoor. Si vous souhaitez récupérer plusieurs commandes, vous pouvez les spécifier dans la section Ressource de la politique IAM.Light_Power_Status
-
{ "Version":"2012-10-17", "Statement": { "Action": "iot:GetCommand", "Effect": "Allow", "Resource": "arn:aws:iot:us-east-1:123456789012:command/command-id" } }
Récupérez un exemple de commande (AWS CLI)
L'exemple suivant montre comment récupérer des informations sur une commande à l'aide du get-command AWS CLI. En fonction de votre application, remplacez-le par l'identifiant de la commande pour laquelle vous souhaitez récupérer des informations. Vous pouvez obtenir ces informations à partir de la réponse de la <command-id>create-command CLI.
aws iot get-command --command-id<command-id>
L'exécution de cette commande génère une réponse contenant des informations sur la commande, la charge utile, ainsi que l'heure à laquelle elle a été créée et mise à jour pour la dernière fois. Il fournit également des informations indiquant si une commande est obsolète ou en cours de suppression.
Par exemple, le code suivant montre un exemple de réponse.
{ "commandId": "LockDoor", "commandArn": "arn:aws:iot:<region>:<account>:command/LockDoor", "namespace": "AWS-IoT", "payload":{ "content": "eyAibWVzc2FnZSI6ICJIZWxsbyBJb1QiIH0=", "contentType": "application/json" }, "createdAt": "2024-03-23T00:50:10.095000-07:00", "lastUpdatedAt": "2024-03-23T00:50:10.095000-07:00", "deprecated": false, "pendingDeletion": false }
Répertoriez les commandes dans votre Compte AWS
Après avoir créé des commandes, vous pouvez consulter celles que vous avez créées dans votre compte. Dans la liste, vous trouverez des informations sur :
-
L'ID de commande et tout nom d'affichage que vous avez spécifié pour les commandes.
-
Le nom de ressource Amazon (ARN) des commandes.
-
État de la commande qui indique si les commandes peuvent être exécutées sur le périphérique cible ou si elles sont obsolètes.
Note
La liste des personnes en cours de suppression de votre compte ne s'affiche pas. Si les commandes sont en attente de suppression, vous pouvez toujours consulter les détails de ces commandes à l'aide de leur ID de commande.
-
Heure à laquelle les commandes ont été créées et mises à jour pour la dernière fois.
Dans la AWS IoT console, vous pouvez trouver la liste des commandes que vous avez créées et leurs détails en accédant au Command Hub
Pour répertorier les commandes que vous avez créées, utilisez l'opération ListCommandsAPI ou la list-commandsCLI.
Exemple de politique IAM
Avant d'utiliser cette opération d'API, assurez-vous que votre politique IAM vous autorise à effectuer cette action sur l'appareil. L'exemple suivant montre une politique IAM qui autorise l'utilisateur à effectuer l'ListCommandsaction.
Dans cet exemple, remplacez :
-
avec votre Région AWS, par exempleregionus-east-1. -
avec votre Compte AWS numéro, par exempleaccount-id.123456789012
-
{ "Version":"2012-10-17", "Statement": { "Action": "iot:ListCommands", "Effect": "Allow", "Resource": "arn:aws:iot:us-east-1:123456789012:command/*" } }
Exemple de liste des commandes dans votre compte
La commande suivante indique comment répertorier les commandes de votre compte.
aws iot list-commands --namespace "AWS-IoT"
L'exécution de cette commande génère une réponse contenant une liste des commandes que vous avez créées, l'heure à laquelle les commandes ont été créées et la date de leur dernière mise à jour. Il fournit également des informations sur l'état de la commande, qui indiquent si une commande est obsolète ou si elle est disponible pour être exécutée sur le périphérique cible. Pour plus d'informations sur les différents statuts et la raison du statut, consultezStatut d’exécution de la commande.
Mettre à jour une ressource de commande
Après avoir créé une commande, vous pouvez mettre à jour le nom d'affichage et la description de la commande.
Note
La charge utile de la commande ne peut pas être mise à jour. Pour mettre à jour ces informations ou utiliser une charge utile modifiée, vous devez créer une nouvelle commande.
Pour mettre à jour une commande depuis la console, accédez au Command Hub
-
Pour mettre à jour une ressource de commande existante, choisissez la commande que vous souhaitez mettre à jour, puis sous Actions, choisissez Modifier.
-
Spécifiez le nom d'affichage et la description que vous souhaitez utiliser, ainsi que toutes les paires nom-valeur en tant que balises pour votre commande.
-
Choisissez Modifier pour enregistrer la commande avec les nouveaux paramètres.
Utilisez l'opération API du plan de UpdateCommandcontrôle ou le update-command AWS CLI pour mettre à jour une ressource de commande. Grâce à cette API, vous pouvez :
-
Modifiez le nom d'affichage et la description d'une commande que vous avez créée.
-
Dépréciez une ressource de commande ou restaurez une commande déjà obsolète.
Exemple de politique IAM
Avant d'utiliser cette opération d'API, assurez-vous que votre politique IAM vous autorise à effectuer cette action sur l'appareil. L'exemple suivant montre une politique IAM qui autorise l'utilisateur à effectuer l'UpdateCommandaction.
Dans cet exemple, remplacez :
-
avec votre Région AWS, par exempleregionus-east-1. -
avec votre Compte AWS numéro, par exempleaccount-id.123456789012 -
avec votre identifiant de commande AWS IoT unique, tel quecommand-id. Si vous souhaitez récupérer plusieurs commandes, vous pouvez les spécifier dans la section Ressource de la politique IAM.LockDoor
-
{ "Version":"2012-10-17", "Statement": { "Action": "iot:UpdateCommand", "Effect": "Allow", "Resource": "arn:aws:iot:us-east-1:123456789012:command/command-id" } }
Exemples de mise à jour des informations relatives à une commande (AWS CLI)
L'exemple suivant montre comment mettre à jour les informations relatives à une commande à l'aide de cette update-command AWS CLI commande. Pour plus d'informations sur la façon dont vous pouvez utiliser cette API pour déprécier ou restaurer une ressource de commande, consultez. Mettre à jour une ressource de commande (CLI)
L'exemple montre comment mettre à jour le nom d'affichage et la description d'une commande. En fonction de votre application, remplacez-le par l'identifiant de la commande pour laquelle vous souhaitez récupérer des informations.<command-id>
aws iot update-command \ --command-id<command-id>--displayname<display-name>\ --description<description>
L'exécution de cette commande génère une réponse contenant les informations mises à jour sur la commande et l'heure de sa dernière mise à jour. Le code suivant montre un exemple de demande et de réponse pour mettre à jour le nom d'affichage et la description d'une commande qui met le courant alternatif hors tension.
aws iot update-command \ --command-id<LockDoor>\ --displayname<Secondary lock door>\ --description<Locks doors to my home>
L'exécution de cette commande génère la réponse suivante.
{ "commandId": "LockDoor", "commandArn": "arn:aws:iot:us-east-1:123456789012:command/LockDoor", "displayName": "Secondary lock door", "description": "Locks doors to my home", "lastUpdatedAt": "2024-05-09T23:15:53.899000-07:00" }
Dépréciation ou restauration d'une ressource de commande
Après avoir créé une commande, si vous ne souhaitez plus continuer à l'utiliser, vous pouvez la marquer comme obsolète. Lorsque vous désapprouvez une commande, toutes les exécutions de commandes en attente continuent de s'exécuter sur le périphérique cible jusqu'à ce qu'elles atteignent le statut de terminal. Une fois qu'une commande est devenue obsolète, si vous souhaitez l'utiliser, par exemple pour envoyer une nouvelle exécution de commande à la machine cible, vous devez la restaurer.
Note
Vous ne pouvez pas modifier une commande obsolète, ni exécuter de nouvelles exécutions pour celle-ci. Pour exécuter de nouvelles commandes sur l'appareil, vous devez le restaurer afin que l'état de la commande passe à Disponible.
Pour plus d'informations sur la dépréciation et la restauration d'une commande, ainsi que sur les considérations associées, consultez. Obsolescence d’une ressource de commande
Supprimer une ressource de commande
Si vous ne souhaitez plus utiliser une commande, vous pouvez la supprimer définitivement de votre compte. Si l'action de suppression est réussie :
-
Si la commande est devenue obsolète pendant une durée supérieure au délai maximum de 12 heures, elle sera immédiatement supprimée.
-
Si la commande n'est pas obsolète, ou si elle l'a été pendant une durée inférieure au délai maximum, la commande sera dans un état.
pending deletionIl sera automatiquement supprimé de votre compte après le délai maximum de 12 heures.
Note
La commande peut être supprimée même si des exécutions de commandes sont en attente. La commande sera en attente de suppression et sera automatiquement supprimée de votre compte.
Pour supprimer une commande de la console, accédez au Command Hub
-
Choisissez la commande que vous souhaitez supprimer, puis sous Actions, choisissez Supprimer.
-
Confirmez que vous souhaitez supprimer la commande, puis choisissez Supprimer.
La commande sera marquée pour suppression et sera définitivement supprimée de votre compte au bout de 12 heures.
Utilisez l'opération API du plan de contrôle DeleteCommand HTTP ou la delete-command AWS CLI commande pour supprimer une ressource de commande. Si l'action de suppression aboutit, vous verrez un HTTP statusCode 204 ou 202, et la commande sera automatiquement supprimée de votre compte après le délai d'expiration maximal de 12 heures. Dans le cas du statut 204, cela indique que la commande a été supprimée.
Exemple de politique IAM
Avant d'utiliser cette opération d'API, assurez-vous que votre politique IAM vous autorise à effectuer cette action sur l'appareil. L'exemple suivant montre une politique IAM qui autorise l'utilisateur à effectuer l'DeleteCommandaction.
Dans cet exemple, remplacez :
-
avec votre Région AWS, par exempleregionus-east-1. -
avec votre Compte AWS numéro, par exempleaccount-id.123456789012 -
avec votre identifiant de commande AWS IoT unique, tel quecommand-id. Si vous souhaitez récupérer plusieurs commandes, vous pouvez les spécifier dans la section Ressource de la politique IAM.LockDoor
-
{ "Version":"2012-10-17", "Statement": { "Action": "iot:DeleteCommand", "Effect": "Allow", "Resource": "arn:aws:iot:us-east-1:123456789012:command/command-id" } }
Exemple de suppression d'une commande (AWS CLI)
Les exemples suivants montrent comment supprimer une commande à l'aide de cette delete-command AWS CLI commande. En fonction de votre application, remplacez-le par l'identifiant de la commande que vous supprimez.<command-id>
aws iot delete-command --command-id<command-id>
Si la demande d'API aboutit, la commande génère un code d'état 202 ou 204. Vous pouvez utiliser l'GetCommandAPI pour vérifier que la commande n'existe plus dans votre compte.