The present invention is related to Resource-Event-Agent (REA) models, and to systems and methods using an REA model. More particularly, the present invention is related to a method of providing security in REA models.
Business users and application developers prefer software applications where primary abstractions are the concepts that business people use to describe their work. For example, the concepts such as economic resources, business partners, contracts, and agreements are natural for business users, while the concepts such as classes, methods, virtual collections, and fields are natural for programmers, but not for business users.
The current trend towards model driven development is an attempt to move away from low level programming, towards modeling based on the concepts of the domain experts. Before one can do any modeling, regardless of whether this model is expressed in code or in a diagram, it is desirable to choose an ubiquitous language that can serve as the language for all people that work with this model. This language should stand the test of time during development and use of the software. An important aspect to ensuring that the language is reliable and comprehensive enough to fulfill these requirements is to base the language on a sound foundation. One modeling language which provides a sound foundation to address these needs is REA.
REA is the name of a prescriptive accounting model introduced by William E. McCarthy in 1982. See for example, William E. McCarthy, The REA Accounting Model: A Generalized Framework for Accounting Systems in a Shared Data Environment, The Accounting Review, Vol. LVII, No. 3, July 1982. REA is often referred to as a model, a framework, an ontology, an enterprise information system architecture, or by other commonly used names. The fundamental advantage of the REA model is that it provides a prescriptive model for describing a business's processes. Around the fundamental prescriptive model, a whole, infrastructure of additions have been added over the years in the form of more specifics on the modeling methodology itself, incorporation of REA in public standards, etc.
While REA allows for the modeling of “ownership” or “involvement”, it does not typically address security aspects of business models. Traditional business applications separate security specifics from the domain or business application modeling. Because of this there is very little to discover when it comes to Security configuration or Meta data and the security subsystem is often either missing or implemented in parallel to the application solution.
Prior solutions to security have typically been to let developers set up a list of properties that can or cannot be viewed by roles in the system. This approach is error prone. Further, this approach involves very complex implementations, frequently requiring several days per installation. Sometimes, this approach is implemented in software by the developer coding the solution. This makes it even more difficult to obtain the right security setup as the users (i.e., system administrators, etc) are not able to change the settings and define their own roles/security access.
A method of providing Resource-Event-Agent (REA) model based security includes identifying an association between a first object and a second object in an REA model. Then, an association class is created for the association between the first object and the second object. The association class, for example called a Security Policy Association Class, defines security between the first object and the second object.
The association class, defined between the first object and the second object, is an object having properties. The properties of the association class object define the security between the first object and the second object. The step of creating the association class can further comprise creating one or more association class objects having properties, with the properties of the one or more association class objects defining security between a first class of objects of which the first object is a member and a second class of objects of which the second object is a member. The second object is a securable object, such as a contract or agreement type object, a commitment type object, an event type object, or a resource type object. The first object is of a particular agent type. A role for a user is defined by the particular agent type for the first object.
The association class created between the first object and the second object can be created in a security model either separate from the REA model, or as part of the REA model. The security defined between the first object and the second object includes defining permissions and rights of the first object relative to the second object. These permissions and rights can be determined dynamically in a security policy logic module outside of the security model. This is particularly useful for permissions and rights which are transient in nature, for example depending upon the date, time, status of an event, etc.
Other features and benefits that characterize embodiments of the present invention will be apparent upon reading the following detailed description and review of the associated drawings.
The Resource-Event-Agent (REA) model allows for the modeling of “ownership” or “involvement”, but REA modeling semantics have not been used to drive security configurations. The present invention is based in part upon the recognition that REA modeling semantics can be used to provide such security. Disclosed is a strategy of using the REA semantics in driving default security configurations from any REA model incorporating these semantics. This strategy is used in the methods and apparatus of the present invention.
Traditional business applications separate security specifics from the domain or business application modeling. In contrast to the security implementing methods used in these traditional business applications, using the strategy disclosed herein, REA modeling techniques can be used to build security information into a domain or business solution. As used herein, the term “semantic model” refers to a computer software model of real-world activities, for example supply chain activities. A semantic model is rich in content and describes classes of objects, relationships, and functions involved in the real-world activities it models. The REA semantic model can be expressed in many formats: the extensible Markup Language (XML), the Universal Modeling Language (UML), a relational database, and/or an object oriented programming language. In the following discussions, security implementing improvements on the REA model are described primarily in terms of UML, but the present invention is not limited to UML implementations.
The invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
A user may enter commands and information into the computer 110 through input devices such as a keyboard 162, a microphone 163, and a pointing device 161, such as a mouse, trackball or touch pad. Other input devices (not shown) may include a joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 120 through a user input interface 160 that is coupled to the system bus, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB). A monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190. In addition to the monitor, computers may also include other peripheral output devices such as speakers 197 and printer 196, which may be connected through an output peripheral interface 195.
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a hand-held device, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110. The logical connections depicted in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN-networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Memory 204 is implemented as non-volatile electronic memory such as random access memory (RAM) with a battery back-up module (not shown) such that information stored in memory 204 is not lost when the general power to mobile device 200 is shut down. A portion of memory 204 is preferably allocated as addressable memory for program execution, while another portion of memory 204 is preferably used for storage, such as to simulate storage on a disk drive.
Memory 204 includes an operating system 212, application programs 214 as well as an object store 216. During operation, operating system 212 is preferably executed by processor 202 from memory 204. Operating system 212, in one preferred embodiment, is a WINDOWS® CE brand operating system commercially available from Microsoft Corporation. Operating system 212 is preferably designed for mobile devices, and implements database features that can be utilized by applications 214 through a set of exposed application programming interfaces and methods. The objects in object store 216 are maintained by applications 214 and operating system 212, at least partially in response to calls to the exposed application programming interfaces and methods.
Communication interface 208 represents numerous devices and technologies that allow mobile device 200 to send and receive information. The devices include wired and wireless modems, satellite receivers and broadcast tuners to name a few. Mobile device 200 can also be directly connected to a computer to exchange data therewith. In such cases, communication interface 208 can be an infrared transceiver or a serial or parallel communication connection, all of which are capable of transmitting streaming information.
Input/output components 206 include a variety of input devices such as a touch-sensitive screen, buttons, rollers, and a microphone as well as a variety of output devices including an audio generator, a vibrating device, and a display. The devices listed above are by way of example and need not all be present on mobile device 200. In addition, other input/output devices may be attached to or found with mobile device 200.
Review of REA Modeling
REA is an established modeling technique, ontology and semantic model for describing economic and business systems. REA describes a business system as a set of economic Resources, economic Events and economic Agents as well as relationships among them. Economic Events capture changes of ownership of economic Resources between economic Agents.
In the REA model, the exchanges of economic Resources are the primary economic data about the enterprise. Accounting artifacts such as debit, credit, journals, ledgers, receivables and accounts are derived from the data describing the exchanges. For example, the quantity on hand for an inventory item can be calculated as the imbalance between the Purchase Events and the Sale Events for that inventory item. In comparison, in most current Enterprise Resource Planning (ERP) systems it is opposite—the economic data is derived from the accounting artifacts. This, in some sense, puts the consequence before the cause and makes the model more complicated.
In addition, REA contains rules (axioms) assuring consistency of the model from an economic perspective. As the result: (1) The REA models are concise and easy to understand; (2) The same model is used across different business domains; (3) Accounting artifacts are always consistent, because they are derived from the same data (e.g., the same data describing the sales event is used in the warehouse management, payroll, distribution, finance and other modules); and (4) The REA model provides for more complete reporting than the reporting based on the accounting artifacts. Business Objects are always related together using a pattern of the general type illustrated in
An “economic Resource” represents the subject of trade. An economic Resource is something of value that is under the control of the “economic Agent.” Examples of economic Resources are products, money, fixed assets, raw materials, and employee qualifications. Many other examples of Resources are also possible. Economic Resources represent the values which management seeks to control. An “economic Event” represents the change of ownership of an economic Resource. Some economic Events occur instantaneously, such as sales of goods. However, some occur over an interval of time, such as rentals or services and employment. Examples of economic Events include, but are not limited to, Shipment (delivery), Payment, Return of Goods, and usage of Employee time.
An “economic Agent” represents an economic unit, or legal entity capable of exchanging economic Resources (or just Resources) with other economic Agents (or just Agents). Examples of economic Agents include Customer, Vendor, and Employee. Agents are discussed in further detail with reference to
Referring now to
As shown in
In
As an example, for an REA model of an organization, an Outside Agent is often outside of the organization being modeled, such as a customer or vendor. An Inside Agent is often an employee of the organization. Which of the Inside and Outside Agents is the External Agent and which is the Internal Agent depends upon which is giving up a Resource in the Event. As a further example, if a transaction is a transfer of Resources between two business units within the organization being modeled, the Internal Agent will be the one giving up the Resource, while the External Agent will be the one receiving it. In the context of the present invention, External and Internal Agents are used to interpret application roles, with each unique External or Internal Agent translated into a new application role.
REA models support the notions of different kinds of relationships. The first type of relationship relates Objects of different types to form new Objects. This type of relationship is referred to as an “Association”. Associations are illustrated in
“Control relationships” are Associations among an Agent on one side and an Economic Event or other type of Object, on the other side. For example, in
Custody is another Association type. In the context of the present application, this Association type is interpreted as “responsibility”. When an Association between a Resource and an Agent (Internal or External) is of type Custody, in embodiments of the present invention the Agent will be granted some default permissions on the Resource. An example of a Custody type Association is illustrated in
Security in REA Modeling
In accordance with embodiments of the present invention, an Association Class is added to the Association between an Agent and a corresponding securable Class. The Association Class is itself one or more new Objects. Each securable Class has a set of operations that can be performed on Instances of the Class. For example, these operations could be “read”, “update”, “delete”, “forward”, “print” or any other number of operations appropriate for the Class in question.
Security governing a particular relationship, an application or a system is often referred to as “Security Policy.” The Security Policy defines the model that describes all roles and securable Objects and their relationships. It further defines all operations that can be performed on each securable Object. This information makes up the static part of the model in a non-generic Object model. Other components such as users, permissions and other factors determining permission grants are dynamic and configurable. The remaining pieces of security components in a typical application are made up of tools and infrastructure to manage and enforce the policy.
The REA security strategy allows the generation of the static part of the Security Policy. With some additional policy capability such as a default configuration expressed in a policy template, the default dynamic configuration of the Security Policy can also be generated. After generating these static and dynamic portions of the Security Policy, in a typical application all that is left to do is to provide the system administrator some tools to manage the Security Policy after the application has been deployed.
To illustrate the concepts of the methods and apparatus of the present invention, portions of an REA model for a simple order entry application are shown and discussed. First consider the Role aspect of security. Role Based Access Control (RBAC) is a technology/strategy commonly used in business applications. In such a model, users have roles and roles have permissions. A role corresponds to a job function in an organization. Conceptually and practically it is easier to manage security permissions for a person when the person's job function is known rather than through the use of other grouping mechanisms not related to job function.
In accordance with aspects of the present invention, in an REA model, a first step in the REA security strategy is to implement the following. For all unique classes stereotyped with the <<Agent>> moniker, a new security role is created. The role can be granted permissions to perform operations on Objects represented with relationships to the role's representative Agent Class in the model. One example of this is depicted in the diagrams provided in
Shown in
In this example the “SalesPerson” marked with the <<Agent>> stereotype becomes a security role. Every other unique Agent in the model also will become security roles to be used in the RBAC implementation. Each of these roles is then analyzed to establish which relationships they have to other classes in the model and for what kind of relationships they have to these classes.
Shown in
When a sales order is created, the SecurityPolicyAssociation Class can contain a template policy that specifies which operations by default are granted to the Agent. Since this is an InternalParticipation Association of type Control, the SalesPerson in question (represented by Object 505) could be awarded full access rights (CRU), with the potential exception of “Delete”. The right to “Delete” the Sales Order Object 510 might be a reserved operation for another Agent. Either way, with the improvements of the present invention in the form of the addition of an Association Class to define the operations that the Agent 505 can perform on the Commitment 510, the REA model can be used to derive automatic security settings based on the existing REA semantics.
Referring now to
Consider now the diagram illustrated in
Also added in
It must be noted that an agent can act on behalf of other agents. This relationship, often referred to as impersonation, gives the impersonator the rights of the impersonated agent. For example, an ambassador is impersonating the head of state in a foreign country, giving the ambassador the access rights of the head of state towards the objects related to the ambassador (the impersonator).
The “Custody” association class is representative of “Responsibility”, so a similar security strategy can be devised by applying the Association Class inventive aspects discussed above, adding permissions to operations into the Association Class Object(s).
From these examples, it can be seen that, using this REA Security strategy to model very important meta data, a security subsystem can be provided which can be used both at administrative and run times. As in the case of the dynamic aspect of administering and enforcing security on REA events, it is in some cases a benefit to abstract some of the decision making into a separate model and a set of business logic. This can be accomplished using a policy object or subsystem.
In some embodiments, the Security Policy is a separate model parallel to the REA model, while the REA model contains all the information the developer can possibly know during design such as the who (roles) and the what (securable Objects+possible operations on those Objects). An example of such a system is illustrated in
In alternate embodiments, one could add “Users” to the REA model itself, but this may not be preferred. However, such an embodiment is within the scope of the invention, and is illustrated in
Again, with security policy logic module 815, answers provided by the Security Policy which are in the when category (e.g., when does the permission apply?) can be generated separately from models 805/810. If requirements exist for allowing a certain set of permissions to be active during regular work hours, and a different set of permissions after hours or on weekends, a separate policy logic system or module 815 can be used, in conjunction with the Security Policy Model 810 having the Security Policy Association Class, where decisions on active policy are made based on different evidence types. Examples of evidence types include time, location, etc.
Another area of importance when it comes to deployment flexibility is how to handle various forms of privacy legislation. Many companies often are at a loss when it comes to adopting their applications to use different privacy policies depending on where they have been deployed. The REA Security strategy plus the external policy ideas will help.
The association class, defined between the first object and the second object, is an object having properties. The properties of the association class object define the security between the first object and the second object. The step of creating the association class can further comprise creating one or more association class objects having properties, with the properties of the one or more association class objects defining security between a first class of objects of which the first object is a member and a second class of objects of which the second object is a member. The second object is a securable object, such as a contract or agreement type object, a commitment type object, an event type object, or a resource type object. The first object is of a particular agent type. A role for a user is defined by the particular agent type for the first object.
The association class created between the first object and the second object can be created in a security model either separate from the REA model, or as part of the REA model. The security defined between the first object and the second object includes defining permissions and rights of the first object relative to the second object. These permissions and rights can be determined dynamically in a security policy logic module outside of the security model. This is particularly useful for permissions and rights which are transient in nature, for example depending upon the date, time, status of an event, etc.
Although the present invention has been described with reference to particular embodiments, workers skilled in the art will recognize that changes may be made in form and detail without departing from the spirit and scope of the invention.