curtiskelsey / doctrine-repo-helper
Generates a trait to help ease the access of custom repo methods
Requires
- php: ^7.0
- doctrine/doctrine-orm-module: ^1.0 || ^2.0
- zendframework/zend-code: ^2.0 || ^3.0
Requires (Dev)
- codeception/codeception: ^2.5
- league/factory-muffin: ^3.0
- league/factory-muffin-faker: ^2.0
- phpunit/phpunit: ^7.0.3
- roave/security-advisories: dev-master
- squizlabs/php_codesniffer: ^2.7
- zendframework/zend-mvc: ^2.0 || ^3.0
- zendframework/zend-mvc-console: ^1.0
- zfcampus/zf-development-mode: ^2.0 || ^3.0
This package is auto-updated.
Last update: 2024-11-11 16:06:03 UTC
README
This package was created for developers using the doctrine/doctrine-orm-module
to provide a CLI command for generating custom repository getter methods. Adds:
php public/index.php orm:generate-repository-trait
to the doctrine-orm-module cli
.
Introduction
Ever worked with Doctrine custom repositories and suffered through
/** @var ExampleRepository $exampleRepo */
$exampleRepo = $this->em->getRepository(Example::class);
$exampleRepo->myMethod();
just to get autocomplete in your IDE?
With this package you can run
php public/index.php orm:generate-repository-trait
To create a trait that will simplify working with custom repositories. Just use the trait it creates to get the magic
use CustomRepositoryAwareTrait;
public function test()
{
$result = $this->getExampleRepository()->myMethod();
}
Setup
You can start with
composer require curtiskelsey/doctrine-repo-helper
then be sure to add
'DoctrineRepoHelper'
to your Zend application's list of loaded modules.
Options
Several options are provided to allow control over the trait created and what entities it serves:
php public/index.php orm:generate-repository-trait --help
Description:
Generate a repository helper trait
Usage:
orm:generate-repository-trait [options]
Options:
--namespace[=NAMESPACE] Declares the namespace
-o, --output[=OUTPUT] Output path [default: "/var/www"]
-c, --className[=CLASSNAME] Classname of the trait [default: "CustomRepositoryAwareTrait"]
--em-getter[=EM-GETTER] Property or method name to access the EntityManager [default: "getObjectManager()"]
-f, --force Overwrite existing trait
--filter[=FILTER] Filter the list of entities getters are created for
-h, --help Display this help message
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi Force ANSI output
--no-ansi Disable ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
Help:
The generate repository trait command creates a trait that will allow your development
environment to autocomplete custom repository methods
Custom output directory
php public/index.php orm:generate-repository-trait -o My/Special/Path
Custom trait class name and namespace
php public/index.php orm:generate-repository-trait -c SpecialName --namespace=Special\\Namespace
Custom entity manager accessor
php public/index.php orm:generate-repository-trait --em-getter=getMyEntityManager()
Overwrite existing trait file
php public/index.php orm:generate-repository-trait -f
Filter the entity repositories used within the generated trait
php public/index.php orm:generate-repository-trait --filter=Cast
# Only inserts repo getters for entities where "Cast" is found withing the FQCN string
Development
Quickstart
git clone
vagrant up
vagrant ssh
php public/index.php orm:schema-tool:update -f
php public/index.php orm:generate-repository-trait