The present invention relates to computer software. More particularly, the present invention relates to a program for modifying business applications used by financial institutions.
A bank analyzer application may be used by banks or financial institutions. Prior to full-scale use, the application may need to be customized by a specialist or partner, who may be a consultant with expertise in the banking industry. Thus, while the bank analyzer application may be designed to manage business processes of a bank, it may require the partner to tailor the application to the particular data structures and implementation details of a specific customer.
Conventional banking products may be based on several components that may be merged to develop a common data structure. The applications may not be convenient for customers or the specialists because the applications may be hard-coded. Applications intended for use with loans, for example, may work only with loans. It may be difficult to use the application with customer-centric data structures.
There thus is a need for a method of enabling banks to easily customize business applications to fit their particular needs.
A master data framework is provided by an exemplary embodiment of the present invention. The master data framework is a data model for banking information that is flexible and extensible. There may be few static, predefined data structures. Instead, a developer may set up a list (or lists) of attributes during customization to match the application to the customer's data model. Several different functions may be provided by the master data framework.
The framework provided for handling transactions and other master data objects may be flexible and may be enhanced by the customer. The enhancement concept allows customers to implement their own fields within the master data framework.
The framework allows standard fields provided in the system to be grouped together with fields and characteristics created by the customer. Basic templates may be assigned to structured templates to form a hierarchy. Templates may be defined in a customizing function at a single-version level. This may ensure that the data in the customizing function is consistent with the data in the application. At the template version level, it may be possible to store default values and field selection control (such as required fields or optional fields) for appropriate fields.
The template categories delivered to the user may give structure to the fields delivered with the system. The fields supplied may be grouped into related units, for example attributes for handling financial terms and conditions, lines, and business partner relationships. Actual characteristic values may be maintained on the basis of the defined templates.
The configuration process may be guided by templates and objects. The user may define the entities, in which the characteristics and key figures are supplied for a primary object. In other words, the source systems may not send characteristics and key figures individually, but instead may send them grouped into business entities. These business entities may be called templates in a financial database, and may be used in conjunction with the following primary objects: financial transaction; financial instrument; account; settlement account; securities position account; customer position account; G/L account; country; hedging relationship; and/or physical asset.
During customization for a particular type of entity, a developer may first develop an entity template. For loans, the developer may generate a loan template. A library of default parameters for each entity type may be provided in the form of predetermined templates, as illustrated in
The developer may access the library and select one of the predetermined templates. The developer may select which fields from predefined field groups (also referred to as service modules) are activated. In the application, the product defines a universe of all field types that can possibly apply to a given entity. When the developer activates certain fields, the template simply records flags to distinguish those fields that are active and those fields that are not active.
Templates may also have several versions. The various template versions may reference each other in a tree structure, such as the one shown in
For instance, default template 24 may be a loan, and template 25.1 may represent a personal loan while template 25.2 may represent a mortgage (the personal loan and mortgage being variations of default template 24, the loan). Template version 26.1 may represent a version of template 25.1, and may represent a personal loan having no prepayment penalty. Template versions 26.2 and 26.3 may represent versions of template 25.2, and may represent two versions of a mortgage. For instance, template version 26.2 may be a fixed-rate mortgage and template version 26.3 may be a variable rate mortgage.
The templates themselves do not represent transactions. Using the example of a loan template, each object using the template may represent a particular loan. Each particular loan may be represented by a separate object that fills the relevant fields with the specific information that defines the loan. The loan object may include a header that identifies the template and the version to which it applies. Thus, a bank's computer system may store many loan objects, each of which refers to a particular type of loan template/version.
Root layer 21 need not relate directly to a specific type of transaction (e.g., loans) performed by a bank. There may be several templates, with each template devoted to a type of loan. Thus, there may be several templates established in parallel for a given transaction type, each of which will include their own default template 24 in root layer 21.
The templates may be modified even after the customization process is finished, and after the bank begins to use the templates on live data. Revising the template results in a new version of the template.
The system may need to be able to redo old applications and operate on historical versions. The system may maintain two dates for each data object: a ‘business date’ and a ‘system date.’ The business date may identify the date for which the object version is effective. For example, a user may enter transaction data after the transaction has been completed and indicate that the new data became effective at some particular date in the past.
The system date is assigned by the computer system itself and cannot be changed by a user. The system date is a timestamp that indicates when a data object was created. This creates a two dimensional time line that is relevant for certain searches, a graphical illustration of which is shown in
For example, assume that on Mar. 11, 2004, data is entered for a transaction that actually occurred on Mar. 11, 2004. The business date and the system date would be identical, Mar. 11, 2004. Assume further that transaction 33 was entered incorrectly (for instance, value A) and on Jun. 1, 2004 the error was corrected to become transaction 34 (for instance, changed to value B). In this situation, the business date remains the same but the system date changes to Jun. 1, 2004.
This feature permits the system to run historical searches. The system can not only re-run a particular search but it also can re-run the search using data as it existed on a specified date.
Templates may include a set of rules for creating primary objects. A template may be described by its attributes. A template category defines which attributes are permitted for describing a primary object. The names of the template categories may match the names of the primary objects listed above. The template categories may each provide a fixed number of attributes for defining templates that represent business entities such as loans, swaps and stocks. A specific real-world occurrence of a template (for example, the loan contract with contract number 4711 of object 46.1 shown in
The structures of templates and objects are described in the following discussion. New, more complex templates may be created by combining templates. This provides a building block for constructing hierarchically structured templates. Templates may need to be combined, for example, for loans that have additional notice options or unscheduled repayment options. If a template is not the result of combining other templates, it is called an elementary template. In contrast, structured templates may be composed of sub-templates, which in turn may be structured themselves.
A similar approach may be adopted for creating objects, because objects represent specific occurrences of templates. Objects that result from elementary templates may be called elementary objects, while objects that result from structured templates may be called structured objects. Consequently, structured objects are composed of individual sub-objects. Here, the object itself forms the root of the hierarchical structure derived from the template, and each sub-object represents a node that is assigned to a version of the corresponding sub-template. As is the case for the object itself, the settings of the template configuration can also be derived for all sub-objects since they have a unique reference to a template version. Structured objects are only valid in their entirety; the individual sub-objects are not independent entities.
Creating and managing versions for objects is described in the following discussion. Changing the attributes of a template may have far-reaching implications, since a template may have been used as the basis for creating a large number of objects. For example, by changing the field selection for an attribute from “inactive/not relevant” to “required field,” all the objects that exist for this template may become inconsistent. For this reason, one template may have several template versions. A template version may operate to “freeze” the status of a template. If the data for a certain template changes during configuration, a new version may be used.
When the field contents for an object are changed, a new object version may be generated automatically. This means that the object values may never be overwritten and all the changes made to a specific object may be traced using the object versions. This feature is illustrated in
An additional feature of an exemplary embodiment of the present invention relates to the release procedure using dual control. This feature provides a validation of modifications to transaction data, and confirms shared responsibility between the person entering the data and their supervisor(s) and/or auditor(s). According to some bank guidelines, for example, one or more employees may need to be designated to check the entries made by a user creating data to ensure that the data entries are accurate. In addition, certain approval powers may be defined for the employees in a bank (such as who is permitted to grant which limits to customers and enter them in the system). The release functionality for data entries of the present invention may support the correct handling of these approval power regulations. Moreover, the auditors and/or controllers may track which employees have released data entries, making them jointly responsible for the results.
While the present invention has been described in connection with the foregoing representative embodiment, it should be readily apparent to those of ordinary skill in the art that the representative embodiment is exemplary in nature and is not to be construed as limiting the scope of protection for the invention as set forth in the appended claims.