QPR ProcessAnalyzer Objects in Expression Language: Difference between revisions
|  (TK-60361) | |||
| (240 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| == | ==Filter== | ||
| Filters contain a set of filter rules used to filter cases and events in models. Filters are objects located in the models. Filters are owned by the creator user, and when a filter publish mode is private, only the creator can use it. | |||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Filter properties''' | ||
| ! '''Description''' | ! '''Description''' | ||
| |- | |- | ||
| || | ||CreatedBy (User) | ||
| || | ||Returns the user who created the filter. | ||
| |- | |- | ||
| ||CreatedDate (DateTime) | ||CreatedDate (DateTime) | ||
| || | ||Returns date when the filter created date. | ||
| |- | |- | ||
| ||Description (String) | ||Description (String) | ||
| || | ||Returns description of the filter. | ||
| |- | |- | ||
| ||Id (Integer) | ||Id (Integer) | ||
| || | ||Returns id of the filter. | ||
| |- | |- | ||
| || | ||LastModifiedBy (User) | ||
| || | ||Returns user who modified the filter. | ||
| |- | |- | ||
| ||LastModifiedDate (DateTime) | ||LastModifiedDate (DateTime) | ||
| || | ||Returns date when the filter last modified. | ||
| |- | |||
| ||Model | |||
| ||Returns model where the filter belongs to. | |||
| |- | |||
| ||ModelId (Integer) | |||
| ||Returns model where the filter belongs to. | |||
| |- | |- | ||
| ||Name (String) | ||Name (String) | ||
| || | ||Returns the name of the filter. | ||
| |- | |- | ||
| || | ||Project | ||
| || | ||Returns project where the filter belongs to. | ||
| |- | |- | ||
| || | ||ProjectId (Integer) | ||
| || | ||Returns project id where the filter belongs to. | ||
| |- | |- | ||
| || | ||PublishMode (String) | ||
| || | ||Returns publish mode of the filter, one of the following: '''Private''', '''Public''', or '''Default'''. | ||
| |- | |- | ||
| || | ||Rules (Dictionary) | ||
| ||Returns  | ||Returns a dictionary containing the filter rules in the filter. | ||
| |} | |} | ||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Filter functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| |- | |- | ||
| ||DeletePermanently | ||DeletePermanently | ||
| ||(none) | ||(none) | ||
| || | || | ||
| Deletes the  | Deletes the filter permanently. To delete own filters, the '''Filtering''' permission is needed, and to delete any filters the '''ManageViews''' permission is needed. | ||
| |- | |- | ||
| || | ||Modify | ||
| || | ||Dictionary | ||
| || | || | ||
| Modifies filter properties. The parameter is a dictionary containing the properties to be changed. Following properties can be changed: ''Name'', ''Description'', ''PublishMode'', and ''Rules''. | |||
| The function returns the updated filter object. Requires ''GenericWrite'' permission for the Project and global ''CreateModel'' permission. | |||
| Example: | Example: | ||
| <pre> | <pre> | ||
| FilterById(1) | |||
| 	.Modify(#{ | |||
| 		"Name": "My filter", | |||
| 		"Description": "My description", | |||
| 		"PublishMode": "Public", | |||
| 		"Rules": #{ | |||
| 			"Items": [ | |||
| 				#{ | |||
| 					"Type": "IncludeCases", | |||
| 					"Items": [ | |||
| 						#{ | |||
| 							"Type": "CaseAttributeValue", | |||
| 							"Attribute": "Account Manager", | |||
| 							"StringifiedValues": [ | |||
| 								"0Mary Wilson" | |||
| 							] | |||
| 						} | |||
| 					] | |||
| 				} | |||
| 			] | |||
| 		} | |||
| 	} | |||
| ) | ) | ||
| </pre> | </pre> | ||
| |} | |} | ||
| Function to get  | Function to get filter id: | ||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| |- | |- | ||
| || | ||FilterById | ||
| || | || | ||
| * Filter id (Integer) | |||
| || | || | ||
| Returns Filter object corresponding to the provided filter id. | |||
| Returns | |||
| |} | |} | ||
| == Model== | ==Model== | ||
| Notes: | |||
| * For in-memory 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_Level_Permissions|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. | |||
| * Properties ''CaseAttributes'', ''EventAttributes'' and ''Eventlog'' work only for the in-memory models and they require 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 properties down require the model to be in the memory. | |||
| {| class="wikitable" | {| class="wikitable" | ||
| Line 178: | Line 123: | ||
| ||CasesDatatable (Datatable) | ||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. | ||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. | ||
| |- | |||
| ||Configuration (Dictionary) | |||
| ||Returns the Model configuration as dictionary. Example: | |||
| <pre> | |||
| ModelById(123).Configuration.DataSource.Events.DataTableName | |||
| </pre> | |||
| |- | |- | ||
| ||ConfigurationJson (String) | ||ConfigurationJson (String) | ||
| ||Returns  | ||Returns the Model configuration as JSON string. | ||
| |- | |- | ||
| ||CreatedBy (User) | ||CreatedBy (User) | ||
| ||User who created the  | ||User who created the model. | ||
| |- | |- | ||
| ||CreatedDate (DateTime) | ||CreatedDate (DateTime) | ||
| Line 190: | Line 141: | ||
| ||DefaultCalendar (BusinessCalendar) | ||DefaultCalendar (BusinessCalendar) | ||
| ||Returns the default [[Business_Calendar|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. | ||Returns the default [[Business_Calendar|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. | ||
| |- | |||
| ||DefaultFilter (Filter) | |||
| ||Default filter of the model. Returns ''null'' if the model does not have a default filter. | |||
| |- | |- | ||
| ||DefaultFilterId (Integer) | ||DefaultFilterId (Integer) | ||
| Line 202: | Line 156: | ||
| ||DeletedBy (User) | ||DeletedBy (User) | ||
| ||User how deleted the Model. | ||User how deleted the Model. | ||
| |- | |||
| ||Diagrams (Diagram*) | |||
| ||Returns an array of all [[Diagram_in_Expression_Language|diagrams]] in the model. | |||
| |- | |- | ||
| ||EstimatedMemory (Integer) | ||EstimatedMemory (Integer) | ||
| Line 214: | Line 171: | ||
| ||EventLog (EventLog) | ||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. | ||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. | ||
| |- | |||
| ||Filters (Filter*) | |||
| ||Returns an array of all [[#Filter|filters]] in the model. | |||
| |- | |- | ||
| ||Id (Integer) | ||Id (Integer) | ||
| ||Model Id. Model Id is generated by QPR ProcessAnalyzer when the model is created. | ||Model Id. Model Id is generated by QPR ProcessAnalyzer when the model is created. | ||
| |- | |- | ||
| || | ||IsValidInMemoryModel (boolean) | ||
| || | ||Returns ''true'' if all the following conditions are met: | ||
| * CheckModelValidity function doesn't return any issues (because invalid models are assumed to be Snowflake models). | |||
| * Model is not an object-centric model. | |||
| * Data source of the model is ''ODBC'' or ''Expression'', or the referred datatable has ''DataSourceType'' either ''Local'' or ''SqlServer''. | |||
| |- | |- | ||
| ||LastModifiedBy (User) | ||LastModifiedBy (User) | ||
| ||User  | ||User who last time modified the model properties. Note that datatables containing the eventlog data are separate objects having similar fields to track the last modification and last data import. | ||
| |- | |- | ||
| ||LastModifiedDate (DateTime) | ||LastModifiedDate (DateTime) | ||
| Line 229: | Line 192: | ||
| ||Name (String) | ||Name (String) | ||
| ||Model name. | ||Model name. | ||
| |- | |- | ||
| ||NCache (Integer) | ||NCache (Integer) | ||
| Line 237: | Line 197: | ||
| |- | |- | ||
| ||NCaseAttributes (Integer) | ||NCaseAttributes (Integer) | ||
| ||Number of [[#AttributeType|CaseAttributes]] in model. | ||Number of [[#AttributeType|CaseAttributes]] in model. Works only for in-memory models. | ||
| |- | |- | ||
| ||NCases (Integer) | ||NCases (Integer) | ||
| ||Number of [[#Case|Cases]] in the model. | ||Number of [[#Case|Cases]] in the model. Works only for in-memory models. | ||
| |- | |- | ||
| ||NEventAttributes (Integer) | ||NEventAttributes (Integer) | ||
| ||Number of [[#AttributeType|EventAttributes]] in model. | ||Number of [[#AttributeType|EventAttributes]] in model. Works only for in-memory models. | ||
| |- | |- | ||
| ||NEvents (Integer) | ||NEvents (Integer) | ||
| ||Number of [[#Event|Events]] in model. | ||Number of [[#Event|Events]] in model. Works only for in-memory models. | ||
| |- | |- | ||
| ||NEventTypes (Integer) | ||NEventTypes (Integer) | ||
| ||Number of [[#EventType|EventTypes]] in the model. | ||Number of [[#EventType|EventTypes]] in the model. Works only for in-memory models. | ||
| |- | |- | ||
| ||Project (Project) | ||Project (Project) | ||
| ||[[#Project|Project]] the model belongs to. | ||[[#Project|Project]] where the model belongs to. | ||
| |- | |- | ||
| ||ProjectId (Integer) | ||ProjectId (Integer) | ||
| ||[[#Project|Project]] id the model belongs to. | ||[[#Project|Project]] id where the model belongs to. | ||
| |- | |- | ||
| ||Status (String) | ||Status (String) | ||
| Line 269: | Line 223: | ||
| * '''Offline''': The model is currently not loaded into the memory. The model needs to be loaded into the memory, so that analyses can be calculated from the model (occurs automatically when an analysis is requested). | * '''Offline''': The model is currently not loaded into the memory. The model needs to be loaded into the memory, so that analyses can be calculated from the model (occurs automatically when an analysis is requested). | ||
| * '''Online''': The model is in the memory and ready for analysis calculation. If the model is dropped from the memory, its status changes to ''offline''. | * '''Online''': The model is in the memory and ready for analysis calculation. If the model is dropped from the memory, its status changes to ''offline''. | ||
| |- | |||
| ||UsedDatatables (Datatable*) | |||
| ||Returns all datatables the model uses as a datasource. | |||
| Example: List datatables used by a model: | |||
| <pre> | |||
| StringJoin(", ", OrderByValue(ModelById(1).UsedDataTables.Name)) | |||
| </pre> | |||
| |} | |} | ||
| {| class="wikitable" | {| class="wikitable" | ||
| !'''Model  | !'''Model functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| Line 290: | Line 247: | ||
| <pre> | <pre> | ||
| ModelById(123).CalendarByName("MyCalendar") | ModelById(123).CalendarByName("MyCalendar") | ||
| </pre> | |||
| |- | |||
| ||CreateDiagram (Diagram) | |||
| ||Parameters dictionary | |||
| || | |||
| Creates a [[Diagram_in_Expression_Language|diagram]] to the model. Parameters is a dictionary containing diagram properties. Following properties are available: | |||
| * '''Name''' (string): Diagram name that distinguishes diagrams in a model. | |||
| * '''Description''' (string): Diagram description text. | |||
| * '''Content''' (dictionary): Diagram content as dictionary. | |||
| Example: | |||
| <pre> | |||
| ModelById(1) | |||
|   .CreateDiagram(#{ | |||
|     "Name": "My diagram", | |||
|     "Description": "This is my new diagram", | |||
|     "Content": #{ ... }, | |||
|   }) | |||
| </pre> | |||
| |- | |||
| ||CreateFilter (Filter) | |||
| ||Parameters dictionary | |||
| ||Creates a filter to a model. Requires ''GenericWrite'' permission for the project and global ''CreateModel'' permission. If a filter with that name already exists in the model, an exception is thrown. | |||
| The parameters dictionary may have the following properties: | |||
| * '''Name''': Name of the filter. This property is mandatory. | |||
| * '''Description''': Description of the filter. This property is optional. | |||
| * '''Rules''': Filter rules for the filter defined as a dictionary according to the [[Filtering_in_QPR_ProcessAnalyzer_Queries|filter json format]]. This property is mandatory. | |||
| * '''PublishMode''': Publish mode of the filter which is one of the following: ''Private'', ''Public'' or ''Default''. This property is optional, and the default value is ''Private''. | |||
| Example: | |||
| <pre> | |||
| let newFilter = modelById(1).CreateFilter(#{     | |||
|   "Name": "My Filter", | |||
|   "Rules": #{ | |||
|     "Items": [#{ | |||
|       "Type": "IncludeCases", | |||
|       "Items": [#{ | |||
|         "Type": "CaseAttributeValue", | |||
|         "Attribute": "Account Manager", | |||
|         "StringifiedValues": [ "0Robert Miller" ] | |||
|       }] | |||
|     }] | |||
|   }, | |||
|   "PublishMode": "Public" | |||
| }); | |||
| } | |||
| </pre> | </pre> | ||
| |- | |- | ||
| Line 295: | Line 298: | ||
| ||(none) | ||(none) | ||
| ||Deletes the Model permanently. The model doesn't need to be in the recycle bin to be able to delete it permanently. | ||Deletes the Model permanently. The model doesn't need to be in the recycle bin to be able to delete it permanently. | ||
| |- | |||
| ||Modify (Model) | |||
| ||Dictionary | |||
| || | |||
| Modifies model properties. The parameter is a dictionary containing the properties to be changed. Following properties can be changed: ''Name'', ''Description'', ''ProjectId'', and ''Configuration''. | |||
| The function returns the updated model object. Requires the ''GenericWrite'' permission for the project and the global ''CreateModel'' permission. | |||
| Example: | |||
| <pre> | |||
| ModelById(1) | |||
| 	.Modify(#{ | |||
| 		"Name": "My model", | |||
| 		"Description": "My description", | |||
| 		"ProjectId": 2, | |||
| 		"Configuration": #{ | |||
| 			"DataSource": #{ | |||
| 				"Cases": #{ | |||
| 					"DataSourceType": "datatable", | |||
| 					"DataTableName": "My cases datatable", | |||
| 					"Columns": #{ | |||
| 						"CaseId": "Case Name" | |||
| 					} | |||
| 				}, | |||
| 				"Events": #{ | |||
| 					"DataSourceType": "datatable", | |||
| 					"DataTableName": "My events datatable", | |||
| 					"Columns": #{ | |||
| 						"CaseId": "Case Name", | |||
| 						"EventType": "Event Type", | |||
| 						"Timestamp": "Start Time" | |||
| 					} | |||
| 				} | |||
| 			} | |||
| 		} | |||
| 	} | |||
| ) | |||
| </pre> | |||
| |- | |||
| ||ResetModelCache | |||
| ||(none) | |||
| || | |||
| Synchronously clears all cached model data. For a Snowflake model, deletes all cache tables related to the model from Snowflake. For an in-memory model, drops the model from the memory and also drops all other model related caches from the memory.  | |||
| |- | |||
| ||ResetPreprocessings | |||
| ||(none) | |||
| || | |||
| Removes all cached items related to the Model, e.g. preprocessings and calculation results. In practice, the Model is reset to a state where it was right after the model was loaded into memory. | |||
| |- | |- | ||
| ||Restore | ||Restore | ||
| ||(none) | ||(none) | ||
| ||Restores the Model from the recycle bin back to the original location. | ||Restores the Model from the recycle bin back to the original location. | ||
| |- | |||
| ||<span id="ToSqlDataFrame">ToSqlDataFrame</span> | |||
| ||In-memory dataframe | |||
| ||Converts an in-memory dataframe to an SQL dataframe. In practice, an SQL query is created from the in-memory dataframe and the query is executed in the datasource so that the data is available in the datasource for further SQL operations. This function is intended only to small amounts of data which is less than 16384 rows. | |||
| Example: Select matching cases from events data using in-memory dataframe: | |||
| <pre> | |||
| let model = ModelById(1); | |||
| let dfEvents = model.EventsDatatable.SqlDataFrame; | |||
| let inMemoryDf = ToDataFrame( | |||
|   [["1"], ["2"], ["3"]], | |||
|   [#{"Name": "id", "DataType": "String"}] | |||
| ); | |||
| model.ToSqlDataFrame(inMemoryDf) | |||
|   .Join(dfEvents, ["id": "CaseId"]) | |||
|   .SelectDistinct(["CaseId"]) | |||
|   .Collect(); | |||
| </pre> | |||
| |- | |- | ||
| ||<span id="TriggerNotifications">TriggerNotifications</span> (Boolean) | ||<span id="TriggerNotifications">TriggerNotifications</span> (Boolean) | ||
| Line 311: | Line 380: | ||
| ModelById(123).TriggerNotifications(); | ModelById(123).TriggerNotifications(); | ||
| Triggers all notifications in model id 123. | Triggers all notifications in model id 123. | ||
| </pre> | |||
| |- | |||
| ||<span id="CheckModelValidity">CheckModelValidity</span> (Object array) | |||
| ||CheckData field in dictionary | |||
| ||Checks the model validity and returns found issues. The returned data is an array of objects where each object represents one validity error and contains the following properties: | |||
| * '''IssueType''' (String): Specifies the issue type. | |||
| * '''ContextType''' (String): Context in which the issue was found, and it can be '''EventDataSource''', '''CaseDataSource''', '''OcelDataSource'''. | |||
| * '''Details''' (Dictionary): Additional details which depend on the type of the issue. | |||
| There are two types of checks available (based on whether the '''CheckData''' parameter is defined): | |||
| * ''Lightweight check'': The check is based on only the configuration data stored in QPR ProcessAnalyzer. This check is very quick and does not require running queries in datasource (e.g., in Snowflake). | |||
| * ''Full check'': The check is comprehensive and it's able to detect any validity issues the model may have. The full check requires running queries to the actual data which makes the check slower, and in case of Snowflake, it uses the Snowflake warehouse to run the queries. | |||
| The lightweight check is performed automatically by the [[QPR_ProcessAnalyzer_Project_Workspace|Workspace]], so if there are any validity issues that the lightweight check can detect, the Workspace notifies about them immediately. If there are any problems with the model calculation results, it might be a good idea to run the full validity check to confirm whether the problems are due to the model being invalid. | |||
| Example: Lightweight check: | |||
| <pre> | |||
| ToJson(ModelById(1).CheckModelValidity()) | |||
| </pre> | |||
| Example: Full check: | |||
| <pre> | |||
| ToJson(ModelById(1).CheckModelValidity(#{ "CheckData": true })) | |||
| </pre> | |||
| |- | |||
| ||CortexAgentsQuery | |||
| || | |||
| ||Creates a Snowflake Cortex semantic model (see ''GetSemanticModel'' function) for the process mining model and makes a natural language query on it using Snowflake Cortex Agents. More information: https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-agents.  | |||
| There are the following parameters: | |||
| # '''Parameters''': Dictionary parameters given to the Cortex Agents REST API query (https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-agents-rest-api). There is a special handling for the following parameters: | |||
| #* '''model''': If not defined, uses the default Cortex Agents model name configured into the database, or if that is not defined, uses "llama3.1-70b". | |||
| #* '''_tools''': Additional tool_spec of type "cortex_analyst_text_to_sql" will be added to this value with a reference to the generated semantic model. | |||
| #* '''_tool_resources''': Generated semantic model is added as an additional resource. | |||
| # '''Filter configuration''': Can be a string containing filter JSON or a dictionary containing the filter configuration. The semantic model is created for the filtered eventlog. If not defined, the entire model eventlog will be used. | |||
| # '''Event column role nappings''': Mappings to apply for event columns. If not defined, default column mappings are used. | |||
| # '''Case column role mappings''': Mappings to apply for case columns. If not defined, default column mappings are used. | |||
| The function returns a dictionary with the following keys: | |||
| # '''Response''': Actual response as a dictionary returned by the Cortex Agents. | |||
| # '''Response items''': Contains processed response consisting of an array of objects having the following properties: | |||
| #* '''Text''': Textual response. | |||
| #* '''Sql''': Response SQL query string. Not mandatory. | |||
| #* '''SqlDataFrame''': SqlDataFrame created for the SQL query in the Sql property. Only present if Sql is present. | |||
| |- | |||
| ||GetSemanticModel | |||
| || | |||
| ||Creates a Snowflake Cortex Analyst semantic model for the process mining model and returns it as a dictionary. More information: https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-analyst/semantic-model-spec. | |||
| There are the following parameters: | |||
| # '''Filter configuration''': Can be a string containing filter JSON or a dictionary containing the filter. The semantic model is created for the filtered eventlog. If not defined, the entire model eventlog will be used. | |||
| # '''Event column role mappings''': Mappings to apply for event columns. If not defined, default column mappings are used. | |||
| # '''Case column role mappings''': Mappings to apply for case columns. If not defined, default column mappings are used. | |||
| Examples: Returns a semantic model without any filtering applied. | |||
| <pre> | |||
| ModelById(1).GetSemanticModel(); | |||
| </pre> | </pre> | ||
| |} | |} | ||
| Line 316: | Line 442: | ||
| Function to get Model by model id: | Function to get Model by model id: | ||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| Line 325: | Line 451: | ||
| || | || | ||
| Returns [[QPR_ProcessAnalyzer_Objects_in_Expression_Language#Model|Model]] object corresponding to the provided model id. | Returns [[QPR_ProcessAnalyzer_Objects_in_Expression_Language#Model|Model]] object corresponding to the provided model id. | ||
| |} | |||
| ==Object-centric model== | |||
| Object-centric models additionally have the following properties and functions. | |||
| {| class="wikitable" | |||
| !'''Object-Centric model properties''' | |||
| ! '''Description''' | |||
| |- | |||
| ||IsOcelModel (boolean) | |||
| ||Returns ''true'' when the model is an OCEL model. | |||
| |- | |||
| ||OcelEvents (Datatable) | |||
| ||Datatable containing event data for the OCEL model. Value ''null'' is returned if event datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |- | |||
| ||OcelEventToObject (Datatable) | |||
| ||Datatable containing event-to-object relations data for the OCEL model. Value ''null'' is returned if event-to-object relation datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |- | |||
| ||OcelEventTypes (Dictionary) | |||
| ||Returns a dictionary containing event type names as keys and the datatables holding event data for that event type in this OCEL model as value. An empty array is returned if event types datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| Example: Get datatable for "Create order" events: | |||
| <pre> | |||
| ModelById(1).OcelEventTypes.Get("Create order") | |||
| </pre> | |||
| |- | |||
| ||OcelObjects (Datatable) | |||
| ||Datatable containing objects data for the OCEL model. Value ''null'' is returned if object datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |- | |||
| ||OcelObjectToObject (Datatable) | |||
| ||Datatable containing object-to-object relations data for the OCEL model. Value ''null'' is returned if object-to-object relation datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |- | |||
| ||OcelObjectTypes (Dictionary) | |||
| ||Returns a dictionary containing object type names as keys and the datatables holding data for that object type in this OCEL model as value. An empty array is returned if object types have not been configured for this model. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |} | |||
| {| class="wikitable" | |||
| !'''Object-centric model functions''' | |||
| !'''Parameters''' | |||
| ! '''Description''' | |||
| |- | |||
| ||OcelEventType | |||
| ||Event type name (String) | |||
| || | |||
| Datatable containing event type attributes of given event type in this OCEL model. Value ''null'' is returned if a datatable is not configured for this model for given event type. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| Example: Get datatable for "Create order" events: | |||
| <pre> | |||
| ModelById(1).OcelEventType("Create order") | |||
| </pre> | |||
| |- | |||
| ||OcelObjectType | |||
| ||Object type name (String) | |||
| ||Datatable containing object type attributes of given object type in this OCEL model. Value ''null'' is returned if a datatable is not configured for this model for given object type. Throws an unsupported operation exception if the model is not an OCEL model. | |||
| |} | |} | ||
| Line 337: | Line 517: | ||
| ||CreatedDate (DateTime) | ||CreatedDate (DateTime) | ||
| ||Timestamp when the Project was created. | ||Timestamp when the Project was created. | ||
| |- | |||
| ||Configuration (Dictionary) | |||
| ||Project settings as Dictionary object. See example in ''ConfigurationJson'' property. | |||
| |- | |||
| ||ConfigurationJson (String) | |||
| ||Project settings as json string. | |||
| <pre> | |||
| { | |||
|   "DefaultLocationInDataSource": { | |||
|     "Database": "MyDatabase", | |||
|     "Schema": "MySchema" | |||
|   }, | |||
|   "ConnectionStringKeys": { | |||
|     "Snowflake": "MyKey1", | |||
|     "SqlServer": "MyKey2" | |||
|   } | |||
| } | |||
| </pre> | |||
| |- | |||
| ||Dashboards (Dashboard*) | |||
| ||Returns all [[Dashboard_in_Expression_Language|dashboards]] in the project. | |||
| |- | |- | ||
| ||Datatables (Datatable*) | ||Datatables (Datatable*) | ||
| Line 343: | Line 544: | ||
| ||DeletedDate (DateTime) | ||DeletedDate (DateTime) | ||
| ||Timestamp when the Project was deleted (moved to the recycle bin). | ||Timestamp when the Project was deleted (moved to the recycle bin). | ||
| |- | |||
| ||Description (String) | |||
| ||Project description. The project description may contain line breaks. | |||
| |- | |- | ||
| ||DeletedBy (User) | ||DeletedBy (User) | ||
| Line 363: | Line 567: | ||
| |- | |- | ||
| ||Parent (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. | ||Parent project, i.e. a Project where the Project is located in the hierarchy of Projects. Returns ''null'' for root level Projects. Throws an error if user doesn't have access to the parent project. | ||
| |- | |||
| ||ParentProjectId (Integer) | |||
| ||Parent project id. Returns ''null'' for root level Projects. The parent project id is returned even if user doesn't have access to the parent project. | |||
| |- | |- | ||
| ||Scripts (Script*) | ||Scripts (Script*) | ||
| ||Scripts that are in the Project. | ||Scripts that are in the Project. | ||
| |- | |||
| ||Secrets (Dictionary*) | |||
| ||Returns array of all [[Storing_Secrets_for_Scripts|secrets]] in the project as Dictionary with following properties: | |||
| * '''Name''' (string): Name of the secret. | |||
| * '''Type''' (string): Type of the secret which is one of the following: "odbc", "sap", "salesforce". | |||
| |} | |} | ||
| Line 374: | Line 586: | ||
| ! '''Description''' | ! '''Description''' | ||
| |- | |- | ||
| ||CreateDatatable (Datatable) | ||CreateDashboard (Dashboard) | ||
| ||Parameters dictionary | |||
| ||Creates a dashboard to the project. ''EditDashboards'' permission to the project is required. The parameter is dictionary with following supported dashboard properties: | |||
| * '''Name''' (String): Name of the dashboard. | |||
| * '''Identifier''' (String): Identifier of the dashboard. | |||
| * '''Description''' (String): Description of the dashboard. | |||
| * '''Content''' (Dictionary): Content of the dashboard. | |||
| Example: Create empty dashboard. | |||
| <pre> | |||
| ProjectById(1) | |||
|   .CreateDashboard(#{ | |||
|     "Name": "My dashboard", | |||
|     "Identifier": "MyDashboard" | |||
|   }); | |||
| </pre> | |||
| Example: Create dashboard with a chart. | |||
| <pre> | |||
| ProjectById(1) | |||
|   .CreateDashboard(#{ | |||
|     "Name": "My dashboard", | |||
|     "Content": #{ | |||
|       "version": 4, | |||
|       "typeName": "View", | |||
|       "name": "My dashboard", | |||
|       "subElements": [ | |||
|         #{ | |||
|           "position": #{ | |||
|             "x": 0, | |||
|             "y": 0, | |||
|             "width": 0.5, | |||
|             "height": 0.5, | |||
|             "zOrder": 0 | |||
|           }, | |||
|           "element": #{ | |||
|             "typeName": "Chart", | |||
|             "configuration": #{ | |||
|               "root": #{ | |||
|                 "expressionType": "Cases", | |||
|                 "expressionParameters": #{} | |||
|               }, | |||
|               "measures": [#{ | |||
|                 "expressionType": "Count", | |||
|                 "expressionParameters": #{} | |||
|               }] | |||
|             } | |||
|           } | |||
|         } | |||
|       ] | |||
|     } | |||
|   }); | |||
| </pre> | |||
| |- | |||
| ||<span id="CreateDatatable">CreateDatatable</span> (Datatable) | |||
| || | |||
| * Parameters dictionary | |||
| ||Creates datatable to the project. After creation, there are no columns or rows in the datatable. The function returns the created datatable entity. Following properties can be set for the datatable: | |||
| * '''Name''' (string): Name of the datatable. This parameter is mandatory. | |||
| * '''Description''' (string): Description for the datatable. This parameter is optional. | |||
| * '''NameInDataSource''' (string): Table name in the datasource (e.g., in Snowflake) which this datatable is linked to. This parameter is optional. | |||
| * '''SchemaNameInDataSource''' (string): Schema name in the datasource (e.g., in Snowflake) which this datatable is linked to. This parameter is optional. | |||
| * '''DatabaseNameInDataSource''' (string): Database name in the datasource (e.g., in Snowflake) which this datatable is linked to. This parameter is optional. | |||
| * '''Type''' (string): Defines where the data for the datatable is located. Available values are '''Snowflake''', '''SqlServer''', and '''Local'''.  This parameter is optional and default value is defined by the [[PA_Configuration_database_table#General_Settings|DefaultDataSource]] setting. | |||
| * '''Connection''': Connection object for the datatable. This parameter is optional. | |||
| Example: Create a new datatable: | |||
| <pre> | |||
| ProjectById(1).CreateDatatable(#{ | |||
|   "Name": "My datatable" | |||
| }); | |||
| </pre> | |||
| Example: Create Snowflake datatable linked to a custom table: | |||
| <pre> | |||
| ProjectById(1).CreateDatatable(#{ | |||
|   "Name": "My datatable", | |||
|   "Description": "My description", | |||
|   "NameInDataSource": "MyTable", | |||
|   "SchemaNameInDataSource": "MySchema", | |||
|   "DatabaseNameInDataSource": "MyDatabase", | |||
|   "Type": "Snowflake" | |||
| }); | |||
| </pre> | |||
| Example: Create Snowflake datatable where connection string is stored as a [[Storing_Secrets_for_Scripts|secret]]: | |||
| <pre> | |||
| ProjectById(1).CreateDatatable(#{ | |||
|   "Name": "My datatable", | |||
|   "Type": "Snowflake", | |||
|   "Connection": ProjectById(1).CreateSnowflakeConnection(#{ "OdbcConnectionStringKey": "MyKey" }) | |||
| }); | |||
| </pre> | |||
| |- | |||
| ||CreateModel (Model) | |||
| || | |||
| * Parameters dictionary | |||
| ||Creates a model to a project. Requires ''GenericWrite'' permission for the Project and global ''CreateModel'' permission. If a model with that name already exists, an exception is thrown. | |||
| Parameters dictionary has the following properties: | |||
| * '''Name''': Name of the model. This property is mandatory. | |||
| * '''Description''': Description of the model. This property is optional. | |||
| * '''Configuration''': Configuration dictionary for the model. This property is technically optional, but a working model requires at least datasource settings to be defined. | |||
| Example: | |||
| <pre> | |||
| ProjectById(1).CreateModel(#{     | |||
|   "Name": "My model", | |||
|   "Description": "My description", | |||
|   "Configuration": #{ | |||
|     "DataSource": #{ | |||
|       "Cases": #{ | |||
|         "DataSourceType": "datatable", | |||
|         "DataTableName": "My cases datatable", | |||
|         "Columns": #{ | |||
|           "CaseId": "Case Name" | |||
|         } | |||
|       }, | |||
|       "Events": #{ | |||
|         "DataSourceType": "datatable", | |||
|         "DataTableName": "My events datatable", | |||
|         "Columns": #{ | |||
|            "CaseId": "Case Name", | |||
|            "EventType": "Event Type", | |||
|            "Timestamp": "Start Time" | |||
|         } | |||
|       } | |||
|     } | |||
|   } | |||
| }); | |||
| </pre> | |||
| |- | |||
| ||<span id="CreateProject">CreateProject</span> (Project) | |||
| || | || | ||
| *  | * Parameters dictionary | ||
| *  | ||Create a project as a sub-project of the context project. Returns the created project. Requires the ''ManageProject'' permission. | ||
| Parameters dictionary has the following properties: | |||
| * '''Name''' (string): Name of the project. This property is required. | |||
| * '''Description''' (string): Description of the project. | |||
| * '''ParentProjectId''' (integer): Id of the parent project where the new project is created. This parameter is usually not needed because the parent project is the context project. The CreateProject function is also available in the generic context where the ''ParentProjectId'' parameter is needed to create sub-projects. | |||
| * '''DatabaseNameInDataSource''' (string): Snowflake database the project is linked to. Data for the datatables in this project will be located in this database. | |||
| * '''SchemaNameInDataSource''' (string): Snowflake schema the project is linked to. Data for the datatables in this project will be located in this schema. If the schema is defined, also the ''DatabaseNameInDataSource'' needs to be defined. | |||
| * '''SnowflakeConnectionStringKey''' (string): Snowflake connection string key to be used for the datatables in this project.  | |||
| Example: | |||
| <pre> | |||
| ProjectById(1).CreateProject(#{ | |||
|   "Name": "My project",  | |||
|   "Description": "My description",  | |||
|   "DatabaseNameInDataSource": "My database",  | |||
|   "SchemaNameInDataSource": "My schema"  | |||
| }) | |||
| </pre> | |||
| |- | |- | ||
| ||DatatableByName (Datatable) | ||DatatableByName (Datatable) | ||
| ||Datatable name (String) | ||Datatable name (String) | ||
| || | || | ||
| Returns Datatable by its name located in the project. Returns null, if Datatable with that name does not exist in the project. | |||
| Example: | Example: | ||
| <pre> | <pre> | ||
| ProjectById(123).DatatableByName("MyDatatable1") | ProjectById(123).DatatableByName("MyDatatable1") | ||
| </pre> | |||
| Example: Get datatable by name, and create it if it doesn't exist: | |||
| <pre> | |||
| let project = ProjectById(123); | |||
| let datatableName = "MyDatatable1"; | |||
| let datatable = project.DatatableByName(datatableName); | |||
| if (datatable == null) { | |||
|   datatable = project.CreateDatatable(datatableName); | |||
| } | |||
| </pre> | </pre> | ||
| |- | |- | ||
| Line 393: | Line 764: | ||
| ||(none) | ||(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. | ||Deletes the Project permanently. Note that the Project doesn't need to be in the recycle bin to be able to delete it permanently. | ||
| |- | |||
| ||Export (String) | |||
| ||(none) | |||
| ||Exports the project and its content to a json string. The json format is described in [[Projects Export File Format]]. | |||
| Example: Export project id 1 to json data: | |||
| <pre> | |||
| ProjectById(1).Export(); | |||
| </pre> | |||
| |- | |||
| ||Import | |||
| ||JSON string | |||
| ||Creates one or several projects from a json string. The project(s) are created as child projects of the context project. The json format is described in [[Projects Export File Format]]. The function returns the created project objects. In case the project names already exist, the import operation automatically adjusts the names to be unique. | |||
| Example: Create project from json data (as child of project id 1): | |||
| <pre> | |||
| let jsonData = `{ "Projects": [ { "Name": "My project" } ] }`; | |||
| let createdProjects = ProjectById(1).Import(jsonData); | |||
| </pre> | |||
| |- | |- | ||
| ||Restore | ||Restore | ||
| ||(none) | ||(none) | ||
| ||Restores the Project from the recycle bin back to the original location. | ||Restores the Project from the recycle bin back to the original location. | ||
| |- | |||
| ||ModelByName (Model) | |||
| ||Model name (String) | |||
| || | |||
| Returns Model by its name located in the project. Returns null, if Model with that name does not exist in the project. | |||
| Example: | |||
| <pre> | |||
| ProjectById(123).ModelByName("My Model 1") | |||
| </pre> | |||
| |- | |||
| ||<span id="ModifyProject">Modify</span> (Project) | |||
| ||Dictionary of settings to change | |||
| || | |||
| Change project settings. Following settings are supported: | |||
| * '''Name''' (String): Name of the project. | |||
| * '''Description''' (String): Description text of the project. | |||
| * '''ParentProjectId''' (Integer): Parent project id. Changing this effectively moves the project into different parent project. | |||
| * '''DatabaseNameInDataSource''': Name of the Snowflake database where the project's datatables are located. The database needs to exist in the same Snowflake account configured in the Snowflake connection string. When defining this setting, define also the ''SchemaNameInDataSource''. | |||
| * '''SchemaNameInDataSource''': Name of the Snowflake schema where the project's datatables are located. The schema needs to exist in the same Snowflake account configured in the Snowflake connection string. When defining this setting, define also the ''DatabaseNameInDataSource''. | |||
| * '''SnowflakeConnectionStringKey''' (String): Snowflake connection string key for the project. Snowflake datatables in the project will use connection string behind this key (unless specified by the datatatable). | |||
| * '''SqlServerConnectionStringKey''' (String): SQL Server connection string key. SQL Server datatables in the project will use connection string behind this key (unless specified by the datatatable). | |||
| ''ManageProject'' permission is needed to change project properties. | |||
| Example: Change project name and move project into other parent project: | |||
| <pre> | |||
| ProjectById(1) | |||
|   .Modify(#{ | |||
|     "Name": "Project 1" | |||
|     "ParentProjectId": 2 | |||
| }); | |||
| </pre> | |||
| Example: Set Snowflake connection string key for the project: | |||
| <pre> | |||
| ProjectById(1) | |||
|   .Modify(#{ | |||
|     "SnowflakeConnectionStringKey": "MyKey1" | |||
| }); | |||
| </pre> | |||
| |- | |||
| ||ScriptByName (Script) | |||
| ||Script name (String) | |||
| || | |||
| Returns Script by its name located in the project. Returns null, if Script with that name does not exist in the project. | |||
| Example: | |||
| <pre> | |||
| ProjectById(123).ScriptByName("MyScript1") | |||
| </pre> | |||
| |- | |||
| ||<span id="SetSecret">SetSecret</span> | |||
| || | |||
| # Secret type (string) | |||
| # Secret name (string) | |||
| # Secret value (string) | |||
| ||Sets or adds a [[Storing_Secrets_for_Scripts|secret]] for the project. Setting the secret value to ''null'' removes the secret. There can be several secrets with the same name in the same project if the type of the secret is different. Setting secrets requires the project specific ''ManageProject'' permission. | |||
| Parameters: | |||
| # '''Type''' (string): Secret type which is one of the following: | |||
| #* "externaldatatableconnection": ODBC connection string used by a datatable (e.g., connection string to Snowflake or SQL Server database) | |||
| #* "odbc": ODBC connection string (e.g., to extract data, or load a model directly) | |||
| #* "sap": SAP password | |||
| #* "salesforce": Salesforce password | |||
| # '''Name''' (string): Secret name, used to refer to the secret in the commands. | |||
| # '''Value''' (string): Secret value which contains the confidential information. | |||
| Example: Set SAP password: | |||
| <pre> | |||
| ProjectById(1).SetSecret("sap", "MySapPassword", "I l0ve 5AP!"); | |||
| </pre> | |||
| Example: Remove SAP password: | |||
| <pre> | |||
| ProjectById(1).SetSecret("sap", "MySapPassword", null); | |||
| </pre> | |||
| |} | |} | ||
| Functions to get project: | |||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| Line 408: | Line 875: | ||
| ||Project id (Integer) | ||Project id (Integer) | ||
| || | || | ||
| Returns  | Returns project object corresponding to the provided project id. | ||
| |- | |||
| ||ProjectByName | |||
| ||Project name (String) | |||
| || | |||
| Returns project object by given project name. If there is no such project or user doesn't have access to it, ''null'' value is returned. If there are multiple projects with the same name, one of them is returned. | |||
| Example: | |||
| <pre> | |||
| let project = ProjectByName("My Project"); | |||
| </pre> | |||
| |} | |||
| Functions to create project: | |||
| {| class="wikitable" | |||
| !'''Functions''' | |||
| !'''Parameters''' | |||
| ! '''Description''' | |||
| |- | |||
| ||<span id="CreateProject">CreateProject</span> (Project) | |||
| ||Parameters dictionary | |||
| ||Create a project. This is a similar function as the [[QPR_ProcessAnalyzer_Objects_in_Expression_Language#CreateProject|CreateProject function]] in the project context. This function in the generic context is needed to create root-level projects (which don't have parent project). | |||
| Example: create a root project: | |||
| <pre> | |||
| CreateProject(#{ | |||
|   "Name": "My project" | |||
| }) | |||
| </pre> | |||
| Example: create a sub-project: | |||
| <pre> | |||
| CreateProject(#{ | |||
|   "Name": "My project" | |||
|   "ParentProjectId": 1 | |||
| }) | |||
| </pre> | |||
| |- | |||
| ||<span id="Import">Import</span> (Project*) | |||
| ||JSON string | |||
| ||Creates one or several projects from a json string. The project(s) are created as the root level projects. The json format is described in [[Projects Export File Format]]. The function returns the created project objects. In case the project names already exist, the import operation automatically adjusts the names to be unique. | |||
| Example: Create a root level project from json data: | |||
| <pre> | |||
| let jsonData = `{ "Projects": [ { "Name": "My project" } ] }`; | |||
| Import(jsonData); | |||
| </pre> | |||
| |} | |} | ||
| Line 492: | Line 1,005: | ||
| 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). | 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  | When a script is called using the Run function, the called script status does not change, because 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. | It's possible to call a script using the Run function several times simultaneously. | ||
| Line 509: | Line 1,022: | ||
| </pre> | </pre> | ||
| The script can be called as follows: | The script can be called as follows (returning 16): | ||
| <pre> | <pre> | ||
| let runResult = ScriptById(123).Run(#{ | let runResult = ScriptById(123).Run(#{ | ||
| Line 515: | Line 1,028: | ||
|    "exponent": 2 |    "exponent": 2 | ||
| }) | }) | ||
| </pre> | |||
| </pre>   | |- | ||
| ||<span id="Start">Start</span> | |||
| ||Dictionary of parameters | |||
| ||Starts the script. The function call doesn't wait for the script run to complete (i.e., asynchronous behavior) which is sane as starting the script in the [[Managing_Scripts#Starting_Script|Workspace]]. | |||
| Parameters to the script can be provided as a dictionary of name-value pairs (which is not possible when script is started in the Workspace). Return value is the script run id (integer) if the script was started. If the script is already running, return value is ''null''. | |||
| Example: Start script (without parameters) and store the script run id: | |||
| <pre> | |||
| let runId = ScriptById(1).Start(); | |||
| </pre> | |||
| Example: Start script with passing parameters: | |||
| <pre> | |||
| ScriptById(1).Start(#{ | |||
|   "variable1": "val1", | |||
|   "variable2": 5 | |||
| }); | |||
| </pre> | |||
| |- | |||
| ||Stop | |||
| || | |||
| ||Stops the script. The operation doesn't wait for the stopping to complete (i.e., asynchronous behavior) which is same as stopping the script in the [[Managing_Scripts#Stopping_Script|Workspace]]. Depending on the operation that the script is performing, the stopping might take some time. | |||
| Return value is the script run id (integer) if the script was running. If the script isn't running, the return value is ''null''. | |||
| Example: | |||
| <pre> | |||
| let runId = ScriptById(1).Stop(); | |||
| </pre> | |||
| |} | |} | ||
| Function to get a script by the script id: | Function to get a script by the script id: | ||
| {| class="wikitable" | {| class="wikitable" | ||
| !''' | !'''Functions''' | ||
| !'''Parameters''' | !'''Parameters''' | ||
| ! '''Description''' | ! '''Description''' | ||
| Line 529: | Line 1,071: | ||
| * Script id (Integer) | * Script id (Integer) | ||
| || | || | ||
| Returns Script object corresponding to the  | Returns Script object corresponding to the given script id. If script with the given id doesn't exist or user doesn't have permissions to it, an error is given. | ||
| |} | |} | ||
| Line 538: | Line 1,080: | ||
| !'''User/group properties''' | !'''User/group properties''' | ||
| ! '''Description''' | ! '''Description''' | ||
| |- | |||
| ||CreatedBy (User) | |||
| ||Returns the user who created the user. | |||
| |- | |||
| ||CreatedDate (DateTime) | |||
| ||Returns the date when the user was created. | |||
| |- | |||
| ||DefaultDashboard (String) | |||
| ||Returns the configured [[User_Settings#Starting_dashboard|starting dashboard]] ("default dashboard") identifier for a group (for users, the starting dashboard cannot be configured). The starting dashboard is automatically opened when a user logs in. | |||
| |- | |- | ||
| ||Description (String) | ||Description (String) | ||
| ||Description of the user. | ||Description of the user. | ||
| |- | |||
| ||EffectiveDefaultDashboard (String) | |||
| ||Returns the [[User_Settings#Starting_dashboard|starting dashboard]] of a user. Value ''null'' means that the user doesn't have a starting dashboard. The starting dashboard comes from the user's groups. If multiple of user's groups have the starting dashboard defined, the user's starting dashboard will be taken from a group having alphabetically the first name. | |||
| |- | |- | ||
| ||Email (String) | ||Email (String) | ||
| Line 549: | Line 1,103: | ||
| |- | |- | ||
| ||GlobalPermissions (String*) | ||GlobalPermissions (String*) | ||
| ||Array of global [[Roles and Permissions  | ||Array of global [[Roles and Permissions#Global_and_Project_Roles|permissions]] of the user. Global permissions come from the global roles assigned to the user and groups that the user belongs to. Note that to get the effective permissions for certain objects, also project specific permissions need to be taken into account. | ||
| |- | |- | ||
| ||GroupMemberNames (String*) | ||GroupMemberNames (String*) | ||
| Line 562: | Line 1,116: | ||
| ||Groups (User*) | ||Groups (User*) | ||
| ||Array of user groups the user belongs to. This property is available for users. | ||Array of user groups the user belongs to. This property is available for users. | ||
| |- | |||
| ||HasPassword (Boolean) | |||
| ||Returns true if user has a password defined in QPR ProcessAnalyzer and thus user can authenticate using the password. If user doesn't have a password, the SAML authentication is the only way to log in. ''ManageUsers'' permission is needed to access this property for other users. | |||
| |- | |- | ||
| ||Id (Integer) | ||Id (Integer) | ||
| Line 571: | Line 1,128: | ||
| ||IsGroup (Boolean) | ||IsGroup (Boolean) | ||
| ||Returns true if the user is a user group. | ||Returns true if the user is a user group. | ||
| |- | |||
| ||IsLocked (Boolean) | |||
| ||Returns true if user account is currently [[User_Session_Management#Preventing_password_guessing_attacks|locked]]. ''ManageUsers'' permission is needed to access this property. | |||
| |- | |||
| ||LastLockedDate (DateTime) | |||
| ||Returns date when user account was locked the last time. Returns ''null'' if the user account has never been locked. ''ManageUsers'' permission is needed to access this property. | |||
| |- | |||
| ||LastLoginDate (DateTime) | |||
| ||Returns date when the user made last successful login. ''ManageUsers'' permission is needed to access this property for other users. | |||
| |- | |||
| ||LastModifiedBy (User) | |||
| ||Returns the user who last modified this user. | |||
| |- | |||
| ||LastModifiedDate (DateTime) | |||
| ||Returns the date when the user was last modified. | |||
| |- | |- | ||
| ||Name (String) | ||Name (String) | ||
| ||Login name of the user or group. | ||Login name of the user or group. | ||
| |- | |- | ||
| ||Roles ( | ||Roles (Object**) | ||
| || | || | ||
| Returns all roles of the user (both global and project roles) as a nested array structure. | |||
| Example: | |||
| <pre> | |||
| ToJson(Users.Where(name == "qpr").Roles) | |||
| Returns (for example): | |||
| [ | |||
|   [{"calcId": "Project:1"}, "Administrator"], | |||
|   [{"calcId": "Project:2"}, "Analyzer"], | |||
|   [{"calcId": "Project:3"}, "Viewer"], | |||
|   [null, "RunScripts"], | |||
|   [null, "Administrator"] | |||
| ] | |||
| </pre> | |||
| |} | |} | ||
| Line 592: | Line 1,178: | ||
| Permissions for the EffectivePermissionsFor function are as follows: | Permissions for the EffectivePermissionsFor function are as follows: | ||
| * All users can query their own permissions | * All users can query their own permissions | ||
| * To get permissions for any user, the user needs to have [[ | * To get permissions for any user, the user needs to have [[Roles_and_Permissions|ManageUsers permission]]. | ||
| Note that ''inactive'' users don't have any effective permissions, so the EffectivePermissionsFor function does not return any permissions for those users. | Note that ''inactive'' users don't have any effective permissions, so the EffectivePermissionsFor function does not return any permissions for those users. | ||
| Line 598: | Line 1,184: | ||
| Examples: | Examples: | ||
| <pre> | <pre> | ||
| EffectivePermissionsFor(ModelById( | UserById(1).EffectivePermissionsFor(ModelById(2).Project) | ||
| Returns (for example): ["EditDashboards", "Filtering", "GenericRead"] | Returns (for example): ["EditDashboards", "Filtering", "GenericRead"] | ||
| </pre> | |||
| |- | |||
| ||GetAttribute | |||
| || | |||
| || | |||
| Returns user attribute value by given attribute name and optionally by the model/project/dashboard context. Supported data types are String, Integer, Float, and DateTime. To store more complex data types, data can be converted into json and stored as string. If the attribute doesn't exist, null is returned. | |||
| For example, if using dashboard as context, the attributes are effectively bound to each user and each dashboard separately. Thus, there can be several attributes with the same name as long as the dashboard is different. | |||
| Parameters: | |||
| # '''Attribute name''' (String): Name of the attribute. | |||
| # '''Attribute context''' (Project/Model/Dashboard): Optional context object the attribute is linked to. | |||
| Users have permissions to get attributes for themselves, and also (administrator) users with global ''ManageUsers'' permission can get attributes for all users. In addition, if using the context object, the ''GenericRead'' permission is required for the context object. | |||
| Example: Get user attribute MyDataValue for myself: | |||
| <pre> | |||
| CurrentUser | |||
|   .GetAttribute("MyDataValue"); | |||
| </pre> | |||
| Example: Get user attribute MyDataValue for user John: | |||
| <pre> | |||
| Users | |||
|   .Where(Name=="John") | |||
|   .GetAttribute("MyDataValue"); | |||
| </pre> | |||
| Example: Get user attribute MyDataValue for user 1 related to dashboard id 1: | |||
| <pre> | |||
| UserById(1) | |||
|   .GetAttribute("MyDataValue", DashboardById(1)); | |||
| </pre> | |||
| |- | |||
| ||SetAttribute | |||
| || | |||
| || | |||
| Sets user attribute value for given attribute name and optionally for the model/project/dashboard context. Supported data types are String, Integer, Float, and DateTime. To store more complex data types, data can be converted into json and stored as string. If setting value ''null'', the user attribute is removed. Required permissions are same as in the GetAttribute function. | |||
| Parameters: | |||
| # '''Attribute name''' (String): Name of the attribute. | |||
| # '''Attribute value''' (String/Integer/Float/DateTime): Attribute value to be stored. | |||
| # '''Attribute context''' (Project/Model/Dashboard): Optional context object the attribute value is linked to. | |||
| Example: Set user attribute MyDataValue for myself: | |||
| <pre> | |||
| CurrentUser | |||
|   .SetAttribute("MyDataValue ", "value"); | |||
| </pre> | |||
| Example: Set value 123 as user attribute MyDataValue for user John: | |||
| <pre> | |||
| Users | |||
|   .Where(Name=="John") | |||
|   .SetAttribute("MyDataValue", 123); | |||
| </pre> | |||
| Example: Set current time as user attribute MyDataValue for user 1 related to dashboard id 1: | |||
| <pre> | |||
| UserById(1) | |||
|   .GetAttribute("MyDataValue", Now, DashboardById(1)); | |||
| </pre> | </pre> | ||
| |} | |} | ||
| Function to get User by user id: | |||
| {| class="wikitable" | |||
| !'''Functions''' | |||
| !'''Parameters''' | |||
| ! '''Description''' | |||
| |- | |||
| ||UserById (User) | |||
| || | |||
| * User id (Integer) | |||
| || | |||
| Returns User object that has the provided user id. Also groups can be queried with this function. Returns an access denied error if the user with given id does not exist or the current user does not have access to it. | |||
| |} | |||
Latest revision as of 10:46, 10 September 2025
Filter
Filters contain a set of filter rules used to filter cases and events in models. Filters are objects located in the models. Filters are owned by the creator user, and when a filter publish mode is private, only the creator can use it.
| Filter properties | Description | 
|---|---|
| CreatedBy (User) | Returns the user who created the filter. | 
| CreatedDate (DateTime) | Returns date when the filter created date. | 
| Description (String) | Returns description of the filter. | 
| Id (Integer) | Returns id of the filter. | 
| LastModifiedBy (User) | Returns user who modified the filter. | 
| LastModifiedDate (DateTime) | Returns date when the filter last modified. | 
| Model | Returns model where the filter belongs to. | 
| ModelId (Integer) | Returns model where the filter belongs to. | 
| Name (String) | Returns the name of the filter. | 
| Project | Returns project where the filter belongs to. | 
| ProjectId (Integer) | Returns project id where the filter belongs to. | 
| PublishMode (String) | Returns publish mode of the filter, one of the following: Private, Public, or Default. | 
| Rules (Dictionary) | Returns a dictionary containing the filter rules in the filter. | 
| Filter functions | Parameters | Description | 
|---|---|---|
| DeletePermanently | (none) | Deletes the filter permanently. To delete own filters, the Filtering permission is needed, and to delete any filters the ManageViews permission is needed. | 
| Modify | Dictionary | Modifies filter properties. The parameter is a dictionary containing the properties to be changed. Following properties can be changed: Name, Description, PublishMode, and Rules. The function returns the updated filter object. Requires GenericWrite permission for the Project and global CreateModel permission. Example: FilterById(1)
	.Modify(#{
		"Name": "My filter",
		"Description": "My description",
		"PublishMode": "Public",
		"Rules": #{
			"Items": [
				#{
					"Type": "IncludeCases",
					"Items": [
						#{
							"Type": "CaseAttributeValue",
							"Attribute": "Account Manager",
							"StringifiedValues": [
								"0Mary Wilson"
							]
						}
					]
				}
			]
		}
	}
)
 | 
Function to get filter id:
| Functions | Parameters | Description | 
|---|---|---|
| FilterById | 
 | Returns Filter object corresponding to the provided filter id. | 
Model
Notes:
- For in-memory 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.
- Properties CaseAttributes, EventAttributes and Eventlog work only for the in-memory models and they require 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 properties down require the model to be in the memory.
| 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. | 
| Configuration (Dictionary) | Returns the Model configuration as dictionary. Example: ModelById(123).Configuration.DataSource.Events.DataTableName | 
| ConfigurationJson (String) | Returns the Model configuration as JSON string. | 
| 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. | 
| DefaultFilter (Filter) | Default filter of the model. Returns null if the model does not have a default filter. | 
| 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. | 
| Diagrams (Diagram*) | Returns an array of all diagrams in 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. | 
| Filters (Filter*) | Returns an array of all filters in the model. | 
| Id (Integer) | Model Id. Model Id is generated by QPR ProcessAnalyzer when the model is created. | 
| IsValidInMemoryModel (boolean) | Returns true if all the following conditions are met: 
 | 
| LastModifiedBy (User) | User who last time modified the model properties. Note that datatables containing the eventlog data are separate objects having similar fields to track the last modification and last data import. | 
| LastModifiedDate (DateTime) | Timestamp when the model was modified the last time. | 
| Name (String) | Model name. | 
| NCache (Integer) | Number of objects related to the model when the model is loaded into the memory. | 
| NCaseAttributes (Integer) | Number of CaseAttributes in model. Works only for in-memory models. | 
| NCases (Integer) | Number of Cases in the model. Works only for in-memory models. | 
| NEventAttributes (Integer) | Number of EventAttributes in model. Works only for in-memory models. | 
| NEvents (Integer) | Number of Events in model. Works only for in-memory models. | 
| NEventTypes (Integer) | Number of EventTypes in the model. Works only for in-memory models. | 
| Project (Project) | Project where the model belongs to. | 
| ProjectId (Integer) | Project id where the model belongs to. | 
| Status (String) | Memory availability status of the model. There are the following statuses: 
 | 
| UsedDatatables (Datatable*) | Returns all datatables the model uses as a datasource. Example: List datatables used by a model: StringJoin(", ", OrderByValue(ModelById(1).UsedDataTables.Name))
 | 
| Model functions | 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")
 | 
| CreateDiagram (Diagram) | Parameters dictionary | Creates a diagram to the model. Parameters is a dictionary containing diagram properties. Following properties are available: 
 Example: ModelById(1)
  .CreateDiagram(#{
    "Name": "My diagram",
    "Description": "This is my new diagram",
    "Content": #{ ... },
  })
 | 
| CreateFilter (Filter) | Parameters dictionary | Creates a filter to a model. Requires GenericWrite permission for the project and global CreateModel permission. If a filter with that name already exists in the model, an exception is thrown. The parameters dictionary may have the following properties: 
 Example: let newFilter = modelById(1).CreateFilter(#{    
  "Name": "My Filter",
  "Rules": #{
    "Items": [#{
      "Type": "IncludeCases",
      "Items": [#{
        "Type": "CaseAttributeValue",
        "Attribute": "Account Manager",
        "StringifiedValues": [ "0Robert Miller" ]
      }]
    }]
  },
  "PublishMode": "Public"
});
}
 | 
| DeletePermanently | (none) | Deletes the Model permanently. The model doesn't need to be in the recycle bin to be able to delete it permanently. | 
| Modify (Model) | Dictionary | Modifies model properties. The parameter is a dictionary containing the properties to be changed. Following properties can be changed: Name, Description, ProjectId, and Configuration. The function returns the updated model object. Requires the GenericWrite permission for the project and the global CreateModel permission. Example: ModelById(1)
	.Modify(#{
		"Name": "My model",
		"Description": "My description",
		"ProjectId": 2,
		"Configuration": #{
			"DataSource": #{
				"Cases": #{
					"DataSourceType": "datatable",
					"DataTableName": "My cases datatable",
					"Columns": #{
						"CaseId": "Case Name"
					}
				},
				"Events": #{
					"DataSourceType": "datatable",
					"DataTableName": "My events datatable",
					"Columns": #{
						"CaseId": "Case Name",
						"EventType": "Event Type",
						"Timestamp": "Start Time"
					}
				}
			}
		}
	}
)
 | 
