Skip to content

Roadiz CMS v2+ development monorepo and environment

License

Notifications You must be signed in to change notification settings

roadiz/core-bundle-dev-app

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Roadiz development monorepo

Unit tests, static analysis and code style Packages Split

This is development app for Roadiz v2. It aggregates all Roadiz bundles and main repositories in one place:

  • DocGenerator
  • Documents
  • DtsGenerator
  • EntityGenerator
  • Jwt
  • Markdown
  • Models
  • OpenId
  • Random
  • RoadizCompatBundle
  • RoadizCoreBundle
  • RoadizFontBundle
  • RoadizRozierBundle
  • RoadizTwoFactorBundle
  • RoadizUserBundle
  • Rozier

If you want to start a new headless project with Roadiz, check https://github.com/roadiz/skeleton instead.

Install

  • Clone this repository containing all monorepo packages in lib directory
  • Checkout develop branch
  • Initialize git flow init to use GitFlow branching model
  • Create a .env.local file with mandatory APP_SECRET and JWT_PASSPHRASE vars minimum
  • Create a compose.override.yaml file to expose containers ports
  • Run composer install to install all dependencies and run scripts. Symfony packages may add some config files and alter your compose.yml file, you can safely rollback to the original one

Run development server

  • Run docker compose to get a local database and Solr server: docker compose up -d
  • Install Roadiz database fixture: docker compose exec app bin/console install
  • Install development fixtures: docker compose exec app bin/console app:install
  • Create a user: docker compose exec app bin/console users:create -s -b -m $EMAIL $EMAIL

Manual configuration

These require a manual configuration in config/packages/*.yaml files and cannot be injected in Container, you'll find configuration example in RoadizCoreBundle/config/packages and RoadizCompatBundle/config/packages folders:

  • Doctrine ORM mapping
  • Doctrine migrations path
  • JMS Serializer naming strategy
  • Monolog custom doctrine handler
  • Roadiz security scheme

Run tests

make test

Note that phpstan can issue wrong errors if your lib/* bundles are symlinked.

Monorepo tools

Roadiz development env uses: https://github.com/symplify/monorepo-builder

  • vendor/bin/monorepo-builder merge: Makes sure all your packages deps are in development repository and
  • vendor/bin/monorepo-builder validate: Make sure all your packages use the same version
  • vendor/bin/monorepo-builder release patch --dry-run: List all steps to do when release a new tag (do not actually perform this when using GitFlow)

Use Frankenphp

Roadiz can be run with frankenphp instead of PHP-FPM + Nginx. If you want to give it a try, override services app, nginx and varnish in your compose.override.yml

Use the target php-dev-franken instead of php-dev.

We use dunglas/frankenphp image with the tag of your PHP version and Debian Bookworm.

Using frankenphp allows you to remove docker/varnish and docker/nginx folders in your project.