Title of Invention

"SYSTEM OF ASSIGNING GANERATING AND DELIVERING CONTENT TO USES OF A COMPUTER NETWORK"

Abstract Systems, methods and computer program products allow intranet adminstrators to assign, generate and deliver content to users of an intranet. Intranet users are defined and assigned to various defined user groups. Units of content available to users of an intranet are also defined and assigned to various defined content groups. The defined content groups are then associated with the defined user groups such that each of the defined user groups has at least one of the defined units of content associated therewith. A content page creation profile is provided for each defined user and is configured to control how content is displayed within a user"s customized content page. Through identified relationships of user groups and content groups, the...
Full Text SYSTEMS, METHODS AND COMPUTER PROGRAM PRODUCTS FOR
ASSIGNING, GENERATING AND DELIVERING
CONTENT TO INTRANET USERS
Field of the Invention
The present invention relates generally to computer networks and, more particularly, to private computer networks. '
Background of the Invention
An intranet|is a private computer network contained within an enterprise and conventionally includes one or more intranet servers in communication •with multiple user computers. An intranet may be comprised of interlinked local area networks and may also use leased-lines in a wide-area network. An intranet may or may not include connections to the outside Internet. Intranets conventionally utilize various Internet protocols and, in general, often look like private versions of the Internet. An intranet user conventionally accesses an intranet server via a web browser running locally on his/her computer. An exemplary web browser is Netscape Navigator® (Netscape Communications Corporation, Mountain View, CA) .
Information, applications and other resources (collectively referred to herein as "content") are 'conventionally delivered from an intranet server to a web browser on a user's computer in the form of hypertext documents or "web pages." As is known to those skilled in this art, a web page is conventionally formatted via a standard page description language such as HyperText Markup Language (HTML), and typically displays text and graphics, and can play sound, animation, and video data. HTML provides basic document formatting and allows a we"b page developer to. specify hypertext links (typically manifested as highlighted text) to other servers and files. When a user selects a particular hypertext link, a web browser reads and interprets the address, called a URL (Uniform Resource Locator) associated with the link, connects the web browser with the web server at that address, and makes an HTTP request for the web page identified in the link. The web server then sends the requested web page to the client in HTML format which the browser .interprets and displays to the user.
Intranets are conventionally used to share content among the employees of an enterprise. When intranets first emerged, content tended to be focused towards a particular set of users. However, as intranets have become more integral with the day-to-day operations of an enterprise, intranet content has become available for many different sets of users. Unfortunately, the task of organizing, distributing and updating large amounts of intranet content can be difficult. Furthermore it can be difficult for users to
keep track of and locate content relevant tp their
jobs. i
containing web pages "content pages") dis
Figs. 1 and 2 illustrate exemplary content-
(referred to hereinafter as played via a web browser in
communication with an intranet server. In Fig. 1, the displayed content on the content page 10 includes a list 12 of available "Administrative Documents". In Fig. 2, a user has selected item 12e from the content page list 12 of Fig. 1, and a list of "1998 Function Reports" 14 has been displayed within a second content page 16, as a result.
Users of an intranet are typically interested only in a subset of the total content available through an intranet. As a result, intranet users often create "bookmarks" or shortcuts to particular content. For example, a user of the intranet content pages illustrated in Figs. 1 and 2 may only have an interest in the unit of content entitled "1998 Guidelines for .Client Managers" (Fig. 2). Rather than accessing the content by displaying the content pages 10, 16 of Figs. 1 and 2, a user can bookmark and store the URL for this unit content ("1998 Guidelines for Client Managers") within his or her web browser. The URL for the unit of content entitled "1998 Guidelines for Client Managers" is : (http://intranet/admin/manage_com/1998__ function_reports/1998_guidelines_client_mgrs.pdf) .
Bookmarks are created within the web browser of a user's computer and are typically stored locally on the user's computer. Unfortunately, the use of
bookmarks can be disadvantageous for several reasons. Locally stored bookmarks may become inoperative if content referenced by a bookmark is relocated to another URL. Furthermore, a user may not have access to his or her locally stored bookmarks if he or she uses a different computer or device to access the intranet.
Often, management of an enterprise wants to direct intranet users to specific content. Unfortunately, it may be difficult for an intranet administrator to force users to update their 'locally stored bookmarks to reflect changes in the 1-ocation of content or to reflect new content. As a result, intranet administrators often deploy content pages of . available URLs to help users find relevant content. In effect, these content pages act as index pages for the content of an intranet. Unfortunately, for intranets containing large amounts of content, a user may have to search through large numbers of URLs to locate specific content. For example, a Java® programmer seeking content related to his/her programming job may have to .initially access an index content page, then an engineering content page, then a programming content page, and then a Java content page to locate the particular content. For many enterprises, the amount of available content may make the task of locating specific content difficult.
Intranet usage can increase computer network .traffic, especially in enterprises where many users are accessing the same content from intranet servers. Such increased traffic may also cause "bursts" of network traffic, such as when a number of users log into an
intranet site in the morning, which may require network

resources to be able to handle thes^ bursts which may
be significantly more traffic than the steady state
traffic level of the network. Increased network traffic
may hamper the availability of content. In addition,
some requested content may require some type of
transformation in order to be viewable by various
users' computers. Unfortunately, content transformation
may increase processing demands on the server which can
degrade server performance, especially during times of
peak demand. - .
Summary of the Invention
In view of the above discussion, it is an
I
object of the present invention to provide intranet x
r
users with the ability to quickly and easily locate and access content.
It is another object of the present invention to allow intranet users to create and maintain customized content page access to content that is available from any computer connected'to an intranet.
It is another object of the present invention to allow intranet administrators to direct specific content to intranet users regardless of where a user's point of access to the intranet is located.
It is another object of the present invention to facilitate the efficient use of intranet system resources and to facilitate the reduction of computer network traffic caused by intranet access and content transformation.
These and other objects of the present
invention are provided by systems, methods and computer program products for assigning, generating and .delivering content to users of an intranet. Intranet 'users are defined and assigned to various defined user groups. Units of content available to users of an intranet are also defined and assigned to various defined content groups. The term "unit of content" refers to any type of information including, but not limited to, a hypertext link (i.e., web link) to information contained elsewhere; an activation device, such as a button on a web page displayed to a user that launches a new browser window to display information/and information embedded within a web page displayed to a user. The defined content groups are then associated with the defined user groups such that each of the defined user groups has at least one of the defined units of content associated therewith. A content page creation profile is provided for each defined user and is configured to control how content is displayed within a user's customized content page.
According to another aspect of the present invention, a content page is generated for a user when the user logs in to an intranet. Upon identifying the user, user groups to which the user is assigned are then identified. Content groups associated with the identified user groups are then identified. Through the identified relationships of user groups and content groups, the units of content assigned to the user can be determined and a content page containing the assigned units of content is created. Preferably, the units of content displayed on a user's content page are
arranged according to a contend page creation profile assigned to the user. The created content page is then delivered to the user for display via a.web browser on the user's device.

The present invention because, upon logging in to an
is advantageous Intranet, a user is

provided with a customized content page that provides access to content specifically relevant to the user. Accordingly, a user does not have to search through pages of often irrelevant content listings to locate content relevant to his or-her job. A user can receive his or her content on any device in communication with an intranet implementing the present invention. An intranet administrator can also direct specific content to intranet users regardless of where a user's point; of access to the intranet is located. In addition, users can create and maintain customized content pages from any device connected to the intiranet.
According to another aspect of the present invention, content may be delivered to a user's computer during off-peak hours prior to the generation of user requests for the content. Units of content assigned to a content group mayi be prefetched from an intranet, or from the Internet,! and exported into a content package. Content packages may be optionally compressed. A determination may be made whether a user device already contains the present version of the _content package and, if not, the content package can be transmitted to the user device. Preferably, content delivery according to this aspect of the present invention is performed during off-peak hours when
network traffic is low. Because a given content group
*
may be shared by a large number of users, the retrieval and delivery of this content group prior to receiving user requests can substantially reduce network traffic and furthermore allow for controlled delivery so as to spread network traffic out over time to reduce traffic bursts.
The present invention also allows content transformations to be performed during off-peak hours, thus conserving processor capacity and reducing user wait time. Preferably, prefetched units of content are transformed from a first format to a second format prior to being exported into a compressed content package. For example, a color image may be transcoded into a gray scale image upon determining that a particular user device is configured to only display gray scale images. Content transformation of prefetched content according to the present invention can reduce processor demand during times of peak demand.
Brief Description of the Drawings
Figs. 1-2 illustrate exemplary content pages, displayed via a browser, that contain lists of URLs for accessing respective units of content available through an intranet.
Fig. 3 schematically illustrates a client-hosting computer and a server-hosting computer in •communication via an intranet in which the present invention can be implemented.
Fig. 4 schematically illustrates an intranet client accessing a content page, hosted by an intranet
server.
Figs. 5A-5D schematically illustrate operations for carrying out various aspects of assigning, generating, and delivering content to intranet users accordir.g to the present invention.
Fig. 6 illustrates four defined user objects
which represent respective users of an intranet, three
defined user group objects which represent respective
defined user groups, and the relationships between the
respective users and user groups, according to the
present invention. " ".
Fig. 7 illustrates four defined content objects which represer.. respective units of content available through an intranet, three defined content group objects which represent respective defined content groups, and the relationships between the respective units of content and content groups, according to the present invention.
Fig. 8 illustrates the three defined user group objects of Fig. 5, the three defined content .group objects of Fig. 7, and the associations between the respective user groups and content groups, according to the present invention.
Fig. 9 illustrates a server-side agent and a client-side agent for performing various operations according to the present invention.
Figs. 10-30 illustrate various exemplary user interfaces for carrying out aspects of the present invention related to assigning content to users of a computer network.
fulfills requests from clients in the same or other
X
computers. A given application in a computer may function as a.client wich requests for services from other programs and a server of requests from other programs. As is understood by those skilled in the art of client/server communications, an authentication server may be utilized to create an environment associated with a specific set of user credentials. Referring now to Fig. 3, a client/server communications configuration within which the present invention can be implemented is schematically illustrated. Users typically access an intranet using a client program, such as a web browser, running on a computer 20. Web browsers typically provide a graphical user interface for retrieving and viewing web pages hosted by servers. Exemplary client-hosting computers 20 may include, but are not limited to, Apple®, IBM®, or IBM-compatible personal computers. A client-hosting computer 20 preferably includes a central processing unit 21, a display 22, a pointing device 23, a keyboard 2.4, a communications device 25 (such as a modem or network interface), and a connection 26 for connecting to the intranet 27. The keyboard 24, having a plurality of keys thereon, is in communication with the central processing unit 21. A pointing device 23, such as a mouse, is also connected to the central processing unit 21. The intranet connection 26 may be made via traditional phone lines, an ISDN link, a Tl link, a T3 link, via cable television, via an ethernet network, and the like.
Detailed Description of the Invention
f
The present invention now will be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, chese embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like numbers refer to like elements throughout.
As will be appreciated by one of skill in the art, the present invention may be embodied as a method, data processing system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. Furthermore, the present invention may take the form of a computer program product on a •computer-usable storage medium having computer-usable program code means embodied in the medium. Any suitable computer readable medium may be utilized including hard disks, CD-ROMs, optical storage devices, or magnetic storage devices.
Client/Server Communications
As is known to those with skill in this art, an intranet may be implemented within a client-server environment. A client is the requesting program in a client/server relationship. A server awaits and
The central processing unit 21 contains one or more microprocessors (not shown) or other computational devices and random access memory (not shown) or its functional equivalent, including but not limited to, RAM, 7LASKRAM, and VRAM for storing programs therein for processing by the microprocessor(s) or o~her computational devices. A portion of the random access memory and/or persistent data storage, referred to as "cache," is often utilized during communications between a client-hosting computer 20 and a server-hosting computer (described below) to store various data transferred from a server.
Preferably, a client-hosting computer 20 has an Intel® 80486 processor (or equivalent) with at least eight megabytes (8 MB) -of RAM, and at least five megabytes (5 MB) of persistent computer storage for caching. Even more preferable is an Intel® Pentium® processor (or equivalent). However, it is to be understood that various processors may be utilized to carry out the present invention without being limited to those enumerated herein. A client-hosting computer 20, if an IBM®, or IBM-compatible personal computer, preferably utilizes either a Windows® 3.1, Windows 95®, Windows 98®, Windows NT®, Unix®, or OS/2® operating system. However, it is to be understood that a device not having computational capability, or having limited computational capability, may be utilized in accordance • with the present invention for retrieving content through an intranet.
Typically, an intranet user accesses content by establishing TCP/IP communications between a client-
I hosting computer 20 and a, server-hosting computer 30
' *»
(referred to hereinafter as an intranet server). For many intranet communications, a web browser communicates with an intnanet server using HyperText Transfer Protocol (HTTP) over a Transmission Control Protocol/Internet Protocol (TCP/IP) link between the client-hosting computer 20 and the intranet server 30. Typically, the data transferred between the client-hosting computer 20 and the intranet server are HTTP data objects (e.g. HTML data).
As is known by those having skill in the art, an intranet server-hosting computer 30 may have a configuration similar to that of a client-hosting computer 20 and may include a central processing unit 31, a display 32, a pointing device 33, a keyboard 34, a communications device 35, and an intranet connection 36 for connecting to the intranet 27. It is preferable that an intranet server-hosting computer 30 have an Intel® Pentium® processor (or equivalent). However, an •intranet server-hosting computer 30 may be implemented u-sing other processors and via other computing devices, including, but not limited to, mainframe computing systems and mini-computers. Intranet server software handles requests from clients for documents, whether they are text, graphic, multimedia, or virtual. The intranet server software typically runs under the operating system of the intranet server.
Referring now to Fig. 4, accessing content hosted by an intranet server is schematically illustrated. During a typical client/server
communication, a client-hosting computer ^20, via a browser, -.akes a TCP/I? request for a web page 40 from the intranet server-hosting computer 30 and displays the web page on the display device 22 of the client-hosting computer 20. If the displayed web page 40 contains a hypertext link 32, the user can activate that link, and the browser will retrieve the linked web page 44 from its intranet server-hosting computer 46, or from other servers to which access is permitted.
Referring now to Figs. 5A-5D, operations for carrying out various aspects of the present invention are illustrated. As illustrated in Fig. 5A, content is assigned to users of a computer network, such as an intranet (Block 100). Then, content pages are generated and delivered to users of the computer network in response to requests from users (Block 200). Content is also delivered to users prior to receiving requests for content from users (Block 300).
Assigning Content to Users of an Intranet
Referring now to Fig. 5B, operations for assigning content to users of a computer network (i.e., an intranet) (Block 100), according to the present invention, are illustrated. Initially, an intranet administrator defines the users of an intranet (Block 102) and also defines one or more user groups (Block • 104) . Next, the defined users are assigned to the defined user groups such that each of the defined user groups eventually has at least one of the defined users assigned thereto (Block 106) .
ig. 6 illustrates four defined-user objects [i.e., data structures) "1, U"2, U3, U4 which represent

respective users cf

an intranet. Fig. 6 also

illustrates three defined user group objects UG1, UG2, UG3 which representirespective defined user groups. Arrows 50 indicate the assigned relationships between users and user grcups (i.e., to which user groups each user has been assigned).
In. the illustrated embodiment, the user objects U1-U4 each contain identification and authentication information about a respective user. In particular, as illustrated in Fig. 6, each user object U1-U4 may include a User ID 52, a user password 53-, a user first name 54, and a user last name 55. Additional fields that describe a user may be included within a user object, as well. It is understood that user objects, according t'o the present invention, may include various types cf information, and are not limited to the illustrated types of information. For example, a user cbject -.ay include a certificate read from a smartcard, a voiceprint, and the like. Preferably, each user cbject U1-U4 contains pointers to user groups UG1-UG3 to which the respective user is assigned. The word "pointer" can refer to any way of creating a relationship between objects, including database relations, DN pointers, data assertions, .specialized Require/Allow/Forbid pointers in LDAP, and memory pointers in cached data. The direction of the pointers is irrelevant to the functioning of the system. Fcr exar.ple, user groups can point to content
groups, or content groups to user groups, or both based on several considerations, such as performance improvements, intuitive.relationships in the schema, ease of updates, and ease of searches. The invention can work: either way, but the preferred embodiment shows pointers going both directions. Also, to facilitate fast lookups, the user objects U1-U4 are preferably stored in a hash table keyed on a particular field, such as User ID 52. Objects, pointers, and hash tables are well understood by those skilled in this art and need not be described further herein. " .
The illustrated user group objects UG1-UG3 each contain the name of. the user group 56, and pointers 58 to all user objects representing respective users in the user group. As would be understood by those skilled in this art, additional data, such as text describing each user group, may be included in each respective user group object UG1-UG3. Preferably, each user group object UG1-UG3 .also includes pointers .to content group objects CG1-CG3, as described below. ' ' Referring back to Fig. 5B, an intranet administrator defines units of content available to users of a computer network (Block 108) and defines one or more content groups (Block 110). Next, the defined units of content are assigned to the defined content groups such that each of the defined content groups eventually has at least one of the defined units of content assigned thereto (Block 112) .
Fig. 7 illustrates four defined content objects Cl, C2 , C3 , C4, which represent respective
units of content. Fig. 7 also illustrates three defined content group objects CGI, CG2, CG3 which represent
respective defined content groupsH Arrows 70 indicate
1 the relationships between content objects and content
groups (i.e., to which content groups a unit of content is assigned). In the illustrated embodiment, the content objects C1-C4 each include a name 60, URL 61, and description 62 for a respective unit of content. Additional fields that describe a respective unit of content may be included within a content object, as well. Preferably, each content object C1-C4 contains pointers to content groups CG1-CG3 to which the respective unit of content is assigned.
The illustrated content group objects CG1-CG3 include the name 72 of the content group, and pointers 74 to all content objects representing respective units of content assigned to a respective content group. As would be understood by those skilled in this art, additional data, such as text describing each group, or •rules for tailoring the content for specific devices, may be included in each respective content group object CG1-CG3.
Referring back to Fig. 5B, an intranet administrator associates the defined content groups with the defined user groups such that each of the defined user groups has at least one of the defined .content groups associated therewith (Block 114). Fig. 8 shows the relationship of content groups and user groups. Arrows 80 indicate the relationships between content group objects CG1-CG3 and user group objects
UG1-UG3 (i.e., to which user groups a content group is assigned) . When a conter.c group is assigned to a user group, a content group object (CG1-CG3.) of the respective center.- group includes a pointer 82 to a user group object (UG1-UG3) of a respective user group. Similarly, a user group object includes pointers 83 to each content group object of respective content groups associated therewith.
It is understood that the relationships (e.g., relationships indicated by arrows 80 in Fig. 8) between content group objects and user group dbjects, according to the presenc invention, may be varied. For example, a relationship may be defined by the types of permissions that users within a user group have. As would be understood by those skilled in this art, such permissions may include, but are not limited to, "requires", "allows", and "forbids."
It should also be noted that users can create their own "personal" content groups and user groups .that other users do not have access to. Accordingly, 'users can "subscribe" themselves to certain user groups in order to obtain access to various content. This "personal subscribing" may be in addition to the user groups to which a user is assigned by an administrator.
In a preferred embodiment, information about users is entered into user objects by an intranet or systems administrator. Alternatively, user information can be extracted automatically from an existing database, as would be known to those skilled in this art. Similarly, information about content may be entered into content objects by an intranet or systems
administrator, or by users themselves. Alternatively,
*v
content information car. be extracted automatically from

a web crawling (searching) pr
4
to those skilled in this art. Preferably, informa

jgram, as would be known
:ion relating to users,

user groups, content, and content groups is stored in a distributed directory such as:one implementing the standard LDAP (lightweight distributed access protocol) specification. LDAP directories are well-known and need not be described further herein. Because LDAP directories are distributed, information relating to users, user groups, content, and content groups can be accessed efficiently from anywhere on a computer network in which the present invention is implemented.
Generating Content Page for User Once users, user groups, content, and content groups have been assigned, a user can log-in to an intranet implementing -he present invention and retrieve a content page containing content specifically 'generated for the user. Content page generation may begin when a user enters a particular URL into a browser to initiate log-in procedures. For example, employees of IBM's Austin, Texas laboratory may enter the URL http://loain.austin. ibm.com to log-in to an intranet server, while employees of IBM's Almaden, California laboratory may enter the URL http://loain. almadsn. ibm.com to log-in to another intranet server. Preferably, by the standard operation of domain name server address resolution protocols, if a user simply types htto: //loom from Almaden, the address will be resolved to
login.almaceri.ibm.com. If the name of a server implementing the present invention is standard (e.g., "login"), by typing the abbreviated version (i.e., http; //login) . a user preferably will log-in to the closest server configured to implement the present invention.
Referring now to Fig. 5C, operations for generating a custom content page for an intranet user (Block 200) are schematically illustrated. When a user logs-in to a server implementing the present invention, the server may respond with a challenge for a user ID and password. When the user responds, the server looks up the supplied user ID in a user object and identifies
the user (Block 202). In addition, the server may
/
authenticate the user by checking any submitted password, certificate, or other identifying token with information contained within a user object. Log-in procedures are well known in the art and need not be described further herein.
Once a user has been identified and authenticated, user groups to which the user is .assigned are identified (Block 204). The user object, for example Ul, for the identified user is retrieved from a hash table using data provided by the user, such as User ID. As described above, the user object contains pointers to user group objects for each respective user group of which this user is a member. In the present example, Ul would include pointers to UG1 and UG2. Each of these pointers is followed, yielding the user group objects for each user group of which this user is a member. Thus, in the present
example, UG1 and UG2 would be identified.
In response zo identifying user groups to which the user ;'.s assigned, content groups associated with the identified user groups are then identified (Block 205) . Each user group object for a respective identified user group contains one or more pointers to content group objects which represent respective content groups associated therewith, as described above. By following these pointers, a list of content groups associated with this user can be obtained. Thus, in the present example, content group object's. CGI and CG2 would be included in the list of content groups.
Units of content ,assigned to the user are then determined (Block 208). Each content group object for a respective content group contains a list of pointers to content objects representing units of content assigned to the user (via content groups and user groups), as described above. By following these pointers, a list of units of content assigned to the user can be produced. This list of assigned units of .content is then used to create a customized content page (Block 210) to be delivered to the user (Block 212). Thus, in -he present example, content objects Cl-C3 would be identified.
A user's customized content page is preferably a hypertext document containing URLs to assigned units of content. A content page may also •display the descriptions of each unit of content, alone with the associated URLs. According to another embodiment of the present invention, actual units of
content may be embedded within a user's content page. Additionally, links to applications that can be executed within a separate browser window may also be provided within a content page.
Preferably, the units of content on a user's content page are arranged according to a content page creation profile assigned to the user. A content page creation profile may designate a "mandatory display" area of a content page that always displays certain assigned units of content. In addition, a content page creation profile may designate one or more "user-modifiable" areas of a content page that allow a user to modify what units of content are displayed within a content page. Accordingly, once a user's content page is created, the user may add or delete units of content displayed within these user-modifiable areas. However, the user will not be able to modify the units of content displayed within mandatory areas.
Content page creation profiles according to the present invention may also be utilized to allow for the different roles of a user. Accordingly, a user may want to create subsets of content corresponding to the different roles the user may have within an enterprise. For example, a software product release manager might want a content page creation profile that corresponds to information about a particular software product. In addition, the same software product release manager .might want a different content page creation profile that corresponds to his/her role as a manager, wherein general information for managers is provided in a content page generated therewith.
In addition, a user may access an intranet via devices having differing capabilities such as, but hot limited to, desktop computers, handheld personal digital assistants (PDAs), smart-phones, or sub-notebooks. According to the present invention, separate content page creation profiles may be utilized for each type of device used by a user to connect to an intranet. In addition, separate content groups can be utilized for different devices. These content groups can include appropriate rules for transforming content into a format best suited -for a particular device. Storing rules with a content group associated with a device allows the transformation to be done in advance of a request from a specific device. During the various user identification and authentication steps (Block 202), the type of device being used by a user can be identified and the content page creation profile associated with the device can be utilized to generate the content page for the user.
Delivering Content to a User Prior to Receiving Request From User
Referring now to Fig. 5D, operations for delivering content to a user prior to receiving a request from the user for the content are schematically illustrated. Operations may include: determining whether units of content assigned to a content group have changed (Block 302); prefetching content associated with a content group (Block 304); using content group to user group pointers and user group to
user pointers to find all users interested in the content group (Block 306); determining whether any interested users require transformed content (Block 308); transforming prefetched units of content from one format to another (Block 310); and exporting prefetched units of content into content packages (Block 312.)
For each user interested in a content group, the timing of delivery to the client device depends on whether a client-pull or server-push mechanism is used to convey the information. With a client-pull mechanism, servers hold information to deliver to the client when the client requests an update. The normal browser request for pages is an example of a client-pull mechanism. Another example would be waiting for the client to log on, and then downloading all of the content packages associated with the user's page. PointCast® (PointCast, Inc., Sunnyvale, CA) is another example of a client-pull mechanism. With a server-push mechanism, the server determines the information that belongs on the client and downloads it without being asked, for example, as soon as the client and server become connected. Microsoft's Channel Definition Facility and Marimba's Castanet (Marimba, Inc., Mountain View, CA) are both examples of server-push techniques. Both client-pull and server-push techniques are well-known in the art and need not be described further herein. However, the invention may work with •either method. A particular implementation of the server agent may support one or both techniques. If both, it must have the ability to decide which technique to use for a given user (Block 314).
According to cr.e embodiment of the present invention, an agent is configured to prefetch units of content assigned to a content grdup (Block 304), to'. export the prefetched units of content into a content package (Block 312), and to transmit the content package to a user device (Block 316). Preferably, a server-side content ager.c 90 (Fig. 9) is programmed to prefetch all units of content associated with each content group (Block 304), including content accessible from links inside each unit of content. The server-side content agent 90 then exports the retrieved units of content into packages (Block 312), such as Channel Definition Format (CDF) files or zip files. Compression of content packages may be utilized. Compressed packages are well known by those skilled in this art and need not be described further herein. It is to be understood that compression of prefetched units of content is not required but may be implemented to help reduce network traffic.
The present invention can reduce the number 'of independent fetches from intranet servers for information that administrators identify as widely useful to their company members, replacing them with local transmissions of possibly compressed collections of information. Thus, instead of every user individually fetching every HTML page, applet, or image file directly from the various hosting servers, a server-side agent performs fetches once for all users associated with a particular content group. The information is then transmitted to the specific users
via possibly compressed files from a nearby server, in place of numerous separate HTTP requests to geographically distributed servers.
Preferably, a client-side agent 92 (Fig. 9) is configured to retrieve information about the content groups associated with a specific user. The client-side agent 92 uses the retrieved information to control retrieval of content packages needed by a particular user. An examples of a mechanism for controlling the retrieval of content packages includes the Microsoft channel protocol, which delivers CDF files from a server-side content agent to a client-side agent. Alternatively, an IBM eNetwork Web Express package file can be downloaded from a server-side content agent on a side-band socket and imported into an IBM eNetwork Web Express client cache.
Preferably, before retrieving information, a client-side agent 92 determines whether a user machine already has the content packages associated with all content groups for users of the machine. Since the cojitent groups associated with a particular user can change over time, an agent can be programmed to check periodically, or every time a user logs-in to an intranet server implementing the present invention, or during low usage times. Subsequent user access of content can occur with minimal network traffic since most of the content has been pre-fetched and loaded on •the user's computer.
According to a preferred embodiment of the present invention, a server-side agent 90 is configured to determine whether units of content assigned Co a
content group have changed (Block 302). If such changes are detected, the server-sidd agent is also configured to automatically update a respective compressed package to include the changes. Preferably, a determination is made whether a user device connected to a computer network implementing the present invention contains a current version of a compressed content package. The mechanism for knowing whether the client already has the package is to reduce network traffic and need not be incorporated with the present invention. If no such mechanism exists, the' server assumes that; the client does not have the package and thus will always download it. If a user device does not contain the latest version of a compressed content package, the compressed- content package is transmitted to the user device.
The present invention can also perform various content transformations from one format to another to tailor retrieved unit% of content for different user devices (Block 308) . For example, some user devices may only have gray scale image display capabilities. Accordingly, transporting color images to such a device would be a waste of network resources. By transcqding a color image into a gray scale image, the amount of data that needs to be transmitted to a user device, and the processing that a user device may have to perform to display the image, can be reduced significantly. Performing such content transformations during off-peak hours can reduce the time that users have to wait to receive the appropriate version for their devices and can reduce demands on intranet
servers during peak hours. In addition, content transformation can facilitate efficient use of server processing power by performing processor and numerically intensive data transformations with machine cycles that often go unused.
For a client machine that hosts multiple users, such as a work station that implements a network computer model, a client-side agent can fetch the union of content pages needed by various users of a computer. Content pages that are needed by multiple users can be retrieved once and reused for different users. A client-side agent can also manage the set of content pages on a computer based on factors such as when a content page was last used, or on frequency of use of a content page. Accordingly, if a user computer runs out of disk space for storing content pages, the content pages that have not been used recently, or with a certain level of frequency, can be deleted.
It will be understood that each block of the flowchart illustrations of Figs. 5A-5D and combinations of blocks in the flowchart illustrations of Figs. 5A-5D, can be implemented by computer program ' instructions. These program instructions may be
provided to a processor to produce a machine, such that the instructions which execute on the processor create means for implementing the functions specified in the flowchart block or blocks. The computer program •instructions may be executed by a processor to cause a series of operational steps to be performed by the processor to produce a computer implemented process such that the instructions which execute on the
processor provide steps for implementing the functions specified in the flowchart block or blocks.
Accordingly, blocks of the flowchart illustrations support combinations of means for performing the specified functions, combinations of steps for performing the specified functions and program instruction means fcbr performing the specified functions. It will also be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by special purpose hardware-based .systems which perform the specified functions or steps, or combinations of special purpose hardware and computer instructions.
The present invention is preferably written in an object oriented programming language such as Java® (Sun Microsystems, Mountain View, California). However, other programming languages including, but not limited to, C, C-r+, and Smalltalk may be utilized. The software for carrying out the various operations and functions of the present invention resides within one or more intranet servers. User devices for accessing an intranet server implementing the present invention only require a web browser. Foriaccessing customized content, according to the present invention, no client-side software, other than a standard web browser is required. For data compression aspects of the present .invention, client software should have the ability to uncompress content packages and the ability to cache content packages in order to utilize prefetching aspects of the present invention. Accordingly, some
aspects of the present invention can be expanded and
»*
enhanced with the inclusion of client side software routines. •
Example
Figs. 10-30, described below, represent exemplary users interfaces for assigning content to users of a computer network, according to an embodiment of the present invention.
Fig. 10 represents an initial login screen
*
all users are presented with. The login screen can be obtained, for example, via the IBM intranet by going to login.raleigh.ibm.com.
Fig. 11 represents a sample content page that is presented to the user "amo" who logged in via Fig. 10. A user profile "Office" controls the display and arrangement of content. Note that the user "amo" clicked on the Stock Ticker button, which brought the stock ticker applet up in a separate window. Content is accessible to the user "amo" via URL "links" 100 (i.e., ."Duke CS Home") listed on the content page, via applications launched from a button 102 (i.e., the Stock Ticker applet) on the content page, and via applications embedded 104 within the content page (like the Java calculator and Yahoo! search).
Fig. 12 illustrates that a user can change which profile is active, which in turn determines how the content page is displayed. Profiles can be configured for different job functions, locations, or machine types. The user has highlighted the profile
"palmtop" in order to change the active profile to one configured for accessing content via a palmtop device.
Fig. 13 illustrates the content page for the user "amo" after the Palmtop profile is made active via the user interface of Fig. 12. Note that this content page is substantially different from the content page displayed in Fig. 11. The image map has been removed, there are no Java applets present, the colors are different, and the layout is different. The content page illustrated in Fig. 13 also contains different content than the content page of Fig. 11 which was produced via the "Office" profile. For example, the Yahoo! search component is not present in the content page of Fig. 13. Additionally, all content in Fig. 13 is displayed as a URL link. The content page of Fig. 13 has a simple layout in order to make the content page load very quickly and with little data transferred.
Fig. 14 illustrates how the settings are configured for the Palmtop profile. A user obtains the user interface of Fig. 14 by clicking on "Edit Home •Page Settings" on the user's content page (106 Fig. 11) -
Fig. 15 illustrates a content page for another user "dlk" who has logged on. Note that the content and settings of this page are different than that for the user "amo". For example, "dlk" is not in the Duke students user group, so the Duke CS Home Page link does not show up on this content page.
Fig. 16 illustrates a default profile for users. User profiles inherit the Default settings
unless a user changes them via "Edit Settings" and "Edit Content" user interfaces. In Fig. 16, the user dlk is changing the default template to "Home Template 2." Fig. 16 also contains a preview function that lets the user see changes made without saving them.
Fig. 17 illustrates an "Edit Home Page Content" user interface for user "dlk." This user interface is used to control what content is displayed on "dlk's" content page, and how content is displayed. A user cannot see content on this user interface unless the user is either allowed"or required to see-the content. The options are Linked, Launched (as a button), Embedded, and Not Shown (an option only available if the user is allowed, but not required, to see a component) . The user has clicked on the "More Info" button for the unit of content "MetricConvert" to see a description of this unit of content.
Fig. 18 illustrates what the content page for user "dlk" looks like after the changes made in Fig. 13 have taken effect.
Fig. 19 illustrates a content page for an administrator of an intranet incorporating the present invention. The User Database 108 lets the administrator add and edit users. The other illustrated options include Component Database 110, Component Groups 112, Home Pages 114, Group Permissions 116, and User Groups 118. Each of these functions will be described below.
Fig. 20 illustrates the component database administration area (accessed via option 110 in Fig. 19). There are different component types (i.e., units
of content) based on their HTML characteristics. For example, applets have a height, width, codebase, and the like, so fields are provided for that information. Links, on the other hand, |only have a name, description, and URL.
Fig. 21 illustrates what an administrator would see after clicking on "Yahoo Search" and then "Edit HTML" in Fig. 20.
Fig. 22 illustrates the user group
administration area (accessed via option 118 in Fig. 19) . Two views of group membership are provided. From the group view, a list of the group's members is provided. From the user view, a list of what groups the user belongs to is provided. From the group view an administrator could also designate a group as a subgroup of another group.
Fig. 23 illustrates what an administrator would see after clicking on "dlk" and then "Edit User" in Fig. 22.
Fig. 24 illustrates the component group •administration area (accessed via option 112 in Fig. 19) . Two views of group membership are provided.
Fig. 25 illustrates what an administrator would see after clicking on "IBM Components" and "Edit Component Group" in Fig. 24.
Fig. 26 illustrates the group permissions administration area (accessed via option 116 in Fig. 19) . This user interface is used by an administrator to associate user groups with component groups (i.e., content groups). There are two available views of the
association.
Fig. 27 illustrates what an'administrator would see after selecting "IBM Programmers" and 'Edit User Group" via Fig. 25. There are four permission types (i.e., disallow, allow, require, forbid) that an administrator can assign to user groups. The final permissions a user has to a component (i.e., unit of content) are determined by combining all of the permissions assigned to the component from all of its user group-component croup associations, and using the highest-priority permissio'n type.
The rules for combining the permissions are as follows: 4) Disallow: This is the default permission type. It has the lowest priority. If the final component permission is "Disallow," the user will not be allowed to display the component (unit of content) on their content page. 3) Allow: This is the next higher-priority permission type. If the final component permission is "Allow," the user will be allowed to display the component (unit of content) on their content page, or they can choose not to display it. 2) Require: This is the next higher-priority permission type. If the final component permission is "Require," the user must display the component (unit of content) on their content page. 1) Forbid: This is the highest priority permission type. If the final component permission is "Forbid," the user will not be •allowed to display the component (unit of content) on their content page.
For example, if the component Cunit of content) "Duke CS Home Page" is in the "Duke" component
group, which is Required by the "Duke Students" user group but Forbidden by the "UNC Students" user group, and a user is a member of both user groups, Required+Forbidden=Forbidden. If the "Duke CS Home Page" is also in the "Computer Science" component group, which is Disallowed by the "IBM Traveller" user group, and a user is a member of "Duke Students" and "IBM Traveller" but no~ "UNC Students", then Required+Disallowed=Required.
Fig. 28 illustrates a user interface from which an administrator can'edit the content pages and profiles of other users.
Fig. 29 illustrates a user interface for an administrator for editing the content page and profile of the user "amo." The displayed user interface is essentially the same as what "amo" would see. A different image map is displayed because the system has detected that the user is an administrator, and the screen colors may be different because "admin" is a different user than •"amo" with his/her own profiles.
Fig. 30 illustrates how the "Edit Home Page" page is created. The present invention uses servlets and a template parser to combine data from the LDAP directory (such as the Required applets) and the HTML request (i.e., the user being edited and the user doing the editing) with a file like this to create the HTML a user sees in his/her browser.
The foregoing is illustrative of the present invention and is not to be construed as limiting thereof. Although a few exemplary embodiments of this invention have been described, those skilled in the art
will readily appreciate that many modifications are possible in the exemplary embodiments without materially departing from the novel teachings and advantages of this invention. Accordingly, all such modifications are intended to be included within the scope of this invention as defined in the claims. Therefore, it is to be understood that the foregoing is illustrative of the present invention and is not to be construed as limited to the specific embodiments disclosed, and that modifications to the disclosed embodiments, as v/ell as other embodiments, are intended to be included within the scope of the appended claims. The invention is defined by the following claims, with equivalents of the claims to be included therein.





