Site Tools


pega:start

Pega

Reporting with pagination from the back-end

Pega's data pages support pagination. In sections for classic ui and views in constellation pagination is supported and accessible using ui features.

If you want to query a database table defining pages, for instance call a datapage with pagination from a data transform or activity to provide the data via a (REST) service, then pagination is not so obvious.

Configuring a data page with report definition referencing the datapage from data transform or activity does not provide the tools/parameter inputs necessary to use pagination.

There are however ways you can use pagination from the back end.

Options

This article will describe the third option to use a report defintion in cobination with the pxRetrieveReportData activity. This option is in my view a balanced approach, compared to SQL connect it is for instance not necessary to know the exact database column names and no need to know SQL. In both cases knowledge about db optimization is necessary. Regarding the pega dx api, in the back end it uses the pxRetrieveReportData activity as well (when the indicated data page is sourced by a report) so in a sense using that option just adds more overhead (connector configuration in design time and api processing in run time).

Using Activity Rule-Obj-Report-Definition pxRetrieveReportData

pre-requisites:

  • Report definition defining the query to run. (Take care of optimizing properties as needed)

Approach:

Create a wrapper activity or perhaps a data transform that will serve as entry point (data source) and takes care of setting up context input parameters and pages, map the results to a desired format/location. This rule wil call the pxRetrieveReportData activity to get the desired data.

The pxRetrieveReportData takes a couple of input parameters of which pyReportName and pyReportClass are required (refencing the report defintion sourcing the data). Also the parameters are passed to the report defintion, so any selection parameters (where clause) can be passed to the activity to take effect.

To query data with pagination it is necessary to provide a page with additional parameters:

  • This page must be of type Embed-QueryInputs.
  • The default name of the page expected is pyReportParamPage but a different name can be used (make sure to indicate the name with parameter pyReportParamPageName when calling pxRetrieveReportData)

There are roughly two approaches for controlling the amount of returned results:

  1. indicate pages and page size → results in meta data indicating how many pages exist and how many results exist in total.
  2. indicate rowindex and rowcount → results in meta data indicating with pxMore true/false if there are more records existing and does not indicate total amount of records.

The second approach seems useful for situations where you dont need to know the total amout of records, like progressively showing results until end user is satisfied. So like when scrolling down or just having a button (more/next). When you want to provide the entire set of data in consumable chunks then approach 1 seems more usefull so that its clear how many records to expect. It provides the possibility to show how many pages exits and select a specific page directly.

Approach 1: Paging

Properties on pyReportParamPage

NameValue
pxObjClassEmbed-QueryInputs
pyPagingSettingsNameValue
pxObjClassEmbed-PagingSettings
pyPageIndex2
pyPageSize3
pyReturnResultCountTrue if false: pxTotalResultCount and pxPageCount not populated (will indicate 0)
pyPagingEnabledTrue returns all results if False

Results on content page:

NameValue
pxTotalResultCount integer value indicating total records selected by the report/query
pxPageCount integer value indicating number of pages given current page size
pxPageSize integer value indicationg number of rows per page
pxResultCount integer value indicating number of current results
pxResults page list containing the requested records/data

Approach 2: Rowindex

Properties on pyReportParamPage

NameValue
pxObjClassEmbed-QueryInputs
pyStartIndex integer value
pyRowCount integer value
pyMaxRecords optional, possible to override the max limit configured on the report definition

Results on content page:

NameValue
pxTotalResultCount not available (always indicates 0)
pxMore True/False
pxResultCount integer value indicating number of current results
pxResults page list containing the requested records/data
This article focusses on the inputs relevant to paging. There are more parameters that can be used to influence the query results.
Rule-Obj-Report-Definition pxRetrieveSearchData activity is also available providing option to use search to retrieve records.
Pega Common (data model) application uses REST api's sourced of which the servce get methods are implemented using report defintions, looks like they use the querying logic similar to how the pega application views api interact with reports via datapages. Looks a bit complicated though. The pega common data model training provides excersize systems that have the common app implemented

Edit input / Dynamic field behavior

In traditional UI App an edit inpout rule could be applied to a property to change the value for instance for transformation to upper case.

In constellation UI similar can be achieved by applying a form refresh condtion combined with a data transform on the flow action related to the form.

On property change a patch call to the backend is made to run the data transform.

A change initiatied to a field with refresh condition originating from another refresh condition will not trigger the refresh again.
So no infinate loop can be created.
Perhaps because the trigger is client side and the data transform runs server side.

Edit Input Not Working in Pega 8.8 (support.pega.com)
Configuring dynamic field behavior (docs.pega.com)

Constellation

Stateless architecture

Because constellation has a stateless architecuter user sessions are not maintained over requests. This has effect on debugging tools. For instance the clipboard viewer tool is not available in run time as it was before.

See article below for tools available to debug applications.

Tools for debugging constellation using tracer tool

Also, Data Page functionality and best practices have changed considerably. Because it is stateless, the Constellation architecture does not support temporary pages – you must use Data Pages instead.

Data pages in Constellation

Creating PDF's in constellation

Authentication

Custom Authorization for (REST) services

For setting up a custom authentication service for API's (on service package) the following is needed:

Rule type Description
Authentication service rule (type custom) Umbrella for the authentication
Timeout activity Activity that optionally contains logic that will be run on timeout
Authentication Activity Activity with purpose of authenticating the requestor.

Configuring the Authentication service

  1. On Serivce tab: Indicate a timeout activity (implementation can be empty) and Indicate a Authentication Activity (needs implementation, described later.)
  2. On Custom tab: (choose Use externally stored credentials, must match the “Use external authentication” setting on operator page which is the result of the authentication activity)

Implementing the Authentciation activity

The purpose of the activity is to do the actual authentication. Successfull authentication is indicated by a couple of parameters:

  1. pyOperPage must be a data-admin-operator-id (the identified operator) clipboard page (as java object)
  2. pyUserIdentifier → operator identifier.

The following can be used in a java step (where myStepPage is the operator page):

tools.putParamValue("pyOperPage", myStepPage);
tools.putParamValue("pyUserIdentifier", myStepPage.getString("pyUserIdentifier"));

Likely a token of some sort is expected in the http headers send by client/user to authenticate. In the authentication context the http headers can be read via following example:

ClipboardPage pxRequestorPage = tools.findPage("pxRequestor");

javax.servlet.http.HttpServletRequest request = (javax.servlet.http.HttpServletRequest) pxRequestorPage.getObject("pxHTTPServletRequest");
authToken = request.getHeader("Authorization");

In the example the Authorization header is fetch into a local variable authToken.

To summarize the flow of the activity:

  1. Get credentials from header
  2. Verify if credentials are valid and identify the client/consumer/user
  3. Iompose Operator Page (read from db or use template opertor)
  4. Indicate success by setting the expected pyOperPage and pyUserIdentifier.
    (If either of the parameters are missing the result will be a 401 unauthorized response.)
pega/start.txt · Last modified: by Niels