Skip to content

Latest commit

 

History

History
160 lines (117 loc) · 8.77 KB

README.md

File metadata and controls

160 lines (117 loc) · 8.77 KB

yii2-advanced-template

Yii2-advanced-template is based on yii2-app-advanced created by yii2 core developers. There are several upgrades made to this template.

  1. This template has additional features listed at the end of this guide.
  2. Application structure has been changed to be 'shared hosting friendly'.

Installation

I am assuming that you know how to: install and use Composer, and install additional packages/drivers that may be needed for you to run everything on your system. In case you are new to all of this, you can check my guides for installing default yii2 application templates, provided by yii2 developers, on Windows 8 and Ubuntu based Linux operating systems, posted on www.freetuts.org.

  1. Create database that you are going to use for your application (you can use phpMyAdmin or any other tool you like).

  2. Now open up your console and cd to your web root directory, for example: cd /var/www/sites/

  3. Run the Composer create-project command:

    composer create-project nenad/yii2-advanced-template advanced

  4. Once template is downloaded, you need to initialize it in one of two environments: development (dev) or production (prod). Change your working directory to _protected and execute php init command.

    cd advanced/_protected/

    php init

    Type 0 for development, execute coomant, type yes to confirm, and execute again.

  5. Now you need to tell your application to use database that you have previously created. Open up main-local.php config file in advanced/_protected/common/config/main-local.php and adjust your connection credentials.

  6. Back to the console. It is time to run yii migrations that will create necessary tables in our database. While you are inside _protected folder execute ./yii migrate command:

    ./yii migrate or if you are on Windows: yii migrate

  7. Execute rbac controller init action that will populate our rbac tables with default roles and permissions:

    ./yii rbac/init or if you are on Windows: yii rbac/init

You are done, you can start your application in your browser.

*Tip: if your application name is, for example, advanced, to see the frontend side of it you just have to visit this url in local host: localhost/advanced. To see backend side, this is enough: localhost/advanced/backend.

Note: First user that signs up will get 'The Creator' (super admin) role. This is supposed to be you. This role have all possible super powers :) . Every other user that signs up after the first one will get 'member' role. Member is just normal authenticated user.

Testing

If you want to run tests you should create additional database that will be used to store your testing data. Usually testing database will have the same structure like the production one. I am assuming that you have Codeception installed globally, and that you know how to use it. Here is how you can set up everything easily:

  1. Let's say that you have created database called advanced. Go create the testing one called advanced_tests.

  2. Inside your main-local.php config file change database you are going to use to advanced_tests.

  3. Open up your console and cd to the _protected folder of your application.

  4. Run the migrations again: ./yii migrate ( on Windows it is yii migrate)

  5. Run rbac/init again: ./yii rbac/init ( on Windows it is yii rbac/init)

  6. Now you can tell your application to use your advanced database again instead of advanced_tests. Adjust your main-local.php config file again.

  7. Now you are ready to tell Codeception to use advanced_tests database.

    Inside: _protected/tests/codeception/config/config.php file tell your db to use advanced_tests database.

  8. Start your php server inside the root of your application: php -S localhost:8080 (if the name of your application is advanced, then root is advanced folder)

  9. To run tests written for frontend side of your application cd to _protected/tests/codeception/frontend , run codecept build and then run your tests.

  10. Take similar steps like in step 9 for backend and common tests.

Directory structure

_protected
    backend
        assets/              contains backend assets definition
        config/              contains backend configurations
        controllers/         contains Web controller classes
        helpers/             contains helper classes
        models/              contains backend-specific model classes
        runtime/             contains files generated during runtime
        views/               contains view files for the Web application
    common
        config/              contains shared configurations
        mail/                contains view files for e-mails
        models/              contains model classes used in both backend and frontend
        rbac/                contains role based access control 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
    environments             contains environment-based overrides
    frontend
        assets/              contains frontend assets definition
        config/              contains frontend configurations
        controllers/         contains Web controller classes
        models/              contains frontend-specific model classes
        runtime/             contains files generated during runtime
        views/               contains view files for the Web application
        widgets/             contains frontend widgets

assets                   contains application assets generated during runtime
backend                  contains the entry script and Web resources for backend side of application
themes                   contains frontend themes

Features

  • Signup with/without account activation
    • The Creator (super admin) can chose whether or not new users need to activate their account using email account activation system before they can log in. (see: backend/setting).
  • Login using email/password or username/password combo.
    • The Creator (super admin) can chose how users will login into system. They can log in either by using their username|password combo or email|password. (see: backend/setting).
  • Rbac tables are installed with other migrations when you run yii migrate command.
    • RbacController's init() action will insert 4 roles and 5 permissions in our rbac tables created by migration.
    • Roles can be easily assigned to users by administrators of the site (see: backend/user).
    • Nice example of how to use rbac in your code is given in this application. See: BackendController.
  • Session data is stored in database out of box.
  • The Creator role (super admin) can use system settings that comes with template (see: backend/setting).
  • Theming is supported out of box.
  • Administrators and The Creator can update their account.
  • Password strength validation and strength meter.
  • All functionalities of default advanced template are included in this template.
  • Code is heavily commented out.

Password strength guide

Since 1.1.1 version has been released, password strength extension has been included as a core part of improved templates. Usage is very simple:

In our signup and account update forms password strength meter is always displayed when users are entering their password. This will give them visual representation of their password strength.
But this is not all. As The Creator you have option in your settings "Force Strong Password" that you can use. If you turn it on, users will be forced to use strong passwords according to preset you chose. For example if you use normal preset, user will be forced to use at least 8 characters long password, with at least one upper-case and one lower-case letter, plus at least one digit.

In our account update form for admins and The Creator, force strong password is always turned on. This is because admins and super admin should always use strong passwords!

Choosing presets:

By default normal preset is used for both signup and account edit forms. if you want to customize which preset is used, see SignupForm model and User model. You will see rules declared for using strong passwords. Presets are located in vendor/nenad/yii2-password-strength/presets.php. You can chose some other preset declared in presets.php, or create new ones.