Contributing
We appreciate your interest in contributing to VoltAgent! VoltAgent aims to be a powerful and flexible backend framework focused on [mention core goals, e.g., building AI-powered applications, simplifying backend development, providing robust voice integration]. We value community contributions that help us achieve this vision.
We follow a code of conduct when participating in the community. Please read it before you make any contributions.
Get in touch:
- If you plan to work on an issue, please mention so in the issue page before you start working.
- If you plan to work on a new feature, consider creating an issue first to discuss it with other community members/maintainers.
- Ask for help if you get stuck! Join our community at Discord.
Project Focus & Contribution Areas
As a backend framework, we particularly welcome contributions in areas such as:
- Core Framework: Improving the fundamental APIs, performance optimizations, middleware enhancements, and overall developer experience.
- CLI Tooling: Adding new commands, improving existing ones, and enhancing the scaffolding process.
- AI/Voice Integration: Contributing to the @voltagent/xsaiand@voltagent/voicepackages, improving integrations, or adding new capabilities.
- Integrations: Developing adapters for databases, external services, or other tools.
- Examples & Use Cases: Creating realistic examples demonstrating VoltAgent's features.
- Bug Fixes & Performance Improvements: Addressing existing issues and optimizing code across all packages.
- Documentation: Enhancing clarity, adding guides, and improving API references.
Our Packages
VoltAgent is a monorepo containing several key packages:
- @voltagent/core: The heart of the framework, containing the main APIs, request/response handling, middleware pipeline, etc. Contributions here often involve core feature development or architectural improvements.
- @voltagent/voice: Handles voice input/output capabilities. Contributions could involve new STT/TTS integrations or improving voice interaction logic.
- @voltagent/anthropic-ai: Provides integration with Anthropic's Claude AI models. Contributions could include improving model interactions, adding new Claude capabilities, or optimizing prompt handling.
- @voltagent/xsai: Focuses on integrating AI functionalities (e.g., LLMs, vector stores). Contributions might include new AI service integrations or improving existing ones.
- @voltagent/vercel-ai: Specific integrations for Vercel AI SDK.
- @voltagent/cli: The command-line interface for creating and managing VoltAgent projects. Contributions typically involve adding/improving commands or developer workflows.
- @voltagent/create-voltagent-app: The scaffolding tool used by- npm create voltagent-app@latest.
Understanding the purpose of each package helps in directing your contributions effectively.
Ways to contribute
- Stars on GitHub: If you use VoltAgent and find it helpful, please star it on GitHub! 🌟
- Improve documentation: Good documentation is vital, especially for a backend framework. Help us by improving existing docs or adding new guides/API references.
- Give feedback: Share your experiences, suggest features (especially backend-focused ones), or report issues via GitHub Issues or our community channel Discord.
- Share VoltAgent: Help spread the word about VoltAgent in the backend development community.
- Contribute to codebase: Help us build the best backend framework! You can work on new features (see Focus Areas above) or fix existing issues.
- Share integrations/examples: Built a cool backend service or integration with VoltAgent? Let us know!
Setting Up Your Environment for Development
Requirements
- Node.js version 20 or higher
- Git and GitHub account
- pnpm version 8.10.5 or higher (as per package.json)
Cloning the Repository
Fork the VoltAgent repository (link-to-your-repo/fork) and clone your fork:
git clone https://github.com/<your-github-username>/VoltAgent.git # Replace with your fork
cd voltagent
Installing Dependencies
After cloning, install dependencies using pnpm. This command also links workspace packages.
pnpm install
You can build all packages later with:
pnpm build
Or build specific packages:
# Example: Build the core package
pnpm build --scope @voltagent/core
Developing Packages
Run the development server for specific backend packages you are working on:
# Example: Develop core and cli packages
pnpm dev --scope @voltagent/core --scope @voltagent/cli
Changes in the specified packages will trigger recompilation.
How to add a dependency to a package?
Navigate to the package directory and use pnpm add:
# Example: Add 'lodash' to the core package
cd packages/core
pnpm add lodash
Running Tests
Use lerna run test with --scope to run tests for the specific backend package(s) you modified:
# Example: Run tests for the core package
pnpm test --scope @voltagent/core
To run tests for all packages:
pnpm test:all
To get coverage reports:
# For a specific package
pnpm test --scope @voltagent/core -- --coverage
# For all packages
pnpm test:all:coverage
Working on Documentation
Our documentation likely resides in the website directory (confirm this structure if different) and may use a static site generator like Docusaurus.
Navigate to the documentation directory and follow its setup instructions (update these steps based on your actual documentation setup):
cd website # Or your actual documentation directory
pnpm install
pnpm start # Or the relevant dev script (e.g., dev, develop)
Committing Your Work and Preparing a Pull Request
We use several tools to ensure code quality and a consistent contribution process.
Linting & Formatting
We use Biome for linting and formatting TypeScript/JavaScript/JSON files and Prettier for Markdown.
- Check: pnpm lintorpnpm lint:ci
- Fix: pnpm lint:fix
- Format Markdown: pnpm format(This also runs Prettier on Markdown)
We recommend installing the Biome VSCode extension and a Prettier extension for a smoother development experience.
Commit Convention
We follow the Conventional Commits specification. Commit messages should follow the format:
<type>(<scope>): <description>
Where <scope> is typically the package name (e.g., core, cli, voice, docs).
Example: feat(core): add new middleware feature or fix(cli): correct argument parsing
Creating a Changeset
For managing versioning and changelogs across our monorepo packages, we use Changesets. Before committing changes that affect any package, create a changeset:
pnpm changeset
Follow the prompts:
- Select the package(s) you modified.
- Choose the appropriate semantic version bump (major,minor,patch).
- Write a clear description of the change. Reference the relevant GitHub issue number (e.g., Fixes #123).
Commit the generated .changeset/*.md file along with your code changes.
Example changeset content:
---
"@voltagent/core": minor
"@voltagent/cli": patch
---
feat(core): Implement awesome feature X
This feature allows users to do Y.
fix(cli): Correct flag parsing issue
Resolves #456
Fixes #789
Creating a Pull Request
- Push your changes (including the changeset file) to your forked repository.
- Create a Pull Request against the mainbranch of the main VoltAgent repository (link-to-your-repo).
- Ensure your PR title and description are clear. Reference any related issues.
- CI checks (linting, tests, commitlint, changeset validation) will run automatically. Please address any failures.
- Maintainers will review your PR. Be responsive to feedback.
We look forward to your contributions! 🎉