| ResetModelCache | (none) | Synchronously clears all cached model data. For a Snowflake model, deletes all cache tables related to the model from Snowflake. For an in-memory model, drops the model from the memory and also drops all other model related caches from the memory. | 
| ResetPreprocessings | (none) | Removes all cached items related to the Model, e.g. preprocessings and calculation results. In practice, the Model is reset to a state where it was right after the model was loaded into memory. | 
| Restore | (none) | Restores the Model from the recycle bin back to the original location. | 
| ToSqlDataFrame | In-memory dataframe | Converts an in-memory dataframe to an SQL dataframe. In practice, an SQL query is created from the in-memory dataframe and the query is executed in the datasource so that the data is available in the datasource for further SQL operations. This function is intended only to small amounts of data which is less than 16384 rows. Example: Select matching cases from events data using in-memory dataframe: let model = ModelById(1);
let dfEvents = model.EventsDatatable.SqlDataFrame;
let inMemoryDf = ToDataFrame(
  [["1"], ["2"], ["3"]],
  [#{"Name": "id", "DataType": "String"}]
);
model.ToSqlDataFrame(inMemoryDf)
  .Join(dfEvents, ["id": "CaseId"])
  .SelectDistinct(["CaseId"])
  .Collect();
 | 
| 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. | 
| CheckModelValidity (Object array) | CheckData field in dictionary | Checks the model validity and returns found issues. The returned data is an array of objects where each object represents one validity error and contains the following properties: 
 There are two types of checks available (based on whether the CheckData parameter is defined): 
 The lightweight check is performed automatically by the Workspace, so if there are any validity issues that the lightweight check can detect, the Workspace notifies about them immediately. If there are any problems with the model calculation results, it might be a good idea to run the full validity check to confirm whether the problems are due to the model being invalid. Example: Lightweight check: ToJson(ModelById(1).CheckModelValidity()) Example: Full check: ToJson(ModelById(1).CheckModelValidity(#{ "CheckData": true }))
 | 
| CortexAgentsQuery | Creates a Snowflake Cortex semantic model (see GetSemanticModel function) for the process mining model and makes a natural language query on it using Snowflake Cortex Agents. More information: https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-agents. There are the following parameters: 
 The function returns a dictionary with the following keys: 
 | |
| GetSemanticModel | Creates a Snowflake Cortex Analyst semantic model for the process mining model and returns it as a dictionary. More information: https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-analyst/semantic-model-spec. There are the following parameters: 
 Examples: Returns a semantic model without any filtering applied. ModelById(1).GetSemanticModel(); | 
Function to get Model by model id:
| Functions | Parameters | Description | 
|---|---|---|
| ModelById | 
 | Returns Model object corresponding to the provided model id. | 
Object-centric model
Object-centric models additionally have the following properties and functions.
| Object-Centric model properties | Description | 
|---|---|
| IsOcelModel (boolean) | Returns true when the model is an OCEL model. | 
| OcelEvents (Datatable) | Datatable containing event data for the OCEL model. Value null is returned if event datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | 
| OcelEventToObject (Datatable) | Datatable containing event-to-object relations data for the OCEL model. Value null is returned if event-to-object relation datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | 
| OcelEventTypes (Dictionary) | Returns a dictionary containing event type names as keys and the datatables holding event data for that event type in this OCEL model as value. An empty array is returned if event types datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. Example: Get datatable for "Create order" events: ModelById(1).OcelEventTypes.Get("Create order")
 | 
| OcelObjects (Datatable) | Datatable containing objects data for the OCEL model. Value null is returned if object datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | 
| OcelObjectToObject (Datatable) | Datatable containing object-to-object relations data for the OCEL model. Value null is returned if object-to-object relation datatable has not been configured for the model. Throws an unsupported operation exception if the model is not an OCEL model. | 
| OcelObjectTypes (Dictionary) | Returns a dictionary containing object type names as keys and the datatables holding data for that object type in this OCEL model as value. An empty array is returned if object types have not been configured for this model. Throws an unsupported operation exception if the model is not an OCEL model. | 
| Object-centric model functions | Parameters | Description | 
|---|---|---|
| OcelEventType | Event type name (String) | Datatable containing event type attributes of given event type in this OCEL model. Value null is returned if a datatable is not configured for this model for given event type. Throws an unsupported operation exception if the model is not an OCEL model. Example: Get datatable for "Create order" events: ModelById(1).OcelEventType("Create order")
 | 
| OcelObjectType | Object type name (String) | Datatable containing object type attributes of given object type in this OCEL model. Value null is returned if a datatable is not configured for this model for given object type. Throws an unsupported operation exception if the model is not an OCEL model. | 
Project
| Project properties | Description | 
|---|---|
| CreatedBy (User) | User who created the Project. | 
| CreatedDate (DateTime) | Timestamp when the Project was created. | 
| Configuration (Dictionary) | Project settings as Dictionary object. See example in ConfigurationJson property. | 
| ConfigurationJson (String) | Project settings as json string. {
  "DefaultLocationInDataSource": {
    "Database": "MyDatabase",
    "Schema": "MySchema"
  },
  "ConnectionStringKeys": {
    "Snowflake": "MyKey1",
    "SqlServer": "MyKey2"
  }
}
 | 
| Dashboards (Dashboard*) | Returns all dashboards in the project. | 
| Datatables (Datatable*) | Returns all Datatables in the project. | 
| DeletedDate (DateTime) | Timestamp when the Project was deleted (moved to the recycle bin). | 
| Description (String) | Project description. The project description may contain line breaks. | 
| 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. Throws an error if user doesn't have access to the parent project. | 
| ParentProjectId (Integer) | Parent project id. Returns null for root level Projects. The parent project id is returned even if user doesn't have access to the parent project. | 
| Scripts (Script*) | Scripts that are in the Project. | 
| Secrets (Dictionary*) | Returns array of all secrets in the project as Dictionary with following properties: 
 | 
| Project functions | Parameters | Description | 
|---|---|---|
| CreateDashboard (Dashboard) | Parameters dictionary | Creates a dashboard to the project. EditDashboards permission to the project is required. The parameter is dictionary with following supported dashboard properties: 
 Example: Create empty dashboard. ProjectById(1)
  .CreateDashboard(#{
    "Name": "My dashboard",
    "Identifier": "MyDashboard"
  });
Example: Create dashboard with a chart. ProjectById(1)
  .CreateDashboard(#{
    "Name": "My dashboard",
    "Content": #{
      "version": 4,
      "typeName": "View",
      "name": "My dashboard",
      "subElements": [
        #{
          "position": #{
            "x": 0,
            "y": 0,
            "width": 0.5,
            "height": 0.5,
            "zOrder": 0
          },
          "element": #{
            "typeName": "Chart",
            "configuration": #{
              "root": #{
                "expressionType": "Cases",
                "expressionParameters": #{}
              },
              "measures": [#{
                "expressionType": "Count",
                "expressionParameters": #{}
              }]
            }
          }
        }
      ]
    }
  });
 | 
