QPR ProcessAnalyzer Objects in Expression Language
DataFrame
Datatable
Datatables are used to store data in QPR ProcessAnalyzer persistently. Datatables consist of one-to-many named columns and zero-to-many rows. The Datatable entity in the expression language is used to access Datatables metadata, such as name, description and audit information. The actual data contents can be accessed by using the DataFrame property, which causes the actual data to be loaded from the database into memory for calculations.
Datatables have many usecases:
- Models can load their data from Datatables.
- Datatables can be used to store data extracted from external systems
- Intermediate ETL calculation results can be stored to Datatables
- It's possible to visualize data from Datatables directly in the dashboards without building a QPR ProcessAnalyzer model
Datatables are stored to QPR ProcessAnalyzer database as database tables. Each datatable belongs to a project.
| Datatable properties | Description | 
|---|---|
| ColumnNames (String*) | Array of Datatable column names in the order they are in the DataTable. The DataTable doesn't need to be loaded into memory to get the column names. | 
| Columns (Dictionary*) | Array of Datatable column metadata in dictionaries. Each dictionary has Name and Datatype properties. Example: 3rd column data type: DatatableById(123).Columns[2].Datatype | 
| CreatedDate (DateTime) | Timestamp when the datatable was created. | 
| DataFrame (DataFrame) | Contents of the DataTable as a DataFrame. | 
| Description (String) | Datatable description. The datatable description may contain line breaks. | 
| Id (Integer) | Datatable Id. Datatable Id is generated by QPR ProcessAnalyzer when the datatable is created. | 
| LastImportDate (DateTime) | Timestamp when data was the last time imported to the datatable. | 
| LastModifiedDate (DateTime) | Timestamp when the datatable was modified the last time, such as name or desctiption. When importing data to the datatable, the LastModifiedDate is not changed. | 
| Name (String) | Name of the datatable. | 
| NColumns (Integer) | Number of columns in the datatable. | 
| NRows (Integer) | Number of data rows in the datatable. | 
| Project (Project) | Project the datatable belongs to. | 
| ProjectId (Number) | Id of the project the datatable belongs to. | 
| Datatable functions | Parameters | Description | 
|---|---|---|
| AddColumn | 
 | Adds a new column to the Datatable. Existing rows in the Datatable will get null values for the created column. The function returns the updated Datatable entity. Example: Add three columns to the Datatable with id 123. DatatableById(123)
  .AddColumn("MyColumn1", "String")
  .AddColumn("MyColumn2", "Float")
  .AddColumn("MyColumn3", "Date")
 | 
| DeletePermanently | (none) | Deletes the Datatable permanently. This will lead to a lost of all data in the Datatable. Datatables cannot be moved to the recycle bin, so they can only be deleted permanently. Example: Delete permanently Datatable with id 123. DatatableById(123).DeletePermanently() | 
| Import | Data to import (DataFrame) | Imports data to the Datatable as new rows from a DataFrame. Column names in the DataFrame need to match with the column names in the Datatable (the column order does not matter). All columns where there are no values in the DataFrame are imported as null values. Example: DatatableById(123).Import(
  ToDataFrame(
    [
      ["Case 1", "A", DateTime(2021,1,2)],
      ["Case 2", "B", DateTime(2021,1,5)],
      ["Case 2", "A", DateTime(2021,1,9)]
    ],
    ["Case", "Event type", "Time"]
  )
)
 | 
| RemoveColumns | Column names (String*) | Removes the listed columns from the Datatable. The data in the removed columns is lost permanently. The function returns the updated Datatable entity. Example: Remove three columns from the Datatable with id 123. DatatableById(123).RemoveColumns(["MyColumn1", "MyColumn2", "MyColumn3"]) | 
| RenameColumns | Column name mappings (Dictionary) | Changes names of one or several columns in the Datatable. The function returns the updated Datatable entity. Example: Rename one/two columns in the Datatable with id 123. DatatableById(123).RenameColumns(#{"MyColumnOldName": "MyColumnNewName"})
DatatableById(123).RenameColumns(#{
  "MyColumnOldName1": "MyColumnNewName1",
  "MyColumnOldName2": "MyColumnNewName2"
})
 | 
