Available in OroCommerce

Manage Storefront OAuth Applications in the Back-Office

The section contains the list of all OAuth applications created for customer users in the back-office. You can view and manage the existing OAuth applications, create new applications selecting the necessary grant type depending on your business needs, either client credentials or a password.

A list of all existing oauth applications

Oro applications support oAuth 2.0 credentials authorization grant type to enable connection of third-party applications to the web API. To connect a third-party application, you need to add it and configure its pre-generated credentials in the back-office of your Oro application. These credentials are managed on user level which enables generation of different credentials for various applications across multiple organizations.

Starting Conditions

To be able to create an OAuth application, make sure that you generate private and public encryption keys and add them to the /var directory of the installed Oro application. Although the path to the keys is predefined, you can change it by providing your custom location in the config.yml file.

Note

If no keys are found, the following warning message will be displayed in the back-office:

OAuth authorization is not available as encryption keys configuration was not complete. Please contact your administrator.

Create an Application

To create a new OAuth application in the back-office:

  1. Navigate to System > User Management > OAuth Applications in the main menu.

  2. Click Create OAuth Application on the top right of the screen.

  3. Provide the following details on the page that opens:

    image_app_create

    • Organization — If you are adding an application within the organization with global access, you can select which other available organization to add the application to. This field is displayed to users with access to multiple organizations.
    • Application Name — Provide a meaningful name for the application you are adding.
    • Active — Select the Active check box to activate the new application.
    • Grants — Select the grant type to apply to the new application. Currently, the available grant types are Client Credentials and Password. The Client Credentials type is used for machine-to-machine authentication (e.g., in a cron job that performs maintenance tasks over an API) and Password is used by trusted first-party clients to exchange the credentials (username and password) for an access token.
    • Users — The field appears when selecting Client Credentials as a grant type in the previous field. Select a customer user who you want to assign the new application to.
  4. Click Create.

A corresponding notification is sent to the primary email address of the user, the owner of oauth application. You can change the default recipient, localization, or an email content if needed by updating the OAuth email templates and the related notification rule set out-of-the-box in the system configuration.

Once the application is created, you are provided with a Client ID and a Client Secret. Click on the icon to copy the credentials to the clipboard.

image_credentials

Important

For security reasons, the Client Secret is displayed only once – immediately after you have created a new application. You cannot view the Client Secret anywhere in the application once you close this dialog, so make sure you save it somewhere safe so you can access it later.

You can create as many applications as you need for any of your existing organizations. All added applications are displayed in the grid, and you can filter them by name, organization, and status.

Hint

Use the More Options menu to view, edit, delete, activate or deactivate the existing OAuth applications.

image_app_actions

Use the generated Client ID and Client Secret to retrieve an access token to connect to your Oro application.

Note

For the details on how to add an OAuth application to a selected user in the back-office, refer to the Add OAuth applications to a selected customer user topic.