Development Guide
This guide explains how to set up and run the SaaS Auth API in development mode.
Prerequisites
Before you start, make sure you have the following installed:
- Go 1.24.1 or later
- Docker and Docker Compose
- Git
- PostgreSQL client (optional, for direct database access)
- Redis client (optional, for direct cache access)
Getting the Code
git clone https://github.com/yersonargotev/saas-auth-api.gitcd saas-auth-apiDevelopment Environment Setup
Using Docker Compose (Recommended)
The project includes a Docker Compose configuration for development that provides:
- Hot reloading using Air
- PostgreSQL database
- Redis cache
To start the development environment:
docker-compose -f docker-compose.dev.yml upThis will:
- Build the development Docker image
- Start PostgreSQL and Redis services
- Run database migrations automatically
- Start the API with hot reloading at http://localhost:3000
Local Development (Without Docker)
If you prefer to run the application directly on your machine:
- 
Install Go dependencies: Terminal window go mod download
- 
Install Air for hot reloading (optional): Terminal window go install github.com/air-verse/air@latest
- 
Set up PostgreSQL and Redis locally or use existing instances. 
- 
Create a .envfile with your configuration (see Configuration section).
- 
Run the application with Air for hot reloading: Terminal window airOr without hot reloading: Terminal window go run cmd/api/main.go
Configuration
The application uses a configuration file located at config/config.yaml. You can override these settings using environment variables:
app:  name: saas-auth-api  version: 0.1.0  env: development  port: 3000
database:  host: localhost  port: 5432  user: postgres  password: postgres  name: saas_auth  sslmode: disable  max_open_conns: 20  max_idle_conns: 5  conn_max_lifetime: 30m
redis:  host: localhost  port: 6379  password: ""  db: 0
jwt:  secret: supersecretkey-change-in-production  access_ttl: 15m  refresh_ttl: 24h
auth:  password_salt: change-this-in-production  api_key_prefix: sk-  api_key_length: 32  rate_limit:    enabled: true    requests: 100    duration: 1mEnvironment variable mapping:
- APP_ENV→- app.env
- APP_PORT→- app.port
- DB_HOST→- database.host
- DB_PORT→- database.port
- DB_USER→- database.user
- DB_PASSWORD→- database.password
- DB_NAME→- database.name
- REDIS_HOST→- redis.host
- REDIS_PORT→- redis.port
- REDIS_PASSWORD→- redis.password
- JWT_SECRET→- jwt.secret
Database Migrations
Migrations are automatically run when the application starts. The migration files are located in the migrations directory.
To manually run migrations, you can use the golang-migrate CLI tool:
# Install the migration toolgo install -tags 'postgres' github.com/golang-migrate/migrate/v4/cmd/migrate@latest
# Run migrationsmigrate -path ./migrations -database "postgres://postgres:postgres@localhost:5432/saas_auth?sslmode=disable" upTesting
Running Unit Tests
go test ./tests/unit/...Running Integration Tests
go test ./tests/integration/...Running End-to-End Tests
go test ./tests/e2e/...API Documentation
You can view the API documentation in the Swagger UI by accessing /docs endpoint when running the application.
Development Workflow
- 
Create a new branch for your feature or bugfix: Terminal window git checkout -b feature/my-feature
- 
Make your changes and write tests. 
- 
Run tests to make sure everything works: Terminal window go test ./...
- 
Commit your changes with a descriptive message: Terminal window git commit -m "Add my new feature"
- 
Push your branch and create a pull request. 
Troubleshooting
Common Issues
- 
Connection refused to PostgreSQL or Redis - Make sure the services are running
- Check if the host and port are correct in the configuration
- Verify that no firewall is blocking the connections
 
- 
Hot reloading not working - Check if Air is installed and configured correctly
- Make sure the .air.tomlfile exists in the project root
 
- 
JWT token issues - Verify that the JWT secret is set correctly
- Check the token expiration times in the configuration
 
- 
Database migration failing - Check the database connection settings
- Make sure the database user has the necessary permissions
- Look for syntax errors in the migration files
 
Logs and Debugging
In development mode, the application logs are verbose and include detailed information about requests, database queries, and errors. You can adjust the log level in the configuration file.
To enable additional debugging information, set the following environment variable:
APP_ENV=developmentCode Structure
The project follows a clean architecture approach with the following structure:
- cmd/api: Application entry point
- config: Configuration files
- docs: API documentation
- internal: Application core- apiKey: API key management
- auth: Authentication service
- role: Role and permission management
- user: User management
 
- migrations: Database migration files
- pkg: Shared packages- config: Configuration loading
- database: Database connection and repositories
- logger: Logging utilities
- middleware: HTTP middlewares
- validator: Input validation
 
- tests: Test suite- e2e: End-to-end tests
- integration: Integration tests
- unit: Unit tests