Edit

Share via


Connect to Azure AI services from workflows in Azure Logic Apps

Applies to: Azure Logic Apps (Consumption + Standard)

To integrate enterprise services, systems, and data with AI technologies, your logic app workflows can connect to Azure OpenAI and Azure AI Search resources that you use for these integration scenarios.

This guide provides an overview and examples that show how to use Azure OpenAI and Azure AI Search connector operations in your workflow.

Why use Azure Logic Apps with AI services?

Usually, building AI solutions involves several key steps and requires a few building blocks. Primarily, you need to have a dynamic ingestion pipeline and a chat interface that can communicate with large language models (LLMs) and vector databases.

Tip

To learn more, you can ask Azure Copilot these questions:

  • What is a dynamic ingestion pipeline in AI?
  • What is a vector database in AI?

To find Azure Copilot, on the Azure portal toolbar, select Copilot.

You can assemble various components, not only to perform data ingestion but also to provide a robust backend for the chat interface. This backend facilitates entering prompts and generates dependable responses during interactions. However, creating the code to manage and control all these elements can pose challenges, which is the case for most solutions.

Azure Logic Apps offers a low code approach and simplifies backend management by providing prebuilt connectors that you use as building blocks to streamline the backend process. This approach lets you focus on sourcing your data and making sure that search results provide current and relevant information. With these AI connectors, your workflow acts as an orchestration engine that transfers data between AI services and other components that you want to integrate.

For more information, see the following resources:

Prerequisites

  • An Azure account and subscription. If you don't have an Azure subscription, sign up for a free Azure account.

  • The Azure AI Search and Azure OpenAI resources to access and use in your workflow, including connection information:

  • A logic app workflow where you want to access your Azure OpenAI and Azure AI Search resources.

    The connectors for these services currently provide only actions, not triggers. Before you can add an Azure AI connector action, make sure your workflow starts with the appropriate trigger for your scenario.

Connector technical reference

The following sections specify the connector reference articles that describe the connection parameters and operation parameters for each connector. If any operations in these connectors show the "Preview" label, they're currently in preview and subject to the Supplemental Terms of Use for Microsoft Azure Previews.

Azure OpenAI

Azure OpenAI Service provides access to OpenAI's language models, for example, GPT-5, GPT-4, GPT-4 Turbo with Vision, GPT-3.5-Turbo, and the Embeddings model series. With the Azure OpenAI connector, your workflow can connect to Azure OpenAI Service and get OpenAI embeddings for your data or generate chat completions.

The Azure OpenAI connector has different versions, based on logic app type and hosting model:

Logic app Environment Connector version
Consumption Multitenant Azure Logic Apps Managed, Azure-hosted connector, which appears in the connector gallery under the Shared filter.

For more information, see Azure OpenAI managed connector reference.
Standard Single-tenant Azure Logic Apps, App Service Environment v3 (Windows plans only), or hybrid deployment, which is your own infrastructure. Built-in connector, which appears in the connector gallery under the Built-in filter and is service provider-based. The built-in connector has the following capabilities among others:

- Multiple authentication type support

- Direct access to resources in Azure virtual networks and endpoints for Azure OpenAI behind firewalls.

For more information, see Azure OpenAI built-in connector reference.

Tip

To learn more, you can ask Azure Copilot these questions:

  • What is an embedding in AI?
  • What is a chat completion in AI?

To find Azure Copilot, on the Azure portal toolbar, select Copilot.

Azure AI Search is platform for AI-powered information retrieval that helps developers build rich search experiences and generative AI apps by combining large language models with enterprise data. With the Azure AI Search connector, your workflow can connect to Azure AI Search to index documents and perform vector searches on your data.

The Azure AI Search connector has different versions, based on logic app type and hosting model:

Logic app Environment Connector version
Consumption Multitenant Azure Logic Apps Managed, Azure-hosted connector, which appears in the connector gallery under the Shared filter.

For more information, see Azure AI Search managed connector reference.
Standard Single-tenant Azure Logic Apps, App Service Environment v3 (Windows plans only), or hybrid deployment, which is your own infrastructure. Built-in connector, which appears in the connector gallery under the Built-in filter and is service provider-based. The built-in connector has the following capabilities among others:

