PUT
/
api
/
v1
/
tools
import os
import syllable_sdk
from syllable_sdk import SyllableSDK


with SyllableSDK(
    api_key_header=os.getenv("SYLLABLESDK_API_KEY_HEADER", ""),
) as ss_client:

    res = ss_client.tools.update(request={
        "name": "Weather Fetcher",
        "definition": {
            "type": syllable_sdk.Type.ENDPOINT,
            "tool": {
                "type": "function",
                "function": {
                    "name": "get_weather",
                    "description": "Get the weather for a city",
                    "parameters": {

                    },
                },
            },
            "endpoint": {
                "url": "https://api.example.com",
                "method": syllable_sdk.ToolHTTPMethod.POST,
                "argument_location": syllable_sdk.ToolArgumentLocation.PATH,
            },
            "defaults": "<value>",
            "static_parameters": [
                {
                    "name": "temperature_unit",
                    "description": "Whether the temperature information should be fetched in celsius or fahrenheit.",
                    "required": True,
                    "type": syllable_sdk.StaticToolParameterType.STRING,
                    "default": "fahrenheit",
                },
            ],
        },
        "service_id": 1,
        "id": 1,
        "last_updated_comments": "Updated to use new API endpoint",
    })

    # Handle response
    print(res)
{
  "name": "Weather Fetcher",
  "definition": {
    "endpoint": {
      "argument_location": "query",
      "method": "get",
      "url": "https://api.open-meteo.com/v1/forecast"
    },
    "tool": {
      "function": {
        "description": "Get the weather for a city",
        "name": "get_weather",
        "parameters": {
          "properties": {
            "latitude": {
              "description": "Latitude of the city",
              "type": "number"
            },
            "longitude": {
              "description": "Longitude of the city",
              "type": "number"
            },
            "current": {
              "default": "temperature_2m,relative_humidity_2m,precipitation,rain,showers",
              "description": "Information to retrieve from the open-meteo API, comma-separated",
              "type": "string"
            }
          },
          "required": [
            "latitude",
            "longitude",
            "current"
          ],
          "type": "object"
        }
      },
      "type": "function"
    },
    "type": "endpoint"
  },
  "service_id": 1,
  "id": 1,
  "last_updated_comments": "Updated to use new API endpoint",
  "service_name": "<string>",
  "prompts_info": [
    {
      "id": 1,
      "name": "Test Prompt"
    }
  ],
  "agents_info": [
    {
      "id": 1,
      "name": "Test Agent"
    }
  ],
  "last_updated": "2023-11-07T05:31:56Z",
  "last_updated_by": "user@email.com"
}

Authorizations

Syllable-API-Key
string
header
required

Body

application/json

Request model to update an existing tool.

name
string
required

The name of the tool

Example:

"Weather Fetcher"

definition
object
required

The definition of the tool

service_id
integer
required

Internal ID of the service to which the tool belongs

Example:

1

id
integer
required

The internal ID of the tool

Example:

1

last_updated_comments
string | null

Comments for the most recent edit to the tool.

Example:

"Updated to use new API endpoint"

Response

200
application/json
Successful Response

Response model for tool operations. A tool is a function that an agent can call to perform actions like accessing databases, making API calls, or processing data. For an agent to have access to a tool, the prompt associated with that agent should be linked to the tool and include instructions to use it. For more information, see Console docs.

name
string
required

The name of the tool

Example:

"Weather Fetcher"

definition
object
required

The definition of the tool

service_id
integer
required

Internal ID of the service to which the tool belongs

Example:

1

id
integer
required

The internal ID of the tool

Example:

1

last_updated
string
required

The timestamp of the most recent update to the service

last_updated_by
string
required

The email of the user who last updated the tool

Example:

"user@email.com"

last_updated_comments
string | null

Comments for the most recent edit to the tool.

Example:

"Updated to use new API endpoint"

service_name
string | null

The name of the service to which the tool belongs

prompts_info
object[] | null

IDs and names of the prompts linked to the tool

Information about a prompt linked to a tool.

agents_info
object[] | null

IDs and names of the agents linked to the tool via a prompt

Information about an agent linked to a tool via a prompt.