| CreateDatatable (Datatable) | 
 | Creates datatable to the project. After creation, there are no columns or rows in the datatable. The function returns the created datatable entity. Following properties can be set for the datatable: 
 Example: Create a new datatable: ProjectById(1).CreateDatatable(#{
  "Name": "My datatable"
});
Example: Create Snowflake datatable linked to a custom table: ProjectById(1).CreateDatatable(#{
  "Name": "My datatable",
  "Description": "My description",
  "NameInDataSource": "MyTable",
  "SchemaNameInDataSource": "MySchema",
  "DatabaseNameInDataSource": "MyDatabase",
  "Type": "Snowflake"
});
Example: Create Snowflake datatable where connection string is stored as a secret: ProjectById(1).CreateDatatable(#{
  "Name": "My datatable",
  "Type": "Snowflake",
  "Connection": ProjectById(1).CreateSnowflakeConnection(#{ "OdbcConnectionStringKey": "MyKey" })
});
 | 
| CreateModel (Model) | 
 | Creates a model to a project. Requires GenericWrite permission for the Project and global CreateModel permission. If a model with that name already exists, an exception is thrown. Parameters dictionary has the following properties: 
 Example: ProjectById(1).CreateModel(#{    
  "Name": "My model",
  "Description": "My description",
  "Configuration": #{
    "DataSource": #{
      "Cases": #{
        "DataSourceType": "datatable",
        "DataTableName": "My cases datatable",
        "Columns": #{
          "CaseId": "Case Name"
        }
      },
      "Events": #{
        "DataSourceType": "datatable",
        "DataTableName": "My events datatable",
        "Columns": #{
           "CaseId": "Case Name",
           "EventType": "Event Type",
           "Timestamp": "Start Time"
        }
      }
    }
  }
});
 | 