Function to get a datatable by id:
| Function | Parameters | Description | 
|---|---|---|
| DataTableById | datatable id (Integer) | Return DataTable with given id. An exception is given if a DataTable with the given id is not found. Examples: DataTableById(27) Returns: DataTable for the data table having id 27. | 
Model
| Model properties | Description | 
|---|---|
| Calendars (BusinessCalendar*) | Returns all business calendars stored to the Model as an array. Returns an empty array, if there are no business calendars stored to the model. Note: UI allows to set only one business calendar for a Model. | 
| CaseAttributes (AttributeType*) | CaseAttributes in the model returned in the alphabetical order. Using this property requires that the model is loaded in the memory. If the model is not in the memory, it's loaded when this property is used. | 
| CasesDatatable (Datatable) | Returns the Datatable the model uses as a datasource for cases. Returns null if the cases Datatable is not defined or if model uses other than the Datatable datasource. | 
| ConfigurationJson (String) | Returns an model configuration in JSON format. | 
| CreatedBy (User) | User who created the Model. | 
| CreatedDate (DateTime) | Timestamp when the model was created. | 
| DefaultCalendar (BusinessCalendar) | Returns the default business calendar of the Model. Returns null, if there are no calendars in the Model or no calendar has been set as a default calendar. Note: UI allows to set only one business calendar for a Model, which is also the default calendar. | 
| DefaultFilterId (Integer) | Default filter id of the model. Returns null if the model does not have a default filter. | 
| Description (String) | Model description. The model description may contain line breaks. | 
| DeletedDate (DateTime) | Timestamp when Model was deleted (moved to the recycle bin). | 
| DeletedBy (User) | User how deleted the Model. | 
| EstimatedMemory (Integer) | Returns an estimation of how much memory in bytes the model requires. | 
| EventsDatatable (Datatable) | Returns the Datatable the model uses as a datasource for events. Returns null if the events Datatable is not defined or if model uses other than the Datatable datasource. | 
| EventAttributes (AttributeType*) | EventAttributes in the model returned in the alphabetical order. Using this property requires that the model is loaded in the memory. If the model is not in the memory, it's loaded when this property is used. | 
| EventLog (EventLog) | EventLog containing the entire model (i.e. event log where no filters have been applied). Using this property requires that the model is loaded in the memory. If the model is not in the memory, it's loaded when this property is used. | 
| Id (Integer) | Model Id. Model Id is generated by QPR ProcessAnalyzer when the model is created. | 
| LastImportDate (DateTime) | Timestamp when data was the last time imported to the model. | 
| LastModifiedBy (User) | User how last time modified the Model. The modification refers to the properties of the Model (not importing data to the model). | 
| LastModifiedDate (DateTime) | Timestamp when the model was modified the last time. | 
| Name (String) | Model name. | 
| NBookmarks (Integer) | Number of bookmarks in the model. | 
| NCache (Integer) | Number of objects related to the model when the model is loaded into the memory. | 
| NCaseAttributes (Integer) | Number of CaseAttributes in model. | 
| NCases (Integer) | Number of Cases in the model. | 
| NEventAttributes (Integer) | Number of EventAttributes in model. | 
| NEvents (Integer) | Number of Events in model. | 
| NEventTypes (Integer) | Number of EventTypes in the model. | 
| NFilters (Integer) | Number of filters in the model. | 
| NOpens (Integer) | Number of times analysis has been requested from the model. | 
| Project (Project) | Project the model belongs to. | 
| ProjectId (Integer) | Project id the model belongs to. | 
| Status (String) | Memory availability status of the model. There are the following statuses: 
 | 