THAT WHICH IS CLAIMED IS:
1. A method of assigning content to users
of a computer network, the method comprising the steps
of:
defining users of the computer network;
defining a plurality of user groups;
assigning the defined users to the defined user groups;
defining units o-f content available, to users of the computer network;
defining a plurality of content groups;
assigning the defined units of content to the defined content groups; and
associating the defined content groups with the defined user groups so as to provide user group specific content.
2. A method according to Claim 1 wherein
"at least one of the defined user groups has at least
ohe of the defined users assigned thereto, wherein at least one of the defined content groups has at least one of the defined units of. content assigned thereto, and wherein each of the defined user groups has at least one of the defined content groups associated therewith.
3. A method according to Claim 1, wherein
the step of defining users of the computer network
comprises creating a respective user object for each
user, wherein each user object includes identification and authentication information for a respective user.
4. A method according to Claim 1, further
comprising the step of providing user group specific
content to a user in a user group.
5. A method according to Claim 1, wherein
the step of defining a plurality of user groups
comprises creating a respective user group object for
each user group, wherein each user group obj-ect
includes information about each respective user
assigned to a respective user group.
6 . A method according to Claim 3 wherein the step of assigning the defined users to the defined user groups comprises associating, with user group objects, a pointer to each user object for a user assigned to the respective user group.
" 7. A method according to Claim 1, wherein
the step of defining units of content available to users of the computer network comprises creating an object associated with each unit of content, wherein each content object includes at least one of a discrete collection of information and a link to a discrete collection of information.
3. A method according to Claim 1, wherein the step of defining units of content available to users of the computer network comprises creating an
object associated with each unit of content, wherein each content object includes at least one of a discrete application and a link to a discrete application.
9 . A method according to Claim 1 wherein the step of assigning the defined units of content to the defined content groups comprises associating, with each .content group object, a pointer to each content object for a respective unit of content assigned to a respective content group.
10. A method according to Claim 1 wherein
the step of associating the defined content groups with
the defined user groups comprises associating, with
each user group object, a pointer to each content group
object for a respective content group associated with a
respective user group object.
11. A method according to Claim 1 further
comprising the step of creating a content page creation
profile for at least one user, wherein the content page
creation profile is configured to control how units of
content are displayed to the user on a device connected
to the computer network.
12. A method of generating a content page
to be displayed to a user of a computer network, the
•method comprising the steps of:
identifying the user;
identifying user groups to which the user is assigned;
identifying content groups associated with the identified user groups;
determining units of content assigned to the user based on the identified content groups associated with the identified user groups; and
creating a content page to be displayed to the user, wherein the content page contains the identified units of cor.cent assigned to the user.
13. A method according to Claim 12 wherein
the step of creating a content page for a user,
comprises arranging the units of content assigned to
the user according to a content page creation profile
assigned to the user.
14. A method according to Claim 13 wherein
the content page creation profile contains an area
wherein the user can modify what units of content are
displayed.
15. A method according to Claim 12 further
comprising the step of delivering the created content
page to the user for display via a device in
communication with the computer network.
16. A method according to Claim 12 wherein
the step of identifying the user comprises comparing
.user provided information with information associated with a user object.
17. A method according to Claim 16 where.,ir.
the step of identifying user groups to which the user is assigned comprises identifying user group objects having pointers to the respective user object for the user associated therewith.
18. A method according to Claim 17 wherein
the step of identifying content groups associated with
the identified user groups comprises7 identifying
content group objects having pointers to user group
objects associated therewith.
19. A method according to Claim 18 wherein
the step of determining units of content assigned to
the user comprises identifying content objects via
pointers associated with the identified content group
objects.
20. A method of delivering content to a user
of a computer network, the method comprising the steps
of:
prefetching units of content assigned to a content group;
exporting the prefetched units of content into a content package; and
transmitting the content package to the user device.
21. A method according to Claim 20 wherein
the step of prefetching units of content assigned to a
content group comprises prefetching content accessible
from hypertext lir.ks embedded within each unit of content.
22. A r.ethod according to Claim 20 further comprising:
determining whether units of content assigned to a content group have changed;
prefctching changed units of content if one or more units of contenc assigned to a content group have changed;
exporting the prefetched changed units of content into a content package; and
transmitting the content package to the user device.
23 . A method according to Claim 22 wherein the step of exporting the prefetched changed units of content comprises exporting the prefetched changed units of content into a compressed content package.
24. A method according to Claim 20 further comprising the step of transforming prefetched units of content from a first format to a second format prior to exporting the prefetched units of content into a content package.
25 . A method of providing content to a user • _of a computer network, the method comprising the steps of:
assigning content to the user;
creating a content page creation profile for the user, wherein the content page creation profile is configured to control how content is displayed to the user; and
generating a content page for the user wherein content is arranged on the content page according to the content page creation profile.
26. A method according to Claim 25 further
comprising the step of delivering the content 'page to
the user prior to receiving a request from the user for
the content page.
27. A method according to Claim 25 wherein
the step of assigning content to the user comprises
assigning the user to at least one of a plurality of
user groups.
28. A method according to Claim 27 wherein
each of the plurality of user groups is associated with
at least one content group having defined units of
co'ntent assigned thereto.
29. A method according to Claim 25 wherein
the step of generating a content page for the user
comprises:
identifying the user;
identifying user groups to which the
identified user is assigned;
identifying content groups associated with the identified user groups;
determining units of content assigned to the user based on the identified content groups; and
creating a content page to be displayed to the user, wherein the content page contains the units of content assigned to the user.
30. A method according to Claim 29 wherein
the created content page contains an area wherein the
user can modify how units of content are displayed.
31. A method according to Claim 26 wherein
the step of delivering the content page to the user
prior to receiving a request from the user for the
content page comprises:
prefetching the units of content assigned to the user;
exporting the prefetched units of content into a compressed content package; and.
transmitting the compressed content package to the user device.
32. A method according to Claim 31 wherein
the step of prefetching the units of content assigned
to the user comprises prefetching content accessible
from hypertext links embedded within each unit of
content.
33. A method according to Claim 31 further
comprising:
determining whether units of content assigned to the user have changed;
prefetching the changed units of content if one or more units of content assigned to the user have changed;
exporting the prefetched changed units of content into a content package; and
transmitting the compressed content package to the user device.
34. A method according to Claim 31 further
comprising the step of transforming prefetched units of
content from a first format to a second format prior to
exporting the prefetched units of content into a
content package.
35. A system for assigning content to users
of a computer network, comprising:
means for defining users of the computer network;
means for defining a plurality of user groups;
means for assigning the defined users to the defined user groups;
means for defining units of content available to users of the computer network;
means for defining a plurality of content groups ,-
means for assigning the defined units of .content to the defined content groups; and
means for associating the defined content groups with the defined user groups so as to provide user group specific ccr.cent .
36. A system according to Claim 35 wherein
at least one of the defined user groups has at least
one of the defined users assigned thereto, wherein each
of the defined content groups has at least one of the
defined units of content assigned thereto, and wherein
at least one of the defined user groups has at least
one of the defined content groups associated therewith.
37. A system according to Claim 35, wherein
the means for defining users of the computer-network
comprises means for creating a respective user object
for each user, wherein each user object includes
identification and authentication information for a
respective user.
38. A system according to Claim 35, further
comprising means for providing user group specific
content to a user in a user group.
39. A system according to Claim 35, wherein
the means for defining a plurality of user groups
comprises means for creating a respective user group '
object for each user group, wherein each user group
object includes information about each respective user
assigned to a respective user group.
40. A system according to Claim 37 wherein
the means for assigning the defined users to the
defined user groups comprises means for associating,
with user group objects, a pointer to each _user object for a user assigned to che respective user group.
41. A system according to Claim 35, wherein
the means for defining units of content available to
users of che computer network comprises means for
creating an object associated with each unit of
content, wherein, each content object includes at least
one of a discrete collection of information and a link
to a discrete collection of information.
42. A system according to Claim 35, wherein
the means for defining units of content available to
users of the computer network comprises means for
creating an object associated with each unit of N
content, wherein each content object includes at least
one of a discrete application and a link to a discrete
application.
43. A system according to Claim 35 wherein
the means for assigning the defined units of content to
the defined content groups comprises means for
associating, with each content group object, a pointer
to each content object for a respective unit of content
assigned to a respective content group.
44. A system according to Claim 35 wherein
the means for associating the defined content groups
with the defined user groups comprises means for
associating, with each user group object, a pointer to
each content group object for a respective content
s
group associated with a respective user group object.
45. A system according to Claim 35 further
comprising means for creating a content page creation
profile for at least one user, wherein the content page
creation profile is configured to control how units of
content are displayed to the user on a device connected
to the computer network.
46. A system of• generating a content page
to be displayed to a user of a computer network,
comprising:
means for identifying the user; • means for identifying user groups to which the user is assigned;
means for identifying content groups associated with the identified user groups;
means for determining units of content assigned to the user based on the identified content groups associated with the identified user groups; and
means for creating a content page to be displayed to the user, wherein the content page contains the identified units of content assigned to
the user.
47. A system according to Claim 46 wherein
the means for creating a content page for a user
comprises means for arranging the units of content
assigned to the user according to a content page
creation profile assigned to the user.
48. A system according to Claim 47 wherein
the content page creation profile contains an area
wherein the user can modify what units of content are
displayed.
49. A system according to Claim 46 further
comprising means for delivering the created content
page to the user for display via a device in
communication with the computer network.
50. A system according to Claim 46 wherein
the means for identifying the user comprises means for
comparing user provided information with information
associated with a user object. ;
51. A system according to Claim 50 wherein
the means for identifying user groups to which the user
is assigned comprises means for identifying user group
objects having pointers to the respective user object
for the user associated therewith.
52. A system according to Claim 51 wherein
the means for identifying content groups associated
with the identified user groups comprises means for
identifying content group objects having pointers to
user group objects associated therewith.
*
53. A system according to Claim 52 wherein
the means for determining units of content assigned tc
the user comprises means for identifying content

