From 7c8a9c0f9a2439bc0559ac5d7941327b057a6a06 Mon Sep 17 00:00:00 2001 From: Alexander Date: Wed, 18 Jan 2012 20:50:20 +0100 Subject: [PATCH] Initial draft for filter documentation --- en/reference/filters.rst | 68 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 en/reference/filters.rst diff --git a/en/reference/filters.rst b/en/reference/filters.rst new file mode 100644 index 000000000..487c52c8d --- /dev/null +++ b/en/reference/filters.rst @@ -0,0 +1,68 @@ +Filters +======= + +Doctrine 2.2 features a filter system that allows the developer to add SQL to +the conditional clauses of queries, regardless the place where the SQL is +generated (e.g. from a DQL query, or by loading associated entities). To give +you an idea on how it works, this chapter starts with an example of a filter. + + +Example filter class +-------------------- +Throughout this document the example ``MyLocaleFilter`` class will be used to +illustrate how the filter feature works. A filter class should extend the base +``Doctrine\ORM\Query\Filter\SQLFilter`` class and implement the ``addFilterConstraint`` +method. The method receives the ClassMetadata of the filtered entity and the +table alias of the table of the entity. + +.. code-block:: php + reflClass->getInterfaceNames())) { + return ""; + } + + return $targetTableAlias.'.locale = ' . $this->getParameter('locale'); + } + } + + + + +Configuration +------------- +Filter classes are added to the configuration as following: + +.. code-block:: php + addFilter("locale", "\Doctrine\Tests\ORM\Functional\MyLocaleFilter"); + + +The ``addFilter()`` method takes a name for the filter and the name of the +class responsible for the actual filtering. + + +Enabling Filters and Setting Parameters +--------------------------------------------------- +Filters can be enabled via the ``FilterCollection`` that is available in the +``EntityManager``. The ``enable`` function will return the filter object. This +object can be used to set certain parameters for the filter. + +.. code-block:: php + getFilters()->enable("locale"); + $filter->setParameter('locale', 'en'); + + +Disabling Filters +----------------- +.. code-block:: php + $filter = $em->getFilters()->disable("locale");