Customer & ShopUser

For handling customers of your system Sylius is using a combination of two entities - Customer and ShopUser. The difference between these two entities is simple: the Customer is a guest in your shop and the ShopUser is a user registered in the system - they have an account.

Customer

The Customer entity was created to collect data about non-registered guests of the system - ones that has been buying without having an account or that have somehow provided us with their e-mail.

How to create a Customer programmatically?

As usual, use a factory. The only required field for the Customer entity is email, provide it before adding it to the repository.

/** @var CustomerInterface $customer */
$customer = $this->container->get('sylius.factory.customer')->createNew();

$customer->setEmail('[email protected]');

$this->container->get('sylius.repository.customer')->add($customer);

The Customer entity can of course hold other information besides an email, it can be for instance firstName, lastName or birthday.

circle-info

The relation between the Customer and the ShopUser is bidirectional. Both entities hold a reference to each other.

ShopUser

ShopUser entity is designed for customers that have registered in the system - they have an account with both e-mail and password. They can visit and modify their account.

While creating a new account the existence of the provided email in the system is checked - if the email was present - it will already have a Customer therefore the existing one will be assigned to the newly created ShopUser, if not, a new Customer will be created together with the ShopUser.

circle-info

Please note that if a newly created ShopUser has been assigned to an existing Customer, they will have access to previously placed orders as a guest.

How to create a ShopUser programmatically?

Assuming that you have a Customer (either retrieved from the repository or a newly created one) - use a factory to create a new ShopUser, and assign the existing Customer and a password via the setPlainPassword() method.

Changing the ShopUser password

The already set password of a ShopUser can be easily changed via the setPlainPassword() method.

Event id
Description

sylius.customer.post_register

dispatched when a new Customer is registered

sylius.customer.pre_update

dispatched when a Customer is updated

sylius.oauth_user.post_create

dispatched when an OAuthUser is created

sylius.oauth_user.post_update

dispatched when an OAuthUser is updated

sylius.shop_user.post_create

dispatched when a User is created

sylius.shop_user.post_update

dispatched when a User is updated

sylius.shop_user.pre_delete

dispatched before a User is deleted

sylius.user.email_verification.token

dispatched when a verification token is requested

sylius.user.password_reset.request.token

dispatched when a reset password token is requested

sylius.user.pre_password_change

dispatched before user password is changed

sylius.user.pre_password_reset

dispatched before user password is reset

sylius.user.security.implicit_login

dispatched when an implicit login is done

security.interactive_login

dispatched when an interactive login is done

Last updated

Was this helpful?