The present disclosure relates to an intermediate software layer for one or more users interacting with enterprise systems and business processes.
Business systems typically offer a flexible user interface (UI) that allows users to enter data in various locations in the user interface. The UI may provide other flexible features for allowing the user to enter data, save and record information, and edit complex objects in a database. Some of the flexible features may allow the UI to be adaptable for various business systems, as well as being easily formatted and modifiable for various user roles and functions. The flexible UI features may also allow the UI to interact with one or more software layers. In one aspect, the UI may interact with an underlying software layer of business logic (BL). The BL layer may maintain, sort, and/or process the entered data for one or more business applications and databases. However, the underlying BL layer tends to be relatively inflexible. Consequently, data entered in the UI tends not to be easily formatted for BL layer use.
In other cases, a user enters and saves data in the UI in a series of steps, in which the BL processes changes in data between steps. For example, the user may enter data in the UI, and the BL may process the data and request more data from the user. In that case, the UI is updated, and the user enters the next item(s) of data in the UI. The BL processes the next item(s) of data, and requests more data from the user. This serial data entry and BL processing continue until the BL receives and processes all of the data needed from the UI for a given scenario.
The present disclosure describes a system that, in one implementation, includes a user interface, business logic, and an intermediate layer. The user interface is able to collect data from a user and the business logic is able to process data collected by the user interface. The intermediate layer is interposed between the user interface and the business logic to rearrange data collected by the user interface into a format that is optimized for processing by the business logic. The system can conduct a data flow between the user interface and the business logic through the intermediate layer, in which the data flow can be initiated by one or more actions of the user interface such as opening a user interface and entering data in the user interface.
The intermediate layer can optimize the rearrangement of data for the business logic. In one case, the rearrangement of data collected by the user interface can include data collection from the user interface and translating the collected data for the business logic. The intermediate layer may provide a buffering of data flow between the user interface and the business logic, in which the buffering of data flow may enable the system to perform batch processing of a number of business processes. The business logic may include a general business logic layer for common business functions and applications, and the intermediate layer may format the data for use in the general business logic layer. The intermediate layer may perform one or more operations on one or more objects to reduce an amount of business processes performed by the business logic, such as collecting and formatting one or more classes of objects.
The system may also include an object model controller to associate the data from the user interface with an object, in which the intermediate layer can receive the object from the object model controller. The object model controller may send data requests to the intermediate layer and may include an object-oriented interface. The data requests may include a read data request, a modify data request, and/or an insert data request.
The system may also include a database to receive data from the business logic and send data to the business logic. The system may also send business logic data to the user interface through the intermediate layer.
In another implementation, the present disclosure describes a method that includes receiving data in a user interface and passing the data from the user interface to an intermediate layer. The intermediate layer may be able to interact with the user interface and a layer of business logic. The method also includes performing one or more operations on the data passed to the intermediate layer and sending data and/or instructions from the intermediate layer to the layer of business logic. The method may also include processing the data and/or instructions in the layer of business logic and sending the processed data and/or processed instructions from the layer of business logic to the user interface. The sending of the processed data and/or instructions may include passing the processed data and/or instructions through the intermediate layer.
The method may also include associating an object with the data received in the user interface, in which the intermediate layer may be able to perform one or more operations on the object. An object model controller can associate an object with the data received from the user interface. The object model controller may allow a user to prevent other users from modifying data until a save data instruction is received in the user interface. The intermediate layer may be able to perform the following operations: receiving an instruction from the object model controller; performing one or more operations relating to the received instruction; and issuing one or more instructions to the layer of business logic. The intermediate layer can determine whether the received instruction from the object model controller includes a known object, an unknown object, and/or a modification of a known object. In response to the received instruction from the object model controller, the intermediate layer may be able to perform any of the following operations: instructing the layer of business logic to approve previous instructions and data entries; instructing the layer of business logic to save data in a database; and initializing a framework to enable a user to perform data entry.
The method may further include sending the data from the layer of business logic to a database and saving the data in the database upon receiving the data from the layer of business logic. The intermediate layer may be able to optimize one or more processes in the layer of business logic and enable batch processing of data entered in the user interface. The intermediate layer may maintain data entries and modifications among various object classes, and the layer of business logic may include common business functions and applications. Also, a data flow between the user interface and the layer of business logic may be initiated by one or more actions of the user interface, such as opening the user interface and/or entering data in the user interface.
In another implementation, an article includes a machine-readable medium storing instructions operable to cause a machine to perform operations. The operations include receiving data in a user interface and passing the data from the user interface to an intermediate layer. The intermediate layer is able to interact with the user interface and a layer of business logic. The operations also include performing one or more operations on the data passed to the intermediate layer and sending data and/or instructions from the intermediate layer to the layer of business logic. Further operations include processing the data and/or instructions in the layer of business logic and sending the processed data and/or processed instructions from the layer of business logic to the user interface. The sending of the processed data and/or instructions includes passing the processed data and/or instructions through the intermediate layer.
The present disclosure also describes a system that, in one implementation, includes a network of computers, business logic, and an intermediate layer. The network of computers includes a database and at least one user interface. The business logic is able to perform a number of business functions and applications. The business logic is also able to process data entered in the user interface and interact with the database. The intermediate layer is able to interact with the user interface and the business logic. The intermediate layer is able to format and rearrange data entered in the user interface to optimize the processing of data in the business logic. A data flow between the user interface and the business logic is conducted through the intermediate layer.
The systems and techniques described here may provide one or more of the following advantages. For example, the intermediate layer can improve the efficiency and speed of the business system, and can allow the user interface to be formatted so that a user can enter larger amounts of data in a more efficient manner. The intermediate layer can permit a more generic implementation of the business logic such that the business logic implementation can be easily transferred among systems that use different user interfaces. Also, the intermediate layer may improve the efficiency of business logic processing by being able to collect, maintain, and optimize the rearrangement of data entries and modifications among various object classes. The intermediate layer may also perform complex formatting and data translation steps that would otherwise have to be implemented and performed in the business logic.
Details of one or more implementations are set forth in the accompanying drawings and the description below. Other features and advantages will be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
The following describes various tasks, techniques, and interfaces for implementing an intermediate layer between a user interface and a layer of business logic.
The data from the UI 110 may be part of one or more objects. The objects may have a group of classes or one or more types of object models. For example, a first object may represent the first name of an employee in a business, and a second object may represent the last name (e.g., family name or surname) of that employee. The first and second names together can be grouped into an object class of “employee name.” A third object name may represent the employee's home address, a fourth object may represent the employee's home telephone number, and a fifth object may represent the employee's home email address. These five objects may be grouped in a larger object class referred to as “employee's home information.”
The UI 110 can receive data from a user, such as an employee's home telephone number, and the intermediate layer can receive an object with the employee's home telephone number. The intermediate layer 120 can then add, update, and/or discard this object and other related objects and data before sending the telephone number information to the BL 130. Some examples of intermediate layer operations are shown in one or more diagrams below.
The intermediate layer 210 may support one or more operations on multiple interdependent attributes of complex business objects. For instance, the UI 210 may have data relating to multiple processes 202, 204, 206, all of which may interact with the intermediate layer 220.
Because data collected from the UI typically is not properly formatted for BL use, the collected data ordinarily must be formatted and rearranged before it is provided to the BL for processing. Absent an intermediate layer, the BL would also have to perform these reformatting and rearranging functions. However, by interposing an intermediate layer between the UI and the BL, the data collected by the UI may be formatted into an optimal arrangement before reaching the BL layer for processing, thereby decreasing complexity and enhancing efficiency and through-put. The optimal arrangement typically would vary with the type of application, specifics of the UI and BL, and the nature of the data being collected and processed. In general, an optimized arrangement of collected data would be that which minimizes processing by the BL to achieve the desired results and in an efficient and timely manner.
The BL layer can be optimized to perform processing functions, and need not necessarily have be configured to also perform data formatting or otherwise facilitate additional data collection. As a result, the BL layer can be more streamlined. For example, the BL layer may be implemented more generically, and may not have to be tailored to receive data for specific user interfaces. In another aspect, the BL layer implementation may be more transferable. The “transferable” implementation may allow the BL layer to be used with a larger variety of user interfaces and/or a larger variety of business systems. For example, the BL layer may be able to process data in disparate applications for which the user interfaces do not relate to the same line of business. Instead of having a BL layer that only processes data with a user interface relating to clothing stores, for example, the BL layer may also be able to handle common processing functions on data with user interfaces relating to computer stores (e.g., the purchasing and shipping of goods). In other cases, the intermediate layer may be tailored to receive data from specific types of user interfaces (e.g., user interfaces for large amounts of data entry), and format that data to be sent to a general BL layer, in which the general BL may be used for common business functions and applications (e.g., maintaining inventory or employee data). The common business functions and applications may be generic and/or frequently-used business functions (e.g., employee data entry). The common business functions may also include business functions that can be used across multiple types of businesses (e.g., employee data entry for computer businesses, employee data entry for hospitals, and employee data entry for retail stores). Because the BL layer does not necessarily include the functionality of the data collection and formatting from the UI, the BL layer may provide data processing with less delay and more efficiency.
The intermediate layer can also provide the advantage of allowing a larger amount of data entry to be entered into the UI in a single step. The data entry may, for example, include all of the data that the BL may need for processing in a single step. The BL may request additional data 338 as needed as in
The entered data (e.g., employee's home telephone number) may be part of a model class (e.g., “employee's home information”). In one case, the entered data may be entered into a field in the UI in which the field is associated with a particular model class. In another case, a separate model controller 404 (object model controller) may receive entries from the UI and associate the data into object model classes to send to the intermediate layer 406. The MAC 404 may associate objects into one or more model classes based on various criteria. For example, the MAC may associate objects into model access classes based on a type of UI (e.g., a UI for entry of employee data, a UI to set up customer account data, or a UI for a particular type of business), based on the data field in the UI (e.g., an employee's first name data field), or based on the type of information (e.g., data with certain text characters). The MAC 404 may have functionality to map, relate, or link data for one or more object classes. The MAC 404 may have an object-oriented interface and may send data requests (e.g., read, modify, insert) to the intermediate layer 406.
In the example shown in
The MAC 404 may also have the functionality to “lock” the object 418. The “lock” function may prohibit other users of a system in other user interfaces from modifying the object. The user may select one specific object (e.g., an employee number object), and specify in the UI 402 that object modifications are to be locked from other users. In this example, locked objects may only be modified 422 by the user of the interface. When the user elects to save the data (e.g., by pressing a “save” button in the UI 402), the save request 428 is sent to the MAC 404. The MAC 404 can notify 430 the intermediate layer 406 that all data changes are to be saved. The BL 408 sends the data to be saved in a database 434. If a user sets an object lock 418, then the object can be unlocked 430 when or after the data is saved.
In
A user can enter data 527 in the UI, and the MAC 510 can associate an object (e.g., object “A”) with the data entry. The MAC can indicate that the object has changed from an empty or “null” state to a state with new data 528 (e.g., A0→A1). The new data may be an entry for an employee number for an employee object (e.g., employee number “12345” for an “employee's information” object). The intermediate layer 512 can determine if there has been a modification of a current/known object or if there is a new/unknown object. An object is “current” or “known” if the object has been previously introduced to the intermediate layer for that trail or session, otherwise the object is “new” or “unknown” to the intermediate layer. If the object is new/unknown to the intermediate layer 512 then there has been an object focus change 530. If the object is not new/known to the intermediate layer 512, but involves a change in the object's state (e.g., modified data), then the object focus has not changed.
Because the object “A” is new or unknown to the intermediate layer 512 then the focus can be changed to “A” 532. The intermediate layer 512 can notify the BL that all changes to any previous objects should be “approved” 534. The intermediate layer 512 can also notify the BL that a new trial or session 536 is started on the object (“A”) 536, and the state of the object is “A1” 538. If the BL 514 has not received a closed, save, or end session request, the BL may request for additional information from the UI via the intermediate layer and the MAC.
In the event that a user modifies data (e.g., employee number “54321”) for the same object (e.g., object “A”), the object's state is changed 548 (e.g., A1→A2). Because operations are performed on the same object, the intermediate layer will not change the focus 550. The intermediate layer 554 can instruct the BL to discard the previous state changes to the object “A” 554 and to start a new trial 556. The intermediate layer 554 can then send the modified state 558 (e.g., A0→A2) to the BL.
In the event that a new object is used (e.g., object “B”), the intermediate layer's focus can be changed 562, 563, and the same steps described above (e.g., steps shown in 534-539) can be performed on the new object. The new object may represent, for example, an employee's start date or organizational title/ranking. Hence, the intermediate layer 554 may be able to recognize different objects (e.g., objects “A” and “B”) and produce changes on those objects (e.g., A0→A2).
Various implementations of the systems and techniques described here can be realized in digital electronic circuitry, integrated circuitry, specially designed ASICs (application specific integrated circuits), computer hardware, firmware, software, and/or combinations thereof. These various implementations can include one or more computer programs that are executable and/or interpretable on a programmable system including at least one programmable processor, which may be special or general purpose, coupled to receive data and instructions from, and to transmit data and instructions to, a storage system, at least one input device, and at least one output device.
The software (also known as programs, software tools or code) may include machine instructions for a programmable processor, and can be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. Some exemplary languages may include C, C++, JAVA (by SUN Microsystems), and ABAP (Advanced Business Application Programming). As used herein, the term “machine-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor.
To provide for interaction with a user, the systems and techniques described here can be implemented on one or more computers each having a display device (e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse or a trackball) by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback); and input from the user can be received in any form, including acoustic, speech, or tactile input.
The systems and techniques described here can be implemented in a computing system that includes a back end component (e.g., as a data server), or that includes a middleware component (e.g., an application server), or that includes a front end component (e.g., a client computer having a graphical user interface, portal, or a Web browser through which a user can interact with an implementation of the systems and techniques described here), or any combination of such back end, middleware, or front end components. The components of the system can be interconnected by any form or medium of digital data communication (e.g., a communication network). Examples of communication networks include a local area network (“LAN”), a wide area network (“WAN”), a wireless local area network (“WLAN”), a personal area network (“PAN”), a mobile communication network using a multiple access technology (e.g., a cellular phone network with Code Division Multiple Access, “CDMA”), and the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
Although only a few implementations have been described in detail above, other modifications are possible. There may be other scenarios that have not been described. For example, the user interface may provide security features that are related to the user. The user's security status may allow only certain data entries and/or modifications. In another example, the operations described in
Other implementations may be within the scope of the following claims.