Skip to content

Commit

Permalink
chore: add a development explainer
Browse files Browse the repository at this point in the history
This change also adds a docker build step to CI and adds the http/
directory to the gitignore.

Signed-off-by: Donnie Adams <[email protected]>
  • Loading branch information
thedadams committed Dec 17, 2024
1 parent 6a6d869 commit df66f62
Show file tree
Hide file tree
Showing 5 changed files with 192 additions and 64 deletions.
75 changes: 75 additions & 0 deletions .github/workflows/docker-build-and-push.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
name: Build and Push Docker Image

permissions:
id-token: write
contents: read
packages: write

on:
push:
branches:
- main
tags:
- 'v*'
paths-ignore:
- docs/**

jobs:
build:
env:
DEPLOY_TO_TEST: ${{ github.ref_type == 'branch' && secrets.RENDER_TEST_DEPLOY_URL != 'disabled' }}
DEPLOY_TO_MAIN: ${{ github.ref_type == 'branch' && secrets.RENDER_MAIN_DEPLOY_URL != 'disabled' }}
runs-on: depot-ubuntu-22.04

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Depot
uses: depot/setup-action@v1

- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Log in to Docker Hub
if: ${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') }}
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Build and push Docker image
uses: depot/build-push-action@v1
with:
project: bbqjs4tj1g
context: .
push: true
tags: |
ghcr.io/${{ github.repository }}:${{ github.ref_name }}
${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') && format('docker.io/obot/{0}:{1}', github.event.repository.name, github.ref_name) || '' }}
platforms: linux/amd64,linux/arm64

- name: Setup crane
uses: imjasonh/[email protected]

- name: Copy to latest tag
if: ${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') }}
run: |
crane tag ghcr.io/${{ github.repository }}:${{ github.ref_name }} latest
crane tag docker.io/obot/${{ github.event.repository.name }}:${{ github.ref_name }} latest
- name: Deploy to Test Render
if: ${{ env.DEPLOY_TO_TEST == 'true' }}
uses: joelwmale/[email protected]
with:
url: ${{ secrets.RENDER_TEST_DEPLOY_URL }}

- name: Deploy to Main Render
if: ${{ env.DEPLOY_TO_MAIN == 'true' }}
uses: joelwmale/[email protected]
with:
url: ${{ secrets.RENDER_MAIN_DEPLOY_URL }}
75 changes: 13 additions & 62 deletions .github/workflows/docker-build.yml
Original file line number Diff line number Diff line change
@@ -1,75 +1,26 @@
name: Build and Push Docker Image

permissions:
id-token: write
contents: read
packages: write

on:
push:
pull_request:
branches:
- main
tags:
- 'v*'
paths-ignore:
- docs/**

jobs:
build:
env:
DEPLOY_TO_TEST: ${{ github.ref_type == 'branch' && secrets.RENDER_TEST_DEPLOY_URL != 'disabled' }}
DEPLOY_TO_MAIN: ${{ github.ref_type == 'branch' && secrets.RENDER_MAIN_DEPLOY_URL != 'disabled' }}
runs-on: depot-ubuntu-22.04

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Depot
uses: depot/setup-action@v1

- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Log in to Docker Hub
if: ${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') }}
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Build and push Docker image
uses: depot/build-push-action@v1
with:
project: bbqjs4tj1g
context: .
push: true
tags: |
ghcr.io/${{ github.repository }}:${{ github.ref_name }}
${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') && format('docker.io/obot/{0}:{1}', github.event.repository.name, github.ref_name) || '' }}
platforms: linux/amd64,linux/arm64

- name: Setup crane
uses: imjasonh/[email protected]

- name: Copy to latest tag
if: ${{ github.ref_type == 'tag' && !contains(github.ref_name, '-rc') }}
run: |
crane tag ghcr.io/${{ github.repository }}:${{ github.ref_name }} latest
crane tag docker.io/obot/${{ github.event.repository.name }}:${{ github.ref_name }} latest
- name: Deploy to Test Render
if: ${{ env.DEPLOY_TO_TEST == 'true' }}
uses: joelwmale/[email protected]
with:
url: ${{ secrets.RENDER_TEST_DEPLOY_URL }}

- name: Deploy to Main Render
if: ${{ env.DEPLOY_TO_MAIN == 'true' }}
uses: joelwmale/[email protected]
with:
url: ${{ secrets.RENDER_MAIN_DEPLOY_URL }}
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Depot
uses: depot/setup-action@v1

- name: Build and push Docker image
uses: depot/build-push-action@v1
with:
project: bbqjs4tj1g
context: .
platforms: linux/amd64,linux/arm64
2 changes: 1 addition & 1 deletion .github/workflows/go.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ on:
pull_request:
branches:
- main
ignore-paths:
paths-ignore:
- ui/admin/**
- ui/user/**

Expand Down
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -44,4 +44,5 @@ Thumbs.db
# Ignore local DB files
obot*.db*


# Ignore http dir for http client files
http/
101 changes: 101 additions & 0 deletions DEVELOPMENT.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# Developing Obot

What follows is a rundown on different ways to run and develop Obot, its UI and its tools locally.

## Running Obot

The easiest way to run Obot locally is to run `make dev`. This will launch three processes: the API server, admin UI, and user UI. Opening `http://localhost:8080/admin/` will launch the admin UI. Changing the UI code will update the UI automatically. Changing any of the Go code requires restarting the server.

## Building and Running the Obot Docker Image

Obot is ultimately packaged into an image for distribution. You can build said image with `docker build -t my-obot .`, and then run the image via `docker run -p 8080:8080 my-obot`.

## Debugging Obot

It is possible to run the server and/or UIs in and IDE for debugging purposes. These steps layout what is necessary for Jet Brains IDEs, but an equivalent process can be used with VSCode based editors.

### Server

To run the server in GoLand:
1. Create a new "Go Build" configuration.
2. In the "Program Arguments" section, enter `server --dev-mode`.

Then you're ready to run or debug this target.

### Admin UI

To run the Admin UI in GoLand or Web Storm:
1. Create a new "npm" build.
2. In the "package.json" dropdown, select the `package.json` file in the `ui/admin` directory.
3. In the "Command" dropdown, select `run`.
4. In the "Scripts" dropdown, select `dev`.
5. In the "Environment" section, enter `VITE_API_IN_BROWSER=true`.

Then you're ready to run or debug this target.

### User UI

To run the User UI in GoLand or Web Storm:
1. Create a new "npm" build.
2. In the "package.json" dropdown, select the `package.json` file in the `ui/user` directory.
3. In the "Command" dropdown, select `run`.
4. In the "Scripts" dropdown, select `dev`.
5. In the "Environment" section, enter `VITE_API_IN_BROWSER=true`.

Then you're ready to run or debug this target.

## Developing Obot Tools

Obot has a set of packaged tools. These tools are in the repo `github.com/obot-platform/tools`. By default, Obot will pull the tools from this repo. However, when developing tools in this repo, you can follow these steps to use a local copy.

1. Clone `github.com/obot-platform/tools` to your local machine.
2. In the root directory of the tools repo on your local machine, run `make build`.
3. Run the Obot server, either with `make dev` or in your IDE, with the `OBOT_SERVER_TOOL_REGISTRY` environment variable set to the root directory of the tools repo.

Now, any time one of these tools is run, your local copy will be used.

> [!IMPORTANT]
> Any time you change a Go based tool in your local repo, you must run `make build` in the tools repo for the changes to take effect with Obot.
> [!NOTE]
> Tool definitions and metadata are only synced to Obot every hour. Therefore, if you make a change to the tool in your local machine, it may not reflect immediately in Obot. Rest assured that the latest version is used when running the tool.
## Obot Server Dev Mode

In the description above for running the server in an IDE, the `--dev-mode` flag is used. This flag is also used when running the server with `make dev`. This does a few things (like turns on debug logging), the most helpful of which is to give you access to the database via `kubectl`. The kubeconfig is located at `tools/devmode-kubeconfig`.

For example, from the root directory of the obot repo, you can list all agents in your setup with `kubectl --kubeconfig tools/devmode-kubeconfig get agents`.

## Obot Credentials

The GPTScript credentials for Obot are, by default, store in an SQLite database called `obot-credentials.db` in the root of the obot repo. You can use the `sqlite3` CLI to inspect the database directly: `sqlite3 obot-credentials.db`.

## Resetting

There may be times when you want to completely wipe your setup and start fresh. The location of data and caches is dependent on your system. For Mac or Linux, you can run the respective command in the root of the obot repo on your local machine.

On Mac:
```bash
rm -rf ~/Library/Application\ Support/obot &&
rm -rf ~/Library/Application\ Support/gptscript &&
rm -rf ~/Library/Caches/obot &&
rm -rf ~/Library/Caches/gptscript &&
rm obot.db obot-credentials.db
```

On Linux:
```bash
rm -rf ~/.local/share/obot &&
rm -rf ~/.local/share/gptscript &&
rm -rf ~/.cache/obot &&
rm -rf ~/.cache/gptscript &&
rm obot.db obot-credentials.db
```

## Serving the Documentation

The documentation for Obot is in the main repo. You can serve the documentation from your local machine by running `make serve-docs` in the root of the obot repo.

## Other Configuration

Obot is configured via environment variables. You can see the relevant environment variables by building the binary (as above) and running `./bin/obot server --help`. There is also documentation available. You can serve the documentation locally as above.

0 comments on commit df66f62

Please sign in to comment.