In complex business management systems, transactions may be handled by many different parts of the system. Operations components of systems may be responsible for receiving orders, shipping, creating invoices, tracking payments and providing information to an accounting system. Such systems can be very complex, and it is difficult to track business transactions that may flow through the system.
The creation of an invoice or other transaction may have ramifications throughout the system. Thus, when an invoice is cancelled, there is a need for different parts of the system to be informed, and to take appropriate actions to ensure that the cancellation is properly handled. It can be difficult to track all everything that may need changing in the face of receiving a cancellation. Further, there can be difficulty in establishing a clear semantical distinction between credit memo and a cancellation. This may result in redundant data and a lack of clarity in appropriate responses to a cancellation.
Cancellation of transactions is detected in a business operations system, and a cancellation message uniquely identifying an operational document describing the transaction is created. The cancellation message is sent to various components in the business operations system and to other systems as desired. The receiving entity is free to select actions taken in response to the cancellation.
In the following description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments which may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that structural, logical and electrical changes may be made without departing from the scope of the present invention. The following description is, therefore, not to be taken in a limited sense, and the scope of the present invention is defined by the appended claims.
The functions or algorithms described herein are implemented in software or a combination of software and human implemented procedures in one embodiment. The software consists of computer executable instructions stored on computer readable media such as memory or other type of storage devices. The term “computer readable media” is also used to represent any means by which the computer readable instructions may be received by the computer, such as by different forms of electromagnetic transmissions. Further, such functions correspond to modules, which are software, hardware, firmware or any combination thereof. Multiple functions are performed in one or more modules as desired, and the embodiments described are merely examples. The software is executed on a digital signal processor, ASIC, microprocessor, or other type of processor operating on a computer system, such as a personal computer, server or other computer system.
Cancellation of a business document, such as an invoice, shipments or goods movement for example is performed by the use of messages to various components. The messages reference a prima nota, or primary document number of the invoice, and leaves it up to the component receiving the message as to how to process the cancellation. A document resulting in the cancellation, such as a credit memo may also become a prima nota with its own reference number, which may also be communicated in the messages informing components of the cancellation.
Order inventory object 114 may include an inventory of all current unshipped orders in one embodiment. It is updated by the use of messages generated as a result of transactions. A transaction may be performed by the orders component 110 in response to receipt of an order. A message to update the inventory object 114 may also result from a delivery transaction via delivery component 115.
Deliver component 115 may also include prima nota 117 that contains primary business documents, such as delivery documents, and a delivery inventory 119, which again may be updated via messages generated by transactions from one or more components.
Invoicing component 120 may also include prima nota 122 that contains primary copies of invoices and other business documents related to functions that the invoicing component 120 performs. Invoicing component 120 may not contain a separate inventory object. It reuses the inventory of the due management component 129. Transactions may result in increases and reductions in the inventory of inventory object 129.
Due management component 125 may also include prima nota 127, such as documents related to amounts due from business partners, collections notices, etc. Due management component 125 may also include a due inventory object that represents amounts due from business partners. It may be updated via messages resulting from transactions in various components, such as invoicing via the invoicing component as represented by line 135. It may also be updated by messages generated from payments received via payment component 130.
Payment component 130 may also include prima nota 132, such as documents related to payments. Payments may take many different forms, such as cash, check, money order, credit card, offsets, and electronic funds transfer. The prima nota may be scanned copies of checks, or associated communications with such payments. The payments are transactions that are processed by the payment component 130 and result in messages incrementing and decrementing a payment register inventory object 134.
In one embodiment, the components perform transactions that modify one or more inventory objects, and also may result in communications of such transactions in the form of messages as indicated at 140, 141, 142, 143 and 144 being sent to a separate accounting/finance system 150. The business operations 100 and accounting/finance system 150 are separate systems that communicate back and forth via messages. In one embodiment, the business operations system 100 is a cash based system, where cash is calculated in real time. The accounting system may operate on an accrual basis. By using messages between these two different systems, and keeping business documents and inventory separate in the operations system, each system is free to select how to handle transactions.
One result of this separation is that a cash management finction 155, which may not be associated with any of the listed components, may quickly obtain information on the overall cash position of a business implemented by the components. Two inventory objects, the due management inventory object 129 and the payment register inventory object 134 contain representations of a substantial percentage of the cash position of the business. In one embodiment, it is approximately 80% of the cash position of the business. Thus, in a simple operation involving only two messages to these inventory objects, a good indication of the cash position of the business is easily obtained.
At 220, payments received are tracked in a single point of inventory payment registry inventory object. As the payments are received by a component, messages are generated to increment or decrement the inventory payment registry inventory object. Such payments may be payments in full, or partial payments, and the inventory object is modified correspondingly. Further methods may be used to obtain totals from the inventory object. In one embodiment, such totals are representative of the cash represented in the object.
At 230, such updating of the payments due inventory object and the payment registry received inventory object is done via messages generated in response to transactions. As indicated above, the transactions may be related to invoices being generated, and invoices being paid partially or fully. In further embodiments, components may send messages resulting from transactions to the separate accounting system, which may be based on a different accounting method.
One example of a complete cancellation involves the receipt of a full credit memo that clearly cancels an invoice, as illustrated in a process 400 flowchart in
This capability can be helpful when dealing with the independent accounting system 150. In one example, an invoice may be posted in the accounting system 150 in December, and the books may be closed by the time a cancellation occurs in January. It would not be helpful to have the component on the business operations side that received the cancellation indicate how the accounting system 150 should handle the cancellation. It may not be possible to reopen the books from December. The method of sending a message that uniquely identifies prima nota from the operations side enables the accounting system to precisely identify the business transactions and potential related secondary documents that it has created, and then decide how to handle the cancellation. It may result in the books being reopened or restated, or it may just be entered into the books in January. The handling of such a cancellation may also be performed according to individual business conditions or rules.
In one embodiment, cancellation are performed on primae noate only. They create a new prima nota unique reference number and reference back to the prima nota which was cancelled. Messages carrying cancellations work by reference, so that no values are transported redundantly. The receiver is free to choose the appropriate strategy to cancel its data, such as the cancellation of accounting documents in closed periods, entries in trade receivables/payables may be cancelled by undoing a clearing and canceling of the original entry. Due management may reopen an already cleared item before canceling it. More flexibility is provided to the receiving components in handling the cancellation.
A block diagram of a computer system that executes programming for performing the above functions is shown in
Computer-readable instructions stored on a computer-readable medium are executable by the processing unit 502 of the computer 510. A hard drive, CD-ROM, and RAM are some examples of articles including a computer-readable medium. The term “computer readable medium” is also used to represent electromagnetic transmission of the software. For example, a computer program 525 capable of providing a generic technique to perform access control check for data access and/or for doing an operation on one of the servers in a component object model (COM) based system according to the teachings of the present invention may be included on a CD-ROM and loaded from the CD-ROM to a hard drive. The computer-readable instructions allow computer 510 to provide generic access controls in a COM based computer network system having multiple users and servers.
The Abstract is provided to comply with 37 C.F.R. §1.72(b) to allow the reader to quickly ascertain the nature and gist of the technical disclosure. The Abstract is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims.