Kye
a4a7ec44de
|
2 years ago | |
---|---|---|
.. | ||
README.md | 2 years ago | |
__init__.py | 2 years ago | |
agent_tools.py | 2 years ago | |
main.py | 2 years ago |
README.md
Here are 20 tools the individual worker swarm nodes can use:
- Write File Tool: Create a new file and write content to it.
- Read File Tool: Open and read the content of an existing file.
- Copy File Tool: Duplicate a file.
- Delete File Tool: Remove a file.
- Rename File Tool: Rename a file.
- Web Search Tool: Use a web search engine (like Google or DuckDuckGo) to find information.
- API Call Tool: Make requests to APIs.
- Process CSV Tool: Load a CSV file and perform operations on it using pandas.
- Create Directory Tool: Create a new directory.
- List Directory Tool: List all the files in a directory.
- Install Package Tool: Install Python packages using pip.
- Code Compilation Tool: Compile and run code in different languages.
- System Command Tool: Execute system commands.
- Image Processing Tool: Perform operations on images (resizing, cropping, etc.).
- PDF Processing Tool: Read, write, and manipulate PDF files.
- Text Processing Tool: Perform text processing operations like tokenization, stemming, etc.
- Email Sending Tool: Send emails.
- Database Query Tool: Execute SQL queries on a database.
- Data Scraping Tool: Scrape data from web pages.
- Version Control Tool: Perform Git operations.
The architecture for these tools involves creating a base Tool
class that can be extended for each specific tool. The base Tool
class would define common properties and methods that all tools would use.
The pseudocode for each tool would follow a similar structure:
Class ToolNameTool extends Tool:
Define properties specific to the tool
Method run:
Perform the specific action of the tool
Return the result
Here's an example of how you might define the WriteFileTool:
import os
from langchain.tools import BaseTool
class WriteFileTool(BaseTool):
name = "write_file"
description = "Create a new file and write content to it."
def __init__(self, root_dir: str):
self.root_dir = root_dir
def _run(self, file_name: str, content: str) -> str:
"""Creates a new file and writes the content."""
try:
with open(os.path.join(self.root_dir, file_name), 'w') as f:
f.write(content)
return f"Successfully wrote to {file_name}"
except Exception as e:
return f"Error: {e}"
This tool takes the name of the file and the content to be written as parameters, writes the content to the file in the specified directory, and returns a success message. In case of any error, it returns the error message. You would follow a similar process to create the other tools.
For completing browser-based tasks, you can use web automation tools. These tools allow you to interact with browsers as if a human user was interacting with it. Here are 20 tasks that individual worker swarm nodes can handle:
- Open Browser Tool: Open a web browser.
- Close Browser Tool: Close the web browser.
- Navigate To URL Tool: Navigate to a specific URL.
- Fill Form Tool: Fill in a web form with provided data.
- Submit Form Tool: Submit a filled form.
- Click Button Tool: Click a button on a webpage.
- Hover Over Element Tool: Hover over a specific element on a webpage.
- Scroll Page Tool: Scroll up or down a webpage.
- Navigate Back Tool: Navigate back to the previous page.
- Navigate Forward Tool: Navigate forward to the next page.
- Refresh Page Tool: Refresh the current page.
- Switch Tab Tool: Switch between tabs in a browser.
- Capture Screenshot Tool: Capture a screenshot of the current page.
- Download File Tool: Download a file from a webpage.
- Send Email Tool: Send an email using a web-based email service.
- Login Tool: Log in to a website using provided credentials.
- Search Website Tool: Perform a search on a website.
- Extract Text Tool: Extract text from a webpage.
- Extract Image Tool: Extract image(s) from a webpage.
- Browser Session Management Tool: Handle creation, usage, and deletion of browser sessions.
You would typically use a library like Selenium, Puppeteer, or Playwright to automate these tasks. Here's an example of how you might define the FillFormTool using Selenium in Python:
from selenium import webdriver
from langchain.tools import BaseTool
class FillFormTool(BaseTool):
name = "fill_form"
description = "Fill in a web form with provided data."
def _run(self, field_dict: dict) -> str:
"""Fills a web form with the data in field_dict."""
try:
driver = webdriver.Firefox()
for field_name, field_value in field_dict.items():
element = driver.find_element_by_name(field_name)
element.send_keys(field_value)
return "Form filled successfully."
except Exception as e:
return f"Error: {e}"
In this tool, field_dict
is a dictionary where the keys are the names of the form fields and the values are the data to be filled in each field. The tool finds each field in the form and fills it with the provided data.
Please note that in a real scenario, you would need to handle the browser driver session more carefully (like closing the driver when it's not needed anymore), and also handle waiting for the page to load and exceptions more thoroughly. This is a simplified example for illustrative purposes.