- Multiple authentication type support

- Direct access to resources in Azure virtual networks and endpoints for Azure OpenAI behind firewalls.

For more information, see Azure AI Search built-in connector reference.

Authentication

The AI managed connectors require an API key for authentication. However, the AI built-in connectors support multiple authentication types for your AI service endpoint. These options provide robust authentication that meets most customers' needs. Both built-in connectors can also directly connect to Azure OpenAI and Azure AI Search resources inside virtual networks or behind firewalls.

The following table describes the built-in connector authentication options, all which require that you provide the URL for the AI service endpoint:

Authentication type Description
URL and key-based authentication Provide the API key or admin generated by the AI service.
Active Directory OAuth (Microsoft Entra ID) Provide information such as your Entra tenant, client ID, and password to authenticate as an Entra user.
Managed identity After you set up managed identity authentication on your AI service resource and your logic app resource, you can use that identity to authenticate access for the connector.

Warning

Always secure and protect sensitive and personal data, such as credentials, secrets, access keys, connection strings, certificates, thumbprints, and similar information with the highest available or supported level of security.

For authentication and authorization, set up or use Microsoft Entra ID with a managed identity. This solution provides optimal and superior security without you having to manually provide and manage credentials, secrets, access keys, and so on because Azure handles the managed identity for you. To set up a managed identity for Azure Logic Apps, see Authenticate access and connections to Azure resources with managed identities in Azure Logic Apps.

If you can't use a managed identity, choose the next highest level security solution available. For example, if you must use a connection string, which includes information required to access a resource, service, or system, remember that this string includes an access key that is similar to a root password.

Make sure that you securely store such information by using Microsoft Entra ID and Azure Key Vault. Don't hardcode this information, share with other users, or save in plain text anywhere that others can access. Set up a plan to rotate or revoke secrets in the case they become compromised. For more information, see the following resources:

For more information, see the following resources:

Add an Azure OpenAI or Azure AI Search action to your workflow

Currently, the connectors for Azure OpenAI and Azure AI Search provide only actions, not triggers. You can start your workflow with any trigger that fits your scenario or needs. Based on whether you have a Consumption or Standard workflow, you can then follow these general steps to add actions for Azure OpenAI, Azure AI Search, and other operations.

Scenarios

The following scenarios describe only two of the many ways that you can use AI connector operations in your workflows:

Create a knowledge base for your enterprise data

Azure Logic Apps provides over 1,400 Microsoft-managed connectors and natively running built-in connectors for your workflow to securely connect with almost any data source, such as SharePoint, Oracle DB, Salesforce, OneDrive, Dropbox, SAP, IBM, and so on. Each connector provides operations, which include triggers, actions, or both, for you to use in your workflow.

For example, you can select from many trigger types to make your automated workflow run on a schedule or based on specific events, such as the uploading of new documents to a SharePoint site. With so many operations for you to choose, you can create a knowledge base and easily build a document ingestion pipeline using vector embeddings for these documents in Azure AI Search.

For more information, see the following resources:

Generate completions

An Azure Logic Apps workflow can accept input, while Azure OpenAI Service can perform completion operations. These capabilities mean that your workflow can ingest real-time questions, generate answers about your data, or send automated responses using Azure OpenAI. You can immediately send the responses back to the client or to an approval workflow for verification.

For more information, see the following resources:

Example scenario with sample code: Ingest data and create chat interactions

This Standard workflow example shows how to use the Azure OpenAI and Azure AI Search built-in connectors to break down the backend logic for ingesting data and conducting simple chat conversations into two key workflows. For faster performance, create stateless workflows that, by default, don't save and store the history for each run.

Sample code

Create a chat using ingested data

Other prerequisites

  • A Standard logic app workflow

  • See the sample code requirements.

  • The following cross-environment parameter values are also used by the workflow operations in this example:

    Parameter name Description
    aisearch_admin_key The admin key for Azure AI Search
    aisearch_endpoint The endpoint URL for the Azure AI Search example
    aisearch_index_name The index to use for the Azure AI Search example
    openapi_api_key The API key for Azure OpenAI
    openai_deployment_id The deployment ID for the Azure OpenAI example
    openai_endpoint The endpoint URL for the Azure OpenAI example
    tokenize_function_url The URL for a custom Azure function that batches and tokenizes data, which is required for Azure OpenAI to properly create embeddings for this example.

    For more information about this function, see the sample code for "Create a chat using ingested data".