Notes:
- For models that are offline, the object counts represent the situation when the model was last time online (loaded into the memory). null is returned if the model has never been loaded into the memory.
- If Case permissions are used for the model, and user doesn't have GenericWrite permission for the model, null is returned for data security reasons. Users that have the GenericWrite permission, see null when the model is offline, and when online, they see counts where the case level permissions settings are applied.
- Using CaseAttributes, EventAttributes and Eventlog properties requires the model to be loaded into the memory. If the model is not in the memory, it is loaded when these properties is used. Other Model object properties down require the model to be in the memory.
| Model Function | Parameters | Description | 
|---|---|---|
| CalendarByName (BusinessCalendar) | name (String) | Returns a business calendar stored to the Model by the name of the calendar. Business calendars can be stored to models in the model properties. Returns null, if a calendar with the provided name is not stored to the model. Examples: ModelById(123).CalendarByName("MyCalendar")
 | 
| DeletePermanently | (none) | Deletes the Model permanently. The model doesn't need to be in the recycle bin to be able to delete it permanently. | 
| Restore | (none) | Restores the Model from the recycle bin back to the original location. | 
| TriggerNotifications (Boolean) | Notification names (String*) | Triggers the given notifications for the Model. Notifications are given by their names. Triggering means that the configured rules are run and notification emails are sent as defined by the rules. If the notification names parameter is not provided, all notifications in the Model are triggered. The function return true if any notification were triggered, otherwise false. ModelById(123).TriggerNotifications(["Notification 1", "Notification 2"]); Triggers notifications Notification 1 and Notification 2 in model id 123. ModelById(123).TriggerNotifications(); Triggers all notifications in model id 123. | 
Function to get Model by model id:
| Function | Parameters | Description | 
|---|---|---|
| ModelById | 
 | Returns Model object corresponding to the provided model Id. | 
Project
| Project properties | Description | 
|---|---|
| CreatedBy (User) | User who created the Project. | 
| CreatedDate (DateTime) | Timestamp when the Project was created. | 
| Datatables (Datatable*) | Returns all Datatables in the project. | 
| DeletedDate (DateTime) | Timestamp when the Project was deleted (moved to the recycle bin). | 
| DeletedBy (User) | User who deleted the Project (moved to the recycle bin). | 
| Id (Integer) | Id of the Project. | 
| LastModifiedBy (User) | User who last modified the Project. | 
| LastModifiedDate (DateTime) | Timestamp when the Project was last modified (refers to the project name, description and parent, not the contents of the project). | 
| Name (String) | Name of the Project. | 
| Models (Model*) | Models that are in the Project. | 
| Parent (Project) | Parent project, i.e. a Project where the Project is located in the hierarchy of Projects. Returns null for root level Projects. | 
| Scripts (Script*) | Scripts that are in the Project. | 
| Project functions | Parameters | Description | 
|---|---|---|
| CreateDatatable (Datatable) | 
 | Creates a Datatable to the project. The first parameter is the name of the Datatable. After creation, there are no columns or rows in the Datatable. The function returns the created Datatable entity. The additional parameters is a reservation for future. | 
| DatatableByName (Datatable) | Datatable name (String) | Gets a Datatable by its name that is in the project. Returns an error if a Datatable with that name does not exist in the project. Example: ProjectById(123).DatatableByName("MyDatatable1")
 | 
| DeletePermanently | (none) | Deletes the Project permanently. Note that the Project doesn't need to be in the recycle bin to be able to delete it permanently. | 
| Restore | (none) | Restores the Project from the recycle bin back to the original location. | 
Script
Scripts are entities that contain executable code, that can be run. Usually scripts contains ETL routines but also other kind of tasks are possible.
| Script properties | Description | 
|---|---|
| Code (String) | Script code. | 
| CreatedBy (User) | User who created the Script. | 
| CreatedDate (DateTime) | Timestamp when the Script was created. | 
| CurrentRunStart (DateTime) | Timestamp of the current run start. Null if the script is currently not running. | 
| Description (String) | Description of the Script. | 
| Id (Integer) | Id of the Script. | 
| Language (String) | Either of the following scripting language: Expression or SQL. When language is Expression, the script is run as an expression script, and when language is SQL, the script is run as an SQL script (using the sandbox database). | 
| LastModifiedBy (User) | User who last modified the Script. | 
| LastModifiedDate (DateTime) | Timestamp when the Script was last modified. | 
| LastRunEnd (DateTime) | Timestamp of the last completed script run end (either successful completion or failure). Null if the Script hasn't been run yet. | 
| LastRunResult (String) | Result of the last run. Options are: 
 Null if the Script hasn't been run yet. | 
