[go: up one dir, main page]

WO1999057664A9 - Systems and methods for automated order processing - Google Patents

Systems and methods for automated order processing

Info

Publication number
WO1999057664A9
WO1999057664A9 PCT/US1999/009017 US9909017W WO9957664A9 WO 1999057664 A9 WO1999057664 A9 WO 1999057664A9 US 9909017 W US9909017 W US 9909017W WO 9957664 A9 WO9957664 A9 WO 9957664A9
Authority
WO
WIPO (PCT)
Prior art keywords
event
objects
action
order
actions
Prior art date
Application number
PCT/US1999/009017
Other languages
French (fr)
Other versions
WO1999057664A1 (en
Inventor
John T Dalton
William Ryan
John Trigg
Richard Howells
Laurel Drummond
Matthew O'brien
Original Assignee
Marcam Solutions Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Marcam Solutions Inc filed Critical Marcam Solutions Inc
Publication of WO1999057664A1 publication Critical patent/WO1999057664A1/en
Publication of WO1999057664A9 publication Critical patent/WO1999057664A9/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/08Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
    • G06Q10/087Inventory or stock management, e.g. order filling, procurement or balancing against orders

Definitions

  • the invention pertains to digital data processing and, more particularly, to systems and methods for automated transaction processing.
  • the invention has application, for example, in automated order processing.
  • an object of the invention is to provide improved digital data processing systems and, more particularly, improved systems and methods for automated transaction processing.
  • a still more particular object of the invention is to provide improved systems and methods for automated order processing.
  • a related object of the invention is to provide such methods and apparatus as can be readily adapted to existing user practices.
  • Still another object of the invention is to provide such methods and apparatus to facilitate order taking, invoicing and shipping procedures on enterprise- wide bases.
  • Yet still another object of the invention is to provide such methods and apparatus that can be readily customized to meet users' needs as initially installed, upon release of software updates and at any other desired time.
  • Still yet another object of the invention is to provide such systems as can be operated on a wide variety of digital data processing systems, from mainframes to workstations to personal computers.
  • the invention provides systems and methods for automated transaction processing utilizing modifiable tables that define significant events in transaction flow and that define actions to be taken in response to those events.
  • systems and methods according to the invention are suited to distributed transaction processing on enterprise-wide bases.
  • the invention has application inter alia in automated order processing.
  • the invention provides a system for automated transaction processing that comprises objects, or other constructs, storing status and other information about respective transactions, e.g., customer orders.
  • An event generator generates event notifications in response to selected changes made in those objects, e.g., by a user interface or other applications program.
  • the notifications can constitute "event" objects, or other constructs, identifying the object that has changed and the type of change.
  • An event processor responds to event notification by specifying a sequence of actions to be taken on the triggering object or with respect to the underlying transaction. These actions, too, can be contained in objects, referred to as "action" objects, or other constructs.
  • Action servers executing in the same or different processes as user interface or other change-effecting applications program, execute those actions - possibly, spawning further events that will be handled by the event generator, event processor and action servers.
  • the event generator dispatches each event object (or other construct) for immediate or delayed processing.
  • Event objects designated for delayed processing are queued for asynchronous execution, typically, in a separate or subsequently executing process.
  • their processing can be delayed until after a specific date and/or time.
  • Events queued for immediate processing can be taken up substantially synchronously with the applications program that triggered the change.
  • an immediate event processor generates one or more action objects to invoke the specified actions on the action servers that can also execute within the same process space. In this synchronous in-process mode of operation, processing of a new event does not commence until the prior one has completed.
  • Akin to synchronous in-process operation is asynchronous in-process operation.
  • selected event objects or the resulting action objects are processed in separate threads. This permits the main thread - e.g., that in which the user interface operates - to continue without delay.
  • Asynchronous in-process operation is beneficial for handling events, such as pricing, that might take a short period (e.g., several seconds) to process and for which it is not necessary to hold up operations in the main. When these operations are complete, the user interface or other application executing in the main thread is notified so that the updates can be displayed.
  • immediate processing refers the synchronous and asynchronous in- process processing of events.
  • the event generator In a system adapted for automated order processing, for example, following entry of an order by a customer sales representative, the event generator generates an immediate event object for determining availability of inventory items requested in the order and a delayed event object for printing and mailing an order acknowledgement.
  • the first event is executed immediately, resulting in an action that queries inventory necessary to fulfill the order.
  • the second is queued for processing by a delayed event processor executing on a back office computer system, e.g., on a separate computer from the computer on which the order was taken.
  • Another delayed event object generated by the event generator can result in repricing of the order a day before it is scheduled to be shipped.
  • the event generator could generate an event object that would result in an action for updating the delivery price. Processing of that action may result in new, cascaded events.
  • each transaction is represented by a set of objects including an order object, an delivery memo object, an invoice object, and billing memo object.
  • the order object which is principally tied to the order-taking function or order- taking site, can be the principal construct representing the transaction.
  • the invoice object stores information pertaining the invoicing function or site and, more generally, to financial liability owed to or owed from a trading partner.
  • the delivery memo object stores information pertaining to inventory and shipping functions or sites.
  • the billing memo object serves as an interface between these various functions or sites, particularly, for example, between an order taking site and the invoicing site.
  • Still other objects can be utilized to represent each transaction, including an expected shipment transaction object, shipping memo object, reservation object, reservation memo object, invoice memo object, and an invoice generator object.
  • triggering conditions in any of the objects representing a given transaction can result in actions affecting any of the other objects for that transaction.
  • the event generator can respond to the corresponding status change in the expected shipping object by generating an event object for effecting access to the expected shipping object (to wit, generation of a pick list) and to the order object (generation of a Shipping Advisory).
  • the set of objects pertaining to an order transaction need not be maintained by a single process, on a single digital data processor, or even at a single site.
  • the order object can be maintained by a workstation at the order entry site; the invoicing and billing memo objects, at the central office; and the expected shipping object, at the warehouse or shipping site.
  • Further aspects of the invention provide automated transaction processing systems as described above in which event objects are designated for immediate or delayed processing. Events that have been classified as immediate are taken up in the order generated, in the same terminal session or process as the triggering object whose change resulted in the event.
  • the action servers invoked by the resulting action objects can be also be carried out substantially synchronously, but may also be carried out substantially asynchronously by out-of-process servers.
  • Event objects designated for delayed processing are queued to a delayed event database for processing at a later time by a delayed event processor that can execute on an out-of-process server.
  • Further aspects of the invention provide error handling mechanisms that retry actions effected by delayed event objects until a maximum retry count is exceeded. This insures that event processing is carried out to completion even if a triggering object or a related object cannot be accessed when the delayed action is first attempted. Further error handling mechanisms periodically search for triggering objects that have events ready to be processed to insure that notifications remain for them in the delayed event queue. This ensures that failure of any notification mechanisms does not result in the loss of those events.
  • a flag e.g., an automation error flag
  • the error can also be recorded to an object (e.g., a persistent error object) that is subsequently used to report the occurrence to the user.
  • an object e.g., a persistent error object
  • the automation error flag is reset or removed by the user, the triggering objects remains in its failed state, thereby, facilitating identification and correction of fault by the user. Once the user takes corrective action, the event that caused the error can be requeued to the delayed event processor for handling.
  • the invention provides, in still further aspects, systems of the type described above that include a table of automation definitions, or an automation definition object, defining the sequence of actions invoked for events that occur with respect to a transaction-related object, e.g., an order object.
  • a sample table may call for the following actions to be taken in response to the following events: Event Actions
  • Multiple transaction-related objects can refer to the same order automation definition and, as a consequence, will be subjected to the same sequences of action during their lifetimes.
  • Other objects can, on the other hand, refer to different respective order automation definition and, consequently, be subjected to different sequences of action during processing.
  • a service bureau that processes telephone orders for several different mail order businesses will assign a first order automation definition to order objects taken on behalf of Trading Partner A, a second order automation definition to order objects taken on behalf of Trading Partner B, and so forth.
  • the automation definition table forms part of an automation database that additionally includes an event definition table and action definition table.
  • the event table, or event definition object lists defined events, their type (e.g., immediate or delayed), and the types of object (e.g., order, shipping, invoice or billing) that can trigger them.
  • the action definition table, or action definition object similarly lists actions, the servers that process them, their parameters or arguments, and the types of objects that can trigger them.
  • the event generator of a system can check the automation definition table to determine whether that event is significant and requires further action. If so, an event object is generated containing inter alia the i.d. of the triggering object, its type (e.g., order, shipping, invoicing or billing), the i.d. of the event, the i.d. of the associated automation definition, and the process type (i.e., whether the resulting actions are to be taken immediately or on a delayed basis). The event object is then queued for immediate or delayed processing, depending on that process type.
  • the process type i.e., whether the resulting actions are to be taken immediately or on a delayed basis
  • an event processor refers to the automation definition table to determine the identity of the actions to be taken.
  • the event processor creates one or more order action objects (and, more specifically, function action objects or transaction action objects) to invoke those actions on the servers identified in the action definition table.
  • the actions objects are loaded with the necessary arguments or parameters, as defined by the action definition table, and sequenced as defined by the order automation definition table.
  • the designated objects are updated, documents generated or notifications sent.
  • the tables that make up the automation database are preferably modifiable by the customer or user. Since these tables define the processing sequence for transactions, e.g., orders, modification of them permits the system to be readily customized. Since those modifications need not be made to the underlying source code, moreover, they carry over from software release to software release, making recustomization unnecessary as the underlying software product is enhanced.
  • Still further aspects of the invention pertain to a system for automated transaction processing that comprises an event generator and an event processor of the types described above.
  • Yet still further aspects of the invention pertain to a system for automated transaction processing that comprises an action server of the type described above.
  • Still yet further aspects of the invention pertain to methods of order automation corresponding to operation of the system described above.
  • a system for automated transaction processing comprising
  • an event processor in communication with the event generator, that responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain, and
  • an action server in communication with the event generator and with the transaction object, for executing the actions specified by the action object.
  • the event generator selectively responds to a change in the information stored in any object in the set of objects by generating an event notification indicating that an event has occurred and identifying the object in which it occurred,
  • the action server executes an action that any of accesses and updates information in any of the objects in the set.
  • a system for automated order processing comprising
  • A. a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction, B. an event generator in communication with the set of objects, the event generator responding to a change in information stored in any of the objects for generating event notification identifying the change and the objects in which it occurred,
  • event processor in communication with the event generator, the event processor responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction, and
  • an action server in communication with the event generator and with the set of objects, for executing the actions specified by the action objects.
  • the action server executes an action that changes information in the order object or any of the related objects, and
  • the event generator responds to a change in information stored in any of the objects by the action server by generating a further event notification.
  • any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
  • any of the action server and delayed event processor generate an error object for reporting the error, and wherein a notification is transmitted to the delayed event processor, upon release of any of the disabling flag and status, to at least one of specify and execute actions for the event notification that resulted in the error.
  • the set of objects include any of (i) an order object storing information pertaining to any of an order site and an order function,
  • a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment
  • an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object
  • (x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
  • a system for order automation comprising
  • an event generator in communication with the set of objects and executing substantially synchronously with the program, that responds to a change effected by the program in information stored in the set of objects, the event generator responding to such a change by generating an event notification identifying the change and the object in which it occurred,
  • an immediate event processor in communication with the event generator and executing substantially synchronously with the program, that responds to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • a system according to claim 14, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the program, that executes actions specified by the immediate event processor.
  • a system according to claim 14, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the program, that execute actions specified by the delayed event processor.
  • a transaction server that executes actions specified by the delayed event processor affecting any object in the set of objects in which the change occurred.
  • any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • the action server execute actions that change information in any object in the set of objects
  • the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
  • any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
  • any of the action server and delayed event processor generates an error object for reporting the error, and wherein a further event notification is transmitted to the delayed event processor sent upon release of any of the disabling flag and status.
  • a system for automated transaction processing comprising A. a set of one or more transaction objects storing information pertaining to a business transaction,
  • an event generator in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
  • an event processor in communication with the event generator, that responds to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
  • event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
  • event processor comprises
  • a delayed event processor in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • a system according to claim 30, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
  • a system according to claim 30, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
  • any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
  • the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • action servers comprise A. a function server that executes actions specified by the delayed event processor affecting the object in which the event occurred, and
  • B a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
  • the action server execute actions that change information in any object in the set of objects
  • the event generator responds to the changes in information effected by the action server by generating a further event notification for the event processor.
  • a system for automated transaction processing comprising
  • an event generator in communication with the set of objects, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred
  • an event processor in communication with the event generator, that responds to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
  • a system according to claim 42 comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to respective sets of objects.
  • a system for automated transaction processing comprising
  • A. a set of one or more transaction objects storing information pertaining to a business transaction
  • B. an automation database including an action table that identifies server processes for processing actions taken on the set of objects
  • an event generator in communication with the set of objects, that selectively responds to changes in information stored in the set by generating event notifications indicating that an event has occurred
  • an event processor in communication with the event generator, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
  • the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
  • the event generator selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on the event table.
  • event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
  • a system according to claim 46 wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
  • the event processor comprises A. an immediate event processor, in communication with the event generator and exc..u. ⁇ ng substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
  • a delayed event processor in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • a system according to claim 48 comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
  • a system according to claim 50 wherein the action server executes in a same process space and a same thread as the program.
  • a system according to claim 50 wherein the action server executes in a same process space as the program but in a different process thread from the program.
  • a system according to claim 48 comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
  • a system according to claim 53 wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • B a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
  • the action server execute actions that change information in any object of the set of objects
  • the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
  • a system for automated order processing comprising
  • an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
  • an event generator in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
  • an event processor in communication with the event generator and with the automation database, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
  • a method for automated transaction processing comprising the steps of A. storing information pertaining to a business transaction in a set of one or more transaction objects,
  • step (B) comprises responding to a change in information effected in step (D) by generating a further event notification.
  • a method according to claim 61 comprising disabling step (B) from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
  • step (D) comprises responding to an error in connection with the execution of an action by setting any of a flag and a status that disables step (B) from generating a further event notification for the transaction object the change in which resulted in that action.
  • step (A) includes storing information pertaining to the business transaction in a set of objects including any of
  • (x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
  • a method according to claim 65 comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
  • step (B) comprises transferring, to a first queue, event notifications to be processed substantially synchronously with the program and transferring, to a second queue, event notifications to be processed by substantially asynchronously with the program.
  • a method according to claim 67 comprising the steps of executing actions that change information in any of the set of plural objects, and responding to the changes in information effected by the action servers by generating further event notifications.
  • a method according to claim 68 comprising the step of disabling generating further event notifications for an object with respect to which an error occurred in connection with processing of a prior event.
  • a method according to claim 69 comprising the steps of responding to an error in connection with the execution of an action by setting any of a flag and a status that disables the generating of further event notification for the transaction object the change in which resulted in that action.
  • a method according to claim 70 comprising the steps of generating an error object for reporting the error that occurred in connection with processing of the prior event, and responding to release of any of the disabling flag and status for re-executing step (C) with respect to the event notification that resulted in the error.
  • a method for automated transaction processing comprising
  • Step (C) transfers to a first queue event notifications to be processed substantially synchronously with the process that changes the object, and wherein the event generator transfers to second queue event notifications to be processed by the substantially a synchronously with respect to the process that changes the object.
  • Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process changed the object, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with respect to the process that changed the object.
  • a method according to claim 75 comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
  • a method according to claim 75 comprising responding to event notifications in the second queue by specifying that the actions to be executed any of on or after a schedule time.
  • a method according to claim 75 comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
  • a method for automated transaction processing comprising the steps of
  • a method according to claim 80 comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to the respective set of objects.
  • a method for automated transaction processing comprising
  • Step (C) comprises selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifies the object in which it occurred, such selective response being made based at least in part on the event table.
  • a method according to claim 83 wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object affected thereby.
  • Step (C) comprises transferring to a first queue event notifications to be processed substantially synchronously with the process that change the object, and wherein Step (C) comprises transferring to a second queue event notifications to be processed by the substantially synchronously with that process.
  • Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process that effected the change, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that affected the corresponding change.
  • a method according to claim 86 comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
  • a method according to claim 86 comprising executing, substantially synchronously with the process that effected the change, the actions specified by the event notifications in the first queue.
  • a method according to claim 86 comprising executing, substantially asynchronously with respect the process that effected the change, the actions specified by the event notifications in the second queue.
  • a method according to claim 89 comprising executing the actions specified by the event notifications in the second queue any of on or after a schedule time.
  • a method according to claim 89 comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
  • a method for automated order processing comprising
  • B. maintaining an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects, C. responding to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
  • the event processor responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
  • a system for automated transaction processing comprising
  • an event generator in communication with the set of objects, that i) selectively responds to a first class of changes in information stored in the set of objects by generating system event notifications indicating at least that a system event has occurred, and ii) selectively responds to a second class of changes in information stored in the set of objects, which second class of changes are listed in the automation definition table, by generating user event notifications indicating at least that a user event has occurred,
  • an event processor in communication with the event generator, that i) responds to the system event notifications to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, ii) responds to the user event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
  • a method for automated transaction processing comprising A. storing a set of one or more transaction objects with information pertaining to a business transaction,
  • a system for automated transaction processing comprising
  • an event generator in communication with the set of objects, that selectively responds to a change in the information stored therein by generating an event notification indicating that an event has occurred
  • an event processor in communication with the event generator, that responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain.
  • the event generator selectively responds to a change in the information stored in any object in the set of objects by generating an event notification indicating that an event has occurred and identifying the object in which it occurred. 3. A system according to claim 2, wherein the event generator responds to at least selected change in information effected by the action server by generating a further event notification.
  • a system for automated order processing comprising
  • A. a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction,
  • event processor in communication with the event generator, the event processor responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction.
  • the set of objects include any of (i) an order object storing information pertaining to any of an order site and an order function,
  • a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object
  • a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction
  • (x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
  • a system for order automation comprising
  • an event generator in communication with the set of objects and executing substantially synchronously with the program, that responds to a change effected by the program in information stored in the set of objects, the event generator responding to such a change by generating an event notification identifying the change and the object in which it occurred,
  • an immediate event processor in communication with the event generator and executing substantially synchronously with the program, that responds to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • the event generator transfers to a first queue event notifications to be processed by the immediate event processor, and the event generator transfers to second queue event notifications to be processed by the delayed event processor.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • a system according to claim 11 wherein the delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
  • a system for automated transaction processing comprising
  • an event generator in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
  • an event processor in communication with the event generator, that responds to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
  • event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
  • a delayed event processor in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • a system for automated transaction processing comprising
  • A. a set of one or more transaction objects storing information pertaining to a business transaction
  • an event generator in communication with the set of objects, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred
  • an event processor in communication with the event generator, that responds to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
  • a system according to claim 21, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to respective sets of objects.
  • a system for automated transaction processing comprising
  • an automation database including an action table that identifies server processes for processing actions taken on the set of objects
  • an event generator in communication with the set of objects, that selectively responds to changes in information stored in the set by generating event notifications indicating that an event has occurred
  • an event processor in communication with the event generator, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
  • the event generator selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on the event table.
  • event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
  • a delayed event processor in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
  • any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
  • the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
  • a system for automated order processing comprising
  • an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects, C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
  • an event processor in communication with the event generator and with the automation database, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
  • a method for automated transaction processing comprising the steps of
  • C. responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain.
  • a method for automated order processing comprising
  • a method for order automation comprising
  • a method for automated transaction processing comprising
  • C. selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
  • a method for automated transaction processing comprising
  • a method for automated transaction processing comprising
  • the event processor responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
  • a method for automated order processing comprising A. storing a set of one or more transaction objects reflecting information pertaining to a business transaction, the set including any of
  • a delivery memo object that stores information for interfacing between the order object and the inventory method interface for order fulfillment
  • an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object
  • an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, " ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
  • C. selectively responding to changes in information stored in the set of objects rating event notifications indicating at least that an event has occurred with respect bject, such selective response being made based at least in part on the event table
  • D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
  • a system for automated transaction processing comprising an action server that executes actions specified by an action object, the action object specifying one or more actions to be executed in connection a business transaction to which a set of one or more transaction objects pertain, the action object having been generated in response to a change in information stored in one of the transaction objects.
  • (x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
  • a transaction server that executes one or more actions comprising a transaction and that affects any of (i) a transaction object the change in which resulted in creation of that action object and (ii) one or more other objects.
  • any of the function server and the transaction server executes the actions specified any of on or after a scheduled time.
  • a method for automated transaction processing comprising the step of executing an action object specifying one or more actions to be executed in connection a business transaction to which a set of one or more transaction objects pertain, the action object having been generated in response to a change in information stored in one of the transaction objects.
  • a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment
  • an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object
  • (x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
  • the executing step includes executing an action that any of accesses and updates information in any of the transaction objects.
  • a transaction server step for executing one or more actions comprising a transaction and that affects any of (i) a transaction object the change in which resulted in creation of that action object and (ii) one or more other objects.
  • any of the function server step and the transaction server step includes the step of executing actions specified any of on or after a scheduled time.
  • Figure 1 depicts the software architecture and data flow for immediate event processing in an automated order processing system according to the invention
  • Figure 2 depicts the software architecture and data flow for immediate and delayed event processing in an automated order processing system according to the invention
  • Figure 3 depicts further details of a software architecture and data flow for delayed event processing in an automated order processing system according to the invention
  • Figure 4 depicts an automation database in a system for automated order processing system according to the invention
  • Figure 5 pertains to the overall design of an order automation system acc rding to the invention
  • FIGS. 6 - 7 provide an overview of an automated order processing system according to the invention.
  • Figures 8 - 13 pertain to delayed event processing in an automated order processing system according to the invention.
  • Figures 14 - 21 pertain to a user interface for use with an automated order processing system according to the invention.
  • Figures 22 - 25 pertain to order automation definition in a system in an automated order processing system according to the invention
  • Figures 26 - 29 pertain to automation event definition in a system for automated order processing system according to the invention.
  • Figures 30 - 33 pertain to automation action definition in a system for automated order processing system according to the invention.
  • Figures 33 - 35 pertain to the action servers definition in a system for automated order processing system according to the invention. Detailed Description of the Illustrated Embodiment
  • Figure 1 depicts an automated order processing system 10 according to the invention for immediate event processing.
  • the system includes a workstation 12 or other device for entry of commands and/or data by a user, e.g., an order entry clerk.
  • plural such workstations 12 or other entry devices are provided.
  • the remaining elements illustrated in the drawing, i.e.., elements 14 - 28, may be executed (in the case of process elements) or stored (in the case of data elements) on workstation 12 or other digital data processing systems to which the workstation is coupled, e.g., via modem, LAN, WAN or otherwise.
  • Commands and/or data entered by the user(s) are received by user interface 14, which facilitates entry of information regarding a transaction, such as a customer order or other business transaction, by displaying screens, questions or other indicia to prompt the user.
  • Interface 14 responds to user input by creating and/or modifying an order object 16 for each transaction.
  • the order object 16 retains status and other information about a transaction.
  • the order object 16 is one of set of objects used to represent each transaction.
  • the additional objects include an delivery memo object, an invoice object, and billing memo object, expected shipment transaction object, shipping memo object, reservation object, reservation memo object, invoice memo object, and an invoice generator object. Still other embodiments may use a subset or superset of a combination of these.
  • the order object in these embodiments, is principally tied to the order-taking function or order-taking site (e.g., workstation 12) and is the principal construct representing the transaction.
  • the invoice object stores information pertaining the invoicing function or site and, more generally, to financial liability owed to or owed from a trading partner.
  • the expected shipment object stores information pertaining to inventory and shipping functions or sites.
  • the billing memo object serves as an interface between these various functions or sites, particularly, for example, between an order taking site and the invoicing site.
  • the object 16 comprises an instantiation of a class defined in an object oriented programming (OOP) language. Accordingly, the object 16 includes not only such information, but also methods tailored to act on that information. Those skilled in the art will appreciate that other constructs, such as records, arrays, and linked lists, may be utilized instead of OOP objects to store information regarding the transactions. In such embodiments, subroutines, functions or other independent code sequences define the methods that act on the information.
  • OOP object oriented programming
  • the order object 16 retains conventional information required for order processing, such as customer name, shipping address, item i.d., quantity ordered, and so forth.
  • the order object 16 additionally includes an order identification that uniquely identifies the object and, thereby, distinguishes it from the order objects for other transactions.
  • the order object also includes an order automation definition identification (oad i.d.) that identifies the table (or other structure) defining the sequence of actions to be executed when events occur with respect to the object 16.
  • the system 10 contains tens, hundreds or thousands or order objects 16 - each reflecting the specifics of a corresponding transaction. Though each such object has a unique order i.d., many of them may contain the same oad i.d. As a consequence, if given event occurring with respect to two (or more) of those objects, will result in identical processing.
  • Methods contained in or otherwise associated with the order object 16 detect changes to the information contained in it. Those methods signal events whenever changes occur that require computational processing (e.g., changes that affect order pricing), that impact order handling (e:g., changes in delivery address), or that are otherwise substantive in nature. In the illustrated embodiment, this signaling is made by communicating to an event generator 18 the identification of the order object 16 with respect to which the event occurred, the identification of the order action definition associated with that order, the identification of the event, and type of source of the event.
  • the source type refers to the type of the object in which the event occurred. In the embodiment of Figure 1, that type is "order object.” In embodiments where each transaction is represented by multiple objects, e.g., an order object, an expected shipment object, an invoice object, and billing memo object, the source identifier reflects the originating object accordingly.
  • Event generator 18 determines whether an action is defined for each signaled event and, if so, generates an event object 20a or 20b memorializing the event. The determination is made by comparing the event information supplied by the order object 16 with an order automation definition maintained in order automation database 22.
  • an event object (or other data storage construct) is loaded with the id of the triggering object (e.g., the id of order object 16), order action definition id, event id, and source type for the event.
  • FIG. 4 depicts the details of an order automation database 22 according to one practice of the invention.
  • An order automation definition table 22a stores, for each oad id/event id pair, a source type, an action id, and an action sequence number.
  • Each order automation is comprised of table 22a entries having the same oad id.
  • the entries are compared with the oad id, event id and source type signaled by the order object 12. If one or more matching entries are found, an event object will be created as indicated above.
  • the matching entry or entries are referenced, subsequently, by the event processor 24 to record the action id's and action sequence numbers.
  • the event generator 18 generates two types of event objects 20a, 20b, depending upon whether the actions demanded for the event is to be handled immediately (e.g., substantially synchronously with the underlying change) or can be delayed (e.g., asynchronously with respect to the change). This is referred to as the process type, which the event generator determines - based on the event id and source type - from the event definition table 22b in the order automation database 22.
  • Event objects 20a queued for immediate processing are passed to immediate event processor 24 for synchronous processing, as shown in Figure 1.
  • Event objects 20b queued for delayed processing are stored to delayed event database 30, as shown in Figure 2, for asynchronous processing
  • a notification of the delayed event is passed event generator 18 to delayed event processor 32.
  • an event object 20a queued for immediate processing is taken up by an event processor 24, which determines what actions necessary to handle the event. More particularly, the event processor 24 passes the event id, source type, and order action definition id to the order automation database 22. Since each event defined by an object 20 may necessitate several sequential actions, the event processor 24 passes a sequence number to the order automation database 22 as well.
  • the order automation database 22 returns an identifier for an action to be taken, the server responsible for processing the action, and the arguments to be passed to the server. These return values are determined from the order automation definition and from an action table, which is also contained in the order automation database 22.
  • the immediate event processor 24 imposes a maximum event count. This limits the number of events that may be triggered by a given order object 16 or by the other objects for the same underlying business transaction. By counting the number of events attributable to each object (or set of related objects), the immediate event processor can halt processing and signal an error whenever the count exceeds the preset maximum. In lieu of counting events at the immediate event processor, undesired looping can be prevented by counting them at the event generator as well.
  • the immediate event processor 24 Based on the order automation definition table 22a and the action definition table 22c, the immediate event processor 24 generates order action objects 26, or other such constructs, for each action necessitated by the event object 20.
  • order action objects 26 identify the order upon which the action is to be taken (order id), as well the action to be taken, the server responsible for taking the action, and the arguments to be passed to the server.
  • the action objects 26 are queued to, or otherwise taken up by, the respective action servers 28.
  • the action servers 28 execute code sequences implicated by the action objects 26 and update the identified objects (e.g., order objects 16) accordingly. As a result of those actions, further events may be generated by the order object 16 for processing as described above.
  • the action servers 28 preferably reside in the same process space as the user interface 14, event generator 18 and event processor 24, though they may operate in separate threads. Servers 28 whose actions can be processed substantially instantaneously and upon whose results the user can be expected to wait are typically processed in the thread in which the user interface 14, event generator 18 and event processor 24 are executed. This synchronous in-process mode of operation ensures that all processing on a current event will be completed before any further events are effected by the user.
  • Servers 28 whose actions may take somewhat longer to process can be executed in separately spawned threads.
  • Asynchronous processing of the action objects by these servers is beneficial for handling events, such as pricing, that might take a short period (e.g., several seconds) to process.
  • these asynchronous in-process servers notify the user interface 14 so that its displays can be updated.
  • delayed event processor 32 generally processes delayed event objects 20b in a manner similar to that described above for immediate event objects 20a. Unlike the immediate event processor, the delayed event processor 32 is typically assigned to operate in a different process space and, possibly, on a different digital data processor, from the user interface 14 and the event generator 18. Thus, processing by the delayed event processor 32 (and the action servers invoked thereby) is said to be substantially asynchronous with respect to occurrence of the underlying events.
  • Delayed event processor 32 utilizes the order automation database 22 (and, specifically, the order automation definition table 22a and the action definition table 22c) to determine what actions are necessary to handle each event. More particularly, the delayed event processor 32 passes the event id, source type, and order action definition id to the order automation database 22 in a manner similar to that describe above. The order automation database 22 likewise returns an identifier for an action to be taken, the server responsible for processing the action, and the arguments to be passed to the server.
  • the delayed event processor 32 gains access to the triggering object (e.g., the order object 16 or one of the corresponding objects for the same transaction) and passes its id to the action server identified by the database 22, along with the action id and the arguments. If the delayed event processor 32 cannot initially access the triggering object, it retries periodically until a maximum retry count is exceeded.
  • the triggering object e.g., the order object 16 or one of the corresponding objects for the same transaction
  • Unscheduled delayed events are processed by the delayed event processor 32 and passed to the corresponding action server as soon as possible.
  • Scheduled delayed events are not passed to the action server until a specified time or, alternatively, are not processed by the action server until that time.
  • An example of this is repricing, the actions for which are not executed, e.g., until a day before the order is scheduled to be shipped.
  • Another example is an automatic cancel order action that may be scheduled for execution a fixed number of days (e.g., 30 days) following issuance of a time-sensitive quote.
  • Action invocations by the delayed event processor 32 can be by way of action objects, as described above, or via any other notification mechanism.
  • Two types of servers are utilized. So-called function servers 28 are utilized to in instances where the actions are to be executed on the object that triggered the original event, whereas transaction servers 34 are utilized to execute actions on the triggering object or any of the other objects for the same underlying transaction.
  • a transaction server 34 If a transaction server 34 cannot initially access a target object (e.g., an order object 16 or one of the objects pertaining to the same transaction), it can either signal an error or request that the delayed event processor 32 request retry. In the later instance, the delayed event processor 32 tries invocation of that server 34 a maximum number of times, e.g., as defined in the argument list or otherwise, before event processing is aborted and an error is signaled.
  • a target object e.g., an order object 16 or one of the objects pertaining to the same transaction
  • Error handling mechanisms retry actions effected by delayed event objects until a maximum retry count is exceeded. This insures that event processing is carried out to completion even if a triggering object or a related object cannot be accessed when the delayed action is first attempted. Further error handling is achieved upon startup of the delayed event processor 32, and periodically thereafter. Specifically, the delayed event processor 32 searches for triggering objects that have events ready to be processed and insures that events for them are recorded in the requisite queues. This ensures that failure of any notification mechanisms does not result in the loss of those events.
  • a flag e.g., an automation error flag
  • the error can also be recorded to an object (e.g., a persistent error object) that is subsequently used to report the occurrence to the user.
  • an object e.g., a persistent error object
  • the automation error flag is reset or removed by the user, the triggering objects remains in its failed state, thereby, facilitating identification and correction of fault by the user. Once the user takes corrective action, the event that caused the error can be requeued to the delayed event processor for handling.
  • the delayed event processor 32 can prevent infinite loops resulting from improper order automation definitions by imposing a maximum event count. This limits the number of events that may be triggered by a given order object 16 or by the other objects for the same underlying business transaction. By counting the number of events attributable to each object (or set of related objects), the delayed event processor can halt processing and signal an error whenever the count exceeds the preset maximum. Those skilled in the art will appreciate that, in lieu of counting events at the immediate event processor, undesired looping can be prevented by counting them at the event generator as well.
  • COM customer order management
  • Protean refers to a digital data processing system in which such a customizable order automation system can be incorporated.
  • Order Automation is effectively the "glue” that holds order processing together.
  • a triggering condition is met during the course of order processing on any of the Protean COM related application objects (the Order object, the Demand Memo object (for Expected Shipments), the Billing Memo object, the Invoice object, the Reservation Memo or the Shipping Memo)
  • an order event is generated. This event may or may not be pertinent for this particular order being processed. If the event is pertinent, the event will be "processed", which means one or more Order Actions will be invoked that will carry out the necessary application behavior associated with this event. That application behavior can include the following:
  • Order Automation There is an important distinction between the definitional elements of Order Automation and the runtime elements of Order Automation. This Section focuses on the latter. Please refer elswhere for discussion of Order Automation definitional elements.
  • immediate events are to be processed synchronously, in the order they were generated, in the same session as the object that generated the event. Immediate events are generally also processed in the same process space as the generating object, for performance reasons; however, the action servers invoked by event processing can be out-of-process servers.
  • the delayed events will also be "processed" in the same session, but that processing will be limited to writing them out to a database for additional processing (by the Delayed Event Processor) at a later time (i.e. after the current user session that generated the event has ended), and quite possibly on a separate application server workstation.
  • the actions associated with these delayed events can't be processed until the current user session that generated the event has terminated, since the user session has the generating object locked and the delayed event may need to modify the generating object.
  • User Events are defined as traditional Protean IPKs, and can have a set of Order Actions associated with them on the Order Automation Definition IPK. Customers can choose whether or not to recognize a User Event in their Order Automation Definition and can also define their own unique set of Order Actions that are executed in response to User Events.
  • System Events are those events that we as the Protean COM developers are using to guarantee consistent behavior between the various COM application objects. The behavior of a User Event may vary; the behavior of a System Event will not vary. Though the term "System Event" would imply an object with different attributes and behavior than a User Event, System Events are, in fact, hardcoded processing logic. System events are always delayed events, in order to allow the system event to keep multiple application objects in synch within one database transaction.
  • Actions are further divided into Functions and Transactions. Functions could be considered to be "simple" actions, in that they can only modify the object that triggered the original event.
  • Functions cannot have any requirement for consistency with other objects. Functions always assume that the object upon which they are acting (i.e. the generating object) is opened for change. They do not call lifecycle methods (i.e. save or close) on the the generating object. Function actions can be associated with both immediate and delayed events. Transaction Actions, on the other hand, are more complex actions. They can only be associated with delayed events. Transaction actions are required when consistency between objects is necessary.
  • the diagram in Figure 5 shows the basic flow of processing a generated event. This processing involves both immediate events and the persistence of delayed events. This diagram depicts the complete process for immediate events and the first of two processing phases of delayed events. It is significant to note that only the Protean Order object may generate immediate events. The three other Protean app objects involved in order automation can only generate delayed events, whereas the Order can generate both immediate and delayed events.
  • the first phase of delayed event processing is to save them to the database to allow for true "processing" at a later time.
  • the order actions associated with delayed events are truly delayed, in that they are executed in a different time frame than that of the generating object. This second phase of delayed event processing is explained in the Protean COM Delayed Order Automation Processing design.
  • the triggering object calls API on the to do the event generation.
  • the EG may decide NOT to generate the event. In any place where you see a reference to the triggering object generating an event, remember that the triggering object is asking the EG to determine if an event needs to be generated and to then it is actually the EG that generates the actual event.
  • an in-memory event can be generated.
  • An in-memory event is an instance of an automation server; it is not a Protean application object. Any Protean COM business object that can generate order events will use the services of an Event Generator (EG) object to generate the actual event.
  • the EG is a C++, dtCore derived object that encapsulates access to the Event Processor automation server.
  • Each app object that needs to generate Order Automation events must contain a EG attribute (or a pointer to an EG (implementation detail).
  • the EG will also have Automation wrapper methods exposed so that third parties can call its APIs.
  • the diagram shows a "Triggering Condition" inside the Protean COM Order object.
  • This triggering condition is effectively a state change that is detected on any of the six COM application objects that can generate an event (i.e. the Order, the Billing Memo, the Invoice, the Demand Memo, the Reservation Memo or the Shipping Memo). Only the Order can generate immediate events; the other objects can only generate delayed events.
  • the in-memory event may be either an immediate event or a delayed event, and will be processed accordingly by the Immediate Event Processor (IEP).
  • IEP Immediate Event Processor
  • Each triggering application object will use the services of an Event Generator (EG).
  • EG Event Generator
  • Each EG will use the services of an Event Processor automation server.
  • the EG owns the EP, and is therefore responsible for creating and initializing the EP and, ultimately, for deleting the EP. Therefore, there is one EG and one EP per triggering object.
  • the COM application object(s) will always try to generate an event when a triggering condition is met.
  • System Events will always be generated.
  • the generation of Custom Events is conditional upon whether that event is defined on the corresponding Order Automation Definition and also if the event is defined for the triggering source.
  • the EG is responsible for ensuring that this event to-be-generated is in fact listed on the Order Automation Definition object as an event for which we want to do order automation processing. If the event is not contained in the collection of Order Event Definitions on the Order Automation Definition object, then we don't need to generate an event, and so we are done.
  • the EG will just return success, but not actually generate a duplicate.
  • the EG If the event is contained on the Order Automation Definition, then the EG generates an Event.
  • the EG will add the in-memory event to the appropriate queue on the JEP.
  • the JEP is an in- process automation server that will contain two collections of in-memory events, one for immediate events and one for delayed events.
  • the IEP will simply add the event to its collection of delayed events to wait to save it to the database as part of the save operation on the object that generated the event. We are now done processing this delayed event (for now, until Step 12). If this is an immediate event, and if the IEP is not currently processing an event, it will retrieve the immediate event from the queue and begin processing. The IEP is only ever concerned with processing immediate events. The Event will contain enough information on it that will allow the IEP to complete its processing. For example, the Event will have the IDispatch* to the Order Automation Definition object.
  • the IEP is currently processing an event, that means the event being added is a "cascaded" event, i.e. an event that was generated from processing the actions associated with some previously generated event.
  • the action PriceDelivery updates the Delivery price attribute, and in so doing, generates the UnitPriceUpdate event as a cascaded immediate event.
  • the IEP will just add the cascaded event to the appropriate in-memory queue of events and will return to the caller, effectively allowing the IEP to continue to process the current event.
  • This cascaded event will be processed in the order of generation, after the current event processing has completed.
  • the IEP will refer to the Order Automation Definition server to get information about the Order
  • Actions associated with this event and also to determine if a particular action is appropriate at the site where the event was generated.
  • Step 6 Since an event can be generated at multiple sites, and since the actions associated with the event vary by site, the IEP will ensure that this action is appropriate for this event source. If so, processing continues. If not, we're done with this step and we skip to Step 9 to look at any other Order Action Definitions in the collection for this event. 2.1.1.6 Step 6
  • the IEP Using the Order Action Definition UK, the IEP will instantiate the Order Action Definition object and obtain the ProgID of the corresponding Order Action Server.
  • the IEP Before proceeding with executing the Action, the IEP has to check the Action Definition object to verify that the Action is defined as "Active". It is possible for users to shut an action on or off by setting the Active/Inactive flag on the Action Definition IPK. This flag allows users to dynamically swap actions in and out of an Order Automation Definition.
  • the JEP will also obtain the list of additional arguments (as defined on the Order Action Definition) and use that along with the other attributes of the original generated event to create the Action Arguments object, yet another in-process automation object (not shown in the diagram in the interest of not adding too much clutter to an already cluttered diagram).
  • the IEP Using the ProgID of the Order Action Server, the IEP will use the MS-COM function to get the ClassLD from the ProgID (the ClassID being a GUID, and the ProgID being a user intelligible string).
  • the JEP will load the Order Action Server, passing the IDispatch pointer of the Action Arguments object, and will invoke the appropriate method on it that will carry out the required order automation behavior.
  • the "appropriate method” will be programmatically determined by the JEP, based upon the generating object and the event source.
  • Each Order Action Server will be required to support a standard set of interfaces in order to implement this functionality.
  • the Action Server will take the appropriate action on triggering business objects.
  • this behavior can only involve updating the original triggering object. This behavior is guaranteed by the Event Source attributes on the Event Definition IPK and the Action Definition IPK. If a customer were to erroneously attach an action that updates the Expected Shipment to an Event that can only be generated at the Ordering site, that action would never even get invoked, as actions are only invoked if they are defined at the site of the triggering object. By virtue of updating the triggering object, the action can lead to the generation of other events, which would be added to the IEP's queue of events (either delayed or immediate). The JEP will process the immediate events in the queue in order of generation and will write the delayed events to the database in the order of generation.
  • the IEP will continue to loop through the collection of Order Action Definitions on the Order
  • Automation Definition object executing Steps 7 through 9 for each action, after determining if the action is pertinent to the event source of the event.
  • the IEP will continue to loop through its internal queue of immediate events. Since we are guaranteeing synchronous processing for the first version of Order Automation, the only events on the queue could be those events that were generated as a result of processing the original event (i.e. cascaded events).
  • Event processing is completed when the triggering event and all of its cascaded immediate events have been processed, and control returns to the application object that triggered the first event.
  • the app object will have been waiting for that processing to complete, and will receive an erError object back from the initial method call that will indicate the status of event processing.
  • this app object will be saved and closed.
  • saving and closing can be two separate user steps at separate times, or they can both be initiated from one user action. Regardless of how they are initiated, we need to treat each differently. Step 11 occurs as the app object is saved.
  • the EG calls saveDelayedEvents on the IEP.
  • the IEP has been maintaining a collection of delayed events that were generated by either the original generating object or any of its subsequent Order Actions.
  • the IEP When saveDelayedEvents() is called, the IEP will loop through its collection of delayed events and for each will construct an IPK that it will save to the database. To optimize access to the AppLock table in the database, we will be using the new saveAndCloseO method defined on IPKs. This minimizes contention on the AppLock table that can result from separate calls to the save() and close() lifecycle methods.
  • the first version of a delayed event then is an in-memory instance of the automated event object (not a Protean app object); the second version of a delayed event is a persistent Protean app object.
  • the postClose() lifecycle hook should call a method on the EG (once again, all event related work will be done by the EG) to initiate notifying the Delayed Event Processor (DEP) if any delayed events were saved that could now be processed.
  • DEP Delayed Event Processor
  • the EG will send the same notification message to the IEP, which should check to see if delayed events were ever saved to the database. If not, you're done. If so, a message is sent to the Delayed Event Processor to inform it that it should wake up and process these delayed events.
  • the intent is to transfer control of processing to the DEP from the active user session that generated delayed events.
  • the IEP notifies the DEP that delayed events were saved. This signals that delayed event processing can begin for the triggering object.
  • the in-memory Event will be generated by the Event Generator and will be added to either the immediate or delayed queue on the Immediate Event Processor.
  • the Event object does not need to be an MS-COM automation server, since we will not be remoting it (i.e. running it on a separate workstation or server), nor will a third party have to call its APIs.
  • the JEP needs to access this object, therefore it will need Automation wrapper methods, since the IEP is an Automation server, and once we make the transition into Automation method calls, we don't want to be switching back and forth between Automation calls and regular C++ calls.
  • the Event is a very simple object whose main purpose is to capture identifying information about the processing required to fulfill the triggering condition that generated it.
  • the Event has several attributes and very little behavior, other than to set and get the values of the attributes.
  • the Event Generator will use the enum to see if this Event is defined on the Order
  • Event UK To the persisted Event Definition IPK, the Event UK (to the persisted Event Definition IPK) will be included on the in-memory event for future reference. This attribute would not be available for a system event. This would be retrieved from the OAD by the EG.
  • the attributes on this in-memory event may need some slight modification in order to persist the delayed event. For example, we cannot persist an
  • IDispatch pointer instead, we would turn the IDispatch pointer into a UK reference, in order to identify the object in subsequent delayed event processing.
  • Each generating object will have the UK of the Order to which it is related. This could be potentially redundant for immediate events, which can only be generated by the Order, therefore, this attribute might only be on in-memory delayed events. This would be provided by the triggering object.
  • Each generating object must know the Order line number to which it is related. This would be provided by the triggering object.
  • Each generating object must know the Delivery line number to which it is related. This would be provided by the triggering object.
  • the event source is significant since the same event can be generated at multiple sites, but might require different actions at different sites. This attribute will be used to determine which actions are required to be executed when processing the event. This would be provided by the triggering object.
  • System events are always processed delayed, but we need to distinguish between system events and delayed user events. System events are always generated when their corresponding triggering conditions are detected. System events are not included on the Order Automation Definition (OAD), as the customer cannot customize their behavior, nor can they choose not to recognize these events. This would be provided by the EG, because the triggering object calls a specific API on the EG (generateSystemEvent) when creating system events. 9. Delayed event flag (yes or no)
  • the EG determines this information from the OAD.
  • Scheduled events are always processed delayed but are treated differently by the DEP, so we need the flag to inform the DEP if this is scheduled or not. This would be provided by the EG, because the triggering object calls a specific API on the EG (generateScheduledEvent) when creating system events. For COM FCS, we are not defining any scheduled events. Scheduled Events could be generated by custom actions.
  • the Event Generator will be a dtCore derived, C++ object with a corresponding Automation wrapper object with exposed Automation methods.
  • the EG will be contained by each app object that needs to generate Order Automation events.
  • a third party e.g. custom action servers
  • Protean app objects can only generate events when they are either in a new state (i.e. newly created and not yet saved) or if they have been opened for change. Events are generated as a result of a state transition on an attribute, and that can't happen during an open for review.
  • the main purpose of the EG is to generate Protean COM Order Automation events and to initiate further processing of the generated events. All event related behavior will be processed via the EG. Essentially, any time a Protean COM object needs to generate an event, remove a delayed event that is no longer applicable, save delayed events, or initiate the processing of delayed events, they will do so via the services of the EG.
  • the EG is the only object that a Protean app object needs to know about in order to deal with Protean COM Order Automation events.
  • One design alternative was to combine the EG and the IEP into one object. This was decided against since it makes sense that we may want the option to configure the EG as an in-process server and the IEP as a remote server. Consequently, the EG provides wrapper methods for much of the IEP's behavior in order to encapsulate all services that Protean objects will need to know into one object.
  • the event to be generated must be defined on the OAD for this event source.
  • the EG then must refer to the list of Event subordinates on the OAD and if it finds the Event subordinate that corresponds to this event, it must verify that the event is defined for this event source; if the event to be generated already exists on one of the IEP's event queues, then the event is not generated. Managing the generation of duplicate events is discussed elsewhere in this Section.
  • the generating object needs to be able to undo the generation of a delayed event. It is possible that a delayed event could be generated, not yet persisted, and then another user action (e.g. suspending a Delivery Line) makes that event no longer applicable.
  • the EG will need to provide APIs to the generating application objects to allow them to remove or un-do the generation of delayed events.
  • the application object will still need to know a fair amount of information about the events which it intends to generate, in order to call the correct APIs on the EG, including: the enum value that identifies the event;
  • This method will be used by a triggering object to generate an user (i.e. non-system) event.
  • the EG can determine whether the event is immediate or delayed by retrieving that information from the GAD.
  • the EG will confirm with the OAD that the event in question is one that the customer has identified on the OAD.
  • An in-memory event object will be created, populated and added to the Immediate Event Processor's appropriate event queue.
  • System events are delayed events and will be added to the IEP's delayed event queue. However, system events are not IPKs, they are not defined on the OAD, they can not be conditionally generated, they are always generated. Protean code can call this method; third party action servers should not call this API. generateScheduledEvent()
  • the EG will confirm with the GAD that the event in question is one that the customer has identified on the OAD.
  • An in-memory event object will be created, populated and added to the Immediate Event Processor's delayed event queue.
  • scheduled events are delayed events that have the additional feature of being time dependent. A scheduled event cannot execute until after a certain date/time. While more details about scheduled events will be provided in the Protean COM Delayed Order Automation Processing design, we mention them here since they will be generated much like other delayed events. The major difference between scheduled events and non- scheduled events is that a scheduled event contains a date/time attribute indicating the point after which the event can be processed.
  • This method will loop thru the collection of delayed in-memory events and create a persistent IPK version of each one and save it in the database.
  • This method will inform the Delayed Event Processor that delayed events have been persisted and that they require processing.
  • the Event Generator will contain a UK reference to the Order Automation Definition. Other than that, it may need to contain some state flags. The necessity of the state flags will be decided upon at implementation time.
  • the Immediate Event Processor will be an MS COM Automation Server because it may be useful to execute it remotely in some customer configurations.
  • Protean objects and third party code should always interact with the TEP via the EG for consistency's sake.
  • a third party could interact directly with it, but they would then need to mimic some of the behavior of the EG.
  • making the EP an automation server doesn't preclude third parties from interacting with the EP directly.
  • the IEP will contain two in-memory queues, one for immediate events and one for delayed events.
  • the IEP will process immediate events and delayed events as described in detail elsewhere in this Section.
  • the delayed event processing that the IEP does is a matter of maintaining a queue of in-memory delayed events and persisting each event at save time.
  • the immediate event processing that the IEP does is more complex.
  • the error handling for immediate event processing is described elsewhere in this Section.
  • the basic immediate event processing is as follows:
  • the IEP in order to process an event, the IEP will refer to the corresponding
  • the GAD contains an Action subordinate object that points to the actual Action IPK, along with an indicator if the Action is defined for the event source within which the event was generated.
  • the IEP will first determine if the action is pertinent for the event source. If so, the IEP will open the Action definition in order to get more information to perform the action. If not, we will skip to the next action; • the IEP opens the Action IPK to retrieve additional information. From the Action IPK, we get the following attributes:
  • Action Arguments attribute which can be used to determine which method to invoke on the Action server
  • Active flag which indicates if this Action is considered to be Active or Inactive. Users may de-activate an action, which would effectively turn the action off as far as Order Automation processing goes.
  • the IEP either instantiates a new action server or uses an existing action server, based upon the Invocation Mode indicator, and then invokes a method on the server, passing in the Action Arguments object.
  • the IEP will programmatically determine which method to call on the Action Server.
  • Order Automation Processing objects provide a framework within which a user may customize their order processing, it is entirely possible that a user could create a situation where duplicate events could be generated and infinite loops could result. Even if an infinite loop did not occur, the generation of duplicate events should be avoided due to additional and unnecessary processing time.
  • the Immediate Event Processor method that adds to the queue should just return success without actually adding the event. Due to the synchronous nature of immediate event processing, we can be assured that the immediate events will be processed sequentially, without user intervention, until all immediate events are processed, or until an error has been detected and returned. Any single immediate event should only be executed once in response to a triggering condition.
  • delayed events we are not completely guaranteeing that we will not be generating duplicates for FCS.
  • delayed events are persisted after each save of the triggering object. It could be possible that delayed events were generated, persisted (and therefore removed from the in-memory queue) and then perhaps generated again. The subsequent generation would check the in-memory queue only to see if the delayed event had already been generated. Since it was no longer on the queue, it would be generated and persisted again, and therefore you could wind up with duplicate delayed events. While this is not desirable, neither should it be too harmful. It would lengthen processing time, but these are delayed events and processed in the background. This can be an optimization for a future release, but at this point it is not critical to prevent this from happening for FCS.
  • Immediate events are, more often than not, generated from app object's set methods, which by coding standards, return an erError object, which is used to return errors to the UI.
  • the generatelmmediateEvents method that the app object calls on the EG will call addlmmediateEvent on the IEP. Any of the methods that the JEP calls as part of processing an immediate event should also return an erError.
  • the Order Actions are the atomic, logical units of work in Order Automation.
  • an error is detected, we keep track of the error message(s) that were generated by that action, and go on to the next action for that immediate event. If any errors are detected on any of the actions, we return the error message to the user, but we do not undo the original triggering condition, nor any of the successful actions that may have occurred.
  • APIs below are provided only to indicate required IEP behavior. It is entirely possible that they may change and that there may be others.
  • This method will be called by the EG's generateEvent method. It will add the generated event to the immediate event queue. For the first immediate event, this will trigger the processing of the immediate event. If adding additional immediate events (i.e. cascaded events), the event will simply be added and control will return to the caller.
  • This method will perform the processing outlined in Steps 5 through 10 of Figure 5.
  • the in-memory immediate event will be removed from the queue and from memory and control will be returned to the calling object.
  • This method will be called by the various EG methods that create delayed events (i.e. generateEvent, generateSystemEvent, and generateScheduledEvent). It will add the generated event to the delayed event queue and control will be returned to the caller.
  • createEvent i.e. generateEvent, generateSystemEvent, and generateScheduledEvent. It will add the generated event to the delayed event queue and control will be returned to the caller.
  • This method will be called by the generating object in those situations where a delayed event may have been generated (and not yet saved) but subsequent application actions have made that delayed event no longer applicable.
  • the JEP will use this method to loop thru its collection of delayed events.
  • This method will inform the DEP that delayed events have been persisted and that they require processing.
  • the IEP needs to be able to inform the triggering objects that delayed events have already been persisted, in the situation where the triggering object may need to undo the generation of those events (i.e. remove them from the database).
  • the IEP will contain the following attributes:
  • Controllers can also be servers.
  • One goal of the COM project is to provide all objects with an OLE Automation API.
  • a user interface for order entry can be constructed using a tool like Microsoft Visual Basic.
  • Other examples include maintaining an existing order by reporting usage and delivery confirmation through an automated process.
  • a set of objects are responsible for the generation of order automation events.
  • An event is generated based on order automation sensitive values, statuses, holds, or points in an object's lifecycle. The primary reason for generating an event is to allow an action to be tied to it.
  • System events There are two categories of events: system and user. All user events provided with the base product are made available through order event definition objects. System events cannot have user defined actions associated . System events are those events which are necessary to make the product operational, e.g., creating and updating an expected shipment object.
  • the update server is a generic example of a order action that responds to a system event.
  • the behavior of the customer order object can be modified by associating actions with events in an order automation definition.
  • the invoice object represents the financial liability owed to or owed from a trading partner.
  • Invoicing happens at the fmancials site. Posting an invoice to fmancials will place the transactions in a common format defined by the Open Applications Group' (OAG).
  • OAG Open Applications Group
  • the creation of a delivery line on an order causes a corresponding delivery memo object to be created. Changes are replicated by the EM facility when the COM site and inventory site are in separate databases.
  • a system action server is one that the delayed event processor (DEP) knows how to invoke.
  • DEP delayed event processor
  • An order action server has a corresponding Protean definition object, the order action definition.
  • the order action server's API is invoked by the event processor.
  • the order action server will contain the specialized business logic to perform actions like complete an order or lock the price on a delivery line. In some eases, e.g., pricing, this order action server will do some front end preparation like gathering action specific data from the order object, contact another server to execute the action, and then update the order with the results.
  • An update server is a specialized system action that is in place to handle the communication of changes between the order and the delivery memo or billing memo objects.
  • the intent of these servers is twofold. First these allow us to break updates into more shorter transactions.
  • update servers will help to reduce the complexity of the order code.
  • the order object (specifically the delivery line) determines when an expected shipment or billing memo should be created, updated, and deleted. Without an update server the order needs to maintain state about this event and then execute logic during the next save operation (this is similar to what the schedule object currently does). Additionally, this complexity only deals with outbound information from the order, there still needs to be a feedback mechanism from the delivery memo or billing memo to the order.
  • Some potential benefits of the update servers is that these updates can happen in background. Furthermore, we could invoke these from an order automation server running on an application server to give us the best throughput.
  • the document messenger facility provides a means to automatically generate a specified document in a requested format This is where integration with a third party forms package occurs.
  • this action When a user action has a reference to a trading partner document on its definition, this action is invoked by the order automation server. This system action gathers up a unique collection of contacts that should be sent the document and passes these on to the document action server.
  • This server contains the logic for determining how to print the specified document.
  • This server is named in the associated Protean document definition object.
  • This OLE automation server conforms to the published document action server API. Typically, this server will retrieve additional information from the order object and then give this data to the third party forms package for formatting.
  • definitional objects work together to ensure the correct set of events and actions are executable at runtime, i.e., actions that can only work in response to an event from a shipping source can not be tied to an event from an invoicing source.
  • This is responsible for executing all defined order actions associated with an order event on a given order automation definition. Also, this can respond to system events with predefined system actions, e.g., the update servers. While there is much more detail in the order automation server than is presented here, this architectural element is responsible for the event queuing and processing. This service guarantees that all events queued will be processed.
  • This object defines the sequence of actions followed for selected order automation events. Each order is created with a reference to an order automation definition. Modifying this object allows a customer to change how one type of order behaves differently from another type.
  • An order action definition object provides a Protean representation of an OLE automation server registered on a client machine. In simplest form, this is a link between Protean and OLE. There are a number of additional attributes on an order action definition that control how the named OLE automation server (identified as an order action server in Figure 6) is contacted prior to invoking the order action compliant API.
  • the order object determines that a new delivery line is complete and generates the Delivery Line Added event. Event generation includes enough information so that the order action server invoked later can determine which delivery line was added.
  • the order automation server looks at the order automation definition referenced by this order to determine if there are any actions to be invoked in response to this event.
  • the Price Line action is defined for the Delivery Line Added event.
  • the order automation server then contacts the pricing order action server through OLE/COM and invokes the order action compliant, exposed OLE automation API.
  • the pricing calculation requires the resource, requested resource characteristics, the quantity ordered, the requested delivery date, along with the ordering trading partner, the selling company and line of business.
  • the pricing order action server gathers this data from the order object. This is possible because the information passed to an order action server from the order automation server includes the dispatch interface to the order object which generated the event. In Visual Basic terms, the order object is passed to the invoked order action server.
  • the order object returns the requested information.
  • the pricing order action server has the data necessary for the pricing calculation, it needs to get the correct price sheet to perform the calculation.
  • the price sheet is determined by the pricing provider object, which is given the assignment criteria as input.
  • the new order delivery line is updated with the result of the pricing calculation. 10.
  • Changing the price causes a Price Changed event to be generated. To prevent recursion problems, this event can be queued up for later processing by the order automation server since an event is currently being handled.
  • Control returns to the pricing order action server from the call to update the price on the new order delivery line.
  • the order automation server is now done with the pricing order action server.
  • the order automation server looks to the order automation definition for more order actions to be executed.
  • the order automation server then checks its event queue to see if there are any other events to be processed for this order and it finds the Price Changed event (generated in step 10).
  • the order automation server again looks to the order automation definition for any actions associated with the Price Changed event.
  • the order automation definition responds that there are no actions defined for the requested event. The event is removed from the queue.
  • the order automation server determines that there are no more events for this order in the queue, so control returns to the order object at the point where the Delivery Line Added event was generated.
  • Control returns to the order entry user interface from the order object. At this point the user interface can be refreshed so that the calculated price for the delivery line is available to the CSR.
  • Order Automation is the COM feature that will allow users to customize order processing to meet their own particular needs. Order Automation consists of several components, including definitional components, immediate event processing components, and delayed event processing components. This Section focuses on the latter.
  • Order processing will have the ability to generate order automation events in response to a variety of triggering conditions.
  • some of these events can be processed immediately, i.e. synchronously in the same process space as the Order.
  • the Order and the other related COM app objects can also generate delayed events, which are processed after the user is done interacting with the generating app object, in a separate process space, on a separate application workstation.
  • This design will explain how multiple COM client workstations can generate delayed events and can initiate their processing via the Delayed Event Processor (DEP). Specifically, the design will focus on delayed user events and the ramifications of errors on delayed event processing and order processing. System events and scheduled events will also be discussed, but in lesser detail.
  • DEP Delayed Event Processor
  • the Delayed Event Processing Manager Service is an NT Service responsible for managing the processing of delayed events.
  • the DEPMS is required to be running on a remote server, on the same network but a physically separate machine than the Order entry workstations. This remote server is also running one single instance of the Protean process.
  • the goal of the DEPMS is to allow multiple clients to asynchronously contact the DEPMS with a request to perform delayed event processing as a background task.
  • the asynchronous call permits the client to continue its path of execution, rather than blocking and waiting for the delayed event processing to complete.
  • the benefit of this asynchronous behavior is most apparent when the client is the Order object, and the closing of the Order initiates delayed event processing. Since the Order object is the only event triggering object with a UI, user response time is critical.
  • the asynchronous model allows many Orders to close simultaneously, with no discernible performance degradation.
  • NT Services are started in two separate ways:
  • the Delayed Event Processing Manager Service is an automatic startup NT Service. However if the DEPMS is not running (due to a crash or other unforeseen circumstance), a clients' first attempt to contact the DEPMS manually starts it.
  • Figure 8 shows the DEPMS after initialization, but prior to any client requests arriving.
  • the DEPMS creates one multithreaded apartment (MTA) and a configurable number of Single Threaded Apartments (STA).
  • MTA multithreaded apartment
  • STA Single Threaded Apartments
  • the number of ST As created by the DEPMS matches the number of STAs created in the single Protean footprint.
  • Both Protean and the DEPMS look at the same data (currently an entry in the protean.ini file) to determine the number of STAs to create.
  • the MTA contains objects requiring simultaneous access from multiple clients. Any objects or shared data residing in the MTA must be thread safe as any one of multiple threads may access this shared data. An MTA is required here to guarantee that any number of clients will always have access to this service and won't be blocked by another process accessing this service.
  • the Queue Manager is a C++ class that contains an in memory queue and a critical section.
  • the critical section is an NT synchronization object used to enforce exclusive access to the queue.
  • All requests to process delayed events are added and removed from the single in memory queue contained in the QMGR. Multiple clients may attempt to access the queue simultaneously, making the queue the synchronization point for the entire DEPMS. Since synchronized entry to the queue is paramount, the critical section enforces exclusive access to the queue.
  • the QMGR has public methods to push() and pop() items from the queue, using the contained critical section to synchronize queue access. C++ encapsulation allows QMGR clients to push() and pop() items from the QMGR. QMGR clients are detached from queue synchronization details in the QMGR implementation .
  • the QMGR also contains an NT Event used at delayed event processing time.
  • the use of this NT Event is discussed fully in the following section.
  • the DEPMS creates a configurable number of STAs.
  • the STAs contained in the DEPMS do not contain any MS COM components. These STAs are single threads that make connections to Protean STAs and then go to sleep, waiting to perform processing logic when awakened.
  • Each DEPMS STA connects to a Protean STA by creating an instance of the Delayed Event Processor (DEP) MS COM component.
  • the DEP is created in a corresponding STA inside the single Protean footprint. After DEP creation, each STA is immediately put to sleep, waiting for clients to push items into the QMGR. It is important to note that the DEP is created in an STA in the Protean process. This is significant considering the DEP opens many Protean objects during its processing of delayed events, and it is most efficient if all this work is executed in the same Protean apartment.
  • the final step of DEPMS startup provides error recovery from the previous run of the DEPMS. Due to one of a number of circumstances (DEPMS crashes, network goes down), it is possible that unprocessed delayed events remain in the database.
  • the DEPMS checks for this situation by running a query across the delayed event IPK table. The DEPMS uses the query results to rebuild the QMGR and begin processing these orphaned delayed events.
  • the DEPMS must ascertain that it did not leave Protean objects applocked due to a previous crash. To check for this, the DEPMS executes a query against the applock table looking for objects left open by the DEP from a previous run. Details about this can be found in Section 3. 1 .2.5 Re-Try Considerations.
  • Figure 9 builds on Figure 8 and shows the DEPMS accepting client requests and synchronously executing these requests as background tasks.
  • the DEPMS is available to accept requests from possibly multiple clients. Lets consider a scenario with multiple Order objects closing simultaneously.
  • the destructor of the Order creates (via CoCreatelnstanceQ) an instance of the Delayed Event Notification Manager (DENM).
  • DENM is an MS COM component created in the MTA of the DEPMS, allowing multiple Order objects the ability to simultaneously create DENM components.
  • the Order object invokes a method on the DENM to notify the DEPMS to start Delayed Event Processing. This notification indicates:
  • the Order object has generated and saved delayed events.
  • the DENM creates a new thread in the MTA and returns immediately to the Order object. This immediate return to the Order object allows the Order to continue its path of execution (the Order is closing).
  • the newly created thread in the MTA pushes an item into the QMGR, but may wait on the critical section that is synchronizing access to the queue.
  • the major benefit of this strategy is that the newly created thread, not the Order object, waits on the critical section.
  • the Order object continues to close, and the newly created thread works in the background, attempting to push data into the QMGR. This is a very important point given that a CSR is waiting for the Order to close. Note: An alternative to this approach is to not create the thread and let the Order object wait on the critical section.
  • the QMGR class contains an NT Event.
  • An NT Event is an NT synchronization object the DEPMS uses to signal sleeping STAs when items are pushed into the QMGR.
  • the QMGR utilizes the contained NT Event to signal a single STA that an item to process is in the queue.
  • the NT event wakes one sleeping STA and the STA pops an item off the QMGR. If there are more items on the QMGR, the pop() sets the NT Event, waking another STA. This process continues until the entire QMGR is processed.
  • the executeQ method is a synchronous call.
  • the DEPMS STA waits for Delayed Event Processing to complete before continuing its path of execution. It is important to note that this synchronous call is happening in the background, long after the Order object is closed. This is the right time to be synchronous and wait for DEP completion.
  • notification request that the DENM receives has a notification count greater than 1 , this indicates that the notification request is being re-tried, due to the fact that an object could not be opened for change (re-try is explained in more detail in Section 3.1.2.5). In such a circumstance, we do not want to immediately place the notification request on the QMGR. It is preferable to wait a configurable amount of time. Notification re-tries will be placed on a separate re-try queue, and a timer will pop the item from the re-try queue and push the item into the QMGR.
  • Delayed Event Processor (DEP) which is instantiated inside a single threaded apartment in the Protean process on the remote server.
  • This processing takes two different forms: 1 for non-scheduled delayed events and 1 for scheduled delayed events.
  • the scheduled version is very similar to the non-scheduled version, but the processing is initiated differently. Both versions are discussed below.
  • TOs in error can still be modified via openForChange (OFC) by processes other than the DEP. These modifications could lead to additional delayed events being generated, which implies additional notification requests to the DEPMS. However, TOs in error should not generate notification requests to the DEPMS. If the automation error flag is on the TO (as opposed to on another object), then this is a simple "if test;
  • OFC openForChange
  • TOs in error need to be retrieved via specialized queries on the TO cabinet. Via dynamic cabinets, we can only join to objects to which the main cabinet object (in this case, the TO) has a reference. Therefore, since our TOs will not be containing a reference to their corresponding Persistent Error Objects, it is preferable if the error flag is on the TO itself;
  • the diagram in Figure 10 depicts the flow of processing of delayed events.
  • the STA from the DEPMS service invokes the execute method on the Delayed Event Processor (DEP) inside of the Protean process running on the same workstation (the remote server which houses the DEPMS). It is significant to note that the DEP is running in the Protean process, as the DEP must talk to many Protean objects and it is far more efficient to do so if it is resident inside the Protean process.
  • DEP Delayed Event Processor
  • the original notification call receives the classID and objectID of the triggering object (TO), along with the user key name parts of the object and a count of how many notifications for this object have been sent.
  • the DEP opens for change (OFC) the TO.
  • the class ID is used to determine which class of user key to construct. Either the user key name parts are filled in or the classID/objID parts are filled in (See Issue # 5) and the UK reference is used to OFC the triggering object. Since delayed events that were generated by this TO are stored as subordinates on a persistent collection on the TO, they will be retrieved as part of a demand fetch operation. (Opens for the Order in particular will always be shallow for efficiency reasons, therefore we will be relying on demand fetch to retrieve subordinates.)
  • w e should determine if there w ere errors on a prev ious execution of delayed events for this TO If there w ere errors, the automation error flag on the TO would be set to TRUE Technically, the DEP should never he attempting to process errors for a TO in an automation error state, since the TO will not send a notification request to the DEPMS if the automation error flag is set However, we really should not process any further if this flag is set. therefore, w e do the check If set, we are done with this notification request and w e terminate processing successfully
  • the DEP w ill retriev e from it the value of the flag to indicate if processing details should be ⁇ tten to a log file If so. the DEP w ill create the log file and retain this flag internally to use it du ⁇ ng v a ⁇ ous processing steps to determine if log file entries need to be created Step 5
  • the maximum event count will be referred to as w e loop through the delayed ev ent collection, if w e exceed the maximum event count, w e generate a c ⁇ tical persistent error on the TO and terminate processing, if this is really a loop, the user can then turn on logging on the O AD. and reinitiate processing The log output w ill help them debug the loop,
  • the DEP will examine the Delayed Ev ent to see if its att ⁇ bute that lists the last successful action that was processed is set If so, that means that this delayed e ent previously had errors and stopped sometime after the action value that is stored in this att ⁇ bute w as completed successfully Explanation of ho this att ⁇ bute is set can he found in Step 9 below If this attribute is set, the DEP w ill refer to the OAD to get the UK of next action associated with this delayed event after the action stored in this att ⁇ bute For example, if the v alue stored in the att ⁇ bute indicates the 3rd action processed successfully, then this round of processing will re-commence w ith the 4th action,
  • Step 7 If this att ⁇ bute is not set, the delayed ev ent is being processed for the first time and so the DEP w ill get the first action associated w ith this delayed ev ent on the OAD Similar .0 immediate e ent processing, 'he DEP must chec.-v on the O AD that the action is defined for this ev ent source (the event source is the "site" of the t ⁇ gge ⁇ ng object — not the site in the Protean sense of a Site UK, for example, but rather the site meaning the Orde ⁇ ng site, the Inv oicing Site, the Inv entory site or Other) Step 7
  • the TO is sav ed after each successful action execution.
  • This w ill persist on the 1 st delayed ev ent on the TO the v alue of the last action successfully processed If a subsequent action fails (hence the TO is not saved), then the delay ed ev ent w ill at least ecord the last successful action processed Therefore, w hen delayed event processing is restarted for this TO, we w ill pick up w ith the action after the last successful action that as processed for this delayed event If no subsequent actions fail, the delayed ev ent is remov ed from the collection, and this attribute is no longer relevant Step 10
  • the DEP w ill instantiate an Action Arguments object, built from details on the event and from the Action Definition IPK
  • the type of Action Arguments object that w e create depends upon whether the Action is a function or a transaction
  • Transaction actions may update objects other than the o ⁇ ginal t ⁇ gge ⁇ ng object
  • Function actions may only update the original t ⁇ gge ⁇ ng object (1 e in terms of Protean objects If there w ere non-Protean objects in a customer env ironment, it is possible that they could be updated in a function action)
  • either form of action serv er w ill always receiv e an IDispatch* to the automation wrapper class for the original t ⁇ gge ⁇ ng object that w as OFC'd in Step 2 abo e
  • Transaction actions w ill also receiv e an IDispatch* to the automation manager class for the original t ⁇ gge ⁇ ng object, as they may need to invoke the sav e lifecycle method on the object
  • Action Arguments object w ill also contain a CMsgList (or some such container of messages) This message list w ill store al] messages ( I e critical errors, arnings and informationals) returned from the execution of action servers
  • the Action Arguments object ill contain a flag indicating if a re-try is being requested Since transaction actions may openForChange objects other than the t ⁇ gge ⁇ ng object, it is possible that the open may fail due to contention. If so, this is not an error but w e do need to re-submit the processing request Hence, all transaction action serv ers must be written such that failed OFC's will turn on the re-try request flag and return that to the DEP Step 1 1
  • the DEP w ill instantiate the action sen er (v la CoCreatelnstance) and w ill invoke the execute method on the Action ser er, passing in the Action Arguments object
  • a side effect of inv oking the action ser er could be inv oking methods on both the t ⁇ gge ⁇ ng object and also other objects (for transaction action serv ers)
  • It t ⁇ e action ser. er DLL cannot be found or is not reg>ste r eJ this s a c ⁇ tical error in which case, w e create an e ⁇ or create a Persistent E ⁇ or Object (this process is described repeatedly below ), and terminate processing Step 12
  • the DEP w ill examine the re-try request flag from the Action Arguments object If a re-try is requested, then an OFC in the transaction action serv er failed Before w e can re-try, how ev er w e must check the notification count that the DEP has been maintaining for this triggering object If this re-try request w ill increment the notification count beyond the configurable v alue that was retriev ed by the DEP from the PROTEAN INI file at DEP initialization time, then w e hav e now exceeded the maximum number of re-tnes allowable We w ant to reflect this with a persisted cntical e ⁇ or, but w e don't need to keep all the other w arnings, informationals, etc from the action server(s) already executed So, we can just create a c ⁇ tical e ⁇ or and persist that, and then terminate processing by closing the TO
  • a Persistent E ⁇ or Object is created, based upon the UK of the TO All e ⁇ ors (warnings, informationals. and cnticals. if any) are copied to the persistent e ⁇ or object
  • the persistent e ⁇ or object is saved and closed, but the t ⁇ gge ⁇ ng object is just closed not saved since there were e ⁇ ors in processing and since w e don't want to persist an object that might be in a e ⁇ or state
  • the OAD must also be closed as pail of termination
  • the message list w ill only be persisted if a c ⁇ tical e ⁇ or is detected after the execution of an action server That is, we only persist messages if something failed Therefore, w e only create a PEO for a TO if something failed If all actions associated with the delayed ev ent being processed only return warnings and informationals, then there were no critical e ⁇ ors, hence there w ill be no PEO Consequently, those warning messages are not persisted We maintain an on-going list of all warnings and informationals returned from all successful actions so that in the event of a cntical e ⁇ or, the persistent e ⁇ or object re fleets all processing for the delayed event now in e ⁇ or
  • Step 14 If no c ⁇ tical e ⁇ ors ere returned from the action execution, w e loop back to the OAD to get the UK of the next action associated w ith this delayed ev ent (as m Step 7 abov e), and continue with Steps 8 through 12 Step 14
  • the DEP will call the remove method on the delayed event collection to remove the delayed event from the TO
  • the DEP will ret ⁇ eve the next delayed event from the TO's delayed event collection and process it according to the steps desc ⁇ bed above, beginning with step 6
  • FCS Scheduled event processing will be very similar to the non-scheduled version, except for the initiation of the notification requests and some tests that will be done to ensure that the time is right to execute this event
  • Scheduled ev ents w ill be stored in a separate collection of delayed e ents on the t ⁇ gge ⁇ ng object, before processing a scheduled event, the DEP must ensure that the scheduled time is equal to or later than the cu ⁇ ent time
  • W e anticipate that the lessons learned in implementing regular delayed ev ent processing w ill be relev ant to scheduled ev ent processing, so postponing this implementation until after delay ed e ent processing is done is a good idea
  • an automation e ⁇ or flag w ill be set on the TO before the first action is executed, and only turned off 1 ) after all actions execute successfully, or 2) if w e need to request a re-try due to OFC contention, as each action is being executed, its v alue w ill be stored in an att ⁇ bute on the delay ed ev ent If the action is successful, the TO is sav ed, thereby sto ⁇ ng the results of the action and the att ⁇ bute indicating the last successful action processed If all actions on the delayed ev ent process successfully, this "last action successfully processed" flag is moot, as the delayed ev ent is remov ed If an action fails, the delayed ev ent reflects the last action successfully processed, the automation e ⁇ or flag w ill be used by a query on the TO to return all TOs in e ⁇ or due to automation processing,
  • the personal user key of the PEO ill be the objectID and classID of the TO
  • the PEO therefore, refers to the TO, and not the other w ay around This is for two reasons 1 ) vve can ' t save the TO once a c ⁇ tical e ⁇ or occurs, and we only create the PEO when a critical e ⁇ or occurs, therefore you can't store the PEO's UK on the TO, and 2) the v anous Memo objects are EM ' d from site to site EM assumes that the object it is updating hasn't changed since it's last update Hence, the Memo object can't contain a UK to the PEO,
  • the TO may be modified, and new delayed ev ents may be generated, but the destructor of the TO w ill not send a notification request to the DEPMS if the automation e ⁇ or flag is set TOs in an automation e ⁇ or state will not be processed by the DEP until the e ⁇ or state is cleared.
  • the automation e ⁇ or flag can only be cleared through a specialized non-standard cabinet action, descnbed below
  • Each class of objects that can generate delayed events will need a new query defined This query, w hen executed, will retriev e from the database all delayed events for instances of this tnggenng object that are in e ⁇ or, based upon the automation e ⁇ or flag on the TO Any one triggering object instance can only have 1 delayed event in e ⁇ or due to the nature of delayed ev ent processing Once the first e ⁇ or is detected, no further e ents are processed
  • This query will return information about all tnggenng objects of this class that have delayed ev ents in e ⁇ or but only if the TO ' s app lock is OFF
  • the app lock cntena is a must since vve don't w ant to ret ⁇ ev e those TOs that are cu ⁇ ently OFC'd and being processed by the DEP, since the DEP will pessimistically set the automation e ⁇ or flag and will have the TO OFC'd So, for example, on the Order cabinet, the query w ill return an answer set indicating all Orders that hav e delayed ev ents in e ⁇ or, along with the name of the ev ent that w as being executed I f we can include the action name too, that would be great — vve w ill resolv e that at implementation time
  • the cabinet action that show s e ⁇ ors for the TO must prov ide the ability to openForRev iew the PEO associated w ith the TO that is in e ⁇ or
  • the PEO's PUK w ill be the bjlD classID combination ot the TO e ⁇ or
  • This OFR w i ll oc done oy constructing a U K for the PEO. and filling in its v alues from the TO and then executing the OFR
  • the erE ⁇ or portion of the PEO will be retnev ed from the object and w ill be displayed in a standard message list v iew er dialog
  • the cabinet action that remov es that e ⁇ or condition would delete the appropnate PLO object, OFC the TO and clear the flag, and then Sav e.AndClose the TO
  • the destructor of the TO w ill send a notification request to the DEPMS if the TO contains delayed events in its collection, w hich w ill re-initiate delayed ev ent processing
  • the Billing Memo (BM ) is created in the Orde ⁇ ng site, and then re-created ( ia EM) in the Inv oicing site
  • the BM is simply a data holder, 1 e no real billing memo processing happens in the Ordenng site, hence no automation events occur It is only created in the Ordenng site, but it is processed in the Inv oicing site.
  • the PEO can only be created for the triggering object w hen the tnggenng object is being created in its ev ent source site, as ev ents are only generated and processed in an object ' s ev ent source site
  • w hen the BM is created in the Ordering site
  • no ev ents are ev er gene/ ited for the BM in the creation site
  • creation WILL generate ev ents, w hich may create automation e ⁇ ors, hich ould lead to the creation of a PEO for that BM
  • the DEP at instantiation time, reads the PROTEAN.INI file to retrieve the maximum re-try count and the notification wait time;
  • the notification count sent over in the original request for a TO is stored in the DEP and incremented each time a re-try request is resubmitted to the DEPMS.
  • the notification wait time will be used to slightly delay this notification request from getting back into DEP processing. The idea with this is that if I could't OFC it, and if the notification queue is emptying out pretty fast, let's wait a bit before I try to OFC it again so that there's a better chance of the OFC working on the re-try; when the DEP determines that the notification count exceeds the maximum re-try count, an PEO is created indicating this e ⁇ or condition, and processing terminates;
  • the Order can be OFC'd by a user and the ensuing closing of the Order w ill inv oke the destructor which will notify the DEPMS that delayed events for this Order exist, and the process is back on track
  • the abstract tnggenng object is an fdEmblnst denved class that will encapsulate all delayed e ent behav ior All tnggenng objects that need to generate events must inhent multiply from fdGenlnst and co.AbsDelEv ent, therefore, this object belongs in the Resource VOB
  • the delayed event IPS w ill inhe ⁇ t directly from fdSublnst It will be a standard subordinate, contained in a persistent collection. This object also belongs in the Resource MOB
  • Delivery line number event source I e Orde ⁇ ng site. Inv entory site, Inv oicing site. Other
  • event ID system event flag yes or no
  • This method w ill retnev e from the PROTEAN INI file the notification re-try count and the maximum delayed event count and store these v alues in internal v a ⁇ ables for use dunng processing executeQ
  • the DEP will use the follow ing att ⁇ butes to keep track of processing
  • the PEO maps to three separate database tables 1 ) the PEO IPK table 2) the persistent message IPS table and 3) the persistent message parameter IPS table If vv e find ov er time that there is contention on these database tables, we can create an additional PEO IPK (w ith co ⁇ esponding subordinates) to partition the usage of the PEOs among v arying tnggenng objects
  • the PEO objects ill also be in the Resource VOB
  • This Section covers the User Inteface design of the Order Automation definitional objects Order E ents, Order Actions, Protean Documents and the Order Automation Designer (OAD)
  • the basic product requirement that order automation must satisfy is customers' flexibility in processing an order
  • the life cycle of a customer order consist of a series of actions and ev ents that are performed on it Order Entry, credit checking, order approv al are some of the actions and ev ents that can be performed dunng the life cycle of an order
  • the sequence in w hich the order ' s ev ents and actions are performed may v ary from customer to customer For examole. for most orders the inv oicing activ ities occur as ⁇ result of a shipment How ev er, w ith some orders inv oicing could occur prior to shipment (ad ance invoicing), and in the case of consignment orders invoicing occurs after the customer has used the resource.
  • the order automation design allows the user to configure the lifecycle of an order
  • the user is able to define the normal actions and ev ents that occur in the lifecycle and the sequence in which the actions occur Events identify the activities or steps that occur dunng the life of an order, such as a user releasing a hold. Events can be catego ⁇ zed as a change to the lifecycle, att ⁇ bute value, hold or status
  • the response to each event is represented as a collection of actions to be performed in the defined sequence Actions identify the processes or updating performed by the system such as credit checking, venfying av ailability, or p ⁇ nting an acknowledgment
  • order automation prov ide a flexible architecture, it easily allow s users to plug in their own logic For example, if a customer wants to use a customized invoice, they simply create an Invoice action, which references the customized API When defining the order automation, they reference their custom Inv oicing action instead of the a predefined Invoicing action.
  • the user can sequence the order that actions are invoked. But as the abo e example illustrates, the sequence for processing an ev ent with multiple sources might be different than that defined on the order automation definition. So, ev en though the user may set up an order automation definition to create the Shipping Advisory first, then the Pick List, the outcome is the same as if the user defined the Pick List to be generated first.
  • the Order Automation Designer ooject has its ow n lifecy cle
  • An automation is initially established as inactn e allowing the implementation specialist to test the automation
  • the OAD is updated to reflect that it is acm e at which point the automation definition becomes protected — events and actions can no longer be added or deleted
  • the effective date controls which Order Automation Designer (OAD) is selected for an order
  • a base product may be contain a number of predefined events
  • users may generate their own custom events
  • Pre-defined events cannot be maintained or deleted
  • the Event UI will have a standard Admin Tab 2 1 1 E ⁇ or messages for Order Event UI
  • the order ev ent should h ⁇ v e a prompted query on name, ev ent source and custom flag
  • the order automation definition requires an order ev ent cabinet: e should be able to reuse the above cabinet.
  • Neither cabinet should allow users to delete predefined events. Through referential integrity vve will prevent users from deleting events that are cu ⁇ ently referenced by other objects .
  • predefined actions can be provided for the cu ⁇ ent list of predefined actions.
  • Predefined Actions are read only, except for the Active flag (defaults to on). Predefined actions cannot be deleted.
  • a Protean Document is the Protean definitional object which describes the capability of a specific OLE Automation server invoked by the document messenger facility to create a document. Order Actions that generate a document, i.e., the automation server indicator is set to document messenger must reference a valid Protean Document. When defining an OAD an Action is referenced, which in turn references a Protean Document. Since a document is always reference through an action, it is not necessary to have overlapping attributes on both objects; attributes such as the active flag and custom level help will appear only at the Action level.
  • Figure 18 shows a Protean Document user interface screen for the illustrated embodiment.
  • the Protean Document cabinet should have a query set to display all Protean
  • Figure 19 shows an Order Automation Designer UI user interface screen for the illustrated embodiment
  • Figure 20 show s detail panels for the Order Automation Designer ev ents and actions
  • Figure 21 shows the effect of adding an event to a tree in the Order Automation Designer
  • This prov ides the ability for an Order Automation to retain a specific name (e g Vv almart) and be assigned once to a Market Profile(s)
  • the use of an effective date (instead of the o ⁇ gmal plan to create a new O D with a new name every time a change occu ⁇ ed) w ill ensure that the user can define versions of this one OAD and minimize the amount of 'ripple-through maintenance that they would hav e to do, e g , to Market Profile's
  • the Order Automation Designer cabinet should hav e a prompted query on Name, effectiv e date and the Activ e flag
  • the Order Automation Designer requires an order action with a prompted query on source
  • the Automation menu w ill hav e items allow ing Addition of Ev ents and Actions, as w ell as nav igation to the Order UI See Table 6
  • This Section cov ers the design of the order automation definition object It is this object that defines how specialized operations of a customer order object w ill behave
  • the order automation definition object is where events in the order's lifecycle are mapped to the actions inv oked in response by the order automation server
  • the order automation definition object supports multiple v ersions of an order automation definition being in use at the same time This supports the reality that our customers face in changing order processing policies New orders can follow the latest policy , while existing orders can continue to follow the policies in effect at the time of entry into Protean
  • the order automation definition object does not make a distinction between an ev ent or action prov ided with the base product from those extensions made by our customers
  • An example incorporating multiple kinds of events and actions is presented to illustrate this concept
  • the order automation definition object is used by the order automation server to determine the processing a giv en order follow s
  • An order object references the order automation definition by user key
  • the assignment of the order automation definition occurs dunng the creation of the order object.
  • the order automation definition object provides controls to assist in its availability to new orders as desc ⁇ bed in the following sections covenng its lifecycle and v ersions Later sections present the data model, its attnbutes and validation rules, as well as the class hierarchy
  • changes to order processing policies may call for a new v ersion of the order automation definition
  • An existing definition can be saved as a new version ith a different effective- from date in an inactive state Orders created with the previous version continue to use that version After all referencing orders have been removed, the unused definition may be removed
  • Figure 23 shows a timeline for multiple order automation definition versions O er time multiple versions of an order automation definition can exist Versions are supported by having a different effective-from date on objects w ith the same name As seen in Figure 23, a typical sequence of events might be
  • the market profile will only store the name, not user key, of an order automation definition.
  • the market profile will query the database to determine that there is at least one active order automation definition with this name.
  • the recommendation for testing order automation definitions is to use a snapshot (or backup) of the "live” database as the "test” database. Having this parallel database is the best way to prove the operation of the order automation definition without compromising our customers' data.
  • the example is based on an order process which takes customer orders usually 30 days prior to the promised ship date (perhaps due to manufactu ⁇ ng lead time) Also, one day p ⁇ or to shipping taking place a credit check is performed If a credit hold is placed on the order, a custom action (notify credit manager) is performed When a credit hold is released, another custom action is performed (notify shipping clerk hold released) and shipping activ lty may proceed
  • the queue preship credit check is a custom action that uses the ev ent queue API to enter a time- based ev ent to occur 1 day prior to the promised ship date on the order dehverv
  • Send order acknow ledgment is a document messenger action, which some amount of custom w ork is required 3 5 4 Deliv ery Reserved
  • This ev ent is base product functionality P ⁇ nting the pick list is a document messenger action which requires some amount of custom work
  • This ev ent is base product functionality
  • Sending the adv anced ship notice is a document messenger action which requires some amount of custom work
  • This ev ent is base product functionality
  • the lock p ⁇ ce and generate inv oice actions are also base product functionality Pnnting the invoice is a document messenger action w hich requires some amount of custom work
  • This ev ent is base product functionality
  • the test for credit hold applied action is custom, it looks to see if a specific hold code (indicating a credit hold) has been applied to the order
  • This customer-defined hold code w ill prev ent shipping activ ity from occumng
  • the custom action could be coded to send the credit manager handling this customer an alert v ia M.API (Messaging Application Programming Interface)
  • the test for credit hold released action is custom, it looks to see if a specific hold code (indicating a credit hold) was released If so, it also looks to see if any deliv enes on the order w ere promised for today or in the recent past If there w ere missed shipments due to a credit hold, then the shipping clerk is notified v ia MAPI The assumption is that the shipping clerk assembles shipments once a day and may be able to expedite those ith (credit) holds released later in the day Data Model
  • the structure of an order automation definition is an object with two levels of collections, as shown in Figure 24.
  • the first level subordinates are the customer-specified collection of order events requiring a response.
  • the response to each event is represented as the collection of order actions to be invoked in the defined sequence.
  • Each order object has a required UK to its order automation definition object. Both the collection of events and actions are just subordinates containing a single attribute, the user key to its associated definition object.
  • Hold Code An embedded user key of the hold code to be applied to the order summary if any e ⁇ or occurs in processing an order event. This is also known as the order automation administrative hold. This is a required attribute,
  • Active A Boolean value, which when true is active, and when false is inactive. Once an order automation definition is made active it can never become inactive. To make an order automation definition active from the UI, validation should be run first.
  • Order Events The collection of selected order events requiring a response.
  • Audit Trail - A Boolean used to indicate whether an audit trail history for this definition should be generated. This history information provides the start and end date and time of an action, what order and event caused it to occur, the duration of action, and the user causing the event. This is helpful in debugging an installation of the order automation definition, and after it has been running, analyses can be used to determine potential bottlenecks and order processing cost information. Can be modified when active.
  • Administrative Site A required reference to the site where this object is maintained. Defaults from the user ' s default site: 4 2 2 coEv entSub
  • Order Actions The collection of order actions invoked as a response to this ev ent Order actions are inv oked in collection defined sequence.
  • Event Handling An enumerated value (same as defined by the event definition object) of NotUsed, Immediate, and Delayed. For shipping, invoicing, and other ev ent sources this v alue is always delayed For ev ents defined for the ordering event source this v alue is copied from the coEventDef object, and the user may ovemde an immediate ev ent to be delayed, but is restncted from overnding a delayed event to be handled as immediate
  • An order automation definition must have at least one event defined.
  • Actions are allow ed to be duplicated on the order automation definition, even within an event. Warnings are returned when duplicates within an event are foumld.
  • Each order action definition must be appropriate for the selected event source. For example, an order action that is only defined for ordering event source cannot be selected for use with a shipping event source. This can be detected when adding the action to the collection on the event, and a critical e ⁇ or is returned.
  • the values for Respond On Event Source on a coActionSub are enabled based on the intersection of the Event Sources from a coEventDef and the Valid Event Sources from a coActionDef. From this list, only one value can be selected. For example, if an event has the ordering, shipping, and invoicing event sources, and an action has the ordering and shipping event sources, only the ordering and shipping choices are the only possible selections.
  • UDS warning

