Identity Access Management

Edit on GitHub

The Identity Access Management capability enables all types of users in a Spryker shop to create and manage accounts. Different levels of security let users manage the access of other users.

Back Office authentication

Back Office supports login via two types of accounts:

  • Back Office account.
  • Account of a third-party service that is configured as a single sign-on.

Login with a Back Office account

Only an existing Back Office user with sufficient permissions or a developer can create Back Office accounts. That is, if you want to onboard a new Back Office user, you need to create an account for them. For instructions on creating accounts in the Back Office, see Create users.

To log in, on the Back Office login page, a user enters the email address and password of their account. If the credentials are correct and their account is active at that time, they are logged in.

If a user does not remember their password, they can reset it using the form available on the login page.

Login with a single sign-on

Your project can have a single sign-on(SSO) login configured for the Back Office. SSO lets users log into the Back Office with accounts of a third-party service.

The feature is shipped with an exemplary ECO module that supports SSO authentication via Microsoft Azure Active Directory. With the existing infrastructure, you can develop your own ECO modules for the identity managers you need. SSO uses the OpenID protocol for authentication.

To log in with an SSO, on the Back Office login page, users click Login with {Third-party service name}. This opens the sign-in page of the configured service. Users sign in with their accounts and get redirected to the Back Office.

If a user chooses to log in using a third party, they are redirected to the OAuth provider’s sign-in page—for example, Microsoft Azure. If the user successfully signs into the third-party service, the check is made if the user exists in the Spryker database. If the user exists in the database and is active, the user is logged in.

The following sections describe different ways of handling users that have access to your SSO service, but don’t have a Back Office account.

SSO authentication strategies

Depending on your access and security requirements, you can have one of the following strategies implemented for SSO authentication.

Registration is required only with the SSO service

If a user logs in with an SSO but does not have a Back Office account, the following happens:

  • Based on the third-party system’s user data, such as first name, last name, and email, a Back Office account is created.
  • The user is assigned to the default user group.
  • The user is logged into the Back Office.

The login process looks like this:

image

Registration is required with the SSO service and with Spryker

If a user logs in with an SSO but does not have a Back Office account, the user is not logged in. To be able to log in, a user must have a Back Office account registered using the email address used for their account with the SSO service. Usually, this strategy is used when not all the users that have access to the SSO service need access to the Back Office.

image

Glue API authentication

For details about Glue API authentication, see Glue API authentication and authorization

Current constraints

The feature has the following functional constraint:

Each of the identity managers is an ECO module that must be developed separately. After the module development, the identity manager’s roles and permissions must be mapped to the roles and permissions in Spryker. The mapping is always implemented at the project level.

INSTALLATION GUIDES GLUE API GUIDES
Install the Spryker Core Back Office feature Authentication and authorization
Install Microsoft Azure Active Directory Security and authentication
Install the Customer Access Glue API Create customers
Confirm customer registration
Manage customer passwords
Authenticate as a customer
Manage customer authentication tokens via OAuth 2.0
Manage customer authentication tokens
Authenticating as a company user
Manage company user authentication tokens
Authenticate as an agent assist
Managing agent assist authentication tokens
Delete expired refresh tokens