@@ -8,7 +8,7 @@ as well as complete CRUD controllers.
...
@@ -8,7 +8,7 @@ as well as complete CRUD controllers.
Installing and configuring
Installing and configuring
--------------------------
--------------------------
Gii is an offical Yii extension. The preferred way to install this extension is through
Gii is an official Yii extension. The preferred way to install this extension is through
[composer](http://getcomposer.org/download/).
[composer](http://getcomposer.org/download/).
You can either run this command:
You can either run this command:
...
@@ -26,11 +26,14 @@ Or you can add this code to the require section of your `composer.json` file:
...
@@ -26,11 +26,14 @@ Or you can add this code to the require section of your `composer.json` file:
Once the Gii extension has been installed, you enable it by adding these lines to your application configuration file:
Once the Gii extension has been installed, you enable it by adding these lines to your application configuration file:
```php
```php
'modules'=>[
return[
'gii'=>[
'bootstrap'=>['gii'],
'class'=>'yii\gii\Module',
'modules'=>[
'gii'=>'yii\gii\Module',
// ...
],
],
]
// ...
];
```
```
You can then access Gii through the following URL:
You can then access Gii through the following URL:
...
@@ -39,7 +42,15 @@ You can then access Gii through the following URL:
...
@@ -39,7 +42,15 @@ You can then access Gii through the following URL:
http://localhost/path/to/index.php?r=gii
http://localhost/path/to/index.php?r=gii
```
```
> Note: if you are accessing gii from an IP address other than localhost, access will be denied by default. To circumvent that default, add the allowed IP addressess to the configuration:
If you have enabled pretty URLs, you may use the following URL:
```
http://localhost/path/to/index.php/gii
```
> Note: if you are accessing gii from an IP address other than localhost, access will be denied by default.
> To circumvent that default, add the allowed IP addresses to the configuration:
>
>
```php
```php
'gii'=>[
'gii'=>[
...
@@ -55,11 +66,12 @@ In basic application template configuration structure is a bit different so Gii
...
@@ -55,11 +66,12 @@ In basic application template configuration structure is a bit different so Gii
```php
```php
// ...
// ...
if(YII_ENV_DEV)
if(YII_ENV_DEV){
{
// configuration adjustments for 'dev' environment
// configuration adjustments for 'dev' environment
$config['bootstrap'][]='debug';
$config['bootstrap'][]='debug';
$config['modules']['debug']='yii\debug\Module';
$config['modules']['debug']='yii\debug\Module';
$config['bootstrap'][]='gii';
$config['modules']['gii']='yii\gii\Module';// <--- here
$config['modules']['gii']='yii\gii\Module';// <--- here
}
}
```
```
...
@@ -67,11 +79,12 @@ if (YII_ENV_DEV)
...
@@ -67,11 +79,12 @@ if (YII_ENV_DEV)
So in order to adjust IP address you need to do it like the following:
So in order to adjust IP address you need to do it like the following:
```php
```php
if(YII_ENV_DEV)
if(YII_ENV_DEV){
{
// configuration adjustments for 'dev' environment
// configuration adjustments for 'dev' environment
@@ -100,8 +113,8 @@ By default there are the following generators available:
...
@@ -100,8 +113,8 @@ By default there are the following generators available:
After choosing a generator by clicking on the "Start" button you will see a form that allows you to configure the
After choosing a generator by clicking on the "Start" button you will see a form that allows you to configure the
parameters of the generator. Fill out the form according to your needs and press the "Preview" button to get a
parameters of the generator. Fill out the form according to your needs and press the "Preview" button to get a
preview of the code that gii is about to generated. Dependend on the generator you chose and whether the files
preview of the code that gii is about to generated. Depending on the generator you chose and whether the files
already existed or not you will get an ouput similar to what you see in the following picuture:
already existed or not, you will get an output similar to what you see in the following picture:
![Gii preview](images/gii-preview.png)
![Gii preview](images/gii-preview.png)
...
@@ -143,7 +156,9 @@ If you open a folder `@app\vendor\yiisoft\yii2-gii\generators`, you'll see six f
...
@@ -143,7 +156,9 @@ If you open a folder `@app\vendor\yiisoft\yii2-gii\generators`, you'll see six f
```
```
This is name generator. If you open any of these folders, you can see the folder `default`. This folder is name of the template.
This is name generator. If you open any of these folders, you can see the folder `default`. This folder is name of the template.
Copy folder `@app\vendor\yiisoft\yii2-gii\generators\crud\default` to another location, for example `@app\myTemplates\crud\`. Now open this folder and modify any template to fit your desires, for example, add `errorSummary` in `views\_form.php`:
Copy folder `@app\vendor\yiisoft\yii2-gii\generators\crud\default` to another location, for example `@app\myTemplates\crud\`.
Now open this folder and modify any template to fit your desires, for example, add `errorSummary` in `views\_form.php`:
```php
```php
<?php
<?php
//...
//...
...
@@ -156,19 +171,21 @@ Copy folder `@app\vendor\yiisoft\yii2-gii\generators\crud\default` to another lo
...
@@ -156,19 +171,21 @@ Copy folder `@app\vendor\yiisoft\yii2-gii\generators\crud\default` to another lo
} ?>
} ?>
//...
//...
```
```
All, in fact our template ready. Now you need to tell GII about our template.The setting is made in the config file:
Now you need to tell GII about our template.The setting is made in the config file:
'myCrud'=>'@app\myTemplates\crud\default', //name tempate => path to template
'myCrud' => '@app\myTemplates\crud\default', //name template => path to template
]
]
]
]
],
],
...
@@ -180,7 +197,10 @@ Open the CRUD generator and you will see that in the field `Code Template` of fo
...
@@ -180,7 +197,10 @@ Open the CRUD generator and you will see that in the field `Code Template` of fo
Creating your own generators
Creating your own generators
----------------------------
----------------------------
Open the folder of any generator and you will see two files `form.php` and `Generator.php`. One is the form, the second is the class generator. For create your own generator, you need to create or override these classes in any folder. Again as in the previous paragraph customize configuration:
Open the folder of any generator and you will see two files `form.php` and `Generator.php`.
One is the form, the second is the class generator. For create your own generator, you need to create or
override these classes in any folder. Again as in the previous paragraph customize configuration:
- Bug #3128: Fixed the bug that `defaultRoles` set in RBAC manager was not working as specified (qiangxue)
- Bug #3128: Fixed the bug that `defaultRoles` set in RBAC manager was not working as specified (qiangxue)
- Bug #3153: Fixed the bug that using "between" operator to build a SQL query will cause a PHP notice (gonimar)
- Bug #3153: Fixed the bug that using "between" operator to build a SQL query will cause a PHP notice (gonimar)
- Enh #2837: Error page now shows arguments in stack trace method calls (samdark)
- Enh #2837: Error page now shows arguments in stack trace method calls (samdark)
- Enh #3088: The debug and gii modules will manage their own URL rules now (hiltonjanfield, qiangxue)
- Enh #3103: debugger panel is now not displayed when printing a page (githubjeka)
- Enh #3103: debugger panel is now not displayed when printing a page (githubjeka)
- Enh #3108: Added `yii\debug\Module::enableDebugLogs` to disable logging debug logs by default (qiangxue)
- Enh #3108: Added `yii\debug\Module::enableDebugLogs` to disable logging debug logs by default (qiangxue)
- Enh #3132: `yii\rbac\PhpManager` now supports more compact data file format (qiangxue)
- Enh #3132: `yii\rbac\PhpManager` now supports more compact data file format (qiangxue)
- Enh: Added support for using sub-queries when building a DB query with `IN` condition (qiangxue)
- Enh: Added support for using sub-queries when building a DB query with `IN` condition (qiangxue)
- Enh: Supported adding a new response formatter without the need to reconfigure existing formatters (qiangxue)
- Enh: Supported adding a new response formatter without the need to reconfigure existing formatters (qiangxue)
- Enh: Added `yii\web\UrlManager::addRules()` to simplify adding new URL rules (qiangxue)
- Chg: Replaced `clearAll()` and `clearAllAssignments()` in `yii\rbac\ManagerInterface` with `removeAll()`, `removeAllRoles()`, `removeAllPermissions()`, `removeAllRules()` and `removeAllAssignments()` (qiangxue)
- Chg: Replaced `clearAll()` and `clearAllAssignments()` in `yii\rbac\ManagerInterface` with `removeAll()`, `removeAllRoles()`, `removeAllPermissions()`, `removeAllRules()` and `removeAllAssignments()` (qiangxue)
- Chg: Added `$user` as the first parameter of `yii\rbac\Rule::execute()` (qiangxue)
- Chg: Added `$user` as the first parameter of `yii\rbac\Rule::execute()` (qiangxue)