Landscapes

  • Business, Economics & Management (AREA)
  • Economics (AREA)
  • Engineering & Computer Science (AREA)
  • Marketing (AREA)
  • Quality & Reliability (AREA)
  • Finance (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Human Resources & Organizations (AREA)
  • Accounting & Taxation (AREA)
  • Operations Research (AREA)
  • Development Economics (AREA)
  • Strategic Management (AREA)
  • Tourism & Hospitality (AREA)
  • Physics & Mathematics (AREA)
  • General Business, Economics & Management (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

Systems and methods for automated transaction processing utilize modifiable tables that define significant events in transaction flow and that define actions to be taken in response to those events. In addition to facilitating customization of the automated processing actions and sequences, systems and methods according to the invention are suited to distributed transaction processing on enterprise-wide bases. The invention has application inter alia in automated order processing.

Description

SYSTEMS AND METHODS FOR AUTOMATED ORDER PROCESSING Background of the Invention
This application claims the benefit of priority of United States Patent Application Serial Nos. 60/084,201, filed May 4, 1998. This application is also a continuation of United States Patent Application No. 09/108,115, filed June 30, 1998. The teachings of all of the aforementioned applications are incorporated herein by reference.
The invention pertains to digital data processing and, more particularly, to systems and methods for automated transaction processing. The invention has application, for example, in automated order processing.
Automated systems handling customer orders have long been available. Early systems were written on custom bases to mirror each vendor's manual, or paper-based, order processing systems. As mass markets grew, labor and maintenance costs rendered custom packages less attractive than their off-the-shelf equivalents. Manufacturers, distributors and retailers alike now choose from a wide variety of these turn-key systems.
While the available order processing systems have proven to be a boon to back office operations, they nonetheless suffer drawbacks. Principal among these are their relative inflexibility. Typically, these products provide few configuration operations, necessitating suppliers to adapt their practices to meet the demands of the software, rather than vice versa. Even among semi-custom products that can be configured to better match existing paper-based systems, full customization is rarely an option. Moreover, these systems often require that each new software release be recustomized.
For example, in one prior art system, modifications for each customer site were implemented by directly changing the source code of the released product. Upgrading a customer to a new version of the product required reapp lying the modifications. This approach was costly to the customer in both time and money as their original investment became obsolete when the next version of the product became available.
The foregoing problems are exacerbated when the automated systems are implemented on an enterprise-wide basis, e.g., for suppliers whose order taking, invoicing and shipping procedures are performed at different sites, perhaps, scattered across the globe.
In view of the foregoing, an object of the invention is to provide improved digital data processing systems and, more particularly, improved systems and methods for automated transaction processing. A still more particular object of the invention is to provide improved systems and methods for automated order processing.
A related object of the invention is to provide such methods and apparatus as can be readily adapted to existing user practices.
Still another object of the invention is to provide such methods and apparatus to facilitate order taking, invoicing and shipping procedures on enterprise- wide bases.
Yet still another object of the invention is to provide such methods and apparatus that can be readily customized to meet users' needs as initially installed, upon release of software updates and at any other desired time.
Still yet another object of the invention is to provide such systems as can be operated on a wide variety of digital data processing systems, from mainframes to workstations to personal computers.
Summary of the Invention
The foregoing objects are met by the invention, which provides systems and methods for automated transaction processing utilizing modifiable tables that define significant events in transaction flow and that define actions to be taken in response to those events. In addition to facilitating customization of the automated processing actions and sequences, systems and methods according to the invention are suited to distributed transaction processing on enterprise-wide bases. The invention has application inter alia in automated order processing.
In one aspect, the invention provides a system for automated transaction processing that comprises objects, or other constructs, storing status and other information about respective transactions, e.g., customer orders. An event generator generates event notifications in response to selected changes made in those objects, e.g., by a user interface or other applications program. The notifications can constitute "event" objects, or other constructs, identifying the object that has changed and the type of change. An event processor responds to event notification by specifying a sequence of actions to be taken on the triggering object or with respect to the underlying transaction. These actions, too, can be contained in objects, referred to as "action" objects, or other constructs. Action servers, executing in the same or different processes as user interface or other change-effecting applications program, execute those actions - possibly, spawning further events that will be handled by the event generator, event processor and action servers.
According to further aspects of the invention, the event generator dispatches each event object (or other construct) for immediate or delayed processing. Event objects designated for delayed processing are queued for asynchronous execution, typically, in a separate or subsequently executing process. According to one aspect of the invention, their processing can be delayed until after a specific date and/or time.
Events queued for immediate processing can be taken up substantially synchronously with the applications program that triggered the change. To this end, an immediate event processor generates one or more action objects to invoke the specified actions on the action servers that can also execute within the same process space. In this synchronous in-process mode of operation, processing of a new event does not commence until the prior one has completed.
Akin to synchronous in-process operation is asynchronous in-process operation. According to this aspect of the invention, selected event objects or the resulting action objects are processed in separate threads. This permits the main thread - e.g., that in which the user interface operates - to continue without delay. Asynchronous in-process operation is beneficial for handling events, such as pricing, that might take a short period (e.g., several seconds) to process and for which it is not necessary to hold up operations in the main. When these operations are complete, the user interface or other application executing in the main thread is notified so that the updates can be displayed. Unless otherwise apparent from context, as used herein the terms "immediate processing," "synchronous processing" and "substantially synchronous processing" refer to the synchronous and asynchronous in- process processing of events.
In a system adapted for automated order processing, for example, following entry of an order by a customer sales representative, the event generator generates an immediate event object for determining availability of inventory items requested in the order and a delayed event object for printing and mailing an order acknowledgement. The first event is executed immediately, resulting in an action that queries inventory necessary to fulfill the order. The second is queued for processing by a delayed event processor executing on a back office computer system, e.g., on a separate computer from the computer on which the order was taken. Another delayed event object generated by the event generator can result in repricing of the order a day before it is scheduled to be shipped.
Continuing the example, were the sales representative to update the quantities of goods specified in the order, the event generator could generate an event object that would result in an action for updating the delivery price. Processing of that action may result in new, cascaded events.
Still further aspects of the invention provide systems as described above, adapted for automated order processing, in which each transaction is represented by a set of objects including an order object, an delivery memo object, an invoice object, and billing memo object. The order object, which is principally tied to the order-taking function or order- taking site, can be the principal construct representing the transaction. The invoice object stores information pertaining the invoicing function or site and, more generally, to financial liability owed to or owed from a trading partner. The delivery memo object stores information pertaining to inventory and shipping functions or sites. The billing memo object serves as an interface between these various functions or sites, particularly, for example, between an order taking site and the invoicing site. Still other objects can be utilized to represent each transaction, including an expected shipment transaction object, shipping memo object, reservation object, reservation memo object, invoice memo object, and an invoice generator object.
According to still further aspects of the invention, triggering conditions in any of the objects representing a given transaction can result in actions affecting any of the other objects for that transaction. For example, once goods ordered by a trading partner have been delivered, the event generator can respond to the corresponding status change in the expected shipping object by generating an event object for effecting access to the expected shipping object (to wit, generation of a pick list) and to the order object (generation of a Shipping Advisory).
According to still further aspects of the invention, the set of objects pertaining to an order transaction need not be maintained by a single process, on a single digital data processor, or even at a single site. Thus, for example, the order object can be maintained by a workstation at the order entry site; the invoicing and billing memo objects, at the central office; and the expected shipping object, at the warehouse or shipping site. Further aspects of the invention provide automated transaction processing systems as described above in which event objects are designated for immediate or delayed processing. Events that have been classified as immediate are taken up in the order generated, in the same terminal session or process as the triggering object whose change resulted in the event. The action servers invoked by the resulting action objects can be also be carried out substantially synchronously, but may also be carried out substantially asynchronously by out-of-process servers. Event objects designated for delayed processing are queued to a delayed event database for processing at a later time by a delayed event processor that can execute on an out-of-process server.
Further aspects of the invention provide error handling mechanisms that retry actions effected by delayed event objects until a maximum retry count is exceeded. This insures that event processing is carried out to completion even if a triggering object or a related object cannot be accessed when the delayed action is first attempted. Further error handling mechanisms periodically search for triggering objects that have events ready to be processed to insure that notifications remain for them in the delayed event queue. This ensures that failure of any notification mechanisms does not result in the loss of those events.
In the event of that an event cannot be processed, e.g., after repeated retries by the delayed event processor, a flag (e.g., an automation error flag) can be set on the object that triggered the object to prevent any further attempts to execute events with respect to it. The error can also be recorded to an object (e.g., a persistent error object) that is subsequently used to report the occurrence to the user. Until the automation error flag is reset or removed by the user, the triggering objects remains in its failed state, thereby, facilitating identification and correction of fault by the user. Once the user takes corrective action, the event that caused the error can be requeued to the delayed event processor for handling.
The invention provides, in still further aspects, systems of the type described above that include a table of automation definitions, or an automation definition object, defining the sequence of actions invoked for events that occur with respect to a transaction-related object, e.g., an order object. By way of example, in an automated order processing system, a sample table may call for the following actions to be taken in response to the following events: Event Actions
Order Created Credit Check
Delivery Entered Available-to-Promise, Price Delivery
Order Entered Price Order, Tax Order, Apply Discounts,
Queue Credit Check, Send Order
Acknowledgment
Delivery Reserved Print Pick List
Order Reserved Send Advanced Shipping Notice
Delivery Shipped Print Bill of Lading
Order Shipped Lock Price, Generate Invoice, Print Invoice
Preship Credit Check Credit Check
Order Hold Applied Test For Credit Hold Applied
Order Hold Released Test For Credit Hold Released
Multiple transaction-related objects can refer to the same order automation definition and, as a consequence, will be subjected to the same sequences of action during their lifetimes. Other objects can, on the other hand, refer to different respective order automation definition and, consequently, be subjected to different sequences of action during processing. Thus, for example, a service bureau that processes telephone orders for several different mail order businesses will assign a first order automation definition to order objects taken on behalf of Trading Partner A, a second order automation definition to order objects taken on behalf of Trading Partner B, and so forth.
According to related aspects of the invention, the automation definition table forms part of an automation database that additionally includes an event definition table and action definition table. The event table, or event definition object, lists defined events, their type (e.g., immediate or delayed), and the types of object (e.g., order, shipping, invoice or billing) that can trigger them. The action definition table, or action definition object, similarly lists actions, the servers that process them, their parameters or arguments, and the types of objects that can trigger them.
When the state of a transaction-representative object, e.g., an order object or its related shipping, invoicing or billing objects changes, the event generator of a system according to the invention can check the automation definition table to determine whether that event is significant and requires further action.. If so, an event object is generated containing inter alia the i.d. of the triggering object, its type (e.g., order, shipping, invoicing or billing), the i.d. of the event, the i.d. of the associated automation definition, and the process type (i.e., whether the resulting actions are to be taken immediately or on a delayed basis). The event object is then queued for immediate or delayed processing, depending on that process type.
When the event object comes up for processing, an event processor refers to the automation definition table to determine the identity of the actions to be taken. The event processor creates one or more order action objects (and, more specifically, function action objects or transaction action objects) to invoke those actions on the servers identified in the action definition table. The actions objects are loaded with the necessary arguments or parameters, as defined by the action definition table, and sequenced as defined by the order automation definition table. As the action objects are processed, the designated objects are updated, documents generated or notifications sent.
The tables that make up the automation database are preferably modifiable by the customer or user. Since these tables define the processing sequence for transactions, e.g., orders, modification of them permits the system to be readily customized. Since those modifications need not be made to the underlying source code, moreover, they carry over from software release to software release, making recustomization unnecessary as the underlying software product is enhanced.
Still further aspects of the invention pertain to a system for automated transaction processing that comprises an event generator and an event processor of the types described above.
Yet still further aspects of the invention pertain to a system for automated transaction processing that comprises an action server of the type described above.
Still yet further aspects of the invention pertain to methods of order automation corresponding to operation of the system described above.
Still further aspects of the invention are set forth in claims-like language in the text below:
AUTOMATED TRANSACTION SYSTEMS AND METHODS ASPECTS
1. A system for automated transaction processing, comprising
A. a set of one or more transaction objects that store information pertaining to a business transaction, B. an event generator, in communication with the set of objects, that selectively responds to a change in the information stored therein by generating an event notification indicating that an event has occurred,
C. an event processor, in communication with the event generator, that responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain, and
D. an action server, in communication with the event generator and with the transaction object, for executing the actions specified by the action object.
2. A system according to claim 1, wherein
A. the event generator selectively responds to a change in the information stored in any object in the set of objects by generating an event notification indicating that an event has occurred and identifying the object in which it occurred,
B. the action server executes an action that any of accesses and updates information in any of the objects in the set.
3. A system according to claim 2, wherein the event generator responds to at least selected change in information effected by the action server by generating a further event notification.
4. A system according to claim 3, wherein the event generator is disabled from generating a further event notification for a transaction object with respect to which an error occurred in connection with processing of a prior event.
5. A system according to claim 4, wherein the action server responds to an error in connection with the execution of an action by setting any of a flag and a status that disables the event generator from generating a further event notification for the transaction object the change in which resulted in that action.
6. A system for automated order processing, comprising
A. a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction, B. an event generator in communication with the set of objects, the event generator responding to a change in information stored in any of the objects for generating event notification identifying the change and the objects in which it occurred,
C. an event processor in communication with the event generator, the event processor responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction, and
D. an action server, in communication with the event generator and with the set of objects, for executing the actions specified by the action objects.
7. A system according to claim 6, wherein
A. the action server executes an action that changes information in the order object or any of the related objects, and
B. the event generator responds to a change in information stored in any of the objects by the action server by generating a further event notification.
8. A system according to claim 7, wherein the event generator is disabled from generating a further event notification for a transaction object with respect to which an error occurred in connection with processing of a prior event.
9. A system according to claim 8, wherein any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
10. A system according to claim 9, wherein any of the action server and delayed event processor generate an error object for reporting the error, and wherein a notification is transmitted to the delayed event processor, upon release of any of the disabling flag and status, to at least one of specify and execute actions for the event notification that resulted in the error.
11. A system according to claim 7, wherein the set of objects include any of (i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment, (iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
12. A system for order automation comprising
A. a digital data processor executing a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. an event generator, in communication with the set of objects and executing substantially synchronously with the program, that responds to a change effected by the program in information stored in the set of objects, the event generator responding to such a change by generating an event notification identifying the change and the object in which it occurred,
C. an immediate event processor, in communication with the event generator and executing substantially synchronously with the program, that responds to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
D. a delayed event processor, in communication with the event generator, that responds to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
13. A system according to claim 12, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
14. A system according to claim 12, wherein the event generator transfers to a first queue event notifications to be processed by the immediate event processor, and the event generator transfers to second queue event notifications to be processed by the delayed event processor.
15. A system according to claim 14, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the program, that executes actions specified by the immediate event processor.
16. A system according to claim 15, wherein the action server executes in a same process space and a same thread therein as the program.
17. A system according to claim 15, wherein the action server executes in a same process space as the program but in a different thread therein from the program.
18. A system according to claim 14, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the program, that execute actions specified by the delayed event processor.
19. A system according to claim 18, wherein the action servers comprise
A. a function server that executes actions specified by any of the immediate and delayed event processor affecting the object in which the change occurred, and
B. a transaction server that executes actions specified by the delayed event processor affecting any object in the set of objects in which the change occurred. 20. A system according to claim 19, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
21. A system according to claim 19, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
22. A system according to claim 14, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
23. A system according to claim 15, wherein
A. the action server execute actions that change information in any object in the set of objects, and
B. the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
24. A system according to claim 19, wherein the event generator is disabled from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
25. A system according to claim 24, wherein any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
26. A system according to claim 25, wherein any of the action server and delayed event processor generates an error object for reporting the error, and wherein a further event notification is transmitted to the delayed event processor sent upon release of any of the disabling flag and status.
27. A system for automated transaction processing, comprising A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an event that identifies changes for which an event notification is to be " generated with respect to each type of object in the set of objects,
C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
D. an event processor, in communication with the event generator, that responds to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
28. A system according to claim 27, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
29. A system according to claim 28, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
30. A system according to claim 29, wherein the event processor comprises
A. an immediate event processor, in communication with the event generator and executing substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change. 31. A system according to claim 30, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
32. A system according to claim 30, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
33. A system according to claim 32, wherein the action server executes in a same process space and a same thread as the program.
34. A system according to claim 32, wherein the action server executes in a same process space as the program but in a different process thread from the program.
35. A system according to claim 30, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
36. A system according to claim 35, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
37. A system according to claim 35, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
38. A system according to claim 30, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
39. A system according to claim 35, wherein the action servers comprise A. a function server that executes actions specified by the delayed event processor affecting the object in which the event occurred, and
B. a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
40. A system according to claim 32, wherein
A. the action server execute actions that change information in any object in the set of objects, and
B. the event generator responds to the changes in information effected by the action server by generating a further event notification for the event processor.
41. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred,
D. an event processor, in communication with the event generator, that responds to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
42. A system according to claim 41, wherein the automation definition table defines sequences in which the defined actions are to be executed for each selected change.
43. A system according to claim 42, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to respective sets of objects.
44. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction, B. an automation database including an action table that identifies server processes for processing actions taken on the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set by generating event notifications indicating that an event has occurred,
D. an event processor, in communication with the event generator, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
45. A system according to claim 44, wherein
A. the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
B. the event generator selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on the event table.
46. A system according to claim 45, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
47. A system according to claim 46, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
48. A system according to claim 47, wherein the event processor comprises A. an immediate event processor, in communication with the event generator and exc..u.ιng substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
49. A system according to claim 48, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
50. A system according to claim 48, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
51. A system according to claim 50, wherein the action server executes in a same process space and a same thread as the program.
52. A system according to claim 50, wherein the action server executes in a same process space as the program but in a different process thread from the program.
53. A system according to claim 48, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
54. A system "according to claim 53, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
55. A system according to claim 53, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server. 56. A system according to claim 48, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
57. A system according to claim 53, wherein the action servers comprise
A. a function server that executes actions affecting objects in which the event occurred, and
B. a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
58. A system according to claim 50, wherein
A. the action server execute actions that change information in any object of the set of objects, and
B. the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
59. A system for automated order processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
D. an event processor, in communication with the event generator and with the automation database, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
60. A method for automated transaction processing, comprising the steps of A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. selectively responding to a change in the information stored in the set of objects by generating an event notification indicating that an event has occurred,
C. responding to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction, and
D. executing the actions specified by the action object.
61. A method according to claim 60, wherein step (B) comprises responding to a change in information effected in step (D) by generating a further event notification.
62. A method according to claim 61, comprising disabling step (B) from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
63. A method according to claim 62, wherein step (D) comprises responding to an error in connection with the execution of an action by setting any of a flag and a status that disables step (B) from generating a further event notification for the transaction object the change in which resulted in that action.
64. A method according to claim 60, adapted for automated order management, wherein step (A) includes storing information pertaining to the business transaction in a set of objects including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
65. A method of automated transaction processing
A. executing on a digital data processor a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. responding to a change effected by the program in information stored in the set objects by generating an event notification identifying the change and the object in which it occurred,
C. responding to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
D. responding to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
66 A method according to claim 65, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
67. A method according to claim 65, wherein step (B) comprises transferring, to a first queue, event notifications to be processed substantially synchronously with the program and transferring, to a second queue, event notifications to be processed by substantially asynchronously with the program.
68. A method according to claim 67, comprising the steps of executing actions that change information in any of the set of plural objects, and responding to the changes in information effected by the action servers by generating further event notifications.
69. A method according to claim 68, comprising the step of disabling generating further event notifications for an object with respect to which an error occurred in connection with processing of a prior event.
70. A method according to claim 69, comprising the steps of responding to an error in connection with the execution of an action by setting any of a flag and a status that disables the generating of further event notification for the transaction object the change in which resulted in that action.
71. A method according to claim 70, comprising the steps of generating an error object for reporting the error that occurred in connection with processing of the prior event, and responding to release of any of the disabling flag and status for re-executing step (C) with respect to the event notification that resulted in the error.
72. A method for automated transaction processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an event table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects,
C. responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
D. responding to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
73. A method according to claim 72, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that changes an object in the set of objects. 74. A method according to claim 73, Step (C) transfers to a first queue event notifications to be processed substantially synchronously with the process that changes the object, and wherein the event generator transfers to second queue event notifications to be processed by the substantially a synchronously with respect to the process that changes the object.
75. A method according to claim 74, wherein Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process changed the object, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with respect to the process that changed the object.
76. A method according to claim 75, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
77. A method according to claim 75, comprising responding to event notifications in the second queue by specifying that the actions to be executed any of on or after a schedule time.
78. A method according to claim 75, comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
79. A method for automated transaction processing, comprising the steps of
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred,
D. responding to the event notification by utilizing the automation database to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
80. A method according to claim 79, wherein the automation definition table defines sequences in which the defined actions are to be executed for each selected change.
81. A method according to claim 80, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to the respective set of objects.
82. A method for automated transaction processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an automation database that includes an action table identifying server processes for processing actions taken on the transaction objects,
C. selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred,
D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, utilizing the action table to determine a server process for processing such action and signaling that server process thereof.
83. A method. according to claim 82, wherein the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
Step (C) comprises selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifies the object in which it occurred, such selective response being made based at least in part on the event table.
84. A method according to claim 83, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object affected thereby.
85. A method according to claim 84, wherein Step (C) comprises transferring to a first queue event notifications to be processed substantially synchronously with the process that change the object, and wherein Step (C) comprises transferring to a second queue event notifications to be processed by the substantially synchronously with that process.
86. A method according to claim 85, wherein Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process that effected the change, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that affected the corresponding change.
87. A method according to claim 86, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
88. A method according to claim 86, comprising executing, substantially synchronously with the process that effected the change, the actions specified by the event notifications in the first queue.
89. A method according to claim 86, comprising executing, substantially asynchronously with respect the process that effected the change, the actions specified by the event notifications in the second queue.
90. A method according to claim 89, comprising executing the actions specified by the event notifications in the second queue any of on or after a schedule time.
91. A method according to claim 89, comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
92. A method for automated order processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. maintaining an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects, C. responding to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
93. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. an event generator, in communication with the set of objects, that i) selectively responds to a first class of changes in information stored in the set of objects by generating system event notifications indicating at least that a system event has occurred, and ii) selectively responds to a second class of changes in information stored in the set of objects, which second class of changes are listed in the automation definition table, by generating user event notifications indicating at least that a user event has occurred,
D. an event processor, in communication with the event generator, that i) responds to the system event notifications to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, ii) responds to the user event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
94. A method for automated transaction processing, comprising A. storing a set of one or more transaction objects with information pertaining to a business transaction,
B. selectively responding to a first class of changes in information stored in the set of objects by generating system event notifications indicating at least that a system event has occurred, and
C. selectively responding to a second class of changes in information stored in the set of objects, which second class of changes are listed in an automation definition table, by generating user event notifications indicating at least that a user event has occurred,
D. responding to the system event notifications to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain,
E. responding to the user event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
EVENT PROCESSOR AND RELATED METHODS ASPECTS
1. A system for automated transaction processing, comprising
A. a set of one or more transaction objects that store information pertaining to a business transaction,
B. an event generator, in communication with the set of objects, that selectively responds to a change in the information stored therein by generating an event notification indicating that an event has occurred, and
C. an event processor, in communication with the event generator, that responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain.
2. A system according to claim 1, wherein the event generator selectively responds to a change in the information stored in any object in the set of objects by generating an event notification indicating that an event has occurred and identifying the object in which it occurred. 3. A system according to claim 2, wherein the event generator responds to at least selected change in information effected by the action server by generating a further event notification.
4. A system according to claim 3, wherein the event generator is disabled from generating a further event notification for a transaction object with respect to which an error occurred in connection with processing of a prior event.
5. A system for automated order processing, comprising
A. a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction,
B. an event generator in communication with the set of objects, the event generator responding to a change in information stored in any of the objects for generating event notification identifying the change and the objects in which it occurred,
C. an event processor in communication with the event generator, the event processor responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction.
6. A system according to claim 5, wherein the set of objects include any of (i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object, (vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
7. A system for order automation comprising
A. a digital data processor executing a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. an event generator, in communication with the set of objects and executing substantially synchronously with the program, that responds to a change effected by the program in information stored in the set of objects, the event generator responding to such a change by generating an event notification identifying the change and the object in which it occurred,
C. an immediate event processor, in communication with the event generator and executing substantially synchronously with the program, that responds to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
D. a delayed event processor, in communication with the event generator, that responds to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
8. A system according to claim 7, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count. 9. A system according to claim 7, wherein the event generator transfers to a first queue event notifications to be processed by the immediate event processor, and the event generator transfers to second queue event notifications to be processed by the delayed event processor.
10. A system according to claim 9, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
11. A system according to claim 7, wherein the event generator is disabled from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
12. A system according to claim 11 , wherein the delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
13. A system according to claim 12, wherein the delayed event processor generates an error object for reporting the error, and wherein a further event notification is transmitted to the delayed event processor sent upon release of any of the disabling flag and status.
14. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an event that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects,
C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
D. an event processor, in communication with the event generator, that responds to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
15. A system according to claim 14, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
16. A system according to claim 15, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
17. A system according to claim 16, wherein the event processor comprises
A. an immediate event processor, in communication with the event generator and executing substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
18. A system according to claim 17, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
19. A system according to claim 17, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
20. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction, B. an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred,
D. an event processor, in communication with the event generator, that responds to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
21. A system according to claim 20, wherein the automation definition table defines sequences in which the defined actions are to be executed for each selected change.
22. A system according to claim 21, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to respective sets of objects.
23. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an automation database including an action table that identifies server processes for processing actions taken on the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set by generating event notifications indicating that an event has occurred,
D. an event processor, in communication with the event generator, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
24. A system according to claim 23, wherein A. the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
B. the event generator selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on the event table.
25. A system according to claim 24, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
26. A system according to claim 25, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
27. A system according to claim 26, wherein the event processor comprises
A. an immediate event processor, in communication with the event generator and executing substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
28. A system according to claim 27, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
29. A system according to claim 27, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
30. A system for automated order processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects, C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
D. an event processor, in communication with the event generator and with the automation database, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
31. A method for automated transaction processing, comprising the steps of
A. storing a set of one or more transaction objects pertaining to a business transaction,
B. selectively responding to a change in the information stored therein by generating an event notification indicating that an event has occurred, and
C. responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain.
32. A method for automated order processing, comprising
A. storing a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction, B. responding to a change in information stored in any of the objects for generating event notification identifying the change and the objects in which it occurred,
C. responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction.
33. A method for order automation comprising
A. executing on a digital data processor a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. responding to such a change by generating an event notification identifying the change and the object in which it occurred,
C. responding to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
D. responding to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
34. A method for automated transaction processing, comprising
A. storing a set of one or more transaction objects containing information pertaining to a business transaction,
B. identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects,
C. selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
D. responding to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
35. A method for automated transaction processing, comprising
A. storing a set of one or more transaction objects containing reflecting pertaining to a business transaction, B. providing an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. selectively responding to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred,
D. responding to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
40. A method for automated transaction processing, comprising
A. storing a set of one or more transaction objects reflecting information pertaining to a business transaction,
B. providing an automation database including an action table that identifies server processes for processing actions taken on the set of objects,
C. selectively responding to changes in information stored in the set by generating event notifications indicating that an event has occurred,
D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process for processing such action and signaling that server process thereof.
36. A method for automated order processing, comprising A. storing a set of one or more transaction objects reflecting information pertaining to a business transaction, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory method interface for order fulfillment, (iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory method and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. providing an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, " ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
C. selectively responding to changes in information stored in the set of objects rating event notifications indicating at least that an event has occurred with respect bject, such selective response being made based at least in part on the event table, D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
ACTION SERVER AND RELATED METHODS ASPECTS
1. A system for automated transaction processing, comprising an action server that executes actions specified by an action object, the action object specifying one or more actions to be executed in connection a business transaction to which a set of one or more transaction objects pertain, the action object having been generated in response to a change in information stored in one of the transaction objects.
2. A system according to claim 1, wherein the set of transaction objects include any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
3. A system according to claim 1, wherein the action server executes an action that any of accesses and updates information in any of the objects in the set.
4. A system according to claim 1, comprising one or more action servers.
5. A system according to claim 4, wherein the action servers comprise
A. a function server that executes actions affecting a transaction object the change in which resulted in creation of that action object, and
B. a transaction server that executes one or more actions comprising a transaction and that affects any of (i) a transaction object the change in which resulted in creation of that action object and (ii) one or more other objects.
6. A system according to claim 5, wherein any of the function server and the transaction server executes the actions specified any of on or after a scheduled time.
7. A method for automated transaction processing, comprising the step of executing an action object specifying one or more actions to be executed in connection a business transaction to which a set of one or more transaction objects pertain, the action object having been generated in response to a change in information stored in one of the transaction objects.
8. A method according to claim 7, wherein the set of transaction objects include any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment, (iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
9. A method according to claim 7, wherein the executing step includes executing an action that any of accesses and updates information in any of the transaction objects.
10. A method- according to claim 7, wherein the executing step includes selectively
A. a function server step for executing actions affecting a transaction object the change in which resulted in creation of that action object, and
B. a transaction server step for executing one or more actions comprising a transaction and that affects any of (i) a transaction object the change in which resulted in creation of that action object and (ii) one or more other objects.
11. A method according to claim 10, wherein any of the function server step and the transaction server step includes the step of executing actions specified any of on or after a scheduled time. These and other aspects of the invention are evident in the drawings and in the description that follows.
Brief Description of the Drawings
A further understanding of the invention may be attained by reference to the drawings, in which:
Figure 1 depicts the software architecture and data flow for immediate event processing in an automated order processing system according to the invention;
Figure 2 depicts the software architecture and data flow for immediate and delayed event processing in an automated order processing system according to the invention;
Figure 3 depicts further details of a software architecture and data flow for delayed event processing in an automated order processing system according to the invention;
Figure 4 depicts an automation database in a system for automated order processing system according to the invention;
> Figure 5 pertains to the overall design of an order automation system acc rding to the invention;
Figures 6 - 7 provide an overview of an automated order processing system according to the invention;
Figures 8 - 13 pertain to delayed event processing in an automated order processing system according to the invention;
Figures 14 - 21 pertain to a user interface for use with an automated order processing system according to the invention;
Figures 22 - 25 pertain to order automation definition in a system in an automated order processing system according to the invention;
Figures 26 - 29 pertain to automation event definition in a system for automated order processing system according to the invention;
Figures 30 - 33 pertain to automation action definition in a system for automated order processing system according to the invention; and
Figures 33 - 35 pertain to the action servers definition in a system for automated order processing system according to the invention; Detailed Description of the Illustrated Embodiment
Figure 1 depicts an automated order processing system 10 according to the invention for immediate event processing. The system includes a workstation 12 or other device for entry of commands and/or data by a user, e.g., an order entry clerk. In a preferred embodiment, plural such workstations 12 or other entry devices are provided. The remaining elements illustrated in the drawing, i.e.., elements 14 - 28, may be executed (in the case of process elements) or stored (in the case of data elements) on workstation 12 or other digital data processing systems to which the workstation is coupled, e.g., via modem, LAN, WAN or otherwise.
Commands and/or data entered by the user(s) are received by user interface 14, which facilitates entry of information regarding a transaction, such as a customer order or other business transaction, by displaying screens, questions or other indicia to prompt the user. Interface 14 responds to user input by creating and/or modifying an order object 16 for each transaction.
The order object 16 retains status and other information about a transaction. In other embodiments of the invention, the order object 16 is one of set of objects used to represent each transaction. In a preferred embodiment, the additional objects include an delivery memo object, an invoice object, and billing memo object, expected shipment transaction object, shipping memo object, reservation object, reservation memo object, invoice memo object, and an invoice generator object. Still other embodiments may use a subset or superset of a combination of these. The order object, in these embodiments, is principally tied to the order-taking function or order-taking site (e.g., workstation 12) and is the principal construct representing the transaction. The invoice object stores information pertaining the invoicing function or site and, more generally, to financial liability owed to or owed from a trading partner. The expected shipment object stores information pertaining to inventory and shipping functions or sites. The billing memo object serves as an interface between these various functions or sites, particularly, for example, between an order taking site and the invoicing site.
In the illustrated embodiment, the object 16 comprises an instantiation of a class defined in an object oriented programming (OOP) language. Accordingly, the object 16 includes not only such information, but also methods tailored to act on that information. Those skilled in the art will appreciate that other constructs, such as records, arrays, and linked lists, may be utilized instead of OOP objects to store information regarding the transactions. In such embodiments, subroutines, functions or other independent code sequences define the methods that act on the information.
In the embodiment of Figure 1, the order object 16 retains conventional information required for order processing, such as customer name, shipping address, item i.d., quantity ordered, and so forth. The order object 16 additionally includes an order identification that uniquely identifies the object and, thereby, distinguishes it from the order objects for other transactions. The order object also includes an order automation definition identification (oad i.d.) that identifies the table (or other structure) defining the sequence of actions to be executed when events occur with respect to the object 16.
In practice, the system 10 contains tens, hundreds or thousands or order objects 16 - each reflecting the specifics of a corresponding transaction. Though each such object has a unique order i.d., many of them may contain the same oad i.d. As a consequence, if given event occurring with respect to two (or more) of those objects, will result in identical processing. Other order objects 16, on the other hand, may contain different oad i.d.'s and, consequently, may be subjected to different processing sequences as event occur with respect to them.
Methods contained in or otherwise associated with the order object 16, detect changes to the information contained in it. Those methods signal events whenever changes occur that require computational processing (e.g., changes that affect order pricing), that impact order handling (e:g., changes in delivery address), or that are otherwise substantive in nature. In the illustrated embodiment, this signaling is made by communicating to an event generator 18 the identification of the order object 16 with respect to which the event occurred, the identification of the order action definition associated with that order, the identification of the event, and type of source of the event.
The source type refers to the type of the object in which the event occurred. In the embodiment of Figure 1, that type is "order object." In embodiments where each transaction is represented by multiple objects, e.g., an order object, an expected shipment object, an invoice object, and billing memo object, the source identifier reflects the originating object accordingly. Event generator 18 determines whether an action is defined for each signaled event and, if so, generates an event object 20a or 20b memorializing the event. The determination is made by comparing the event information supplied by the order object 16 with an order automation definition maintained in order automation database 22. In the drawing, this is indicated by the passing of an event id, source type and oad id from event generator 18 to database 22 and the return of a Boolean indicating whether an action is so defined. In the case that an action is indeed defined by the order automation definition, an event object (or other data storage construct) is loaded with the id of the triggering object (e.g., the id of order object 16), order action definition id, event id, and source type for the event.
Figure 4 depicts the details of an order automation database 22 according to one practice of the invention. An order automation definition table 22a stores, for each oad id/event id pair, a source type, an action id, and an action sequence number. Each order automation is comprised of table 22a entries having the same oad id. In order to determine whether an action is defined for an event, the entries are compared with the oad id, event id and source type signaled by the order object 12. If one or more matching entries are found, an event object will be created as indicated above. The matching entry or entries are referenced, subsequently, by the event processor 24 to record the action id's and action sequence numbers.
The event generator 18 generates two types of event objects 20a, 20b, depending upon whether the actions demanded for the event is to be handled immediately (e.g., substantially synchronously with the underlying change) or can be delayed (e.g., asynchronously with respect to the change). This is referred to as the process type, which the event generator determines - based on the event id and source type - from the event definition table 22b in the order automation database 22.
Event objects 20a queued for immediate processing are passed to immediate event processor 24 for synchronous processing, as shown in Figure 1. Event objects 20b queued for delayed processing are stored to delayed event database 30, as shown in Figure 2, for asynchronous processing In addition, a notification of the delayed event is passed event generator 18 to delayed event processor 32.
Referring to the embodiment of Figure 1, an event object 20a queued for immediate processing is taken up by an event processor 24, which determines what actions necessary to handle the event. More particularly, the event processor 24 passes the event id, source type, and order action definition id to the order automation database 22. Since each event defined by an object 20 may necessitate several sequential actions, the event processor 24 passes a sequence number to the order automation database 22 as well. The order automation database 22 returns an identifier for an action to be taken, the server responsible for processing the action, and the arguments to be passed to the server. These return values are determined from the order automation definition and from an action table, which is also contained in the order automation database 22.
To prevent infinite loops due to the improper construction of an order automation definition by a user, the immediate event processor 24 imposes a maximum event count. This limits the number of events that may be triggered by a given order object 16 or by the other objects for the same underlying business transaction. By counting the number of events attributable to each object (or set of related objects), the immediate event processor can halt processing and signal an error whenever the count exceeds the preset maximum. In lieu of counting events at the immediate event processor, undesired looping can be prevented by counting them at the event generator as well.
Based on the order automation definition table 22a and the action definition table 22c, the immediate event processor 24 generates order action objects 26, or other such constructs, for each action necessitated by the event object 20. These action objects 26 identify the order upon which the action is to be taken (order id), as well the action to be taken, the server responsible for taking the action, and the arguments to be passed to the server.
The action objects 26 are queued to, or otherwise taken up by, the respective action servers 28. The action servers 28 execute code sequences implicated by the action objects 26 and update the identified objects (e.g., order objects 16) accordingly. As a result of those actions, further events may be generated by the order object 16 for processing as described above.
The action servers 28 preferably reside in the same process space as the user interface 14, event generator 18 and event processor 24, though they may operate in separate threads. Servers 28 whose actions can be processed substantially instantaneously and upon whose results the user can be expected to wait are typically processed in the thread in which the user interface 14, event generator 18 and event processor 24 are executed. This synchronous in-process mode of operation ensures that all processing on a current event will be completed before any further events are effected by the user.
Servers 28 whose actions may take somewhat longer to process can be executed in separately spawned threads. Asynchronous processing of the action objects by these servers is beneficial for handling events, such as pricing, that might take a short period (e.g., several seconds) to process. When processing is complete, these asynchronous in-process servers notify the user interface 14 so that its displays can be updated.
Referring to Figure 3, delayed event processor 32 generally processes delayed event objects 20b in a manner similar to that described above for immediate event objects 20a. Unlike the immediate event processor, the delayed event processor 32 is typically assigned to operate in a different process space and, possibly, on a different digital data processor, from the user interface 14 and the event generator 18. Thus, processing by the delayed event processor 32 (and the action servers invoked thereby) is said to be substantially asynchronous with respect to occurrence of the underlying events.
Delayed event processor 32 utilizes the order automation database 22 (and, specifically, the order automation definition table 22a and the action definition table 22c) to determine what actions are necessary to handle each event. More particularly, the delayed event processor 32 passes the event id, source type, and order action definition id to the order automation database 22 in a manner similar to that describe above. The order automation database 22 likewise returns an identifier for an action to be taken, the server responsible for processing the action, and the arguments to be passed to the server.
The delayed event processor 32 gains access to the triggering object (e.g., the order object 16 or one of the corresponding objects for the same transaction) and passes its id to the action server identified by the database 22, along with the action id and the arguments. If the delayed event processor 32 cannot initially access the triggering object, it retries periodically until a maximum retry count is exceeded.
Unscheduled delayed events are processed by the delayed event processor 32 and passed to the corresponding action server as soon as possible. Scheduled delayed events are not passed to the action server until a specified time or, alternatively, are not processed by the action server until that time. An example of this is repricing, the actions for which are not executed, e.g., until a day before the order is scheduled to be shipped. Another example, is an automatic cancel order action that may be scheduled for execution a fixed number of days (e.g., 30 days) following issuance of a time-sensitive quote.
Action invocations by the delayed event processor 32 can be by way of action objects, as described above, or via any other notification mechanism. Two types of servers are utilized. So-called function servers 28 are utilized to in instances where the actions are to be executed on the object that triggered the original event, whereas transaction servers 34 are utilized to execute actions on the triggering object or any of the other objects for the same underlying transaction.
If a transaction server 34 cannot initially access a target object (e.g., an order object 16 or one of the objects pertaining to the same transaction), it can either signal an error or request that the delayed event processor 32 request retry. In the later instance, the delayed event processor 32 tries invocation of that server 34 a maximum number of times, e.g., as defined in the argument list or otherwise, before event processing is aborted and an error is signaled.
Error handling mechanisms retry actions effected by delayed event objects until a maximum retry count is exceeded. This insures that event processing is carried out to completion even if a triggering object or a related object cannot be accessed when the delayed action is first attempted. Further error handling is achieved upon startup of the delayed event processor 32, and periodically thereafter. Specifically, the delayed event processor 32 searches for triggering objects that have events ready to be processed and insures that events for them are recorded in the requisite queues. This ensures that failure of any notification mechanisms does not result in the loss of those events.
In the event of that an event cannot be processed, e.g., after repeated retries by the delayed event processor, a flag (e.g., an automation error flag) can be set on the object that triggered the object to prevent any further attempts to execute events with respect to it. The error can also be recorded to an object (e.g., a persistent error object) that is subsequently used to report the occurrence to the user. Until the automation error flag is reset or removed by the user, the triggering objects remains in its failed state, thereby, facilitating identification and correction of fault by the user. Once the user takes corrective action, the event that caused the error can be requeued to the delayed event processor for handling. Like the immediate event processor 24, the delayed event processor 32 can prevent infinite loops resulting from improper order automation definitions by imposing a maximum event count. This limits the number of events that may be triggered by a given order object 16 or by the other objects for the same underlying business transaction. By counting the number of events attributable to each object (or set of related objects), the delayed event processor can halt processing and signal an error whenever the count exceeds the preset maximum. Those skilled in the art will appreciate that, in lieu of counting events at the immediate event processor, undesired looping can be prevented by counting them at the event generator as well.
A more complete understanding of the invention may be attained by the discussion that follows, in which "COM" refers to customer order management and, more generally, to an embodiment of a customizable order automation system according to the invention, and in which Protean refers to a digital data processing system in which such a customizable order automation system can be incorporated.
Section I - COM Order Automation Processing Design
\_. Introduction
The purpose of this Section is to introduce and explain the roles and relationships of the various objects that are being designed to implement the Order Automation functionality of Protean COM.
Order Automation is effectively the "glue" that holds order processing together. When a triggering condition is met during the course of order processing on any of the Protean COM related application objects (the Order object, the Demand Memo object (for Expected Shipments), the Billing Memo object, the Invoice object, the Reservation Memo or the Shipping Memo), an order event is generated. This event may or may not be pertinent for this particular order being processed. If the event is pertinent, the event will be "processed", which means one or more Order Actions will be invoked that will carry out the necessary application behavior associated with this event. That application behavior can include the following:
1. updating the object that originally triggered the event; 2. updating (or creating or deleting) one or more of the other objects in the group of four application objects that model order processing behavior (i.e. the Order, the Billing Memo, the Expected Shipment, or the Invoice);
3. generating a Document via the Document Messenger Action Server;
4. executing customer designed MS-COM automation servers that are tied into this processing via the Order Automation Definition.
There is an important distinction between the definitional elements of Order Automation and the runtime elements of Order Automation. This Section focuses on the latter. Please refer elswhere for discussion of Order Automation definitional elements.
Likewise, there is an important distinction between immediate events and delayed events. Immediate events are to be processed synchronously, in the order they were generated, in the same session as the object that generated the event. Immediate events are generally also processed in the same process space as the generating object, for performance reasons; however, the action servers invoked by event processing can be out-of-process servers. The delayed events will also be "processed" in the same session, but that processing will be limited to writing them out to a database for additional processing (by the Delayed Event Processor) at a later time (i.e. after the current user session that generated the event has ended), and quite possibly on a separate application server workstation. The actions associated with these delayed events can't be processed until the current user session that generated the event has terminated, since the user session has the generating object locked and the delayed event may need to modify the generating object.
As long as we're making distinctions here, we should note the difference between system events and user events. User Events are defined as traditional Protean IPKs, and can have a set of Order Actions associated with them on the Order Automation Definition IPK. Customers can choose whether or not to recognize a User Event in their Order Automation Definition and can also define their own unique set of Order Actions that are executed in response to User Events. System Events, on the other hand, are those events that we as the Protean COM developers are using to guarantee consistent behavior between the various COM application objects. The behavior of a User Event may vary; the behavior of a System Event will not vary. Though the term "System Event" would imply an object with different attributes and behavior than a User Event, System Events are, in fact, hardcoded processing logic. System events are always delayed events, in order to allow the system event to keep multiple application objects in synch within one database transaction.
The same distinction applies between System Actions and User Actions, in that User Actions are defined as traditional Protean IPK instances and System Actions are effectively hardcoded logic, which is implemented in action specific update servers.
Actions are further divided into Functions and Transactions. Functions could be considered to be "simple" actions, in that they can only modify the object that triggered the original event.
Functions cannot have any requirement for consistency with other objects. Functions always assume that the object upon which they are acting (i.e. the generating object) is opened for change. They do not call lifecycle methods (i.e. save or close) on the the generating object. Function actions can be associated with both immediate and delayed events. Transaction Actions, on the other hand, are more complex actions. They can only be associated with delayed events. Transaction actions are required when consistency between objects is necessary.
1.1 Focus of this Section.
This Section will be focusing on the following:
• the details of event generation;
• the actual event object; immediate event processing; and
• the first phase of delayed event processing, i.e. the generation of delayed events and their -subsequent persistence to the database.
2. Design Overview
The diagram in Figure 5 shows the basic flow of processing a generated event. This processing involves both immediate events and the persistence of delayed events. This diagram depicts the complete process for immediate events and the first of two processing phases of delayed events. It is significant to note that only the Protean Order object may generate immediate events. The three other Protean app objects involved in order automation can only generate delayed events, whereas the Order can generate both immediate and delayed events. The first phase of delayed event processing is to save them to the database to allow for true "processing" at a later time. The order actions associated with delayed events are truly delayed, in that they are executed in a different time frame than that of the generating object. This second phase of delayed event processing is explained in the Protean COM Delayed Order Automation Processing design.
Each step in the diagram is explained in detail below.
All error processing on immediate events will be in-memory, i.e. we will not be generating persistent errors from immediate event processing.
The discussion frequently refers to the triggering object generating an event. However, it is actually the Event Generator (EG) that is generating the event. The triggering object calls API on the to do the event generation. The EG may decide NOT to generate the event. In any place where you see a reference to the triggering object generating an event, remember that the triggering object is asking the EG to determine if an event needs to be generated and to then it is actually the EG that generates the actual event.
2.1 Event Processing Flow
2.1.1 Processing Immediate Events
2.1.1.1 Step l
In the normal course of order processing, as values change, an in-memory event can be generated. An in-memory event is an instance of an automation server; it is not a Protean application object. Any Protean COM business object that can generate order events will use the services of an Event Generator (EG) object to generate the actual event. The EG is a C++, dtCore derived object that encapsulates access to the Event Processor automation server. Each app object that needs to generate Order Automation events must contain a EG attribute (or a pointer to an EG (implementation detail). The EG will also have Automation wrapper methods exposed so that third parties can call its APIs. By making the EG a C++ object, we are improving the access time that the app object will take in order to generate events. The EG, then, is effectively the bridge between Protean app objects and the MS- COM Event Processor automation server.
The diagram shows a "Triggering Condition" inside the Protean COM Order object. This triggering condition is effectively a state change that is detected on any of the six COM application objects that can generate an event (i.e. the Order, the Billing Memo, the Invoice, the Demand Memo, the Reservation Memo or the Shipping Memo). Only the Order can generate immediate events; the other objects can only generate delayed events.
The in-memory event may be either an immediate event or a delayed event, and will be processed accordingly by the Immediate Event Processor (IEP).
Each triggering application object will use the services of an Event Generator (EG). Each EG will use the services of an Event Processor automation server. The EG owns the EP, and is therefore responsible for creating and initializing the EP and, ultimately, for deleting the EP. Therefore, there is one EG and one EP per triggering object.
2.1.1.2 Step 2
The COM application object(s) will always try to generate an event when a triggering condition is met. System Events will always be generated. The generation of Custom Events is conditional upon whether that event is defined on the corresponding Order Automation Definition and also if the event is defined for the triggering source. The EG is responsible for ensuring that this event to-be-generated is in fact listed on the Order Automation Definition object as an event for which we want to do order automation processing. If the event is not contained in the collection of Order Event Definitions on the Order Automation Definition object, then we don't need to generate an event, and so we are done.
In some situations where the generation of an event would lead to a duplicate event on the event queue, the EG will just return success, but not actually generate a duplicate.
2.1.1.3 Step 3
If the event is contained on the Order Automation Definition, then the EG generates an Event.
2.1.1.4 Step 4
The EG will add the in-memory event to the appropriate queue on the JEP. The JEP is an in- process automation server that will contain two collections of in-memory events, one for immediate events and one for delayed events.
If this was a delayed event, the IEP will simply add the event to its collection of delayed events to wait to save it to the database as part of the save operation on the object that generated the event. We are now done processing this delayed event (for now, until Step 12). If this is an immediate event, and if the IEP is not currently processing an event, it will retrieve the immediate event from the queue and begin processing. The IEP is only ever concerned with processing immediate events. The Event will contain enough information on it that will allow the IEP to complete its processing. For example, the Event will have the IDispatch* to the Order Automation Definition object.
If the IEP is currently processing an event, that means the event being added is a "cascaded" event, i.e. an event that was generated from processing the actions associated with some previously generated event.
As an example of cascaded events, consider the following scenario: Event Action OrderQtyUpdate 1) PriceDelivery
2) CheckAvailability
3) UpdateOrderStatus UnitPriceUpdate 1) CreditCheck
The action PriceDelivery updates the Delivery price attribute, and in so doing, generates the UnitPriceUpdate event as a cascaded immediate event. In this situation, the IEP will just add the cascaded event to the appropriate in-memory queue of events and will return to the caller, effectively allowing the IEP to continue to process the current event. This cascaded event will be processed in the order of generation, after the current event processing has completed.
2.1.1.5 Step 5
The IEP will refer to the Order Automation Definition server to get information about the Order
Actions associated with this event and also to determine if a particular action is appropriate at the site where the event was generated.
Since an event can be generated at multiple sites, and since the actions associated with the event vary by site, the IEP will ensure that this action is appropriate for this event source. If so, processing continues. If not, we're done with this step and we skip to Step 9 to look at any other Order Action Definitions in the collection for this event. 2.1.1.6 Step 6
Using the Order Action Definition UK, the IEP will instantiate the Order Action Definition object and obtain the ProgID of the corresponding Order Action Server.
Before proceeding with executing the Action, the IEP has to check the Action Definition object to verify that the Action is defined as "Active". It is possible for users to shut an action on or off by setting the Active/Inactive flag on the Action Definition IPK. This flag allows users to dynamically swap actions in and out of an Order Automation Definition.
The JEP will also obtain the list of additional arguments (as defined on the Order Action Definition) and use that along with the other attributes of the original generated event to create the Action Arguments object, yet another in-process automation object (not shown in the diagram in the interest of not adding too much clutter to an already cluttered diagram).
2.1.1.7 Step 7
Using the ProgID of the Order Action Server, the IEP will use the MS-COM function to get the ClassLD from the ProgID (the ClassID being a GUID, and the ProgID being a user intelligible string).
Using the ClassID, the JEP will load the Order Action Server, passing the IDispatch pointer of the Action Arguments object, and will invoke the appropriate method on it that will carry out the required order automation behavior.
The "appropriate method" will be programmatically determined by the JEP, based upon the generating object and the event source. Each Order Action Server will be required to support a standard set of interfaces in order to implement this functionality.
2.1.1.8 Step 8
By virtue of invoking the action method on the Order Action Server, the Action Server will take the appropriate action on triggering business objects.
For immediate events, which can only occur on the Order, this behavior can only involve updating the original triggering object. This behavior is guaranteed by the Event Source attributes on the Event Definition IPK and the Action Definition IPK. If a customer were to erroneously attach an action that updates the Expected Shipment to an Event that can only be generated at the Ordering site, that action would never even get invoked, as actions are only invoked if they are defined at the site of the triggering object. By virtue of updating the triggering object, the action can lead to the generation of other events, which would be added to the IEP's queue of events (either delayed or immediate). The JEP will process the immediate events in the queue in order of generation and will write the delayed events to the database in the order of generation.
For those situations where a generated event can lead to an action that updates a business object other than the generating object, we will have to define those events as delayed and the actions associated with that event as transaction servers (see details in the Protean COM Delayed Order Automation Processing design). We are doing this for a variety of reasons:
• shorter transactions;
• better performance; better scalability;
• this reduces the complexity of the application code, as it can be problematic in the Protean Framework to have one application object manage the lifecycle of another application object.
If this is a custom action, it is possible that it would not be updating the original triggering object, but rather some non-Protean object in the customer's system environment.
2.1.1.9 Step 9
The IEP will continue to loop through the collection of Order Action Definitions on the Order
Automation Definition object, executing Steps 7 through 9 for each action, after determining if the action is pertinent to the event source of the event.
Once all pertinent actions have been invoked for the generated event, the processing for this event is complete and the IEP will now remove the immediate event from its queue and also from memory.
2.1.1.10 Step 10
The IEP will continue to loop through its internal queue of immediate events. Since we are guaranteeing synchronous processing for the first version of Order Automation, the only events on the queue could be those events that were generated as a result of processing the original event (i.e. cascaded events).
2.1.1.11 Step 11
Event processing is completed when the triggering event and all of its cascaded immediate events have been processed, and control returns to the application object that triggered the first event. The app object will have been waiting for that processing to complete, and will receive an erError object back from the initial method call that will indicate the status of event processing.
At some point, this app object will be saved and closed. For objects that are accessed via the UI, saving and closing can be two separate user steps at separate times, or they can both be initiated from one user action. Regardless of how they are initiated, we need to treat each differently. Step 11 occurs as the app object is saved.
As the original generating object is saved, its postSave() lifecycle hook method should always call saveDelayedEvents() on the Event Generator. This will ensure that the delayed events are only written to the database if the actual generating object has been successfully saved. After saving, the delayed events should be removed from the delayed event queue.
This will handle the circumstance where the app object might be changed (therefore events generated), then saved, then changed, then saved, etc.
2.1.1.12 Step 12
The EG calls saveDelayedEvents on the IEP.
We are having the triggering object call saveDelayedEvents on the EG, which then calls the same named method on the IEP because we only want the app objects to know about the EG. In other words, all event related processing that an app object must do can be done through API on the EG.
2.1.1.13 Step 13
The IEP has been maintaining a collection of delayed events that were generated by either the original generating object or any of its subsequent Order Actions.
When saveDelayedEvents() is called, the IEP will loop through its collection of delayed events and for each will construct an IPK that it will save to the database. To optimize access to the AppLock table in the database, we will be using the new saveAndCloseO method defined on IPKs. This minimizes contention on the AppLock table that can result from separate calls to the save() and close() lifecycle methods. The first version of a delayed event then is an in-memory instance of the automated event object (not a Protean app object); the second version of a delayed event is a persistent Protean app object.
2.1.1.14 Step 14
As the generating object is closing, the postClose() lifecycle hook should call a method on the EG (once again, all event related work will be done by the EG) to initiate notifying the Delayed Event Processor (DEP) if any delayed events were saved that could now be processed.
We want the DEP to kick in only after we know the triggering object has been closed. The preClose() hook would therefore not be sufficient, so this requirement led to the Framework enhancement request to add a postClose lifecycle hook.
2.1.1.15 Step 15
The EG will send the same notification message to the IEP, which should check to see if delayed events were ever saved to the database. If not, you're done. If so, a message is sent to the Delayed Event Processor to inform it that it should wake up and process these delayed events. We wait to notify the DEP until the object is closed, because the DEP needs to open the original triggering object in order to process the delayed events. We don't want to send this message to the DEP on postSaveQ, because save does not necessarily imply close. We wait until the object is closed so the DEP has a greater chance of being able to open the triggering object. The intent is to transfer control of processing to the DEP from the active user session that generated delayed events.
2.1.1.16 Step 16
The IEP notifies the DEP that delayed events were saved. This signals that delayed event processing can begin for the triggering object.
3. In-Memorv Event Object Design Details
The in-memory Event will be generated by the Event Generator and will be added to either the immediate or delayed queue on the Immediate Event Processor.
The Event object does not need to be an MS-COM automation server, since we will not be remoting it (i.e. running it on a separate workstation or server), nor will a third party have to call its APIs. However, the JEP needs to access this object, therefore it will need Automation wrapper methods, since the IEP is an Automation server, and once we make the transition into Automation method calls, we don't want to be switching back and forth between Automation calls and regular C++ calls.
The Event is a very simple object whose main purpose is to capture identifying information about the processing required to fulfill the triggering condition that generated it. The Event has several attributes and very little behavior, other than to set and get the values of the attributes.
If necessary, we may decide at implementation time to have a slightly different structure for the immediate in-memory event and the delayed in-memory event. It is also possible that the additional design work on delayed event processing might indicate the need for some additional API on the event.
3.1 Event API
The only necessary APIs on this object will be to set and get the attributes.
3.2 Event Attributes
1. Event ID
Corresponds to the 32bit unsigned integer on the Event Definition IPK. Application code that generates events will do so using the corresponding enum string value for the integer.
The Event Generator will use the enum to see if this Event is defined on the Order
Automation Definition (OAD). This would be provided by the triggering object.
2. Event UK
For non-system events, the Event UK (to the persisted Event Definition IPK) will be included on the in-memory event for future reference. This attribute would not be available for a system event. This would be retrieved from the OAD by the EG.
3. IDispatch* of OLE wrapper class of generating object
We need the wrapper class and NOT the manager class because, for immediate event processing, we want the ability to call semantic methods and not lifecycle methods on the generating object. Details for delayed events are still in design, but this could be one of the differences between the immediate and delayed in-memory events.
For delayed events, the attributes on this in-memory event may need some slight modification in order to persist the delayed event. For example, we cannot persist an
IDispatch pointer. Instead, we would turn the IDispatch pointer into a UK reference, in order to identify the object in subsequent delayed event processing.
4. Order UK
Each generating object will have the UK of the Order to which it is related. This could be potentially redundant for immediate events, which can only be generated by the Order, therefore, this attribute might only be on in-memory delayed events. This would be provided by the triggering object.
5. Order line number
Each generating object must know the Order line number to which it is related. This would be provided by the triggering object.
6. Delivery line number
Each generating object must know the Delivery line number to which it is related. This would be provided by the triggering object.
7. Event Source
This will be an enum indicating the site within which the event was generated (i.e. Ordering, Invoicing, Shipping, Other. The event source is significant since the same event can be generated at multiple sites, but might require different actions at different sites. This attribute will be used to determine which actions are required to be executed when processing the event. This would be provided by the triggering object.
8. System event flag (yes or no)
System events are always processed delayed, but we need to distinguish between system events and delayed user events. System events are always generated when their corresponding triggering conditions are detected. System events are not included on the Order Automation Definition (OAD), as the customer cannot customize their behavior, nor can they choose not to recognize these events. This would be provided by the EG, because the triggering object calls a specific API on the EG (generateSystemEvent) when creating system events. 9. Delayed event flag (yes or no)
Determines the queue on which the event will be placed. This would be provided by the EG object. The EG determines this information from the OAD.
10. Scheduled event flag (yes or no)
Scheduled events are always processed delayed but are treated differently by the DEP, so we need the flag to inform the DEP if this is scheduled or not. This would be provided by the EG, because the triggering object calls a specific API on the EG (generateScheduledEvent) when creating system events. For COM FCS, we are not defining any scheduled events. Scheduled Events could be generated by custom actions.
11. time (if scheduled)
Determines the time after which a scheduled event may be processed. At the time of this writing, no Marcam supplied events are scheduled events. This feature is being designed for customization purposes only, and further details are provided in the Protean COM Delayed Event Processing design. This could only be provided by the triggering object, as the time value will probably vary with each scheduled event generated.
4. Event Generator Design Details
The Event Generator will be a dtCore derived, C++ object with a corresponding Automation wrapper object with exposed Automation methods.
The EG will be contained by each app object that needs to generate Order Automation events. A third party (e.g. custom action servers) will need the ability to call the EG's APIs, but this can be done through the Automation wrapper class and its methods. Protean app objects can only generate events when they are either in a new state (i.e. newly created and not yet saved) or if they have been opened for change. Events are generated as a result of a state transition on an attribute, and that can't happen during an open for review.
The main purpose of the EG is to generate Protean COM Order Automation events and to initiate further processing of the generated events. All event related behavior will be processed via the EG. Essentially, any time a Protean COM object needs to generate an event, remove a delayed event that is no longer applicable, save delayed events, or initiate the processing of delayed events, they will do so via the services of the EG. The EG is the only object that a Protean app object needs to know about in order to deal with Protean COM Order Automation events. One design alternative was to combine the EG and the IEP into one object. This was decided against since it makes sense that we may want the option to configure the EG as an in-process server and the IEP as a remote server. Consequently, the EG provides wrapper methods for much of the IEP's behavior in order to encapsulate all services that Protean objects will need to know into one object.
When a triggering condition is detected on the app object, it will always try to generate an event, because the app object doesn't always know if the event is pertinent in every circumstance. The EG will determine that. To do so, it must consider the following: system events are always generated. They are not defined on the OAD, and are therefore always generated and always executed (albeit delayed);
• (for user (i.e. non-system) events), the event to be generated must be defined on the OAD for this event source. The EG then must refer to the list of Event subordinates on the OAD and if it finds the Event subordinate that corresponds to this event, it must verify that the event is defined for this event source; if the event to be generated already exists on one of the IEP's event queues, then the event is not generated. Managing the generation of duplicate events is discussed elsewhere in this Section.
Additionally, the generating object needs to be able to undo the generation of a delayed event. It is possible that a delayed event could be generated, not yet persisted, and then another user action (e.g. suspending a Delivery Line) makes that event no longer applicable. The EG will need to provide APIs to the generating application objects to allow them to remove or un-do the generation of delayed events.
In spite of the fact that the EG does most of the event generation work, the application object will still need to know a fair amount of information about the events which it intends to generate, in order to call the correct APIs on the EG, including: the enum value that identifies the event;
• whether the event is system or scheduled; whether it needs to attempt to undo the generation of a previously generated event. Additional services that the EG must provide to generating application objects include the ability to persist the delayed events and the ability to notify the Delayed Event Processor that delayed events have been persisted and require processing.
4.1 Event Generator API and Behavior generateEvent()
This method will be used by a triggering object to generate an user (i.e. non-system) event. The EG can determine whether the event is immediate or delayed by retrieving that information from the GAD. The EG will confirm with the OAD that the event in question is one that the customer has identified on the OAD. An in-memory event object will be created, populated and added to the Immediate Event Processor's appropriate event queue.
We are distinguishing the generation of regular events, system and scheduled events with specific APIs due to potential differences in the attributes of the in-memory events to be generated here and also to re-enforce the different behavior of these events. Since these APIs will be accessible via Automation, three similar but different methods will alert the third party user to the different behavior. generateSystemEvent()
System events are delayed events and will be added to the IEP's delayed event queue. However, system events are not IPKs, they are not defined on the OAD, they can not be conditionally generated, they are always generated. Protean code can call this method; third party action servers should not call this API. generateScheduledEvent()
As with non-scheduled delayed events, the EG will confirm with the GAD that the event in question is one that the customer has identified on the OAD. An in-memory event object will be created, populated and added to the Immediate Event Processor's delayed event queue.
However, scheduled events are delayed events that have the additional feature of being time dependent. A scheduled event cannot execute until after a certain date/time. While more details about scheduled events will be provided in the Protean COM Delayed Order Automation Processing design, we mention them here since they will be generated much like other delayed events. The major difference between scheduled events and non- scheduled events is that a scheduled event contains a date/time attribute indicating the point after which the event can be processed.
• removeDelayedEvent(), removeSystemEvent(), removeScheduledEvent() The generating object needs to have the ability to retract a previously generated delayed event that has yet to be persisted. The details behind this are particular to each application object that can generate events. For example, the removal or suspension of Delivery Line on an Order should result in the removal of all delayed events generated but not yet persisted for that Delivery Line.
We might need several methods to implement this behavior. Essentially, each will search the delayed event queue and remove the event in question. How to identify the event to be removed is the question. Once again, the details behind this are particular to each application object.
• saveDelayedEvents()
This method will loop thru the collection of delayed in-memory events and create a persistent IPK version of each one and save it in the database.
Each application object that can generate delayed events will need to call this method as part of its save lifecycle processing. There are two possible save lifecycle hooks where we may call this method, dependent upon database re-try capability support in Framework (see Issue #2).
We do not persist the delayed events until the original generating object itself has saved, in order to guarantee inter-object consistency, i.e. we wouldn't want to save the delayed events until we know the generating object has successfully saved. notifyDEPO
This method will inform the Delayed Event Processor that delayed events have been persisted and that they require processing.
Each application object that can generate delayed events will need to call this method as part of its close lifecycle processing.
We do not notify the DEP about the delayed events to be processed until the generating object itself has closed, since the DEP will need to open the generating object and since we want to minimize write contention. Details about this behavior will be provided in the Protean COM Delayed Order Automation Processing design
4.2 Event Generator attributes
The Event Generator will contain a UK reference to the Order Automation Definition. Other than that, it may need to contain some state flags. The necessity of the state flags will be decided upon at implementation time.
5. Immediate Event Processor Design Details
The Immediate Event Processor will be an MS COM Automation Server because it may be useful to execute it remotely in some customer configurations. However, Protean objects and third party code should always interact with the TEP via the EG for consistency's sake. Considering that it is an Automation Server, a third party could interact directly with it, but they would then need to mimic some of the behavior of the EG. There are differing thoughts as to whether this would be a good idea. It is the author's opinion that this is a bad idea; third parties should be encouraged to always generate events thru the EG's services. However, making the EP an automation server doesn't preclude third parties from interacting with the EP directly.
The IEP will contain two in-memory queues, one for immediate events and one for delayed events. The IEP will process immediate events and delayed events as described in detail elsewhere in this Section.
The delayed event processing that the IEP does is a matter of maintaining a queue of in-memory delayed events and persisting each event at save time.
The immediate event processing that the IEP does is more complex. The error handling for immediate event processing is described elsewhere in this Section. The basic immediate event processing is as follows:
• in order to process an event, the IEP will refer to the corresponding
Order Automation Definition to get the list of Order Actions associated with the event. The GAD contains an Action subordinate object that points to the actual Action IPK, along with an indicator if the Action is defined for the event source within which the event was generated. For each action on the list, the IEP will first determine if the action is pertinent for the event source. If so, the IEP will open the Action definition in order to get more information to perform the action. If not, we will skip to the next action; • the IEP opens the Action IPK to retrieve additional information. From the Action IPK, we get the following attributes:
• the ProgID of the Action server, which must be defined in the Registry on any workstation that wants to execute this action;
• the Invocation Mode indicator, which determines if the IEP should use a currently active Action server to execute this action or always start a new server;
• the optional Action Arguments attribute, which can be used to determine which method to invoke on the Action server; the Active flag, which indicates if this Action is considered to be Active or Inactive. Users may de-activate an action, which would effectively turn the action off as far as Order Automation processing goes.
• the IEP will build an Action Arguments object with information on the in-memory event and also the additional arguments defined on the Action definition;
• the IEP either instantiates a new action server or uses an existing action server, based upon the Invocation Mode indicator, and then invokes a method on the server, passing in the Action Arguments object. The IEP will programmatically determine which method to call on the Action Server.
That process is followed for each action on each immediate event. Once all actions for an event have been successfully processed, the event is done, the JEP removes the event from the immediate event queue and from memory. Then, the IEP retrieves the next immediate event and processes its actions as described above.
5.1 The Generation of Duplicate Events
Given that the Order Automation Processing objects provide a framework within which a user may customize their order processing, it is entirely possible that a user could create a situation where duplicate events could be generated and infinite loops could result. Even if an infinite loop did not occur, the generation of duplicate events should be avoided due to additional and unnecessary processing time.
If an event is generated (either immediate or delayed) and that event is already on the immediate or delayed event queue, the Immediate Event Processor method that adds to the queue should just return success without actually adding the event. Due to the synchronous nature of immediate event processing, we can be assured that the immediate events will be processed sequentially, without user intervention, until all immediate events are processed, or until an error has been detected and returned. Any single immediate event should only be executed once in response to a triggering condition.
For delayed events, we are not completely guaranteeing that we will not be generating duplicates for FCS. Remember that delayed events are persisted after each save of the triggering object. It could be possible that delayed events were generated, persisted (and therefore removed from the in-memory queue) and then perhaps generated again. The subsequent generation would check the in-memory queue only to see if the delayed event had already been generated. Since it was no longer on the queue, it would be generated and persisted again, and therefore you could wind up with duplicate delayed events. While this is not desirable, neither should it be too harmful. It would lengthen processing time, but these are delayed events and processed in the background. This can be an optimization for a future release, but at this point it is not critical to prevent this from happening for FCS.
We will be implementing another application check to guarantee against infinite loops in event processing (both immediate and delayed). There will be a configurable count of events processed that a user may set for their own environment. If this count is exceeded, that will indicate that we are most likely in an infinite loop. For immediate processing, we need to guarantee that the user does not save the triggering object, and so our best choice is to throw an exception. For delayed events, we are in control and will be able to programmatically determine whether or not to save the triggering object.
5.2 Immediate Event Processor Error Handling
Immediate event processing will only generate in-memory errors. Delayed event processing, on the other hand, must persist its errors.
Immediate events are, more often than not, generated from app object's set methods, which by coding standards, return an erError object, which is used to return errors to the UI. The generatelmmediateEvents method that the app object calls on the EG will call addlmmediateEvent on the IEP. Any of the methods that the JEP calls as part of processing an immediate event should also return an erError.
The Order Actions are the atomic, logical units of work in Order Automation. When, in the course of processing the actions associated with immediate order automation events, an error is detected, we keep track of the error message(s) that were generated by that action, and go on to the next action for that immediate event. If any errors are detected on any of the actions, we return the error message to the user, but we do not undo the original triggering condition, nor any of the successful actions that may have occurred.
5.3 Immediate Event Processor API and Behavior
The APIs below are provided only to indicate required IEP behavior. It is entirely possible that they may change and that there may be others.
• AddlmmediateEventO
This method will be called by the EG's generateEvent method. It will add the generated event to the immediate event queue. For the first immediate event, this will trigger the processing of the immediate event. If adding additional immediate events (i.e. cascaded events), the event will simply be added and control will return to the caller.
This method will perform the processing outlined in Steps 5 through 10 of Figure 5. When processing is completed, the in-memory immediate event will be removed from the queue and from memory and control will be returned to the calling object.
• AddDelayedEvent()
This method will be called by the various EG methods that create delayed events (i.e. generateEvent, generateSystemEvent, and generateScheduledEvent). It will add the generated event to the delayed event queue and control will be returned to the caller.
• RemoveDelayedEvent()
This method will be called by the generating object in those situations where a delayed event may have been generated (and not yet saved) but subsequent application actions have made that delayed event no longer applicable.
It should be noted that the app object will have to be coded to always code this method, whether or not the delayed event really was generated. Consequently, this method can't fail it it does not find the delayed event in question. RtnlmmedEventO
The IEP will use this method to loop thru its collection of immediate events. RtnDelayedEventO
The JEP will use this method to loop thru its collection of delayed events.
• SaveDelayedEventsQ This method will loop thru the collection of delayed in-memory events and create a persistent IPK version of each one and save it in the database.
NotifyDEPO
This method will inform the DEP that delayed events have been persisted and that they require processing.
• HaveDeIayedEventsBeenPersisted()
Or some such name.... Basically, the IEP needs to be able to inform the triggering objects that delayed events have already been persisted, in the situation where the triggering object may need to undo the generation of those events (i.e. remove them from the database).
5.4 Immediate Event Processor Attributes
The IEP will contain the following attributes:
• in-memory collection of immediate events; in-memory collection of delayed events;
• flag to indicate whether delayed events were saved;
• a pointer to the Order Automation Definition currently in use.
Section II - Order Automation Overview
1. Design Overview
The elements of the order automation design are presented in Figure 6 . An overview of each of these elements, working from the left side of the page to the right, is presented in the following sections .
1.1 OLE Controllers
In general client/server terms this is usually known as the client object. In the evolving Microsoft terminology this is known as an OLE controller, or ActiveX controller. This is the object that is driving or demanding services from another object. Controllers can also be servers.
For purposes of this discussion, only objects outside of the order automation design are considered controllers. 1.1.1 Order Entry UI
One goal of the COM project is to provide all objects with an OLE Automation API. At this base level of support, a user interface for order entry can be constructed using a tool like Microsoft Visual Basic.
1.1.2 Automated Order Entry
A number of different examples of automated order entry exist, but perhaps the best known is EDI. Once the data mapping is performed by the EDI translation software, the order is entered into COM via the OLE automation API provided on the order object. The piece of logic embodied by this controller must take the output of the EDI translation and create the order, set appropriate attributes, save and close the order.
Other examples include maintaining an existing order by reporting usage and delivery confirmation through an automated process.
1.1.3 Invoice UI
The same course for the invoice user interface will be followed as mentioned above for order entry.
1.2 Order Automation Event Generation
A set of objects are responsible for the generation of order automation events. An event is generated based on order automation sensitive values, statuses, holds, or points in an object's lifecycle. The primary reason for generating an event is to allow an action to be tied to it.
There are two categories of events: system and user. All user events provided with the base product are made available through order event definition objects. System events cannot have user defined actions associated . System events are those events which are necessary to make the product operational, e.g., creating and updating an expected shipment object.
The update server is a generic example of a order action that responds to a system event.
1.2.1 Customer Order
This is the central object in COM as well as the object responsible for generating the most order automation events. The behavior of the customer order object can be modified by associating actions with events in an order automation definition. 1.2.2 Invoice
The invoice object represents the financial liability owed to or owed from a trading partner. As a side effect of an invoice being a read only object, there are only a few events generated by this object. Invoicing happens at the fmancials site. Posting an invoice to fmancials will place the transactions in a common format defined by the Open Applications Group' (OAG).
1.2.3 Enterprise Management Enabled Objects
There are two objects that support COM in its goal of being an enterprise application: the delivery memo and billing memo objects. These objects are not only important for their enterprise support, but also as primary integration points to other ERP vendors products.
For example, from COM's viewpoint, when integrated properly, there is no way of knowing if the inventory and shipping functions are being done by Protean or by another ERP vendor's product.
As far as being EM enabled is concerned, changes to these object will be replicated to remote databases.
1.2.3.1 Delivery Memo
This is the interface object between COM and the inventory and shipping functions. The creation of a delivery line on an order causes a corresponding delivery memo object to be created. Changes are replicated by the EM facility when the COM site and inventory site are in separate databases.
1.2.3.2 Billing Memo
This is the interface object between an order taking site and the invoicing site. Although we are providing both pieces, the reasoning here is that in many scenarios there is only one invoicing site, while there may be multiple order taking sites. This is a reflection that fmancials is usually done at one site, therefore the invoicing is also done at that site.
1.3 Order Automation Actions
These are the actions carried out in response to an event. Similar to events, there are two kinds of actions: system and user actions, Most of the design concerns itself with supporting user actions, which are those order action servers named by their corresponding order action definition object. These user actions can be incorporated into order automation definitions. Examples of user actions provided with the base product include: pricing, taxation, and discounting. The system can be extended in the field by adding new action definitions and servers.
A system action server is one that the delayed event processor (DEP) knows how to invoke. There are two specific types of system actions currently defined: an update server and the document messenger server. (Both are transaction servers).
1.3.1 Order Action Server
This is an OLE automation server which provides an order automation action compliant API.
An order action server has a corresponding Protean definition object, the order action definition. The order action server's API is invoked by the event processor.
Beyond providing a compliant API there are no other restrictions on the order action server. Typically the order action server will contain the specialized business logic to perform actions like complete an order or lock the price on a delivery line. In some eases, e.g., pricing, this order action server will do some front end preparation like gathering action specific data from the order object, contact another server to execute the action, and then update the order with the results.
1.3.2 Update Server
An update server is a specialized system action that is in place to handle the communication of changes between the order and the delivery memo or billing memo objects. The intent of these servers is twofold. First these allow us to break updates into more shorter transactions.
This goes along with the design principle of many short transactions are better than fewer long transactions.
Secondly, these update servers will help to reduce the complexity of the order code. In particular, the order object (specifically the delivery line) determines when an expected shipment or billing memo should be created, updated, and deleted. Without an update server the order needs to maintain state about this event and then execute logic during the next save operation (this is similar to what the schedule object currently does). Additionally, this complexity only deals with outbound information from the order, there still needs to be a feedback mechanism from the delivery memo or billing memo to the order. Some potential benefits of the update servers is that these updates can happen in background. Furthermore, we could invoke these from an order automation server running on an application server to give us the best throughput.
As currently envisioned there are six update servers, which represent the three bidirectional communication paths . these are:
1. Order to Expected Shipment
2. Expected Shipment to Order
3. Order to Billing Memo
4. Billing Memo to Order
5. Invoice to Billing Memo
6. Billing Memo to Invoice 1.3.3 Document Messenger Facility
This is a built-in system action provided with the base product. The document messenger facility provides a means to automatically generate a specified document in a requested format This is where integration with a third party forms package occurs.
1.3.3.1 Document Messenger
When a user action has a reference to a trading partner document on its definition, this action is invoked by the order automation server. This system action gathers up a unique collection of contacts that should be sent the document and passes these on to the document action server.
1.3.3.2 Document Action Server
This contains the logic for determining how to print the specified document. This server is named in the associated Protean document definition object. This OLE automation server conforms to the published document action server API. Typically, this server will retrieve additional information from the order object and then give this data to the third party forms package for formatting.
1.4 Order Automation Event Processing
There are two major components to this element of the order automation design: the definitional objects and the runtime OLE automation servers. This element of the design must be aware of the enterprise nature of the installed COM configuration. The definitional objects work together to ensure the correct set of events and actions are executable at runtime, i.e., actions that can only work in response to an event from a shipping source can not be tied to an event from an invoicing source.
1.4.1 Order Automation Event Processor
This is responsible for executing all defined order actions associated with an order event on a given order automation definition. Also, this can respond to system events with predefined system actions, e.g., the update servers. While there is much more detail in the order automation server than is presented here, this architectural element is responsible for the event queuing and processing. This service guarantees that all events queued will be processed.
1.4.2 Definitional Objects for Order Automation
This is the set of objects that allow the base product functionality to be extended, replaced, and in some cases removed. All base product functionality (beyond the defined system events and actions) is implemented in terms of these objects. Any functionality added to the product after a release is also defined in terms of these objects. Therefore, from the viewpoint of the customer there is no apparent difference between what comes with the original release and what may be added by other parties. This uniform view of the definitional objects is not only a benefit to customers, but also to the order automation server — its operation is determined by these objects alone.
One common feature worth noting about these objects is their release management support. This feature assists that order automation implementation specialist with a means to test each object, make it available for use, and obsolete its use in a controlled manner. This is important since each of these Protean objects is referencing an OLE automation server that potentially needs to be installed on each client machine throughout the enterprise.
1.4.2.1 Order Automation Definition
This object defines the sequence of actions followed for selected order automation events. Each order is created with a reference to an order automation definition. Modifying this object allows a customer to change how one type of order behaves differently from another type.
For example, consider an ABC ranking of customers (representing 50%, 40% and 10% of the company's business), where credit checks are not done for A ranked customers. Through the use of trading partner selection lists set up with the A ranked trading partners, and assigning this list to a market profile, a different order automation definition can be selected when creating an order. The differences in how the A ranked customers' orders are handled can be embodied in the order automation definition used and the defaults from the market profile placed on the order.
1.4.2.2 Order Event Definition
This is a very simple object that defines a specific order automation event. All events (except those defined as system events) generated in the base product are registered through this object. Custom implemented order actions can generate events as long as a definition has been registered. This allows customizations to extend the events available for incorporation into order automation definitions.
1.4.2.3 Order Action Definition
An order action definition object provides a Protean representation of an OLE automation server registered on a client machine. In simplest form, this is a link between Protean and OLE. There are a number of additional attributes on an order action definition that control how the named OLE automation server (identified as an order action server in Figure 6) is contacted prior to invoking the order action compliant API.
Similar in nature to the previously discussed order event definition object, all order actions provided with the base product (except the defined system actions) are registered through this object. In addition, this object provides integration with the document messenger facility by referencing a Protean document definition object.
1.4.2.4 Protean Document Definition
This represents the capabilities for generating a particular document that can be used as validation criteria on the contact object's document role, e.g., languages supported, format and transmission methods. More detail can be found in COM Order Automation Action Definition.
2. An Order Pricing Example
Now that each element of the design has been introduced, an example is presented to show how these elements work together to provide a flexible and extensible solution for our customers. This is an online order entry scenario where a customer service representative (CSR) has a customer ordering by telephone. In this scenario, the customer may want to know the total cost of a delivery before committing to the order. As a result, an order automation definition has been established that prices each delivery line as it is added to the order. The object interactions shown in Figure 7 begin when the CSR has completed entry of a delivery line.
1. From the order entry user interface the CSR completes entry of a new delivery line.
2. The order object determines that a new delivery line is complete and generates the Delivery Line Added event. Event generation includes enough information so that the order action server invoked later can determine which delivery line was added.
3. The order automation server looks at the order automation definition referenced by this order to determine if there are any actions to be invoked in response to this event.
4. The Price Line action is defined for the Delivery Line Added event.
5. The order automation server then contacts the pricing order action server through OLE/COM and invokes the order action compliant, exposed OLE automation API.
6. To carry out line pricing, the pricing calculation requires the resource, requested resource characteristics, the quantity ordered, the requested delivery date, along with the ordering trading partner, the selling company and line of business. The pricing order action server gathers this data from the order object. This is possible because the information passed to an order action server from the order automation server includes the dispatch interface to the order object which generated the event. In Visual Basic terms, the order object is passed to the invoked order action server.
7. The order object returns the requested information.
8. Now that the pricing order action server has the data necessary for the pricing calculation, it needs to get the correct price sheet to perform the calculation. The price sheet is determined by the pricing provider object, which is given the assignment criteria as input.
9. The new order delivery line is updated with the result of the pricing calculation. 10. Changing the price causes a Price Changed event to be generated. To prevent recursion problems, this event can be queued up for later processing by the order automation server since an event is currently being handled.
11. Control returns to the pricing order action server from the call to update the price on the new order delivery line.
12. Pricing is done, so control returns to the order automation server.
13. The order automation server is now done with the pricing order action server. The order automation server looks to the order automation definition for more order actions to be executed.
14. No other actions have been defined for the Delivery Line Added event, so it is removed from the event queue.
15. The order automation server then checks its event queue to see if there are any other events to be processed for this order and it finds the Price Changed event (generated in step 10).
16. The order automation server again looks to the order automation definition for any actions associated with the Price Changed event.
17. The order automation definition responds that there are no actions defined for the requested event. The event is removed from the queue.
18. The order automation server determines that there are no more events for this order in the queue, so control returns to the order object at the point where the Delivery Line Added event was generated.
19. Control returns to the order entry user interface from the order object. At this point the user interface can be refreshed so that the calculated price for the delivery line is available to the CSR.
This description above pertains to synchronous in-process operation of order automation. It is reasonable to expect a complex operation like pricing not to be instantaneous. Therefore, in a synchronous in-process operation some delay may be visible to the user. In an asynchronous in-process mode the pricing operation executes on a thread while the user continues with order entry. When the pricing operation is complete, the UI is notified so that the price can be displayed. Section III - Delayed Order Automation Processing Design
1. Introduction
Order Automation is the COM feature that will allow users to customize order processing to meet their own particular needs. Order Automation consists of several components, including definitional components, immediate event processing components, and delayed event processing components. This Section focuses on the latter.
Order processing will have the ability to generate order automation events in response to a variety of triggering conditions. For the COM Order object, some of these events can be processed immediately, i.e. synchronously in the same process space as the Order. However, the Order and the other related COM app objects can also generate delayed events, which are processed after the user is done interacting with the generating app object, in a separate process space, on a separate application workstation.
This design will explain how multiple COM client workstations can generate delayed events and can initiate their processing via the Delayed Event Processor (DEP). Specifically, the design will focus on delayed user events and the ramifications of errors on delayed event processing and order processing. System events and scheduled events will also be discussed, but in lesser detail.
3. Design Overview
3.1.1 Architectural Details
The Delayed Event Processing Manager Service (DEPMS) is an NT Service responsible for managing the processing of delayed events. For customer installations, the DEPMS is required to be running on a remote server, on the same network but a physically separate machine than the Order entry workstations. This remote server is also running one single instance of the Protean process.
The goal of the DEPMS is to allow multiple clients to asynchronously contact the DEPMS with a request to perform delayed event processing as a background task. The asynchronous call permits the client to continue its path of execution, rather than blocking and waiting for the delayed event processing to complete. The benefit of this asynchronous behavior is most apparent when the client is the Order object, and the closing of the Order initiates delayed event processing. Since the Order object is the only event triggering object with a UI, user response time is critical. The asynchronous model allows many Orders to close simultaneously, with no discernible performance degradation.
The following sections detail the DEPMS NT Service at both startup time and event processing (i.e. after the triggering object is closed) time.
3.1.1.1 DEPMS Startup
NT Services are started in two separate ways:
1. At server boot time. This is an automatic startup NT Service.
2. At a clients' first attempt to contact the Service. This is a manual startup NT Service.
The Delayed Event Processing Manager Service (DEPMS) is an automatic startup NT Service. However if the DEPMS is not running (due to a crash or other unforeseen circumstance), a clients' first attempt to contact the DEPMS manually starts it.
Figure 8 shows the DEPMS after initialization, but prior to any client requests arriving.
On startup, the DEPMS creates one multithreaded apartment (MTA) and a configurable number of Single Threaded Apartments (STA). The number of ST As created by the DEPMS matches the number of STAs created in the single Protean footprint. Both Protean and the DEPMS look at the same data (currently an entry in the protean.ini file) to determine the number of STAs to create.
The MTA contains objects requiring simultaneous access from multiple clients. Any objects or shared data residing in the MTA must be thread safe as any one of multiple threads may access this shared data. An MTA is required here to guarantee that any number of clients will always have access to this service and won't be blocked by another process accessing this service.
One object contained in the MTA is the Queue Manager (QMGR). The Queue Manager is a C++ class that contains an in memory queue and a critical section. The critical section is an NT synchronization object used to enforce exclusive access to the queue.
All requests to process delayed events are added and removed from the single in memory queue contained in the QMGR. Multiple clients may attempt to access the queue simultaneously, making the queue the synchronization point for the entire DEPMS. Since synchronized entry to the queue is paramount, the critical section enforces exclusive access to the queue. The QMGR has public methods to push() and pop() items from the queue, using the contained critical section to synchronize queue access. C++ encapsulation allows QMGR clients to push() and pop() items from the QMGR. QMGR clients are detached from queue synchronization details in the QMGR implementation .
The QMGR also contains an NT Event used at delayed event processing time. The use of this NT Event is discussed fully in the following section.
During startup, the DEPMS creates a configurable number of STAs. The STAs contained in the DEPMS do not contain any MS COM components. These STAs are single threads that make connections to Protean STAs and then go to sleep, waiting to perform processing logic when awakened.
Each DEPMS STA connects to a Protean STA by creating an instance of the Delayed Event Processor (DEP) MS COM component. The DEP is created in a corresponding STA inside the single Protean footprint. After DEP creation, each STA is immediately put to sleep, waiting for clients to push items into the QMGR. It is important to note that the DEP is created in an STA in the Protean process. This is significant considering the DEP opens many Protean objects during its processing of delayed events, and it is most efficient if all this work is executed in the same Protean apartment.
At DEP instantiation time, it will read PROTEAN.INI file or registry to get a re-try count and a maximum delayed event count. The DEP will use the re-try count to determine if notification requests have exceeded the configurable re-try count. The maximum delayed event count can be used to ensure that delayed event processing doesn't degenerate into an infinite loop. Details of both of these processing controls are covered in Section 3.1.2.2 Application Processing Details.
Startup of the Protean process is not a concern for this design. If the Protean process is already running on the remote workstation, the DEP is created in a Protean apartment. If the Protean process is not running, creation of the initial DEP starts Protean.
The final step of DEPMS startup provides error recovery from the previous run of the DEPMS. Due to one of a number of circumstances (DEPMS crashes, network goes down), it is possible that unprocessed delayed events remain in the database. The DEPMS checks for this situation by running a query across the delayed event IPK table. The DEPMS uses the query results to rebuild the QMGR and begin processing these orphaned delayed events.
Likewise, during DEPMS startup, the DEPMS must ascertain that it did not leave Protean objects applocked due to a previous crash. To check for this, the DEPMS executes a query against the applock table looking for objects left open by the DEP from a previous run. Details about this can be found in Section 3. 1 .2.5 Re-Try Considerations.
3.1.1.2 Delayed Event Processing
After the DEPMS is started and initialized, the DEPMS is ready to service client requests and perform Delayed Event Processing. Figure 9 builds on Figure 8 and shows the DEPMS accepting client requests and synchronously executing these requests as background tasks.
As described in the previous section, the DEPMS is available to accept requests from possibly multiple clients. Lets consider a scenario with multiple Order objects closing simultaneously.
If delayed events exist in the Order object's collection of delayed events, the destructor of the Order creates (via CoCreatelnstanceQ) an instance of the Delayed Event Notification Manager (DENM). The DENM is an MS COM component created in the MTA of the DEPMS, allowing multiple Order objects the ability to simultaneously create DENM components. The Order object invokes a method on the DENM to notify the DEPMS to start Delayed Event Processing. This notification indicates:
1. The Order object has generated and saved delayed events.
2. The Order object is closing and the DEPMS must process those delayed events.
The DENM creates a new thread in the MTA and returns immediately to the Order object. This immediate return to the Order object allows the Order to continue its path of execution (the Order is closing). The newly created thread in the MTA pushes an item into the QMGR, but may wait on the critical section that is synchronizing access to the queue. The major benefit of this strategy is that the newly created thread, not the Order object, waits on the critical section. The Order object continues to close, and the newly created thread works in the background, attempting to push data into the QMGR. This is a very important point given that a CSR is waiting for the Order to close. Note: An alternative to this approach is to not create the thread and let the Order object wait on the critical section. However, if the number of Order objects closing simultaneously is large, Order closing performance degrades. The number of closing Orders that begin to degrade performance is unknown at this time. It is possible that we may never reach this number and the extra threads are unnecessary. Regardless, our prototyping has indicated that the overhead of thread creation is minimal.
As described in the previous section, the QMGR class contains an NT Event. An NT Event is an NT synchronization object the DEPMS uses to signal sleeping STAs when items are pushed into the QMGR. The QMGR utilizes the contained NT Event to signal a single STA that an item to process is in the queue. The NT event wakes one sleeping STA and the STA pops an item off the QMGR. If there are more items on the QMGR, the pop() sets the NT Event, waking another STA. This process continues until the entire QMGR is processed.
When the NT Event wakes one of the STAs, the STA invokes the executeQ method on the corresponding DEP to perform all Delayed Event Processing in a Protean apartment. The executeQ method is a synchronous call. The DEPMS STA waits for Delayed Event Processing to complete before continuing its path of execution. It is important to note that this synchronous call is happening in the background, long after the Order object is closed. This is the right time to be synchronous and wait for DEP completion.
After the QMGR is emptied, all the STAs go back to sleep, waiting for more data to be pushed into the QMGR.
3.1.1.3 Re-try considerations
If the notification request that the DENM receives has a notification count greater than 1 , this indicates that the notification request is being re-tried, due to the fact that an object could not be opened for change (re-try is explained in more detail in Section 3.1.2.5). In such a circumstance, we do not want to immediately place the notification request on the QMGR. It is preferable to wait a configurable amount of time. Notification re-tries will be placed on a separate re-try queue, and a timer will pop the item from the re-try queue and push the item into the QMGR.
3.1.2 Application Processing Details
All application processing of delayed events is driven by the Delayed Event Processor (DEP) which is instantiated inside a single threaded apartment in the Protean process on the remote server. This processing takes two different forms: 1 for non-scheduled delayed events and 1 for scheduled delayed events. The scheduled version is very similar to the non-scheduled version, but the processing is initiated differently. Both versions are discussed below.
3.1.2.1 But first, a brief note about error handling. . .
At times, we need to be able to flag an error on the triggering object (TO) for which we are processing delayed events. We need this ability for the following reasons:
1. we must catch errors in delayed event processing and flag the TO in error;
2. TOs in error can still be modified via openForChange (OFC) by processes other than the DEP. These modifications could lead to additional delayed events being generated, which implies additional notification requests to the DEPMS. However, TOs in error should not generate notification requests to the DEPMS. If the automation error flag is on the TO (as opposed to on another object), then this is a simple "if test;
3. TOs in error need to be retrieved via specialized queries on the TO cabinet. Via dynamic cabinets, we can only join to objects to which the main cabinet object (in this case, the TO) has a reference. Therefore, since our TOs will not be containing a reference to their corresponding Persistent Error Objects, it is preferable if the error flag is on the TO itself;
4. There are some other simplifications to this less-than simple design that resulted from putting this flag on the TO.
Now then, technically, we would only want to set the automation error flag on the TO when we know we really have an automation error. However, once an error has occurred, we cannot save the TO, since we want to maintain object integrity and we have no idea if the action that failed left the object in an incomplete state.
"A Pessimist is an Optimist With Experience"
Hence, our pessimistic error handling approach, as follows (additional details provided below, this section here just to set you up, that is, to provide the necessary background):
• after we OFC the TO, we must do some preliminary setup logic. Once we determine that we are actually going to execute an action, we set the automation error flag on the TO and save the TO. This will set the flag in the event any subsequent action that gets executed fails. if all actions execute successfully, we turn the automation error flag off and save the TO as the last step of processing.
Yes, this requires two additional saves of the TO in delayed event processing. However, this approach significantly simplifies processing logic, and has the added benefit of actually appearing to be do-able, as opposed to some of the other approaches that were considered.
The diagram in Figure 10 depicts the flow of processing of delayed events.
3.1.2.2 PROCESSING DELAYED EVENTS — Non-Scheduled version Step 1
The STA from the DEPMS service invokes the execute method on the Delayed Event Processor (DEP) inside of the Protean process running on the same workstation (the remote server which houses the DEPMS). It is significant to note that the DEP is running in the Protean process, as the DEP must talk to many Protean objects and it is far more efficient to do so if it is resident inside the Protean process.
The original notification call receives the classID and objectID of the triggering object (TO), along with the user key name parts of the object and a count of how many notifications for this object have been sent. Step 2
The DEP opens for change (OFC) the TO. The class ID is used to determine which class of user key to construct. Either the user key name parts are filled in or the classID/objID parts are filled in (See Issue # 5) and the UK reference is used to OFC the triggering object. Since delayed events that were generated by this TO are stored as subordinates on a persistent collection on the TO, they will be retrieved as part of a demand fetch operation. (Opens for the Order in particular will always be shallow for efficiency reasons, therefore we will be relying on demand fetch to retrieve subordinates.)
If the collection of delayed events is empty, that would be curious, but is not really an error. Technically, this should not happen, but, if this were to happen, processing for this notification request would simply terminate successfully. The collection of delat ed ev ents w ill alw j; s be in the sequence ir w hich the ev ents were generated, as one may only add new delayed ev ents to the end of the collection This is significant since delayed ev ents must always be processed in the order of generation
If the OFC on the TO fails ( 1 e another user has the object locked), w e cannot continue processing In this situation, w e must re-issue the notification ping to re-queue the request to process delayed ev ents We increment the notification count passed over in the ping that initiated this process, and re-send the notification request Then, w e stop processing this request If, howev er, we hav e exceeded the configurable limit of how manv re-tπes to attempt, w e do not send the notification request Refer to Section 3 1 2 5 on Re- Try Logic for a more complete discussion of how to handle failure of OFC on the tπggeπng object
Note that OFC not w orking is not an error Due to Protean's one writer manv readers access strategv , this is normal application behav ior We hav e to handle this situation gracefully and allow for re-try How ever, e are limiting the number of re-pings as we could get ourselves into a loop here if the TO is in an extremely long edit session or if it has an errant app lock which might need to be cleaned up before processing can begin In this ease, once the maximum number of re-pings hav e been executed, we now need to stop pinging and consider this as a possible error Step 3
Before continuing, w e should determine if there w ere errors on a prev ious execution of delayed events for this TO If there w ere errors, the automation error flag on the TO would be set to TRUE Technically, the DEP should never he attempting to process errors for a TO in an automation error state, since the TO will not send a notification request to the DEPMS if the automation error flag is set However, we really should not process any further if this flag is set. therefore, w e do the check If set, we are done with this notification request and w e terminate processing successfully
Technically, this is a programmatic error, w hich e w ould normally treat by throw ing an exception Howev er. Protean's exceptions are not real C — exceptions, and ill cause Protean to terminate, w hich is not desirable in remote processing Consequently, w e should log this information to the automation processing log file, but this is behav ior that w e should catch n 'estm ail of our tπgger ng objects Customers should ne er see this in their log files
Step 4
The DEP w ill openForReview (OFR) the Order Automation Definition (OAD) object that corresponds to the tπggeπng object
This should never fail, but again throwing an exception is not a possibility Instead, in this ease, we w ill create an error, create a Persistent Error Object for this TO. set the automation error flag on the TO. sav e the TO, and terminate processing after closing all open objects
Once the OAD is opened, the DEP w ill retriev e from it the value of the flag to indicate if processing details should be πtten to a log file If so. the DEP w ill create the log file and retain this flag internally to use it duπng v aπous processing steps to determine if log file entries need to be created Step 5
W e can now begin to process the delayed ev ents We retrieve the first delayed event from the collection First w e determine if this is a system or a user event System ev ents are treated differently than user ev ents System events are effectiv ely hard-coded logic that guarantees that Protean objects remain in synch User Events are processed based upon the Actions associated w ith them on the OAD
If this is a system event, a pπv ate method will be called on the DEP that will contain all of the necessary logic to process this event System events will invoke transaction action serx ers w hich w ill perform the necessary logic for that system ev ent System event behavior cannot be customized, therefore the DEP does not need to refer to the OAD to get the list of actions associated with this event, as that list is hardcoded in the pπvate method on the DEP More often than not, there w ill only be 1 action per system ev ent, but that is not the point The main distinction is that e code all system ev ent logic and the users may not customize s stem ev ent behav ior
Upon completion of the priv ate method that executed the system ev ent, e check for errors If there are eπors. w e terminate processing If no errors, we get the next delayed ev ent to process
S7 \OTE The DEP \ ill work thiough the delayed event collection one at a time We process 1 delayed event at a time to its completion, that is, we process all the actions associated with this delayed e ent in order If an action generates an immediate event, that event will be processed immediately before any remaining actions for the cuπent delayed event
For an example of delayed event processing creating cascaded immediate events, consider the following scenaπo
Event Action
Order Maιntamed(DE) 1) Pπce Order
2) Credit Check
3) Print Acknowledgement
L nit Price Updated (IE) 1) Evaluate Delivery Conditions
In this situation, processing the delayed event "Order Maintained" will first execute the first action. "Price Order", which will loop through and price all Delivery Lines on the Order The pricing of each Delivery Line will generate the immediate event "Unit Pπce Updated" For each Delivery Line, the action associated with "Unit Pπce Updated" event, "Evaluate Delivery Conditions", will execute next Only after all Delivery Lines ha e been priced and after the "Evaluate Delivery Conditions" action has been executed for each Delivery Line ill the "Credit Check" action on the "Order Maintained" delayed event be executed This is desirable behavior from the Customer viewpoint, as the Credit Check action would want everything priced before inquiπng if the total pπce is within the valid credit limit
NOTE If an action generates delayed events on the tπggeπng object (TO), they will be inserted at the end of the delayed event collection on the TO, and subsequently processed as the DEP loops through the collections of delayed events In this scenaπo, when we close the oπginal tπggeπng object (Step 16 below), its destructor will not ping the DEPMS, as all delayed events for the object will have been processed
There is another unusual case that we must consider here It is possible that an action on a delayed event A can generate delayed event B. and an action on delayed event B could generate delayed event A The actions that we distribute with Protean will be of course tested for such a problem Ho e er, since users ill be writing their own action servers and
SS since users άΛ' customize automation processing v u 'he Order Automation Definition (O D), then this case may occur Since cascaded delayed events are added directly to the end of the delayed ev ent collection on the tπggeπng object, and since we loop through the delayed e ent collection one at a time, a situation such as this would create an infinite loop Our method to handle this situation is as follows the DEP, at initialization time, w ill retπeve from the PROTEAN INI file a configurable maximum event count and will store this value internally,
• the maximum event count will be referred to as w e loop through the delayed ev ent collection, if w e exceed the maximum event count, w e generate a cπtical persistent error on the TO and terminate processing, if this is really a loop, the user can then turn on logging on the O AD. and reinitiate processing The log output w ill help them debug the loop,
• if this isn't a loop, the user can increase the maximum ev ent count and reinitiate processing
On another note, since actions can be operating on objects other than the object that tnggered the original delayed event (1 e in delayed ev ent processing the action can be updating an object other than the oπginal tπggeπng object), the close operation on that object w ould result in a ping to the DEPMS in order to queue up the processing for that tπggeπng object
• Step 6
If the delayed event is a user event, the DEP will examine the Delayed Ev ent to see if its attπbute that lists the last successful action that was processed is set If so, that means that this delayed e ent previously had errors and stopped sometime after the action value that is stored in this attπbute w as completed successfully Explanation of ho this attπbute is set can he found in Step 9 below If this attribute is set, the DEP w ill refer to the OAD to get the UK of next action associated with this delayed event after the action stored in this attπbute For example, if the v alue stored in the attπbute indicates the 3rd action processed successfully, then this round of processing will re-commence w ith the 4th action,
If this attπbute is not set, the delayed ev ent is being processed for the first time and so the DEP w ill get the first action associated w ith this delayed ev ent on the OAD Similar .0 immediate e ent processing, 'he DEP must chec.-v on the O AD that the action is defined for this ev ent source (the event source is the "site" of the tπggeπng object — not the site in the Protean sense of a Site UK, for example, but rather the site meaning the Ordeπng site, the Inv oicing Site, the Inv entory site or Other) Step 7
The DEP w ill OFR the Action Definition IPK to retriev e additional information before executing the action
In addition to the checking that is done for immediate ev ent processing (1 e is the action activ e, along w ith retπev mg w hat, if anything, is defined in the Additional Arguments field on the Action Definition), w e must also pay attention to hether this action is a function action or a transaction action
If the OFR fails, this is a significant error This should nev er happen, but if it did. w e w ould create a Persistent Eπor Object, add a critical error, and terminate processing Eπor processing w ill be discussed in detail below Step 8
If in fact we are going to execute this action (1 e if e passed the tests in Steps 6 and 7). and if this is the first action to be executed, w e take this oppoπunity to set the automation error flag on the TO and then we save the TO This w ill ensure that the TO will accurately reflect if any subsequent actions fail We w ait till this moment to do this in to handle the possibility (remote how ev er it might be) that all actions for this ev ent are either inactivated or not relev ant for this ev ent source Step 9
Since w e are about to execute an action, w e update the delayed ev ent's attπbute that indicates which action last processed successfully with the index of this action in the event's collection of actions on the OAD Giv en that an action can be associated multiple times with a particular event in an Order Automation Definition, this v alue should be an index into the action collection, and not the actual UK of the action This attπbute will only be used if the delayed ev ent does not process to a successful completion
As is explained below in greater detail, the TO is sav ed after each successful action execution. This w ill persist on the 1 st delayed ev ent on the TO the v alue of the last action successfully processed If a subsequent action fails (hence the TO is not saved), then the delay ed ev ent w ill at least ecord the last successful action processed Therefore, w hen delayed event processing is restarted for this TO, we w ill pick up w ith the action after the last successful action that as processed for this delayed event If no subsequent actions fail, the delayed ev ent is remov ed from the collection, and this attribute is no longer relevant Step 10
The DEP w ill instantiate an Action Arguments object, built from details on the event and from the Action Definition IPK The type of Action Arguments object that w e create depends upon whether the Action is a function or a transaction
Transaction actions may update objects other than the oπginal tπggeπng object Function actions may only update the original tπggeπng object (1 e in terms of Protean objects If there w ere non-Protean objects in a customer env ironment, it is possible that they could be updated in a function action) Regardless, either form of action serv er w ill always receiv e an IDispatch* to the automation wrapper class for the original tπggeπng object that w as OFC'd in Step 2 abo e Transaction actions w ill also receiv e an IDispatch* to the automation manager class for the original tπggeπng object, as they may need to invoke the sav e lifecycle method on the object
Additionally, the Action Arguments object w ill also contain a CMsgList (or some such container of messages) This message list w ill store al] messages ( I e critical errors, arnings and informationals) returned from the execution of action servers
Also, for transaction actions only, the Action Arguments object ill contain a flag indicating if a re-try is being requested Since transaction actions may openForChange objects other than the tπggeπng object, it is possible that the open may fail due to contention. If so, this is not an error but w e do need to re-submit the processing request Hence, all transaction action serv ers must be written such that failed OFC's will turn on the re-try request flag and return that to the DEP Step 1 1
The DEP w ill instantiate the action sen er (v la CoCreatelnstance) and w ill invoke the execute method on the Action ser er, passing in the Action Arguments object Note from Figure 10 that a side effect of inv oking the action ser er could be inv oking methods on both the tπggeπng object and also other objects ( for transaction action serv ers) It tϋe action ser. er DLL cannot be found or is not reg>stereJ this s a cπtical error in which case, w e create an eπor create a Persistent Eπor Object (this process is described repeatedly below ), and terminate processing Step 12
The "execute" method inv oked on the Action Serv er ill return an HRESULT ( as all COM Automation methods must) The DEP w ill retπev e the CMsgList from the Arguments object and determine if there were any cπtical errors If so, we must consider the case (in the ev ent of a transaction action only ' ) that the eπor could be because an OFC w as not possible
In this situation, the DEP w ill examine the re-try request flag from the Action Arguments object If a re-try is requested, then an OFC in the transaction action serv er failed Before w e can re-try, how ev er w e must check the notification count that the DEP has been maintaining for this triggering object If this re-try request w ill increment the notification count beyond the configurable v alue that was retriev ed by the DEP from the PROTEAN INI file at DEP initialization time, then w e hav e now exceeded the maximum number of re-tnes allowable We w ant to reflect this with a persisted cntical eπor, but w e don't need to keep all the other w arnings, informationals, etc from the action server(s) already executed So, we can just create a cπtical eπor and persist that, and then terminate processing by closing the TO
If we have not exceeded the notification count, we discard the eπor list, close all opened objects re-submit the notification request after incrementing the notification count, and terminate processing
REALLY SIGNIFICANT POINT So, remember that automation eπor flag that w e set on the TO w ay back in Step S 7 Well, w e've just decided to stop processing, not because of an eπor. but because of OFC contention It is cπtical that e turn that eπor flag off now , because that eπor flag determines if this TO shows up in the query of TOs in an automation eπor state How ev er, turning that flag off involv es saving the TO Generally, w e don't sav e the TO unless the action executed successfully In order to guarantee that w e can rely upon the automation eπor flag, transaction action ser ers that OFC multiple objects must do all their OFC'mg up front, before changing any v alues on the TO It any OFC fails then thev should make no changes to anything, close any successfully opened objects and set the re- try requested flag and return Then, and only then, can e turn off the automation eπor flag and save the TO and sleep easy
But, if there were cπtical eπors and the retry flag is not set, then w e must terminate processing A Persistent Eπor Object (PEO) is created, based upon the UK of the TO All eπors (warnings, informationals. and cnticals. if any) are copied to the persistent eπor object In this case, the persistent eπor object is saved and closed, but the tπggeπng object is just closed not saved since there were eπors in processing and since w e don't want to persist an object that might be in a eπor state The OAD must also be closed as pail of termination
Due to our pessimistic eπor handling approach, we hav e already set the automation eπor flag on the TO, so that now correctly reflects the automation processing eπor Likew ise the delayed ev ent reflects the previous action (not this action) as the last successful action that w as processed
If there w ere no cπtical eπors, the action executed successfully The TO is saved after each successful action execution, to guarantee that the results of this action are persisted to the database and also that the last successful action indicator on the delayed event is also persisted to the database
Note that the message list w ill only be persisted if a cπtical eπor is detected after the execution of an action server That is, we only persist messages if something failed Therefore, w e only create a PEO for a TO if something failed If all actions associated with the delayed ev ent being processed only return warnings and informationals, then there were no critical eπors, hence there w ill be no PEO Consequently, those warning messages are not persisted We maintain an on-going list of all warnings and informationals returned from all successful actions so that in the event of a cntical eπor, the persistent eπor object re fleets all processing for the delayed event now in eπor
Also note that after each action execution (successful or not), the action arguments object must be destroyed as it is only relev ant for 1 action Step 13
If no cπtical eπors ere returned from the action execution, w e loop back to the OAD to get the UK of the next action associated w ith this delayed ev ent (as m Step 7 abov e), and continue with Steps 8 through 12 Step 14
If all actions were processed successfully, the delayed event has been completely processed The DEP will call the remove method on the delayed event collection to remove the delayed event from the TO
At this point, the only messages on the CMsgList that we have been passing into each action execution are either warnings or informationals We have decided that due to the large volume of TOs, persisting warnings and informationals for successful delayed event processing is an administrative nightmare How would we decide when to delete them If we made that a user action, perhaps they would never get deleted If we made that a programmatic action, perhaps the user would never have the time to view them before they were deleted
Consequently, we have chosen not to persist the warnings and informationals These messages will be dumped to the automation log file when automation processing is run in "logging" mode (1 e when the switch is set on the GAD) This will give the system implementor the opportunity test their automation processing logic and review its output Step 15
The DEP will retπeve the next delayed event from the TO's delayed event collection and process it according to the steps descπbed above, beginning with step 6
• Step 16
Once all delayed events that were returned in the answer set have been processed successfully, we are done processing At this point, we must turn off the automation eπor flag on the TO, because there are no eπors So, the last step in successful delayed event processing turns of this flag and saves the TO, and returns to the thread from the DEPMS ser ice that originally invoked the execute method on the DEP in Step 1
3123 PROCESSING DELAYED EVENTS —Scheduled version
At this point, we are not focusing on scheduled event processing, since this is not a must have for FCS Scheduled event processing will be very similar to the non-scheduled version, except for the initiation of the notification requests and some tests that will be done to ensure that the time is right to execute this event
At a minimum, we can state the following .nitiation 0ι v- ulen ev ent processing w nl be αseu upon some configurable timed interv al, at w hich point a Scheduled E ent Notification Manager (SENM) running inside the DEPMS service should "wake-up" and execute a query retriev ing identify ing information for all TOs with scheduled ev ents to be processed This information w ill be added to the queue in the form of a notification request,
• Scheduled ev ents w ill be stored in a separate collection of delayed e ents on the tπggeπng object, before processing a scheduled event, the DEP must ensure that the scheduled time is equal to or later than the cuπent time
W e anticipate that the lessons learned in implementing regular delayed ev ent processing w ill be relev ant to scheduled ev ent processing, so postponing this implementation until after delay ed e ent processing is done is a good idea
3 1 2 4 Eπor Handling Considerations
Many of the details of eπor handling w ere cov ered in the explanation of Application Processing Details (Section 3 1 2 2) This is perhaps the hardest part of this design and if anything w ill change during implementation, it could be this
This is just a brief recap of the high points of our eπor handling approach
• in our pessimistic eπor handling approach, an automation eπor flag w ill be set on the TO before the first action is executed, and only turned off 1 ) after all actions execute successfully, or 2) if w e need to request a re-try due to OFC contention, as each action is being executed, its v alue w ill be stored in an attπbute on the delay ed ev ent If the action is successful, the TO is sav ed, thereby stoπng the results of the action and the attπbute indicating the last successful action processed If all actions on the delayed ev ent process successfully, this "last action successfully processed" flag is moot, as the delayed ev ent is remov ed If an action fails, the delayed ev ent reflects the last action successfully processed, the automation eπor flag w ill be used by a query on the TO to return all TOs in eπor due to automation processing,
• a coπesponding Persistent Eπor Object (PEO) is onlv created for a TO when critical eπors are encountered in automation processing W arnings and informationals are not persisted unless a critical eπor also occurs. the personal user key of the PEO ill be the objectID and classID of the TO The PEO, therefore, refers to the TO, and not the other w ay around This is for two reasons 1 ) vve can't save the TO once a cπtical eπor occurs, and we only create the PEO when a critical eπor occurs, therefore you can't store the PEO's UK on the TO, and 2) the v anous Memo objects are EM'd from site to site EM assumes that the object it is updating hasn't changed since it's last update Hence, the Memo object can't contain a UK to the PEO,
OFCs on TOs that are in an automation eπor state can still occur outside DE processing, the TO may be modified, and new delayed ev ents may be generated, but the destructor of the TO w ill not send a notification request to the DEPMS if the automation eπor flag is set TOs in an automation eπor state will not be processed by the DEP until the eπor state is cleared. the automation eπor flag can only be cleared through a specialized non- standard cabinet action, descnbed below
Resolv ing Eπors on Delayed Events
Each class of objects that can generate delayed events will need a new query defined This query, w hen executed, will retriev e from the database all delayed events for instances of this tnggenng object that are in eπor, based upon the automation eπor flag on the TO Any one triggering object instance can only have 1 delayed event in eπor due to the nature of delayed ev ent processing Once the first eπor is detected, no further e ents are processed
This query will return information about all tnggenng objects of this class that have delayed ev ents in eπor but only if the TO's app lock is OFF The app lock cntena is a must since vve don't w ant to retπev e those TOs that are cuπently OFC'd and being processed by the DEP, since the DEP will pessimistically set the automation eπor flag and will have the TO OFC'd So, for example, on the Order cabinet, the query w ill return an answer set indicating all Orders that hav e delayed ev ents in eπor, along with the name of the ev ent that w as being executed I f we can include the action name too, that would be great — vve w ill resolv e that at implementation time
There w ill be two non-standard cabinet actions on this cabinet 1 ) show eπors for this TO, and 2) remov e the eπor condition These actions w ill behav e as follows
The cabinet action that show s eπors for the TO must prov ide the ability to openForRev iew the PEO associated w ith the TO that is in eπor The PEO's PUK w ill be the bjlD classID combination ot the TO eπor This OFR w i ll oc done oy constructing a U K for the PEO. and filling in its v alues from the TO and then executing the OFR Once opened, the erEπor portion of the PEO will be retnev ed from the object and w ill be displayed in a standard message list v iew er dialog
The cabinet action that remov es that eπor condition would delete the appropnate PLO object, OFC the TO and clear the flag, and then Sav e.AndClose the TO The destructor of the TO w ill send a notification request to the DEPMS if the TO contains delayed events in its collection, w hich w ill re-initiate delayed ev ent processing
The intent is that users w ill query all TOs in eπor, they w ill look at the eπors, take w hate er measures necessary to coπect them, and then re-start processing through this non- standard cabinet action
Some EM Considerations
In multi-site, enterprise installations, some of our triggering objects can exist in sev eral sites For example, the Billing Memo (BM ) is created in the Ordeπng site, and then re-created ( ia EM) in the Inv oicing site In the Ordeπng site, the BM is simply a data holder, 1 e no real billing memo processing happens in the Ordenng site, hence no automation events occur It is only created in the Ordenng site, but it is processed in the Inv oicing site. EM has to get it there In the Inv oicing site, the BM processing occurs, therefore ev ents can be triggered, therefore processing eπors may occur For the purposes of this discussion, let's call the Ordenng site the creation site and the Invoicing site the event source site
The PEO can only be created for the triggering object w hen the tnggenng object is being created in its ev ent source site, as ev ents are only generated and processed in an object's ev ent source site In this example, w hen the BM is created in the Ordering site, no ev ents are ev er gene/ ited for the BM in the creation site EM w ill guarantee that the BM gets created in the In oicing site, and that creation WILL generate ev ents, w hich may create automation eπors, hich ould lead to the creation of a PEO for that BM
A conclusion to be draw n from this discussion is that hile the tnggenng object may be E enabled, the PEO w ill nev er be, as it is only relev ant in the event source site
3 1 2 5 Re-try Considerations
To recapitulate re-try is only necessary if we cannot OFC an object, due to Protean's 1 writer/many readers approach; the DEP, at instantiation time, reads the PROTEAN.INI file to retrieve the maximum re-try count and the notification wait time;
• the notification count sent over in the original request for a TO is stored in the DEP and incremented each time a re-try request is resubmitted to the DEPMS. The notification wait time will be used to slightly delay this notification request from getting back into DEP processing. The idea with this is that if I couldn't OFC it, and if the notification queue is emptying out pretty fast, let's wait a bit before I try to OFC it again so that there's a better chance of the OFC working on the re-try; when the DEP determines that the notification count exceeds the maximum re-try count, an PEO is created indicating this eπor condition, and processing terminates;
• But if only life were this simple...
So, this works OK for those situations when the object you are trying to OFC is not the TO, i.e. for those objects OFC'd by transaction action servers. But suppose the object you can't OFC is the TO itself and you exceed the re-try count'? Well, we'd like to flag this as eπor, but unfortunately, the automation eπor flag is on the TO, which we can't OFC, so that's not possible. Using a separate eπor flag elsewhere means all other aforementioned eπor processing logic now has to look in two places, and that is less than desirable.
Now, if the TO is just locked in a long edit session, our re-try approach should be acceptable. If, however, the TO is locked due to a previous Protean crash (i.e. it's app lock was never coπectly turned off because Protean crashed), then our re-try logic as explained above will take us to infinite loop land. Consequently, the following decision has been made: if the DEP/DEPMS crashes, at restart of the DEPMS, a query will be executed that will effectively perform the same action as the Checked Out objects cabinet, i.e. it will tum off the app lock on the TO and remove the row in the app lock table for those TOs which are listed in the app lock table as being OFC'd by the DEP (remember good of Assumption #1, how the DEP will be registered as a valid Protean user? This is just one reason why.) This way, we are at least cleaning up after ourselves. if someone else crashes w e hav e to assume that they w ill clean up after themselves This processing is already a tad convoluted, we can't start solving other processing eπors here too So, if someone left an eπant app lock on a TO and never cleared it, and if w e exceed the re-try count on a TO in DEP processing, we just stop and assume that sooner or later this app lock w ill be cleared
Please don't think that this decision was made lightly Once the app lock is cleared, the Order can be OFC'd by a user and the ensuing closing of the Order w ill inv oke the destructor which will notify the DEPMS that delayed events for this Order exist, and the process is back on track
4 Abstract Tnggenng Obiect Details
The abstract tnggenng object is an fdEmblnst denved class that will encapsulate all delayed e ent behav ior All tnggenng objects that need to generate events must inhent multiply from fdGenlnst and co.AbsDelEv ent, therefore, this object belongs in the Resource VOB
See Figure 1 1 coAbsDel Event Inhentance hierarchy diagram
4 1 co.AbsDelEvent Attributes and Behavior a persistent collection of delayed ev ent subordinates, with standard collection APIs with the exception that vve should only support insertAtEnd, as we want to ensure that delayed ev ents will only be added at the end of the collection so that they are processed in the order in which they w ere generated, the Order Automation Definition UK — it makes sense that this attπbute mov e here, as all TOs will need this attπbute,
• the pointer to the Event Generator class, which is used to generate immediate ev ents, and which will be of use in determining if delayed events should be added to the collection
• coAbsDelEvent w ill handle sending the notification request to the DEPMS in its destructor Prev iously, it was thought that vve needed some kind of postClose behavior to do this, as w e w ant this request sent after the app lock is turned off on the TO, but before the object is out of memory Putting this behav ior in the destructor is the πght way to handle preRe ov e on this class w ill fail if the delayed e ent collection *s not empty, i.e you should not be able to remove a tπggeπng object if it has outstanding delayed events that have not yet been processed.
5 Delaved Event IPS Details
The delayed event IPS w ill inheπt directly from fdSublnst It will be a standard subordinate, contained in a persistent collection. This object also belongs in the Resource MOB
See Figure 12 Delayed Event IPS Inhentance hierarchy diagram
5 1 Delayed Ev ent Attπbutes Order line number
Delivery line number event source ( I e Ordeπng site. Inv entory site, Inv oicing site. Other) event ID system event flag (yes or no) last successful action completed value
6 Delaved Ev ent Processor Design Details
Oπginally, I was thinking that the DEP would be an ATL wizard generated automation server It is possible that it could be wπtten entirely in VB This option will be explored duπng implementation time
6 1 Delayed Ev ent Processor API and Behavior lnitiahzeO
This method w ill retnev e from the PROTEAN INI file the notification re-try count and the maximum delayed event count and store these v alues in internal v aπables for use dunng processing executeQ
This method will initiate all of the logic that is outlined in Section 3.1.2.1 Application Processing Details
Additionally, there will be v arious priv ate methods to handle the necessary processing steps, including methods for each of the system ev ents to be processed bv the DEP. 6 2 Delay ed E ent Processor attributes
The DEP will use the follow ing attπbutes to keep track of processing
• logging flag - read from OAD for the tnggenng object, used to deteπrnne if processing details should be wntten to a log file during v anous processing steps, maximum re-try count - used to determine if a processing notification request should be resubmitted maximum ev ent count - used to determine if vv e hav e exceeded the maximum number of delayed events to indicate that delayed ev ent processing has led to a processing loop
7 Persistent Eπor Object Details
There ill only be one PEO that will be used by all tnggenng objects The PEO maps to three separate database tables 1 ) the PEO IPK table 2) the persistent message IPS table and 3) the persistent message parameter IPS table If vv e find ov er time that there is contention on these database tables, we can create an additional PEO IPK (w ith coπesponding subordinates) to partition the usage of the PEOs among v arying tnggenng objects The PEO objects ill also be in the Resource VOB
See Figure 13 Persistent Eπor Object Inheritance hierarchy diagram
7 1 Persistent Eπor Object API and Behavior
The PEO's behavior is defined in Section 3 1 2 4 Eπor Handling Considerations
Section IV - Order Automation User Interface Design
J Introduction & Scope
This Section covers the User Inteface design of the Order Automation definitional objects Order E ents, Order Actions, Protean Documents and the Order Automation Designer (OAD)
The basic product requirement that order automation must satisfy is customers' flexibility in processing an order The life cycle of a customer order consist of a series of actions and ev ents that are performed on it Order Entry, credit checking, order approv al are some of the actions and ev ents that can be performed dunng the life cycle of an order The sequence in w hich the order's ev ents and actions are performed may v ary from customer to customer For examole. for most orders the inv oicing activ ities occur as α result of a shipment How ev er, w ith some orders inv oicing could occur prior to shipment (ad ance invoicing), and in the case of consignment orders invoicing occurs after the customer has used the resource. The order automation design allows the user to configure the lifecycle of an order The user is able to define the normal actions and ev ents that occur in the lifecycle and the sequence in which the actions occur Events identify the activities or steps that occur dunng the life of an order, such as a user releasing a hold. Events can be categoπzed as a change to the lifecycle, attπbute value, hold or status
The response to each event is represented as a collection of actions to be performed in the defined sequence Actions identify the processes or updating performed by the system such as credit checking, venfying av ailability, or pπnting an acknowledgment
In Figure 14a hen the Delivery Shipped event occurs, two actions are tnggered first a shipping advisory is generated, then a pick list is produced
Not only does order automation prov ide a flexible architecture, it easily allow s users to plug in their own logic For example, if a customer wants to use a customized invoice, they simply create an Invoice action, which references the customized API When defining the order automation, they reference their custom Inv oicing action instead of the a predefined Invoicing action.
Not surpπsmgly the concept becomes more complex when supporting automation at physically separate sites In a distributed environment the site where the action will occur must be specified .
In Figure 14b, an event, Deliven Shipped, has been defined with tw o sources the ordeπng site and the shipping site When the delivery is shipped, two actions are triggered a Pick List is generated at the shipping site using the expected shipment object and a Shipping Advisory is issued from the ordeπng site using the order object.
Through the Order Automation Designer the user can sequence the order that actions are invoked. But as the abo e example illustrates, the sequence for processing an ev ent with multiple sources might be different than that defined on the order automation definition. So, ev en though the user may set up an order automation definition to create the Shipping Advisory first, then the Pick List, the outcome is the same as if the user defined the Pick List to be generated first. The Order Automation Designer ooject has its ow n lifecy cle An automation is initially established as inactn e allowing the implementation specialist to test the automation When the automation is ready for production, the OAD is updated to reflect that it is acm e at which point the automation definition becomes protected — events and actions can no longer be added or deleted Additionally, the effective date controls which Order Automation Designer (OAD) is selected for an order
See Figure 15 Order Automation Designer storyboard
2 Design Overview
2 1 Order Ev ent UI
A base product may be contain a number of predefined events In addition to predefined ev ents, users may generate their own custom events It should be noted that there w ill be a number of ev ents (refeπed to as system events) that are hard coded in the system and happen regardless of the order automation definition Update Deln en to Expected Shipment might be one such system ev ent System ev ents are not available to users and do not display in the cabinets Pre-defined events cannot be maintained or deleted
See Figure 16, show ing an Order Event user interface screen for the illustrated embodiment
See Table 1 Order Ev ent Behavior Table That table, as well as the other tables refeπed to herein, are filed as an attachment hereto
Once the ev ent is sav ed, all attnbutes become protected, essentially all attnbutes are one shot
• For this reason the Save As dialog should allow the user to change the user key values, as our standard
Figure imgf000105_0001
e as dialogs do, in addition, it must allow the user to enter a Ev ent ID A
Figure imgf000105_0002
e As of a Protean prov ided event will blank out the Provider and set the custom flag to on
• The Event UI will have a standard Admin Tab 2 1 1 Eπor messages for Order Event UI
See Table 1 Eπor messages for Order Ev ent UI 2 1 2 Cabinets
The order ev ent should hαv e a prompted query on name, ev ent source and custom flag The order automation definition requires an order ev ent cabinet: e should be able to reuse the above cabinet.
Neither cabinet should allow users to delete predefined events. Through referential integrity vve will prevent users from deleting events that are cuπently referenced by other objects .
2.1.3 Menus
There are no specific menu items for Order Events.
2.2 Order Action UI
Like events, a number of base-product, predefined actions can be provided for the cuπent list of predefined actions. Predefined Actions are read only, except for the Active flag (defaults to on). Predefined actions cannot be deleted.
See Figure 17, showing an Order Action user interface screen for the illustrated embodiment.
See Table 2: Order Action Behavior Table
2.3 Protean Document UI
A Protean Document is the Protean definitional object which describes the capability of a specific OLE Automation server invoked by the document messenger facility to create a document. Order Actions that generate a document, i.e., the automation server indicator is set to document messenger
Figure imgf000106_0001
must reference a valid Protean Document. When defining an OAD an Action is referenced, which in turn references a Protean Document. Since a document is always reference through an action, it is not necessary to have overlapping attributes on both objects; attributes such as the active flag and custom level help will appear only at the Action level.
Figure 18 shows a Protean Document user interface screen for the illustrated embodiment.
See Table 3: Protean Document -Basic Tab Behavior Table
2.3.1 Eπor messages for Protean Document Basic Tab
See Table 4: Eπor messages for Protean Document Basic Tab
2.3.2 Cabinets
• The Protean Document cabinet should have a query set to display all Protean
Documents. 2 3 3 Menus
There are no specific menu items for Protean Documents
2 4 Order Automation Designer
Figure 19 shows an Order Automation Designer UI user interface screen for the illustrated embodiment
The default for v iewing existing definitions is to show just the ev ents not expanded
See Table 5 Order Automation Designer UI Behavior Table
Figure 20 show s detail panels for the Order Automation Designer ev ents and actions
Figure 21 shows the effect of adding an event to a tree in the Order Automation Designer
We do not v alidate against duplicate actions -ev en duplicate actions w ithin the same ev ent It is possible (though not probable) that a user might want an action to be kicked off tvv ice For example, a custom document needs to pnnt at both the ordeπng site and the shipping sit Such a scenaπo could be achie ed by adding the action twice to the same ev ent w ith different tnggenng sources
2 4 1 New Versions
Users may use an 'Effective From' date to take a snap shot of Order Action Designer at any given time An Automation (without an effective date) will be assigned to a Market Profile When entenng an order, the most recent automation that is active w ill be assigned to the order
This prov ides the ability for an Order Automation to retain a specific name (e g Vv almart) and be assigned once to a Market Profile(s) The use of an effective date (instead of the oπgmal plan to create a new O D with a new name every time a change occuπed) w ill ensure that the user can define versions of this one OAD and minimize the amount of 'ripple-through maintenance that they would hav e to do, e g , to Market Profile's
Possible scenano
User creates OAD with an effective date (e g November 1 7, 1997) and assigns it to a Market Profile It is not flagged as 'Active', meaning that changes can still be made against this OAD, its actions and its events W hen flagged as 'Activ e', further additions deletions to the OAD are prohibited This OAD w ill remain in effect until such time as another, same name, later Eilecti e Date . activ e OAD, comes into oeing See COM Oi aei luto ation Definition, for further information on testing OADs 2 4 2 Cabinets
The Order Automation Designer cabinet should hav e a prompted query on Name, effectiv e date and the Activ e flag
• The Order Automation Designer requires an order event cabinet with a prompted query on source
The Order Automation Designer requires an order action with a prompted query on source
2 4 3 Menus
The Automation menu w ill hav e items allow ing Addition of Ev ents and Actions, as w ell as nav igation to the Order UI See Table 6
Section V - Order Automation Definition
J Introduction
This Section cov ers the design of the order automation definition object It is this object that defines how specialized operations of a customer order object w ill behave The order automation definition object is where events in the order's lifecycle are mapped to the actions inv oked in response by the order automation server
The order automation definition object supports multiple v ersions of an order automation definition being in use at the same time This supports the reality that our customers face in changing order processing policies New orders can follow the latest policy , while existing orders can continue to follow the policies in effect at the time of entry into Protean
The order automation definition object does not make a distinction between an ev ent or action prov ided with the base product from those extensions made by our customers An example incorporating multiple kinds of events and actions is presented to illustrate this concept
3 Design Ov erview
The order automation definition object is used by the order automation server to determine the processing a giv en order follow s An order object references the order automation definition by user key The assignment of the order automation definition occurs dunng the creation of the order object.
The order automation definition object provides controls to assist in its availability to new orders as descπbed in the following sections covenng its lifecycle and v ersions Later sections present the data model, its attnbutes and validation rules, as well as the class hierarchy
3 1 Object Lifecycle
An order automation definition follows a simple, prescπbed lifecycle. as seen below in Figure 22 The inactive/ active lifecycle states provide our customers with a means to manage the impact changes may have on their organization A new definition is created in the inactiv e state Once approv ed for use, the order automation definition is activated Finally, it cannot return to an inactive state once it is made activ e
After a peπod of use, changes to order processing policies may call for a new v ersion of the order automation definition An existing definition can be saved as a new version ith a different effective- from date in an inactive state Orders created with the previous version continue to use that version After all referencing orders have been removed, the unused definition may be removed
One thing to note about the active state — it is not used by the object to prev ent any processing If a valid order automation definition object can be saved, it can be used These states are for the conv enience of objects referencing an order automation definition For example, the new order dialog will not allow the user to select an inactiv e order automation definition
3.2 Versions
Figure 23 shows a timeline for multiple order automation definition versions O er time multiple versions of an order automation definition can exist Versions are supported by having a different effective-from date on objects w ith the same name As seen in Figure 23, a typical sequence of events might be
1 Create a new , inactiv e order automation definition (v ersion 1 is named Def Ul/97)
2 Build and test the new definition
3 Activ ating the definition makes it av ailable for use w ith new orders 4. Order processing policy changes are identified.
5. Create version 2 (named Def:6/l/97) of the order automation definition from the cuπent version .
6. Implement and test the order processing policy changes.
7. Make version 2 of the order automation definition active, and therefore available for new orders.
8. Orders created with version 1 will continue to operate against that order automation definition.
9. All references to version 1 have been removed, and the order automation definition is removed.
3.3 Defaulting From Market Profile
The market profile will only store the name, not user key, of an order automation definition. When validated, the market profile will query the database to determine that there is at least one active order automation definition with this name.
At runtime, when the market profile is asked for the user key to the order automation definition to default onto the order, a query will be made for the active order automation definition cuπently in effect.
3.4 Testing Order Automation Definitions
When a complete environment for testing the automation definition for a customer order is considered, there are potential interactions with both the inventory and fmancials modules that cannot be faked. Every module must be operational in a test environment in order to prove that the order automation definition built will satisfy the specified order processing requirements.
Therefore, the recommendation for testing order automation definitions is to use a snapshot (or backup) of the "live" database as the "test" database. Having this parallel database is the best way to prove the operation of the order automation definition without compromising our customers' data.
In anticipation that many versions of an order automation definition will be created for testing, it is recommended that the first version created have an effective-from date far in the past. This allows a new version to easily supersede the earlier version with eπors. 3 5 Example Order Automation Definition
An example order automation definition is presented in Table 7 A descnption of each ev ent and its actions follow The goal of this example is to demonstrate how the base functionality of the product can be combined with extensions to provide a custom order automation solution
The example is based on an order process which takes customer orders usually 30 days prior to the promised ship date (perhaps due to manufactuπng lead time) Also, one day pπor to shipping taking place a credit check is performed If a credit hold is placed on the order, a custom action (notify credit manager) is performed When a credit hold is released, another custom action is performed (notify shipping clerk hold released) and shipping activ lty may proceed
Note Remember that ev ents are independent of order The user can aπange the e ents in w hatev er order seems logical to them Actions, howev er, are executed in the order defined
See Table 7 Example Order Automation Definition
3 5 1 Order Created
This ev ent has only one action defined which is to πin a credit check Both the event and the action here are provided ith the base product
3 5 2 Deliv ery Entered
Once an order delivery line has been entered, av ailable to promise (ATP) and deli ery based pncing are performed Both the ev ent and the actions mentioned here are prov ided w ith the base product
3 5 3 Order Entered
Once order entry is complete (saving the order and closing it for the first time) a set of actions are performed, all at the ordering site, this event is defined as part of the base product The price order, tax order and apply discounts actions are part of the base product
The queue preship credit check is a custom action that uses the ev ent queue API to enter a time- based ev ent to occur 1 day prior to the promised ship date on the order dehverv
Send order acknow ledgment is a document messenger action, which some amount of custom w ork is required 3 5 4 Deliv ery Reserved
This ev ent is base product functionality Pπnting the pick list is a document messenger action which requires some amount of custom work
3 5 5 Order Reserved
This ev ent is base product functionality Sending the adv anced ship notice is a document messenger action which requires some amount of custom work
3 5 6 Delivery Shipped
This event is base product functionality Pnnting the bill of lading is a document messenger action which requires some amount of custom work
3 5 7 Order Shipped
This ev ent is base product functionality The lock pπce and generate inv oice actions are also base product functionality Pnnting the invoice is a document messenger action w hich requires some amount of custom work
3 5 8 Preship Credit Check
This is a custom event It is also a time based event, winch was placed in the event queue by the queue preship credit check action The credit check action is planned base product functionality
3 5 9 Order Hold Applied
This ev ent is base product functionality The test for credit hold applied action is custom, it looks to see if a specific hold code (indicating a credit hold) has been applied to the order This customer-defined hold code w ill prev ent shipping activ ity from occumng The custom action could be coded to send the credit manager handling this customer an alert v ia M.API (Messaging Application Programming Interface)
3 5 10 Order Hold Released
This event is base product functionality The test for credit hold released action is custom, it looks to see if a specific hold code (indicating a credit hold) was released If so, it also looks to see if any deliv enes on the order w ere promised for today or in the recent past If there w ere missed shipments due to a credit hold, then the shipping clerk is notified v ia MAPI The assumption is that the shipping clerk assembles shipments once a day and may be able to expedite those ith (credit) holds released later in the day Data Model
4.1 Order Automation Definition Structure
The structure of an order automation definition is an object with two levels of collections, as shown in Figure 24. The first level subordinates are the customer-specified collection of order events requiring a response. The response to each event is represented as the collection of order actions to be invoked in the defined sequence.
Each order object has a required UK to its order automation definition object. Both the collection of events and actions are just subordinates containing a single attribute, the user key to its associated definition object.
4.2 Attributes
Once active, no attributes may be changed except those noted below, 4.2.1 coAutoDef
1. Name - A 30 character string that is part of the user key.
2. Effective-From Date - A date (bcDateTime) that is part of the user key.
3. Extended Description - A 256 character string to describe the order automation definition in more detail.
4. Hold Code - An embedded user key of the hold code to be applied to the order summary if any eπor occurs in processing an order event. This is also known as the order automation administrative hold. This is a required attribute,
5. Active - A Boolean value, which when true is active, and when false is inactive. Once an order automation definition is made active it can never become inactive. To make an order automation definition active from the UI, validation should be run first.
6. Order Events - The collection of selected order events requiring a response.
7. Audit Trail - A Boolean used to indicate whether an audit trail history for this definition should be generated. This history information provides the start and end date and time of an action, what order and event caused it to occur, the duration of action, and the user causing the event. This is helpful in debugging an installation of the order automation definition, and after it has been running, analyses can be used to determine potential bottlenecks and order processing cost information. Can be modified when active.
8. Administrative Site - A required reference to the site where this object is maintained. Defaults from the user's default site: 4 2 2 coEv entSub
1 Name - From the contained UK to the coEventDef object
2 Order Actions - The collection of order actions invoked as a response to this ev ent Order actions are inv oked in collection defined sequence.
4 2 3 coActionSub
1 Name - From the contained UK to the coActionDef object
2 Respond On Event Source - This attπbute only applies for actions associated w ith ev ents having multiple sources This enumerated value defines which event source will cause this action to be invoked For example, an event can be defined to have ordering and shipping sources, and an action defined to be operable for both as well. The order automation definition must specify which ev ent source the action w ill respond Otherwise it w ould be possible for the same event at each of its multiple source to cause multiple responses . w hen only one is required In fact, it is potentially a problem if an action were to be triggered multiple times for the same event (a w arning is given if this is (detected) When only one ev ent source is defined, this source becomes the default for this attnbute When multiple sources are possible, this attnbute is defaulted to none, forcing the user to make a selection
3 Event Handling - An enumerated value (same as defined by the event definition object) of NotUsed, Immediate, and Delayed. For shipping, invoicing, and other ev ent sources this v alue is always delayed For ev ents defined for the ordering event source this v alue is copied from the coEventDef object, and the user may ovemde an immediate ev ent to be delayed, but is restncted from overnding a delayed event to be handled as immediate
4.3 Validation Rules
1 The effective-from date must be unique This is enforced by being part of the object's user key If an effective-from date before today is chosen, a w arning is returned.
2 An order automation definition must have at least one event defined.
3 Each event must have at least one order action defined
4 All ev ents on the order automation definition are unique If adding a duplicate is attempted, it is ignored and a cπtical eπor returned
12 5. Actions are allow ed to be duplicated on the order automation definition, even within an event. Warnings are returned when duplicates within an event are foumld.
6. All references to objects must be valid (coEventDef. coActionDef, coHoldCode, and administrative site).
7. Warnings are returned for any referenced actions still in an inactive state. The order action server will not execute inactive actions.
8. Each order action definition must be appropriate for the selected event source. For example, an order action that is only defined for ordering event source cannot be selected for use with a shipping event source. This can be detected when adding the action to the collection on the event, and a critical eπor is returned.
9. The values for Respond On Event Source on a coActionSub are enabled based on the intersection of the Event Sources from a coEventDef and the Valid Event Sources from a coActionDef. From this list, only one value can be selected. For example, if an event has the ordering, shipping, and invoicing event sources, and an action has the ordering and shipping event sources, only the ordering and shipping choices are the only possible selections.
10. For those eases where an event has multiple sources, a warning (UDS) message is returned to the user when the sequence of the actions will be executed differently than specified.
1 1 . For a new order being saved - The order must have a valid UK to an active order automation definition.
12. Events defined to be handled immediately are restricted to be combined only with actions defined as functions. Therefore, if the selected event source only supports delayed event handling (this is always true for shipping, invoicing, and other event sources) then the selected action definition cannot be used if the automation server indicator is set to function server. Furthermore, an event defined as an other source (always handled delayed) cannot be combined with a defined action where its automation server indicator is set to document server.
5. Hierarchies
The order automation definition class. coAutoDef. is an IPK and therefore derived from fdGenlnst. The coEventSub and coActionSub classes are IPSs and are derived from IdSublnst Both ot these classes can oe seen in Figure 25, sho ing order automation definition objects class hierarchies
Section \ I - Order Automation Event Relerence Document
1 Introduction
This Section is to be used as a reference for the Order Automation dev elopment and implementation of the COM project It identifies the predefined events that can be provided w ith the illustrated embodiment Attached to each event is a descπption, an indication of ev ent process type and ev ent source 1 1 Object Types
Ev ents are broken out by object type This is an indication of the container w ithin the set of order-related objects, from which the ev ent is generated We hav e the follow ing set of types
Order - order summary Line - order line
Delivery - order delivery, expected shipment or billing memo Invoice Charge Discount Tax
Letter of Credit Comment- Address
The object type should not be confused with ev ent source, which uses similar categoπzation (order, shipping and invoicing) The Event Source, as descπbed below, indicates the type of scenaπo - an order entry/maintenance session, a shipping activity update, an inv oice cancellation, dunng w hich the ev ent can be generated 1 2 Major vs Minor
Sev eral elements make up the ev ent process type First is a categorization by major and minor ev ents Major ev ents represent an ev ent that cov er states changes of an object as a whole A major ev ent does not discern what has been updated on the object in question, it simply knows that some attπbute of the target object has been updated .Vlinor ev ents cover the individual attnbutes of an object A minor event not only tells us that there has been some state change on the target object but also gives us an indication of what attπbute has been updated
Therefore it should be apparent to the reader that a single update of an object, for instance the ship-to trading partner of an order delivery, generates two events, one major (Deliv ery Maintained) and one minor (Ship-To Trading Partner Updated) One other note about major and minor events When a user opens an object for change, such as an Order Deliv ery, they may update several attnbutes of the same object dunng the one session, It is the expectation of this project that in this instance we would receive a minor event for each of the attributes modified, but only one major event to cover the containing object
For instance the ev ent set generated during the maintenance of the following deliv ery
Order 123, Line 1 , Delivery 1
Attπbute Was Change Event
Quantity 100 90 Delivery Quantity Updated (minor)
Ship-To Trading Partner
001 003 Ship-To Trading Partner Updated (minor)
Deliv ery Pπoπty
5 3 Delivery Pπoπty Updated (minor)
Delivery Maintained (major)
1.3 Process Type
The next level of grouping indicates whether the listed event should be treated as an immediate ev ent or as a delayed event.
The application of rules here help in the immediate vs. delayed decision
1 All ev ents w hen generated from an object other than the order object, are treated as delayed ev ents This allow s functions such as shipping and invoicing to complete their updates w ithout incuπing the processing 'expense' of immediate ev ents Also as the objects that are generating ev ents (expected shipment, invoice, billing memo) are less dynamic and tangible than the order, users snould not feel that they are losing accuracy concuπency oy using delayed ev ent processing
2 All major events are candidates for delayed ev ent processing More importantly, minor events are always immediate, when generated from the order It is our view that a minor event, such as the update of an indiv idual attnbute, is the likely time that an additional in- process operation will be needed The generation of a major event represents more of a milestone, one which can be acted on outside the cuπent process A major event should signal that 'the big picture' has changed, hence, what do vv e need to do to synchronize other information (reports, associated objects, extracts etc)
Can a major ev ent ever be an immediate event0 The only instance recorded herein are the 'Deliv ery Validated', 'Line Validated' and 'Order Validated' (and the coπesponding '\ alidation Fail') events These are flagged as immediate to giv e us the opportunity to attach custom v alidation
1 4 Event Source
The final attnbute in the User Event table is the Source attnbute This indicates w hich of the order-related objects (or group of objects) can tnggers the named ev ent, The event source codes '0', 'S' and T represent the order, shipping (expected shipment) and inv oicing (invoice & billing memo) aspects of a customer order
Note that certain events, such as 'Unit Pπce Updated' can be sourced from the order and from shipping The shipping source for this would be the update to the expected shipment Unit Pπce attπbute This itself would be initiated by a change to the unit pπce on the coπesponding order delivery This update would in turn be detected and processed by a system action server and conveyed as an update to the coπesponding Expected Shipment
1 5 Special Considerations for Event Generation/Management
1 5 1 Suspended States
Dunng the entry of an entire order, or during the entry of a deliv ery, the user has the option of setting the order or delivery state to SUSPEND The suspend state allow s a user to complete the task of entering the order or deliv ery, w ithout necessanly hav ing all of the v alid data defined When the order object detects a suspended order or deliv ery , v alidation is by -passed It is also necessary to prev ent any ev ent generation for a suspended order or delivery Because of the circumstances suπounding the suspended state the following maybe true,
1 Order or deliv ery has not yet performed related defaulting At the order lev el this would mean that no Order Automation definition had been retnev ed and hence no event processing could occur
2 Order or deliv ery v alues may not be coπect W;ιth this being true, any events & actions would generate unpredictable & undesirable results
When a suspended order or deliv ery is set from SUSPEND to ENTERED, then all events that would be generated dunng the normal entry of the order or delivery should be invoked
Note When an order is suspended, all of its deliv enes are also considered suspended
Note A suspended delivery can exist on an ENTERED order amongst ENTERED delivenes
Note Once an order or delivery has a state of ENTERED, it cannot be suspended
1.5 2 Removing Delayed Events
Dunng an order session, a user may perform a senes of steps that generate a host of delayed events. If the user, before saving the modified order, decides to cancel all changes (using close without save or deleting a delivery that was being entered), then it is imperative that the queued delayed events are not persisted
2 User Events
A user ev ent is defined as an event to which the designer of the Order Automation definition can attach actions These are typically reported following a state change in an attnbute, collection or containing object. . Svstem Events
These system ev ents are used to control the life-cycles of objects w hich the user has no direct control ov er (billing memos and expected shipments) The control is spaw ned from the customer order object As opposed to user ev ents which are reporting the occuπence of some ev ent, a system ev ent is the report of the need to perform a predictable sequence of actions - create biihng memo, delete expected shipment. Automation designers cannot attach actions to system events.
All system events are DELAYED.
See Table 8.
4. Custom Events
A third class of event is the Custom Event. These are defined, designed & created outside
COM during the implementation. By allowing custom events, COM allows users to trigger events based on User Interface gestures, updates to external objects, add-ons and so forth.
Section VII - Order Automation Event Definition
1 Introduction
This Section describes the design of the order automation event definition object for use by the Customer Order Management module. One goal of this design is to provide a means by which parties outside of the Protean lab can extend the base product functionality by adding new event definitions that can be included in an order automation definition. Another concern of this design is to support the creation of meaningful order automation definitions in a distributed configuration built on the forthcoming enterprise management facility.
3_. Design Overview
This design presents the sources of events and the definition of these events. Events are used in an order automation definition to cause a user defined sequence of order actions to take place. The major topics covered by this design are the sources of events, the categories of events, sequence of event generation when multiple sources are possible for an event, and a description of system versus user events.
3.1 Sources of Events
Order automation events come from a small number of different sources. The most obvious of these of course is the order object itself. However, to be effective as a complete solution for our customers, we must consider the entire scope of the order process, from entry, through delivery, to invoicing. Each step possible in a order process must be capable
18 of generating order automation events to allow proper actions to be taken for a specific customer's operation.
Another consideration in classifying order automation events is the distribution of the application itself. The design goals for COM are to allow configurations where order taking, shipping of inventory, and invoicing can take place in geographically separate locations, each of
Which may work with different physical Protean databases, loosely connected by the enterprise management facility. This distributed configuration is shown in Figure 26, and will be used by our larger market customers. A range of product configurations are possible, for example on the other end of the scale a customer may have all operations within a single site and Protean database.
To recognize that not all classifications of event sources have been identified an additional classification of other exists. These four classifications (ordering, shipping, invoicing, and after) are used to validate the construction of an order automation definition as certain order actions may not support certain event sources. These classifications are also used by the order automation server at runtime to verify whether a received event is valid for the object and site where it was generated.
3.2 Categories of Events
Stepping down a level from the big picture of the event sources is the categories of actual order automation events. The following sections describes specific events that are generated by the base product which can be incorporated into an order automation definition. By being available for inclusion in order automation definitions we distinguish these as user events, which are differentiated from those described later in Section 3.4 System Events.
As a quick preview the categories of user events are:
• Lifecycle
Attribute Value Change
* Hold Change Status Change
As mentioned before, the customer (or any party outside of the Protean lab) can define events to be used in addition to or separate from the defined ordering, shipping, and
19 invoicing events This capability is prov ided to giv e an order automation implementation specialist some leeway in constructing and using order automation in ways not cuπently env isioned
3 3 Event Generation Sequence
In review ing the tables of events in the previous section, the reader may hav e noticed that a few events have multiple sources This is to support a distπbuted environment where it is important to perform an action in response to an event at that source It also simplifies creation of order automation definitions
For example, instead of hav ing multiple events like O/dei Deln en Shipped and Expected Shipment Deln en Shipped there is one event Deln en Shipped w ith sources of ordeπng and shipping The order automation implementation specialist w ill nev er be required to hav e a deep understanding of the entire Protean architecture just to create an order automation definition Our definition objects should just work together to help guide proper construction of an order automation definition
With that stated as a pnnciple guiding the design, an order action ser er for creating a pick list should be able to operate on information av ailable only at the shipping source This pick list action can be tied to a Deliven Shipped event in an order automation definition since this event has multiple sources, shipping and ordeπng An order action defined to work only with ordeπng event sources e g , transmit adv ance ship notice, can be added as α second action to the Deln en Shipped event The only question w ith ev ents hav ing multiple sources is hat sequence are the order actions executed
In general, in the-sequence defined by the user However, w ith multiple sources for an ev ent, the sequence is defined by the event source in user defined sequence Therefore, at validation time on the order automation definition the user will be given a warning that the actions will be executed in sequence different from the way they appear
Why9 This has ev erything to (It) with the multiple sources themselv es, l e , w hich object is the oπginal source for an event, and which objects repeat the e ent The follow ing example should help to claπfy this
3 3 1 An Example of Ev ent Generation Sequence
As an example of an ev ent with multiple sources, consider the Deln en Shipped ev ent At the shipping site it is important to know that an expected shipment has been snipped so that a bill of lading can be generated At the ordering sue a shipping adv isory document is generated and transmitted to the customer's buyer (order-by trading partner on the delivery)
The sequence that these ev ents occur are shown in Figure 27
1 From a shipping activity form, the shipped quantity for a deliv ery is entered The expected shipment is then updated w ith this v alue, and since the quantity shipped is at least the quantity requested, the shipped flag is set Setting this flag causes the De//veπ Shipped event to be generated at the shipping site ( A Quantitx Shipped Changed event is also generated when that is modified, but is ignored in this example )
2 The Gene/ ate Pick List action is tied to the Deln en Shipped event in the order automation definition assigned to this order (and also earned on this expected shipment) This action is defined to only operate w ith a shipping source The order automation serv er at the shipping site is responsible for inv oking this order action
3 The Enterprise Management facility picks up the changes from the shipping site and updates the attnbutes on the coπesponding expected shipment object at the ordenng site Since this is not the shipping site, no shipping site events are generated as a result of this update Howev er, a pnvate system event (update Deliven From Expected Shφmentjis sent to the order automation server at the ordenng site, as these are attnbutes that are also maintained on the order deliv ery line See Section 3 4 Sxstem Events for more information
4 When the system order action serverS at the ordenng site updates the deliv ery line from the new information on the expected shipment, the Deln en Shipped event is generated at the ordering site (The Ouantin Shipped Changed ev ent is also generated, but again is ignored in this example )
5 The Trans/nit Shipping Advison action is also tied to the Delnen Shipped ev ent in the order automation definition defined for this order This action is defined only to operate w ith an ordenng source The order automation serv er at the ordenng site is responsible for inv oking this order action The order automation server ignores all but the ordering source actions in the order automation definition For this example, the Pick List action is skipped The point of this example is to show that actions tied to an event w ith multiple sources are processed in the sequence defined by the event So. even though the user may set up an order automation definition in following two ways
1 Deliv ery Shipped Generate Pick List. Transmit Shipping Adv isory
2 Deliv ery Shipped Transmit Shipping Advisory. Generate Pick List the outcome is the same Generate Pick list. Transmit Shipping Advisory Howev er, this is a simple example
3 4 System Events
The ev ents descπbed in the preceding sections can be classified as user ev ents That is. events that users can tie to actions in their order automation definitions There exist a number of actions to ev ents w e w ant to always happen regardless of the order automation definition in use A system ev ent is one of a select number of ev ents that the order automation ser ice can respond w ith an action directly System ev ents do not hav e a definition object stored in the Protean database, they are hard-w ired into the code where they are generated and w here they are processed Another w ay to look at system ev ents is that without them, billing memos and expected shipments are not created and updates to these objects are not transmitted back to the order
While potentially outside the scope of this Section, a specialized order action server for handling system events is known as a system order action se e In this example, the system order action serv er identified is the expected shipment-to-order update serv er, which is responsible for moving changes from the expected shipment to the appropriate delivery line on an order
One such system event w as identified in the section abov e. Update Delnen From Expected Shipment When the order automation serv ice receiv es this event, it w ill alw ays inv oke a system order action to update the order delivery line w ith the changes made to the expected shipment object by the enterpnse management facility In this case, the Update Deln en From Expected Shipment ev ent is queued for later processing, it is not handled as a synchronous operation w ithin the expected shipment update
The key point to this section is that a number of system defined ev ents and actions exist and are part of the order automation sen ice These allow us as the dev elopers of the software to take advantage of the architecture and decouple some of the functions that must be performed.
3.5 Timing Of Event Handling: Immediate Or Delayed
Some refinement in our understanding of event processing requires attributes for declaring when an event is processed after generation at a specific event source. This attribute is used in combination with an order action definition's process type attribute ( function, transaction, or document) in determining whether the event/action pairing can be established on the order automation definition.
When marked as handle immediate, the event processor invokes the actions associated with this event on the order automation definition at the time of event generation. However, when marked delayed, the event is queued for later processing (also known as delayed event processing). A feature of the order automation definition allows overriding an event marked as immediate handling on its definition to be handled as delayed.
Immediate processing is found with objects that a user may interact with, such as the order object. As a result, system related objects like a billing memo or demand memo that have no direct user interaction always generate delayed events. Therefore, events generated at a Shipping, in voicing, or other source always have delayed handling, and only the ordering event source allows a choice between immediate and delayed event handling.
While never seen in an event definition object, system events as previously discussed, are alvvavs generated as delaved events.
3.6 Controlling Access To Order Event Definition
The order automation event definition user interface tool is like any other Protean desktop tool in that it must be available on the user's workspace. An administrator can control what tools are in a user's workspace. Therefore, access to the order automation event definition tool can be controlled by providing it to selected individuals.
4. Data Model
The order automation event definition object, as seen in Figure 28, is a simple IPK which is referenced from an order automation definition.
4.1 Attributes
The order automation event definition object is a simple object with very few- attributes: 1. Order Automation Event Name - This is the unique user visible name for the object. This is 30 characters in length and is the user key.
2. Event Source - Set of four booleans to indicate that the event is generated by this source. One each for: ordering, shipping, in voicing, and other.
3. Event Sequence - Set of four integers. One for each event source. Determines the sequence events are processed when multiple sources are defined. Not used if only one event source is defined .
4. Event Handling - An enumeration that identifies the event handling for an event generated at an ordering event source. The enumerated values are: NotUsed, Immediate, and Delayed. The value of this attribute depends on the value of the coπesponding event source Boolean.
5. Event Identifier - This (unsigned 32-bit) integer value provides another unique as well as language and (Protean) database independent way to identify an order automation event. This attribute (as the first part of the unique index) along with the custom event attribute avoids conflicts in event identifiers between Protean and custom defined events. Protean event identifiers are from an enumerated list of C++ values.
6. Custom Event Flag - This is a Boolean value used to indicate whether this event was provided as part of Protean or was custom installed. This is used with the event identifier as a unique index. This flag cannot be modified by the user .
7. Event Provider Name - This 30 character string allows the provider to take credit for installing the event. For base product events this attribute will be set to Protean.
8. Administrative Site - A reference to the site where this object is maintained. Defaults to the riser's default site.
9. Help File Name - This is the name of the file which contains instance specific help for this order action. This is a file which must live in the installed Protean help directory on the client machine (same requirement as add-ons).
10. Help Context ID - A (32 bit) integer value which is required when a help file name is specified. This identifies which topic (the context) within the help file to display.
4.2 Validation Rules
1 . Since the custom event flag and event identifier make up a unique value, this should be verified prior to saving the object so that a reasonable message is returned to the user Otherwise a database data integπty eπor message will be returned, w hich w hile useful, doesn't really give the user the nght infoπnation
2 Also, once the object has been saved to the database no attributes can be modified All attnbutes are one-shot We should probably w rn the user (UI only issue) before saving the object that this cannot be changed once saved
3 Protean provided ev ent definitions (custom ev ent flag false) cannot be removed from the database Custom events can be removed as long as no references to the object exist
4 When multiple sources are identified for an event, the sequence must be valid In other words, multiple sources can not have the same sequence number selected
5 When the ordering ev ent source attnbute (a Boolean) value is TRUE, the ev ent handling attnbute must be set to either immediate or dekn cd The default is clekn ed
This unique identifier (used in conjunction with the custom flag) is the same no matter when the event is installed (avoids relying on order or where installed (relying on name which can be translated) A reasonable analogy is a UI resource ID for controls and static text
5 Hierarchies
The order automation even definition is a simple IPK As seen in Figure 29 it is derived from fdGenlnst
Section VIII - Order Automation Action Reference j Introduction
This Section lays out the standard Automation Actions which can be provided with an embodiment of the invention An action is some senes of steps that are performed in response to the generation of an Automation Event
In this Section we use the terms function, transaction and document to classify the actions This terminology is designed to help all developers and users of Order Automation understand the scope of an Order Action
Functions are intended to cov er those actions that extend a standard process This extension can take the form of calculation, data retriev l, attnbute updates against the cuπent object It is not env isioned that functions try to perform intπcate object updates or ev en save the cuπent object Instead they should operate w ithin the scope of the cuπent operation, and rely on that operation to perform the object life-cycle tasks. Although not limited to immediate events, all functions should be designed to operate as part of the in- process operation. As such their impact on the performance of the standard Order object should be considered measured during implementation.
Transactions are larger functions. A transaction must open, save & close all objects that are utilized with its scope. The primary role of the transaction is to perform cross-object updates, such as creating a schedule upon the creation of a new order. As a transaction expects to perform all of the life-cycle operations, including those against the triggering object, the Automation Definition tool will prevent users from adding a transaction to an immediate event.
Documents are those actions that generate some representation of information pertaining to an object - a report, an invoice, an instructional document. These documents can be derived from one or more object. Due to their nature, document actions are treated as a subset of transactions. As with transactions, a document will not be able to be tied to an immediate event.
This Section sets out the cuπently known order actions, the purpose of each and where each is invoked. The 'Location' attribute has three possible values. The location codes '0', 'S' and T represent the order, shipping (expected shipment) and invoicing (invoice & billing memo) sites that are found in a COM implementation.
This Section also describes what are known as system actions, These actions typically have a one-to-one coπespondence to system events. As with system events, system actions are operations that must be executed in order that standard COM objects remain in synch. As such each system action can be classified as a transaction.
Section IX - Order Automation Action Definition
_L Introduction
This Section covers the design of order automation action definitions for the Customer Order Management module. These actions can be configured to be executed in response to an order event. An order action as described here can be predefined, or it can be defined by the customer, or by a third party. This design describes the order automation action and Protean document definition objects. Specifically, the role these play as the link between Protean and an OLE automation server containing the business logic for an action.
3_. Design Overview
This design describes the order action definition and predefined document objects including their structure, attributes, and behavior. These objects are by nature definitional objects that can be included in an order automation definition. A customer can extend base product functionality by defining new, specialized order actions to be invoked during order processing.
Order actions are defined as a response to an order event. The map of events and their actions are held by the order automation definition. The order automation server is responsible for executing the action associated with an event.
Typically an order action definition maps one-to-one to an order action server (plug- in), however, the architecture allows multiple actions to be performed by a single plug-in. An invoked order action server has access to the event source object (via its MS COM automation interface), which τn-|nany cases is the Customer Order. The primary responsibility of an order action definition object is to provide a Protean representation of an MS COM automation object (or ActiveX object).
Features of an order action definition include:
• Order action server configuration control for identifying and connecting to a specific MS COM automation server.
• An optional argument string that can be used for additional configuration and control of the invoked order action server.
• Integration with the document messenger facility. 3.1 PreDefined Order Actions
The items listed in Table 9 define a set of order actions planned as base product functionality. This list is meant to be illustrative, not exhaustive.
3.2 Order Action Definition Lifecycle
An order action follows a simple lifecycle as seen below in Figure 30. The active/inactive states provide our customers with a means to manage the impact changes may have on their organization. A new order action definition is created in the inactive state. Once the associated MS COM automation server is approved for use, the definition is activated. Should there be problems, or policy changes necessary to implement, the order action definition can be deactivated.
Once placed in the active state, no attributes can be modified on the object, except for the changing the state back to inactive. When referenced by an order automation definition object, the associated order action automation server is invoked only when the order action definition is in the active state. Therefore, if an action is no longer needed by all existing order automation definitions, it can be deactivated without needing to activate new versions of the order automation definitions.
Assuming that at some point all order automation definition objects referencing this order action definition have been removed from the database, this object can be removed. (Only those objects marked as custom installed can be removed, those provided w ith the base product cannot be removed). After this point an uninstall program could be run to remove the associated order action automation server (and its registry entries) from all potential client machines.
While in either state, the order action definition can be saved as a new object in the inactive state.
3.3 Deploying Custom Order Actions
One of the key points of this design is to open the definition of order actions to parties outside the Protean lab. However, along with this valuable integration feature comes a software distribution challenge. This section outlines some issues an IC needs to be aware when confronted with deploying custom order action automation servers.
The MS COM automation server that implements the order action functionality must be installed on all potential client machines. Installation of an MS COM automation server requires the software (a DLL or EXE file) and entries in the registry. It is the custom order action servers provided after initial Protean installation that are the issue.
Once the MS COM automation server has been built and tested, it needs to be deployed to all potential client machines. We will provide guidelines for creating, testing, and installing custom actions along with recommending tools to accomplish these steps. As a general statement of direction, testing is to be done in a separate database so as not to
.28 effect the live production data. The test database is likely a snapshot of the live production database.
3.4 Functions And Transactions
An order action definition identifies itself as representing the capabilities of an automation server that can handle either a function, transaction, or a document (covered in the next section).
An action that identifies itself as a function intends to extend the operation of an object. It cannot have any requirements for maintaining consistency of changes with other objects, and it does not invoke any lifecycle methods (e.g. , save or close) on the object that generated the event.
Functions can be tied to immediate or delayed events, however the implementer must be aware of UI response impact when choosing to combine a function with an immediate event.
A transaction has a larger scope than a function. An action identified as a transaction is required when to maintaining consistency of changes across multiple objects. As a result, transactions are also provided access to the lifecycle methods of the triggering object. Transactions can only be tied to delayed events, In addition, the document messenger is intended to be a specialized, well known transaction, therefore documents are always tied to delayed events.
Lastly, actions defined as supporting the other event source can only be marked as transactions. Since this event source is a catch-all category, it is felt that this restriction is reasonable as the generation of the event may have nothing to do with any known Protean object.
3.5 Document Messenger Integration
This design supports integration with the document messenger facility by allowing a Protean document to be referenced along with the ProgID of a specific document automation server. When the order automation server is processing events for an order automation definition, and it sees that this action definition references a Protean document, it will invoke the document messenger server as the order action server. 3 6 Controlling Access To Order Action Definition
The order action definition user interface tool is like any other Protean desktop tool in that it must be av ailable on the user's workspace An administrator can control what tools are in a user's workspace Therefore, access to the order action definition tool can be controlled by prov iding it to selected individuals.
4 Data Model
As seen in Figure 31 , the data model for an order action definition object is relatively simple, it prov ides a Protean representation for a specific MS COM automation server It may reference a Protean document hen specifying a document messenger action in addition to naming an MS COM automation server A Protean document references an MS COM automation ser er and contains a collection of references to language codes
4 1 coActionDef
The follow ing sections describe the attnbutes and validation rules that the order action definition object contains
4 1 1 Attnbutes
1 Name - This is the unique user visible name for the object This required text attπbute is 30 characters in length and is the object's user key.
2 OLE Automation Server Name - This 256 character stπng is used by MS COM to identify a specific automation server (a ProgID is analogous to a Protean UK) This is the same stπng registered with MS COM that is used by the Visual Basic CreateObject function to gain access to the Automation Object
This is used by the order automation server to retπeve the GUID (or class ID) of the object from the OLE registry (via the CLSIDFromProgID() function) For example, the ProgID to invoke Microsoft Word version 6 is "Word Document 6" and the v ersion independent ProgID is "Word Document", which the registry ev entually maps to the cuπent v ersion
4 Arguments - Use of this stπng is defined by the action ser er This prov ides the ability to use the same MS COM automation serv er for multiple actions This is an optional 256 character length stπng
5 Activ e - A Boolean v alue, w hich w hen true is ac e and when false is inactn e Once an order action definition is made activ e, no other attnbutes mav be modified. Only this attribute can be modified in the active state so that it can be deactivated. When an order action definition is saved-as another object, this state defaults to inactive. The order automation server ignores inactive order actions during event processing.
6. Valid Event Sources - These four Boolean values indicate whether this action can be used to respond to an ordering, shipping, invoicing, or other event source. At least one of these values must be true .
7. Custom Action Flag - This Boolean value indicates whether this was provided with the base installed product (false) or was custom installed (true). This indicator cannot be modified through the UI. Only custom installed objects may be removed from the database. Save-as always sets this flag to custom.
8. Provider - This optional 30 character string allows the provider to take credit for installing this action. The objects provided with the base product will set this attribute to Protean,
10. Automation Server Indicator - This attribute indicates whether this order action definition is specifying an automation server for an action (function or transaction) or a document. This is an enumeration with values of function server, transaction server, and document server. This attribute is used by the order automation definition to determine whether an action can be connected to an immediate event.
11. Protean document - This is a reference (UK) to a Protean document to be handled by the document messenger. This reference is required when the automation server indicator is set to document server.
12. Help File "Name - This is the name of the file which contains instance specific help for this order action. This is a file which must live in the installed Protean help directory on the client machine (same requirement as add-ons).
13. Help Context ID - A (32 bit) integer value which is required when a help file name is specified. This identifies which topic (the context) within the help file to display.
4.1.2 Validation Rules
1 . The MS COM automation server name (ProgID) is required.
3. All references to objects must be valid (e.g., admin site and fdProteanDocument).
4. At least one event source must be specified. 5. If help file is specified, the context ED is also required.
6. If other is selected as a valid event source, the automation server indicator can only have a value of transaction. If a service from the plug-in design allows us to do this, we should also try to validate that the named MS COM automation server conforms to the order automation API. The additional validation that should be possible with this service includes:
1. Is the named server registered with OLE?
2. Does the server provide the required exposed automation methods to be compliant with order automation? This may differ for an order action server and a Protean document server.
3. In checking the exposed automation methods, we may also be able to check the number and name of the dispatched parameters.
Note: The more we can do to check for conformance with the order automation APIs at definition time, the sooner problems can be identified. The harshest way of going about this is to always generate a critical error message at validation time. If necessary we could back this off so that only while inactive UDS (User definable severity, which are predefined to a warning severity) warning messages are returned.
4.2 fdProteanDocument
The following sections describe the attributes and validation rules for the Protean Document definition object.
4.2.1 Attributes
1. Name - This is the unique user visible name for the object. This required text attribute is 30 characters in length and is the object's user key.
3. Document Type - Identifies the use for this document, can also be used for filtering comments onto the document. An enumeration: invoice, shipping, inventory order, fmancials, and other. Note that this is independent of the event source so that a shipping document could be created as the result of an ordering (source) event.
4. Document Audience - An enumeration: internal and external. Can be used for filtering comments onto a document as well as determining how much information is placed in a document. 5. Delivery Methods - Defines the delivery capabilities of the named MS COM automation OA automation server. Four Boolean flags: FAX, email, print postal, and EDI. Used by validation logic in the Contact's document role tab.
6. Languages - A list of languages supported by the document. Used by validation logic in the Contact's document role tab. This is similar to the collection of contacts on the trading partner definition object, i.e., a subordinate that contains a UK to the language object. One of the languages is identified as the primary language, see validation rules for use of this.
4.2.2 Validation Rules
1. At least one delivery method must be specified.
2. At least one language must be specified. All languages referenced must be valid.
3. One language must be identified as the primary language.
4. One document type must be selected.
On the contact's document role (requires changes to existing validation logic):
1. Validate that the referenced document exists.
2. Provide a UDS message if the contact's language is not supported by the referenced Protean document.
3. Provide a UDS message if the Protean document does not support a delivery method selected for the contact.
Note: If a contact's language is not supported by the document, the primary language is used. The document messenger may substitute the requested language with the primary language prior to invoking the protean document automation server.
4.3 An Order Action Definition Example
Consider the three pricing actions Price Order; Price Line Item, and Price Delivery. If we build one pricing algorithm to handle a single delivery it can be extended to loop through all deliveries for a line item or for the entire order.
We could require that this be built as three separate order action servers, or we could find a way to reuse one server in these three slightly different ways. The initial cost is building the pricing algorithm, which could be shared among three servers by packaging it as a DLL. However, there is an incremental cost to create, maintain, ship, install, register, etc. each additional order action server,
When the difference between these order action definitions is so slight (basically a flag to control which code path to execute) it seems that a parameter passed into the order action server would be less costly.
Figure 32 shows how, instead of building three separate order action servers , we can provide one that supports three different order action definitions. Each order action definition is differentiated by the argument string (defined in Section 4.1 coActionDef which is passed into the shared order action server.)
Another example where multiple order action definitions potentially can he serviced by one order action server are the predefined actions such as Lock Price, Lock Discounts, Lock Charges, and Lock Taxes.
5. Hierarchies
The order action definition and Protean document are IPKs derived from fdGenlnst. Figure 33 also shows the Protean document with a collection of subordinates containing a language reference .
Section X - Action Servers Design
1. Introduction
This Section covers the design of the Order Action Servers developed to support Order Automation. The goal of this Section is to lay out common design elements for all the action servers and then discuss each of the Protean-developed servers in some detail.
An action server is a automation server which is invoked to carry out some defined action. An action is a general term used to define some application behavior that the customer may remove, replace, or override. A single action server can support multiple actions.
Actions servers are one of the places in COM that we are enabling our customers to do customization without modification (CWOM). We will be providing automation interfaces to allow customers to easily develop their own action servers. Implementing an action server will be as simple as telling Visual Basic which interface to use and filling in the one or two methods that are required. This Section will discuss how action servers will be written, their automation interface and arguments passed, but will not discuss the processing details of the actions that make up an action server.
Another goal of this Section is to discuss how custom action servers (developed outside the lab) should be designed so they can be easily integrated into our Order Automation architecture.
One type of action server, the document action servers, will not be covered in this design. Document action servers are a type of action server that handles printing standard Protean documents (invoice, order acknowledgment, etc.). Although there are some similarities between the actions servers discussed in this document and document action servers, they are different enough to necessitate another design.
3. Design Overview
The section will discuss the different types of action servers that Order Automation will support. It will discuss each of the Supplied action servers. This section will also contain tips on how customers can write their own action servers.
3.1 Action Servers - General
3.1.1 Action Types
Actions are processing that is done in response to some state change (an event). In the ease of an immediate event, the goal is for actions that are associated with this type of event to be fast (since the user will have the hour glass while the action is processing). Delayed events, on the other hand are processed asynchronously. So for delayed events, the actions associated to them are less performance critical. We define the action types function and transaction below:
Function - an action that modifies only on the triggering object. It cannot have a requirement to keep multiple objects in synch. Performance is critical for these actions since they can be tied to immediate events. An example of a function action is PriceDelivery. It is triggered by the order and in its processing modifies only the order. transaction - an action that is larger and more complicated than a function. It can (but doesn't have to) update multiple objects and keep them consistent. Performance is less critical here since these actions will always take place in the background because they can only be attached to delayed events. A specialization of a transaction action is a document action.
Document - an action that is run to create a document (invoice, pick list, etc.).
Protean supplied actions and custom actions (written outside the lab) will be defined as either a function, document or transaction action. An action server can only contain actions of the same types (functions or transactions).
It is important to note that immediate events can only generate function actions. This restriction will prevent users from associating actions with longer duration (transaction actions) with immediate events. Delayed events can generate any type of action.
The main technical difference between writing a function action and a transaction action is how the life cycle of objects is managed. For performance reasons, the triggering object will only be opened for change and closed one time by the event processor for each event processed. This would mean that any action server can assume the triggering object is open and immediately make changes to it. The difference in function and transaction actions lies in the where the triggering object is saved. In function actions, only the triggering object can be updated, in transaction actions multiple objects can be updated and these changes may need to be saved in one database transaction (to ensure inter-object consistency). So the event processor (immediate or delayed) will save the triggering object after executing a function action, but will not save the triggering object after a transaction action. This would mean that anyone writing a transaction action would need to save the triggering object if it was modified.
Figure 34 illustrates how the action servers fit into the event processing 'big picture'.
3.1.2 Automation Interface
All action servers provided by Protean and written outside the lab will support either (or both) the automation interfaces IoaFunction and IoaTransaction. IoaFunction is for function actions, so if the action server has a function action, it will need to support this interface. IoaTransaction is for transaction actions, so if the action server has a transaction action, it will need to support this interface.
Both interfaces will have a method, Execute. The difference between the two Execute 's will be the arguments passed in. See the next section for details on the arguments. Figure 35 shows the interlaces that should be supported by function and transaction action servers. 3.1.3 Arguments
All action server Execute methods will take an automation interface pointers to one of our arguments objects. Function actions will get an loaFuncArgs and transaction actions will get an loaTransArgs. Passing these generic argument objects will give us the ability to change the data that is passed into the Execute() methods without changing its API. The parameters that are common to both loaFuncArgs and loaTransArgs are:
• Action - This argument determines which of the supported actions for this server will be performed. For example, the pricing server will support three actions: PriceOrder, PriceDelivery and PriceLine. Every action server will have a default action (PriceOrder for the pricing server, for example), so if no action is specified, the default action will be called. This parameter will be passed as a string. This is not a required parameter.
• Triggering Object - This is the IDispatch* of the object that has triggered the event that has started this action server, This is a required parameter.
• Triggering Object Line - This is an index to the order line that the event references (if the triggering object is not an order, this will be 0). This is not a required parameter.
• Triggering Object Delivery - This is an index to the order delivery that the event references (if the triggering object is not an order, this will be 0). This is not a required parameter.
Protean Session — This is an IDispatch* to the Protean session object.
Eπor Object - This is an output parameter that will be used to return any eπors generated in the action processing back to the caller. This parameter is an Idispatch* to a CMsgList. This is a required parameter.
• Event Source - This is an enum (passed an an integer) that could be one of either: order taking site, shipping site, invoicing site or other. It is set based on where the event is generated. Most actions can only occur on one site, but there are a few that can happen at more than one site. For those few exceptions, this parameter will tell the action what site the event was triggered on.
Function Action Arguments
There are no additional arguments needed by functions. Transaction Action Arguments
This argument is part of the transaction arguments:
• Action Server - This argument will be used by the document messenger server. It will indicate the proglD of the action server that will be called by this server. This is not a required parameter.
It is not expected that the arguments object will give the action servers all the information they need to perform their processing. However, it should provide the minimum necessary for an action to be able to gather the information it needs (through subsequent calls to Protean objects).
Because the arguments objects are generic and not restrictive, it is possible for programming eπors to occur when building it and passing them to the action servers. For example, an argument that is not required in general, but is required for a particular action could be left out. If a situation like this does occur, the action server should respond by throwing an exception which is consistent with the way programming eπors are handled in Protean.
3.1.4 Developing Automation Servers using VB
As stated in the Assumptions section, Visual Basic will be the tool of choice for developing our action servers. Visual Basic makes it very easy to write actions servers if an automation interface is supplied. The steps for creating an action server with Visual Basic are:
1. Create either an ActiveX executable (for an out of process server) or ActiveX dll (for an in process server).
2. Reference the type library that has the desired interface.
3. Type the implements keyword and VB will give you a list of the available interfaces, select the one you want.
4. Select the methods that are part of the interface. VB will create the empty methods. Fill in the methods with the appropriate code (since our action server interfaces only have one method, there will be only one method to fill in).
5. Build and use the action server. It is a good idea to read the help text on the Implements keyword. Described above is an automated transaction processing system and, more particularly, an automated order processing system meeting the goals set forth earlier. It will be appreciated, of course, that the embodiments shown in the drawings and describe in detail above are provided merely by way of example and that other embodiments incorporating variations thereon fall within the scope of the invention. Thus, for example, it will be appreciate that procedures attributed to OOP objects can, instead, be carried out by functions, subroutines or other code sequences. Likewise, data described as being stored in tables, objects or variable, etc. can be stored in records, databases, and other constructs. These and other modifications within the ken of those of ordinary skill in the art are contemplated by the invention, of which we claim:
Table 1: Error messages for Order Event UI
Figure imgf000142_0001
Table 2: Order Action Behavior Table
Figure imgf000143_0001
Figure imgf000144_0001
Figure imgf000145_0001
Table 3: Protean Document - Basic Tab Behavior Table
Figure imgf000146_0001
Languages table: read only •The Primary, except for i.e., default primary column language is (image does not checked - only reflect celltype) one primary language is allowed. When the document messenger runs, it needs to know what to do if the document does not support the contact's language - in which case it will use the primary language on the document, •user can remove an object reference from the table by selecting a row and using the Del key or Delete option on the Edit menu.
Add command opens a 10 button language cabinet. User can select multiple languages from the cabinet and append to the end of the table
Figure imgf000148_0001
Table 4: Error messages for Protean Document Basic Tab
Figure imgf000149_0001
Table 5: Order Automation Designer UI Behavior Table
Figure imgf000150_0001
Figure imgf000151_0001
Figure imgf000152_0001
View Actions combo box filters the list of All Sources triggered by: actions that (default) * lower priority appear in the Ordering Site function tree. Shipping Site Invoicing Site
Defaults to Other view all sources
For example, if the user selects to view only actions that are triggered at the Ordering Site; the trees the tree is updated to display only those actions that will take place at the ordering site (i.e., triggering event is Ordering Site). All events will appear regardless of whether the event has any associated actions occurring at the Ordering Site.
Add Event command •Launches the default button button event cabinet, Order event where events cabinet displaying can be added to all events with a the tree (can prompted query also be on source launched via right mouse). •Events may be added to the tree by
1. double clicking event in the cabinet
2. dragging from the cabinet and dropping into the tree
•An event is dropped below the event that has focus, or below the parent event of the action that has focus. See example in figure 22 •Adds events to first level of tree
•Button is disabled if the OAD's saved state is Active
Figure imgf000155_0001
Figure imgf000156_0001
Figure imgf000157_0001
Hide Actions/ command •Button toggles Defaults to Hide 14 Show Action button between Hide Actions Actions and Show Actions •Hide Actions collapse all the events - showing only the events. •Shows Actions expands all the events showing the associated actions
•Essentially this button expands the tree one level or collapses the tree one level. •Button should be enabled when there is more than one event in the tree •Button should be enabled even ifthe definition opened in view only mode.
Figure imgf000159_0001
Triggering combo box •If action has Source only one source (most cases) the triggering source value is the action's event source. The combo is protected. •Ifthe action has multiple sourcing sites the combo box is populated with the intersection between the event's sources and the action's sources and the user must select one. For example ifthe event takes place at both the Ordering and Invoicing site and the action is defined to possibly occur at the Ordering, Invoicing, or Shipping site, the combo box is populated with: Ordering and Invoicing site. The initial default will be 'none' and as the user moves focus from the action, they are prompted to choose one of the two possible Table 6
Figure imgf000161_0001
Table 7: Example Order Automation Definition
Figure imgf000162_0001
Table 8
Figure imgf000163_0001
Figure imgf000164_0001
Figure imgf000165_0001
*PT = Process Type; I = Immediate Event, D = Delayed Event
Table 9: Order Actions in Base Product
Figure imgf000166_0001

Claims

1. A system for automated transaction processing, comprising
A. a set of one or more transaction objects that store information pertaining to a business transaction,
B. an event generator, in communication with the set of objects, that selectively responds to a change in the information stored therein by generating an event notification indicating that an event has occurred,
C. an event processor, in communication with the event generator, that responds to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction to which the set of objects pertain, and
D. an action server, in communication with the event generator and with the transaction object, for executing the actions specified by the action object.
2. A system according to claim 1, wherein
A. the event generator selectively responds to a change in the information stored in any object in the set of objects by generating an event notification indicating that an event has occurred and identifying the object in which it occurred,
B. the action server executes an action that any of accesses and updates information in any of the objects in the set.
3. A system according to claim 2, wherein the event generator responds to at least selected change in information effected by the action server by generating a further event notification.
4. A system according to claim 3, wherein the event generator is disabled from generating a further event notification for a transaction object with respect to which an error occurred in connection with processing of a prior event.
5. A system according to claim 4, wherein the action server responds to an error in connection with the execution of an action by setting any of a flag and a status that disables the event generator from generating a further event notification for the transaction object the change in which resulted in that action.
6. A system for automated order processing, comprising
A. a set of objects comprising an order object and zero, one or more related objects for storing information pertaining to an order transaction, each object in the set storing information associated with a respective site and function associated with the order transaction, B. an event generator in communication with the set of objects, the event generator responding to a change in information stored in any of the objects for generating event notification identifying the change and the objects in which it occurred,
C. an event processor in communication with the event generator, the event processor responding to the event notification by generating action objects specifying one or more actions to be executed in connection the order transaction, and
D. an action server, in communication with the event generator and with the set of objects, for executing the actions specified by the action objects.
7. A system according to claim 6, wherein
A. the action server executes an action that changes information in the order object or any of the related objects, and
B. the event generator responds to a change in information stored in any of the objects by the action server by generating a further event notification.
8. A system according to claim 7, wherein the event generator is disabled from generating a further event notification for a transaction object with respect to which an error occurred in connection with processing of a prior event.
9. A system according to claim 8, wherein any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
10. A system according to claim 9, wherein any of the action server and delayed event processor generate an error object for reporting the error, and wherein a notification is transmitted to the delayed event processor, upon release of any of the disabling flag and status, to at least one of specify and execute actions for the event notification that resulted in the error.
11. A system according to claim 7, wherein the set of objects include any of (i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment, (iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
12. A system for order automation comprising
A. a digital data processor executing a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. an event generator, in communication with the set of objects and executing substantially synchronously with the program, that responds to a change effected by the program in information stored in the set of objects, the event generator responding to such a change by generating an event notification identifying the change and the object in which it occurred,
C. an immediate event processor, in communication with the event generator and executing substantially synchronously with the program, that responds to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and D. a delayed event processor, in communication with the event generator, that responds to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
13. A system according to claim 12, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
14. A system according to claim 12, wherein the event generator transfers to a first queue event notifications to be processed by the immediate event processor, and the event generator transfers to second queue event notifications to be processed by the delayed event processor.
15. A system according to claim 14, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the program, that executes actions specified by the immediate event processor.
16. A system according to claim 15, wherein the action server executes in a same process space and a same thread therein as the program.
17. A system according to claim 15, wherein the action server executes in a same process space as the program but in a different thread therein from the program.
18. A system according to claim 14, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the program, that execute actions specified by the delayed event processor.
19. A system according to claim 18, wherein the action servers comprise
A. a function server that executes actions specified by any of the immediate and delayed event processor affecting the object in which the change occurred, and
B. a transaction server that executes actions specified by the delayed event processor affecting any object in the set of objects in which the change occurred.
20. A system according to claim 19, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
21. A system according to claim 19, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
22. A system according to claim 14, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
23. A system according to claim 15, wherein
A. the action server execute actions that change information in any object in the set of objects, and
B. the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
24. A system according to claim 19, wherein the event generator is disabled from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
25. A system according to claim 24, wherein any of the action server and delayed event processor responds to an error in connection with the execution of an action by setting any of a flag and a status that disables generation of further event notification for the transaction object the change in which resulted in that action.
26. A system according to claim 25, wherein any of the action server and delayed event processor generates an error object for reporting the error, and wherein a further event notification is transmitted to the delayed event processor sent upon release of any of the disabling flag and status.
27. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an event that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects,
C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table, D. an event processor, in communication with the event generator, that responds to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the event occurred, and (ii) the business transaction to which those objects pertain.
28. A system according to claim 27, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
29. A system according to claim 28, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
30. A system according to claim 29, wherein the event processor comprises
A. an immediate event processor, in communication with the event generator and executing substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
31. A system according to claim 30, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects.pertaining to a business transaction exceeds a predetermined count.
32. A system according to claim 30, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
33. A system according to claim 32, wherein the action server executes in a same process space and a same thread as the program.
34. A system according to claim 32, wherein the action server executes in a same process space as the program but in a different process thread from the program.
35. A system according to claim 30, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
36. A system according to claim 35, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
37. A system according to claim 35, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
38. A system according to claim 30, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
39. A system according to claim 35, wherein the action servers comprise
A. a function server that executes actions specified by the delayed event processor affecting the object in which the event occurred, and
B. a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
40. A system according to claim 32, wherein
A. the action server execute actions that change information in any object in the set of objects, and
B. the event generator responds to the changes in information effected by the action server by generating a further event notification for the event processor.
41. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred, D. an event processor, in communication with the event generator, that responds to the event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
42. A system according to claim 41, wherein the automation definition table defines sequences in which the defined actions are to be executed for each selected change.
43. A system according to claim 42, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to respective sets of objects.
44. A system for automated transaction processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction,
B. an automation database including an action table that identifies server processes for processing actions taken on the set of objects,
C. an event generator, in communication with the set of objects, that selectively responds to changes in information stored in the set by generating event notifications indicating that an event has occurred,
D. an event processor, in communication with the event generator, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action definition table to determine a server process fcr processing such action and signaling that server process thereof.
45. A system according to claim 44, wherein
A. the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
B. the event generator selectively responds to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on the event table.
46. A system according to claim 45, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object.
47. A system according to claim 46, wherein the event generator transfers to a first queue event notifications to be processed substantially synchronously with the process that effects the change, and wherein the event generator transfers to second queue event notifications to be processed substantially asynchronously with the process that effects the change.
48. A system according to claim 47, wherein the event processor comprises
A. an immediate event processor, in communication with the event generator and executing substantially synchronously with the process that effected the change, that responds to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with that process, and
B. a delayed event processor, in communication with the event generator, that responds to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that effected the change.
49. A system according to claim 48, wherein any of the event generator, immediate event processor and the delayed event processor signal an error if a number of event notifications attributable to set of objects pertaining to a business transaction exceeds a predetermined count.
50. A system according to claim 48, comprising an action server, in communication with the immediate event processor and executing substantially synchronously with the process that effected the change, that executes actions specified by the immediate event processor.
51. A system according to claim 50, wherein the action server executes in a same process space and a same thread as the program.
52. A system according to claim 50, wherein the action server executes in a same process space as the program but in a different process thread from the program.
53. A system according to claim 48, comprising one or more action servers, in communication with the delayed event processor and executing substantially asynchronously with respect the process that effected the change, that execute actions specified by the delayed event processor.
54. A system according to claim 53, wherein any of the function server and the transaction server executes the actions specified by the delayed event processor any of on or after a scheduled time.
55. A system according to claim 53, wherein the delayed event processor i) responds to a failure to access the object in which the change occurred by retrying, until a first maximum retry count is exceeded, obtaining such access, and ii) responds to a failure of the transaction server to access the object in the set of objects in which the change occurred by retrying, until a second maximum retry count is exceeded, invocation of the transaction server.
56. A system according to claim 48, wherein the delayed event processor at least one of (i) upon invocation and (ii) periodically, identifies objects for which events remain to be processed and confirms that event notifications are recorded for them on the second queue.
57. A system according to claim 53, wherein the action servers comprise
A. a function server that executes actions affecting objects in which the event occurred, and
B. a transaction server that executes actions affecting objects in the set other than that object in which the change occurred.
58. A system according to claim 50, wherein
A. the action server execute actions that change information in any object of the set of objects, and
B. the event generator responds to the changes in information effected by the action servers by generating a further event notification for the event processor.
59. A system for. automated order processing, comprising
A. a set of one or more transaction objects storing information pertaining to a business transaction, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object, (iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
C. an event generator, in communication with the set of objects and with the automation database, that selectively responds to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
D. an event processor, in communication with the event generator and with the automation database, that responds to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
60. A method for automated transaction processing, comprising the steps of
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. selectively responding to a change in the information stored in the set of objects by generating an event notification indicating that an event has occurred,
C. responding to the event notification by generating an action object specifying one or more actions to be executed in connection the business transaction, and
D. executing the actions specified by the action object.
61. A method according to claim 60, wherein step (B) comprises responding to a change in information effected in step (D) by generating a further event notification.
62. A method according to claim 61, comprising disabling step (B) from generating a further event notification for an object with respect to which an error occurred in connection with processing of a prior event.
63. A method according to claim 62, wherein step (D) comprises responding to an error in connection with the execution of an action by setting any of a flag and a status that disables step (B) from generating a further event notification for the transaction object the change in which resulted in that action.
64. A method according to claim 60, adapted for automated order management, wherein step (A) includes storing information pertaining to the business transaction in a set of objects including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object, (v) a reservation object that stores information pertaining to inventory reservation functions,
(vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation.
65. A method of automated transaction processing
A. executing on a digital data processor a program that updates a set of one or more objects storing information pertaining to a business transaction,
B. responding to a change effected by the program in information stored in the set objects by generating an event notification identifying the change and the object in which it occurred,
C. responding to selected ones of the event notifications by specifying one or more actions to be executed substantially synchronously with the program, and
D. responding to selected other ones of the event notifications by specifying one or more actions to be executed substantially asynchronously with the program.
66 A method according to claim 65, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
67. A method according to claim 65, wherein step (B) comprises transferring, to a first queue, event notifications to be processed substantially synchronously with the program and transferring, to a second queue, event notifications to be processed by substantially asynchronously with the program.
68. A method according to claim 67, comprising the steps of executing actions that change information in any of the set of plural objects, and responding to the changes in information effected by the action servers by generating further event notifications.
69. A method according to claim 68, comprising the step of disabling generating further event notifications for an object with respect to which an error occurred in connection with processing of a prior event.
70. A method according to claim 69, comprising the steps of responding to an error in connection with the execution of an action by setting any of a flag and a status that disables the generating of further event notification for the transaction object the change in which resulted in that action.
71. A method according to claim 70, comprising the steps of generating an error object for reporting the error that occurred in connection with processing of the prior event, and responding to release of any of the disabling flag and status for re-executing step (C) with respect to the event notification that resulted in the error.
72. A method for automated transaction processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an event table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects,
C. responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifying the object in which it has occurred, such selective response being made based at least in part on information stored in the event table,
D. responding to the event notification by generating one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
73. A method according to claim 72, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that changes an object in the set of objects.
74. A method according to claim 73, Step (C) transfers to a first queue event notifications to be processed substantially synchronously with the process that changes the object, and wherein the event generator transfers to second queue event notifications to be processed by the substantially a synchronously with respect to the process that changes the object.
75. A method according to claim 74, wherein Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process changed the object, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with respect to the process that changed the object.
76. A method according to claim 75, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
77. A method according to claim 75, comprising responding to event notifications in the second queue by specifying that the actions to be executed any of on or after a schedule time.
78. A method according to claim 75, comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
79. A method for automated transaction processing, comprising the steps of
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred,
D. responding to the event notification by utilizing the automation database to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
80. A method according to claim 79, wherein the automation definition table defines sequences in which the defined actions are to be executed for each selected change.
81. A method according to claim 80, comprising a plurality of automation definition tables, each associated with one or more sets of objects and each defining different respective actions, or sequences thereof, to be executed in response to least selected changes that occur with respect to the respective set of objects.
82. A method for automated transaction processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects,
B. maintaining an automation database that includes an action table identifying server processes for processing actions taken on the transaction objects,
C. selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred,
D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, utilizing the action table to determine a server process for processing such action and signaling that server process thereof.
83. A method according to claim 82, wherein the automation database comprises an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, and
Step (C) comprises selectively responding to changes in information stored in the set of objects by generating event notifications indicating that an event has occurred and identifies the object in which it occurred, such selective response being made based at least in part on the event table.
84. A method according to claim 83, wherein the event table identifies, for each change for which an event notification is to be generated, whether that event notification is to be processed substantially synchronously or substantially asynchronously with a process that effects the corresponding change in the object affected thereby.
85. A method according to claim 84, wherein Step (C) comprises transferring to a first queue event notifications to be processed substantially synchronously with the process that change the object, and wherein Step (C) comprises transferring to a second queue event notifications to be processed by the substantially synchronously with that process.
86. A method according to claim 85, wherein Step (D) comprises responding to event notifications in the first queue by specifying one or more actions to be executed substantially synchronously with the process that effected the change, and responding to event notifications in the second queue by specifying one or more actions to be executed substantially asynchronously with the process that affected the corresponding change.
87. A method according to claim 86, comprising generating an error if a number of event notifications attributable to a set of objects pertaining to a business transaction exceeds a predetermined count.
88. A method according to claim 86, comprising executing, substantially synchronously with the process that effected the change, the actions specified by the event notifications in the first queue.
89. A method according to claim 86, comprising executing, substantially asynchronously with respect the process that effected the change, the actions specified by the event notifications in the second queue.
90. A method according to claim 89, comprising executing the actions specified by the event notifications in the second queue any of on or after a schedule time.
91. A method according to claim 89, comprising retrying until a maximum retry count is exceeded execution of actions executed in response to notifications in the second queue.
92. A method for automated order processing, comprising
A. storing information pertaining to a business transaction in a set of one or more transaction objects, the set including any of
(i) an order object storing information pertaining to any of an order site and an order function,
(ii) a delivery memo object that stores information for interfacing between the order object and the inventory system interface for order fulfillment,
(iii) an expected shipment transaction object that stores information relating to the record of a shipment of goods requested by the order object,
(iv) a shipping memo object that stores information for interfacing between the inventory system and the order object,
(v) a reservation object that stores information pertaining to inventory reservation functions, (vi) a reservation memo object that stores information for interfacing between the inventory reservation functions and the order object,
(vii) a billing memo object that stores information for interfacing between order object and invoice object functions involved in the underlying business transaction,
(viii) an invoice object that stores information pertaining to any of an invoicing site, an invoicing function, and financial liabilities in connection with the business transaction,
(ix) an invoice memo object that stores information for interfacing between the invoice object and order object functions involved in the underlying business transaction,
(x) an invoice generator object that stores information pertaining to creation of a set of invoices and that results from invoice generation,
B. maintaining an automation database comprising i) an automation definition table that identifies changes for which an event notification is to be generated with respect to each type of object in the set of objects, ii) an event table identifying changes for which an event notification is to be generated with respect to each type of object in the set of objects, iii) an action table that identifies server processes for processing actions taken on the transaction objects,
C. responding to changes in information stored in the set of objects by generating event notifications indicating at least that an event has occurred with respect to that object, such selective response being made based at least in part on the event table,
D. responding to the event notification by specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, for each such action, the event processor utilizing the action table to determine a server process for processing such action and signaling that server process of such action.
93. A system for automated transaction processing, comprising A. a set of one or more transaction objects storing information pertaining to a business transaction, B. an automation definition table that defines one or more actions to be executed in response to least selected changes that occur with respect to the set of objects,
C. an event generator, in communication with the set of objects, that i) selectively responds to a first class of changes in information stored in the set of objects by generating system event notifications indicating at least that a system event has occurred, and ii) selectively responds to a second class of changes in information stored in the set of objects, which second class of changes are listed in the automation definition table, by generating user event notifications indicating at least that a user event has occurred,
D. an event processor, in communication with the event generator, that i) responds to the system event notifications to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, ii) responds to the user event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and
(ii) the business transaction to which those objects pertain.
94. A method for automated transaction processing, comprising
A. storing a set of one or more transaction objects with information pertaining to a business transaction,
B. selectively responding to a first class of changes in information stored in the set of objects by generating system event notifications indicating at least that a system event has occurred, and
C. selectively responding to a second class of changes in information stored in the set of objects, which second class of changes are listed in an automation definition table, by generating user event notifications indicating at least that a user event has occurred,
D. responding to the system event notifications to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain, E. responding to the user event notification by utilizing the automation definition table to generate one or more action objects specifying one or more actions to be executed with respect to (i) one or more objects in the set of objects in which the change occurred, and (ii) the business transaction to which those objects pertain.
PCT/US1999/009017 1998-05-04 1999-04-26 Systems and methods for automated order processing WO1999057664A1 (en)

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US8420198P 1998-05-04 1998-05-04
US60/084,201 1998-05-04
US10811598A 1998-06-30 1998-06-30
US09/108,115 1998-06-30
US24879499A 1999-02-12 1999-02-12
US09/248,794 1999-02-12

