yiisoft/yii2-app-advanced
Yii 2 Advanced Application Template: a starter project for building Yii2 apps with separate frontend and backend, shared common code, environment-specific configs, and ready-to-use tools for development, testing, and deployment.
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.
[!IMPORTANT]
- The minimum required PHP version of Yii is PHP
8.2.
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
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/
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:
17.04 for development (see Performance tuning for volume mounts)~/.composer-docker/cache for Composer cachesEdit 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:
config/ directories to customize your application as required.tests directory for information specific to application tests.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
How can I help you explore Laravel packages today?