US 20070250426 A1
An information management system that consists of data, a rules database, and user profiles is provided. The rules database stores information about system responses to modifications of the data. The user profiles store information concerning the availability of information and displays depending upon the user. Automatic updates to user profiles in response to modifications to the data are performed.
1. An information management system comprising:
a first database storing first information for viewing and manipulation by one or more system users, said first information being manipulated and/or viewed by system users but not being used directly to define system operation or function;
a user profile database wherein said database has stored therein identification information which correlates at least one of said system users with a user specific data manipulation logic and/or data display format that at least in part defines system operation;
a rules database storing information defining system response to user modifications to said first information; wherein at least one system response to a first user modifying said first information comprises altering the user profile of at least a second user.
2. The system of
3. The system of
4. In a computerized information management system, a method of managing financial portfolios comprising:
storing information in a database;
assigning a user profile to each of a set of users, wherein said user profile defines the information in said database which is available to a user, and/or the data manipulation in said database that the user may perform;
defining a set of rules governing how a first user action such as altering information in said database is to affect user profiles of users other than said first user;
automatically updating in accordance with said rules information in said database, wherein said updating is in response to said first user's activity; and
automatically updating in accordance with said automatic update of information said user profile of said first user and said user profiles other than said first user's profile in response to said first user's activity.
5. A computerized equity based transaction management system, available to a plurality of different types of users that manages the entire life cycle of an equity order transaction, said system comprising:
a. at least one server coupled to an investment advisor computer network comprising data processing devices used by one or more users required to complete an equity order transaction, the users comprising a plurality of clients, portfolio managers, assistant portfolio managers, compliance officers, equity traders, executing brokers, custodian banks, clearing houses and electronic trading venues;
b. an internet browser on the data processing devices that are connected to the network via an internet/intranet connection that allows one or more of the users to interact with the network at an investment advisor's internet site during an equity order transaction;
c. a data repository system that stores, delivers and retrieves data for the-system, wherein at least a portion of the data is accessible for at least one of viewing and manipulating by the users during the entire life cycle of an equity order transaction and is updated after the user manipulates the information, and wherein said data comprises:
i. client account information including one or more of account number, account description, account trading restrictions, account balance information, account transactions, and account holdings;
ii. user profile information which correlates a user's role in the equity order transaction with specific data manipulation logic which defines the user's access entitlements to the client account information and a specific data display format that is presented to the user;
iii. valid dialog/presentation information combinations that are available to the user based on the user's profile information;
iv. valid business logic information combinations that are available to the system based on the user's role and an investment advisor's definition of business access authorization, the business logic information defines specific data manipulation routines and logic that are permitted against an equity order transaction through out the life cycle of the transaction as defined by authorized user(s);
v. valid user/investment advisor site information used for site configurations and user roles, and used to modify the business logic information and dialog/presentation information;
vi. valid management information combinations for external connections;
d. a business logic manager that manages the system operations that are performed in response to transaction requests by users based on the business logic information combinations as defined by authorized administrators of the system;
e. a user profile and session manager that manages the user's profile information, authorizes the user's role, determines which transaction information is available to a user for manipulation, and determines the data display format of the transaction to the user;
f. a user database interface manager that manages the user's access to the data on the data repository system and the client account information, and allows at least one of viewing or manipulating the information depending on the authorized user's role;
g. a presentation dialog manager that stores and displays the various screens that are available to the authorized users defined by the valid dialog/presentation information combinations;
h. a user/investment advisor site manager that defines specific business functions that the investment advisor site is authorized to perform and the specific dialogues the user investment advisor site is allowed to view;
i. a transaction manager that manages how the transaction will interact with a user comprising:
i. receiving transaction requests from the user profile and session manager;
ii. forwarding transactions that the user is authorized to perform to transaction execution modules in accordance to the user profile information and the business logic information; and
iii. transmitting a presentation request to the presentation dialog manager;
j. a user plug-in module that manages how data is formatted when either sent or received from users during the transaction;
k. an information manager that manages the connections and data exchange with third party vendor databases, comprising modifying client account information in third party vendor databases in response to the executed transaction;
l. a security module that authenticates the user session to allow the authorized user access to the system;
m. a network connection module that interfaces with the security module allowing network traffic in and out of the network and that manages network connections.
n. wherein a common set of client transaction information is available for display and manipulation to said plurality of clients, portfolio managers, assistant portfolio managers, compliance officers, equity traders, executing brokers, custodian banks, clearing houses and electronic trading venues throughout the life cycle of an equity order transaction in accordance with said user profiles defined for each corresponding user.
This application is a continuation of U.S. patent application Ser. No. 09/658,332 entitled “Transaction and Account Management System” filed on Sep. 8, 2000, which application in turn claims priority under 35 U.S.C. § 119 to U.S. Provisional Application No. 60/152,920, filed Sep. 8, 1999. The disclosure of both of these applications is hereby incorporated by reference in its entirety.
1. Field of the Invention
The invention relates generally to the field of computer implemented account tracking, processing, and management. The techniques are applicable to diverse fields.
2. Description of the Related Art
With the advent of the Internet, a wide variety of computer implemented methods of tracking customer activity, fulfilling customer orders, and the like have been implemented or proposed. In some cases, these methods include the creation of user specific accounts which include various types of information about the customer, and which help define, at least in part, the nature of a system user's interaction with the system.
One specific area which involves extensive account maintenance and monitoring is the securities trading environment. In these systems, an example of which is provided in
To open an account 202, all relevant information about the client and his/her account is recorded. This information will include among other data, name, addresses, account type, contact information, compliance restrictions, billing information, custodian bank details, legal information and broker/dealer (B/D) requirements in addition to security and cash holdings. Different elements of the client account information will be used in each of the 12 processes. The relevant information for a user is presently not available in an efficient manner.
When an new account is opened for a client, the IA will record all of the new client holdings 204. These can include equity and/or fixed income securities, mutual fund shares and cash. As each new trade is executed for a client, the IA may record the result in the client's account.
Next, the IA should receive a record of the client's holdings at the custodian 206 and reconcile. Securities and cash owned by each client are held by a custodian bank and not by the IA. The custodian bank maintains records for each client showing these holdings. The records of the IA preferably match the records of the custodian bank for each client. Whenever a new account is opened for a new client, there may be a delay in receiving the information from the custodian bank and recording the client's initial holdings. During this delay, the client's holdings may change. Moneys can be added and/or withdrawn and securities traded. After an account is opened, the correct 207 step takes place. The IA must reconcile its client account information with the custodian bank's information on a regular basis. If the IA had a different record of holdings than the record of the custodian 206, then the IA should will see the inconsistency and notify the custodian 208. Account reconciliation can be done daily, weekly or monthly. This will depend upon how often the custodian bank makes the client's data available and how much time the IA has available to reconcile accounts. Presently the IA does not have information regarding a client's holdings at the custodian bank on a real time basis. The IA therefore does not know exactly what funds are available to be invested and may be recording inaccurately the securities in the client's account. Any systems that may potentially allow for a real time reconciliation require tremendous resources for the IA and the custodian to be able to communicate and make such information available to each other.
At the end of the month (E.O.M.) or the end of the quarter (E.O.Q.), the IA runs special routines. If it is the end of the month or the end of the quarter, the E.O.M. OR E.O.Q. step 224 will perform certain operations. If it is not the end of the month or end of the quarter, the next step will be performed. At the E.O.M. the IA runs performance information for each client's account, obtains equity security split and dividend information, updates fixed income securities payment information, reconciles client account information with the custodian bank records, etc. At the E.O.Q. the IA performs the E.O.M. routines plus run the client billing. IAs typically bill clients on a quarterly system on the basis of average assets under management during the quarter. The billing process includes reconciling all client account information with the custodian bank's records. The IA should determine if there have been any additions and/or withdrawals in the accounts during the quarter and if so make appropriate billing adjustments from the day the adjustment occurred to the end of the quarter. The IA should prepare and distribute necessary client account statements and reports.
A portfolio manager (PM) performs trade identification 210. A PM will use various analytic tools to determine what trade he/she wants to make. The analytical decision to buy or sell is based on extensive research by the PM. The PM researches and studies the thousands of different companies and investment vehicles that are available. The PM will need to analyze company specific data to make the investment decision. The PM's will also make investment decisions based on the investment objectives that the client agreed to with the PM when the account was opened.
The PM will next review holdings positions for any buy/sell 212. Once a PM decides on a trade he/she wants to execute for his/her clients, he/she must refer back to the client account information for each client to determine which client accounts can participate in the trade, e.g. sufficient cash or any restrictions preventing the trade for the client account. The PM must determine which accounts to include in the trade taking into consideration account restrictions. The process of referring to account information and parsing it to see how many client accounts can do the trade remains a largely manual process. Even if the information is already in some electronic format, the PM has to refer back to each account, identify any constraints and compare these constraints against the trade details to determine the clients which are eligible to participate. Ideally, the trade details would automatically be compared against a database holding the client account information to identify clients which are not able to participate. Whenever the PM decides to place an order, the PM must pass the order to the trader for execution.
Under the step of pass orders to trader for execution 214, the PM creates a formal request for the trader. This formal request to execute an order passes all relevant trade details and all regulatory requirements. The trader should be able to execute and act upon the PM's request at anytime during trading hours.
Under the step of execute order until complete 216, the trader then must decide how to execute this trade, either as a single order or combine this order with another identical order and create a block order. One factor the trader may identify in constructing the trade is the particular designated B/D requirements for each client. A client may specify that all of its trades or some percentage be directed to a specific B/D. Once the trader has determined how many trades go to each B/D, he/she will either call a B/D or use an online system for a particular B/D to place the trade. The online system may require the trader to re-key the trade request into the B/D's proprietary system or perform some “cut and paste” operation to move the data electronically into the online system. The trader needs to be able to transmit order requests correctly to the B/D in each B/D's format for execution. The trader preferably should be able to simultaneously manage several orders with multiple B/Ds.
The trade correct 218 then has the trader verify that the order was correctly executed by the B/D. The order should reflect the correct order parameters such as buy or sell, quantity, price or market request (e.g. at the market or limit). The correct trade with broker &/or custodian 220 requires the trader to record the time and report information from the B/D upon notification from the B/D. If the order is not correct, it is the responsibility of the trader to notify the B/D of any errors and correct the order. The trader passes the trade to the settlement area in order to settle the trade.
To settle trade 222, a portfolio assistant will then take the trade details and confirm the information with the B/D and the custodian. Any information which does not match needs to be reconciled until the order matches. The portfolio assistant will have to provide settlement details for the security and cash payments. Each client account can have multiple clearing instructions depending upon the security being sold/purchased. The correct settlement instructions should be reflected for each client participating in the trade. The settlement instructions should be provided by the IA to the custodian bank and the B/D. The custodian bank and the B/D should agree on the settlement of the trade. All regulatory requirements should be satisfied when settling a trade. DTC eligible trades should be affirmed i.e. approved, for the trade to settle. Once all the trades have settled, the information should be posted into all the relevant client accounts.
In addition, a user will perform E.O.D/E.O.T. routines 222. At the end of the day (E.O.D.) or end of the trade (E.O.T.), the trader will generate a report to comply with all regulatory requirements. The trader has to notify the PM regarding the completion of the trade, which includes the price of the trade.
Other environments have similar account tracking requirements. In the retail sales environment, for example, a set of core processes can be defined that are fundamental parts of retail sales. In these and other environments, existing art today is cumbersome and addresses only segments of identified core processes. It consists of components that separately handle distinct tasks. No one program or set of programs completely addresses and handles core processes of an enterprise from start to finish. The solutions today address each process and provide a solution as if it was an isolated body of information not connected to the next. The connections between programs are not seamless or do not exist at all. For the most part the data has to be manually re-entered upon the commencement of the next process.
Thus, the transition from one of the core processes to another identifies a break in the flow that requires information to be moved from a process to the next process. The data may be moved (1) manually to the next process by re-keying the information into the system to be used in the next process, (2) by a “cut & paste” approach in which data will be electronically “cut” from one system and “pasted” into the next system by the user, or (3) by electronically moving the information by manually invoking a program that will take as input a file and then pass the information on to the next process.
Regardless of the approach, each time a system user has to move to the next process there is a break in the flow of information. This can translate into one piece of information, such as the client account number, being keyed into different systems as the IA moves from one process to the next. This is known as a “portage”. Each portage or break and re-entry of data represents an possible risk of error and an inefficiency because it is an added step in running the business as the user moves from each process to the next.
In one embodiment, the present invention comprises an information management system including a collection of data that can be changed or viewed by system users. The system also includes a user profile database that stores system related information. User identification information is stored so that a user may gain access to the system and so the system knows the access rights of the user. In other words, there are certain displays and/or modifications that are allowed dependent on the user that is using the system. In addition, there is a rules database, which stores information that guides the system how to react in response to a user modification to information in the financial database. User profiles of other system users will be updated when there is a system response to a user modification.
In one advantageous embodiment, the system can be web hosted. The system users can interface with the system using a web browser such as Microsoft Explorer or Netscape Navigator.
In another embodiment, computer implemented tasks such as opening accounts, recording client information, and executing business transactions are performed. In addition, when one or more of these tasks is completed, one or more user profiles are updated.
Embodiments of the invention will now be described with reference to the accompanying Figures, wherein like numerals refer to like elements throughout. The terminology used in the description presented herein is not intended to be interpreted in any limited or restrictive manner, simply because it is being utilized in conjunction with a detailed description of certain specific embodiments of the invention. Furthermore, embodiments of the invention may include several novel features, no single one of which is solely responsible for its desirable attributes or which is essential to practicing the inventions herein described.
In the investment account management embodiment, and as depicted in
The second component depicted in
Another component of the system of
Although three separate databases are illustrated, it will be appreciated by those of skill in the art that all of the information, including financial information, rules, and user profiles may be combined into one database, as is shown for example, in
In accordance with one aspect of the invention, user profiles 306 may be updated automatically and transparently when there is a change to the information 302 in the financial database. For example, the user profile of a selected portfolio manager will define what client accounts that portfolio manager can view. As any given portfolio manager will manage only a subset of the investment advisor firm clients, the user profile will specify those particular accounts that portfolio manager is responsible for, allowing viewing and processing of those accounts only. If an assistant adds a new client and the associated information to the financial database 302, the rules 304 specify that the user profile of the appropriate portfolio manager be automatically and transparently updated to allow the correct portfolio manager access to the client information to view and process the client account.
The user can view information in the database or can attempt to modify 410 the information in the database. If the user wishes to modify 412, the modification must be in accordance with the rules, or the system will reject the modification. As discussed above, after the modification at block 414, one or more user profiles may be updated in response to the modification. Then the user may continue view until another modification or log-off is requested 416. After log off, the process stops at block 418.
In some embodiments of the invention, modifications to the database 302 and the user profiles 306 are made in real time, and all users logged onto the system are notified of the changes. This type of real time update to a user profile is illustrated by the screen displays of
Turning now to
In this embodiment, the database 806 would be maintained on servers 804 that would not be located at the investment advisor firm. The server 804 would receive information from the custodian banks and B/Ds that the investment advisor has business relationships with. This data would be accessible by the investment advisor firm on local computers 812 via an Internet/Intranet connection. The system 802 eliminates the need for the investment advisor to maintain any other technology infrastructure.
Furthermore, all the information required by an IA to efficiently execute trades and update all users in accordance with the latest database information would reside in one place, and be available to the entire IA firm as well as associated entities such as brokers and banks. The information and tools that any user needs to complete his/her task then could be displayed in an easily customizable format. Due to the automatic updates to the user profiles, a user's interface would display all relevant data to complete his/her task without the need to migrate data from a prior user or to the next user. This would eliminate the “portage” in the IA's workflow.
For example, portfolio managers would then be able to use this information to determine which client accounts are eligible for a particular trade. Once a trade has been identified, the PM can easily run a routine that determines who can execute the trade and if there are any limitations on how the trade must be executed.
Once the PM has identified the client accounts to be included in a trade, the trader would use his/her interface to determine how the trade can be best executed, i.e. as several trades with multiple broker/dealers or as a single block order trade. The dealing rules 304 for each client account would be readily accessible and the trader can accommodate them easily. The trader then would be able to use the on-line trading systems of any B/D without re-keying in the trade order on each B/D's proprietary system. In accordance with a user profile associated with each broker, the system would process the trade into the format required by each B/D system. The system 802 also allows the B/D to send confirmations back to the IA through the BID's proprietary system and format. The system 802 takes the confirmation, receives the data in the unique format from each B/D and in accordance with the B/D user profile, changes the format as required by the trader and IA's settlement area.
Once trades have been confirmed by the B/D, trade and settlement details would be sent to the custodian bank and B/D based on each client account's information. All these details would be stored in the database 806, and would allow straight through processing of the trade. Once trades have settled, all client account information would automatically be updated.
As depicted in
The Transaction Manager 918 categorizes the user request into a business component, which is handled by the Business Logic Manager 920, and presentation layer, which is handled by the Presentation/Dialog Manager. The Transaction Manager 918 is a multitasking engine that can handle thousands of requests. Each user request is coordinated with the User Profile and Session Manager 916. The User Profile and Session Manager 916 maintains the user entitlements, the user session settings and the requests currently pending and the request currently executing. The Transaction Manager 918 issues a command to both the Business Logic Manager 920 and the Presentation/Dialog Manager 940. The requests issued to the Business Manager 920 and Presentation/Dialog Manager 940 run in parallel. Running tasks concurrently reduces execution time. Since the Transaction Manager 918 coordinates the user request with the User Profile and Session Manager, this allows the Transaction Manager 918 to process other user requests as the 1st request is being processed by the Business Manager 920 and Presentation/Dialog Manager 940.
The system has taken the 12 core processes of the investment advisor business and places the business logic within the Business Logic Manager 920 and the screen presentations in the Presentation/Dialog Manager 940. Both the Business Logic Manager 920 and the Presentation/Dialog Manager 940 make calls to the database 806 to determine the exact algorithm to execute and the formatting of the user dialog. This allows for custom logic algorithms and custom screen settings for each investment advisor user. The User Profile and Session Manager 916 tag each request with a field that Transaction Manager 918 passes to the Business Logic Manager and the Presentation/Dialog Manager 940. This database approach allows the system 802 to maintain an infinite number of custom settings for each investment advisor shop and each investment advisor user at each shop. The User/investment advisor Site Manager 914 is the interface to add, modify and/or remove business logic and presentation/dialog settings. This approach allows the investment advisor to modify business practices without having to reengineer the system 802.
The advantages of the breaking up the business logic into the Business Logic Manager 920 and the screen presentations into the Presentation/Dialog Manager 940 is (1) there is a centralized location of business logic and screen settings, (2) new logic can be introduced into the system without reengineering the system and (3) a technician can troubleshoot an investment advisor client problem remotely.
Centralized location of the database 806 and logic allows the system to make any specific customer requests or general changes without the need to visit each customer site. The changes or modifications can be tested at the host server's location on a test database. Such changes can then can be made to the production database that is also on site at the host server's location without requiring visits to each user's site.
On a one-time basis the only software that has to be installed on the investment advisor's system is an Internet browser and security software that uniquely identifies the investment advisor browser to the host server.
An executable file and a DLL are installed at the investment advisor site only if the investment advisor user wishes to invoke the Database Interface Module 924 locally. This will allow the investment advisor to work locally with a program such as Excel or Word and a local database on the investment advisor PC. The DLL is a modification to the investment advisor's operating system that allows the PC to communicate to the system's 802 executable.
The executable and DLLs on a investment advisor's PC can be maintained and modified by the host server 804. If a new version of a DLL is required, the host server 804 can electronically send the new version to the investment advisor PC and install this software automatically on the investment advisor site. This eliminates the need for the investment advisor to maintain anything beyond a simple PC network with Internet access.
Once the user enters the system, the investment advisor can access any of modules he/she has permission to access. In one embodiment, the modules available are Trader, Maintenance/Assistant, Portfolio Manager, Billing, Reporting module, Compliance, Portfolio Management Accounting System, Fixed Income Securities, Pricing and 3rd Party Connection.
The User Profile and Session Manager 916 determines what data the user is allowed to access as well as the format the data will be presented. This method allows each user to have a custom look and feel. In conjunction with the User/investment advisor Site Manager 914, the investment advisor can customize his/her settings, e.g. change the font and color.
The database 806 is advantageously structured such that the entire database 806 can be accessed via such key fields such as “client account number”, “client name”, “security name”, “trade date “and” ticket number. This capability allows the end user to obtain any field of information within the database.
There is virtually no limit to the number of data fields that can be used in the system. With this database anytime an entry is made, changed or created the modification is recorded. There can be an endless number of changes that a user can make and all of the changes will be recorded.
Each recorded modification may include the time the change was made, the user that made the change and the data prior to the change.
The User Profile and Session Manager 916 resolves conflicts when two users attempt to perform the same task at the same time, such as updating a client account number. The user that submitted the update request first will be allowed to modify the field and the second user will be notified of the situation. The conflict is resolved at the User Profile and Session Manager 916 level rather then the database level. This approach removes the possibility of data corruption and the overhead associated with processing a concurrent update at the database
The different modules within the system allows each person to think and function within their respective task. As data is transferred from one job function to another job function, the data is presented in the format that is expected and clearly understood within the specific job function. This can be accomplished without moving the data from one user to the next user as all the data is located in a central database.
The system will reduce the hardware requirements of each investment advisor client because the investment advisor will no longer be required to maintain servers and specialized network connectivity software and/or hardware. The Plug-In Module 928 allows the investment advisor to connect the various systems. This allows data integration with systems, such as an Office File Server and e-mail system, network connectivity. The system 802 already has several layers of security such as the security module 902 that allow secure Internet connection. The Plug-In Module 928 allows the investment advisor to take advantage of these secure network connections. This in effect eliminates all but the LAN 104 for the investment advisor to maintain as an infrastructure. The investment advisor can access to his/her data from anywhere in the world as long as he/she has access to the Internet. All information is viewable on a real-time basis.
Turning now to the retail store (RS) environment, it will be appreciated that there may also be defined a set of core process for managing information. Product specifications, terms, availability can vary from vendor to vendor. The RS has to determine shelf life, shelf requirements, shipping requirements for both receiving the product and shipping the product to customers, cost of the product, minimum and maximum inventory levels, re-ordering requirements of the product and pricing fluctuations of the product due to market conditions.
As with the investment advisory firm system described above, in an application f the invention to the retail store environment, all information required to manage inventory and order information may reside in a database or series of databases available to the entire firm. The information and tools that any user needs to complete his/her task then could be displayed in an easily customizable format. A user's interface would display all relevant data to complete his/her task without the need to migrate data from a prior user or to the next user. The data for each user's tasks would reside in one place. This again would eliminate the “portage” in the workflow.
All of the information regarding a product initially is entered into the database when the product is ordered. This would include basic product details such as product description, vendor, vendor terms, vendor lead time to fill order, vendor minimum and maximum order, product shelf requirements, product shipping requirements, product packaging requirements, product re-order requirements, manufacturer contact and vendor return policy. All the information as to how a product must be processed would be maintained in one central location.
The store manager and the buyer would then be able to use this information to determine which products should be purchased and the quantity for the order. Once the desired products have been identified for order, the buyer can focus on filling the order, electronically notify the order details to the receiving department, accounting department and inform customers of pending orders. With the ability to pass product information to the store manager, the buyer can focus on vendor visits to see product displays, new product samples and report his/her finds to the store manager.
A retail store system 1002, implemented in a fashion similar to the system 802 depicted in
Once orders have been confirmed and shipped by the vendor, the system 1002 allows the vendor to interface with the system 1002. The interface will provide the vendor with exact packaging requirements, best fit method of the physical goods onto trucks, vans, etc . . . , know exactly what items have been processed for shipment, when the shipment has left the vendor and the best route to the by the retail store. The system 1002 also enables the retail store to maintain one central system for product tracking, product inventory, product offering, such as point of sale and on-line sales. The Online sales system would be an integral part of the retail store's infrastructure system. As online orders are received and processed the same information regarding best shipping and packaging methods used to receive the items can also be re-used to ship the product to customers. The information about product availability and vendor lead-time to fill orders will allow the retail store to maintain minimum inventory levels
Once orders have settled, i.e. payments have been received from the customer and made to the vendor, all product and account information would automatically be updated.
End of day (E.O.D) and/or end of trade (E.O.T.) routines will also be performed in order to generate reports.
When the user enters data in a dialog or when the user clicks a dialog button, such as “Next” a series of steps are invoked. These actions include verifying the data entered is in the correct format, i.e. no “dirty-data”, executing a series of programs that will store/retrieve and/or perform some algorithm with the data that the user has on his/her screen. The Transaction Manager 918 categorizes the user request into a business component, which is handled by the Business Logic Manager 920, and presentation layer, which is handled by the Presentation/Dialog Manager 940. The Transaction Manager 918 is a multitasking engine that can handle thousands of requests. Each user request is coordinated with the User Profile and Session Manager 916. The User Profile and Session Manager maintains the user entitlements, the user session settings and the requests currently pending and the request currently executing. The Transaction Manager 918 issues a command to both the Business Logic Manager 920 and the Presentation/Dialog Manager 940. The requests issued to the Business Manager 920 and Presentation/Dialog Manager 940 run in parallel. Running tasks concurrently reduces execution time. Since the Transaction Manager 918 coordinates the user request with the User Profile and Session Manager 916, this allows the Transaction Manager 918 to process other user requests as the 1st request is being processed by the Business Manager 920 and Presentation/Dialog Manager 940.
The core processes of the RS business are implemented within the Business Logic Manager 920 and the screen presentations in the Presentation/Dialog Manager 940. Both the Business Logic Manager 920 and the Presentation/Dialog Manager 940 make calls to the database 806 to determine the exact algorithm to execute and the formatting of the user dialog. Data flow, user profile storage and automatic alteration, as well as other aspects of the user interfaces and system responses are analogous to that presented above with reference to
The foregoing description details certain embodiments of the invention. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the invention can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the invention should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the invention with which that terminology is associated. The scope of the invention should therefore be construed in accordance with the appended claims and any equivalents thereof.