Publications (2)

Publication Number Publication Date
WO1999057664A1 WO1999057664A1 (en) 1999-11-11
WO1999057664A9 true WO1999057664A9 (en) 2000-03-02

Family

ID=27374733

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/009017 WO1999057664A1 (en) 1998-05-04 1999-04-26 Systems and methods for automated order processing

Country Status (1)

Country Link
WO (1) WO1999057664A1 (en)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7096189B1 (en) * 2001-01-12 2006-08-22 Cisco Technology, Inc. Methods and system for processing changes to existing purchase orders in an object-oriented order processing system
AUPR464601A0 (en) * 2001-04-30 2001-05-24 Commonwealth Of Australia, The Shapes vector
US10417051B2 (en) 2008-05-23 2019-09-17 International Business Machines Corporation Synchronizing shared resources in an order processing environment using a synchronization component
US11379276B2 (en) * 2020-11-02 2022-07-05 Sourcecode Technology Holdings, Inc. Event translation for business objects
US20230229737A1 (en) * 2022-01-18 2023-07-20 Dell Products L.P. Intelligent order problem learning and mitigation in automated order processing system

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1992004679A1 (en) * 1990-08-31 1992-03-19 Seer Technologies, Inc. Transaction processor
US5319542A (en) * 1990-09-27 1994-06-07 International Business Machines Corporation System for ordering items using an electronic catalogue
EP0550369A2 (en) * 1991-12-31 1993-07-07 International Business Machines Corporation Method and system for the automatic performance of a task within an object-oriented software system
WO1993015469A1 (en) * 1992-01-31 1993-08-05 Genoa3 Partners Method and apparatus for an object oriented material management system

