User and Rights Management
User and rights management is a general term that describes the security functionality for controlling user access to perform various roles throughout the system.
In the Spryker Commerce OS user and rights management is implemented in the following three bundles:
- ACL - ACL stands for Access Control List. This is where you can manage your roles, groups, privileges and resources.
- Auth - manages the authorization of a specific user by returning true or false if the credentials are allowed to access the system or not. It is used for login, logout, and used by the login controller to verify if a given user token is authenticated. Login is authenticated with a form or a header (via token). Auth is also used to validate that Zed has authorization to process incoming requests from Yves or 3rd parties such as payment providers.
- User - Allows to create users and assign them to groups. Each group contains a set of roles.
Users and Customers
It is important to distinguish between users and customers. A user works with the back-end side of the store and handles the store maintenance such as creating users and assigning them to roles that will allow them to perform actions such as editing the CMS, activating and deactivating products and managing discounts. A customer on the other hand is the final consumer of the online store i.e. the person who places orders. Customers are also managed in Zed but in a different section.
Users are assigned to groups. Groups are a collection of Roles e.g. customer-care, root, 3rd party etc. Roles have Resources (rules) assigned to them. Resources (rules) are used to assign specific privileges to a Role for example, a Sales Representative Role or a System Administrator Role. Resources are always /module/controller/action and you can use * as placeholder.
- /customer/*/* would mean everything in /customer.
- /customer/view/* would mean a user can only see customers but can’t edit them.
The Auth, ACL and User bundles are configured and managed through the Zed user interface. Bundles correspond with the tabs in Zed. You can find which name you should place here from the file /project/config/Zed/navigation.xml
Learn to create and manage Users, Groups and Roles in Users Control Manual.
Apart from being able to configure user access to Zed resources via Zed UI, you can grant access to additional resources by specifying them in config_*.php. The following options are used to do that:
- AclConstants::ACL_DEFAULT_RULES - is used to provide/restrict access to Zed resources, defined in the Spryker\Zed\Auth\AuthConfig::$ingorable property. For example:
$config[AclConstants::ACL_DEFAULT_RULES] = [ // .... [ 'bundle' => 'auth', 'controller' => 'login', 'action' => 'index', 'type' => 'deny', ], // .... ];
In the example, we restrict access for everyone to Zed login page. This option affects both logged-in and anonymous users. The key feature is the ability to restrict/provide access for anonymous users.
$config[AclConstants::ACL_USER_RULE_WHITELIST] = [ // .... [ 'bundle' => 'application', 'controller' => '*', 'action' => '*', 'type' => 'allow', ], // .... ];
In the example, we grant access to the Application module resources for all users.
With the configuration provided in the example, users are granted access to these resources regardless of ACL configuration in ZED UI.
$config[AclConstants::ACL_DEFAULT_CREDENTIALS] = [ 'email@example.com' => [ 'rules' => [ [ 'bundle' => '*', 'controller' => '*', 'action' => '*', 'type' => 'allow', ], ], ], ]
In the example, we grant the user firstname.lastname@example.org access to all Zed resources. To make it work, we should also add email@example.com to this option: `UserConstants::USER_SYSTEM_USERS`. Here, a system user is any user who has additional ACL rules defined for them in config_*.php file.
Currently, the feature has the following functional constraints which are going to be resolved in the future.
customers can access their accounts across all stores available in your Spryker project, regardless of the store they have singed up in
customer groups are available for all stores
you cannot restrict access for a customer or a customer group to one of the available stores