| CreateProject (Project) | 
 | Create a project as a sub-project of the context project. Returns the created project. Requires the ManageProject permission. Parameters dictionary has the following properties: 
 Example: ProjectById(1).CreateProject(#{
  "Name": "My project", 
  "Description": "My description", 
  "DatabaseNameInDataSource": "My database", 
  "SchemaNameInDataSource": "My schema" 
})
 | 
| DatatableByName (Datatable) | Datatable name (String) | Returns Datatable by its name located in the project. Returns null, if Datatable with that name does not exist in the project. Example: ProjectById(123).DatatableByName("MyDatatable1")
Example: Get datatable by name, and create it if it doesn't exist: let project = ProjectById(123);
let datatableName = "MyDatatable1";
let datatable = project.DatatableByName(datatableName);
if (datatable == null) {
  datatable = project.CreateDatatable(datatableName);
}
 | 
| 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. | 
| Export (String) | (none) | Exports the project and its content to a json string. The json format is described in Projects Export File Format. Example: Export project id 1 to json data: ProjectById(1).Export(); | 
| Import | JSON string | Creates one or several projects from a json string. The project(s) are created as child projects of the context project. The json format is described in Projects Export File Format. The function returns the created project objects. In case the project names already exist, the import operation automatically adjusts the names to be unique. Example: Create project from json data (as child of project id 1): let jsonData = `{ "Projects": [ { "Name": "My project" } ] }`;
let createdProjects = ProjectById(1).Import(jsonData);
 | 
