Robotic process automation (RPA) systems enable automation of repetitive and manually intensive computer-based tasks. In an RPA system, computer software, namely a software robot (often referred to as a “bot”), may mimic the actions of a person in order to perform various computer-based tasks. For instance, an RPA system can interact with one or more software applications through user interfaces, as a person would do. Therefore, RPA systems typically do not need to be integrated with existing software applications at a programming level, thereby eliminating the difficulties inherent to integration. Advantageously, RPA systems permit automation of application level repetitive tasks via software robots that are coded to repeatedly and accurately perform the repetitive tasks.
Unfortunately, however, execution of software robots sometime fail because resources used by the software robots are unavailable when the software robots are executing. The needed resources can, for example, be application programs, databases, cloud storage, etc. During execution of a software robot, if a needed resource is not available to the software robot, then the execution of the software robot normally fails. Additionally, performance, reliability and cost savings associated with utilization of software robots are not well tracked or evaluated.
Therefore, there is a need for improved approaches to execute software robots, such that software robots can execute more reliably and RPA systems can better understand performance and benefits of software robots.
Improved management of software robots for RPA systems is disclosed. One aspect of certain embodiments can provide cross-platform execution management of software robots by utilizing an automation management server to receive and respond to automation requests to execute a software robot. An automation request can request permission to execute a particular software robot. The automation management server can interact with a status database to obtain status data that is used to determine whether the software robot should be given permission to execute, while taking into consideration administrative requirements and/or dependent resources utilized by the software robot. Another aspect of certain embodiments can support milestone recordation after a software robot completes its execution. The milestone being recorded can denote that the corresponding software robot has executed and its execution status. The milestone being recorded can include or be linked to additional corresponding data that allows for greater performance and/or value monitoring for the corresponding software robot. As an example, the additional corresponding data for the milestone can denote one or more of: tasks completed, skills utilized, estimated value or savings.
The invention can be implemented in numerous ways, including as a method, system, device, or apparatus (including computer readable medium and graphical user interface). Several embodiments of the invention are discussed below.
As a method for controlling execution of software robots, one embodiment can, for example, include at least: identifying a software robot to be executed; requesting, from a remote service, execution permission for execution of the software robot; receiving a response from the remote service; determining whether the software robot has permission to execute based on the response from the remote service; and permitting execution of at least a portion of the software robot if the determining determines that the software robot has permission to execute.
As a non-transitory computer readable medium including at least computer program code tangibly stored thereon for controlling execution of software robots, one embodiment can, for example, include at least: computer program code for identifying a software robot to be executed; computer program code for requesting, from a remote service, execution permission for execution of the software robot; computer program code for receiving a response from the remote service; computer program code for determining whether the software robot has permission to execute based on the response from the remote service; and computer program code for permitting execution of at least a portion of the software robot if the determining determines that the software robot has permission to execute.
As a method for controlling execution of software robots, one embodiment can, for example, include at least: receiving, at a remote service, a permission request seeking permission to execute a software robot, the permission request identifying the software robot by at least a software robot identifier; retrieving the software robot identifier from the permission request; accessing a central management database to retrieve at least status data pertaining to the software robot identified by at least the software robot identifier; determining whether the software robot has permission to execute based on at least a portion of the status data from the central management remote service; and sending, from the remote server, a permission response in response to the permission request, the permission response indicating at least whether the software robot has permission to execute.
As a computer-implemented method for managing execution of software robots, one embodiment can, for example, include at least: receiving, at a cross-platform automation management server, an automation start permission request pertaining to a software robot, the cross-platform automation management server being configured to access a status database; parsing the automation start permission request to retrieve at least a software robot identifier pertaining to the software robot; forming a query to the status database, the query including at least the software robot identifier; accessing the status database using the query to retrieve, from the status database, status data pertaining to the software robot; determining an automation start permission for the software robot based on at least a portion of the status data, the automation start permission indicating whether the software robot is permitted to execute; forming an automation start permission response, the automation start permission response including at least the automation start permission for the software robot; and returning the automation start permission response, the automation start permission response being responsive to the automation start permission request.
As an automation management system for software robots, one embodiment can, for example, include at least: a status database configured to store status data concerning a plurality of software robots; and a cross-platform automation management server operatively coupled to the status database. The cross-platform automation management server being configured to at least: receive an automation start permission request pertaining to a software robot; parse the automation start permission request to retrieve at least a software robot identifier pertaining to the software robot; form a query to the status database, the query including at least the software robot identifier; access the status database using the query to retrieve, from the status database, status data pertaining to the software robot; determine an automation start permission for the software robot based on at least a portion of the status data, the automation start permission indicating whether the software robot is permitted to execute; form an automation start permission response, the automation start permission response including at least the automation start permission for the software robot; and return the automation start permission response in response to the automation start permission request.
As a non-transitory computer readable medium including at least computer program code tangible stored thereon for managing execution of software robots, one embodiment can, for example, include at least: computer program code for receiving an automation start permission request pertaining to a software robot; computer program code for parsing the automation start permission request to retrieve at least a software robot identifier pertaining to the software robot; computer program code for forming a query to a status database, the query including at least the software robot identifier; computer program code for accessing the status database using the query to retrieve status data pertaining to the software robot; computer program code for determining an automation start permission for the software robot based on at least a portion of the status data, the automation start permission indicating whether the software robot is permitted to execute; computer program code for forming an automation start permission response, the automation start permission response denoting at least the automation start permission for the software robot; and computer program code for returning the automation start permission response in response to the automation start permission request.
As a computer readable medium including computer program code for a template that facilitates management of a software robot, one embodiment can, for example, include at least: a permission call code section including program code to initiate a request for permission to execute of the software robot; a software robot code section including program code of the software robot; and an execution control code section including program code to initiate execution of the program code of the software robot provided at least in part in the software robot code section, the program code to initiate execution of the program code of the software robot is configured to operate to initiate execution of the program code of the software robot provided that permission to execute is returned in response to the permission call code section.
As a method for providing a repository of milestone data for software robots that have executed, one embodiment can, for example, include at least: identifying a software robot that has concluded its execution, the software robot being identified by a software robot (SR) identifier; obtaining milestone data associated with the identified software robot that has concluded its execution; requesting, via a request to a milestone recordation service, recordation of a milestone, the milestone being associated with the execution that has concluded for the identified software robot; subsequently receiving a response from the milestone recordation service; parsing the response from the milestone service to obtain at least a milestone identifier, the milestone identifier identifying the milestone that has been recorded by the milestone recordation service and assigned the milestone identifier; and storing the milestone identifier for subsequent retrieval of the milestone using the milestone identifier.
As a computer-implemented method for managing recordation of milestones concerning execution of software robots, one embodiment can, for example, include at least: receiving, at a milestone management server, a milestone recordation request pertaining to a software robot that has at least partially executed; parsing the milestone recordation request to retrieve at least milestone data; generating a milestone identifier; forming a milestone data record including the milestone identifier and the milestone data; and storing the milestone data record to a milestone database.
As an automation management system for software robots, one embodiment can, for example, include at least: a milestone database configured to store milestones concerning a plurality of software robots; and a milestone management server operatively coupled to the milestone database. The milestone management server is configured to at least: receive a milestone recordation request pertaining to a software robot that has at least partially executed; parse the milestone recordation request to retrieve at least milestone data; generate a milestone identifier; form a milestone data record including the milestone identifier and the milestone data; and store the milestone data record to the milestone database.
As a non-transitory computer readable medium including at least computer program code tangible stored thereon for managing recordation of milestones concerning execution of software robots, one embodiment can, for example, include at least: computer program code for receiving, at a milestone management server, a milestone recordation request pertaining to a software robot that has at least partially executed; computer program code for parsing the milestone recordation request to retrieve at least milestone data; computer program code for generating a milestone identifier; computer program code for forming a milestone data record including the milestone identifier and the milestone data; and computer program code for storing the milestone data record to a milestone database.
Other aspects and advantages of the invention will become apparent from the following detailed description taken in conjunction with the accompanying drawings which illustrate, by way of example, the principles of the invention.
The invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, wherein like reference numerals designate like elements, and in which:
Various embodiments providing management of software robots for RPA systems are disclosed. One aspect of certain embodiments can provide cross-platform execution management of software robots by utilizing an automation management server to receive and respond to automation requests to execute a software robot. An automation request can be a request for permission to execute a particular software robot. The automation management server can interact with a status database to obtain status data that is used to determine whether the software robot should be given permission to execute, while taking into consideration administrative requirements and/or dependent resources utilized by the software robot. The execution management provided by the various embodiments can provide better control and utilization of software robots. Advantageously, software robots can be executed in instances when their resources required for execution are known to be available, thus improving efficiency and performance.
Another aspect of certain embodiments can support milestone recordation after a software robot completes its execution. The milestone being recorded can denote that the corresponding software robot has executed and its execution status. Additionally, the milestone being recorded can include or be linked to additional corresponding data that allows for greater performance and/or value monitoring for the corresponding software robot. The additional corresponding data for the milestone can denote one or more of: tasks completed, skills utilized, estimated value or savings. In one or more embodiments, the milestones can be recorded in a centralized manner (e.g., cloud storage) and available for cross-platform utilization. Moreover, if milestones are configured to denote skills, tasks, and/or value data, then performance or value (e.g., cost savings) of the software robot can be consistently quantified.
Generally speaking, RPA systems use computer software to emulate and integrate the actions of a person interacting within digital systems. In an enterprise environment, RPA systems are often designed to execute a business process. In some cases, RPA systems use artificial intelligence (AI) and/or other machine learning capabilities to handle high-volume, repeatable tasks that previously required humans to perform. RPA systems also provide for creation, configuration, management, execution, and/or monitoring of software automation programs.
A software automation program can be referred to as a software robot, software agent, or a bot. A software automation program can interpret and execute tasks on one's behalf. Software automation programs are particularly well suited for handling a lot of the repetitive tasks that people perform every day. Software automation programs can accurately perform a task or workflow they are tasked with over and over. As one example, a software automation program can locate and read data in a document, email, file, or window. As another example, a software automation program can connect with one or more Enterprise Resource Planning (ERP), Customer Relations Management (CRM), core banking, and other business systems to distribute data where it needs to be in whatever format is necessary. As another example, a software automation program can perform data tasks, such as reformatting, extracting, balancing, error checking, moving, copying, or any other desired tasks. As another example, a software automation program can retrieve, modify or add data desired from a webpage, application, screen, file, or other data source. As still another example, a software automation program can be triggered based on time or an event, and can serve to take files or data sets and move them to another location, whether it is to a customer, vendor, application, department or storage. These various capabilities can also be used in any combination. As an example of an integrated software automation program making use of various capabilities, the software automation program could start a task or workflow based on a trigger, such as a file being uploaded to an FTP system. The integrated software automation program could then download that file, scrape relevant data from it, upload the relevant data to a database, and then send an email to a recipient to inform the recipient that the data has been successfully processed.
Embodiments of various aspects of the invention are discussed below with reference to
The RPA computing environment 100 includes a first RPA system 102. The first RPA system 102 can be coupled to a storage 104 for storage of software automation programs. The RPA computing environment 100 can also include a second RPA system 106. The second RPA system 106 can be coupled to a storage 108 for storage of software automation programs. The RPA systems 102, 106 support and facilitate execution of a plurality of different software automation programs. These software automation programs can be referred to as “software robots,” “bots” or “software bots.” The RPA computing environment 100 can concurrently support numerous software robots, such as more than one hundred different software robots, or even more than one thousand different software robots.
The platform used by the first RPA system 102 can be the same as the platform used by the second RPA system 102, or the platform used by the first RPA system 102 can be different than the platform used by the second RPA system 102.
Additionally, the RPA computing environment 100 can support various different types of computing devices that can interact with the first RPA system 102 and/or the second RPA system 106. These computing devices can be referred to as client computing devices. The RPA computing environment 100 includes one or more client computing devices 110. Each of the client computing devices 110 can, for example, be an electronic device having computing capabilities, such as a mobile phone (e.g., smart phone), tablet computer, desktop computer, portable computer, server computer, and the like.
The RPA environment 100 can also include a network 112 made up of one or more wired or wireless networks that serve to electronically interconnect various computing devices, systems or servers for data transfer. As shown in
To facilitate centralized management of automation processes, the RPA environment 100 can include an automation management server 114. The automation management server 114 can manage execution of software automation programs (e.g., “software robots” or “bots”). By supporting different platforms, the automation management server 114 can support or service numerous software robots, such as more than one hundred different software robots. The automation management server 114 can be assisted by a status database 116. The status database 116 can store information about numerous software automation programs, such as which resources the corresponding software automation programs are reliant on during execution. For example, the automation management server 114 can prevent a particular software automation program from being executed if its needed resources are not then available. In doing so, the automation management server 114 can access the status database 116 to retrieve status data pertaining to those resources that the corresponding software automation program is reliant on during execution. The needed resources can vary with implementation and can vary with different software automation programs. As an example, the needed resources can include one or more of: (i) dependent services or applications (e.g., an accessible database, a network accessible server, an operational application program, Application Programming Interfaces (APIs), and (ii) the like); one or more approvals (e.g., administrative approvals, even multiple levels thereof); and/or (iii) completed registration, documentation and/or testing.
The automation management server 114 can also consider whether the software automation program to be executed has any administrative approvals that are required. The status database 116 can store information about administrative status of the numerous software automation programs. For example, the automation management server 114 can prevent a particular software automation program from being executed if needed administrative approvals have not been acquired. The needed administrative approvals can vary with implementation. As examples, the needed administrative approvals can include one or more of: automation leader approval, security review, code review, proof of documentation, or an on/off status (which could be manually set via a web interface).
In one embodiment, the status data can pertain to a consolidated status flag, such as a Yes/No flag that denotes a multi-conditional result from a plurality of conditions. The consolidated status flag can be stored in a status database. In one implementation, the multi-conditional result can consider one or more conditions, such as one or more of: (i) Software Robot (SR) Identifier approved (e.g., registered with automation management system); (ii) software robot administrative approval; and (iii) group identifier being valid (e.g., software robot registered with an existing group). In other implementations, the one or more conditions can additionally or alternatively include one or more of: (i) group owner approved; (ii) proof of documentation; and (iii) software robot registered in status database. The status data can pertain to the one or more conditions, the consolidated status flag, or both or some combination thereof. The status data can be stored in a status database. The status database can store and maintain up-to-date status data, such that the status remains current.
In one embodiment, the status data can also include data concerning dependent resources. For example, if the software robot, during execution, interacts with one or more application programs or other resources, then the availability of these dependent resources can be considered in determining whether the software robot is permitted to execute. If one or more dependent resources are not available, then the software robot should not be given permission to execute. In such case, the status data can include consideration of the availability of dependent resources.
In another embodiment, the data concerning dependent resources can be considered separate from the status data. For example, if the software robot, during execution, interacts with one or more application programs or other resources, then the availability of these dependent resources can be considered in determining whether the software robot is permitted to execute. If one or more dependent resources are not available, then the software robot should not be given permission to execute.
In one embodiment, the conditions to be considered in determining or setting status data can be configurable. For example, in registering a software robot, a user interface can enable a user to select or identify those conditions to be considered in determining status data for the software robot.
Further, to facilitate centralized reporting, the RPA environment 100 can include a milestone management server 118. The milestone management server 118 can manage the storage and retrieved of milestone data. Milestone data is data pertaining to execution of software automation programs. Milestone data can facilitate reporting of successes or savings associated with a particular software automation program. Milestone data can facilitate comparative evaluation of performance, successes or savings associated with multiple software automation programs. With the centralized reporting, the milestone management server 118 is able to operate across various RPA platforms. Hence, reporting or evaluating successes or savings can be across different RPA platforms, if desired. For example, successes can be task(s) completed by the particular software automation program. As an example, savings can be an amount of time (e.g., hours) of value (e.g., money) saved by automation of otherwise manually performed work.
Also, in one implementation, savings yielded by a software robot can be quantified. For example, savings yielded by execution of a given software robot can be quantified by an amount of time (e.g., hours) saved by automation of otherwise manually performed work, such as amount of time per task completed by the software robot. The amount of time saved can also be converted into a monetary value (e.g., money) saved by multiplying the amount of time saved multiplied by an hourly rate for the associated task or skill related thereto.
In one embodiment, saving yielded by a software automation program can be computed by a unit of work performed by a software automation program. For example, the unit of work can be considered a task. As noted above, one or more tasks can be associated with a software automation program. A task, as well as a value for the completion of the task, can also be known or denoted in the milestone data for a given milestone. For a given milestone, a number of times the task has been performed by the software automation program can be stored in the milestone data. In an implementation noted below, the number of times a task is performed during an execution of a software automation program can be referred to as a successful task count and can be stored in a milestone. The task can be associated with a skill undertaken by the task. The skill or task can have an associated value. The value for the completion of each task is the value for the skill or task. Often, a software automation program can perform more than one task in a given execution, in which case the value for the completion of the execution of the software automation is the sum of the values for each of the tasks being completed. Different tasks can use different skills and have different values. A software automation program may be designed to perform multiple tasks in order to complete a personal or business-related process. Each of the various tasks can be said to be of a specific skill type. For example, in order to complete a business process of on-boarding new employees, a software automation program may need to perform tasks of various skill types such as, but not limited to, letter generation, email composition, spreadsheet updating, and database updating. Said in another way, software automation programs can have one or more skills, skill types, or they can have various skill sets.
The techniques described within this application allow for the tracking and measurement of software automation program execution success or failure at various levels. A first level of measurement measures the success or failure of a software automation program in terms of its ability to complete its objective or goal. Another level of measurement measures how many of the individual tasks that the software automation program is designed to perform were successfully completed. Yet another level of measurement measures how many tasks of each skill type were successfully completed. The techniques described herein allow for performance measurements of software automation program executions at multiple levels, more granular levels, and according to various metrics that give automation designers and engineers additional insight regarding the effectiveness of software automation programs.
In some implementations, each skill type may be assigned an associated measure of value. An example measure of value is resources saved per time, where resources can be money (e.g., US dollars, Indian Rupees, etc.), energy, man hours, compute time, green house cases, etc. In some settings, a skill type can be assigned a value of US dollars saved per hour that a human worker need not devote to specific task given a software automation program will complete the task for the human worker. For example, if a software automation program is designed to generate letters, it may have multiple skills, each of which allow it to perform different types of letter generation tasks. Such a software automation program is capable of generating letters for different teams within a company, e.g.:
In the above example, the skills represent the different types of work that the software automation program can perform, and the hourly rate/time associated with the human equivalent work. So even though the bot in this case can perform multiple tasks, the type of tasks that it is performing creates respective amounts of value.
The performance of software automation programs can be measured and/or ranked based on skill types and the associated measures of value. As previously mentioned, this allows automation designers and engineers additional insight regarding the effectiveness of software automation programs. In one example, software automation programs may be ranked based on the amount of resources saved or their return on investment.
The RPA system 102, 106 can create, maintain, execute, and/or monitor recordings, including previously established recordings, to carry out software automation programs. The RPA system 102, 106 can support creation and storage of software automation programs. For example, the RPA system 102, 106 can support a recording session in which a series of user interactions with one or more application programs operating on a computing device can be recorded. The series of user interactions can then be utilized by the RPA system 102, 106 to form (i.e., create) a software automation program (e.g., bot) for carrying out such actions in an automated manner. The RPA utilization environment 100 can also store the software automation programs (e.g., bots) that have been created to storage 104, 108.
In addition, the RPA system 102, 106 supports the execution of the one or more software automation programs that have been created by the RPA system 102, 106 or some other RPA system. Execution (or running) of a software automation program at a computing device causes playback of the software automation program.
On execution of one or more of the software automation programs, the software automation programs can interact with one or more software programs. One example of a software program is an application program. Application programs can vary widely with a user's computer system and tasks to be performed thereby. For example, application programs being used might be word processing programs, spreadsheet programs, email programs, ERP programs, CRM programs, web browser programs, any many more. A software program, when operating, typically presents and supports interaction with one or more windows. For example, a user interface presented within the one or more windows can be programmatically interacted with through execution of the one or more software automation programs.
In some cases, the software automation program seeks to access documents that contain data that is to be extracted and then suitably processed. The documents are typically digital images of documents, which might be presented in one or more windows of a software program or accessed via a storage device providing document storage. The RPA system 102, 106 can include processing and structures to support the extraction of data from such document images. Some examples of documents include emails, web pages, forms, invoices, purchase orders, delivery receipts, bill of lading, insurance claims forms, loan application forms, tax forms, payroll reports, etc.
When robotic process automation operations are being performed, the RPA system 102, 106 seeks to interact with one or more software programs. However, since the RPA system 102, 106 is not integrated with the software program, the RPA system 102, 106 often requires an ability to understand what content is contained in a window produced by the software program. For example, the content being presented in a window can pertain to a graphical user interface or a document. In this regard, the RPA system 102, 106 can interact with the software program by interacting with the content in the window. By doing so, the software automation program being carried out can effectively interface with the software program via the window as would a user, even though no user is involved because the actions detailed in the software automation program are programmatically performed. Once the content of the window 108 is captured and understood, the RPA system 102, 106 can perform an action requested by the software automation program by inducing action(s) with respect to the software program.
The RPA execution management system 200 can include an automation platform 202. In one implementation, the automation platform 202 can be part of an RPA system. The automation platform 202 is a platform that is capable of facilitating execution of software robots. In this regard, the automation platform 202 can execute software robots and/or can provide software robots to client computing devices for execution thereon. The automation platform 202 can couple to a software robot (SR) repository 204. The SR repository 204 can store one or more software robots that are accessible by the automation platform 202. The SR repository 204 can be part of the RPA system or external to the RPA system but accessible thereby. The automation platform 202 can also couple to a SR engine 206, which is able to execute software robots. In one implementation, the SR engine 206 can be resident within the RPA system. In another implementation, the SR engine 206 can be resident within a client computing device.
The RPA execution management system 200 can also include an automation management server 208. The automation management server 208 can operatively connect to the automation platform 202 or to software robots managed by the automation platform 252. Typically, the automation management server 208 is a separate server from an RPA system, such that the automation management server 208 is able to provide services to various different automation platforms or to various software robots therefrom. For example, the automation management server 208 can couple to one or more networks to receive execution requests from software robots (see, e.g.,
The automation management server 208 can determine whether a software robot is presently able to execute. In doing so, the automation management server 208 can couple to a status database 210. The status database 210 can store status data relevant to execution of software robots. The status data is data that denotes a status of various resources that might be used by software robots that are being executed. The automation management server 208 can access the status data stored in the status database 210 and use a relevant portion of such status data in determining whether a software robot is presently permitted to execute.
In one implementation, the automation management server 208 can operate to monitor resources and/or approvals potentially utilized by computing device(s) in their execution of corresponding software robots. By monitoring such resources, the automation management server 208 can store, to the status database 210, status data concerning resources and/or approvals potentially utilized by computing device(s) in their execution of corresponding software robots. Here, in such an implementation, the automation management server 208 can directly access, monitor or maintain current status data for various resources. The current status data can also be recorded in the status database 210 for subsequent retrieval.
The RPA execution management system 200 can also include a registration manager 212. The registration manager 212 can couple to the automation management server 208. The registration manager 212 can allow software robots to be registered for use with the automation management server 208. A registration process for a software robot can be a computer-implemented process to receive descriptive data and/or dependency data pertaining to the software robot. In one implementation, the registration process can assign a SR identifier for the software robot being registered.
The RPA management system 250 can include an automation platform 252. In one implementation, the automation platform 252 can be part of an RPA system. The automation platform 252 is a platform that is capable of (i) facilitating execution of software robots and (ii) recordation of milestones. In this regard, the automation platform 252 can execute software robots and/or can provide software robots to client computing devices for execution thereon. The automation platform 252 can couple to a SR repository 204. The SR repository 204 can store one or more software robots that are accessible by the automation platform 252. The SR repository 204 can be part of the RPA system or external to the RPA system but accessible thereby. The automation platform 252 can also couple to a SR engine 206, which is able to execute software robots. In one implementation, the SR engine 206 can be resident within the RPA system. In another implementation, the SR engine 206 can be resident within a client computing device.
The RPA management system 250 can include an automation management server 208. The automation management server 208 can operatively connect to the automation platform 252 or to software robots managed by the automation platform 252. Typically, the automation management server 208 is a separate server from an RPA system, such that the automation management server 208 is able to provide services to various different automation platforms or to various software robots therefrom. For example, the automation management server 208 can couple to one or more networks to receive execution requests from software robots (see, e.g.,
The automation management server 208 can determine whether a software robot is presently able to execute. In doing so, the automation management server 208 can couple to a status database 210. The status database 210 can store status data relevant to execution of software robots. The status data is data that denotes a status of various resources that might be used by software robots that are being executed. The automation management server 208 can access the status data stored in the status database 210 and use a relevant portion of such status data in determining whether a software robot is presently permitted to execute.
In one implementation, the automation management server 208 can operate to monitor resources potentially utilized by computing device(s) in their execution of corresponding software robots. By monitoring such resources, the automation management server 208 can store, to the status database 210, status data concerning resources potentially utilized by computing device(s) in their execution of corresponding software robots. Here, in such an implementation, the automation management server 208 can maintain and access current status data from the status database 210.
The RPA management system 250 can also include a registration manager 212, such as shown in
Still further, the RPA management system 250 can include a milestone management server 254 and a milestone database 256. The milestone management server 254 can operatively connect to the automation platform 252 or to software robots managed by the automation platform 252. Typically, the milestone management server 254 is a separate server from an RPA system, such that the milestone management server 254 is able to provide services to various different automation platforms or to various software robots therefrom. For example, the milestone management server 254 can couple to one or more networks to receive calls from software robots. Although shown separately in
More generally, the data fields descriptive of the corresponding software robot can be considered to contain descriptive data. For example, descriptive data concerning the corresponding software robot can be found in one or more of the fields: bot name, bot description, bot GUID, group, documentation path, automation platform, owner name, owner email, last updated date/time, last updated by, registration ID, archived, and/or version. The dependent application(s) field can be considered to contain dependency data. The various status fields (e.g., bot status, admin status, and/or factory status) can contain status data. The skill field and its sub-fields can be considered to contain skill data, which can also be considered a particular type of descriptive data.
The exemplary milestone data pertains to a milestone and includes the exemplary data for the various fields. In this particular embodiment, the exemplary milestone data pertains to a milestone from a bot GUID of “MSTNFGIS4204MFNDS”, a bot result of “Success”, a bot start time of “2/13/2022 17:00:00”, a bot end time of “2/13/2022 17:21:00”, a bot successful task count of “5”, bot failed task count of “0”, milestone GUID of “TRANS0349582FKSC245D”, bot skill of “Letter Generation”, bot user account of “LetterBt1”, bot workstation of “AA-AWS15C3”, and an optional payload that includes details of three letters that were generated by the corresponding software robot.
The software robot template 300 can optionally include milestone recordation logic 310 and milestone logic 312. By providing the software robot template 300 with such regions, the software robot template 300 can facilitate storage of milestones to a milestone database, such as the milestone database 256 illustrated in
The execution management process 400 can begin with a decision 402 that determines whether a software robot desires to run. When the decision 402 determines that a software robot does not presently desire to run (i.e., execute), then the execution management process 400 can await until a software robot desires to run. On the other hand, when the decision 402 determines that a software robot does desire to run, then a SR identifier for the software robot can be identified 404. The SR identifier can be a GUID, which is a unique digital identifier for the corresponding software robot.
An automation start permission (ASP) can then be requested 406 for the software robot. The automation start permission is a request for permission to execute a particular software robot, which is identified by a SR identifier. The automation start permission can be requested 406 from an automation management server, such as the automation management server 208 illustrated in
Next, a decision 408 can determine whether a response has been received to the automation start permission that has been requested 406. When the decision 408 determines that a response to the request for the automation start permission as not been received, the execution management process 400 can await such a response. Once the decision 408 determines that a response to the request for automation start permission has been received, the response for the automation start permission can be parsed 410. For example, by parsing 410 the response for the automation start permission, data can be retrieved from the response, including response data. For example, the response data being retrieved from the response can include at least an automation start permission (ASP) for the software robot that desires to run and that is identified by the SR identifier.
A decision 412 can then determine whether the automation start permission is equivalent to “true”. When the automation start permission is equivalent to “true”, the automation management server has determined that the software robot is permitted to operate, that is, the software robot is approved to execute. More particularly, when the decision 412 determines that the automation start permission is “true”, then execution of the software robot can be permitted 414. Alternatively, when the automation start permission is not equivalent to “true”, then execution of the software robot can be declined 416.
The milestone management process 500 can begin with a decision 502 that determines whether a software robot has ended its execution. In other words, the decision 502 determines whether a previously executing software robot has ended its execution. When the decision 502 determines that the software robot has not yet ended its execution, the milestone management process 500 awaits its completion. In other words, the milestone management process 500 can be activated after a software robot has completed its execution, regardless of whether its execution ended normally or under an error condition.
When the decision 502 determines that the software robot has ended, then the milestone management process 500 can be performed. In this regard, a SR identifier, execution status, and milestone data can be identified 504 for the software robot that has completed its execution. Next, milestone recordation can be requested 506. Here, a milestone can be formed from at least the SR identifier, the execution status and the milestone data. The milestone, which is a milestone data entry, can then be packaged as a request for the milestone recordation. The request 506 for the milestone recordation can be sent to a milestone management server, such as the milestone management server 254 illustrated in
Next, a decision 508 can determine whether a response to the request 506 for the milestone recordation has been received. The response to the request 506 can be received from the milestone management server. When the decision 508 determines that a response to the request for the milestone recordation has not yet been received, the milestone management process 500 can await such a response. Alternatively, when the decision 508 determines that the response to the request for the milestone recordation has been received, the response can be parsed 510 for a milestone identifier. The milestone identifier is a unique identifier for a stored milestone. For example, the milestone identifier can be a milestone GUID. Thereafter, the milestone identifier can be stored 512. The milestone identifier allows the milestone to be subsequently located and retrieved from a milestone database 256. Here, the milestone identifier can be stored 512 at an automation platform, such as the automation platform 252 illustrated in
The execution status process 600 can begin with a decision 602 that determines whether an automation start permission (ASP) request has been received. The automation start permission request can, for example, be requested by block 406 of the execution management process 400 illustrated in
Alternatively, when the decision 602 determines that an automation start permission request has been received, the execution status process 600 can continue (or be initiated). In this regard, the automation start permission request can be parsed 604 for a SR identifier. The SR identifier serves to uniquely identify the software robot associated with the automation start permission request. Next, a query to a status database can be formed 606, with the query including the SR identifier. The status database can then be accessed 608 using the query to retrieve status data and dependency data pertaining to the software robot associated with the SR identifier.
Next, the automation start permission for the software robot can be determined 610 based on at least a portion of the status data and/or dependency data. Thereafter, an automation start permission response can be formed 612, with the automation start permission response including at least the automation start permission that has been determined for the software robot. Subsequently, the automation start permission response can be returned 614. For example, the automation start permission response can be returned 614 to the issuer of the automation start permission request such as the automation platform 202 illustrated in
The execution status process 600 illustrated in
The milestone recordation process 700 can begin with a decision 702 that determines whether a milestone recordation request has been received. The milestone recordation request can, for example, be requested by block 506 of the milestone management process 500 illustrated in
After the milestone recordation request has been received, the milestone recordation request can be parsed 704 to retrieve milestone data from the milestone recordation request. Then, the milestone recordation process 700 can generate 706 a milestone identifier for the particular milestone to be recorded. The milestone identifier can be a GUID, which is a unique digital identifier for the corresponding milestone. Next, a milestone data record can be formed 708, with the milestone data record including at least the milestone identifier and the milestone data. Thereafter, the milestone data record can be stored 710 to a milestone database. For example, milestone database can pertain to the milestone database 256 illustrated in
The various aspects disclosed herein can be utilized with or by robotic process automation systems. Exemplary robotic process automation systems and operations thereof are detailed below.
The RPA system 800 can also include a control room 808. The control room 808 is operatively coupled to the data storage 802 and is configured to execute instructions that, when executed, cause the RPA system 800 to respond to a request from a client device 810 that is issued by a user 812.1. The control room 808 can act as a server to provide to the client device 810 the capability to perform an automation task to process a work item from the plurality of work items 806. The RPA system 800 is able to support multiple client devices 810 concurrently, each of which will have one or more corresponding user session(s) 818, which provides a context. The context can, for example, include security, permissions, audit trails, etc. to define the permissions and roles for bots operating under the user session 818. For example, a bot executing under a user session, cannot access any files or use any applications that the user, under whose credentials the bot is operating, does not have permission to do so. This prevents any inadvertent or malicious acts from a bot under which bot 804 executes.
The control room 808 can provide, to the client device 810, software code to implement a node manager 814. The node manager 814 executes on the client device 810 and provides a user 812 a visual interface via browser 813 to view progress of and to control execution of automation tasks. It should be noted that the node manager 814 can be provided to the client device 810 on demand, when required by the client device 810, to execute a desired automation task. In one embodiment, the node manager 814 may remain on the client device 810 after completion of the requested automation task to avoid the need to download it again. In another embodiment, the node manager 814 may be deleted from the client device 810 after completion of the requested automation task. The node manager 814 can also maintain a connection to the control room 808 to inform the control room 808 that device 810 is available for service by the control room 808, irrespective of whether a live user session 818 exists. When executing a bot 804, the node manager 814 can impersonate the user 812 by employing credentials associated with the user 812.
The control room 808 initiates, on the client device 810, a user session 818 (seen as a specific instantiation 818.1) to perform the automation task. The control room 808 retrieves the set of task processing instructions 804 that correspond to the work item 806. The task processing instructions 804 that correspond to the work item 806 can execute under control of the user session 818.1, on the client device 810. The node manager 814 can provide update data indicative of status of processing of the work item to the control room 808. The control room 808 can terminate the user session 818.1 upon completion of processing of the work item 806. The user session 818.1 is shown in further detail at 819, where an instance 824.1 of user session manager 824 is seen along with a bot player 826, proxy service 828, and one or more virtual machine(s) 830, such as a virtual machine that runs Java® or Python®. The user session manager 824 provides a generic user session context within which a bot 804 executes.
The bots 804 execute on a player, via a computing device, to perform the functions encoded by the bot. Some or all of the bots 804 may in certain embodiments be located remotely from the control room 808. Moreover, the devices 810 and 811, which may be conventional computing devices, such as for example, personal computers, server computers, laptops, tablets and other portable computing devices, may also be located remotely from the control room 808. The devices 810 and 811 may also take the form of virtual computing devices. The bots 804 and the work items 806 are shown in separate containers for purposes of illustration but they may be stored in separate or the same device(s), or across multiple devices. The control room 808 can perform user management functions, source control of the bots 804, along with providing a dashboard that provides analytics and results of the bots 804, performs license management of software required by the bots 804 and manages overall execution and management of scripts, clients, roles, credentials, security, etc. The major functions performed by the control room 808 can include: (i) a dashboard that provides a summary of registered/active users, tasks status, repository details, number of clients connected, number of scripts passed or failed recently, tasks that are scheduled to be executed and those that are in progress; (ii) user/role management—permits creation of different roles, such as bot creator, bot runner, admin, and custom roles, and activation, deactivation and modification of roles; (iii) repository management—to manage all scripts, tasks, workflows and reports etc.; (iv) operations management—permits checking status of tasks in progress and history of all tasks, and permits the administrator to stop/start execution of bots currently executing; (v) audit trail—logs creation of all actions performed in the control room; (vi) task scheduler—permits scheduling tasks which need to be executed on different clients at any particular time; (vii) credential management—permits password management; and (viii) security: management—permits rights management for all user roles. The control room 808 is shown generally for simplicity of explanation. Multiple instances of the control room 808 may be employed where large numbers of bots are deployed to provide for scalability of the RPA system 800.
In the event that a device, such as device 811 (e.g., operated by user 812.2) does not satisfy the minimum processing capability to run a node manager 814, the control room 808 can make use of another device, such as device 815, that has the requisite capability. In such case, a node manager 814 within a Virtual Machine (VM), seen as VM 816, can be resident on the device 815. The node manager 814 operating on the device 815 can communicate with browser 813 on device 811. This approach permits RPA system 800 to operate with devices that may have lower processing capability, such as older laptops, desktops, and portable/mobile devices such as tablets and mobile phones. In certain embodiments the browser 813 may take the form of a mobile application stored on the device 811. The control room 808 can establish a user session 818.2 for the user 812.2 while interacting with the control room 808 and the corresponding user session 818.2 operates as described above for user session 818.1 with user session manager 824 operating on device 810 as discussed above.
In certain embodiments, the user session manager 824 provides five functions. First is a health service 838 that maintains and provides a detailed logging of bot execution including monitoring memory and CPU usage by the bot and other parameters such as number of file handles employed. The bots 804 can employ the health service 838 as a resource to pass logging information to the control room 808. Execution of the bot is separately monitored by the user session manager 824 to track memory, CPU, and other system information. The second function provided by the user session manager 824 is a message queue 840 for exchange of data between bots executed within the same user session 818. The third function is a deployment service (also referred to as a deployment module) 842 that connects to the control room 808 to request execution of a requested bot 804. The deployment service 842 can also ensure that the environment is ready for bot execution, such as by making available dependent libraries. The fourth function is a bot launcher 844 which can read metadata associated with a requested bot 804 and launch an appropriate container and begin execution of the requested bot. The fifth function is a debugger service 846 that can be used to debug bot code.
The bot player 826 can execute, or play back, a sequence of instructions encoded in a bot. The sequence of instructions can, for example, be captured by way of a recorder when a human performs those actions, or alternatively the instructions are explicitly coded into the bot. These instructions enable the bot player 826, to perform the same actions as a human would do in their absence. In one implementation, the instructions can compose of a command (action) followed by set of parameters, for example: Open Browser is a command, and a URL would be the parameter for it to launch a web resource. Proxy service 828 can enable integration of external software or applications with the bot to provide specialized services. For example, an externally hosted artificial intelligence system could enable the bot to understand the meaning of a “sentence.”
The user 812.1 can interact with node manager 814 via a conventional browser 813 which employs the node manager 814 to communicate with the control room 808. When the user 812.1 logs in from the client device 810 to the control room 808 for the first time, the user 812.1 can be prompted to download and install the node manager 814 on the device 810, if one is not already present. The node manager 814 can establish a web socket connection to the user session manager 824, deployed by the control room 808 that lets the user 812.1 subsequently create, edit, and deploy the bots 804.
In the embodiment shown in
Turning to the bots Bot 1 and Bot 2, each bot may contain instructions encoded in one or more programming languages. In the example shown in
The control room 808 operates to compile, via compiler 1008, the sets of commands generated by the editor 1002 or the recorder 1004 into platform independent executables, each of which is also referred to herein as a bot JAR (Java ARchive) that perform application level operations captured by the bot editor 1002 and the bot recorder 1004. In the embodiment illustrated in
As noted in connection with
An entry class generator 1108 can create a Java class with an entry method, to permit bot execution to be started from that point. For example, the entry class generator 1108 takes, as an input, a parent bot name, such “Invoice-processing.bot” and generates a Java class having a contract method with a predefined signature. A bot class generator 1110 can generate a bot class and orders command code in sequence of execution. The bot class generator 1110 can take, as input, an in-memory bot structure and generates, as output, a Java class in a predefined structure. A Command/Iterator/Conditional Code Generator 1112 wires up a command class with singleton object creation, manages nested command linking, iterator (loop) generation, and conditional (If/Else If/Else) construct generation. The Command/Iterator/Conditional Code Generator 1112 can take, as input, an in-memory bot structure in JSON format and generates Java code within the bot class. A variable code generator 1114 generates code for user defined variables in the bot, maps bot level data types to Java language compatible types, and assigns initial values provided by user. The variable code generator 1114 takes, as input, an in-memory bot structure and generates Java code within the bot class. A schema validator 1116 can validate user inputs based on command schema and includes syntax and semantic checks on user provided values. The schema validator 1116 can take, as input, an in-memory bot structure and generates validation errors that it detects. The attribute code generator 1118 can generate attribute code, handles the nested nature of attributes, and transforms bot value types to Java language compatible types. The attribute code generator 1118 takes, as input, an in-memory bot structure and generates Java code within the bot class. A utility classes generator 1120 can generate utility classes which are used by an entry class or bot class methods. The utility classes generator 1120 can generate, as output, Java classes. A data type generator 1122 can generate value types useful at runtime. The data type generator 1122 can generate, as output, Java classes. An expression generator 1124 can evaluate user inputs and generates compatible Java code, identifies complex variable mixed user inputs, inject variable values, and transform mathematical expressions. The expression generator 1124 can take, as input, user defined values and generates, as output, Java compatible expressions.
The JAR generator 1128 can compile Java source files, produces byte code and packs everything in a single JAR, including other child bots and file dependencies. The JAR generator 1128 can take, as input, generated Java files, resource files used during the bot creation, bot compiler dependencies, and command packages, and then can generate a JAR artifact as an output. The JAR cache manager 1130 can put a bot JAR in cache repository so that recompilation can be avoided if the bot has not been modified since the last cache entry. The JAR cache manager 1130 can take, as input, a bot JAR.
In one or more embodiment described herein command action logic can be implemented by commands 1001 available at the control room 808. This permits the execution environment on a device 810 and/or 815, such as exists in a user session 818, to be agnostic to changes in the command action logic implemented by a bot 804. In other words, the manner in which a command implemented by a bot 804 operates need not be visible to the execution environment in which a bot 804 operates. The execution environment is able to be independent of the command action logic of any commands implemented by bots 804. The result is that changes in any commands 1001 supported by the RPA system 800, or addition of new commands 1001 to the RPA system 800, do not require an update of the execution environment on devices 810, 815. This avoids what can be a time and resource intensive process in which addition of a new command 1001 or change to any command 1001 requires an update to the execution environment to each device 810, 815 employed in an RPA system. Take, for example, a bot that employs a command 1001 that logs into an on-online service. The command 1001 upon execution takes a Uniform Resource Locator (URL), opens (or selects) a browser, retrieves credentials corresponding to a user on behalf of whom the bot is logging in as, and enters the user credentials (e.g., username and password) as specified. If the command 1001 is changed, for example, to perform two-factor authentication, then it will require an additional resource (the second factor for authentication) and will perform additional actions beyond those performed by the original command (for example, logging into an email account to retrieve the second factor and entering the second factor). The command action logic will have changed as the bot is required to perform the additional changes. Any bot(s) that employ the changed command will need to be recompiled to generate a new bot JAR for each changed bot and the new bot JAR will need to be provided to a bot runner upon request by the bot runner. The execution environment on the device that is requesting the updated bot will not need to be updated as the command action logic of the changed command is reflected in the new bot JAR containing the byte code to be executed by the execution environment.
The embodiments herein can be implemented in the general context of computer-executable instructions, such as those included in program modules, being executed in a computing system on a target, real or virtual, processor. Generally, program modules include routines, programs, libraries, objects, classes, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The program modules may be obtained from another computer system, such as via the Internet, by downloading the program modules from the other computer system for execution on one or more different computer systems. The functionality of the program modules may be combined or split between program modules as desired in various embodiments. Computer-executable instructions for program modules may be executed within a local or distributed computing system. The computer-executable instructions, which may include data, instructions, and configuration parameters, may be provided via an article of manufacture including a computer readable medium, which provides content that represents instructions that can be executed. A computer readable medium may also include a storage or database from which content can be downloaded. A computer readable medium may further include a device or product having content stored thereon at a time of sale or delivery. Thus, delivering a device with stored content, or offering content for download over a communication medium, may be understood as providing an article of manufacture with such content described herein.
The exemplary computing environment 1200 may have additional features such as, for example, tangible storage 1210, one or more input devices 1214, one or more output devices 1212, and one or more communication connections 1216. An interconnection mechanism (not shown) such as a bus, controller, or network can interconnect the various components of the exemplary computing environment 1200. Typically, operating system software (not shown) provides an operating system for other software executing in the exemplary computing environment 1200, and coordinates activities of the various components of the exemplary computing environment 1200.
The tangible storage 1210 may be removable or non-removable, and includes magnetic disks, magnetic tapes or cassettes, CD-ROMs, DVDs, or any other medium which can be used to store information in a non-transitory way, and which can be accessed within the computing system 1200. The tangible storage 1210 can store instructions for the software implementing one or more features of a PRA system as described herein.
The input device(s) or image capture device(s) 1214 may include, for example, one or more of a touch input device (such as a keyboard, mouse, pen, or trackball), a voice input device, a scanning device, an imaging sensor, touch surface, or any other device capable of providing input to the exemplary computing environment 1200. For multimedia embodiment, the input device(s) 1214 can, for example, include a camera, a video card, a TV tuner card, or similar device that accepts video input in analog or digital form, a microphone, an audio card, or a CD-ROM or CD-RW that reads audio/video samples into the exemplary computing environment 1200. The output device(s) 1212 can, for example, include a display, a printer, a speaker, a CD-writer, or any another device that provides output from the exemplary computing environment 1200.
The one or more communication connections 1216 can enable communication over a communication medium to another computing entity. The communication medium conveys information such as computer-executable instructions, audio or video input or output, or other data. The communication medium can include a wireless medium, a wired medium, or a combination thereof.
The various aspects, features, embodiments or implementations of the invention described above can be used alone or in various combinations.
Embodiments of the invention can, for example, be implemented by software, hardware, or a combination of hardware and software. Embodiments of the invention can also be embodied as computer readable code on a computer readable medium. In one embodiment, the computer readable medium is non-transitory. The computer readable medium is any data storage device that can store data which can thereafter be read by a computer system. Examples of the computer readable medium generally include read-only memory and random-access memory. More specific examples of computer readable medium are tangible and include Flash memory, EEPROM memory, memory card, CD-ROM, DVD, hard drive, magnetic tape, and optical data storage device. The computer readable medium can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will become obvious to those skilled in the art that the invention may be practiced without these specific details. The description and representation herein are the common meanings used by those experienced or skilled in the art to most effectively convey the substance of their work to others skilled in the art. In other instances, well-known methods, procedures, components, and circuitry have not been described in detail to avoid unnecessarily obscuring aspects of the present invention.
In the foregoing description, reference to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment can be included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Further, the order of blocks in process flowcharts or diagrams representing one or more embodiments of the invention do not inherently indicate any particular order nor imply any limitations in the invention.
The many features and advantages of the present invention are apparent from the written description. Further, since numerous modifications and changes will readily occur to those skilled in the art, the invention should not be limited to the exact construction and operation as illustrated and described. Hence, all suitable modifications and equivalents may be resorted to as falling within the scope of the invention.
This application claims priority to U.S. Provisional Patent Application No. 63/442,103, filed Jan. 30, 2023, and entitled “CROSS-PLATFORM EXECUTION MANAGEMENT FOR ROBOTIC PROCESS AUTOMATION SYSTEMS,” which is hereby incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
63442103 | Jan 2023 | US |