Skip to main content

OpenBra.in agent creation and tuning Gradio deployment.

Project description

ob-tuner

CI Status CI Status

PyPI - Version License: AGPL v3 Code style: black Conventional Commits pre-commit Made with GH Actions semantic-release

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.

img_3.png

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

  1. 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.
  2. Register with Cognito:

    • Register with Amazon Cognito and obtain a client_id and client_secret for the OAuth2 client. You will need to provide your callback_url during this process.
  3. 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 an A record pointing to your EBS endpoint.
  4. 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.
  5. Create an ACM Certificate:

    • Create a certificate in AWS Certificate Manager (ACM) for the custom domain.
  6. 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.
  7. Add EBS Admin Access:

    • Ensure that Elastic Beanstalk has the necessary administrative access.

    img_1.png img_2.png

After Deploying

  1. Create a Route 53 Record Set:

    • Create a Route 53 record set pointing your callback URL domain to the Elastic Beanstalk URL.

    img.png

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

  1. 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.

  2. Before deploying, register with Cognito and get a client_id and client_secret for the OAuth2 client. You will need to provide your callback_url.

  3. 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.

  4. Before deploying, create a custom domain in your cognito user pool. This requires the record above to be created first.

  5. Before deploying you must creaet a certificate in ACM for the custom domain.

  6. 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.

  7. Befoer deploying, add EBS admin access img_1.pngimg_2.png

After deploying

  1. After deploying, create a Route 53 record set pointing your callback URL domain to the EBS URL. img.png

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ob_tuner-4.0.0.tar.gz (478.4 kB view details)

Uploaded Source

Built Distribution

ob_tuner-4.0.0-py3-none-any.whl (476.1 kB view details)

Uploaded Python 3

File details

Details for the file ob_tuner-4.0.0.tar.gz.

File metadata

  • Download URL: ob_tuner-4.0.0.tar.gz
  • Upload date:
  • Size: 478.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.5.0-1023-azure

File hashes

Hashes for ob_tuner-4.0.0.tar.gz
Algorithm Hash digest
SHA256 266c2423e0b19505332c22c5fe53119715ead69116fa2c499bccbf9b0f8552aa
MD5 77aff0ffa1df2e9090a2fb1536aca55b
BLAKE2b-256 c3c2ec3b6f1a9ca8a7532cc5441bf24ccf07f3b60d772bb30d080ff6d17e6a25

See more details on using hashes here.

File details

Details for the file ob_tuner-4.0.0-py3-none-any.whl.

File metadata

  • Download URL: ob_tuner-4.0.0-py3-none-any.whl
  • Upload date:
  • Size: 476.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.5.0-1023-azure

File hashes

Hashes for ob_tuner-4.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 784a573d3b0792d2deb5093a159a3044a7944b0bf93435625464f831a43a1e99
MD5 86bb35b60cadb0b724ffa30032f66374
BLAKE2b-256 d4c97d92435fafb27c05296646a0c8e9a6a8914a24b545e8778ae76d4107cc16

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page