mirror of
https://github.com/Significant-Gravitas/AutoGPT.git
synced 2026-01-09 15:17:59 -05:00
## Summary - Added search functionality to find nodes in the graph by block type, node ID, and input/output names - Search icon added to both new and old control panels - Implemented node highlighting on hover and navigation on click https://github.com/user-attachments/assets/8cc69186-5582-446d-b2cd-601de992144f ## Changes - Created `GraphSearchMenu` component for the new control panel - Created `GraphSearchControl` component for the old control panel - Added `GraphSearchContent` component with search UI similar to BlockMenu - Implemented `useGraphSearch` hook with fuzzy search logic - Added node highlighting without viewport movement on hover - Added node navigation with centering and highlighting on selection ## Features - Search by block type name, node ID, or input/output field names - Real-time filtering with keyboard navigation support - Visual feedback with node highlighting on hover - Click to navigate and center on selected node - Consistent styling with BlockMenu including category colors - Works in both old and new control panels ## Test plan - [x] Test search functionality in both old and new control panels - [x] Verify search by block type name works - [x] Verify search by node ID works - [x] Verify search by input/output names works - [x] Test keyboard navigation (arrow keys and enter) - [x] Verify node highlighting on hover - [x] Verify node navigation on click - [x] Check popover alignment with control panel top
243 lines
8.1 KiB
Markdown
243 lines
8.1 KiB
Markdown
# CLAUDE.md
|
|
|
|
This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
|
|
|
|
## Repository Overview
|
|
|
|
AutoGPT Platform is a monorepo containing:
|
|
|
|
- **Backend** (`/backend`): Python FastAPI server with async support
|
|
- **Frontend** (`/frontend`): Next.js React application
|
|
- **Shared Libraries** (`/autogpt_libs`): Common Python utilities
|
|
|
|
## Essential Commands
|
|
|
|
### Backend Development
|
|
|
|
```bash
|
|
# Install dependencies
|
|
cd backend && poetry install
|
|
|
|
# Run database migrations
|
|
poetry run prisma migrate dev
|
|
|
|
# Start all services (database, redis, rabbitmq, clamav)
|
|
docker compose up -d
|
|
|
|
# Run the backend server
|
|
poetry run serve
|
|
|
|
# Run tests
|
|
poetry run test
|
|
|
|
# Run specific test
|
|
poetry run pytest path/to/test_file.py::test_function_name
|
|
|
|
# Run block tests (tests that validate all blocks work correctly)
|
|
poetry run pytest backend/blocks/test/test_block.py -xvs
|
|
|
|
# Run tests for a specific block (e.g., GetCurrentTimeBlock)
|
|
poetry run pytest 'backend/blocks/test/test_block.py::test_available_blocks[GetCurrentTimeBlock]' -xvs
|
|
|
|
# Lint and format
|
|
# prefer format if you want to just "fix" it and only get the errors that can't be autofixed
|
|
poetry run format # Black + isort
|
|
poetry run lint # ruff
|
|
```
|
|
|
|
More details can be found in TESTING.md
|
|
|
|
#### Creating/Updating Snapshots
|
|
|
|
When you first write a test or when the expected output changes:
|
|
|
|
```bash
|
|
poetry run pytest path/to/test.py --snapshot-update
|
|
```
|
|
|
|
⚠️ **Important**: Always review snapshot changes before committing! Use `git diff` to verify the changes are expected.
|
|
|
|
### Frontend Development
|
|
|
|
```bash
|
|
# Install dependencies
|
|
cd frontend && pnpm i
|
|
|
|
# Start development server
|
|
pnpm dev
|
|
|
|
# Run E2E tests
|
|
pnpm test
|
|
|
|
# Run Storybook for component development
|
|
pnpm storybook
|
|
|
|
# Build production
|
|
pnpm build
|
|
|
|
# Type checking
|
|
pnpm types
|
|
```
|
|
|
|
We have a components library in autogpt_platform/frontend/src/components/atoms that should be used when adding new pages and components.
|
|
|
|
|
|
## Architecture Overview
|
|
|
|
### Backend Architecture
|
|
|
|
- **API Layer**: FastAPI with REST and WebSocket endpoints
|
|
- **Database**: PostgreSQL with Prisma ORM, includes pgvector for embeddings
|
|
- **Queue System**: RabbitMQ for async task processing
|
|
- **Execution Engine**: Separate executor service processes agent workflows
|
|
- **Authentication**: JWT-based with Supabase integration
|
|
- **Security**: Cache protection middleware prevents sensitive data caching in browsers/proxies
|
|
|
|
### Frontend Architecture
|
|
|
|
- **Framework**: Next.js App Router with React Server Components
|
|
- **State Management**: React hooks + Supabase client for real-time updates
|
|
- **Workflow Builder**: Visual graph editor using @xyflow/react
|
|
- **UI Components**: Radix UI primitives with Tailwind CSS styling
|
|
- **Feature Flags**: LaunchDarkly integration
|
|
|
|
### Key Concepts
|
|
|
|
1. **Agent Graphs**: Workflow definitions stored as JSON, executed by the backend
|
|
2. **Blocks**: Reusable components in `/backend/blocks/` that perform specific tasks
|
|
3. **Integrations**: OAuth and API connections stored per user
|
|
4. **Store**: Marketplace for sharing agent templates
|
|
5. **Virus Scanning**: ClamAV integration for file upload security
|
|
|
|
### Testing Approach
|
|
|
|
- Backend uses pytest with snapshot testing for API responses
|
|
- Test files are colocated with source files (`*_test.py`)
|
|
- Frontend uses Playwright for E2E tests
|
|
- Component testing via Storybook
|
|
|
|
### Database Schema
|
|
|
|
Key models (defined in `/backend/schema.prisma`):
|
|
|
|
- `User`: Authentication and profile data
|
|
- `AgentGraph`: Workflow definitions with version control
|
|
- `AgentGraphExecution`: Execution history and results
|
|
- `AgentNode`: Individual nodes in a workflow
|
|
- `StoreListing`: Marketplace listings for sharing agents
|
|
|
|
### Environment Configuration
|
|
|
|
#### Configuration Files
|
|
|
|
- **Backend**: `/backend/.env.default` (defaults) → `/backend/.env` (user overrides)
|
|
- **Frontend**: `/frontend/.env.default` (defaults) → `/frontend/.env` (user overrides)
|
|
- **Platform**: `/.env.default` (Supabase/shared defaults) → `/.env` (user overrides)
|
|
|
|
#### Docker Environment Loading Order
|
|
|
|
1. `.env.default` files provide base configuration (tracked in git)
|
|
2. `.env` files provide user-specific overrides (gitignored)
|
|
3. Docker Compose `environment:` sections provide service-specific overrides
|
|
4. Shell environment variables have highest precedence
|
|
|
|
#### Key Points
|
|
|
|
- All services use hardcoded defaults in docker-compose files (no `${VARIABLE}` substitutions)
|
|
- The `env_file` directive loads variables INTO containers at runtime
|
|
- Backend/Frontend services use YAML anchors for consistent configuration
|
|
- Supabase services (`db/docker/docker-compose.yml`) follow the same pattern
|
|
|
|
### Common Development Tasks
|
|
|
|
**Adding a new block:**
|
|
|
|
Follow the comprehensive [Block SDK Guide](../../../docs/content/platform/block-sdk-guide.md) which covers:
|
|
- Provider configuration with `ProviderBuilder`
|
|
- Block schema definition
|
|
- Authentication (API keys, OAuth, webhooks)
|
|
- Testing and validation
|
|
- File organization
|
|
|
|
Quick steps:
|
|
1. Create new file in `/backend/backend/blocks/`
|
|
2. Configure provider using `ProviderBuilder` in `_config.py`
|
|
3. Inherit from `Block` base class
|
|
4. Define input/output schemas using `BlockSchema`
|
|
5. Implement async `run` method
|
|
6. Generate unique block ID using `uuid.uuid4()`
|
|
7. Test with `poetry run pytest backend/blocks/test/test_block.py`
|
|
|
|
Note: when making many new blocks analyze the interfaces for each of these blocks and picture if they would go well together in a graph based editor or would they struggle to connect productively?
|
|
ex: do the inputs and outputs tie well together?
|
|
|
|
**Modifying the API:**
|
|
|
|
1. Update route in `/backend/backend/server/routers/`
|
|
2. Add/update Pydantic models in same directory
|
|
3. Write tests alongside the route file
|
|
4. Run `poetry run test` to verify
|
|
|
|
**Frontend feature development:**
|
|
|
|
1. Components go in `/frontend/src/components/`
|
|
2. Use existing UI components from `/frontend/src/components/ui/`
|
|
3. Add Storybook stories for new components
|
|
4. Test with Playwright if user-facing
|
|
|
|
### Security Implementation
|
|
|
|
**Cache Protection Middleware:**
|
|
|
|
- Located in `/backend/backend/server/middleware/security.py`
|
|
- Default behavior: Disables caching for ALL endpoints with `Cache-Control: no-store, no-cache, must-revalidate, private`
|
|
- Uses an allow list approach - only explicitly permitted paths can be cached
|
|
- Cacheable paths include: static assets (`/static/*`, `/_next/static/*`), health checks, public store pages, documentation
|
|
- Prevents sensitive data (auth tokens, API keys, user data) from being cached by browsers/proxies
|
|
- To allow caching for a new endpoint, add it to `CACHEABLE_PATHS` in the middleware
|
|
- Applied to both main API server and external API applications
|
|
|
|
### Creating Pull Requests
|
|
|
|
- Create the PR aginst the `dev` branch of the repository.
|
|
- Ensure the branch name is descriptive (e.g., `feature/add-new-block`)/
|
|
- Use conventional commit messages (see below)/
|
|
- Fill out the .github/PULL_REQUEST_TEMPLATE.md template as the PR description/
|
|
- Run the github pre-commit hooks to ensure code quality.
|
|
|
|
### Reviewing/Revising Pull Requests
|
|
|
|
- When the user runs /pr-comments or tries to fetch them, also run gh api /repos/Significant-Gravitas/AutoGPT/pulls/[issuenum]/reviews to get the reviews
|
|
- Use gh api /repos/Significant-Gravitas/AutoGPT/pulls/[issuenum]/reviews/[review_id]/comments to get the review contents
|
|
- Use gh api /repos/Significant-Gravitas/AutoGPT/issues/9924/comments to get the pr specific comments
|
|
|
|
### Conventional Commits
|
|
|
|
Use this format for commit messages and Pull Request titles:
|
|
|
|
**Conventional Commit Types:**
|
|
|
|
- `feat`: Introduces a new feature to the codebase
|
|
- `fix`: Patches a bug in the codebase
|
|
- `refactor`: Code change that neither fixes a bug nor adds a feature; also applies to removing features
|
|
- `ci`: Changes to CI configuration
|
|
- `docs`: Documentation-only changes
|
|
- `dx`: Improvements to the developer experience
|
|
|
|
**Recommended Base Scopes:**
|
|
|
|
- `platform`: Changes affecting both frontend and backend
|
|
- `frontend`
|
|
- `backend`
|
|
- `infra`
|
|
- `blocks`: Modifications/additions of individual blocks
|
|
|
|
**Subscope Examples:**
|
|
|
|
- `backend/executor`
|
|
- `backend/db`
|
|
- `frontend/builder` (includes changes to the block UI component)
|
|
- `infra/prod`
|
|
|
|
Use these scopes and subscopes for clarity and consistency in commit messages.
|