1. Technical Field
The present invention relates in general to a system and method for integrating applications based upon a user's actions. More particularly, the present invention relates to a system and method of integrating portlets so that source portlets are able to automatically provide data to target portlets.
2. Background Art
The portal market is one of the fastest growing markets of computer software. A portal, in the context of a preferred embodiment of the present invention, may be defined as an application that provides a secure, single point of interaction with diverse information, business processes, and people, personalized to a user's needs and responsibilities. A portal, or “Web portal,” is a Web site or service that offers a broad array of resources and services, such as e-mail, forums, search engines, and on-line shopping malls. Portals are typically accessed by a user on the Internet using a software application, such as a Web browser. A Web browser, or “browser,” is a software application used to locate and display Web pages. Two popular browsers are NETSCAPE NAVIGATOR™ and MICROSOFT INTERNET EXPLORER™. Both of these are graphical browsers, which means that they can display graphics as well as text. In addition, most modern browsers can present multimedia information, including sound and video, though they often require plug-ins in order to handle some formats.
The demand for portals drives rapid development of new technologies by different portal vendors in order to place their products in advantageous market positions. Not surprisingly, portals have evolved to their current state from a more primitive beginning. Originally, portals were mainly used as access points to different information sources with content being chosen by the portal operator. Next, portal customization provided users with the ability to choose the content that was displayed on the user's view of the portal using a Web browser. In this phase, the user was able to select information according to the user's interests and retrieve information related to his or her interests more expeditiously. Customized information delivery led to the introduction of business, or corporate, portals. Business portals were introduced to provide intra-business data within an organization.
The ongoing evolution of portals also left its footprint in the architecture of portal products. At first, portal-like products were delivered as pre-packaged applications that could be installed out of the box and included standard applications, which provided the portal functionality. As new applications were needed, vendors extended their products in order to satisfy requirements of the new applications. Due to the use of proprietary designs, portal vendors added exclusive functionality to their portals, tying the success of a portal to the applications that the portal included. This led to the decomposition of monolithic portal structures and the creation of portal frameworks.
Portal products offered today employ architectures whereby the portal itself only implements standard functionality, such as security, authorization, authentication, aggregation, caching, user management, enrollment, rendering, and the like. The portal provides the infrastructure to integrate other application components. A typical embodiment of this type of architecture includes APIs for integrating applications so that applications from different vendors can be used so long as they match the portal product's API. According to current computing jargon, these applications are commonly called “portlets.” Other synonyms for “portlets” in current use in the art include ‘iViews’ (a term utilized by SAP AG of Walldorf, Germany) or ‘web parts’ (a term utilized by Microsoft, Inc. of Redmond, Wash.).
Portlets are components that can be added to portals and are designed to run inside a portal's portlet container. Portlets may provide different functions ranging from simple rendering of static or dynamic content to application functions such as e-mail, electronic calendaring, and the like. Portlets are invoked indirectly via the portal infrastructure and produce content that is suited for aggregation in larger pages.
While portlets allow separation of application components from each other and from the underlying portal, a challenge of using portlets is the difficulty in transmitting data that appears on one portlet to another portlet. For example, if one portlet displays orders for an organization and another portlet displays details for orders, vendors would have to “couple” the portlets to allow the user to send data from one portlet to another. In a business system, many portlets may be driven from the same pieces of information, such as order numbers, account numbers, and customer numbers. Closely coupling portlets to one another increases development requirements and maintenance of each portlet. In addition, coupling portlets may require activation of each of the coupled portlets even though the user only wants to view a subset of the coupled portlets.
In commonly assigned and copending application U.S. Ser. No. 10/448,968 (CHOUDHARY, ET AL.) May 30, 2003, entitled “System and Method for User Driven Interactive Application Integration,” a manner of using information from a first portlet in performing an action in a second portlet, referred to as “Click-to-Action” is disclosed. When a user selects one of the “Click-to-Action” icons or controls displayed in a Source portlet, he or she sees a menu of actions invocable with respect to target portlets on the page that can process the properties (i.e., data items) that the icon or control is associated with. The user selects one of the actions from the menu, which results in a request being delivered to a Target portlet to perform the given action. The “Click-to-Action” feature described in the CHOWDHURY, ET AL. patent application, however, does not provide a way to persistently couple portlets.
In another commonly-assigned copending patent application, U.S. Ser. No. 10/292,074 (DUNNE, ET AL.) Nov. 12, 2002, a tool for allowing a user or administrator to couple portlets through a web-based interface was described. The DUNNE, ET AL. application describes the creation of “wires.” A wire, as the term is used in the DUNNE, ET AL. application and herein, is a persistent association between a property in a source portlet and an action in a target portlet. When an event occurs that affects the property of a wire, the action associated with that property is triggered.
Although DUNNE, ET AL. tool significantly enhanced a user's ability to custom-configure a portal interface, one drawback to the tool was that a user would have to first interact with the portlets on the portal page itself, or in complex cases read additional documentation, then navigate to a separate tool interface display in order to couple or de-couple portlets. In a moderately complex portal, a user might have to switch back and forth between the portal and the tool interface a number of times in order to complete the user's configuration of the portal, which can be inconvenient.
What is needed, therefore, is a system and method for allowing a user to couple portlets without having to switch back and forth between a tool interface display and the portal itself.
The present invention provides a method, computer program product, and apparatus for allowing an end-user or administrator to couple portlets in a portal so that information may be shared between the portlets. In particular, a preferred embodiment of the present invention provides a simplified interface through which portlets may be coupled through user interface events taking place on the portal display itself. A database stores information about the data items (called “properties”) produced and consumed by the portlets.
When the portal is displayed, if the user actuates a control corresponding to a property in a registered portlet, a menu of actions that can be performed with that data by other portlets is provided to the user. In addition to this “conventional” manner of actuating the component, an alternative manner of actuating the component is provided to the user such that if the user actuates the control in this alternative manner, the user is provided the option of making the chosen action “persistent,” so that the next time the control is actuated by the user, or the associated property is otherwise produced, the chosen action is performed automatically, without requiring the user to choose an action.
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:
Turning now to
Web application server 210 is shown serving a portal page (portal interface 212) generated via portal server 218. Portal server 218, is a specialized application to which requests for a portal (indicated, in a preferred embodiment, by URLs having a certain prefix) are handed over for processing. Since, from the perspective of web application 210, portal server 218 is an application like any other web application, web application server 210 may invoke portal server 218 through any of a number of standard web application interfaces, such as the widely-used JAVA® servlets interface standard, for example. Portal server 218 processes portlets (such as portlets 214 and 216), aggregates their markup, adds additional header/footer/formatting markup, and returns a resulting portal page 212 to web application server 210. In a preferred embodiment, portal server 218 is implemented as WEBSPHERE PORTAL SERVER, which is also a product of International Business Machines Corporation of Armonk, N.Y., and which is executed on a WEBSPHERE APPLICATION SERVER platform. One of ordinary skill in the art will recognize, however, that various portal servers are available from a number of vendors, and that the present invention is not limited to the use of any particular portal server, web server, or web application server.
Portlets 214 and 216 are two portlets that make up a portal served by web application server 210. In a preferred embodiment portlets 214 and 216 are implemented in the form of specialized servlets. However, Hypertext Markup Language (HTML) or extensible HTML (XHTML) pages with embedded server-side scripting code and/or server-side includes (SSIs) may also be used in alternative embodiments of the present invention.
A preferred embodiment of the present invention makes use of what is known as the “servlet” paradigm of web application development, where “servlets” house the program control logic. A servlet is a piece of code that follows certain standard APIs (application programming interfaces) that allow it to be invoked by a web application server. Usually, the term “servlet” is used in conjunction with the JAVA® programming language of Sun Microsystems, Inc., although those skilled in the art will recognize that the term may be applied in the context of other programming languages and run-time environments, as well, and it is in this more general sense that the term “servlet” is used in this document. In a typical JAVA® based implementation of a web application, however, servlets are used to house the program control logic of the application, JAVA® Server Pages (JSPs) are used to create the view (i.e., what is displayed to the user), and JavaBeans are created and passed to the JSPs by the servlets in order to allow the JSP-generated view to reflect the computational results and/or the computational state of the servlets.
Servlets, JSPs, and JavaBeans allow the design of a web application to be decomposed cleanly according to a model-view-controller (MVC) pattern. MVC is a manner of partitioning the design of interactive software into conceptual levels of abstraction that fall into the three categories of “model,” “view,” and “controller”. In general, the “model” represents the internal data of the program and the relationships between the data, the “view” represents how a user views the state of the model, and the “controller” is represents the manner in which the user changes the state or provides input. The data and code encapsulation provided by servlets, JSPs, and JavaBeans simplifies the design of web applications by allowing the applications to conform to an MVC design pattern.
“Server-side scripting code” is program code that is directly embedded into the content of an HTML/XHTML document through the use of special markup tags. When a web page with server-side scripting code is served by a web server, the web server identifies the presence of server-side scripting code and causes the code to be executed before the web page is transmitted to the client. Typically, server-side scripting code is used to place dynamic content into a web page before the page is transmitted to a web client. A number of server-side scripting languages and programming tools are available in the art. Java Server Pages (JSP), for example, is a technology (available from Sun Microsystems, Inc.) that allows Java program code to be embedded in an HTML document for server-side execution. Other server-side programming systems include Active Server Pages (a product of Microsoft, Inc.) and PHP, which is a popular open-source programming language and interpreter for producing server-side scripting code. “Server-side include” (SSI) is a similar mechanism for placing dynamic text in web documents in which the web server replaces special tags in a source HTML/XHTML document with other text and/or markup (such as a time/date stamp or the contents of another HTML file, for example). The popular Apache open-source web server provides SSI capabilities. Server-side scripting and server-side includes were designed as a simplification over previous forms of providing dynamic web content, such as CGI (Common Gateway Interface) scripting, which are less commonly used today as a result. One of ordinary skill in the art will recognize that although a preferred embodiment of the present invention utilizes servlets, one may also practice the teachings of the present invention using other forms of dynamic content production, including server-side scripting and CGI, without departing from the scope and spirit of the present invention.
Portal server 218, in a preferred embodiment, combines the data and program content of portlets 214 and 216 by simply consolidating the raw source HTML/XHTML (including any server-side scripting code or SSIs) into a single HTML/XHTML document with some additional “glue/wrapper” HTML/XHTML markup to specify the arrangement of portlets on portal page 212. The additional markup may itself be quite significant to the operation of the portal, and can include (in addition to markup for arranging portlet views and in a non-limiting sense), headers, footers, portal navigation links, links to common services, search bars, client-side executable code (such as JavaScript, q.v.), and the like.
Portal page 212 is served to browser 202 (via web/application server 210 in this preferred embodiment) as if it were a monolithic page. Since server-side scripting code for both portlets 214 and 216 is included in portal page 212, web application server 210 may execute whatever server-side scripting code is present in portal page 212 as if the page were originally written as a single HTML/XHTML page with server-side scripts. Web application server 210 then serves the resulting page (with server-side scripts processed) to browser 202. Alternatively, the server-side scripting code may be executed prior to assembly of portal page 212 from its constituent portlets. For example, in a preferred embodiment utilizing WEBSPHERE PORTAL SERVER, portal server 218 runs as an application within web application server 210 and utilizes the JSP processor of web application server 210 to execute the JSP scriptlets for portlets 214 and 216 individually prior to the assembly of portal page 212, so that no post-processing of the assembled portal page 212 by web application server 210 is necessary.
One of ordinary skill in the art will recognize that an alternative method of serving dynamic portal content would be to execute each of portlets 214 and 216 as a separate process (for example, as separate CGI scripts) to obtain HTML/XHTML output and then consolidate the output of the two portlets into a single HTML/XHTML page for serving to browser 202. One of ordinary skill in the art will also recognize the content served to browser 202 need not be HTML/XHTML content, but may comprise any of a number of content types presently in existence or developed in the future. For example, the content produced by portal 214 may be in a format based on the eXtensible Markup Language (XML), such as eXtensible Stylesheet Language-Formatting Objects (XSL-FO), Scalable Vector Graphics (SVG), or Wireless Markup Language (WML). In addition the content types produced by the different portlets need not be homogeneous. For example, portlet 214 may produce an SVG graphic while portlet 216 produces a document in PDF (Portable Document Format). PDF is a published document format produced by Adobe, Inc.
The present invention is directed to a method, computer program product, and data processing system for allowing a user to couple or “wire” a pair of portlets to allow information to be shared between portlets on a portal page in the context of using the portlets.
When a portlet control is actuated in the “alternative” manner, the user is given also provided with a menu of action choices, but prior to dispatching the selected action, an additional dialog is shown. This additional dialog asks the user whether or not to “persist” the selected action (i.e., by wiring the property corresponding to the actuated portlet control to an action to be performed by a target portlet). According to our terminology, a “property” is a data item that is produced by, consumed by, stored by, or otherwise associated with a portlet. For instance, in the example provided in
Once the user has made a selection of an action, the user is then prompted to specify whether to make that action “persistent.” That is, the user is given the option of having that action be associated with the user interface control or property in the future. In
Returning now to
Other options are provided by dialog box 400 in
In a preferred embodiment of the present invention, the reverse operation, namely deleting a wire, may be executed in a similar fashion, as shown in
The “on-the-portal” user interface for creating and deleting wires, depicted in
The depicted process begins with browser 801 requesting the portal page from web application server 803 (message 802). Web application server 803 then determines from the URL of the request that a portal page is requested (message 804). This causes web application server 803 to pass the request on to portal server 805 (message 806). Portal server 805 then queries a database 807 to determine a list of portlets present on the requested page (messages 808, 810). Database 807 (described in more detail in
The process of invoking the portlets themselves then begins. If a particular action for a portlet is specified in the URL of the request, an identification of that action is then delivered to the portlet (e.g., portlet 809) (messages 814, 816). Portal server 805 then requests the markup for each portlet in the page (messages 818, 820). To the obtained portlet markup, portal server adds additional markup for footers and other features that are located after the portlet markup itself in the portal page (message 822). This portal page is then returned to web application server 803 (message 824), which then serves the generated portal page as a monolithic page of markup (message 826).
As can be observed from
The E-R (entity-relationship) approach to database modelling provides a semantics for the conceptual design of databases. With the E-R approach, database information is represented in terms of entities, attributes of entities, and relationships between entities, where the following definitions apply. The modelling semantics corresponding to each definition is illustrated in
Entity: An entity is a principal object about which information is collected. For example, in a database containing information about personnel of a company, an entity might be “Employee.” In E-R modelling, an entity is represented with a box. An entity may be termed weak or strong, relating its dependence on another entity. A strong entity exhibits no dependence on another entity, i.e. its existence does not require the existence of another Entity. As shown in
Attribute: An attribute is a label that gives a descriptive property to an entity (e.g., name, color, etc.). Two types of attributes exist. Key attributes distinguish among occurrences of an entity. For example, in the United States, a Social Security number is a key attribute that distinguishes between individuals. Descriptor attributes merely describe an entity occurrence (e.g., gender, weight). As shown in
In some cases, an attribute may have multiple values. For example, an entity representing a business may have a multi-valued attribute “locations.” If the business has multiple locations, the attribute “locations” will have multiple values. A multi-valued attribute is represented by concentric ovals, as shown in
Relationships: A relationship is a connectivity exhibited between entity occurrences. Relationships may be one to one, one to many, and many to many, and participation in a relationship by an entity may be optional or mandatory. For example, in the database containing information about personnel of a company, a relation “married to” among employee entity occurrences is one to one (if it is stated that an employee has at most one spouse). Further, participation in the relation is optional as there may exist unmarried employees. As a second example, if company policy dictates that every employee have exactly one manager, then the relationship “managed by” among employee entity occurrences is many to one (many employees may have the same manager), and mandatory (every employee must have a manager).
As shown in
We now turn to the semantic content of
Turning now to portlet entity 1212, a portlet produces (relationship 1214) properties (entity 1216) and performs (relationship 1218) various actions (entity 1220) that consume (relationship 1222) properties (entity 1216). A wire (entity 1224) maps a single “producer” (entity 1228) to a single consumer (entity 1234) (relationships 1226 and 1232). A “producer” (entity 1228) is (relationship 1231) a portlet (entity 1212) that produces (relationship 1230) a particular property (entity 1216), while a “consumer” (entity 1234) is (relationship 1236) an action (entity 1220) that consumes (relationship 1222) the property (entity 1216) produced by the corresponding producer (entity 1228), as associated by wire entity 1224 and relationships 1226 and 1232. A producer and consumer may be able to share a property based on some criterion associated with the property, such as a data type. A user (entity 1200) may make use of (relationship 1238) a number of wires (entity 1224).
PCI bus 1314 provides an interface for a variety of devices that are shared by host processor(s) 1300 and Service Processor 1316 including, for example, flash memory 1318. PCI-to-ISA bridge 1335 provides bus control to handle transfers between PCI bus 1314 and ISA bus 1340, universal serial bus (USB) functionality 1345, power management functionality 1355, and can include other functional elements not shown, such as a real-time clock (RTC), DMA control, interrupt support, and system management bus support. Nonvolatile RAM 1320 is attached to ISA Bus 1340. Service Processor 1316 includes JTAG and I2C busses 1322 for communication with processor(s) 1300 during initialization steps. JTAG/I2C busses 1322 are also coupled to L2 cache 1304, Host-to-PCI bridge 1306, and main memory 1308 providing a communications path between the processor, the Service Processor, the L2 cache, the Host-to-PCI bridge, and the main memory. Service Processor 1316 also has access to system power resources for powering down information handling device 1301.
Peripheral devices and input/output (I/O) devices can be attached to various interfaces (e.g., parallel interface 1362, serial interface 1364, keyboard interface 1368, and mouse interface 1370 coupled to ISA bus 1340. Alternatively, many I/O devices can be accommodated by a super I/O controller (not shown) attached to ISA bus 1340.
In order to attach computer system 1301 to another computer system to copy files over a network, LAN card 1330 is coupled to PCI bus 1310. Similarly, to connect computer system 1301 to an ISP to connect to the Internet using a telephone line connection, modem 1375 is connected to serial port 1364 and PCI-to-ISA Bridge 1335.
While the computer system described in
While particular embodiments of the present invention have been shown and described, it will be obvious to those skilled in the art that, based upon the teachings herein, that changes and modifications may be made without departing from this invention and its broader aspects. Therefore, the appended claims are to encompass within their scope all such changes and modifications as are within the true spirit and scope of this invention. Furthermore, it is to be understood that the invention is solely defined by the appended claims. It will be understood by those with skill in the art that is a specific number of an introduced claim element is intended, such intent will be explicitly recited in the claim, and in the absence of such recitation no such limitation is present. For non-limiting example, as an aid to understanding, the following appended claims contain usage of the introductory phrases “at least one” and “one or more” to introduce claim elements. However, the use of such phrases should not be construed to imply that the introduction of a claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an”; the same holds true for the use in the claims of definite articles.
This application is a continuation application of U.S. Non-Provisional patent application Ser. No. 10/776,040, entitled “Persistence of Inter-Application Communication Patterns and Behavior Under User Control,” filed on Feb. 11, 2004 now U.S. Pat. No. 7,376,739.
Number | Name | Date | Kind |
---|---|---|---|
6832263 | Polizzi et al. | Dec 2004 | B2 |
6918088 | Clark et al. | Jul 2005 | B2 |
6938067 | Hershenson | Aug 2005 | B2 |
6950990 | Rajarajan et al. | Sep 2005 | B2 |
6950991 | Bloomfield et al. | Sep 2005 | B2 |
6957218 | Wyatt | Oct 2005 | B1 |
6981263 | Zhang et al. | Dec 2005 | B1 |
6990653 | Burd et al. | Jan 2006 | B1 |
6996778 | Rajarajan et al. | Feb 2006 | B2 |
7013329 | Paul et al. | Mar 2006 | B1 |
7028261 | Smyth et al. | Apr 2006 | B2 |
7043531 | Seibel et al. | May 2006 | B1 |
7051084 | Hayton et al. | May 2006 | B1 |
7089560 | Uhler et al. | Aug 2006 | B1 |
7103642 | Chen et al. | Sep 2006 | B1 |
7107543 | Berry et al. | Sep 2006 | B2 |
7111060 | Araujo et al. | Sep 2006 | B2 |
7146404 | Kay et al. | Dec 2006 | B2 |
7146563 | Hesmer et al. | Dec 2006 | B2 |
7159180 | Ward | Jan 2007 | B2 |
7167448 | Wookey et al. | Jan 2007 | B2 |
7188112 | Lindquist et al. | Mar 2007 | B1 |
7194683 | Hind et al. | Mar 2007 | B2 |
7200804 | Khavari et al. | Apr 2007 | B1 |
7203909 | Horvitz et al. | Apr 2007 | B1 |
7210098 | Sibal et al. | Apr 2007 | B2 |
7216298 | Ballard et al. | May 2007 | B1 |
7216351 | Maes | May 2007 | B1 |
7231608 | Fano et al. | Jun 2007 | B1 |
7240280 | Jolley et al. | Jul 2007 | B2 |
7240296 | Matthews et al. | Jul 2007 | B1 |
7246324 | Mikhail et al. | Jul 2007 | B2 |
7263663 | Ballard et al. | Aug 2007 | B2 |
7277924 | Wichmann et al. | Oct 2007 | B1 |
7281060 | Hofmann et al. | Oct 2007 | B2 |
7281202 | Croney et al. | Oct 2007 | B2 |
7281217 | Choudhary et al. | Oct 2007 | B2 |
7281252 | Lindquist et al. | Oct 2007 | B1 |
7299274 | Rajarajan et al. | Nov 2007 | B2 |
7310677 | Cohen et al. | Dec 2007 | B1 |
7313621 | Gudorf et al. | Dec 2007 | B2 |
7340679 | Botscheck et al. | Mar 2008 | B2 |
7366795 | O'Neil et al. | Apr 2008 | B2 |
7454195 | Lewis et al. | Nov 2008 | B2 |
7472170 | Zak et al. | Dec 2008 | B2 |
7475346 | Bullock et al. | Jan 2009 | B1 |
7480921 | Vigesaa et al. | Jan 2009 | B1 |
7490135 | Klug et al. | Feb 2009 | B2 |
7509397 | Totty et al. | Mar 2009 | B1 |
7533142 | Ng et al. | May 2009 | B2 |
7555529 | Bloomfield et al. | Jun 2009 | B2 |
7653744 | Kanefsky et al. | Jan 2010 | B2 |
7668913 | Underwood et al. | Feb 2010 | B1 |
7716591 | Chen et al. | May 2010 | B2 |
7725560 | Bales et al. | May 2010 | B2 |
7778717 | Bachman et al. | Aug 2010 | B2 |
7792947 | Kembel et al. | Sep 2010 | B1 |
7801990 | Anuff et al. | Sep 2010 | B2 |
7802207 | Agboatwalla et al. | Sep 2010 | B2 |
20030105854 | Thorsteinsson et al. | Jun 2003 | A1 |
20030110448 | Haut et al. | Jun 2003 | A1 |
20030167315 | Chowdhry et al. | Sep 2003 | A1 |
20040090969 | Jerrard-Dunne et al. | May 2004 | A1 |
20040133660 | Junghuber et al. | Jul 2004 | A1 |
20040148341 | Cotte | Jul 2004 | A1 |
20040167989 | Kline et al. | Aug 2004 | A1 |
20040199603 | Tafla et al. | Oct 2004 | A1 |
20040216036 | Chu et al. | Oct 2004 | A1 |
20040268288 | Bajuk et al. | Dec 2004 | A1 |
20050071853 | Jones et al. | Mar 2005 | A1 |
20050097190 | Abdelhak | May 2005 | A1 |
20050188066 | Papanikolaou et al. | Aug 2005 | A1 |
20060031222 | Hannsmann | Feb 2006 | A1 |
Number | Date | Country |
---|---|---|
961452 | Dec 1999 | EP |
967558 | Dec 1999 | EP |
2000090058 | Mar 2000 | JP |
2000222297 | Aug 2000 | JP |
Number | Date | Country | |
---|---|---|---|
20080201476 A1 | Aug 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10776040 | Feb 2004 | US |
Child | 12108850 | US |