jackai / symfony-entity-helper
Automatically generate `Getter` / `Setter` / `Isser` / `Hasser` function through annotation, Automatically generate through `@ORM\Column` judgment to generate toArray return and auto load values to entity.
Installs: 15
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
pkg:composer/jackai/symfony-entity-helper
Requires
- php: ^7.1
- doctrine/annotations: ^1.0
- symfony/framework-bundle: ^4.0|^5.0
Requires (Dev)
- doctrine/annotations: ^1.2
- doctrine/common: ^2.4
- sensio/framework-extra-bundle: ^4.0|^5.0
- symfony/asset: ^4.0|^5.0
- symfony/browser-kit: ^4.0|^5.0
- symfony/cache: ^4.0|^5.0
- symfony/config: ^4.0|^5.0
- symfony/console: ^4.0|^5.0
- symfony/dom-crawler: ^4.0|^5.0
- symfony/form: ^4.0|^5.0
- symfony/phpunit-bridge: ^4.0|^5.0
- symfony/property-access: ^4.0|^5.0
- symfony/routing: ^4.0|^5.0
- symfony/stopwatch: ^4.0|^5.0
This package is auto-updated.
Last update: 2025-10-10 04:25:31 UTC
README
- Automatically generate Getter/Setter/Isser/Hasserfunctions through annotation
- Automatically generate through @ORM\Columnjudgment to generate toArray return.
- Auto load values to entity.
Installation
1.Open a command console, enter your project directory and execute the following command to download the latest version of this bundle:
composer require jackai/symfony-entity-helper
2.Open config/services.yaml and add this config:
services:
    Jackai\EntityHelper\ClearEntityHelperCache:
        tags:
          - { name: kernel.cache_clearer }
Useage
Auto load values
namespace App\Controller;
use App\Entity\Product;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Annotation\Route;
use Doctrine\ORM\EntityManagerInterface;
use Jackai\EntityHelper\EntityHelpers;
class TestController extends AbstractController
{
    /**
     * @Route("/test")
     */
    public function test(Request $request)
    {
        $entityManager = $this->getDoctrine()->getManager();
        try {
            $query = $request->query->all();
            
            // validate your values
            
            $product = new Product();
            
            // auto load your values
            EntityHelpers::load($product, $query);
            $entityManager->persist($product);
            $entityManager->flush();
            return new JsonResponse([
                'code' => 'ok',
                'ret' => $product->toArray(),
            ]);
        } catch (\Exception $e) {
            return new JsonResponse([
                'code' => $e->getCode(),
                'msg' => $e->getMessage(),
            ]);
        }
    }
}
Automatically generate Getter / Setter / Isser / Hasser functions
namespace App\Entity;
use App\Repository\ProductRepository;
use Doctrine\ORM\Mapping as ORM;
use Jackai\EntityHelper\Annotations as EH;
use Jackai\EntityHelper\EntityHelperTrait;
/**
 * @ORM\Entity(repositoryClass=ProductRepository::class)
 */
class Product
{
    use EntityHelperTrait;
    /**
     * @EH\Getter
     * @ORM\Id()
     * @ORM\GeneratedValue()
     * @ORM\Column(type="integer")
     */
    private $id;
    /**
     * @EH\Getter
     * @EH\Setter
     * @ORM\Column(type = "string", length = 255)
     */
    private $name;
    
    /**
     * @EH\Getter
     * @EH\Hasser
     * @EH\Setter
     * @ORM\OneToMany(targetEntity="App\Entity\Pictures", mappedBy="product")
     */
    private $pictures;
    
    /**
     * @EH\Isser
     * @EH\Setter
     * @ORM\Column(type = "boolean", name="on_sale")
     */
    private $onSale;
}