objects via pointers associated with the identified content group objects.
54. A system of delivering content to a user
of a computer network comprising:
means for prefetching units of content assigned to a content croup;
means for exporting the prefetched units of content into a content package; and
means for transmitting the content package to
the user device. • • *
55. A system according to Claim 54 wherein
the means for prefetching units of content assigned to
a content group comprises means for prefetching content
accessible from hypertext links embedded within each
unit of content.
56. A systerr. according to Claim 54 further
comprising:
means for determining whether units of content assigned to a content group have changed;
means for prefetching changed units of content if one or more units of content assigned to a content group have changed;
means for exporting the prefetched changed units of content into a content package; and
means for transmitting the content package to the user device.
57. A system according to Claim 56 wherein
the means for means for exporting the prefetched
changed units of content comprises means for exporting
the prefetched changed units of content into a
compressed content package.
58. A system according to Claim 54 further
comprising means for transforming prefetched units of
content from a first format to a second format prior to
exporting the prefetched units of content into a
content package.
59. A system of providing content to a user
of a computer network, comprisingi
means for assigning content to the user;.
means for creating a content page creation profile for the user, wherein the content page creation profile is configured to control how content is displayed to the user; and
means for generating a content page for the "user wherein content is arranged on the content page according to the content page creation profile.
60. A system according to Claim 59 further
comprising means for delivering the content page to the
user prior to receiving a request from the user for the
content page.
61. A system according to Claim 59 wherein
the means for assigning content to the user ^comprises means for assigning the user to at least one of a plurality of user groups.
62. A system according to Claim 61 wherein
each of the plurality of user groups is associated with
at least one content group having defined units of
>
content assigned thereto.
63. A system according to Claim 59 wherein
the means for generating a-content page for the user
comprises:
means for identifying the user;
means for identifying user groups to which the identified user is assigned;
means for identifying content groups associated with the identified user groups;
means for determining units of content assigned to 'the user based on the identified content groups; and
means for creating a content page to be displayed to the user, wherein the content page contains the units of content assigned to the user.
64. A system according to Claim 63 wherein
the created content page contains an area wherein the
user can modify how units of content are displayed.
65. A system according to Claim 60 wherein
the means for delivering the content page to the user
comorises:
r.eans for prefetching the units of content assigned to the user;
-.cans for exporting the prefetched units of content inzo a content package; and
means for transmitting the content package to the user device .
56. A system according to Claim 65 v/herein
the means for prefetching the units of content assigned
to the user comprises means for prefetching content
accessible from hypertext -links embedded within each
unit of content.
57. A system according to Claim 65 further
comprising:
means for determining whether units of content assigned to the user have changed;
means for prefetching the changed units of content if one or more units of content assigned to the user have changed;
means for exporting the prefetched changed units of content into a content package; and
means for transmitting the content package to the user device.


8. A system according to Claim 65 further comprising means for transforming prefetched units of .content from a first format to a second format prior to exporting che prefetched units of content into a compressed content package.
69 . A computer program product for assigning
content to users of a computer network, the computer
program product comprising a computer usable storage
medium having computer readable program code means
embodied in the medium, the computer readable program
code means comprising:
computer readable program code means for defining users of the computer network;
computer readable program code means for defining a plurality of user groups,-
computer readable program code means for assigning the defined users to the defined user groups;
computer readable program code means.for defining units of content available to users of the computer network;
computer readable program code means for defining a plurality of content groups;
computer readable program code means for assigning the defined units of content to the defined content groups; and
computer readable program code means for
associating the defined content groups with the defined user groups so as to provide user group specific content.
70 . A computer program product according to
Claim 69 wherein at least one of the defined user
.groups has at least one of the defined users assigned
thereto, wherein each of the defined content groups has at least one of the defined units of content assigned thereto, and wherein at least one of the defined user
groups has at least one of the defined content groups associated therewith.
71. A computer program product according to
Claim 69, wherein the computer readable program code
means for defining users of the computer network
comprises computer readable program code means for
creating a respective user object for each user,
wherein each user object includes identification and
authentication information for a respective user.
72. A computer program product according to
Claim 69, further comprising computer readable program
code means for providing user group specific content to
a user in a user group.
73. A computer program product according to
Claim 69, wherein the computer readable program code
means for defining a plurality of user groups comprises
computer readable program code means for creating a
respective user group object for each user group,
wherein each user group object includes information
about each respective user assigned to a respective
user group.
74. A computer program product according to
Claim 71 wherein the computer readable program code
means for assigning the defined users to the defined
user groups comprises computer readable program code
means for associating, with user group objects, a

