Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message

User Persistence Orm Bundle Laravel Package

dcs/user-persistence-orm-bundle

View on GitHub
Deep Wiki
Context7

Getting Started

Minimal Setup

  1. Install Dependencies

    composer require damianociarla/dcs-user-persistence-orm-bundle
    
  2. Enable the Bundle Add to config/bundles.php:

    return [
        // ...
        Damianociarla\DCSUserPersistenceORMBundle\DCSUserPersistenceORMBundle::class => ['all' => true],
    ];
    
  3. Configure Core Bundle Update config/packages/dcs_user_core.yaml:

    dcs_user_core:
        repository_service: dcs_user.persistence.orm.repository
    
  4. Run Migrations

    php bin/console doctrine:migrations:diff
    php bin/console doctrine:migrations:migrate
    

First Use Case

Fetch a User

use DCS\User\CoreBundle\Model\User;
use DCS\User\CoreBundle\Repository\UserRepositoryInterface;

class SomeService {
    public function __construct(
        private UserRepositoryInterface $userRepository
    ) {}

    public function findUser(int $id): ?User {
        return $this->userRepository->find($id);
    }
}

Implementation Patterns

Core Workflow

  1. Event-Driven Persistence The bundle listens to DCSUserPersistenceORMEvents (e.g., UserSaveEvent, UserDeleteEvent) to auto-persist User entities via Doctrine.

  2. Repository Integration

    • Inject UserRepositoryInterface (auto-wired) for CRUD operations.
    • Extend DCSUserPersistenceORMEvents to add custom logic (e.g., pre-save validation).
  3. Custom User Mapping Override the default User entity mapping by extending the base class:

    use DCS\User\CoreBundle\Model\User as BaseUser;
    
    class CustomUser extends BaseUser {
        // Add custom fields
    }
    

Common Patterns

  • Service Integration

    // Auto-persist a user via event
    $user = new User();
    $this->eventDispatcher->dispatch(new UserSaveEvent($user));
    
  • Bulk Operations

    $users = $this->userRepository->findBy(['role' => 'admin']);
    foreach ($users as $user) {
        $user->setActive(false);
        $this->eventDispatcher->dispatch(new UserSaveEvent($user));
    }
    
  • Soft Deletes Configure DCSUserPersistenceORMEvents::USER_DELETE to use soft-delete logic:

    # config/packages/dcs_user_persistence_orm.yaml
    dcs_user_persistence_orm:
        soft_delete: true
    

Gotchas and Tips

Pitfalls

  1. Event Dispatching Order Ensure DCSUserPersistenceORMBundle is loaded after DCSUserCoreBundle in bundles.php to avoid missing events.

  2. Doctrine Mapping Conflicts If extending User, ensure custom fields are annotated with @ORM\Column or mapped in orm.xml:

    use Doctrine\ORM\Mapping as ORM;
    
    class CustomUser extends BaseUser {
        /**
         * @ORM\Column(type="string", nullable=true)
         */
        private ?string $customField;
    }
    
  3. Migration Issues Run doctrine:schema:update --force if migrations fail due to schema changes.

Debugging Tips

  • Event Listeners Log events to verify they’re dispatched:

    $this->eventDispatcher->addListener(
        DCSUserPersistenceORMEvents::USER_SAVE,
        function (UserSaveEvent $event) {
            error_log('User saved: ' . $event->getUser()->getId());
        }
    );
    
  • Repository Debugging Enable Doctrine debug mode in .env:

    DOCTRINE_ORM_OPTIMIZER_ENABLED=false
    

Extension Points

  1. Custom Events Extend DCSUserPersistenceORMEvents for domain-specific logic:

    class CustomUserEvents {
        public const USER_PRE_SAVE = 'user.pre_save';
    }
    
  2. Repository Decorators Decorate the default repository to add methods:

    # config/services.yaml
    services:
        App\Service\CustomUserRepository:
            decorates: 'dcs_user.persistence.orm.repository'
            arguments: ['@dcs_user.persistence.orm.repository']
    
  3. Doctrine Lifecycle Callbacks Use @ORM\PrePersist/@ORM\PreRemove in custom User extensions for pre-persistence logic.

Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
craftcms/url-validator
directorytree/privacy-filter-classifier
directorytree/privacy-filter
datacore/hub-sdk
develia/commons
cuci/prototurk-sdk
cuci/prototurk-sdk-symfony
develia/geo-bundle
dreamzy/livewire-charts
touchestate-sdk/php-sdk
22h/doctrine-garbage-collection-bundle
agtp/agtp-php
agtp/mod-php
splash/sonata-admin
splash/metadata
splash/openapi
splash/scopes
splash/toolkit
testo/output-teamcity
testo/bridge-symfony