Compartir vía


Ejemplo de script de la CLI de Azure: creación de una aplicación lógica

Se aplica a: Azure Logic Apps (consumo)

Este script crea una aplicación lógica de ejemplo a través de la extensión de Logic Apps de la CLI de Azure (az logic). Para obtener una guía detallada sobre la creación y administración de aplicaciones lógicas mediante la CLI de Azure, consulte el inicio rápido de Logic Apps para la CLI de Azure.

Advertencia

Actualmente, la extensión Logic Apps de la CLI de Azure se encuentra en fase experimental y no está incluida en el soporte al cliente. Use esta extensión de la CLI con precaución, sobre todo en entornos de producción.

Requisitos previos

Comprobación de requisitos previos

Valide el entorno antes de empezar:

  • Inicie sesión en Azure Portal y compruebe que la suscripción está activa, para lo que debe ejecutar az login.

  • Compruebe la versión de la CLI de Azure en una ventana de terminal o de comandos, para lo que debe ejecutar az --version. Para saber cuál es la versión más reciente, consulte las notas de la versión más reciente.

Explicación del flujo de trabajo de ejemplo

Este archivo de definición de flujo de trabajo de ejemplo crea el mismo ejemplo de flujo de trabajo de aplicación lógica de Consumo que en elinicio rápido para Azure Portal.

Este flujo de trabajo de ejemplo:

  1. Especifica el esquema $schema, para la aplicación lógica.

  2. Define un desencadenador para la aplicación lógica en la lista de desencadenadores, triggers. El desencadenador se repite (recurrence) cada 3 horas. Las acciones se desencadenan cuando se publica un nuevo elemento de fuente (When_a_feed_item_is_published) para la fuente RSS especificada (feedUrl).

  3. Define una acción para la aplicación lógica en la lista de acciones, actions. La acción envía un correo electrónico (Send_an_email_(V2)) a través de Microsoft 365 con detalles de los elementos de fuente RSS, tal y como se especifica en la sección de cuerpo (body) de las entradas de la acción (inputs).

Definición del flujo de trabajo de ejemplo

Antes de ejecutar el script de ejemplo, primero debe crear una definición de flujo de trabajo de ejemplo.

  1. Cree un archivo JSON testDefinition.json en el equipo.

  2. Copie el siguiente contenido en el archivo JSON:

    
    {
        "definition": {
            "$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
            "actions": {
                "Send_an_email_(V2)": {
                    "inputs": {
                        "body": {
                            "Body": "<p>@{triggerBody()?['publishDate']}<br>\n@{triggerBody()?['title']}<br>\n@{triggerBody()?['primaryLink']}</p>",
                            "Subject": "@triggerBody()?['title']",
                            "To": "test@example.com"
                        },
                        "host": {
                            "connection": {
                                "name": "@parameters('$connections')['office365']['connectionId']"
                            }
                        },
                        "method": "post",
                        "path": "/v2/Mail"
                    },
                    "runAfter": {},
                    "type": "ApiConnection"
                }
            },
            "contentVersion": "1.0.0.0",
            "outputs": {},
            "parameters": {
                "$connections": {
                    "defaultValue": {},
                    "type": "Object"
                }
            },
            "triggers": {
                "When_a_feed_item_is_published": {
                    "inputs": {
                        "host": {
                            "connection": {
                                "name": "@parameters('$connections')['rss']['connectionId']"
                            }
                        },
                        "method": "get",
                        "path": "/OnNewFeed",
                        "queries": {
                            "feedUrl": "https://www.pbs.org/now/rss.xml"
                        }
                    },
                    "recurrence": {
                        "frequency": "Hour",
                        "interval": 3
                    },
                    "splitOn": "@triggerBody()?['value']",
                    "type": "ApiConnection"
                }
            }
        },
        "parameters": {
            "$connections": {
                "value": {
                    "office365": {
                        "connectionId": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/testResourceGroup/providers/Microsoft.Web/connections/office365",
                        "connectionName": "office365",
                        "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/providers/Microsoft.Web/locations/westus/managedApis/office365"
                    },
                    "rss": {
                        "connectionId": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourceGroups/testResourceGroup/providers/Microsoft.Web/connections/rss",
                        "connectionName": "rss",
                        "id": "/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/providers/Microsoft.Web/locations/westus/managedApis/rss"
                    }
                }
            }
        }
    }
    
    
  3. Actualice los valores del marcador de posición con su propia información:

    1. Reemplace la dirección de correo electrónico del marcador de posición ("To": "test@example.com"). Debe usar una dirección de correo electrónico compatible con los conectores de Logic Apps. Para más información, consulte la sección los requisitos previos.

    2. Reemplace los detalles adicionales del conector si usa un conector de correo electrónico que no sea el conector de Office 365 Outlook.

    3. Reemplace los valores de suscripción del marcador de posición (00000000-0000-0000-0000-000000000000) para los identificadores de conexión (connectionId y id) en el parámetro de conexiones ($connections) con sus propios valores de suscripción.

  4. Guarde los cambios.

Script de ejemplo

Nota:

Este ejemplo está escrito para el shell de bash. Si quiere ejecutar este ejemplo en otro shell, como Windows PowerShell o el símbolo del sistema, es posible que deba realizar modificaciones en el script.

Antes de ejecutar este script de ejemplo, ejecute este comando para conectarse a Azure:


az login

A continuación, navegue hasta el directorio en el que creó la definición del flujo de trabajo. Por ejemplo, si ha creado el archivo JSON de definición del flujo de trabajo en el escritorio:


cd ~/Desktop

A continuación, ejecute este script para crear una aplicación lógica.


#!/bin/bash

# Create a resource group

az group create --name testResourceGroup --location westus

# Create your logic app

az logic workflow create --resource-group "testResourceGroup" --location "westus" --name "testLogicApp" --definition "testDefinition.json"

Limpieza de la implementación

Una vez que haya terminado de usar el script de ejemplo, ejecute el siguiente comando para quitar el grupo de recursos y todos sus recursos anidados, incluida la aplicación lógica.


az group delete --name testResourceGroup --yes

Explicación del script

Este script de ejemplo usa los siguientes comandos para crear un nuevo grupo de recursos y la aplicación lógica.

Get-Help Notas
az group create Crea un grupo de recursos en el que se almacenan los recursos de la aplicación lógica.
az logic workflow create Crea una aplicación lógica basada en el flujo de trabajo definido en el parámetro --definition.
az group delete Elimina un grupo de recursos y todos sus recursos anidados.

Pasos siguientes

Para más información sobre la CLI de Azure, consulte la documentación de la CLI de Azure.

Puede encontrar más ejemplos de scripts de la CLI de Logic Apps en el explorador de ejemplos de código de Microsoft.