Also Published As

Publication number Publication date
WO1999057664A1 (en) 1999-11-11

Similar Documents

Publication Publication Date Title
US7647251B2 (en) Process integration error and conflict handling
US8775591B2 (en) Real-time information technology environments
US8365185B2 (en) Preventing execution of processes responsive to changes in the environment
US6523134B2 (en) Selective undo
US4974149A (en) Data distribution apparatus and method having a data description including information for specifying a time that a data distribution is to occur
CA2146984C (en) System and method for interfacing to a transaction processing system
US8346931B2 (en) Conditional computer runtime control of an information technology environment based on pairing constructs
US8868441B2 (en) Non-disruptively changing a computing environment
US8782662B2 (en) Adaptive computer sequencing of actions
US8682705B2 (en) Information technology management based on computer dynamically adjusted discrete phases of event correlation
US8447859B2 (en) Adaptive business resiliency computer system for information technology environments
US8375244B2 (en) Managing processing of a computing environment during failures of the environment
US6065009A (en) Events as activities in process models of workflow management systems
CN1783132B (en) Synchronization of runtime and application state via batching of workflow transactions
JP5026506B2 (en) Policy-based message aggregation framework
US20090171730A1 (en) Non-disruptively changing scope of computer business applications based on detected changes in topology
US7844659B2 (en) Process integration persistency
US20090172669A1 (en) Use of redundancy groups in runtime computer management of business applications
US20050182638A1 (en) Intelligent State engine system
US20020161840A1 (en) Adapter for interfacing with a workflow engine
US20030171947A1 (en) system and method for enterprise-wide business process management
US20090171731A1 (en) Use of graphs in managing computing environments
US20060259912A1 (en) Supporting extensions to production event message schemes via production database server versioning
US20090172674A1 (en) Managing the computer collection of information in an information technology environment
US20090171703A1 (en) Use of multi-level state assessment in computer business environments

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): CA JP

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: C2

Designated state(s): CA JP

AL Designated countries for regional patents

Kind code of ref document: C2

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

COP Corrected version of pamphlet

Free format text: PAGES 1-118, DESCRIPTION, REPLACED BY NEW PAGES 1-164; PAGES 118-135, CLAIMS, REPLACED BY NEW PAGES165-184; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
122 Ep: pct application non-entry in european phase