-
Notifications
You must be signed in to change notification settings - Fork 508
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add connector tool #7384
Add connector tool #7384
Changes from 4 commits
6e5120d
28e7127
be603ad
1bc04d1
57df6da
f3f35ac
7b0d718
d829054
313552d
b2b79dc
e82d658
5001ec2
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,168 @@ | ||
--- | ||
layout: default | ||
title: Connector tool | ||
has_children: false | ||
has_toc: false | ||
nav_order: 20 | ||
parent: Tools | ||
grand_parent: Agents and tools | ||
--- | ||
|
||
<!-- vale off --> | ||
# Connector tool | ||
**Introduced 2.15** | ||
{: .label .label-purple } | ||
<!-- vale on --> | ||
|
||
The `ConnectorTool` uses a [connector]({{site.url}}{{site.baseurl}}/ml-commons-plugin/remote-models/connectors/) to call any REST API function. For example, you can use a `ConnectorTool` to call a Lambda function through its REST API interface. | ||
|
||
## Step 1: Register a connector with an execute action | ||
|
||
The `ConnectorTool` can only run an `execute` action within a connector. Before you can create a `ConnectorTool`, configure a connector and provide an `execute` action in the `actions` array. The `execute` action is used to invoke a function at a REST API endpoint. It is similar to the `predict` action, which is used to invoke a machine learning (ML) model. | ||
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
For this example, you'll create a connector for a simple AWS Lambda function that accepts two integers and returns their sum. This function is hosted on a dedicated endpoint with a specific URL, which you'll provide in the `url` parameter. For more information, see [Lambda function URLs](https://docs.aws.amazon.com/lambda/latest/dg/lambda-urls.html). | ||
|
||
To create a connector, send the following request: | ||
|
||
```json | ||
POST _plugins/_ml/connectors/_create | ||
{ | ||
"name": "Lambda connector of simple calculator", | ||
"description": "Demo connector of lambda function", | ||
"version": 1, | ||
"protocol": "aws_sigv4", | ||
"parameters": { | ||
"region": "YOUR AWS REGION", | ||
"service_name": "lambda" | ||
}, | ||
"credential": { | ||
"access_key": "YOUR ACCESS KEY", | ||
"secret_key": "YOUR SECRET KEY", | ||
"session_token": "YOUR SESSION TOKEN" | ||
}, | ||
"actions": [ | ||
{ | ||
"action_type": "execute", | ||
"method": "POST", | ||
"url": "YOUR LAMBDA FUNCTION URL", | ||
"headers": { | ||
"content-type": "application/json" | ||
}, | ||
"request_body": "{ \"number1\":\"${parameters.number1}\", \"number2\":\"${parameters.number2}\" }" | ||
} | ||
] | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
OpenSearch responds with a connector ID: | ||
|
||
```json | ||
{ | ||
"connector_id": "Zz1XEJABXWrLmr4mewEF" | ||
} | ||
``` | ||
|
||
## Step 2: Register a flow agent that will run the ConnectorTool | ||
|
||
For this example, the Lambda function adds the two input numbers and returns their sum in the `result` field: | ||
|
||
```json | ||
{ | ||
"result": 5 | ||
} | ||
``` | ||
|
||
By default, the `ConnectorTool` expects the response from the Lambda function to contain a field named `response`. However, in this example the Lambda function response doesn't include a `response` field. To retrieve the result from the `result` field instead, you need to provide a `response_filter`, specifying the dot path to the `result` field (`$.result`). Using the `response_filter`, the `ConnectorTool` will retrieve the result from the `result` field of the Lambda function response and return it in the OpenSearch response. | ||
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
To configure running the Lambda function, create a flow agent. A flow agent runs a sequence of tools in order and returns the last tool's output. To create a flow agent, send the following register agent request, providing the connector ID from the previous step and a response filter: | ||
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
```json | ||
POST /_plugins/_ml/agents/_register | ||
{ | ||
"name": "Demo agent of Lambda connector", | ||
"type": "flow", | ||
"description": "This is a demo agent", | ||
"app_type": "demo", | ||
"tools": [ | ||
{ | ||
"type": "ConnectorTool", | ||
"name": "lambda_function", | ||
"parameters": { | ||
"connector_id": "YOUR CONNECTOR ID", | ||
"response_filter": "$.result" | ||
} | ||
} | ||
] | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
For parameter descriptions, see [Register parameters](#register-parameters). | ||
|
||
OpenSearch responds with an agent ID: | ||
|
||
```json | ||
{ | ||
"agent_id": "az1XEJABXWrLmr4miAFj" | ||
} | ||
``` | ||
|
||
## Step 3: Run the agent | ||
|
||
Then, run the agent by sending the following request: | ||
|
||
```json | ||
POST /_plugins/_ml/agents/9X7xWI0Bpc3sThaJdY9i/_execute | ||
{ | ||
"parameters": { | ||
"number1": 2, | ||
"number2": 3 | ||
} | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
OpenSearch returns the output of the Lambda function run. In the output, the field name is `response`, and the `result` field contains the Lambda function result: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. "run" => "execution"?
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
```json | ||
{ | ||
"inference_results": [ | ||
{ | ||
"output": [ | ||
{ | ||
"name": "response", | ||
"result": 5 | ||
} | ||
] | ||
} | ||
] | ||
} | ||
``` | ||
|
||
## Register parameters | ||
|
||
The following table lists all tool parameters that are available when registering an agent. | ||
|
||
Parameter | Type | Required/Optional | Description | ||
:--- | :--- | :--- | :--- | ||
`connector_id` | String | Required | A connector ID of a connector configured with an `execute` action that invokes an API. | ||
`response_filter` | String | Optional | A JSON dot path to the response field that contains the result of invoking the API. | ||
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Execute parameters | ||
|
||
When running the agent, you can define any parameter needed for the API call in the `request_body` of your connector's `execute` action. In this example, the parameters are `number1` and `number2`: | ||
|
||
```json | ||
"actions": [ | ||
{ | ||
"action_type": "execute", | ||
"method": "POST", | ||
"url": "YOUR LAMBDA FUNCTION URL", | ||
"headers": { | ||
"content-type": "application/json" | ||
}, | ||
"request_body": "{ \"number1\":\"${parameters.number1}\", \"number2\":\"${parameters.number2}\" }" | ||
} | ||
] | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -33,6 +33,7 @@ Each tool takes a list of parameters specific to that tool. In the preceding exa | |
|:--- |:--- | | ||
|[`AgentTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/agent-tool/) |Runs any agent. | | ||
|[`CatIndexTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/cat-index-tool/) |Retrieves index information for the OpenSearch cluster. | | ||
|[`ConnectorTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/connector-tool/) |Run execute action in connector. | | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. "Runs the execute action in a connector"? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Reworded.
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|[`IndexMappingTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/index-mapping-tool/) |Retrieves index mapping and setting information for an index. | | ||
|[`MLModelTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/ml-model-tool/) |Runs machine learning models. | | ||
|[`NeuralSparseSearchTool`]({{site.url}}{{site.baseurl}}/ml-commons-plugin/agents-tools/tools/neural-sparse-tool/) | Performs sparse vector retrieval. | | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -74,7 +74,7 @@ The `actions` parameter supports the following options. | |
|
||
| Field | Data type | Description | | ||
|:---|:---|:---| | ||
| `action_type` | String | Required. Sets the ML Commons API operation to use upon connection. As of OpenSearch 2.9, only `predict` is supported. | | ||
| `action_type` | String | Required. Sets the ML Commons API operation to use upon connection. Valid values are `predict` (to invoke an externally hosted model) and `execute` (to invoke any REST API function). | | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The
kolchfa-aws marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| `method` | String | Required. Defines the HTTP method for the API call. Supports `POST` and `GET`. | | ||
| `url` | String | Required. Sets the connection endpoint at which the action occurs. This must match the regex expression for the connection used when [adding trusted endpoints]({{site.url}}{{site.baseurl}}/ml-commons-plugin/remote-models/index#adding-trusted-endpoints). | | ||
| `headers` | JSON object | Sets the headers used inside the request or response body. Default is `ContentType: application/json`. If your third-party ML tool requires access control, define the required `credential` parameters in the `headers` parameter. | | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this refers to an AWS Lambda, function, we should use the full service name here and just "Lambda" thereafter.