fsi / doctrine-extensions-bundle
FSi Doctrine extensions bundle.
Installs: 29 312
Dependents: 2
Suggesters: 0
Security: 0
Stars: 3
Watchers: 10
Forks: 8
Open Issues: 1
Type:symfony-bundle
Requires
- php: ^7.4|^8.0
- doctrine/doctrine-bundle: ^1.2|^2.0
- fsi/doctrine-extensions: ^2.0
- knplabs/knp-gaufrette-bundle: ~0.6
- sensio/framework-extra-bundle: ^5.0
- symfony/form: ^4.4|^5.0
- symfony/framework-bundle: ^4.4|^5.0
- symfony/http-foundation: ^4.4|^5.0
- symfony/options-resolver: ^4.4|^5.0
- symfony/twig-bundle: ^4.4|^5.0
- symfony/validator: ^4.4|^5.0
- twig/twig: ^2.11|^3.0
Requires (Dev)
- doctrine/orm: ^2.5
- friends-of-phpspec/phpspec-expect: ^3.0|^4.0
- fsi/datagrid-bundle: ^2.0
- phpspec/phpspec: ^5.0|^6.0
- phpstan/phpstan: ^0.12.66
- phpunit/phpunit: ^7.5|^8.0
- squizlabs/php_codesniffer: ^3.5
- symfony/asset: ^4.4|^5.0
- symfony/phpunit-bridge: ^4.4|^5.0
- symfony/security: ^4.4|^5.0
- symfony/twig-bridge: ^4.4|^5.0
This package is auto-updated.
Last update: 2024-10-26 15:16:53 UTC
README
This bundle provides integration with the FSi DoctrineExtensions library.
Installation
This is the master branch, which is under development. For a stable release, please
use version 1.1
.
Add the bundle to composer.json
and run composer.phar update
.
{ "require": { "fsi/doctrine-extensions-bundle": "2.0@dev", } }
Register bundles in AppKernel.php
// app/AppKernel.php public function registerBundles() { return [ new Knp\Bundle\GaufretteBundle\KnpGaufretteBundle(), new FSi\Bundle\DoctrineExtensionsBundle\FSiDoctrineExtensionsBundle(), ]; }
Configure listeners
Listeners are not registered by default and you need to enable them in the
app/config/config.yml
file before using.
# app/config/config.yml fsi_doctrine_extensions: orm: default: translatable: true uploadable: true
Be sure to enable the translations in app/config/config.yml
, even if you do not
wish to use the translatable component of the bundle.
framework: translator: { fallback: %locale% }
Example of an entity with an uploadable field
<?php namespace FSi\DemoBundle\Entity; use Doctrine\ORM\Mapping as ORM; use FSi\Bundle\DoctrineExtensionsBundle\Validator\Constraints as FSiAssert; use FSi\DoctrineExtensions\Uploadable\Mapping\Annotation as FSi; use Symfony\Component\Validator\Constraints as Assert; /** * @ORM\Entity() */ class Article { /** * @var integer * * @ORM\Column(type="integer") * @ORM\Id */ private $id; /** * It is important that this column is nullable, because the value is set * after the entity is persisted. * * @ORM\Column(nullable=true) * @FSi\Uploadable(targetField="photo") */ private $photoKey; /** * Currently there is no common interface for uploaded files. * * @var mixed * * @FSiAssert\Image( * maxWidth = 1000, * maxHeight = 460 * ) */ private $photo; public function getId(): int { return $this->id; } public function setPhoto($photo): void { $this->photo = $photo; } public function getPhoto() { return $this->photo; } public function setPhotoKey(?string $photoKey): void { $this->photoKey = $photoKey; } public function getPhotoKey(): ?string { return $this->photoKey; } }
Example of an entity with translatable fields and a translation entity
namespace Entity; use Doctrine\ORM\Mapping as ORM; use Doctrine\Common\Collections\ArrayCollection; use Doctrine\Common\Collections\Collection; use FSi\DoctrineExtensions\Translatable\Mapping\Annotation as Translatable; /** * The entity's repository needs to implement the * \FSi\DoctrineExtensions\Translatable\Model\TranslatableRepositoryInterface * * @ORM\Entity(repositoryClass="FSi\DoctrineExtensions\Translatable\Entity\Repository\TranslatableRepository") */ class Article { /** * @var integer * * @ORM\Column(type="integer") * @ORM\Id */ private $id; /** * @var string * * @Translatable\Locale */ private $locale; /** * @var string * * @Translatable\Translatable(mappedBy="translations") */ private $title; /** * @var string * * @Translatable\Translatable(mappedBy="translations") */ private $contents; /** * @var Collection|ArticleTranslation[] * * @ORM\OneToMany(targetEntity="ArticleTranslation", mappedBy="article", indexBy="locale") */ private $translations; public function __construct() { $this->translations = new ArrayCollection(); } public function getId(): int { return $this->id; } public function setTitle(?string $title): void { $this->title = $title; } public function getTitle(): ?string { return $this->title; } public function setContents(?string $contents): void { $this->contents = $contents; } public function getContents(): ?string { return $this->contents; } public function setLocale(?string $locale): void { $this->locale = $locale; } public function getLocale(): ?string { return $this->locale; } public function getTranslations(): Collection { return $this->translations; } }
namespace Entity; use Doctrine\ORM\Mapping as ORM; use FSi\DoctrineExtensions\Translatable\Mapping\Annotation as Translatable; /** * @ORM\Entity */ class ArticleTranslation { /** * @var integer * * @ORM\Column(type="integer") * @ORM\Id */ private $id; /** * @var string * * @Translatable\Locale * * @ORM\Column(length=2) */ private $locale; /** * @ORM\Column * @var string */ private $title; /** * @var string * * @ORM\Column */ private $contents; /** * @var Article * * @ORM\ManyToOne(targetEntity="Article", inversedBy="translations") */ private $article; public function setTitle(?string $title): void { $this->title = $title; } public function getTitle(): ?string { return $this->title; } public function setContents(?string $contents): void { $this->contents = $contents; } public function getContents(): ?string { return $this->contents; } public function setLocale(?string $locale): void { $this->locale = $locale; } public function getLocale(): ?string { return $this->locale; } public function setArticle(?Article $article): void { $this->article = $article; } public function getArticle(): ?Article { return $this->article; } }
Additional documentation
Extended validators
There are two validators that can be used with FSi uploadable file.
@FSiAssert\Image
- extends Symfony's Image validator
@FSiAssert\File
- extends Symfony's File validator
Both of these have exactly the same options as their parent classes.