Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/venturaproject/symfony-project
Symfony application structured to adhere to best practices in software architecture, implementing various design patterns and principles.
https://github.com/venturaproject/symfony-project
cqrs-pattern ddd-architecture docker docker-compose repository-pattern symfony
Last synced: about 2 months ago
JSON representation
Symfony application structured to adhere to best practices in software architecture, implementing various design patterns and principles.
- Host: GitHub
- URL: https://github.com/venturaproject/symfony-project
- Owner: venturaproject
- Created: 2024-07-17T14:18:04.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-10-15T05:50:47.000Z (3 months ago)
- Last Synced: 2024-10-20T12:35:11.955Z (3 months ago)
- Topics: cqrs-pattern, ddd-architecture, docker, docker-compose, repository-pattern, symfony
- Language: PHP
- Homepage:
- Size: 399 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: Readme.md
Awesome Lists containing this project
README
# Symfony Application Overview
This repository contains a Symfony application structured to adhere to best practices in software architecture, implementing various design patterns and principles. Below is an overview of the implemented patterns and the directory structure:
## Implemented Design Patterns and Architectural Principles
### Repository Pattern
The repository pattern is implemented to abstract the data access layer from the domain logic.
- **UserRepositoryInterface**: Defines methods to interact with the User entity.
- **UserRepository**: Concrete implementation using Doctrine for data persistence.### Data Transfer Object (DTO)
Data Transfer Objects are used to transfer data between different layers of the application.
- **UserDTO**: Represents a data structure for transferring user-related information.
### Command Query Responsibility Segregation (CQRS)
CQRS separates commands (write operations) from queries (read operations).
- **CreateUserCommand**: Represents a command to create a new user.
- **CreateUserCommandHandler**: Handles the CreateUserCommand to persist a new user.### Domain-Driven Design (DDD)
The application structure follows DDD principles to organize code around business domains.
- **Domain**: Contains domain logic and entities.
- **Application**: Implements use cases and application services.
- **Infrastructure**: Provides implementations for repositories, services, and external dependencies.### Onion Architecture
The application architecture is based on the Onion Architecture pattern, emphasizing separation of concerns and dependency inversion.
- **Core (Domain)**: Contains the core business logic and domain entities.
- **Application Services**: Implements application-specific logic and use cases.
- **Infrastructure**: Handles external dependencies such as database access and third-party integrations.
- **Shared**: Contains shared interfaces and utilities used across different layers.## Directory Structure
```
├── Products
│ ├── Application
│ │ ├── Command
│ │ │ ├── CreateProduct
│ │ │ │ ├── CreateProductCommand.php
│ │ │ │ └── CreateProductCommandHandler.php
│ │ │ └── CreateProductConsoleCommand.php
│ │ ├── DTO
│ │ │ └── ProductDTO.php
│ │ └── Query
│ │ ├── GetActiveProducts
│ │ │ ├── GetActiveProductsQuery.php
│ │ │ └── GetActiveProductsQueryHandler.php
│ │ └── GetProductById
│ │ ├── GetProductByIdQuery.php
│ │ └── GetProductByIdQueryHandler.php
│ ├── Domain
│ │ ├── Entity
│ │ │ └── Product.php
│ │ ├── Factory
│ │ │ └── ProductFactory.php
│ │ └── Repository
│ │ └── ProductRepositoryInterface.php
│ └── Infrastructure
│ ├── Database
│ │ └── ORM
│ │ └── Product.orm.xml
│ └── Repository
│ └── ProductRepository.php
├── Shared
│ ├── Application
│ │ ├── Command
│ │ │ ├── CommandBusInterface.php
│ │ │ ├── CommandHandlerInterface.php
│ │ │ └── CommandInterface.php
│ │ └── Query
│ │ ├── QueryBusInterface.php
│ │ ├── QueryHandlerInterface.php
│ │ └── QueryInterface.php
│ ├── Domain
│ │ └── Service
│ │ └── UlidService.php
│ └── Infrastructure
│ ├── ApiResource
│ │ └── .gitignore
│ ├── Bus
│ │ ├── CommandBus.php
│ │ └── QueryBus.php
│ ├── Controller
│ │ ├── HealthCheckAction.php
│ │ ├── HomepageController.php
│ │ ├── PhpinfoController.php
│ │ ├── ProductController.php
│ │ └── WeatherController.php
│ ├── Database
│ │ ├── Fixtures
│ │ │ └── ProductFixtures.php
│ │ └── Migrations
│ │ ├── Version20240706235206.php
│ │ ├── Version20240726082748.php
│ │ └── Version20240726165031.php
│ ├── EventSubscriber
│ │ └── RouteNotFoundSubscriber.php
│ ├── Form
│ │ └── CityType.php
│ ├── Kernel.php
│ └── Service
│ ├── MailService.php
│ └── OpenWeatherMapService.php
└── Users
├── Application
│ ├── Command
│ │ ├── CreateUser
│ │ │ ├── CreateUserCommand.php
│ │ │ └── CreateUserCommandHandler.php
│ │ ├── CreateUserConsoleCommand.php
│ │ ├── EraseUserCredentials
│ │ │ ├── EraseUserCredentialsCommand.php
│ │ │ └── EraseUserCredentialsCommandHandler.php
│ │ └── EraseUserCredentialsConsoleCommand.php
│ ├── DTO
│ │ └── UserDTO.php
│ └── Query
│ └── FindUserByEmail
│ ├── FindUserByEmailQuery.php
│ └── FindUserByEmailQueryHandler.php
├── Domain
│ ├── Entity
│ │ └── User.php
│ ├── Factory
│ │ └── UserFactory.php
│ ├── Repository
│ │ └── UserRepositoryInterface.php
│ └── Service
│ └── UserCredentialsService.php
└── Infrastructure
├── Database
│ └── ORM
│ └── User.orm.xml
└── Repository
└── UserRepository.php
```## API Connections and Service Examples
In addition to the core architectural patterns and principles implemented, this application also includes examples of how to connect to external APIs and create associated services. These examples are designed to demonstrate best practices for integrating external systems and managing service dependencies.
### API Connections
- **OpenWeatherMapService**: This service provides an example of how to interact with the OpenWeatherMap API to fetch weather data. It demonstrates how to:
- Configure API keys and endpoints.
- Handle API requests and responses.
- Implement error handling and data processing.- **Location**: `Shared/Infrastructure/Service/OpenWeatherMapService.php`
### Service Creation
- **MailService**: This service serves as an example for integrating with email systems. It shows how to:
- Configure email sending capabilities.
- Create methods for composing and sending emails.
- Implement integration with external email providers or SMTP servers.- **Location**: `Shared/Infrastructure/Service/MailService.php`
These examples provide a foundation for building and integrating additional services into the application, adhering to the principles of clean architecture and separation of concerns.