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.
Note
This article is part of a tutorial series on creating and using custom connectors in Azure Logic Apps, Microsoft Power Automate and Microsoft Power Apps, and calling connectors as tools in Microsoft Copilot Studio. Make sure you read the custom connector overview to understand the process.
To create a custom connector, describe the API you want to connect to so the connector understands the API's actions and data structures. In this article, you create a custom connector using a Postman collection that describes the Cognitive Services Text Analytics Sentiment API (the example for this series).
For other ways to describe an API, go to the following topics:
Prerequisites
Check the prerequisites to make sure you have everything you need to create a custom connector. You need:
- A Postman collection that describes the example API. Follow the guidance in Create a Postman collection for a custom connector.
Note
Postman is one option for creating a collection, but you can also use other tools, like Insomnia, to create a collection for testing purposes. When creating a custom connector, the collection must be no larger than 1 MB.*
- An API key for the Cognitive Services Text Analytics API. 
- One of the following subscriptions: - Azure, if you're using Logic Apps
- Power Automate
- Power Apps
 
- If you're using Logic Apps, first create an Azure Logic Apps custom connector. 
Import the Postman collection
Now you're ready to use the Postman collection you created or downloaded. The collection has much of the required information. You can review and update this information as you go through the custom connector wizard. Start by importing the Postman collection for Logic Apps or for Power Automate and Power Apps.
Import the Postman collection for Logic Apps
- Go to the Azure portal, and open the Logic Apps connector you created earlier in Create an Azure Logic Apps custom connector. 
- In your connector's menu, choose Logic Apps Connector, then choose Edit.  
- Under General, choose Upload Postman collection V1, then navigate to the Postman collection that you created.  - The wizard imports the collection, then converts it to an OpenAPI definition named - generatedApiDefinition.swagger.json.
Note
This tutorial focuses on a REST API, but you can also use a SOAP API with Logic Apps.
Import the Postman collection for Power Automate and Power Apps
- Go to make.powerapps.com or flow.microsoft.com. 
- In the navigation pane, select More > Discover all 
- In the Data section, select Custom connectors. 
- Choose New custom connector, then choose Import a Postman collection. 
- Enter a name for the custom connector, then navigate to the Postman collection that you downloaded or created, and choose Continue.  - Parameter - Value - Custom connector title - "SentimentDemo" - The wizard imports the collection and converts it to an OpenAPI definition named - generatedApiDefinition.swagger.json.
Update general details
From this point, this article shows the Power Automate UI, but the steps are mostly the same across all three technologies. Differences are highlighted as needed.
- On the General page, review the information that was imported from the Postman collection, including the host and the base URL for the API. The connector uses the host and base URL to determine how to call the API. - Note - For more information about connecting to on-premises APIs, see Connect to on-premises APIs using the data gateway. 
- Update the description to something meaningful. This description appears in the custom connector's details and helps other users understand how your connector is useful. - Parameter - Value - Description - "Uses the Cognitive Services Text Analytics Sentiment API to determine whether text is positive or negative" 
Specify authentication type
Custom connectors support several authentication options. The Cognitive Services APIs use API key authentication.
- On the Security page, under Authentication type, choose API Key. 
- Under API Key, specify a parameter label, name, and location. Choose an expressive and meaningful label. This text will be displayed to users to direct them in making connections using your custom connector. The parameter name and location must match what the API expects (in this case the header you specified in Postman). Choose Connect.  - Parameter - Value - Parameter label - "API key" - Parameter name - "Ocp-Apim-Subscription-Key" - Parameter location - "Header" 
- At the top of the wizard, make sure the name is set to "SentimentDemo", then choose Create connector. 
Review and update the connector definition
The custom connector wizard offers many options for defining how your connector works and how it's exposed in logic apps, flows, apps, and agents. This section explains the UI and covers a few options, but you can explore more on your own.
Review the UI and definition
Before you follow the steps on the Definition page, review the UI.
- This area displays any actions, triggers (for Logic Apps and Power Automate), references, and policies that are defined for the connector. In this case, the - DetectSentimentaction from the Postman collection is displayed. There are no triggers in this connector, but you can learn about triggers for custom connectors in Use webhooks with Azure Logic Apps and Power Automate.
- The General area displays information about the action or trigger currently selected. This information comes from the Postman collection. You can edit the information here, including the Visibility property for operations and parameters in a logic app or flow: - important: always shown to the user first
- none: displayed normally in the logic app or flow
- advanced: initially hidden under an additional menu
- internal: not shown to the user
 
- The Request area displays information based on the HTTP request that's included in the Postman collection. In this case, you see that the HTTP verb is POST, and the URL is "/text/analytics/v2.0/sentiment" (the full URL to the API is - <https://westus.api.cognitive.microsoft.com//text/analytics/v2.0/sentiment>). You'll take a closer look at the body parameter shortly.
- The Response area displays information based on the HTTP response that's included in the Postman collection. In this case, the only response defined is for "200" (a successful response), but you can define additional responses. 
- The Validation area displays any issues that are detected in the API definition. Make sure to check this area before you save a connector. 
Update the definition
Now change a few settings to make the connector easier to use in a Logic App, Power Automate, or Power Apps.
- In the General area, update the summary to "Returns a numeric score representing the sentiment detected". 
- In the Request area, choose body then Edit. 
- In the Parameter area, you now see the three parameters that the API expects: - id,- language, and- text. Choose id then Edit.
- In the Schema Property area, update values for the parameter, then choose Back.  - Parameter - Value - Title - "ID" - Description - "An identifier for each document that you submit" - Default value - "1" - Is required - "Yes" 
- In the Parameter area, choose language then Edit, and repeat the process you used above with the following values. - Parameter - Value - Title - "Language" - Description - "The 2 or 4 character language code for the text" - Default value - "en" - Is required - "Yes" 
- In the Parameter area, choose text then Edit, and repeat the process you used above with the following values. - Parameter - Value - Title - "Text" - Description - "The text to analyze for sentiment" - Default value - None - Is required - "Yes" 
- In the Parameter area, choose Back to take you back to the main definition page. 
- At the top right of the wizard, choose Update connector. 
Test the connector
After you create the connector, test it to make sure it works correctly. Testing is available only in Power Automate and Power Apps.
Important
When you use an API key, wait a few minutes after creating the connector before testing it. The connector might not be ready to connect to the API right away.
- On the Test page, choose New connection. 
- Enter the API key from the Text Analytics API, then choose Create connection. 
- Return to the Test page: - In Power Automate, you are taken back to the Test page. Choose the refresh icon to make sure the connection information is updated.
- In Power Apps, you are taken to the list of connections available in the current environment. In the upper right corner, choose the gear icon, then choose Custom connectors. Choose the connector you created, then go back to the Test page.
 
- On the Test page, enter a value for the text field (the other fields use the defaults that you set earlier), then choose Test operation. 
- The connector calls the API, and you can review the response, which includes the sentiment score.  
Limitations
In Power Automate and Power Apps, if you update an existing custom connector using a Postman collection, you need to redo any previous customizations before saving the connector. For example, you need to reconfigure the authentication type and default values of the parameters for the actions.
Next steps
After you create a custom connector and define its behaviors, use the connector.
- Use a custom connector from a flow
- Use a custom connector from an app
- Use a custom connector from a logic app
You can also share a connector within your organization or get the connector certified so people outside your organization can use it.
Provide feedback
We greatly appreciate feedback on issues with our connector platform, or new feature ideas. To provide feedback, go to Submit issues or get help with connectors and select your feedback type.