| LastRunStart (DateTime) | Timestamp of the last completed script run start time. Null if the Script hasn't been run yet. | 
| Name (String) | Name of the Script. | 
| OperationId (Integer) | Id of the operation which runs the Script. Null if the script is currently not running. | 
| Project (Project) | Project where the Script is located. Null if the script is in the global context. | 
| ProjectId (Integer) | Id of the project where the Script is located. Null if the script is in the global context. | 
| Status (String) | Current status of the script. Options are: 
 | 
| Script functions | Parameters | Description | 
|---|---|---|
| Run (Object) | Dictionary of parameters | Runs the script using the provided parameters. The parameters are available in the script as variables (see the example). Any type of variables can be passed to the script. Note that if the script assumes certain variables, but that they are not passed to the script, the script run will throw an error. For SQL scripts, the passed parameters are available in the script as variables in format @_parameter_<ParameterName> where <ParameterName> is the name of the parameter, e.g. parameter_myParameter1. Only string type of parameters can be used, so any other type of data in parameter values is converted into strings. The return value of the script is returned by the Run function. Expression scripts return a value with the return statement or alternatively the result of the last line of the script is the return value. If the script does not return any value, the Run function returns _empty. For SQL scripts, the return value is the last dataset produced by the script (returned as a DataFrame) (SQL scripts might create several datasets using the --#ShowReport command or the Show parameter). When a script is called using the Run function, the called script status does not change, because the it's the parent script that is Running. Also the called script log is not filled, but instead the logging goes to the calling script. It's possible to call a script using the Run function several times simultaneously. If there is an error when running the called script, the Run function throws the error to the calling script. Scripts are run in the script entity context, so for example the following properties are available: 
 Example: Following script (id 123) raises a specified number to a specified power: return Pow(numberToRaise, exponent); The script can be called as follows: let runResult = ScriptById(123).Run(#{
  "numberToRaise": 4,
  "exponent": 2
})
Returns: 16
 | 
Function to get a script by the script id:
| Function | Parameters | Description | 
|---|---|---|
| ScriptById | 
 | Returns Script object corresponding to the provided script Id. | 
User/Group
User objects represents users and user groups. Note that some properties can only be used for users and some for groups.
| User/group properties | Description | 
|---|---|
| Description (String) | Description of the user. | 
| Email (String) | Email address of the user. | 
| FullName (String) | Full name of the user or group name. | 
| GlobalPermissions (String*) | Array of global permissions of the user. Global permissions come from the global roles assigned to the user and groups that the user belongs to. To get the actual (effective) permissions for certain objects, also project specific permissions need to be taken into account. | 
| GroupMemberNames (String*) | Array of names of members of a user group. This property is available for groups. | 
| GroupMembers (User*) | Array of members of a user group. This property is available for groups. | 
| GroupNames (String*) | Array of names of user groups the user belongs to. This property is available for users. | 
| Groups (User*) | Array of user groups the user belongs to. This property is available for users. | 
| Id (Integer) | Id of the user, which is unique for every user. | 
| IsActive (Boolean) | Returns true only if the user is active (not disabled). | 
| IsGroup (Boolean) | Returns true if the user is a user group. | 
| Name (String) | Login name of the user or group. | 
| Roles (String*) | System roles of user as string array. | 
| User/group functions | Parameters | Description | 
|---|---|---|
| EffectivePermissionsFor (String Array) | 
 | Returns effective (actual) permission of the user to the given project. Project is given as a project object (not as a project id). Effective permissions determine the actual permissions that the user has, i.e. a combination of all permissions assigned to the user and groups the user belong to, including both project specific and global roles. Permissions for the EffectivePermissionsFor function are as follows: 
 Note that inactive users don't have any effective permissions, so the EffectivePermissionsFor function does not return any permissions for those users. Examples: EffectivePermissionsFor(ModelById(1234).Project) Returns (for example): ["EditDashboards", "Filtering", "GenericRead"] |