1. Technical Field
The present invention relates generally to an improved data processing system. In particular, the present invention relates to a method, apparatus, and computer instructions for using business models directly in message oriented middleware.
2. Description of Related Art
Component-based distributed enterprise computing is an appealing solution to business computing needs. Rather than requiring extensive custom software (and in some cases hardware) to be written to meet the particular enterprise, a component-based distributed enterprise computing model allows different individual applications, services, or other components, possibly operating in disparate hardware or software environments, to interoperate. Distributed enterprise computing systems achieve this interoperability through the use of middleware.
Middleware is software that provides a platform for interoperation between software components in a distributed system. Message-oriented middleware is often used in application integration strategies. One common interaction pattern supported by this type of middleware is publish/subscribe.
Currently, publish/subscribe systems employ a topic-based approach to publishing messages. Subscriber 104 first registers to receive messages based on a subject or topic name. Subscriber 104 may register using explicit subject or topic names or, alternatively, use wildcards to receive a broader subscription. Publisher 102 sends the message to subscriber 104 only if the subscription matches the published topic.
Business analysts in an industry may define an organization in terms of the organization's processes, rules, and goals of the organization, as well as elements within the organizational structure and the relationship between these elements. The analysts then create business models for the application domain using a rich hierarchy of objects. An object may represent a single component or element of a business process and the interactions between objects can be shown through workflow diagrams. However, there is a juxtaposition between the business model that is used to represent the application domain and how conventional messaging systems, such as publish/subscribe, create topics for subscription.
Consider the example of a developer who is responsible for one component, called ‘AutoTeller’, which is part of a large enterprise application, e-Bank. For the sake of example, assume that the application used to system test the developer's code is capable of producing notifications by publishing test records that detail the causes of failure.
In the scenario above, the developer would like to be notified when his component causes a test case to fail on Linux and Windows because of a null pointer exception. Using Java Message Service (JMS), the developer may create notification topics such as the topics below:
In an alternative example, conventional publish/subscribe systems may employ a combination of notification topics and message selectors to match fields in the header. For example, the topic may be “e-Bank/AutoTeller” with a selector/header of:
Therefore, it would be advantageous to have a method, apparatus, and computer instructions for allowing business models to be used directly in message oriented middleware, and specifically in publish/subscribe brokers.
The present invention provides a method, system, and computer instructions for using the language of the business domain to express subscriptions to a publish/subscribe messaging system. The resulting notifications sent to the subscriber are instances of the business model used to create the subscription. A subscriber may subscribe to the messaging system against the same information that the subscriber receives in a notification from the messaging system. The present invention uses the model from the business domain as the basis for notification subscriptions to allow for defining filters directly against the model's attributes, reducing problems caused by translating business models to a middleware description.
The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
With reference now to the figures and in particular with reference to
In the depicted example, a server 204 is connected to network 202 along with storage unit 206. In addition, client 208, 210, and 212 also are connected to network 202. These clients may be, for example, without limitation, personal computers or network computers. A network computer is any computer, coupled to a network, which receives a boot image from another computer coupled to the network and also may be a server managed computer. Server 204 provides data, and may be form example, a web server on the Internet, and applications to clients 208-212. Clients 208, 210, and 212 are clients to server 204. Distributed data processing system 200 may include additional servers, clients, and other devices not shown.
Turning next to
An operating system runs on processor 302 and is used to coordinate and provide control of various components within data processing system 300 in
Those of ordinary skill in the art will appreciate that the hardware in
The present invention provides a method, system, and computer instructions for using business models directly in message oriented middleware. In particular, the present invention allows for using the language of the business domain to express subscriptions to a publish/subscribe messaging system. By using business models when subscribing to a publish/subscribe system, the resulting notifications sent to the subscriber are actually instances of the business model used to create the subscription. In other words, a subscriber may subscribe to the messaging system against the same information that the subscriber receives in a notification from the messaging system. The present invention provides a mechanism to introspect on a business model and define filters directly against the business model's attributes. By using business models defined by business analysts directly in the message-oriented middleware, no translation of the business model to middleware description is necessary.
An application framework, such as Firefly Runtime framework which is a product of International Business Machines Corporation located in Armonk, N.Y., may be used to easily create an environment that facilitates the construction of integrated, server-based, application development components. Firefly Runtime is a framework that enables enterprise integration using a messaging based infrastructure. Firefly Runtime allows for loose coupling between applications and for notifications from applications to be routed to other applications as well as users of those applications.
To implement the present invention, a notification provider, which is a system that generates notifications and sends them to a notification framework system such as Firefly Runtime, must first be registered with the notification framework. For example, the provider administrator sends an email request to the notification framework administrator and includes the name of the provider. In response, the notification framework administrator creates a service ID for the provider and registers the provider using the service ID and the provider name.
Once the provider is registered, the provider creates a notification model in order to send a notification to the notification framework. This notification model defines the data types that flow as part of the notification and is created based on the data types from the business model. The notification model is then registered with the notification framework. The notification provider may also create and register filter sets with the notification framework system. For example, the provider administrator may use a WebSphere Studio workbench to access and login to the notification framework using the service ID and password obtained when the provider was registered. The provider administrator may use the graphical user interface (GUI) provided by the notification framework plug-in to create filter sets. After the filter sets are created, the provider is able to send notifications to the notification framework system.
When a user subscribes to receive notifications, the user may only subscribe for notifications that originate from a notification provider to which the user has access. Thus, if a subscriber does not have access to a provider but would like to receive notifications from the provider, the user should make such a request to the provider. Consequently, the provider may add the subscriber to its access list. Once a subscriber is added to a provider's access list, the subscriber is eligible to receive notifications from that provider.
In addition, the subscriber defines the delivery channel preferences in order to receive notifications. For example, a subscriber may assign delivery channel preferences such as Simple Object Access Protocol (SOAP), Enterprise Java Bean (EJB), and Simple Mail Transfer Protocol (SMTP). A delivery channel may be associated with a subscription. When a notification matches a subscription, it is delivered to the owner of the subscription at the endpoint specified by the delivery channel associated with the subscription.
Furthermore, the subscriber may optionally define filters according to the user's needs. A subscriber may select filters created by the provider. A filter represents a condition that an incoming notification must satisfy in order for the notification to be delivered to the subscriber.
Turning now to
Notification model repository 404 stores the business models which are registered by providers in a central repository. Although the implementation shown in
Matchmaking subsystem 408 performs content based matching based on incoming notifications and the list of current subscriptions. For example, a relational database may be used to create dynamic SQL queries based on the provider's model as well as the incoming notification. When a match occurs, dispatching subsystem 410 is contacted with the original notification, a list of matched principals, and a list of dispatch channels. The notification may be dispatched using assigned delivery channels, such as EJB session bean invocation 430, SMTP message 432, JMS Message 434, and SOAP/HTTP Web service call 436.
Firefly Runtime framework 400 is presented as an example of an application framework for enterprise integration using a messaging based infrastructure in which the present invention may be embodied. Firefly Runtime framework 400 is not meant to imply architectural limitations to the present invention. Presently available message based infrastructures may include additional functions not shown or may omit functions shown in Firefly Runtime framework 400. A message based framework may be any infrastructure that is used to provide notifications on a distributed data processing system.
Notification framework subscription model 500 is shown to include filter set 502. Filter sets are defined by the providers, such as provider 504. The provider administrator may define filter sets using WebSphere Studio workbench to access and login to the notification framework using the service ID and password obtained when the provider was registered. The provider administrator may use the graphical user interface provided by the notification framework plug-in to create filter sets. Provider 504 is associated with filter set 502 through provider location 506, provider location descriptor 508, and filter set descriptor 510. Notification model 512, which contains the model a user may subscribe against, is associated with provider location 506.
Filter set 502 contains filters, such as filters 514, which in turn contain filter fragments, such as filter fragments 516. Subscription 518 is associated with filter 514 through filter descriptor 520. Subscription 518 is also associated with delivery channel 522 through delivery channel descriptor 524. Once filter sets 502 are created, provider 504 is able to send notifications to the notification framework system.
In this particular example, EMF is used to aid in the construction of a notification model within the notification framework. EMF is a basic Java development environment and code generation facility for building a development environment from plug-in components. EMF allows for developing models that may be defined using XML Metadata Interchange (XMI). XMI enables easy interchange of metadata among modeling tools and repositories in a distributed heterogeneous environment. For example, the notification model may be defined using a Unified Modeling Language (UML) modeling tool, such as Rational Rose. The notification model may also be defined using an XML schema or by annotating Java interfaces with model properties. Once the EMF business model is defined, the EMF code generator may be used to create a corresponding set of Java implementation classes. An internal metamodel called Ecore, which is a subset of Meta Object Facility (MOF), may use the EMF code generator to generate a complete Java Application Programming Interface (API) for the EMF notification model.
Once notification provider 602 is registered with the notification framework, notification provider 602 may create a notification model, such as notification model 600. Each provider has a provider location, such as provider location 604, which specifies the location of the provider. Notification model 600 may also contain artifacts, such as artifact 606, which represents process deliverables, such as use-cases, code, plans, test cases, and test results.
Provider 602 may be used to extend notification model 600, such that notification models Build 608, TestCase 610, and ChangeRequest 612 are created and form an inheritance relationship with artifact 606. In this manner, artifact 606 may be further defined by notification models Build 608, TestCase 610, and ChangeRequest 612.
In addition, notification model 600 may also be used to extend notification model 600. For example, NightlyBuild 614 may be created to inherit from Build 608, and be further defined by IntegrationBuild 616. Likewise, FVTTestCase 618 may be created to inherit from TestCase 610, and be further defined by Orphan 620.
Turning now to
Once the objects are serialized, notification models 702, 704, and 706 may be registered with a notification broker. As a result of registering the notification models with the notification broker, a subscriber may subsequently view the notification models the subscriber is authorized to subscribe against in GUI 700.
Once the subscription is named, the user may then select the subscription class, as shown in graphical user interface 810 in
Turning now to
The user may apply a filter against an attribute by first selecting an attribute name. In the example, attribute name “current action” has been selected from dropdown list 902. Once the attribute has been identified, the user may apply operators and values against the selected attribute. For example, for current action attribute, the “=” operator has been selected from dropdown list 904 and the “verify” operand has been entered in operand box 906. The user may then select finish button 908 at the bottom of GUI 900 to continue the subscription process.
Turning now to
When a notification matches a subscription, it is delivered to the owner of the subscription at the endpoint specified by the delivery channel associated with the subscription. A subscriber can define one or more delivery channels.
The example in GUI 1100 shows a new delivery channel, “MyApplicationSink” 1102, has been created. Once the delivery channel is named, the user may then select the method of delivery. For example, GUI 1100 allows the user to select either EJB 1104, SOAP 1106, or Email (SMTP) 1108 delivery channel. Once the user has selected the delivery channel, the user may then click next button 1110 at the bottom of GUI 1100 to continue the subscription process.
When a notification is to be delivered, the delivery channel property for the subscription is accessed. In this example, delivery channel property 1206 has a value of “workbench default”. Consequently, workbench default delivery channel 1206, in this case SOAP 1208, is used to send the notification to the subscriber.
Turning now to
The process begins by registering business models with a notification framework (step 1402). Next, the user creates a new subscription to subscribe against a provider's notification models (step 1404). In this step, the user names the subscription and selects the class for the subscription. Filters may then be added against the selected attributes of the subscription (step 1406). For example, the notification model is first introspected to determine the attributes. Once the attributes are determined, filters in the form of operators and values are applied against each attribute.
Next, notification delivery protocols are selected for the subscription (step 1408). For example, a user may select that the notification be delivered via a delivery channel such as EJB, SOAP, or Email (SMTP). The subscriber may then receive the notification based on the business model (step 1410), with the process terminating thereafter.
Thus, the present invention provides a method, apparatus, and computer instructions for allowing business models to be used directly in message oriented middleware, and specifically in publish/subscribe brokers. The advantages of the present invention should be apparent in view of the detailed description provided above. Messaging systems using topics with message selectors may provide notifications to applications. However, such topic-based approaches have proven to be problematic since it is often difficult to transform the business model into an effective topic, as well as potentially resulting in a large number of topics. In addition, it may be difficult to express all attributes in a message header when the model contains multiple levels. In contrast, the present invention uses the model from the business domain as the basis for notification subscriptions to allow for defining filters directly against the model's attributes, reducing problems caused by translating business models to a middleware description.
It is important to note that while the present invention has been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions and a variety of forms and that the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer readable media include recordable-type media, such as a floppy disk, a hard disk drive, a RAM, CD-ROMs, DVD-ROMs, and transmission-type media, such as digital and analog communications links, wired or wireless communications links using transmission forms, such as, for example, radio frequency and light wave transmissions. The computer readable media may take the form of coded formats that are decoded for actual use in a particular data processing system.
The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.