dify/api/core/tools
liuhaoran 570f10d91c
fix issues:Image file not deleted when a doc is removed #9541 (#10465)
Signed-off-by: root <root@localhost.localdomain>
Co-authored-by: root <root@localhost.localdomain>
2024-11-11 21:43:37 +08:00
..
docs docs: Add Japanese documentation for tools (#8469) 2024-09-22 09:04:00 +08:00
entities fix(tools): remove the undefined variable parameter_type (#9908) 2024-10-27 11:56:29 +08:00
provider chore (vanna): update form parameter from 'form' to 'llm' in vanna.yaml (#10488) 2024-11-11 16:41:47 +08:00
tool feat/enhance the multi-modal support (#8818) 2024-10-21 10:43:49 +08:00
utils fix issues:Image file not deleted when a doc is removed #9541 (#10465) 2024-11-11 21:43:37 +08:00
__init__.py improve: generalize tool parameter converter (#4786) 2024-06-03 21:26:58 +08:00
errors.py chore(api/core): apply ruff reformatting (#7624) 2024-09-10 17:00:20 +08:00
README_CN.md docs: Add Japanese documentation for tools (#8469) 2024-09-22 09:04:00 +08:00
README_JP.md docs: Add Japanese documentation for tools (#8469) 2024-09-22 09:04:00 +08:00
README.md docs: Add Japanese documentation for tools (#8469) 2024-09-22 09:04:00 +08:00
tool_engine.py feat/enhance the multi-modal support (#8818) 2024-10-21 10:43:49 +08:00
tool_file_manager.py chore(lint): Use logging.exception instead of logging.error (#10415) 2024-11-07 21:13:02 +08:00
tool_label_manager.py chore(api/core): apply ruff reformatting (#7624) 2024-09-10 17:00:20 +08:00
tool_manager.py chore(lint): Use logging.exception instead of logging.error (#10415) 2024-11-07 21:13:02 +08:00

Tools

This module implements built-in tools used in Agent Assistants and Workflows within Dify. You could define and display your own tools in this module, without modifying the frontend logic. This decoupling allows for easier horizontal scaling of Dify's capabilities.

Feature Introduction

The tools provided for Agents and Workflows are currently divided into two categories:

  • Built-in Tools are internally implemented within our product and are hardcoded for use in Agents and Workflows.
  • Api-Based Tools leverage third-party APIs for implementation. You don't need to code to integrate these -- simply provide interface definitions in formats like OpenAPI , Swagger, or the OpenAI-plugin on the front-end.

Built-in Tool Providers

Alt text

API Tool Providers

Alt text

Tool Integration

To enable developers to build flexible and powerful tools, we provide two guides:

Quick Integration 👈🏻

Quick integration aims at quickly getting you up to speed with tool integration by walking over an example Google Search tool.

Advanced Integration 👈🏻

Advanced integration will offer a deeper dive into the module interfaces, and explain how to implement more complex capabilities, such as generating images, combining multiple tools, and managing the flow of parameters, images, and files between different tools.