OpenBra.in agent creation and tuning Gradio deployment.
Project description
ob-tuner
Introduction
ob-tuner is a user-friendly, interactive GUI interface for creating, testing, and managing AI agents for OpenBrain. It provides a Gradio-based interface for users to create and fine-tune agent configurations and test various setups. The ob-tuner UI aims to simplify the process of working with AI agents by providing a comprehensive toolset for developers and researchers.
Your AI Agents will use tools, such as access to your CRM's API, to funnel leads into your campaigns. This UI gives you a place to tweak parameters of your agents (temperature, mode, tools, etc.), store the keys for any tools that require authentication, and test the agents in real-time.
Features
- Interactive GUI: Easily create, modify, and test agent configurations using a web-based interface powered by Gradio.
- Real-time Testing: Test your agent configurations in real-time and see immediate feedback on changes.
- Configuration Management: Save, load, and manage different agent configurations using DynamoDB.
Using ob-tuner
Agent Configuration
In the ob-tuner interface, you can create and modify agent configurations. These configurations can be saved to your DynamoDB tables in AWS, allowing you to reference them in any AWS workflow using the boto3 library.
Testing and Tuning
Use the interactive interface to test different configurations and fine-tune agent parameters. The interface provides real-time feedback, making it easy to see the effects of your changes immediately.
Procedures
Before Deploying
-
Ensure AWSServiceRoleForElasticBeanstalk Exists:
- Verify that the
AWSServiceRoleForElasticBeanstalk
exists in your roles. If it does not exist, create it using the AWS Management Console. The UI will guide you to create the role correctly without needing to fill in the name, trust relationship, or policy document.
- Verify that the
-
Register with Cognito:
- Register with Amazon Cognito and obtain a
client_id
andclient_secret
for the OAuth2 client. You will need to provide yourcallback_url
during this process.
- Register with Amazon Cognito and obtain a
-
Create a Route53 Record for Your Base Domain:
- Create a Route 53 record for your base domain. This requires a root A record in the root domain. For example, set
openbra.in
with anA
record pointing to your EBS endpoint.
- Create a Route 53 record for your base domain. This requires a root A record in the root domain. For example, set
-
Create a Custom Domain in Cognito:
- Set up a custom domain in your Cognito user pool. Ensure the Route 53 record above is created first before proceeding with this step.
-
Create an ACM Certificate:
- Create a certificate in AWS Certificate Manager (ACM) for the custom domain.
-
Create an SSH Key Pair:
- Generate an SSH key pair and store the private key in a secure location. Use the key pair name in the
ec2_key_name
parameter.
- Generate an SSH key pair and store the private key in a secure location. Use the key pair name in the
-
Add EBS Admin Access:
- Ensure that Elastic Beanstalk has the necessary administrative access.
After Deploying
-
Create a Route 53 Record Set:
- Create a Route 53 record set pointing your callback URL domain to the Elastic Beanstalk URL.
Note
- Avoid Immediate Redeployment:
- Do not redeploy the application for at least 5 minutes after a successful deployment to avoid failed runs. This requires additional logic in the deployment pipeline to handle such cases automatically.
:construction: The following procedures are not guaranteed to work, it's where the project is going though. :construction:
Quick Start
Installation
Install ob-tuner and its dependencies using pip:
pip install ob-tuner
Setting Up Your Environment
To set up your environment, create a .env
file:
cp .env.example .env
Edit the .env
file with your own values.
Running ob-tuner
To launch the ob-tuner interface:
ob-tuner
Contributing
Contributions are welcome! Please see CONTRIBUTING.md for guidelines on how to contribute to the project.
License
ob-tuner is open-source software licensed under the AGPLv3. For commercial use, contact us.
Procedures
Before deploying
-
Ensure AWSServiceRoleForElasticBeanstalk exists in your roles, if not, create it. Use the UI and it weil be created correctly without havingto fill in the name or trust relationship or policy document.
-
Before deploying, register with Cognito and get a
client_id
andclient_secret
for the OAuth2 client. You will need to provide yourcallback_url
. -
Before deploying, create a Route53 record for your base domain. This requires a root A record in the root domain. For example
openbra.in
A
EBS endpoint
. -
Before deploying, create a custom domain in your cognito user pool. This requires the record above to be created first.
-
Before deploying you must creaet a certificate in ACM for the custom domain.
-
Before deploying, create ssh keypair and store the private key in a secure location. Use the key pair name in the
ec2_key_name
parameter. -
Befoer deploying, add EBS admin access
After deploying
- After deploying, create a Route 53 record set pointing your callback URL domain to the EBS URL.
When updating to a new major version of openbrain
You should do a manual semantic-release version
to bump the version before commit, otherwise, the major versions will be out of sync until the next release (the pipeline will release for you)
NOTE: Do not redeploy app for at least 5 minutes (if last one was succesful) to avoid failed runs... requires more logic in the pipeline to automate this case
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ob_tuner-4.5.0.tar.gz
.
File metadata
- Download URL: ob_tuner-4.5.0.tar.gz
- Upload date:
- Size: 623.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.5.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2cb389d6ee09dbe3f71c5dc5fcd9bd965ec0992d81fea1152d4e132b6f9cbbc6 |
|
MD5 | d79b535378de2e9c77bc18f8bc95ac98 |
|
BLAKE2b-256 | 52607eee978831cea1ba019f216a507872dbd07a8114378ebdffc5561ffa22de |
File details
Details for the file ob_tuner-4.5.0-py3-none-any.whl
.
File metadata
- Download URL: ob_tuner-4.5.0-py3-none-any.whl
- Upload date:
- Size: 622.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.5.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 433392e4ad088822c084132e97523de906b051b72aa94bf7bce886b9a33fedae |
|
MD5 | 1a7a96188807fe98a5803ff15007e12d |
|
BLAKE2b-256 | fe8fda89454c91d53f63f958416c0671c9fd5bf7a57f618993a8a7d2beed7a1e |