Skip to main content


         This documentation site is for previous versions. Visit our new documentation site for current releases.      
 

Authentication

Updated on March 15, 2022

Apply authentication methods to ensure that only users and systems with a verified identity can access your applications, web pages, APIs, and data. Authentication includes verifying user credentials, Pega Platform requests to external services, and external service requests to Pega Platform. You can also authenticate by using an external identity provider.

User credentials

In a browser, a user logs in to a Pega Platform application, or a developer logs in to Dev Studio to make changes to an application. Authentication services verify these user credentials.

For more information, see Authentication services.

The following table lists the protocols for user logins that Pega Platform supports.

Authentication typeProtocol
SAML 2.0An external identity provider that supports the SAML 2.0 protocol, such as Microsoft Active Directory.
OpenID ConnectAn external identity provider that supports the OpenID Connect (OIDC) protocol.
Basic CredentialsA user ID and password that are stored in the Pega Platform database or in another internal or external data source.
Token CredentialsA token that is validated by an external identity provider or by the OAuth 2.0 authorization layer in Pega Platform (often used in offline mobile applications).
AnonymousSupports activity by guest users, who are prompted to authenticate themselves partway through a session.

For example, an unauthenticated user can add items to a shopping cart, and enter credentials when they check out.

CustomIf none of the above authentication types meet your requirements or meets your use case, you can write your own logic to challenge users for credentials and to validate the credentials. For example, using a Lightweight Directory Access Protocol (LDAP)-compliant directory server.
KerberosA network authentication protocol that is based on tickets that can be securely presented by a client or a service on the client's behalf to a server for access to services.

You can configure a custom authentication service to use information that is stored within the identity provider to determine the user roles and privileges in Pega Platform.

Make your application more secure by configuring the authentication service rule to implement policies such as multi-factor authentication. For example, each time a user logs in, the application can send an authentication code to the user by email and SMS. To log in, the user enters that code in addition to a password. For more information, see Configuring login policies such as multi-factor authentication, CAPTCHA, and attestation.

You can use authentication services (including SAML 2.0, OpenID Connect, or token credentials) to implement single sign-on (SSO) solutions. SSO solutions limit repetitive requests for credentials when users access a variety of systems or applications.

For complete control over the login process, you can define custom authentication services.

Requests to external services from Pega Platform connectors

To invoke an external REST service to get information from an external system or application, a Pega Platform application must authenticate to that service. This type of authentication uses an authentication profile and OAuth provider data instances. The supported forms of authentication include basic credentials, NT LAN Manager credentials (NTLM), and OAuth 2.0.

For more information, see:

External requests for execution to Pega Platform services

An external system or application can invoke a REST service that is defined in Pega Platform or within a Pega Platform application to get case information. This type of authentication uses a service type and service package instances. Supported forms of authentication include basic credentials, OAuth 2.0, and custom authentication.

Session management

After the initial authentication, the session management features in Pega Platform ensure that requests for access to the system and its data only come from authenticated requestors.

In Pega Platform, you can define various policies to control session time-outs, automatically terminate sessions, deactivate operators after successive days of inactivity, run cross-origin resource sharing (CORS), and detect cross-site request forgery (CSRF).

Authentication process flow

In Pega Platform, during a user-interactive login, the authentication service rules perform the following functions, in order.

Note: For token-based authentication types, the authentication service rules skip step 3. For anonymous authentication types, the authentication service rules skip steps 3–7.
  1. Pega Platform determines if this is the initial user request.
  2. Pega Platform initializes an unauthenticated session.
    1. The access group specified by the browser requestor type provides the application context for the session in this state:

      The access group specified by the browser requestor type
      The access group is specified in the Definition tab of the browser requestor type.
  3. Pega Platform executes the pre-authentication activity, if any.
  4. Pega Platform prompts for and verifies operator credentials.
    • If a Basic authentication service, operator credentials are always promoted and verified.
    • If a SSO authentication service, the external identity provider may prompt for credentials if needed.
    • If a Custom authentication service, the behavior depends on authentication activity logic, with the typical response being a login page.
  5. Pega Platform verifies operator identity in the database. If provisioning of new operators is disabled and the operator does not exist, authentication fails.
  6. If this is the operator’s first login and provisioning is enabled, Pega Platform creates a new operator instance based on a model operator or through a data transform.
  7. Pega Platform maps information from the identity provider or from data pages to the clipboard.
  8. Pega Platform persists the operator information from the clipboard to the operator record in the database.
  9. Pega Platform invokes client-selected security policies, such as multi-factor authentication (MFA), CAPTCHA, and Attestation.
  10. Pega Platform marks the session as authenticated.
  11. Pega Platform establishes the application context for the session, based on the requested application or the application specified in the default access group.
  12. Pega Platform executes the post-authentication activity, if any.
    Note: The session established in step 1 has a short time-out period, which is set to two minutes. If the session sits idle in excess of this time period at any point during login, Pega Platform destroys the session. This is the only feature within Pega Platform that attempts to mitigate DOS attacks.

A simplified overview of the Authorization process flow
A flow chart of the Authorization process flow described above
  • Creating an authentication service

    To override or extend the default authentication process, create an authentication service. By creating an authentication service, you implement more specialized authentication requirements than the default, for example, to use pre-authentication and post-authentication activities.

  • Authenticating requests in services

    You can configure Pega Platform to access external systems to retrieve data and perform application processing. Similarly, you can allow external systems to access services in Pega Platform. By communicating with external systems, you can make use of functionality that has already been configured, and avoid the need to duplicate the same functions in multiple applications.

  • Using JNDI to specify an LDAP server when using an authentication service

    You can set up an authentication service to override or extend the default Pega Platform™ authentication process. You can enter a Java Naming and Directory Interface (JNDI) entry, which represents a directory located on the LDAP server. Using JNDI enables you relocate servers without having to reconfigure the application.

  • Authentication time-out

    When users are inactive for a certain period of time, Pega Platform requires users to reauthenticate by entering their login credentials. The browser session cannot resume until the login and password are accepted. Requiring reauthentication helps prevent a malicious or unauthorized user from hijacking the browser session. However, if reauthentication fails or is canceled, some or all of the data on the screen might continue to be displayed.

  • Authentication login failures

    When a user fails to authenticate with proper credentials, safeguards ensure that repeated failed attempts to authenticate have repercussions to mitigate automated attempts to gain unauthorized access to the system.

  • Security tab of the Application Definition

    Use this tab to define security settings in your application, map authentication services, and enable content, mashups, and digital messaging security.

  • Web Service Security profile

    Use a Web Service Security profile (WS-Security) to determine how to authenticate a web service message.

Have a question? Get answers now.

Visit the Support Center to ask questions, engage in discussions, share ideas, and help others.

Did you find this content helpful?

Want to help us improve this content?

We'd prefer it if you saw us at our best.

Pega.com is not optimized for Internet Explorer. For the optimal experience, please use:

Close Deprecation Notice
Contact us