This is a Laravel project template that follows the principles of Clean Architecture, designed to help you build robust and maintainable applications. Clean Architecture promotes a clear separation of concerns, making your codebase more organized, testable, and adaptable. This README will guide you through the project structure, tools, and commands used in this template.
The project is structured into four main directories, each representing a specific layer of the Clean Architecture:
-
app/Application: This layer contains application-specific code and use cases. It defines the application's high-level business rules and logic.
-
app/Domain: The domain layer represents the core business logic of your application. It contains entities, value objects, and the repository interfaces that define how data is stored and retrieved.
-
app/Infrastructure: The infrastructure layer handles the implementation details, including database connections, third-party integrations, and other external dependencies. This layer should be kept as thin as possible.
-
app/Presenter: The presenter layer is responsible for presenting data to the user, which can include views, controllers, and UI-specific logic.
Before using this project template, ensure you have the following prerequisites installed:
This project template provides several Makefile commands to simplify common tasks:
make up
: Launch the application using Laravel Sail.make down
: Stop the application and associated services.make ssh
: Access the Laravel container via SSH.make optimize
: Optimize the application for production.make refresh
: Refresh the application's database with fresh migrations and seed data.make test
: Run PHPUnit tests within the Laravel container.make phpcs
: Run PHP CodeSniffer for code linting and coding standard checks.make phpcbf
: Run PHP Code Beautifier and Fixer for automated code fixes.
Make sure you replace make
with ./vendor/bin/sail
if you prefer running these commands directly through Laravel Sail.
To get started with this project template, follow these steps:
- Clone the project to your local machine.
- Navigate to the project directory.
- Run
make up
to start the application. - Access the application via your web browser at http://localhost.
- You can start building your application within the Clean Architecture structure.
- You can customize the PHP CodeSniffer rules by editing the
phpcs.xml
file. - Adjust the project structure and add your own code within the Clean Architecture layers as needed.
- Refer to Laravel and Clean Architecture documentation for more details on Laravel and Clean Architecture principles.
Remember to run make down
when you're done working on the project to stop the application and associated services.
This repository follows the conventional commits guid lines https://www.conventionalcommits.org/en/v1.0.0/
This project template is open-source and available under the MIT License. Feel free to use it for your own projects and make any modifications as necessary.