mrprotocoll / api-boilerplate-laravel
This Laravel 11 API boilerplate provides a structured foundation for building robust backend applications with Laravel, integrating essential features and tools.
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 2
Forks: 0
Open Issues: 0
Type:project
Requires
- php: ^8.2
- ext-fileinfo: *
- darkaonline/l5-swagger: ^8.6
- laravel/breeze: ^2.1
- laravel/framework: ^11.9
- laravel/sanctum: ^4.0
- laravel/socialite: ^5.15
- laravel/tinker: ^2.9
- larowka/prevent-duplicate-requests: ^1.1
Requires (Dev)
- fakerphp/faker: ^1.23
- laravel/pint: ^1.13
- laravel/sail: ^1.26
- mockery/mockery: ^1.6
- nunomaduro/collision: ^8.0
- nunomaduro/larastan: ^2.9
- pestphp/pest: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
README
🕹️🕹️ Laravel API Boilerplate🕹️🕹️
📗 Table of Contents
📖 API Boilerplate
A robust, modular Laravel 11 API boilerplate built using a Domain-Driven Design (DDD) approach. This boilerplate provides a scalable foundation for modern API development with essential features like role-based access, versioning, Google OAuth integration, and more..
Features
- Domain-Driven Architecture: Organized modules and shared resources for scalability.
- Versioning: Supports multiple API versions with structured routing.
- Role-Based Access Control: Integrated roles and permissions with easy extensibility.
- Google OAuth: Simplified OAuth 2.0 authentication setup.
- Modular Components: Independent modules for Auth, User, and more.
- Enums and Helpers: Centralized, reusable enums and helper methods.
- Custom Middlewares: Pre-configured middlewares for JSON responses, caching, logging, and preventing duplicate requests.
- Optimized Exception Handling: Friendly and consistent error responses.
- Custom Base Model: A UUID-enabled base model for consistency across entities.
- Seeders and Factories: Simplified data seeding with predefined roles.
- Rate Limiting: API throttling to prevent abuse.
- Fully Documented: Swagger/OpenAPI support for API documentation.
Architecture Overview
Domain-Driven Design (DDD)
The project structure is organized to separate concerns:
src/modules
: Contains feature-specific modules, e.g., Auth and User.
src/shared
: Shared resources like helpers, enums, and base classes.
Versioning
Version-specific modules and routes are located in the V1
directory for flexibility.
Tech Stack
🚀 Links
To access the documentation goto the below link
- Link to api routes
http://localhost:8000/v1
- Link to documentation
http://localhost:8000/v1/documentation
💻 Getting Started
To get a local copy up and running, follow these steps.
Prerequisites
In order to run this boilerplate, you need:
- PHP ^8.2
use the following link to setupPHP
if you dont have it already installed on your computer
- Composer
use the following link to DownloadComposer
if you dont have it already installed on your computer
Install
clone the repository:
git clone git@github.com:mrprotocoll/api-boilerplate-laravel.git
Install dependencies:
composer install
Setup
create .env file, change using the .env.example file and update the Database, Google Oauth (optional), and Email credentials.
cp .env.example .env
Generate keys, Run the migration and seed roles:
php artisan key:generate
php artisan migrate --seed
Usage
The following command can be used to run the application.
php artisan serve
Contributing
Feel free to fork the repository, make changes, and submit pull requests. Feedback is always welcome!
License
This project is licensed under the MIT License.