Thank you for considering contributing to Invoicen! We welcome all contributions and are excited to have you on board. This document will guide you through the process of contributing to our project.
Please note that by contributing, you agree to abide by our Code of Conduct.
To get started with contributing, please follow the steps below:
-
Fork and Clone the Repository
- Fork the repository by clicking the "Fork" button at the top right of this page.
- Clone the repository locally:
git clone https://github.com/<your-username>/invoicen.git cd invoicen
-
Set Up the Project
- Ensure you have the following installed:
- Node.js (v16 or higher)
- pnpm (v8 or higher)
- PostgreSQL
- Redis
- MinIO
- Install dependencies:
pnpm install
- Set up the environment variables by copying
.env.example
to.env
and updating the values as per your setup:cp .env.example .env
- Run the development environment:
pnpm dev
- Ensure you have the following installed:
-
Monorepo Structure
- The repository follows a monorepo structure with the following key directories:
- apps/: Contains the main application and services.
- packages/: Shared libraries and utilities.
- tooling/: Development tools and configurations.
- Each directory has its own
README.md
for more details.
- The repository follows a monorepo structure with the following key directories:
To contribute effectively, follow these steps:
-
Create a Branch
- Use a descriptive branch name:
git checkout -b feature/your-feature-name
- Use a descriptive branch name:
-
Implement Your Changes
- Follow coding standards and ensure proper documentation.
- If you're working on APIs, update the Swagger configuration.
- Run tests to ensure your changes don't break existing functionality:
pnpm test
-
Commit Your Changes
- Use Conventional Commits for commit messages. Example:
feat(auth): add user login endpoint fix(storage): resolve bucket creation error
- Use Conventional Commits for commit messages. Example:
-
Push and Open a Pull Request
- Push your branch to your fork:
git push origin feature/your-feature-name
- Open a pull request (PR) against the
main
branch. - Provide a detailed description of your changes in the PR.
- Push your branch to your fork:
To ensure a smooth contribution process:
- Focus Your Changes: Keep PRs small and focused on a single feature or fix.
- Write Tests: Add tests for new functionality or bug fixes.
- Maintain Documentation: Update relevant documentation in the codebase.
- Follow Linting and Formatting Rules:
pnpm lint pnpm format
- Check for Breaking Changes: Ensure your changes are backward-compatible unless a major version update is planned.
Here is a quick reference for setting up the environment variables:
PORT=8080
# PostgreSQL
DB_HOST=localhost
DB_PORT=5432
DB_DATABASE=keizer-auth
DB_USERNAME=postgres
DB_PASSWORD=password
DB_SCHEMA=public
# MinIO
MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=minioadmin
MINIO_PORT=9000
# Redis
REDIS_HOST=localhost
REDIS_PORT=6379
REDIS_PASSWORD=password
# SMTP
SMTP_HOST=localhost
SMTP_PORT=1025
SMTP_USER=keizer
[email protected]
- Run all unit tests:
pnpm test
- Run linting and formatting checks:
pnpm lint pnpm format
- Use the staging environment for testing end-to-end functionality before merging.
- How to Contribute to Open Source
- About Pull Requests
- GitHub Help
- Conventional Commits
- Conventional Commits VSCode Extension
- GitHub Issues and Pull Requests VSCode Extension
Thank you for your interest in contributing to Invoicen! If you have any questions, feel free to open an issue or reach out to the team. We're excited to collaborate with you.