| Restore | (none) | Restores the Project from the recycle bin back to the original location. | 
| ModelByName (Model) | Model name (String) | Returns Model by its name located in the project. Returns null, if Model with that name does not exist in the project. Example: ProjectById(123).ModelByName("My Model 1")
 | 
| Modify (Project) | Dictionary of settings to change | Change project settings. Following settings are supported: 
 ManageProject permission is needed to change project properties. Example: Change project name and move project into other parent project: ProjectById(1)
  .Modify(#{
    "Name": "Project 1"
    "ParentProjectId": 2
});
Example: Set Snowflake connection string key for the project: ProjectById(1)
  .Modify(#{
    "SnowflakeConnectionStringKey": "MyKey1"
});
 | 
| ScriptByName (Script) | Script name (String) | Returns Script by its name located in the project. Returns null, if Script with that name does not exist in the project. Example: ProjectById(123).ScriptByName("MyScript1")
 | 
| SetSecret | 
 | Sets or adds a secret for the project. Setting the secret value to null removes the secret. There can be several secrets with the same name in the same project if the type of the secret is different. Setting secrets requires the project specific ManageProject permission. Parameters: 
 Example: Set SAP password: ProjectById(1).SetSecret("sap", "MySapPassword", "I l0ve 5AP!");
Example: Remove SAP password: ProjectById(1).SetSecret("sap", "MySapPassword", null);
 | 
Functions to get project:
| Functions | Parameters | Description | 
|---|---|---|
| ProjectById | Project id (Integer) | Returns project object corresponding to the provided project id. | 
| ProjectByName | Project name (String) | Returns project object by given project name. If there is no such project or user doesn't have access to it, null value is returned. If there are multiple projects with the same name, one of them is returned. Example: let project = ProjectByName("My Project");
 | 
Functions to create project:
| Functions | Parameters | Description | 
|---|---|---|
| CreateProject (Project) | Parameters dictionary | Create a project. This is a similar function as the CreateProject function in the project context. This function in the generic context is needed to create root-level projects (which don't have parent project). Example: create a root project: CreateProject(#{
  "Name": "My project"
})
Example: create a sub-project: CreateProject(#{
  "Name": "My project"
  "ParentProjectId": 1
})
 | 
| Import (Project*) | JSON string | Creates one or several projects from a json string. The project(s) are created as the root level projects. The json format is described in Projects Export File Format. The function returns the created project objects. In case the project names already exist, the import operation automatically adjusts the names to be unique. Example: Create a root level project from json data: let jsonData = `{ "Projects": [ { "Name": "My project" } ] }`;
Import(jsonData);
 | 
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 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 (returning 16): let runResult = ScriptById(123).Run(#{
  "numberToRaise": 4,
  "exponent": 2
})
 | 
| Start | Dictionary of parameters | Starts the script. The function call doesn't wait for the script run to complete (i.e., asynchronous behavior) which is sane as starting the script in the Workspace. Parameters to the script can be provided as a dictionary of name-value pairs (which is not possible when script is started in the Workspace). Return value is the script run id (integer) if the script was started. If the script is already running, return value is null. Example: Start script (without parameters) and store the script run id: let runId = ScriptById(1).Start(); Example: Start script with passing parameters: ScriptById(1).Start(#{
  "variable1": "val1",
  "variable2": 5
});
 | 
| Stop | Stops the script. The operation doesn't wait for the stopping to complete (i.e., asynchronous behavior) which is same as stopping the script in the Workspace. Depending on the operation that the script is performing, the stopping might take some time. Return value is the script run id (integer) if the script was running. If the script isn't running, the return value is null. Example: let runId = ScriptById(1).Stop(); | 
Function to get a script by the script id:
| Functions | Parameters | Description | 
|---|---|---|
| ScriptById | 
 | Returns Script object corresponding to the given script id. If script with the given id doesn't exist or user doesn't have permissions to it, an error is given. | 
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 | 
|---|---|
| CreatedBy (User) | Returns the user who created the user. | 
| CreatedDate (DateTime) | Returns the date when the user was created. | 
| DefaultDashboard (String) | Returns the configured starting dashboard ("default dashboard") identifier for a group (for users, the starting dashboard cannot be configured). The starting dashboard is automatically opened when a user logs in. | 
| Description (String) | Description of the user. | 
| EffectiveDefaultDashboard (String) | Returns the starting dashboard of a user. Value null means that the user doesn't have a starting dashboard. The starting dashboard comes from the user's groups. If multiple of user's groups have the starting dashboard defined, the user's starting dashboard will be taken from a group having alphabetically the first name. | 
| 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. Note that to get the 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. | 
| HasPassword (Boolean) | Returns true if user has a password defined in QPR ProcessAnalyzer and thus user can authenticate using the password. If user doesn't have a password, the SAML authentication is the only way to log in. ManageUsers permission is needed to access this property for other 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. | 
| IsLocked (Boolean) | Returns true if user account is currently locked. ManageUsers permission is needed to access this property. | 
| LastLockedDate (DateTime) | Returns date when user account was locked the last time. Returns null if the user account has never been locked. ManageUsers permission is needed to access this property. | 
| LastLoginDate (DateTime) | Returns date when the user made last successful login. ManageUsers permission is needed to access this property for other users. | 
| LastModifiedBy (User) | Returns the user who last modified this user. | 
| LastModifiedDate (DateTime) | Returns the date when the user was last modified. | 
| Name (String) | Login name of the user or group. | 
| Roles (Object**) | Returns all roles of the user (both global and project roles) as a nested array structure. Example: ToJson(Users.Where(name == "qpr").Roles)
Returns (for example):
[
  [{"calcId": "Project:1"}, "Administrator"],
  [{"calcId": "Project:2"}, "Analyzer"],
  [{"calcId": "Project:3"}, "Viewer"],
  [null, "RunScripts"],
  [null, "Administrator"]
]
 | 
