Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
effd47db
Commit
effd47db
authored
Jun 22, 2014
by
Abderrahim Bajja
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/master'
Update from remote
parents
8dead867
60b38a1a
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
352 additions
and
44 deletions
+352
-44
caching-overview.md
docs/guide-ru/caching-overview.md
+19
-0
concept-behaviors.md
docs/guide/concept-behaviors.md
+14
-2
concept-events.md
docs/guide/concept-events.md
+12
-0
structure-controllers.md
docs/guide/structure-controllers.md
+7
-4
structure-filters.md
docs/guide/structure-filters.md
+264
-22
translation-status.md
docs/internals/translation-status.md
+1
-1
ActiveForm.php
extensions/bootstrap/ActiveForm.php
+1
-1
CHANGELOG.md
framework/CHANGELOG.md
+1
-0
HttpCache.php
framework/filters/HttpCache.php
+3
-3
PageCache.php
framework/filters/PageCache.php
+3
-4
BaseInflector.php
framework/helpers/BaseInflector.php
+1
-1
Session.php
framework/web/Session.php
+2
-1
InflectorTest.php
tests/unit/framework/helpers/InflectorTest.php
+1
-1
BreadcrumbsTest.php
tests/unit/framework/widgets/BreadcrumbsTest.php
+23
-4
No files found.
docs/guide-ru/caching-overview.md
0 → 100644
View file @
effd47db
Кэширование
=======
Кэширование — это простой и эффективный способ повысить производительность веб-приложения. Сохраняя относительно
статичные данные в кэше и извлекая их из кэша, когда потребуется, мы экономим время, затрачиваемое на генерацию
данных с нуля каждый раз.
Кэширование может использоваться на различных уровнях веб-приложения. На стороне сервера, на более низшем уровне мы
используем кэширование для хранения основных данных, таких как список последних статьей запрашиваемых из базы данных;
и на более высоком уровне, кэш может использоваться для хранения фрагментов или целых веб-страниц, например как результат
рендеринга последних статьей. На стороне клиента может использоваться HTTP-кэширование, чтобы сохранить содержимое
недавно посещенных страниц в кэше браузера.
Yii поддерживает все эти механизмы кэширования:
*
[
Кэширование данных
](
caching-data.md
)
*
[
Кэширование фрагментов
](
caching-fragment.md
)
*
[
Кэширование страниц
](
caching-page.md
)
*
[
HTTP-кэширование
](
caching-http.md
)
docs/guide/concept-behaviors.md
View file @
effd47db
...
...
@@ -136,8 +136,20 @@ $component->attachBehaviors([
]);
```
You may also attach behaviors through
[
configurations
](
concept-configurations.md
)
. For more details, please
refer to the
[
Configurations
](
concept-configurations.md#configuration-format
)
section.
You may also attach behaviors through
[
configurations
](
concept-configurations.md
)
like the following. For more details,
please refer to the
[
Configurations
](
concept-configurations.md#configuration-format
)
section.
```
php
[
'as myBehavior2'
=>
MyBehavior
::
className
(),
'as myBehavior3'
=>
[
'class'
=>
MyBehavior
::
className
(),
'prop1'
=>
'value1'
,
'prop2'
=>
'value2'
,
],
]
```
Detaching Behaviors <a name="detaching-behaviors"></a>
...
...
docs/guide/concept-events.md
View file @
effd47db
...
...
@@ -162,6 +162,18 @@ $foo->on(Foo::EVENT_HELLO, function ($event) {
},
$data
,
false
);
```
Besides calling the
`on()`
method, you may also attach event handlers in
[
configurations
](
concept-configurations.md
)
like the following. For more details, please refer to the
[
Configurations
](
concept-configurations.md#configuration-format
)
section.
```
php
[
'on hello'
=>
function
(
$event
)
{
echo
'hello event is triggered'
;
}
]
```
Detaching Event Handlers <a name="detaching-event-handlers"></a>
------------------------
...
...
docs/guide/structure-controllers.md
View file @
effd47db
...
...
@@ -2,10 +2,13 @@ Controllers
===========
Controllers are part of the
[
MVC
](
http://en.wikipedia.org/wiki/Model%E2%80%93view%E2%80%93controller
)
architecture.
They are objects responsible for processing requests and generating responses. In particular, after
taking over the control from
[
applications
](
structure-applications.md
)
, controllers will analyze incoming request data,
pass them to
[
models
](
structure-models.md
)
, inject model results into
[
views
](
structure-views.md
)
,
and finally generate outgoing responses.
They are objects of classes extending from
[
[yii\base\Controller
]
] and are responsible for processing requests and
generating responses. In particular, after taking over the control from
[
applications
](
structure-applications.md
)
,
controllers will analyze incoming request data, pass them to
[
models
](
structure-models.md
)
, inject model results
into
[
views
](
structure-views.md
)
, and finally generate outgoing responses.
## Actions <a name="actions"></a>
Controllers are composed by
*actions*
which are the most basic units that end users can address and request for
execution. A controller can have one or multiple actions.
...
...
docs/guide/structure-filters.md
View file @
effd47db
Filters
=======
> Note: This section is under development.
Filters are objects that run before and/or after
[
controller actions
](
structure-controllers.md#actions
)
. For example,
an access control filter may run before actions to ensure that they are allowed to be accessed by particular end users;
a content compression filter may run after actions to compress the response content before sending them out to end users.
You may apply some action filters to controller actions to accomplish tasks such as determining
who can access the current action, decorating the result of the action, etc
.
A filter may consist of a pre-filter (filtering logic applied
*before*
actions) and/or a post-filter (logic applied
*after*
actions)
.
An action filter is an instance of a class extending
[
[yii\base\ActionFilter
]
].
To use an action filter, attach it as a behavior to a controller or a module. The following
example shows how to enable HTTP caching for the
`index`
action:
## Using Filters <a name="using-filters"></a>
Filters are essentially a special kind of
[
behaviors
](
concept-behaviors.md
)
. Therefore, using filters is the same
as
[
using behaviors
](
concept-behaviors.md#attaching-behaviors
)
. You can declare filters in a controller class
by overriding its
[
[yii\base\Controller::behaviors()|behaviors()
]
] method like the following:
```
php
public
function
behaviors
()
{
return
[
'httpCache'
=>
[
'class'
=>
\yii\filters\HttpCache
::
className
()
,
'only'
=>
[
'index'
],
[
'class'
=>
'yii\filters\HttpCache'
,
'only'
=>
[
'index'
,
'view'
],
'lastModified'
=>
function
(
$action
,
$params
)
{
$q
=
new
\yii\db\Query
();
return
$q
->
from
(
'user'
)
->
max
(
'updated_at'
);
...
...
@@ -27,21 +31,259 @@ public function behaviors()
}
```
You may use multiple action filters at the same time. These filters will be applied in the
order they are declared in
`behaviors()`
. If any of the filter cancels the action execution,
the filters after it will be skipped.
By default, filters declared in a controller class will be applied to
*all*
actions in that controller. You can,
however, explicitly specify which actions the filter should be applied to by configuring the
[
[yii\base\ActionFilter::only|only
]
] property. In the above example, the
`HttpCache`
filter only applies to the
`index`
and
`view`
actions. You can also configure the
[
[yii\base\ActionFilter::except|except
]
] property to blacklist
some actions from being filtered.
Besides controllers, you can also declare filters in a
[
module
](
structure-modules.md
)
or
[
application
](
structure-applications.md
)
.
When you do so, the filters will be applied to
*all*
controller actions belonging to that module or application,
unless you configure the filters'
[
[yii\base\ActionFilter::only|only
]
] and
[
[yii\base\ActionFilter::except|except
]
]
properties like described above.
> Note: When declaring filters in modules or applications, you should use [routes](structure-controllers.md#routes)
instead of action IDs in the
[
[yii\base\ActionFilter::only|only
]
] and
[
[yii\base\ActionFilter::except|except
]
] properties.
This is because action IDs alone cannot fully specify actions within the scope of a module or application.
When multiple filters are configured for a single action, they are applied according to the rules described below,
*
Pre-filtering
-
Apply filters declared in the application in the order they are listed in
`behaviors()`
.
-
Apply filters declared in the module in the order they are listed in
`behaviors()`
.
-
Apply filters declared in the controller in the order they are listed in
`behaviors()`
.
-
If any of the filters cancel the action execution, the filters (both pre-filters and post-filters) after it will
not be applied.
*
Running the action if it passes the pre-filtering.
*
Post-filtering
-
Apply filters declared in the controller in the reverse order they are listed in
`behaviors()`
.
-
Apply filters declared in the module in the reverse order they are listed in
`behaviors()`
.
-
Apply filters declared in the application in the reverse order they are listed in
`behaviors()`
.
When you attach a filter to a controller, it can be applied to all actions of that controller;
If you attach a filter to a module (or application), it can be applied to the actions of any controller
within that module (or application).
## Creating Filters <a name="creating-filters"></a>
To create a new action filter, extend from
[
[yii\base\ActionFilter
]
] and override the
[
[yii\base\ActionFilter::beforeAction()|beforeAction()
]
] and
[
[yii\base\ActionFilter::afterAction()|afterAction()
]
]
[
[yii\base\ActionFilter::beforeAction()|beforeAction()
]
] and
/or
[
[yii\base\ActionFilter::afterAction()|afterAction()
]
]
methods. The former will be executed before an action runs while the latter after an action runs.
The return value of
[
[yii\base\ActionFilter::beforeAction()|beforeAction()
]
] determines whether
an action should be executed or not. If
`beforeAction()`
of a filter returns false, the filters after this one
will be skipped and the action will not be executed.
The return value of
[
[yii\base\ActionFilter::beforeAction()|beforeAction()
]
] determines whether an action should
be executed or not. If it is false, the filters after this one will be skipped and the action will not be executed.
The following example shows a filter that logs the action execution time:
```
php
namespace
app\components
;
use
Yii
;
use
yii\base\ActionFilter
;
class
ActionTimeFilter
extends
ActionFilter
{
private
$_startTime
;
public
function
beforeAction
(
$action
)
{
$this
->
_startTime
=
microtime
(
true
);
return
parent
::
beforeAction
(
$action
);
}
public
function
afterAction
(
$action
,
$result
)
{
$time
=
microtime
(
true
)
-
$this
->
_startTime
;
Yii
::
trace
(
"Action '
{
$action
->
uniqueId
}
' spent
$time
second."
);
return
parent
::
afterAction
(
$action
,
$result
);
}
}
```
## Core Filters <a name="core-filters"></a>
Yii provides a set of commonly used filters, found primarily under the
`yii\filters`
namespace. In the following,
we will briefly introduce these filters.
### [[yii\filters\AccessControl|AccessControl]] <a name="access-control"></a>
AccessControl provides simple access control based on a set of
[
[yii\filters\AccessControl::rules|rules
]
].
In particular, before an action is executed, AccessControl will examine the listed rules and find the first one
that matches the current context variables (such as user IP address, user login status, etc.) The matching
rule will dictate whether to allow or deny the execution of the requested action. If no rule matches, the access
will be denied.
The following example shows how to allow authenticated users to access the
`create`
and
`update`
actions
while denying all other users from accessing these two actions.
```
php
use
yii\filters\AccessControl
;
public
function
behaviors
()
{
return
[
'access'
=>
[
'class'
=>
AccessControl
::
className
(),
'only'
=>
[
'create'
,
'update'
],
'rules'
=>
[
// allow authenticated users
[
'allow'
=>
true
,
'roles'
=>
[
'@'
],
],
// everything else is denied by default
],
],
];
}
```
For more details about access control in general, please refer to the
[
Authorization
](
security-authorization.md
)
section.
### [[yii\filters\ContentNegotiator|ContentNegotiator]] <a name="content-negotiator"></a>
ContentNegotiator supports response format negotiation and application language negotiation. It will try to
determine the response format and/or language by examining
`GET`
parameters and
`Accept`
HTTP header.
In the following example, ContentNegotiator is configured to support JSON and XML response formats, and
English (United States) and German languages.
```
php
use
yii\filters\ContentNegotiator
;
use
yii\web\Response
;
public
function
behaviors
()
{
return
[
[
'class'
=>
ContentNegotiator
::
className
(),
'formats'
=>
[
'application/json'
=>
Response
::
FORMAT_JSON
,
'application/xml'
=>
Response
::
FORMAT_XML
,
],
'languages'
=>
[
'en-US'
,
'de'
,
],
],
];
}
```
Response formats and languages often need to be determined much earlier during
the
[
application lifecycle
](
structure-applications.md#application-lifecycle
)
. For this reason, ContentNegotiator
is designed in a way such that it can also be used as a
[
bootstrap component
](
structure-applications.md#bootstrap
)
besides filter. For example, you may configure it in the
[
application configuration
](
structure-applications.md#application-configurations
)
like the following:
```
php
use
yii\filters\ContentNegotiator
;
use
yii\web\Response
;
The
[
authorization
](
authorization.md
)
section of this guide shows how to use the
[
[yii\filters\AccessControl
]
] filter,
and the
[
caching
](
caching.md
)
section gives more details about the
[
[yii\filters\PageCache
]
] and
[
[yii\filters\HttpCache
]
] filters.
These built-in filters are also good references when you learn to create your own filters.
[
'bootstrap'
=>
[
[
'class'
=>
ContentNegotiator
::
className
(),
'formats'
=>
[
'application/json'
=>
Response
::
FORMAT_JSON
,
'application/xml'
=>
Response
::
FORMAT_XML
,
],
'languages'
=>
[
'en-US'
,
'de'
,
],
],
],
];
```
### [[yii\filters\HttpCache|HttpCache]] <a name="http-cache"></a>
HttpCache implements client-side caching by utilizing the
`Last-Modified`
and
`Etag`
HTTP headers.
For example,
```
php
use
yii\filters\HttpCache
;
public
function
behaviors
()
{
return
[
[
'class'
=>
HttpCache
::
className
(),
'only'
=>
[
'index'
],
'lastModified'
=>
function
(
$action
,
$params
)
{
$q
=
new
\yii\db\Query
();
return
$q
->
from
(
'user'
)
->
max
(
'updated_at'
);
},
],
];
}
```
Please refer to the
[
HTTP Caching
](
caching-http.md
)
section for more details about using HttpCache.
### [[yii\filters\PageCache|PageCache]] <a name="page-cache"></a>
PageCache implements server-side caching of whole pages. In the following example, PageCache is applied
to the
`index`
action to cache the whole page for maximum 60 seconds or until the count of entries in the
`post`
table changes. It also stores different versions of the page depending on the chosen application language.
```
php
use
yii\filters\PageCache
;
use
yii\caching\DbDependency
;
public
function
behaviors
()
{
return
[
'pageCache'
=>
[
'class'
=>
PageCache
::
className
(),
'only'
=>
[
'index'
],
'duration'
=>
60
,
'dependency'
=>
[
'class'
=>
DbDependency
::
className
(),
'sql'
=>
'SELECT COUNT(*) FROM post'
,
],
'variations'
=>
[
\Yii
::
$app
->
language
,
]
],
];
}
```
Please refer to the
[
Page Caching
](
caching-page.md
)
section for more details about using PageCache.
### [[yii\filters\RateLimiter|RateLimiter]] <a name="rate-limiter"></a>
RateLimiter implements a rate limiting algorithm based on the
[
leaky bucket algorithm
](
http://en.wikipedia.org/wiki/Leaky_bucket
)
.
It is primarily used in implementing RESTful APIs. Please refer to the
[
Rate Limiting
](
rest-rate-limiting.md
)
section
for details about using this filter.
### [[yii\filters\VerbFilter|VerbFilter]] <a name="verb-filter"></a>
VerbFilter checks if the HTTP request methods are allowed by the requested actions. If not allowed, it will
throw an HTTP 405 exception. In the following example, VerbFilter is declared to specify a typical set of allowed
request methods for CRUD actions.
```
php
use
yii\filters\VerbFilter
;
public
function
behaviors
()
{
return
[
'verbs'
=>
[
'class'
=>
VerbFilter
::
className
(),
'actions'
=>
[
'index'
=>
[
'get'
],
'view'
=>
[
'get'
],
'create'
=>
[
'get'
,
'post'
],
'update'
=>
[
'get'
,
'put'
,
'post'
],
'delete'
=>
[
'post'
,
'delete'
],
],
],
];
}
```
docs/internals/translation-status.md
View file @
effd47db
...
...
@@ -21,7 +21,7 @@ structure-controllers.md | Yes
structure-views.md | Yes
structure-models.md | Yes
structure-modules.md | Yes
structure-filters.md |
structure-filters.md |
Yes
structure-widgets.md |
structure-assets.md |
structure-extensions.md |
...
...
extensions/bootstrap/ActiveForm.php
View file @
effd47db
...
...
@@ -21,7 +21,7 @@ use yii\base\InvalidConfigException;
* use yii\bootstrap\ActiveForm;
*
* $form = ActiveForm::begin(['layout' => 'horizontal'])
*
```
* ```
*
* This will set default values for the [[yii\bootstrap\ActiveField|ActiveField]]
* to render horizontal form fields. In particular the [[yii\bootstrap\ActiveField::template|template]]
...
...
framework/CHANGELOG.md
View file @
effd47db
...
...
@@ -51,6 +51,7 @@ Yii Framework 2 Change Log
-
Bug #3909:
`Html::to()`
should not prefix base URL to URLs that already contain scheme (qiangxue)
-
Bug #3934: yii.handleAction() in yii.js does not correctly detect if a hyperlink contains useful URL or not (joni-jones, qiangxue)
-
Bug #3968: Messages logged in shutdown functions are not handled (qiangxue)
-
Bug #3996: Traversing
`Yii::$app->session`
may cause a PHP error (qiangxue)
-
Bug: Fixed inconsistent return of
`\yii\console\Application::runAction()`
(samdark)
-
Bug: URL encoding for the route parameter added to
`\yii\web\UrlManager`
(klimov-paul)
-
Bug: Fixed the bug that requesting protected or private action methods would cause 500 error instead of 404 (qiangxue)
...
...
framework/filters/HttpCache.php
View file @
effd47db
...
...
@@ -12,11 +12,11 @@ use yii\base\ActionFilter;
use
yii\base\Action
;
/**
*
The HttpCache provides functionality for caching via HTTP Last-Modified and Etag
headers.
*
HttpCache implements client-side caching by utilizing the `Last-Modified` and `Etag` HTTP
headers.
*
* It is an action filter that can be added to a controller and handles the `beforeAction` event.
*
* To use
AccessControl
, declare it in the `behaviors()` method of your controller class.
* To use
HttpCache
, declare it in the `behaviors()` method of your controller class.
* In the following example the filter will be applied to the `list`-action and
* the Last-Modified header will contain the date of the last update to the user table in the database.
*
...
...
@@ -24,7 +24,7 @@ use yii\base\Action;
* public function behaviors()
* {
* return [
*
'httpCache' =>
[
* [
* 'class' => 'yii\filters\HttpCache',
* 'only' => ['index'],
* 'lastModified' => function ($action, $params) {
...
...
framework/filters/PageCache.php
View file @
effd47db
...
...
@@ -13,15 +13,14 @@ use yii\base\Action;
use
yii\caching\Dependency
;
/**
*
The PageCache provides functionality for whole page caching
*
PageCache implements server-side caching of whole pages.
*
* It is an action filter that can be added to a controller and handles the `beforeAction` event.
*
* To use PageCache, declare it in the `behaviors()` method of your controller class.
* In the following example the filter will be applied to the `
list`-
action and
* In the following example the filter will be applied to the `
index`
action and
* cache the whole page for maximum 60 seconds or until the count of entries in the post table changes.
* It also stores different versions of the page depended on the route ([[varyByRoute]] is true by default),
* the application language and user id.
* It also stores different versions of the page depending on the application language.
*
* ~~~
* public function behaviors()
...
...
framework/helpers/BaseInflector.php
View file @
effd47db
...
...
@@ -415,7 +415,7 @@ class BaseInflector
public
static
function
slug
(
$string
,
$replacement
=
'-'
,
$lowercase
=
true
)
{
$string
=
static
::
transliterate
(
$string
);
$string
=
preg_replace
(
'/[^a-zA-Z=\s—–-]+/u'
,
''
,
$string
);
$string
=
preg_replace
(
'/[^a-zA-Z
0-9
=\s—–-]+/u'
,
''
,
$string
);
$string
=
preg_replace
(
'/[=\s—–-]+/u'
,
$replacement
,
$string
);
$string
=
trim
(
$string
,
$replacement
);
...
...
framework/web/Session.php
View file @
effd47db
...
...
@@ -507,6 +507,7 @@ class Session extends Component implements \IteratorAggregate, \ArrayAccess, \Co
*/
public
function
getIterator
()
{
$this
->
open
();
return
new
SessionIterator
;
}
...
...
@@ -516,6 +517,7 @@ class Session extends Component implements \IteratorAggregate, \ArrayAccess, \Co
*/
public
function
getCount
()
{
$this
->
open
();
return
count
(
$_SESSION
);
}
...
...
@@ -539,7 +541,6 @@ class Session extends Component implements \IteratorAggregate, \ArrayAccess, \Co
public
function
get
(
$key
,
$defaultValue
=
null
)
{
$this
->
open
();
return
isset
(
$_SESSION
[
$key
])
?
$_SESSION
[
$key
]
:
$defaultValue
;
}
...
...
tests/unit/framework/helpers/InflectorTest.php
View file @
effd47db
...
...
@@ -126,7 +126,7 @@ class InflectorTest extends TestCase
{
$data
=
[
''
=>
''
,
'hello world
'
=>
'hello-world
'
,
'hello world
123'
=>
'hello-world-123
'
,
'remove.!?[]{}…symbols'
=>
'removesymbols'
,
'minus-sign'
=>
'minus-sign'
,
'mdash—sign'
=>
'mdash-sign'
,
...
...
tests/unit/framework/widgets/BreadcrumbsTest.php
View file @
effd47db
...
...
@@ -13,16 +13,35 @@ use yii\widgets\Breadcrumbs;
class
BreadcrumbsTest
extends
\yiiunit\TestCase
{
private
$breadcrumbs
;
private
$app
;
public
function
setUp
()
{
$this
->
app
=
$this
->
mockApplication
();
Yii
::
setAlias
(
'@testWeb'
,
'/'
);
Yii
::
setAlias
(
'@testWebRoot'
,
'@yiiunit/data/web'
);
// dirty way to have Request object not throwing exception when running testHomeLinkNull()
$_SERVER
[
'SCRIPT_FILENAME'
]
=
"index.php"
;
$_SERVER
[
'SCRIPT_NAME'
]
=
"index.php"
;
$this
->
mockApplication
([],
'yii\web\Application'
);
$this
->
breadcrumbs
=
new
Breadcrumbs
();
}
public
function
testHomeLinkNull
()
{
$this
->
breadcrumbs
->
homeLink
=
null
;
$this
->
breadcrumbs
->
links
=
[
'label'
=>
'My Home Page'
,
'url'
=>
'http://my.example.com/yii2/link/page'
];
$expectedHtml
=
"<ul class=
\"
breadcrumb
\"
><li><a href=
\"
./index.php
\"
>Home</a></li>
\n
"
.
"<li class=
\"
active
\"
>My Home Page</li>
\n
"
.
"<li class=
\"
active
\"
>http://my.example.com/yii2/link/page</li>
\n
"
.
"</ul>"
;
ob_start
();
$this
->
breadcrumbs
->
run
();
$actualHtml
=
ob_get_contents
();
ob_end_clean
();
$this
->
assertEquals
(
$expectedHtml
,
$actualHtml
);
}
public
function
testEmptyLinks
()
{
$this
->
assertNull
(
$this
->
breadcrumbs
->
run
());
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment