Embodiments generally relate to data processing, and more particularly to data processing systems and method that facilitate secure and compliant execution of processes.
Computer applications such as enterprise systems execute processes for delivery of services or products. Successful execution of the processes ensures continuity in serving an organizational goal for a particular customer. Best practice in enterprises is to ensure that the processes comply with legal and/or organizational requirements, to prevent disruptive incidents such as fraudulent execution of processes, or issues related to conflict of interest. Failing to comply with the legal and organizational requirements may lead to loss of continuity in serving the organizational goal. For example, consider a complex process such as ‘insurance claim process’ that may include tasks, e.g. ‘claim intimation’, ‘pre-processing’, ‘pre-adjudication’, ‘validation’, ‘post settlement’, and ‘reporting’ that may have multiple workflows to complete the process from start to end. If one of the workflow fails to comply with the legal and/or organizational requirements, continuity in serving the organizational goal may be lost. Solving the continuity issue during runtime may be time consuming, and eventually leads to either cancelation of the processes, or violation of the legal and organizational requirements. In order to maintain the continuity in serving the organizational goal, individual workflows have to be explored at runtime. As a result, a significant amount of time and effort is lost. Therefore, it is a challenge to ensure secure and compliant execution of processes for delivery of services or products, and maintain continuity in serving the organizational goal.
The claims set forth the embodiments with particularity. The embodiments are illustrated by way of examples and not by way of limitation in the figures of the accompanying drawings in which like references indicate similar elements. The embodiments, together with its advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings.
Embodiments of techniques for secure and compliant execution of processes are described herein. In the following description, numerous specific details are set forth to provide a thorough understanding of the embodiments. One skilled in the relevant art will recognize, however, that the embodiments can be practiced without one or more of the specific details, or with other methods, components, materials, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail.
Reference throughout this specification to “one embodiment”. “this embodiment” and similar phrases, means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one of the one or more embodiments. Thus, the appearances of these phrases in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined in any suitable manner in one or more embodiments.
The authorization constraints include task specific constraints that may include separation of duty (SoD) constraints, binding of duty (BoD) constraints, role constraints, temporal constraints, etc. In the context of process, SoD constraints may enforce conflict of interest constraints. For example, a SoD constraint may be represented as {((t1, t2), ≠)}, this means that if the ‘process participant A’ has executed task(t1) then ‘process participant A’ may not be allowed to execute task (t2). Based on the authorization policy (P), ‘process participant B’ may be allowed to execute task (t2). The BoD constraints include subject-binding constraints and role-binding constraints. The subject-binding constraints define that if a ‘process participant’ execute a first task then the ‘process participant’ may also be allowed to execute tasks associated with the first task. For example, a BoD constraint may be {((t1, t3), =)}, this means that if ‘process participant A’ has executed task (t1) then ‘process participant A’ may be also allowed to execute task (t3). Role-binding constraints define that process participants with identical user roles may be allowed to execute the tasks associated with the first task. For example, the BoD constraint {((t1, t3), =)}, if ‘process participant A’ is allowed to execute task (t1) and ‘process participant B’ is allowed to execute task (t2), then ‘process participant A’ and ‘process participant B’ may have identical user roles.
The ‘WFM system’ 102 may be integrated with ‘application’ 104 to ensure secure and compliant execution of the processes. The ‘WFM system’ 102 and ‘application’ 104 may be using in-memory database to process data. The ‘application’ 104 may be an enterprise application that ensures successful execution of workflows associated with the processes while enforcing authorization policies, and authorization constraints. For example, ‘application’ 104 may be SAP® Cerberus. The ‘WFM system’ 102 and the ‘application’ 104 may include functionalities that are designed during design time and executed during runtime.
At design time, a user referred as ‘process designer’ 106 may access ‘workflow modeling’ 108 to design, and generate a workflow model for a process. The workflow model for the process is generated using a process model language or a process model and notation language. For example, the ‘process designer’ 106 may design workflow model for a process ‘travel itinerary’ that may include tasks such as ‘trip request (t1)’. ‘car rental (t2)’, ‘hotel booking (t3)’, ‘≠light reservation (t4)’ and ‘trip validation (t5)’. The ‘process designer’ 106 may also input authorization policies such as (P)={(t1, A), (t1, B), (t1, C), (t2, A), (t2, B), (t2, C), (t3, A), (t3, B), (t4, B), (t4, C), (t5, A)}, and authorization constraints such as AC={((t1, t2), ≠), ((t2, t5), ≠), ((t2, t3), ≠), ((t3, t5), ≠), ((t1, t4), ≠)} associated with the workflow model generated. The ‘process designer’ 106 may also provide the authorization policies (P) during runtime. The ‘workflow modeling’ 108 may be connected with ‘workflow model repository’ 110. The ‘workflow modeling’ 108 is a graphical user interface for the ‘process designer’ 106 to design workflows. The workflow model ‘S’ generated by the process designer 106 may be stored in the ‘workflow model repository’ 110.
‘Monitor synthesizer’ 112 of the ‘application’ 104, may receive the workflow model generated by the ‘workflow modeling’ 108. The workflow model may be received in the form of graphical representation. For example, the graphical representation of the workflow model may be a XML code. The ‘monitor synthesizer’ 112 may translate the workflow model into a transition system format that may be acceptable by ‘model checker’ 116. The workflow model may be translated into the transition system format using mathematical modeling languages, e.g. Petri net or place/transition net, etc. The ‘model checker’ 116 may be connected with the ‘monitor synthesizer’ 112 to receive the workflow model. The ‘model checker’ 116 may apply backward reachability procedures to generate a reachability graph for the workflow model received in the form of transition system format. The backward reachability procedures may be algorithms including a set of instructions to generate a reachability graph that has the ability to trace a workflow execution path from an initial state to a final state and vice versa. The reachability graph may include possible workflow execution paths in the process.
The reachability graph includes nodes representing states and edges representing execution of a task by a ‘process participant’ 118. The ‘monitor synthesizer’ 112 may translate the reachability graph in a database query format, e.g. structured query language (SQL) or Datalog to be stored in the ‘monitor repository’ 114. The reachability graph is translated to generate a ‘monitor’ 122 that may be referred as an enforcement mechanism. The ‘monitor’ 122 is capable of ensuring successful execution of tasks associated with the process by enforcing the authorization constraints and authorization policies based on the reachability graph. The ‘monitor’ 122 may be able to support multiple authorization policies during runtime.
At runtime, the ‘workflow engine’ 120 may receive the workflow model and the ‘monitor 122’ as input from the ‘workflow model repository’ 110 and ‘monitor repository’ 114. The ‘workflow engine’ 120 may receive requests from the ‘process participant’ 118 to execute the task associated with the process in the ‘graphical user interface’ (GUI) 124 connected with the ‘workflow engine’ 120. The GUI 124 may query the ‘monitor’ 122 based on the requests received from the ‘process participant’ 118. The GUI 124 may be a web interface, e.g. web task management dashboard, accessible by the authorized ‘process participant’ 118. For example, the ‘process participant’ 118 may request for the task ‘car rental (t2)’ after execution of the task ‘trip request (t1)’. The ‘workflow engine’ 120 may invoke the ‘monitor’ 122 based on the request received from the ‘process participant’ 118. The GUI 124 may query the ‘monitor’ 122 based on the authorization constraints and the authorization policies to enforce successful execution of the requested task, i.e. ‘car rental (t2)’, by the ‘process participant’ 118. Based on the ‘process participant’ 118 request, ‘monitor’ 122 may be queried and provide either “request grant” or “request deny” as an output to be displayed in the GUI 124. ‘Process participant’ 118 may receive “request grant” in the GUI 124 to execute the task ‘car rental (t2)’ based on the authorization policies and authorization constraints. In another example, ‘process participant B’ may request to execute the task ‘trip validation (t5)’ after successful execution of the task ‘car rental (t2)’, in the GUI 124. The ‘monitor’ 122 may be queried to enforce the authorization policies and authorization constraints, and provide “request deny” to ‘process participant B’ in the GUI 124.
Based on the workflow model, the ‘workflow engine’ 120 may also direct execution of tasks, e.g. computer system tasks, scripting or coding tasks, etc., to the invoked applications 126, using procedure calls, e.g. structured query language (SQL) procedure call. The ‘workflow engine’ 120 may invoke the ‘monitor’ 122, when the ‘process participant’ 118 is required to execute the tasks associated with the workflow model. Therefore, secure and compliant execution of the workflow model ensures continuity in serving the organizational goal.
At design time, in one embodiment, the number of process participants required to execute the tasks in the ‘workflow model’ 204 may depend on the number of tasks included in the ‘workflow model’ 204. For example, if there are ‘n’ number of tasks in the ‘workflow model’ 204, then ‘k’ number of process participants are required to execute ‘n’ number of the tasks, and satisfy a condition (k≦n). Accordingly the ‘workflow model’ 204 may require three process participants, e.g. ‘process participant A’, ‘process participant B’ and ‘process participant C’ to execute the four tasks 210 to 216 in the ‘loan origination process’. In another embodiment, the minimum number of process participants required to execute the tasks in the ‘workflow model’ 204 may also depend on the number of ‘authorization constraints’ associated with the ‘workflow model’ 204. For example, since there are two SoD constraints 218 and 220, the minimum number of process participants required to execute the ‘workflow model’ 204 may be two. Accordingly the ‘process participant A’ may execute the tasks ‘evaluate external credit rating (t2)’ 212 and ‘approve loan (t4)’ 216 while ‘process participant B’ may execute the tasks ‘request loan (t1)’ 210 and ‘evaluate internal credit rating (t3)’ 214.
During runtime, the ‘process designer’ 202 or an administrator may also input ‘authorization policies’ to indicate assignment of process participants to execute specific tasks. The number of process participants provided in the ‘authorization policies’ at runtime may be different from the number of process participants determined to execute the tasks in the ‘workflow model’ 204 at design time. The ‘authorization policies’ may include assignment of the ‘process participant A’, ‘process participant B’, and ‘process participant C’ to execute the tasks (t1 to t4) in the ‘workflow model’ 204. For example, the ‘process designer’ 202 or an administrator may input ‘authorization policies’, as shown below in table 1. The ‘authorization policies’ shown in table 1 may be for the ‘loan origination process’.
According to the ‘authorization policies’ (p1) to (p4): (p1) the ‘process participant A’, ‘process participant B’, and ‘process participant C’ are authorized to execute the ‘request loan (t1)’ 210; (p2) the ‘process participant A’, ‘process participant B’, and ‘process participant C’ may be authorized to execute the ‘evaluate external credit rating (t2)’ 212; (p3) the ‘process participant A’ and ‘process participant B’ are authorized to execute the ‘evaluate internal credit rating (t3)’ 214; and (p4) the ‘process participant A’ is authorized to execute the ‘approve loan (t4)’ 216.
Based on the ‘authorization policies’, the ‘process participant A’ may be allowed to execute the task ‘request loan (t1)’ 210, and the ‘process participant B’ may request execution of the task ‘evaluate external credit rating (t2)’ 212. The ‘process participant B’ may be allowed to execute the requested task ‘evaluate external credit rating (t2)’ 212, since, the ‘process participant B’ has not executed tasks earlier, associated with SoD constraints. Next, the ‘process participant A’ may be allowed to execute ‘evaluate internal credit rating (t3)’ 214 and satisfy the SoD constraint 218. However, no process participants may be available to execute the ‘approve loan (t4)’ 216 and also satisfy the SoD constraint 220, and the ‘authorization policies’. As a result, when the task ‘approve loan (t4)’ 216 is not executed, this may either lead to loss of continuity or violation of ‘authorization policies’ in completing execution of the ‘loan origination process’. Loss of continuity of the process implies an unsuccessful execution of the ‘workflow model’ 204.
The ‘process designer’ 202 may change or insert, or delete ‘authorization policies’ during runtime. The ‘workflow model’ 204 and the existing ‘authorization constraints’ may be used with different ‘authorization policies’ during runtime. For example, two banks may implement the ‘loan origination process’ that include identical ‘authorization constraints’ and tasks (t1) to (t4) but different ‘authorization policies’ for different process participants.
Successful execution of the ‘workflow model’ 204, e.g. the ‘loan origination process’, ensures workflow satisfiability. The workflow satisfiability is defined as execution of the tasks associated with the ‘workflow model’ 204 by the process participants, based on the ‘authorization policies’, satisfying the ‘authorization constraints’. For example, the successful execution of the ‘loan origination process’ may involve successful execution of all the tasks (t1 to t4) without violating the ‘authorization constraints’ 204 such as SoD 218 and 220, and also satisfying all the ‘authorization policies’ as shown in table 1.
Based on the ‘authorization policies’, the ‘workflow model’ 204 may include following valid workflow execution paths as examples. In workflow execution path-I, ‘process participant C’ may execute the ‘request loan (t1)’ 210, ‘process participant A’ may execute the ‘evaluate external credit rating (t2)’ 212, ‘process participant B’ may execute the ‘evaluate internal credit rating (t3)’ 214, and ‘process participant A’ may execute the ‘approve loan (t4)’ 216. In workflow execution path-II, ‘process participant A’ may execute the ‘request loan (t1)’ 210, ‘process participant B’ may execute the ‘evaluate internal credit rating (t3)’ 214, ‘process participant C’ may execute the ‘evaluate external credit rating (t2)’ 212, and ‘process participant A’ may execute the ‘approve loan (t4)’ 216.
In the above examples, ‘workflow execution path-I’ and ‘workflow execution path-II’ ensure workflow satisfiability, since, all the tasks (t1) to (t4) are successfully executed based on the ‘authorization policies’, and also satisfying the SoD constraints 218 and 220. Therefore, secure and compliant execution of the ‘workflow model’ 204 of the process, ensures continuity in serving the organization goal.
The ‘transition system format’ 302 may be a graphical representation of the ‘workflow model’ in which tasks (t1) to (t4) may be referred as transitions or events and ‘positions’ 304 to 314 may be referred as enabling conditions for execution of the tasks (t1) to (t4), as shown in the
As an exemplary embodiment, execution of the tasks (t1) to (t4) may be shown in the form of Boolean expressions, as shown in table-II below. Successful execution of the task (t) may be represented as ‘dt’. The enabling condition (p0) at ‘position’ 304 that satisfies the condition on task (t1) may be expressed as (p0dt1), this means that the token is at ‘position’ 304 and execution of task (t1) is yet to occur. When task (t1) is executed, it may be referred as true (T) else false (F). Functions ‘at’ and ‘ht’ may be introduced for the execution of tasks (t1) to (t4). The function ‘at’ defines a function that behaves as an abstract interface to ‘authorization policies’ provided by the ‘process designer’. The ‘process designer’ may input the ‘authorization policies’ either during design time or during runtime. The function at(u) is true, if a ‘process participant (u)’ is allowed to execute the task (t). The function ‘ht’ defines execution history of the tasks (t1) to (t4) by ‘process participant (u)’. The function ht(u) is true, if the ‘process participant (u)’ has executed the task (t). According to table 2, enabling condition (p0) is associated with the ‘position’ 304; enabling condition (p1) is associated with the ‘position’ 306; enabling condition (p2) is associated with the ‘position’ 308; enabling condition (p3) is associated with the ‘position’ 310; enabling condition (p4) is associated with the ‘position’ 312; and enabling condition (p5) is associated with the ‘position’ 314.
dt4
In the above table 2, first column represents name of the transitions i.e. tasks (t1 to t4) that depends on the ‘process participant’ (u). Second column shows the ‘enabled execution’ of the tasks (t1) to (t4). This column is divided into two, such as ‘execution constraints’ and ‘authorization constraints’. Third column represents ‘workflow execution’ of the transitions. Fourth column represents authorization of the ‘process participant (u)’ based on the ‘authorization constraints’ and ‘authorization policies’. Based on the ‘transition system format’ 302, a reachability graph for the ‘workflow model’ may be generated.
The ‘reachability graph’ 450 may include nodes 451 to 468. The nodes 451 to 468 may represent a set of states in the ‘workflow model’. For example, the node 458 represents a state in which ‘process participant A’ has not executed the task (t1) and node 456 represents the state in which the ‘process participant A’ has executed the task (t1) and the like. The ‘reachability graph’ 450 also includes edges representing execution of tasks by process participants, referenced by ‘tx_y’. The ‘tx’ may represent task number, e.g. ‘request loan (t1)’, ‘evaluate external credit rating (t2)’, ‘evaluate internal credit rating (t3)’, and ‘approve loan (t4)’. The ‘y’ in the edge representation ‘tx_y’ may represent ‘process participant y’. For example, edge ‘t1_B’ represents that the task (t1), e.g. ‘request loan (t1)’, may be executed by ‘process participant B’. The node 451 is the root node with no outgoing edges. The root node may represent the states with complete workflow execution of the ‘workflow model’. For example, node 451 may represent successful execution of all the tasks (t1 to t4) in the ‘loan origination process’. The nodes 458 to 464 may represent initial states with no incoming edges, e.g. node 408 may represent states when none of the tasks (tt to t4) are executed in the ‘loan origination process’.
The ‘reachability graph’ 450 includes possible workflow execution paths that may include nodes and edges to represent successful execution of the tasks (t1 to t4) in the ‘workflow model’. The workflow execution path may start from one of the initial states e.g. leaf node 458 or node 460 and ends at the root node, e.g. node. For example, one of the workflow execution path may include nodes {458, 456, 453, 452, 451} and edges {t1_A, t3_B, t2_A, t4_A}. For example, if the ‘workflow model’ includes sequential execution of ‘n’ number of tasks then the possible workflow execution path may include ‘n+1’ number of nodes and ‘n’ number of edges. The number of nodes in the workflow execution path is ‘n+1’ because the execution of the ‘workflow model’ starts from the state when none of the tasks are executed and ends at the state when all the tasks are successfully executed. In the ‘loan origination process’ as there are four tasks (t1 to t4) in the ‘loan origination process’, the possible workflow execution paths may include five nodes and four edges.
In an exemplary embodiment, the ‘reachability graph’ 450 is for a ‘workflow model’ that includes sequential and parallel execution of tasks. Height or depth of the ‘reachability graph’ 450 i.e. the distance between the initial nodes to the root node is equivalent to the ‘n’ number of tasks in the ‘workflow model’. All the possible workflow execution paths of the ‘workflow model’ complies with the ‘authorization constraints’ provided by the ‘process designer’. For example, the ‘loan origination process’ may include ‘authorization constraints’ between the tasks (t2) and (t3), and between the tasks (t3) and (t4). Therefore, the workflow execution path may not include edges that shows subsequent execution of the tasks (t2) and (t3) or tasks (t3) and (t4) by the same ‘process participant’. The workflow execution path may include edges that show subsequent execution of the tasks (t1) and (t3) or tasks (t2) and (t4) by the same ‘process participant’, since, there are no SoD constraints that exists between the tasks (t1) and (t3) or tasks (t2) and (t4).
The maximum number of process participants required to execute the tasks (tx) may be directly proportional to the ‘n’ number of tasks in the ‘workflow model’. For example, the ‘reachability graph’ 450 include four ‘process participant A’ to ‘process participant D’ to execute the tasks (t1 to t4). Also, the number of process participants required to execute the tasks in the workflow execution path may depend on the number of ‘authorization constraints’ in the ‘workflow model’.
In an exemplary embodiment, the ‘reachability graph’ 450 may be incrementally generated according to the backward reachability procedures. First, a node 451 is generated and labeled by the ‘state formula F’ representing a set of final states that allocate tokens to ‘positions’ of transition system format of the ‘workflow model’. Once the node 451 may be assigned or added to a set of TBV nodes, the backward reachability procedures may initiate iteration for generating set of nodes ‘N’, i.e. the set of nodes ‘N’ corresponds to the nodes 451 to 468, shown in
After completion of the first iteration, one node is chosen from the set of TBV nodes, e.g. nodes 452 and 467, to initiate the next iteration. The backward reachability procedure stops generating nodes when a terminating point is reached i.e., when the set of TBV nodes is empty. When the terminating point is reached, attempts are made to apply the formula WLP(tr, λ[i]) on the transitions (tr) associated with nodes 458 to 464 with no incoming edges, and returns false.
The number of process participants introduced during the generation of the ‘reachability graph’ 450 may not be equivalent to the number of users in the ‘authorization policies’ provided by the ‘process designer’ during runtime. During runtime, the workflow execution path that satisfies the ‘authorization constraints’ and the ‘authorization policies’ may be selected for successful execution of the ‘workflow model’. For example, one of the workflow execution path may include nodes {464, 466, 455, 452, 451} and edges {t1_D, t2_C, t3_B, t4_A}. The ‘process participant A’ to ‘process participant D’ are required to execute the tasks (t1 to t4). In another example, the workflow execution path may include nodes (459, 456, 468, 452, 451) and edges {t1_B, t3_B, t2_A, t4_A}, ‘process participant A’ and ‘process participant B’ are required to execute the tasks (t1 to t4). Based on the ‘reachability graph’ 450, a ‘monitor’ may be generated in database query format, e.g. SQL. The ‘reachability graph’ 450 may be translated into database query format, the translated ‘reachability graph’ 450 may be referred as ‘monitor’. The ‘monitor’ may enforce the ‘authorization constraints’ and ‘authorization policies’ during runtime based on the reachability graph generated.
The generated ‘monitor’ 512 is referred as enforcement mechanism that ensures secure and complaint execution of the ‘workflow model’ 506 during runtime. Successful execution of the ‘workflow model’ 506 is achieved by complying with ‘authorization constraints’ 508 and ‘authorization policies’ 514. The ‘process designer’ 502 or an administrator may provide ‘authorization policies’ 514, e.g. {(t1, A), (t1, B), (t1, C), (t2, A), (t2, B), (t2, C), (t3, A), (t3, B), (t4, B), (t4. C), (t5, A)}, corresponding to the ‘workflow model’ 506, either during design time or during runtime. The ‘authorization policies’ 514 may be changed during runtime. Therefore, the ‘authorization policies’ 514 may also act as runtime parameters provided to the ‘monitor’ 512 for executing the ‘workflow model’ 506. The ‘monitor’ 512 may use the ‘authorization policies’ 514 to ensure successful completion of each of the tasks (t1) to (t4) in the ‘workflow model’ 506 without violating the ‘authorization constraints’ 508. The reachability graph provides the knowledge of the possible workflow execution paths for successful execution of the ‘workflow model’ 506, i.e. executing each of the tasks (t1) to (t4) included in the ‘workflow model’ 506. Various illustrations explained above with respect to design time and runtime are merely exemplary. It should be appreciated that the processes may be executed completely in design time or completely in runtime or a combination of both.
The ‘WFM system’ 606 may include GUI (graphical user interface) connected with the ‘workflow engine’ 608. The GUI facilitates an authorized process participant to view instances of the tasks associated with the ‘workflow model’ that needs to be executed. The process participant may request for executing task (t) of an instance (i) associated with the ‘workflow model’ in the GUI. For example, in the ‘loan origination process’, ‘process participant A’ may request for executing the task ‘evaluate external credit rating (t2)’ of ‘instance 1’. Instances may represent tasks associated with ‘workflow model’ that needs to be executed by the process participants. These instances may be generated by an administrator or a ‘process designer’. The ‘workflow engine’ 608 may receive ‘instances’ and authorization policies from an ‘input block’ 610. The ‘workflow engine’ 608 may invoke the ‘monitor’ 602 and enables the GUI to query the ‘monitor’ 602 to execute the requested task (t) for the instance (i) by the process participant. The GUI may query the ‘monitor’ 602 by sending ‘execution request’ 612. The ‘execution request’ 612 received at the ‘monitor’ 602 may include information to check if the ‘process participant A’ is allowed to execute the ‘request loan (t1)’. Based on the ‘reachability graph’. ‘authorization constraints’ and the ‘authorization policies’ associated with the instance (i), the ‘monitor’ 602 may provide ‘response’ 614 either as “request grant” or “request deny” to the ‘workflow engine’ 608. For example, corresponding to ‘execution request’ 612 for ‘instance 1’, the ‘monitor’ 602 may send ‘response’ 614 “request grant” to allow ‘process participant A’ to execute the task ‘evaluate external credit rating (t2)’. In another example, in ‘instance 2’, after successful execution of the ‘evaluate external credit rating (t2)’, the ‘process participant A’ may request for executing the task ‘evaluate internal credit rating (t3)’. The ‘monitor’ 602 may send ‘response’ 614 “request deny” to prevent ‘process participant A’ from executing task ‘evaluate internal credit rating (t3)’. Therefore, the ‘monitor’ 602 ensures secure and compliant execution of the processes associated with in-memory database during runtime, without violating the ‘authorization constraints’, and also satisfying the ‘authorization policies’.
According to an exemplary embodiment, the ‘monitor’ 602 may be the translated version of the ‘reachability graph’ in SQL format stored in the ‘monitor repository’. The ‘monitor’ 602 may be invoked by the ‘workflow engine’ 608 to provide ‘response’ 614 either as “request grant” or “request deny”. For example, consider ‘process participant’ represented by symbol ‘u’ may request execution of a task represented by symbol ‘T’. This may be represented by a mathematical function: execute (u, T). The ‘workflow engine’ 608 may invoke the ‘monitor’ 602 to query the ‘reachability graph’ by enforcing the ‘authorization constraints’ and the ‘authorization policies’. The ‘monitor’ 602 may provide “request grant” or “request deny” to the ‘process participant (u)’. Below is an excerpt of the ‘monitor’ 602 for the ‘loan origination process’ in SQL query format, as an example, to enforce the authorization policies and authorization constraints:
SELECT U2.ID FROM PROCESS USERS AS U1, USERS AS U2 WHERE HST.dt1=1 AND HST.dt2=0, HST.dt3=1 AND HST.dt4=0 AND (U1.ID < > U2.ID) AND NOT HST.t3by=U1.ID AND NOT HST.t3by=U2.ID AND U1.ID IN (SELECT ID2 FROM PROCESS_PARTICIPANT_B) AND U2.ID IN (SELECT ID4 FROM PROCESS_PARTICIPANT_D)
In the abovementioned SQL query, to execute task (t2), the ‘monitor’ 602 may have allowed execution of the task (t1) and task (t3) but not task (t2) and task (4). This is mentioned as “HST.dt1=1 AND HST.dt2=0, HST.dt3=1 AND HST.dt4=0” in the query. The syntax “HST.dt1” represents execution history of the task (t1). The ‘process participant U1’ and ‘process participant U2’ may be authorized to execute the tasks (t2) and task (t4), and also satisfies the ‘authorization constraints’ and ‘authorization policies’. The ‘authorization constraints’ such as SoD constraints may be mentioned as “NOT HST.t3by=U1.ID AND NOT HST.t3by=U2.ID”, in the SQL query. These SoD constraints may exist between the tasks (t2) and (t3) and between the tasks (t3) and (t4). The ‘process participant U1’ may execute the task (t2) as the ‘ID2’ is selected from table ‘PROCESS_PARTICIPANT_B’ table and ‘process participant U2’ may execute the task (t4) as the ‘ID4’ is selected from table ‘PROCESS_PARTICIPANT_D’.
An administrator or the ‘process designer’ may specify ‘authorization policies’ in a user interface by linking each of the tasks (t1 to t4) to corresponding process participants. The tasks (t1 to t4) may be represented by respective task identifiers such as, e.g. ‘taskid1’, ‘taskid2’, ‘taskid3’ and ‘taskid4’. For example, ‘process designer’ may link ‘process participant A’, ‘process participant B’, ‘process participant C’ and ‘process participant D’ with the respective tasks identifiers ‘taskid1’ to ‘taskid4’, in the ‘workflow model’ 700. The ‘taskid1’ represents ‘request loan (t1)’ 704, ‘taskid2’ represents ‘evaluate external credit rating (t2)’ 706 and ‘taskid3’ represents ‘evaluate internal credit rating (t3)’ 708 and ‘taskid4’ represents ‘approve loan (t4)’ 716, in the ‘workflow model’ 700. The ‘authorization policies’ may be deployed during runtime. A ‘reachability graph’ may be generated for the ‘workflow model’ 700 based on backward reachability procedures. The ‘reachability graph’ may include possible workflow execution paths for the ‘workflow model’ 700.
Some embodiments may include the above-described methods being written as one or more software components. These components, and the functionality associated with each, may be used by client, server, distributed, or peer computer systems. These components may be written in a computer language corresponding to one or more programming languages such as, functional, declarative, procedural, object-oriented, lower level languages and the like. They may be linked to other components via various application programming interfaces and then compiled into one complete application for a server or a client. Alternatively, the components maybe implemented in server and client applications. Further, these components may be linked together via various distributed programming protocols. Some example embodiments may include remote procedure calls being used to implement one or more of these components across a distributed programming environment. For example, a logic level may reside on a first computer system that is remotely located from a second computer system containing an interface level (e.g., a graphical user interface). These first and second computer systems can be configured in a server-client, peer-to-peer, or some other configuration. The clients can vary in complexity from mobile and handheld devices, to thin clients and on to thick clients or even other servers.
The above-illustrated software components are tangibly stored on a computer readable storage medium as instructions. The term “computer readable storage medium” should be taken to include a single medium or multiple media that stores one or more sets of instructions. The term “computer readable storage medium” should be taken to include any physical article that is capable of undergoing a set of physical changes to physically store, encode, or otherwise carry a set of instructions for execution by a computer system which causes the computer system to perform any of the methods or process steps described, represented, or illustrated herein. A computer readable storage medium may be a non-transitory computer readable storage medium. Examples of a non-transitory computer readable storage media include, but are not limited to: magnetic media, such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs, DVDs and holographic devices; magneto-optical media; and hardware devices that are specially configured to store and execute, such as application-specific integrated circuits (“ASICs”), programmable logic devices (“PLDs”) and ROM and RAM devices. Examples of computer readable instructions include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter. For example, an embodiment may be implemented using Java. C++, or other object-oriented programming language and development tools. Another embodiment may be implemented in hard-wired circuitry in place of, or in combination with machine readable software instructions.
A data source is an information resource. Data sources include sources of data that enable data storage and retrieval. Data sources may include databases, such as, relational, transactional, hierarchical, multi-dimensional (e.g., OLAP), object oriented databases, and the like. Further data sources include tabular data (e.g., spreadsheets, delimited text files), data tagged with a markup language (e.g., XML data), transactional data, unstructured data (e.g., text files, screen scrapings), hierarchical data (e.g., data in a file system, XML data), files, a plurality of reports, and any other data source accessible through an established protocol, such as, Open DataBase Connectivity (ODBC), produced by an underlying software system (e.g., ERP system), and the like. Data sources may also include a data source where the data is not tangibly stored or otherwise ephemeral such as data streams, broadcast data, and the like. These data sources can include associated data foundations, semantic layers, management systems, security systems and so on.
In the above description, numerous specific details are set forth to provide a thorough understanding of embodiments. Although the processes illustrated and described herein include series of steps, it will be appreciated that the different embodiments are not limited by the illustrated ordering of steps, as some steps may occur in different orders, some concurrently with other steps apart from that shown and described herein. In addition, not all illustrated steps may be required to implement a methodology in accordance with the one or more embodiments. Moreover, it will be appreciated that the processes may be implemented in association with the apparatus and systems illustrated and described herein as well as in association with other systems not illustrated.
The above descriptions and illustrations of embodiments, including what is described in the Abstract, is not intended to be exhaustive or to limit the one or more embodiments to the precise forms disclosed. While specific embodiments of, and examples for, the one or more embodiments are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the one or more embodiments, as those skilled in the relevant art will recognize. These modifications can be made in light of the above detailed description. Rather, the scope is to be determined by the following claims, which are to be interpreted in accordance with established doctrines of claim construction.