yiisoft / yii2-app-advanced
Yii 2 Advanced Project Template
Package info
github.com/yiisoft/yii2-app-advanced
Type:project
pkg:composer/yiisoft/yii2-app-advanced
Requires
- php: >=7.4.0
- yiisoft/yii2: ~2.0.45
- yiisoft/yii2-bootstrap5: ~2.0.2
- yiisoft/yii2-symfonymailer: ~2.0.3
Requires (Dev)
- codeception/codeception: ^5.0.0 || ^4.0
- codeception/lib-innerbrowser: ^4.0 || ^3.0 || ^1.1
- codeception/module-asserts: ^3.0 || ^1.1
- codeception/module-filesystem: ^3.0 || ^2.0 || ^1.1
- codeception/module-yii2: ^1.1
- codeception/verify: ^3.0 || ^2.2
- phpunit/phpunit: ~9.5.0
- yiisoft/yii2-debug: ~2.1.0
- yiisoft/yii2-faker: ~2.0.0
- yiisoft/yii2-gii: ~2.2.0
- dev-master
- 2.0.54
- 2.0.53
- 2.0.52
- 2.0.51
- 2.0.50
- 2.0.49
- 2.0.48
- 2.0.47
- 2.0.46
- 2.0.45
- 2.0.44
- 2.0.43
- 2.0.42
- 2.0.41
- 2.0.40
- 2.0.39
- 2.0.38
- 2.0.37
- 2.0.36
- 2.0.35
- 2.0.34
- 2.0.33
- 2.0.32
- 2.0.31
- 2.0.26
- 2.0.22
- 2.0.19
- 2.0.18
- 2.0.17
- 2.0.16
- 2.0.14
- 2.0.13
- 2.0.12
- 2.0.11
- 2.0.10
- 2.0.9
- 2.0.8
- 2.0.7
- 2.0.6
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 2.0.0-rc
- 2.0.0-beta
- 2.0.0-alpha
This package is auto-updated.
Last update: 2026-03-21 21:23:58 UTC
README
Yii 2 Advanced Project Template
Yii 2 Advanced Project Template is a skeleton Yii 2 application best for developing complex Web applications with multiple tiers.
The template includes three tiers: front end, back end, and console, each of which is a separate Yii application.
The template is designed to work in a team development environment. It supports deploying the application in different environments.
Documentation is at docs/guide/README.md.
Docker
REQUIREMENTS
Important
- The minimum required PHP version of Yii is PHP
8.2.
Install via Composer
If you do not have Composer, you may install it by following the instructions at getcomposer.org.
You can then install this project template using the following commands:
composer create-project --prefer-dist yiisoft/yii2-app-advanced advanced
cd advanced
Frontend
Backend
DIRECTORY STRUCTURE
common
config/ contains shared configurations
mail/ contains view files for e-mails
models/ contains model classes used in both backend and frontend
tests/ contains tests for common classes
console
config/ contains console configurations
controllers/ contains console controllers (commands)
migrations/ contains database migrations
models/ contains console-specific model classes
runtime/ contains files generated during runtime
backend
assets/ contains application assets such as JavaScript and CSS
config/ contains backend configurations
controllers/ contains Web controller classes
models/ contains backend-specific model classes
runtime/ contains files generated during runtime
tests/ contains tests for backend application
views/ contains view files for the Web application
web/ contains the entry script and Web resources
frontend
assets/ contains application assets such as JavaScript and CSS
config/ contains frontend configurations
controllers/ contains Web controller classes
models/ contains frontend-specific model classes
runtime/ contains files generated during runtime
tests/ contains tests for frontend application
views/ contains view files for the Web application
web/ contains the entry script and Web resources
widgets/ contains frontend widgets
vendor/ contains dependent 3rd-party packages
environments/ contains environment-based overrides
Initialize the application for the Development environment:
php init --env=Development --overwrite=All
Now you should be able to access the application through the following URLs, assuming advanced is the directory
directly under the Web root.
http://localhost/advanced/frontend/web/
http://localhost/advanced/backend/web/
Install with Docker
Build and start the containers:
docker compose up -d --build
Install dependencies inside the container:
docker compose exec frontend composer update --prefer-dist --no-interaction
Initialize the application for the Development environment:
docker compose exec frontend php /app/init --env=Development --overwrite=All
After running init, update the database connection in common/config/main-local.php to use the mysql
service hostname:
'db' => [ 'class' => \yii\db\Connection::class, 'dsn' => 'mysql:host=mysql;dbname=yii2advanced', 'username' => 'yii2advanced', 'password' => 'secret', 'charset' => 'utf8', ],
You can then access the application through the following URLs:
http://127.0.0.1:20080 (frontend)
http://127.0.0.1:21080 (backend)
To run the test suite, also update common/config/test-local.php to use the mysql hostname and create the
test database:
'db' => [ 'dsn' => 'mysql:host=mysql;dbname=yii2advanced_test', ],
docker compose exec -T mysql mysql -uroot -pverysecret -e "CREATE DATABASE IF NOT EXISTS yii2advanced_test; GRANT ALL PRIVILEGES ON yii2advanced_test.* TO 'yii2advanced'@'%'; FLUSH PRIVILEGES;" docker compose exec -T frontend php /app/yii_test migrate --interactive=0 docker compose exec -T frontend vendor/bin/codecept build docker compose exec -T frontend vendor/bin/codecept run
NOTES:
- Minimum required Docker engine version
17.04for development (see Performance tuning for volume mounts) - The default configuration uses a host-volume in your home directory
~/.composer-docker/cachefor Composer caches
CONFIGURATION
Database
Edit the file common/config/main-local.php with real data, for example:
return [ 'components' => [ 'db' => [ 'class' => \yii\db\Connection::class, 'dsn' => 'mysql:host=localhost;dbname=yii2advanced', 'username' => 'root', 'password' => '1234', 'charset' => 'utf8', ], ], ];
When using Docker, the MySQL service is pre-configured. Update common/config/main-local.php to use:
'db' => [ 'class' => \yii\db\Connection::class, 'dsn' => 'mysql:host=mysql;dbname=yii2advanced', 'username' => 'yii2advanced', 'password' => 'secret', 'charset' => 'utf8', ],
Apply migrations:
php yii migrate
Or with Docker:
docker compose exec frontend php /app/yii migrate
NOTES:
- Yii won't create the database for you, this has to be done manually before you can access it. When using Docker, the MySQL service creates the database automatically.
- Check and edit the other files in the
config/directories to customize your application as required. - Refer to the README in the
testsdirectory for information specific to application tests.
TESTING
Tests are located in frontend/tests, backend/tests, and common/tests directories.
They are developed with Codeception PHP Testing Framework.
Tests can be executed by running:
vendor/bin/codecept run --env php-builtin
Or using the Composer script:
composer tests