The present invention relates generally to portal servers and, in particular, to wireless portal servers having customizable client aware content selection and rendering capability.
The use of Web portals has become widespread for obtaining information, news, entertainment, and the like, via the World Wide Web. A Web portal is generally a Web “supersite” that provides a variety of services including Web searching, news, white and yellow pages directories, free e-mail, discussion groups, online shopping and links to other sites. The Web portal term is generally used to refer to general purpose sites, however, it is increasingly being used to refer to vertical market sites that offer the same services, but only to a particular industry such as banking, insurance or computers, or fulfill specific needs for certain types of users, for example, business travelers who are often away from their office or their primary point of business.
Certain types of Web portals have evolved into customized, user type specific sources of information. One example would be a corporate Web site, wherein an internal Web site (intranet) provides proprietary, enterprise-wide information to company employees as well as access to selected public Web sites and vertical-market Web sites (suppliers, vendors, etc.). Such a Web site would typically include a customized search engine for internal documents as well as the ability to customize the portal page for different user groups and individuals. Access to such customized Web sites by business travelers, or other types of users who require concise prompt access to information, is a highly sought-after goal. For example, for a mobile user (e.g., business traveler), it would be very advantageous to obtain wireless access to a Web portal via a portable handheld device, such as a cell phone or a wireless PDA. However, presentation of information on the small screens typical with such portable handheld devices requires customization of the Web portal and the formatting of the data it provides.
Standards have been developed to provide a widely used method of formatting data for the smaller screens of portable handheld devices. One such standard is WML (Wireless Markup Language). WML is a tag-based language used in the Wireless Application Protocol (WAP). WML is an XML document type allowing standard XML and HTML tools to be used to develop WML applications. WAP is a standard for providing cellular phones, pagers and other handheld devices with secure access to e-mail and text-based Web pages. WAP provides a complete environment for wireless applications that includes a wireless counterpart of TCP/IP and a framework for telephony integration such as call control and phone book access. WAP features the Wireless Markup Language (WML) and is a streamlined version of HTML for small screen displays. It also uses WMLScript, a compact JavaScript-like language that runs in limited memory. WAP is designed to run over all the major wireless networks in place now and in the future.
A conventional portal server arrangement is shown in
As the number of different types of access devices proliferates, conventional portal servers are not equipped to provide the appropriate markup for each type of device. Each cellular phone or personal digital assistant (PDA) device understands a different type of markup language. For example, a PDA may have a completely different display than a mobile phone. Examples of types of markup language include HyperText Markup Language (HTML) commonly used for PC-based applications, Wireless Markup Language (WML) for mobile applications, Compact HTML (CHTML) for small information appliances, and Extensible HTML (XHTML) as an HTML alternative language.
The default path is to use a PC-based HTML type of markup, but this does not work on many non-PC access devices. In a mobile phone type of access device, for example, there is not a standard or universal type of markup language. There are several different types of markup language with each phone manufacturer and/or service provider using its own markup for a particular “look-and-feel” of the device. In conventional portal server approaches, it is very difficult and not cost effective to handle the thousands of different access devices currently available. One solution to this problem, as will be described in more detail below, involves using a generic markup language, such as Abstract Markup Language (AML), and then converting a document from AML to a device-specific markup language. A limitation of this approach is in the level of customization of the device-specific markup language that is generated per device. Moreover, a given device-specific markup language may not be ideal for certain Access Device.
It would be desirable to have a way to customize the containers and providers so that the markup can be customized while being generated dynamically in a wireless portal server. Although tools are in place (e.g., wirelessly connected portable handheld devices, WML and WAP based communications standards, customized Web portals, etc.) to provide customized, application specific, information to business travelers and other various types of users via portable handheld devices, existing prior art applications and methods are still generally targeted towards desktop implementations. The number of individually customized and tailored information delivery mechanisms is limited.
The present invention provides a solution that can customize information presented from a Web site or a Web portal with respect to a particular device of an individual user. The present invention automatically formats the information in accordance with the requirements of a particular client device.
In one embodiment, the present invention is implemented as a method for customizable client aware content aggregation and rendering in a portal server. The method includes step of servicing a request for content using at least one of a plurality of channels. To service the request, a first file path is accessed. The first file path points to generic non-customized information for a client device. A second file path is accessed to service the request, wherein the second file path points to customized information for the client device. The first file path can be the default file path. Aggregated content from a plurality channels is processed using a rendering engine, wherein the rendering engine is configured to output the aggregated content in a markup language tailored for the client device. The aggregated content is subsequently output in the second markup language to the client device.
In another embodiment, the present invention is implemented as a method of customizing markup includes two options: (i) changing a file path so as to not select a default Abstract Markup Language (AML) file path; and/or (ii) introducing special “tags” around device-specific markup. In this way, an AML page or document can be changed to customize the generated markup. This “customized” AML can be used to change the “look-and-feel” of a particular device accessing a portal server.
The accompanying drawings, which are incorporated in and form a part of this specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention:
Prior art
Prior art
Prior art
Reference will now be made in detail to the embodiments of the invention, examples of which are illustrated in the accompanying drawings. While the invention will be described in conjunction with the preferred embodiments, it will be understood that they are not intended to limit the invention to these embodiments. On the contrary, the invention is intended to cover alternatives, modifications and equivalents, which may be included within the spirit and scope of the invention as defined by the appended claims. Furthermore, in the following detailed description of the present invention, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be obvious to one of ordinary skill in the art that the present invention may be practiced without these specific details. In other instances, well known methods, procedures, components, and circuits have not been described in detail as not to unnecessarily obscure aspects of the present invention.
Notation and nomenclature
Some portions of the detailed descriptions which follow are presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits within a computer memory. These descriptions and representations are the means used by those skilled in the data processing arts to convey most effectively the substance of their work to others skilled in the art. A procedure, computer executed step, logic block, process, etc., are here, and generally, conceived to be self-consistent sequences of steps or instructions leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer system. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussions, it is appreciated that throughout the present invention, discussions utilizing terms such as “processing,” “examining,” “accessing,” “routing,” “determining,” “transmitting,” -storing,” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system registers or memories or other such information storage, transmission, or display devices Embodiments of the present invention function in part to solve problems associated with handling content requests from one of a large number of possible devices. Embodiments the present invention provide a way to transfer the content information from a web or application server by using a generic or Abstract Markup Language (AML) and a “Rendering Container”. Using AML and converting to an appropriate device-specific language using a “Rendering Engine” allows a portal server to accommodate conceivable access devices. Embodiments of the present invention utilize abstract markup language but still efficiently enable the customization of the content provided to the client devices. Implementations of this approach can include software that can be installed on a server, such as a portal server.
In solving problems associated with handling content requests from one of a large number of possible devices, a way to transfer the content information from a web or application server by using a generic or Abstract Markup Language (AML) and a “Rendering Container” can be employed. Using AML and converting to an appropriate device-specific language using a “Rendering Engine” allows a portal server to accommodate conceivable access devices. Further, according to embodiments, methods of customizing markup include: (i) changing a file path so as to not select the default AML file path; and/or (ii) introducing special “tags” around device-specific markup. In this way, an AML page or document can be changed to customize the generated markup. This “customized” AML can be used to change the “look-and-feel” of a particular device. For example, customization can be used by a cellular phone service carrier in order to create a standard drop-down menu look-and-feel across different mobile phone models. Implementations of this approach can include software that can be installed on a server, such as a portal server.
Referring now to
According to an embodiment, in one mode of operation, a request can arrive via the Access Device from an authenticated user to the Desktop Servlet. The Desktop Servlet can begin to form the front page, but the proper format suitable for the Access Device must be determined. Based on the type of Access Device and/or on the configuration of the Portal Server, a request may be forwarded to the Rendering Container, for example. The term “rendering” as used herein implies the ability to translate the AML-based templates to device-specific markup. The Rendering Container must be able to present the different channels desired based on the Access Device type and/or configuration. The content of the channels themselves can be generated by a provider, which can include content from a non-rendering Provider 212 or a Rendering Provider 214. Non-rendering Providers 212 can generate actual content in a device-specific format, but Rendering Provider 214 can generate actual content in AML, or a suitable generic language, format. Further, such AML content can be customized. The providers can give their content to the containers for aggregation. A container, such as Rendering Container 210 can include information or copies of content from different providers and can present an integrated view of a document in AML format. A post-processing step may be used to convert an AML document, which may be in the default AML document or in a customized markup, into a device-specific markup document. Such post-processing can occur when Rendering Container 210 calls Rendering Engine 216, which can convert the document into whatever markup is needed for presentation to Access Device 202. For a document received in AML compatible format, Rendering Engine 216 can translate the document based on the type of Access Device 202. Thus, different markups can be sent back from Rendering Engine 216. For example, if the Access Device is a Nokia phone, WML can be sent back from Rendering Engine 216. The type of Access Device can be distinguished and the Rendering Engine can return the appropriate markup. The post-processed content can then go back to the Rendering Container 210 and out to the Access Device 202. Further, the AML can be customized, as will be discussed in more detail below.
FilePath 218 can store various possible file paths for a given Access Device. A default file path for devices needing rendering can be “aml.” However, according to an embodiment, AML can be customized by changing a file path from the default to a path containing customized templates. One example of such a file path for a Nokia 7110 mobile phone can be:
In another method option, device-specific markup can be used for customization. According to embodiments, special AMLContainer “tags” can be included around device-specific markup. In this way, the Rendering Engine will know not to convert or translate the device-specific markup language within the AMLContainer. As an example, three templates may be used in a rendering component in the following fashion:
In this case, Templates B and C can be device-specific markup while Template A can include an AMLContainer tag. Accordingly, the Rendering Engine can convert Template A, but not Templates B or C, to a device-specific markup.
Depending on the type of Access Device and/or the configuration of the Portal Server, channels of content can come from device-specific or “non-rendering” providers and/or via the Rendering Provider path. Both Device-specific Containers 208 and Rendering Container 210 can accommodate a mix of “rendering” and “non-rendering” channels. Further, customization can be performed on rendering channels. Such arrangements will be described in more detail below with reference to
The flexibility in allowing combinations of channels from non-rendering Providers 212 as well as from Rendering Provider 214 is one advantage of this approach. A particular configuration may designate the device-specific path for optimized performance in cases where certain types of Access Devices are known. For example, a commonly used Nokia type of mobile phone can be supported by a configuration whereby its content is generated by a non-rendering provider via a Device-specific Container 208. Because no post-processing step is needed for this example, there is less translation involved and the access path can be optimized for performance. Also, because Nokia contains a large market share, it may be considered worth the effort to develop Nokia-specific containers. However, this would not necessarily be the case for newer types of PDAs where the market is not yet developed. For these cases, a rendering approach from an AML type document or a customized AML document may be preferred because only the rendering or “back-end” would need to be changed to accommodate a device in this category. Further, because there is currently an installed portal base with many customers, there already are many Device-specific Containers available. Accordingly, the ability to integrate the Rendering Provider 214 information with Device-specific Containers 208 through Rendering Container 210 can be important. In such an approach, the aggregated document can then be fully or partially translated via Rendering Engine 216.
Referring now to
Referring now to
Referring now to
Referring now to
The foregoing descriptions of specific embodiments of the present invention have been presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed, and obviously many modifications and variations are possible in light of the above teaching. The embodiments were chosen and described in order best to explain the principles of the invention and its practical application, thereby to enable others skilled in the art best to utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the Claims appended hereto and their equivalents.
This application is related to commonly assigned copending U.S. Patent Application “A METHOD AND SYSTEM FOR CLIENT AWARE CONTENT AGGREGATION AND RENDERING IN A PORTAL SERVER” by Sambhus et al., filed on ______, Ser. No. ______, Attorney Docket No. SUN-P030086, and “A METHOD AND SYSTEM FOR RESPONSE BUFFERING IN A PORTAL SERVER FOR CLIENT DEVICES” by Batchu et al., filed on ______, Ser. No. ______, Attorney Docket No. SUN-P030062, which are both incorporated herein in their entirety.