Moved tools to Advanced topic, included simple setting up tools in Installation. Reworked CLI tool to print a template when no cli-config.php is defined.
This commit is contained in:
parent
bdfe6098a4
commit
a7d764f6c0
5 changed files with 107 additions and 24 deletions
|
@ -13,32 +13,47 @@
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* This software consists of voluntary contributions made by many individuals
|
* This software consists of voluntary contributions made by many individuals
|
||||||
* and is licensed under the LGPL. For more information, see
|
* and is licensed under the MIT license. For more information, see
|
||||||
* <http://www.doctrine-project.org>.
|
* <http://www.doctrine-project.org>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use Symfony\Component\Console\Helper\HelperSet;
|
||||||
|
use Doctrine\ORM\Tools\Console\ConsoleRunner;
|
||||||
|
|
||||||
(@include_once __DIR__ . '/../vendor/autoload.php') || @include_once __DIR__ . '/../../../autoload.php';
|
(@include_once __DIR__ . '/../vendor/autoload.php') || @include_once __DIR__ . '/../../../autoload.php';
|
||||||
$configFile = getcwd() . DIRECTORY_SEPARATOR . 'cli-config.php';
|
|
||||||
|
|
||||||
$helperSet = null;
|
$directories = array(getcwd(), getcwd() . DIRECTORY_SEPARATOR . 'config');
|
||||||
$commands = array();
|
|
||||||
if (file_exists($configFile)) {
|
$configFile = null;
|
||||||
if ( ! is_readable($configFile)) {
|
foreach ($directories as $directory) {
|
||||||
trigger_error(
|
$configFile = $directory . DIRECTORY_SEPARATOR . 'cli-config.php';
|
||||||
'Configuration file [' . $configFile . '] does not have read permission.', E_ERROR
|
|
||||||
);
|
if (file_exists($configFile)) {
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
require $configFile;
|
if ( ! file_exists($configFile)) {
|
||||||
|
ConsoleRunner::printCliConfigTemplate();
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! is_readable($configFile)) {
|
||||||
|
echo 'Configuration file [' . $configFile . '] does not have read permission.' . "\n";
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
$commands = array();
|
||||||
|
|
||||||
|
$helperSet = require $configFile;
|
||||||
|
|
||||||
|
if ( ! ($helperSet instanceof HelperSet)) {
|
||||||
foreach ($GLOBALS as $helperSetCandidate) {
|
foreach ($GLOBALS as $helperSetCandidate) {
|
||||||
if ($helperSetCandidate instanceof \Symfony\Component\Console\Helper\HelperSet) {
|
if ($helperSetCandidate instanceof HelperSet) {
|
||||||
$helperSet = $helperSetCandidate;
|
$helperSet = $helperSetCandidate;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$helperSet = ($helperSet) ?: new \Symfony\Component\Console\Helper\HelperSet();
|
|
||||||
|
|
||||||
\Doctrine\ORM\Tools\Console\ConsoleRunner::run($helperSet, $commands);
|
\Doctrine\ORM\Tools\Console\ConsoleRunner::run($helperSet, $commands);
|
||||||
|
|
|
@ -27,7 +27,6 @@ Getting Started
|
||||||
|
|
||||||
* **Setup**:
|
* **Setup**:
|
||||||
:doc:`Installation & Configuration <reference/configuration>` |
|
:doc:`Installation & Configuration <reference/configuration>` |
|
||||||
:doc:`Commandline Tools <reference/tools>`
|
|
||||||
|
|
||||||
* **Tutorial**:
|
* **Tutorial**:
|
||||||
:doc:`Code First <tutorials/getting-started>` |
|
:doc:`Code First <tutorials/getting-started>` |
|
||||||
|
@ -71,6 +70,7 @@ Advanced Topics
|
||||||
* :doc:`Architecture <reference/architecture>`
|
* :doc:`Architecture <reference/architecture>`
|
||||||
* :doc:`Advanced Configuration <reference/advanced-configuration>`
|
* :doc:`Advanced Configuration <reference/advanced-configuration>`
|
||||||
* :doc:`Limitations and knowns issues <reference/limitations-and-known-issues>`
|
* :doc:`Limitations and knowns issues <reference/limitations-and-known-issues>`
|
||||||
|
* :doc:`Commandline Tools <reference/tools>`
|
||||||
* :doc:`Transactions and Concurrency <reference/transactions-and-concurrency>`
|
* :doc:`Transactions and Concurrency <reference/transactions-and-concurrency>`
|
||||||
* :doc:`Filters <reference/filters>`
|
* :doc:`Filters <reference/filters>`
|
||||||
* :doc:`NamingStrategy <reference/namingstrategy>`
|
* :doc:`NamingStrategy <reference/namingstrategy>`
|
||||||
|
|
|
@ -92,3 +92,31 @@ Configuration <reference/advanced-configuration>` section.
|
||||||
You can learn more about the database connection configuration in the
|
You can learn more about the database connection configuration in the
|
||||||
`Doctrine DBAL connection configuration reference <http://docs.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html>`_.
|
`Doctrine DBAL connection configuration reference <http://docs.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html>`_.
|
||||||
|
|
||||||
|
Setting up the Commandline Tool
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
Doctrine ships with a number of command line tools that are very helpful
|
||||||
|
during development. You can call this command from the Composer binary
|
||||||
|
directory:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
$ php vendor/bin/doctrine
|
||||||
|
|
||||||
|
You need to register your applications EntityManager to the console tool
|
||||||
|
to make use of the tasks by creating a ``cli-config.php`` file with the
|
||||||
|
following content:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
// cli-config.php
|
||||||
|
require_once 'my_bootstrap.php';
|
||||||
|
|
||||||
|
// Any way to access the EntityManager from your application
|
||||||
|
$em = GetMyEntityManager();
|
||||||
|
|
||||||
|
$helperSet = new \Symfony\Component\Console\Helper\HelperSet(array(
|
||||||
|
'db' => new \Doctrine\DBAL\Tools\Console\Helper\ConnectionHelper($em->getConnection()),
|
||||||
|
'em' => new \Doctrine\ORM\Tools\Console\Helper\EntityManagerHelper($em)
|
||||||
|
));
|
||||||
|
|
|
@ -4,30 +4,29 @@ Tools
|
||||||
Doctrine Console
|
Doctrine Console
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
The Doctrine Console is a Command Line Interface tool for
|
The Doctrine Console is a Command Line Interface tool for simplifying common
|
||||||
simplifying common tasks during the development of a project that
|
administration tasks during the development of a project that uses Doctrine 2.
|
||||||
uses Doctrine 2.
|
|
||||||
|
|
||||||
Take a look at the :doc:`Configuration <configuration>` for more
|
Take a look at the :doc:`Installation and Configuration <configuration>`
|
||||||
information how to setup the console command.
|
chapter for more information how to setup the console command.
|
||||||
|
|
||||||
Getting Help
|
Display Help Information
|
||||||
~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Type ``php vendor/bin/doctrine-orm`` on the command line and you should see an
|
Type ``php vendor/bin/doctrine`` on the command line and you should see an
|
||||||
overview of the available commands or use the --help flag to get
|
overview of the available commands or use the --help flag to get
|
||||||
information on the available commands. If you want to know more
|
information on the available commands. If you want to know more
|
||||||
about the use of generate entities for example, you can call:
|
about the use of generate entities for example, you can call:
|
||||||
|
|
||||||
.. code-block:: php
|
.. code-block:: php
|
||||||
|
|
||||||
$> php vendor/bin/doctrine-orm orm:generate-entities --help
|
$> php vendor/bin/doctrine orm:generate-entities --help
|
||||||
|
|
||||||
|
|
||||||
Configuration
|
Configuration
|
||||||
~~~~~~~~~~~~~
|
~~~~~~~~~~~~~
|
||||||
|
|
||||||
Whenever the ``doctrine-orm`` command line tool is invoked, it can
|
Whenever the ``doctrine`` command line tool is invoked, it can
|
||||||
access all Commands that were registered by developer. There is no
|
access all Commands that were registered by developer. There is no
|
||||||
auto-detection mechanism at work. The Doctrine binary
|
auto-detection mechanism at work. The Doctrine binary
|
||||||
already registers all the commands that currently ship with
|
already registers all the commands that currently ship with
|
||||||
|
|
|
@ -23,8 +23,27 @@ use Symfony\Component\Console\Application;
|
||||||
use Symfony\Component\Console\Helper\HelperSet;
|
use Symfony\Component\Console\Helper\HelperSet;
|
||||||
use Doctrine\ORM\Version;
|
use Doctrine\ORM\Version;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Tools\Console\Helper\ConnectionHelper;
|
||||||
|
use Doctrine\ORM\Tools\Console\Helper\EntityManagerHelper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles running the Console Tools inside Symfony Console context.
|
||||||
|
*/
|
||||||
class ConsoleRunner
|
class ConsoleRunner
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Create a Symfony Console HelperSet
|
||||||
|
*
|
||||||
|
* @return HelperSet
|
||||||
|
*/
|
||||||
|
public static function createHelperSet(EntityManager $entityManager)
|
||||||
|
{
|
||||||
|
return new HelperSet(array(
|
||||||
|
'db' => new ConnectionHelper($entityManager->getConnection()),
|
||||||
|
'em' => new EntityManagerHelper($entityManager)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Runs console with the given helperset.
|
* Runs console with the given helperset.
|
||||||
*
|
*
|
||||||
|
@ -73,4 +92,26 @@ class ConsoleRunner
|
||||||
new \Doctrine\ORM\Tools\Console\Command\InfoCommand()
|
new \Doctrine\ORM\Tools\Console\Command\InfoCommand()
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static public function printCliConfigTemplate()
|
||||||
|
{
|
||||||
|
echo <<<'HELP'
|
||||||
|
You are missing a "cli-config.php" or "config/cli-config.php" file in your
|
||||||
|
project, which is required to get the Doctrine Console working. You can use the
|
||||||
|
following sample as a template:
|
||||||
|
|
||||||
|
<?php
|
||||||
|
use Doctrine\ORM\Tools\Console\ConsoleRunner;
|
||||||
|
|
||||||
|
// replace with file to your own project bootstrap
|
||||||
|
require_once 'bootstrap.php';
|
||||||
|
|
||||||
|
// replace with mechanism to retrieve EntityManager in your app
|
||||||
|
$entityManager = GetEntityManager();
|
||||||
|
|
||||||
|
return ConsoleRunner::createHelperSet($entityManager);
|
||||||
|
|
||||||
|
HELP;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue