Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Important
The Azure OpenAI extension for Azure Functions is currently in preview.
The Azure OpenAI extension for Azure Functions implements a set of triggers and bindings that enable you to easily integrate features and behaviors of Azure OpenAI in Foundry Models into your function code executions.
Azure Functions is an event-driven compute service that provides a set of triggers and bindings to easily connect with other Azure services.
With the integration between Azure OpenAI and Functions, you can build functions that can:
| Action | Trigger/binding type | 
|---|---|
| Use a standard text prompt for content completion | Azure OpenAI text completion input binding | 
| Respond to an assistant request to call a function | Azure OpenAI assistant trigger | 
| Create an assistant | Azure OpenAI assistant create output binding | 
| Message an assistant | Azure OpenAI assistant post input binding | 
| Get assistant history | Azure OpenAI assistant query input binding | 
| Read text embeddings | Azure OpenAI embeddings input binding | 
| Write to a vector database | Azure OpenAI embeddings store output binding | 
| Read from a vector database | Azure OpenAI semantic search input binding | 
Install extension
The extension NuGet package you install depends on the C# mode in-process or isolated worker process you're using in your function app:
Add the Azure OpenAI extension to your project by installing the Microsoft.Azure.Functions.Worker.Extensions.OpenAI NuGet package, which you can do using the .NET CLI:
dotnet add package Microsoft.Azure.Functions.Worker.Extensions.OpenAI  --prerelease
When using a vector database for storing content, you should also install at least one of these NuGet packages:
- Azure AI Search: Microsoft.Azure.Functions.Worker.Extensions.OpenAI.AzureAISearch
- Azure Cosmos DB for MongoDB vCore: Microsoft.Azure.Functions.Worker.Extensions.OpenAI.CosmosDBSearch
- Azure Cosmos DB for NoSQL: Microsoft.Azure.Functions.Worker.Extensions.OpenAI.CosmosDBSearch
- Azure Data Explorer: Microsoft.Azure.Functions.Worker.Extensions.OpenAI.Kusto
Install bundle
To be able to use this preview binding extension in your app, you must reference a preview extension bundle that includes it.
Add or replace the following code in your host.json file, which specifically targets the latest preview version of the 4.x bundle:
{
  "version": "2.0",
  "extensionBundle": {
    "id": "Microsoft.Azure.Functions.ExtensionBundle.Preview",
    "version": "[4.0.0, 5.0.0)"
  }
}
Select the previous link to verify that the latest preview bundle version does contain the preview extension.
Connecting to OpenAI
To use the Azure OpenAI binding extension, you need to specify a connection to OpenAI. This connection is defined using application settings, and the AIConnectionName property of the trigger or binding. You can also use environment variables to define key-based connections.
We recommend that you use managed identity-based connections and the AIConnectionName property.
The OpenAI bindings have an AIConnectionName property that you can use to specify the <ConnectionNamePrefix> for this group of app settings that define the connection to Azure OpenAI:
| Setting name | Description | 
|---|---|
| <CONNECTION_NAME_PREFIX>__endpoint | Sets the URI endpoint of the Azure OpenAI in Foundry Models. This setting is always required. | 
| <CONNECTION_NAME_PREFIX>__clientId | Sets the specific user-assigned identity to use when obtaining an access token. Requires that <CONNECTION_NAME_PREFIX>__credentialis set tomanagedidentity. The property accepts a client ID corresponding to a user-assigned identity assigned to the application. It's invalid to specify both a Resource ID and a client ID. If not specified, the system-assigned identity is used. This property is used differently in local development scenarios, whencredentialshouldn't be set. | 
| <CONNECTION_NAME_PREFIX>__credential | Defines how an access token is obtained for the connection. Use managedidentityfor managed identity authentication. This value is only valid when a managed identity is available in the hosting environment. | 
| <CONNECTION_NAME_PREFIX>__managedIdentityResourceId | When credentialis set tomanagedidentity, this property can be set to specify the resource Identifier to be used when obtaining a token. The property accepts a resource identifier corresponding to the resource ID of the user-defined managed identity. It's invalid to specify both a resource ID and a client ID. If neither are specified, the system-assigned identity is used. This property is used differently in local development scenarios, whencredentialshouldn't be set. | 
| <CONNECTION_NAME_PREFIX>__key | Sets the shared secret key required to access the endpoint of Azure OpenAI using key-based authentication. As a security best practice, you should always use Microsoft Entra ID with managed identities for authentication. | 
Consider these managed identity connection settings when then AIConnectionName property is set to myAzureOpenAI:
- myAzureOpenAI__endpoint=https://contoso.openai.azure.com/
- myAzureOpenAI__credential=managedidentity
- myAzureOpenAI__clientId=aaaaaaaa-bbbb-cccc-1111-222222222222
At runtime, these settings are collectively interpreted by the host as a single myAzureOpenAI setting like this:
"myAzureOpenAI":
{
    "endpoint": "https://contoso.openai.azure.com/",
    "credential": "managedidentity",
    "clientId": "aaaaaaaa-bbbb-cccc-1111-222222222222"
}
When using managed identities, make sure to add your identity to the Cognitive Services OpenAI User role.
When running locally, you must add these settings to the local.settings.json project file. For more information, see Local development with identity-based connections.
For more information, see Work with application settings.