pointer to each user object for a user assigned to the respective user group.
75. A computer program product according to
Claim 69, wherein the computer readable program code
means for defining units of content available to users
of the computer network comprises computer readable
program code means for creating an object associated
with each unit of content, wherein each content object
includes at least one of a discrete collection of
information and a link to a discrete collection of
information.
76. A computer program product according to
Claim 69, wherein the computer readable program code
means for defining units of content available to users
of the computer network comprises computer readable
program code means for creating an object associated
with each unit of content, wherein each content object
includes at least one of a discrete application and a
link to a discrete application.
77. A computer program product according to-
Claim 69 wherein the computer readable program code
means for assigning the defined units of content to the
defined content groups comprises computer readable
program code means for associating, with each content
group object, a pointer to each content object for a
respective unit of content assigned to a respective
content group.
78. A computer program product according to
Claim 69 wherein the computer readable program code
•means for associating the defined content groups with the defined user groups comprises computer readable program code means for associating, with each user group object, a pointer to each content group object for a respective content group associated with a respective user group object.
79. A computer program product according to
Claim 69 further comprising computer readable program
code means for creating a content page creation profile
for at least one user, wherein the content page
creation profile is configured to control how units of
-content are displayed to the user on a device connected
to the computer network.
80. A computer program product for
generating a content page to be displayed to a user of a computer network, the computer program product
-comprising a computer usable storage medium having
i
• computer readable program code means embodied in the medium, the computer readable program code means comprising:
computer readable program code means for identifying the user;
computer readable program code means for .identifying user groups to which the user is assigned;
computer readable program code means for identifying content groups associated with the identified user groups;
computer readable program code means for determining units of content assigned to the user based •on the identified content groups associated with the identified user groups; and
computer readable program code means for creating a content page to be displayed to the user, wherein the content page contains the identified units of content assigned to the user.
81. A computer program product according to
Claim 80 wherein the computer readable program code
means for creating a content page for a user comprises
computer readable program code means for arranging the
units of content assigned to the user according to a
content page creation profile assigned to the user,.
82. A computer program product according to
Claim 81 wherein the content page creation profile
contains an area wherein the user can modify what units
of content are displayed.
83. A computer program product according to
Claim 80 further comprising computer readable program
code means for delivering the created content page to
the user for display via a device in communication with
the computer network.
84 . A computer program product according to Claim 80 wherein the computer readable program code means for identifying the user comprises computer readable program code means for comparing user provided
means embodied in the medium, the computer -readable program code means co-prising:
computer readable program code means for
i prefetching units of content assigned to a content
group;
computer readable program code means for exporting the prefetcr.ed units of content into a content package; and
computer readable program code means for transmitting the content package to the user device.
89. A computer program product according to Claim 88 wherein the computer readable program code means for prefetching units of content assigned to a content group comprises computer readable program code means for prefetching content accessible from hypertext links embedded within each unit of content.
90.- A computer program product according to Claim 88 wherein the computer readable program code means for exporting the prefetched units of content into a content package comprises computer readable program code means for exporting the prefetched units of content into a content package.
91. A computer program product according to Claim 88 further comprising:
computer readable program code means for determining whether units of content assigned to a content group have changed;
computer readable program code means for prefetc.Mng changed units of content if one or more units c:! content assigned to a content group have changec ;
computer readable program code means for export ing the prefetched changed units of content into a con' ent package; and
computer readable program code means for transmitting the content package to the user device.
92. A computer program product according to
Clai •. 88 further comprising computer readable program
code rceans for transforming prefetched units of content
frci, a first format to a second format prior to
expor :ing the prefetched units of content into a c- nteat package.
93. A computer program product for providing
center t to a user of a computer network, the computer
program product comprising a computer usable storage
mediur having computer readable program code means
embodied in the medium, the computer readable program
*
code :»eans comprising:
computer readable program code means for assigning content to the user;
computer readable program code means for creating a content page creation profile for the user, wherein the content page creation profile is configured to cont -ol how content is displayed to the user; and
computer readable program code means for generating a content page for the user wherein content
computer readable program code means for generating a content page for the user wherein content 'is arranged on the content page according to the content page creation profile.
94. A computer program product according to
Claim 93 further comprising computer readable program
code means for delivering the content page to the user
prior to receiving a request from the user for the
content page.
95. A computer program product according to
Claim 93 wherein the computer readable program code
means for assigning content to the user comprises
computer readable program code means for assigning the
user to at least one of a plurality of user groups.
96. A computer program product according to
Claim 95 wherein each of the plurality of user groups
is associated with at least one content group having
"defined units of content assigned thereto.
97. A computer program product according to
Claim 93 wherein the computer readable program code
means for generating a content page for the user
comprises:
computer readable program code means for • identifying the user;
computer readable program code means for identifying user groups to which the identified user is assigned;
computer readable program code means for
»-
identifying content groups associated with the identified user groups;
computer readable program code means for determining units of content assigned to the user based on the identified content groups; and
computer readable program code means for creating a content page to be displayed to the user, wherein the content page contains the units of content assigned to the user.
98. A computer program product according to
Claim 97 wherein the created content page contains an
area wherein the user can modify how units of content
are displayed.
99. A computer program product according to
Claim 94 wherein the computer readable program code
means for delivering the content page to the user
comprises:
computer readable program code means for prefetching the units of content assigned to the user;
computer readable program code means for exporting the prefetched units of content into a compressed content package; and
computer readable program code means for transmitting the compressed content package to the user device.
100. A comcuter program product according ~o
Claim 99 wherein the computer readable program code means for prefetching the units of content assigned to the user comprises computer readable program code means

for prefetching content

accessible from hypertext links

embedded within each unit of content.
101. A computer program product according to
Claim 99 further comprising:
computer readable program code means for determining whether units of content assigned to the user have changed;
computer readable program code means for prefetching the changed units of content if one or more units of content assi-erned to the user have changed;
computer readable program code means for exporting the prefetched changed units of content into a content package; and
computer readable program code means for transmitting the content package to the user device if the user device does not contain the content package.
102. A computer program product according to
Claim 99 further comprising computer readable program
code means for transforming prefetched units of content
from a first format to a second format prior to
exporting the prefetched units of content into a
content package.
103. A method of assigning content to users of a computer network
substantially as herein described with reference to the
accompanying drawings.
104. A method of generating a content page to be displayed to a
user of a computer network substantially as herein described
with reference to the accompanying drawings.
105. A method of delivering content to a user of a computer
network substantially as herein described with reference to the
accompanying drawings.
106. A method of providing content to a user of a computer network
substantially as herein described with reference to the
accompanying drawings.
107. A system for assigning content to users of a computer network
substantially as herein described with reference to the
accompanying drawings.
108. A system of delivering content to a user of a computer network
substantially as herein described with reference to the
accompanying drawings.
109. A system of providing content to a user of a computer network
substantially as herein described with reference to the
accompanying drawings.
110. A computer program product for assigning content to users of a
computer network substantially as herein described with
reference to the accompanying drawings.
111. A computer program product for generating a content page to
be displayed to a user of a computer network substantially as
herein described with reference to the accompanying drawings.
112. A computer program product for delivering content to a user of
a computer network substantially as herein described with
reference to the accompanying drawings.
113. A computer program product for providing content to a user of
a computer network substantially as herein described with
reference to the accompanying drawings.

Documents:

in-pct-2001-00239-del-abstract.pdf

in-pct-2001-00239-del-claims.pdf

in-pct-2001-00239-del-correspondence-others.pdf

in-pct-2001-00239-del-correspondence-po.pdf

in-pct-2001-00239-del-drawings.pdf

in-pct-2001-00239-del-form-1.pdf

in-pct-2001-00239-del-form-13.pdf

in-pct-2001-00239-del-form-19.pdf

in-pct-2001-00239-del-form-2.pdf

in-pct-2001-00239-del-form-3.pdf

in-pct-2001-00239-del-form-5.pdf

in-pct-2001-00239-del-gpa.pdf

in-pct-2001-00239-del-pa.pdf

in-pct-2001-00239-del-pct-101.pdf

in-pct-2001-00239-del-pct-210.pdf

in-pct-2001-00239-del-pct-220.pdf

in-pct-2001-00239-del-pct-304.pdf

in-pct-2001-00239-del-pct-308.pdf

in-pct-2001-00239-del-pct-332.pdf

in-pct-2001-00239-del-pct-401.pdf

IN-PCT-2001-239-DEL-Assignment-(07-12-2011).pdf

IN-PCT-2001-239-DEL-Correspondence Others-(07-12-2011).pdf

IN-PCT-2001-239-DEL-Form-16-(07-12-2011).pdf

