A business process is a combination of operational steps or activities that a business undertakes. A business may conduct a high number of business processes throughout the course of a day or year, in order to accomplish the business's goals. An operational step or activity may be any action from the mundane to the complex.
Through the use of technology, businesses can now model their business processes in a graphical nature. What used to be a loosely defined set of procedures can now be formalized into complex business process workflows. The formalized business processes allow managers to understand the bottlenecks of a process, and to redesign the business processes for efficiency.
Business can now also incorporate business process design into their existing technology systems. Instead of providing a simple map of a business process, integration with computer systems allows business process designers to design interactive business processes that drive business workflow. Business process designers can receive data from various sources and perform a wide range of actions on the data directly, and create business processes in an easy to understand visual manner.
Businesses create workflows as a part of business process design to assist in managing their internal operations. Business processes allow users to represent the current state of their business operations in a graphical manner. Users can also simulate new business operations through the use of business processes.
Business process design is typically performed on a terminal connected to a process server. The process server is able to execute the business process and connect with external data sources. When the business process designer wishes to continue to design an in environment that is not connected to a process server, the business process designer often does not have access to the necessary tools and functions.
Additionally, business process designers very quickly find that they are configuring components of a process the same way over and over again in multiple processes. Although wizard-driven design patterns and productivity enhancements make designing processes faster than ever, they still do not eliminate the need to design the same configuration more than once. The business process designer has no capability to “save” a component of work in the process design for reuse in future designs.
The present disclosure provides methods and apparatuses for designing business processes without being connected to a process server. Using the methods and apparatus herein, users can fully model a business process, business entity, or business policy without being connected to a process server, or in an offline mode.
Using the methods and apparatus herein, users can also save components of work in the process design for reuse in future designs.
Additional features and advantages are described herein, and will be apparent from, the following Detailed Description and the figures.
The present system is most readily realized in a network communications system. A high level block diagram of an exemplary network communications system 100 is illustrated in
The business process server 104 stores a plurality of files, programs, and/or web pages in one or more business process databases 106 for use by the business process designer terminals 102. The business process database 106 may be connected directly to the business process server 104 or via one or more network connections. The business process database 106 preferably stores business process data.
One business process server 104 may interact with a large number of business process designer terminals 102. Accordingly, each business process server 104 is typically a high end computer with a large storage capacity, one or more fast microprocessors, and one or more high speed network connections. Conversely, relative to a typical business process server 104, each business process designer terminal 102 typically includes less storage capacity, a single microprocessor, and a single network connection.
A more detailed block diagram of a business process designer terminal 102 is illustrated in
In particular, the memory 208 preferably stores an artifact library module 224. The artifact library module 224 allows for the creation, management and use of items on the business process designer terminal 102, when the business process designer terminal 102 is disconnected from the business process server 104.
The artifact library module 224 may include a program to allow the business process designer to access artifact information from either the business process server 104 or from the storage device 218. For example the artifact library module 224 may include an artifact library plugin, shown in
The interface circuit 212 may be implemented using any suitable interface standard, such as an Ethernet interface and/or a Universal Serial Bus (USB) interface. One or more input devices 214 may be connected to the interface circuit 212 for entering data and commands into the main unit 202. For example, the input device 214 may be a keyboard, mouse, touch screen, track pad, track ball, isopoint, and/or a voice recognition system.
One or more displays, printers, speakers, and/or other output devices 216 may also be connected to the main unit 202 via the interface circuit 212. The display 216 may be a cathode ray tube (CRTs), liquid crystal displays (LCDs), or any other type of display. The display 216 generates visual displays of data generated during operation of the business process designer terminal 102. For example, the display 216 may be used to display web pages received from the business process server 104. The visual displays may include prompts for human input, run time statistics, calculated values, data, etc.
One or more storage devices 218 may also be connected to the main unit 202 via the interface circuit 212. For example, a hard drive, CD drive, DVD drive, and/or other storage devices may be connected to the main unit 202. The storage devices 218 may store any type of data used by the business process designer terminal 102.
The business process designer terminal 102 may also exchange data with other network devices 220 via a connection to the network 112. The network connection may be any type of network connection, such as an Ethernet connection, digital subscriber line (DSL), telephone line, coaxial cable, etc. Users of a business process designer terminal 102 may be required to register with the business process server 104. In such an instance, each user of a business process designer terminal 102, may choose a user identifier (e.g., e-mail address) and a password which may be required for the activation of services. The user identifier and password may be passed across the network 108 using encryption built into the business process designer terminal 102 browser. Alternatively, the user identifier and/or password may be assigned by the business process server 104.
A more detailed block diagram of a business process server 104 is illustrated in
In particular, the memory 308 preferably stores an artifact storage module 312 and an artifact sharing module 314. The artifact storage module 312 may interface with the business process database 106 to store information regarding business process artifacts For an example screenshot of the artifact library storage in the database 106 see
The business process designer may wish to save a component for further use. For example, the designer might find that for every process they design they configure a Mail Event to send an email every time they configure an activity to handle the outcome for a user selecting “Declined” as an action. The designer may wish to configure the Mail Event in such a way that it could be saved for reuse later. artifact storage module 312 allows the user to save activities. The business process designer can fully, or partially, configure an Event, an Activity, with 0 to many events, or multiple Activities on a process and then save them to the Artifact Library for future use. The business process database 106 may store all artifact data. The artifact storage module 312 may index the artifact data to improve performance. For example, the artifact storage module 312 may create an indexed listing of the artifact data so that external programs can quickly access the correct artifact.
When creating a new artifact, the artifact storage module 312 may first determine a user's security permissions. For example, if a user is not permitted to create artifacts in a given category, the artifact storage module 312 may not permit the user to create the new artifact. Creating a new artifact will be discussed further in relation to
The business process designer may also wish to set a security level for a newly created object. The business process storage module 312 allows the business process designer to set a security level. For example, the business process designer may wish to restrict access to an artifact based on group permissions. The business process storage module 312 may restrict access to the artifact based on the business process designer's settings. In another example, the business process designer could set the artifact to “Private” where only the business process designer could access the artifact. Permission levels may cascade down the directory structure, to preserve security integrity. New artifacts may inherit permissions from its parent. Different levels of security may include: read only—so that a mapped user may not add or remove artifacts from a category or its children; modify—so that the mapped user may add, edit or remove artifacts or categories from a category or its children; etc.
The artifact sharing module 314 may process the artifact library objects to allow easy use to software processes that interface with the artifact sharing module 314. For example, the artifact sharing module 314 may receive data associated with an artifact library object from the business process database 106, and expose the data as PersistableObjectCollections. The artifact sharing module 314 may also provide extra functionality to the artifact library. For example, the artifact sharing module 314 may allow searching of the artifact library objects. The artifact sharing module 314 may also associate an image with an artifact. For example, a workflow process stored in the artifact library may be represented with geometric shapes indicative of the type of workflow process. In another example, the artifact sharing module 314 may create a thumbnail, representative of a workflow process to represent an artifact library process.
A diagram of an example artifact library system 400 is presented in
The artifact library system 400 may have a business process server 104 and a business process designer terminal 102. It should be understood that the business process server 102 may be a plurality of connected servers and that components may be located on separate servers. The business process server 104 may have an artifact library runtime server component 402 and an artifact library client API assembly 404.
The artifact library runtime server component 402 and the artifact library client API assembly 404 may be controlled by the artifact sharing module 314 located in the memory 308 of the business process server 104. The artifact library runtime server 402 may be responsible for making the artifact library stored procedures accessible to the business process designer terminal 102. The artifact library runtime server 402 decides what data the business process designer terminal 102 is allowed to receive.
The artifact library client API assembly 404, may process the artifact library objects to allow easy use to software processes that interface with the artifact sharing module 314. For example, the artifact sharing module 314 may receive data associated with an artifact library object from the business process database 106, and expose the data as PresistableObjectCollections.
The business process designer terminal 102 may include a client artifact library 406 and an artifact library plugin 408. The client artifact library 406 may store localized copies of artifact objects when the business process designer terminal 102 is not connected to the business process server 104. The artifact library plugin 408 may interface with the artifact library client API assembly 404 when the business process designer terminal 102 is connected to the business process server 104, and connect to the client artifact library 406 when the business process designer terminal 102 is not connected to the business process server 104.
The artifact library system 400 may also have a business process database 106. The business process database 106 may store the artifact library database.
A screenshot of an example artifact items table 500 is presented in
The artifact items table 500 may represent the artifacts stored in the business process database 106. The artifact items table 500 may indicate a plurality of databases that store artifact items. For example, the artifact items table 500 may show a file viewer 502 that shows the plurality of databases that store artifact items. The artifact items table 500 may also contain a detailed description of the artifact items stored in a given database. For example, a detailed view 504 may provide information such as the artifact identification number, the artifact data values, etc.
A screenshot of an example artifact library plugin 600 is presented in
The artifact library plugin 408 interfaces with the artifact library client API assembly 404 to expose the artifact library data to the business process designer at the business process designer terminal 102. The artifact library plugin 408 only allows viewing of artifacts that the business process designer has permission to view. The artifact library plugin 408 may have categorize the artifacts available to the business process designer. For example, the artifact library plugin may display an artifacts folder 602 and individual artifacts 604 that the user may access. The business process designer may wish to publish a new artifact. The business process designer may drag a part of the process over a category of the library plugin 408. The library plugin 408 may interact with the artifact library client API assembly 404 to save serialized data streams into the business process database 106.
The artifact library plugin 408 also handles the insertion of an artifact into a canvas. The artifact library plugin 408 will execute different logic depending on the type of artifact being inserted. If the artifact contains placeholders, as shown in
A screenshot of an example artifact publishing wizard naming screen 700 is presented in
The artifact publishing wizard naming screen 700 may include fields to allow the business process developer to enter a name 602 and a description 604.
A screenshot of an example artifact publishing wizard placeholder screen 800 is presented in
The artifact publishing wizard placeholder screen 800 may display when a business process designer has configured an event apart from the artifact library and then wishes to add their event to the artifact library. For example, the business process designer may have already created the “Mail” event using a wizard as shown in
A screenshot of an example event wizard screen 900 is presented in
A screenshot of an example artifact publishing wizard edit placeholder screen 1000 is presented in
The business designer may wish to add a hard coded value to be used for the placeholder value. The business process user can edit data directly into the placeholders. For example, in the “Email” event, a “CustomerEmail” placeholder may be edited to insert “customer@email.com” 1002 into the field on process execution.
A screenshot of an example creating offline cache screen 1100 is presented in
The business process designer may wish to work without being connected to the business process server 104. For example, the business process designer may select a “Work Offline” function. The business process designer may be presented with a creating offline cache screen 1100. The offline cache may allow the business process designer to use workflow objects without being connected to the business process server 104. The creating offline cache screen 1100 may contain a caching progress bar.
When caching, the artifact library plugin 408 interfaces with the artifact library client API assembly 404 may recursively query the business process server 104 asking for all data, which is then cached into the client artifact library 406 which may be stored on the storage device 218. User rights may also be cached.
A screenshot of an example begin synchronization screen 1200 is presented in
The begin synchronization screen 1200 may be displayed to the user when the business process developer terminal 102 is reconnected to the business process server 104. The artifact library plugin 408 interfaces with the artifact library client API assembly 404 to determine if any conflicts exist between the client artifact library 406 and the artifacts on the business process database 106. A listing of modified artifacts may be displayed on the begin synchronization screen 1200. For example, a conflict listing 1202 may be displayed along with a progress bar 1204. The conflicts may be displayed in another form such as that shown in
A screenshot of an example resolve conflict screen 1400 is presented in
The resolve conflict screen 1400 may have artifact identifying information 1402 and a conflict resolution choice 1404. For example, the conflict resolution choice 1404 may include the options “Do not add to server,” “Add to server,” “Apply choice to all remaining conflicts,” etc.
A screenshot of an example commit offline changes screen 1500 is presented in
The commit offline changes screen 1500 may contain a conflict summary 1502. For example, the conflict summary 1502 may detail the number of items updated to the server, number of items added to the server, etc.
It should be understood that various changes and modifications to the presently preferred embodiments described herein will be apparent to those skilled in the art. Such changes and modifications can be made without departing from the spirit and scope of the present subject matter and without diminishing its intended advantages. It is therefore intended that such changes and modifications be covered by the appended claims.
The present application claims benefit to U.S. Patent Application No. 60/867,344, METHOD AND APPARATUS FOR CREATING WORK FLOW, filed on Nov. 27, 2006; and U.S. Patent Application No. 60/939,282, METHODS AND APPARATUS FOR MODELING A WORKFLOW PROCESS IN AN OFFLINE ENVIRONMENT, filed on May 21, 2007, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60939282 | May 2007 | US | |
60867344 | Nov 2006 | US |