| 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: UserById(1).EffectivePermissionsFor(ModelById(2).Project) Returns (for example): ["EditDashboards", "Filtering", "GenericRead"] | 
| GetAttribute | Returns user attribute value by given attribute name and optionally by the model/project/dashboard context. Supported data types are String, Integer, Float, and DateTime. To store more complex data types, data can be converted into json and stored as string. If the attribute doesn't exist, null is returned. For example, if using dashboard as context, the attributes are effectively bound to each user and each dashboard separately. Thus, there can be several attributes with the same name as long as the dashboard is different. Parameters: 
 Users have permissions to get attributes for themselves, and also (administrator) users with global ManageUsers permission can get attributes for all users. In addition, if using the context object, the GenericRead permission is required for the context object. Example: Get user attribute MyDataValue for myself: CurrentUser
  .GetAttribute("MyDataValue");
Example: Get user attribute MyDataValue for user John: Users
  .Where(Name=="John")
  .GetAttribute("MyDataValue");
Example: Get user attribute MyDataValue for user 1 related to dashboard id 1: UserById(1)
  .GetAttribute("MyDataValue", DashboardById(1));
 | |
| SetAttribute | Sets user attribute value for given attribute name and optionally for the model/project/dashboard context. Supported data types are String, Integer, Float, and DateTime. To store more complex data types, data can be converted into json and stored as string. If setting value null, the user attribute is removed. Required permissions are same as in the GetAttribute function. Parameters: 
 Example: Set user attribute MyDataValue for myself: CurrentUser
  .SetAttribute("MyDataValue ", "value");
Example: Set value 123 as user attribute MyDataValue for user John: Users
  .Where(Name=="John")
  .SetAttribute("MyDataValue", 123);
Example: Set current time as user attribute MyDataValue for user 1 related to dashboard id 1: UserById(1)
  .GetAttribute("MyDataValue", Now, DashboardById(1));
 | 
Function to get User by user id:
| Functions | Parameters | Description | 
|---|---|---|
| UserById (User) | 
 | Returns User object that has the provided user id. Also groups can be queried with this function. Returns an access denied error if the user with given id does not exist or the current user does not have access to it. |