Video: Learn how to build AI applications using logic apps

Learn how to build AI applications using logic apps

Ingest data workflow

To save considerable time and effort when you build an ingestion pipeline, implement the following pattern with any data source. This pattern encapsulates all the advantages and benefits currently offered by Standard workflows in single-tenant Azure Logic Apps.

Each step in this pattern makes sure that the AI seamlessly extracts all the crucial information from your data files. If run as a stateless workflow, this pattern also provides faster performance. This approach simplifies not only the coding aspect but also guarantees that your workflows have effective authentication, monitoring, and deployment processes in place.

Screenshot shows Azure portal, Standard workflow designer, and workflow operations that implement data ingestion functionality.

Step Task Underlying operation Description
1 Check for new data. When an HTTP request is received A trigger that either polls or waits for new data to arrive, either based on a scheduled recurrence or in response to specific events respectively. Such an event might be a new file that's uploaded to a specific storage system, such as SharePoint, OneDrive, or Azure Blob Storage.

In this example, the Request trigger operation waits for an HTTP or HTTPS request sent from another endpoint. The request includes the URL for a new uploaded document.
2 Get the data. HTTP An HTTP action that retrieves the uploaded document using the file URL from the trigger output.
3 Compose document details. Compose A Data Operations action that concatenates various items.

This example concatenates key-value information about the document.
4 Create token string. Parse a document A Data Operations action that produces a token string using the output from the Compose action.
5 Create content chunks. Chunk text A Data Operations action that splits the token string into pieces, based on either the number of characters or tokens per content chunk.
6 Convert tokenized data to JSON. Parse JSON A Data Operations action that converts the token string chunks into a JSON array.
7 Select JSON array items. Select A Data Operations action that selects multiple items from the JSON array.
8 Generate the embeddings. Get multiple embeddings An Azure OpenAI action that creates embeddings for each JSON array item.
9 Select embeddings and other information. Select A Data Operations action that selects embeddings and other document information.
10 Index the data. Index documents An Azure AI Search action that indexes the data based on each selected embedding.

Chat workflow

As your vector databases continue to ingest data, make sure the data is easily searchable so that when a user asks a question, the backend Standard logic app workflow can process the prompt and generate a reliable response.

The following pattern is only one example that shows how a chat workflow might look:

Screenshot shows Azure portal, Standard workflow designer, and workflow operations that implement a chat interaction.

Step Task Underlying operation Description
1 Wait for input prompt. When an HTTP request is received A trigger that either polls or waits for new data to arrive, either based on a scheduled recurrence or in response to specific events respectively.

In this example, the Request trigger waits for and captures the customer's question.
2 Input system message for the model. Compose A Data Operations action that provides input to train the model.
3 Input sample questions and responses. Compose A Data Operations action that provides sample customer questions and associated roles to train the model.
4 Input system message for search query. Compose A Data Operations action that provides search query input to train the model.
5 Generate search query. Execute JavaScript Code An Inline Code action that uses JavaScript to create a search query for the vector store, based on the outputs from the preceding Compose actions.
6 Convert query to embedding. Get chat completions An Azure OpenAI action that connects to the chat completion API, which guarantees reliable responses in chat conversations.

In this example, the action accepts search queries and roles as input to the model and returns vector embeddings as output.
7 Get an embedding. Get an embedding An Azure OpenAI action that gets a single vector embedding.
8 Search the vector database. Search vectors An Azure AI Search action that executes searches in the vector store.
9 Create prompt. Execute JavaScript Code An Inline Code action that uses JavaScript to build prompts.
10 Perform chat completion. Get chat completions An Azure OpenAI action that connects to the chat completion API, which guarantees reliable responses in chat conversations.

In this example, the action accepts prompts and roles as input to the model and returns model-generated responses as output.
11 Return a response. Response A Request action that returns the results to the caller when you use the Request trigger.