IN-PCT-2001-239-DEL-GPA-(07-12-2011).pdf


Patent Number 214960
Indian Patent Application Number IN/PCT/2001/00239/DEL
PG Journal Number 10/2008
Publication Date 07-Mar-2008
Grant Date 19-Feb-2008
Date of Filing 22-Mar-2001
Name of Patentee INTERNATIONAL BUSINESS MACHINES CORPORATION
Applicant Address ARMONK, NEW YORK 10504, USA
Inventors:
# Inventor's Name Inventor's Address
1 KAMINSKY DAVID LOUIS 103 CORBIN HILL CIRCLE, CHAPEL HILL, NORTH CAROLINA 27514, USA
2 O'MEARA ANN MARIE 16200 CLAIRE AVENUE, CLEVELAND, OHIO 44111-2902, U.S.A.
3 BABER STEPHEN C. 102 MANTLE COURT, RALEIGH, NORTH CAROLINA 27607, U.S.A
4 BLOUNT BRIAN 702 AIRPORT ROAD, AIRPORT ROAD, APT. C-7, CHAPEL HILL, NORTH CAROLINA 27514, U.S.A.
5 BRITTON KATHRYN HENINGER 613 CASWELL ROAD, CHAPEL HILL, NORTH CAROLINA 27514, U.S.A.
PCT International Classification Number G06F 17/30
PCT International Application Number PCT/US99/05389
PCT International Filing date 1999-03-12
PCT Conventions:
# PCT Application Number Date of Convention Priority Country
1 09/164,697 1998-10-01 U.S.A.