regniblod / symfony-ddd-edition
A Symfony standard skeleton following DDD architecture.
Installs: 48
Dependents: 0
Suggesters: 1
Security: 0
Stars: 78
Watchers: 6
Forks: 7
Open Issues: 0
Type:project
Requires
- php: >=5.5.9
- doctrine/doctrine-bundle: ^1.6
- doctrine/doctrine-cache-bundle: ^1.2
- doctrine/orm: ^2.5
- incenteev/composer-parameter-handler: ^2.0
- sensio/distribution-bundle: ^5.0
- sensio/framework-extra-bundle: ^3.0.2
- symfony/monolog-bundle: ^2.8
- symfony/polyfill-apcu: ^1.0
- symfony/swiftmailer-bundle: ^2.3
- symfony/symfony: 3.2.x-dev
Requires (Dev)
This package is not auto-updated.
Last update: 2020-11-27 04:27:38 UTC
README
Symfony Standard DDD Edition
Welcome to the Symfony Standard DDD Edition - a fully-functional Symfony application with DDD architecture that you can use as the skeleton for your new applications.
For details on how to download and get started with Symfony, see the Installation chapter of the Symfony Documentation.
Installing the Symfony Standard DDD Edition
When it comes to installing the Symfony Standard DDD Edition, you have the following options.
Use Composer (recommended)
As Symfony uses Composer to manage its dependencies, the recommended wayto create a new project is to use it.
If you don't have Composer yet, download it following the instructions on http://getcomposer.org/ or just run the following command:
curl -s http://getcomposer.org/installer | php
Then, use the create-project
command to generate a new Symfony application:
php composer.phar create-project regniblod/symfony-ddd-edition --stability=dev path/to/install
Composer will install Symfony and all its dependencies under the path/to/install
directory.
Download an Archive File
To quickly test Symfony, you can also download an archive of the Standard DDD Edition and unpack it somewhere under your web server root directory.
If you downloaded an archive "without vendors", you also need to install all the necessary dependencies. Download composer (see above) and run the following command:
php composer.phar install
Checking your System Configuration
Before starting coding, make sure that your local system is properly configured for Symfony.
Execute the check.php
script from the command line:
php bin/symfony_requirements
Access the config.php
script from a browser:
http://localhost/path/to/symfony/config.php
If you get any warnings or recommendations, fix them before moving on.
Getting started with Symfony
This distribution is meant to be the starting point for your Symfony applications.
A great way to start learning Symfony is via the Quick Tour, which will take you through all the basic features of Symfony2.
Once you're feeling good, you can move onto reading the official Symfony2 book.
A default bundle, ModuleBundle
, shows you Symfony DDD architecture in action. After playing with it, you can remove it by following these steps:
- remove the routing entries referencing ModuleBundle in
app/config/routing.yml
. - remove the ModuleBundle from the registered bundles in
app/AppKernel.php
. - remove
src/Project/Module
andtests/Project/Module
directories. - Remove all the
.gitkeep
files:find . -name .git -prune -o -type d -empty -exec touch {}/.gitkeep \;
How to add a new module
Use the command symfony-ddd:generator:create-module <module_name>
to create a new module with the complete src and tests directory structure, bundle, services and repositories files, routing and Doctrine mapping.
What's inside?
The Symfony Standard DDD Edition is configured with the following defaults:
- A ModuleBundle you can use to start coding.
- Twig as the only configured template engine.
- Doctrine ORM/DBAL.
- Swiftmailer.
- Annotations enabled for everything.
It comes pre-configured with the following bundles:
- FrameworkBundle - The core Symfony framework bundle
- SensioFrameworkExtraBundle - Adds several enhancements, including template and routing annotation capability
- DoctrineBundle - Adds support for the Doctrine ORM
- TwigBundle - Adds support for the Twig templating engine
- SecurityBundle - Adds security by integrating Symfony's security component
- SwiftmailerBundle - Adds support for Swiftmailer, a library for sending emails
- MonologBundle - Adds support for Monolog, a logging library
- WebProfilerBundle (in dev/test env) - Adds profiling functionality and the web debug toolbar
- SensioDistributionBundle (in dev/test env) - Adds functionality for configuring and working with Symfony distributions
- SensioGeneratorBundle (in dev/test env) - Adds code generation capabilities
- DebugBundle (in dev/test env) - Adds Debug and VarDumper component integration
- SymfonyDDDGeneratorBundle (in dev/test env) - Adds code generation capabilities specifically for this Symfony distribution.
All libraries and bundles included in the Symfony Standard Edition are released under the MIT or BSD license.
Architecture
TODO: Explain different layers.
Folder structure
src
└── Project
└── Module
├── Application
│ └── ModuleBundle
│ ├── Command
│ ├── Controller
│ ├── DependencyInjection
│ │ └── Compiler
│ └── Resources
│ ├── config
│ │ └── doctrine
│ └── views
│ └── default
├── Domain
│ ├── Component
│ ├── Event
│ ├── Exception
│ ├── Model
│ ├── Repository
│ ├── Service
│ └── Value
└── Infrastructure
├── Migrations
│ └── Doctrine
├── Repository
│ └── Doctrine
└── Service
Inspiration
- @moein and our work at trivago.
- https://github.com/PhpFriendsOfDdd/state-of-the-union
Other implementations:
- https://github.com/josecelano/ddd-symfony-sample
- https://github.com/tyx/ddd-sample-symfony
- https://github.com/leopro/trip-planner
- https://github.com/tyx/cqrs-php-sandbox
- https://github.com/dddinphp/ddd
- https://github.com/codeliner/php-ddd-cargo-sample
- https://github.com/qandidate-labs/broadway
- https://github.com/jgimeno/taskreporter
- https://github.com/ddd-php/ddd-components
- https://github.com/webdevilopers/php-ddd
ToDo
- Explain architecture.
- Create sample app.