US20090094346A1 - Method and System for Retrieval and Usage of Remote Entry Points - Google Patents

Method and System for Retrieval and Usage of Remote Entry Points Download PDF

Info

Publication number
US20090094346A1
US20090094346A1 US12/335,399 US33539908A US2009094346A1 US 20090094346 A1 US20090094346 A1 US 20090094346A1 US 33539908 A US33539908 A US 33539908A US 2009094346 A1 US2009094346 A1 US 2009094346A1
Authority
US
United States
Prior art keywords
computer
secure
entry point
remote entry
client
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US12/335,399
Inventor
Patrice Gautier
Jeffrey L. Robbin
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Priority to US12/335,399 priority Critical patent/US20090094346A1/en
Publication of US20090094346A1 publication Critical patent/US20090094346A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/51Discovery or management thereof, e.g. service location protocol [SLP] or web services

Definitions

  • the present invention relates to client-server computer environments and, more specifically, to interactions between client applications (e.g., media management applications) and server computers.
  • client applications e.g., media management applications
  • Media players such as digital media players, are specialized portable computing devices that store and present (e.g., play, display) digital media (e.g., music, videos, or images). Often media players are small hand-held devices with limited media storage capacity and limited media management capability. As a result, media players typically associate with a host computer.
  • the host computer can utilize an application resident on the host computer to perform media management for the host computer and the media player, such management including purchasing of media items, downloading purchased media items, and transfer of the media items and their attributes between the host computer and the media player.
  • One such media management application is iTunesTM, produced by and available from Apple Inc. of Cupertino, Calif.
  • An example of a popular media player is an iPodTM which is also produced by and available from Apple Inc.
  • the invention pertains to improved techniques for communicating between a client application operating on a client computer and one or more server computers.
  • the improved techniques enable remote entry points on remote servers to be flexibly assigned and utilized at client applications without code changes at the client applications.
  • the invention can be implemented in numerous ways, including as a method, system, device, apparatus, graphical user interface, or computer readable medium. Several embodiments of the invention are discussed below.
  • a client application operating on a client computer can check if a client application operation requires a remote entry point. Upon determining that a remote entry point is required, the client computer can obtain a set of remote entry points for at least one remote server computer. The remote entry point associated with the client application operation can then be retrieved from the set of remote entry points and the client application operation is directed to a remote server in accordance with the retrieved remote entry point.
  • a server computer receives a request from a client computer for a set of remote entry points.
  • the server computer can retrieve an appropriate set of remote entry points and then transmits them to the client computer.
  • a computer-implemented method for communicating between a client application operating on a client computer and a plurality of remote server computers can, for example, include at least the acts of: determining if a client application operation requires a remote entry point; and determining whether the client application operation requires a secure entry point. If it is determined that the client application operation requires a remote entry point and it is determined that a secure entry point is not required, then: requesting a non-secure entry point file from a remote server computer; receiving the non-secure entry point file from the remote server computer; and storing the non-secure entry point file on the client computer.
  • the client application operation requires a remote entry point and it is determined that a secure entry point is required, then: requesting a secure entry point file from the remote server computer; receiving the secure entry point file from the remote server computer; and storing the secure entry point file on the client computer.
  • a computer implemented method can securely communicate between a client application operating on a client computer and a plurality of server computers.
  • the computer implemented method can, for example, include at least the acts of: determining if a client application operation requires a secure remote entry point; obtaining, at the client computer, a set of secure remote entry points for at least one remote server computer; retrieving a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and directing the client application operation to the remote server in accordance with the particular secure remote entry point.
  • a computer-implemented method for delivering a set of remote entry points from a server computer to a client computer can, for example, include at least the acts of: receiving, at the server computer, a request from a client computer for a set of secure remote entry points; retrieving, at the server computer, the set of secure remote entry points; and transmitting the set of secure remote entry points to the client computer.
  • a system for communicating between a client computer and a plurality of server computers can, for example, include at least: a client computer including at least a processor, volatile memory and a storage disk drive; and a plurality of server computers.
  • the client computer can communicate with the server computer via a data network.
  • the client computer can perform a client application and in doing so the processor can execute computer program code.
  • the computer program code can operate to at least: determine if a client application operation requires a secure remote entry point; obtain, at the client computer, a set of secure remote entry points for at least one remote server computer; retrieve a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and direct the client application operation to the remote server in accordance with the particular secure remote entry point.
  • a computer readable medium including at least executable computer program code stored thereon for communicating between a client application operating on a client computer and at least one server computer can, for example, include at least: computer code for receiving, at a server computer, a request from a client computer for at least one secure remote entry point; computer code for retrieving, at the server computer, the at least one secure remote entry point; and computer code for transmitting the at least one secure remote entry point to the requesting client computer.
  • FIG. 1 is a block diagram of a generic application window according to one embodiment of the invention.
  • FIG. 2 is a block diagram of a computer network according to one embodiment of the invention.
  • FIG. 3 is a flow diagram of a client remote entry point retrieval process according to one embodiment of the invention.
  • FIG. 4 is a flow diagram of a server-side remote entry point file retrieval process in accordance with one embodiment of the invention.
  • FIG. 5 is a flow diagram of a secure remote entry point retrieval process in accordance with one embodiment of the invention.
  • FIG. 6 is a flow diagram of a server-side secure remote entry point file retrieval process in accordance with one embodiment of the invention.
  • FIG. 7A shows a computer system according to one embodiment of the invention.
  • FIG. 7B is a system block diagram of a computer system used to execute the software of an embodiment of the invention.
  • the invention pertains to improved techniques for communicating between a client application operating on a client computer and one or more server computers.
  • the improved techniques enable remote entry points on remote servers to be flexibly assigned and utilized at client applications without code changes at the client applications.
  • FIG. 1 is a block diagram of a generic application window 100 according to one embodiment of the invention.
  • the generic application window 100 is produced by a client application operating on a client computer and contains one or more program controls 105 .
  • the program controls 105 are a means for the client application to obtain input from the user and/or to request information to be displayed for the user.
  • the program controls 105 can be user interface components, such as text boxes, menus and hyperlinks.
  • These program controls 105 are associated with operations of the client application.
  • the operations although associated with the client application, at least partially rely on interaction with another computer, such as a remote server.
  • the client computer couples to the other computer via the Internet or some other suitable network.
  • the generic application window 100 also contains one or more display areas 110 which may be used to display text and/or graphics.
  • the iTunesTM application can produce a graphical user interface that resembles the generic application window 100 containing several program controls 105 .
  • the iTunesTM application can be referred to as a media management application for various media items.
  • the media items can pertain to audio items (e.g., audio files or songs, such as for music or audiobooks), video items (e.g., video files or movies), or image items (e.g., photos).
  • the program controls 105 for the iTunesTM application might pertain to operations, such as, search, browse, login, buy, or might be a hyperlink to a remote server. In any case, once an operation is activated or initiated at the iTunesTM application, the iTunesTM application executes the associated operation, which can require access to remote server computers as described in reference to FIGS. 2-6 , discussed below.
  • FIG. 2 is a block diagram of a computer network 200 according to one embodiment of the invention.
  • the computer network 200 includes one or more servers 210 .
  • the computer network 200 would include a plurality of different clients 204 .
  • Each client 204 includes a client application 208 .
  • the client application 208 is an application program (e.g., software application) that operates on the client 204 , which is a computing device.
  • the client 204 is coupled to the server 202 through a data network 206 .
  • any of the clients 204 can request remote entry point file 212 from the server 210 ′ such that it is locally accessible to client application 208 .
  • the remote entry point file once retrieved from the server 210 ′, can be stored in volatile memory at the client 204 .
  • the client application 208 Once the client application 208 has access to remote entry point file 212 , it can then access any one of the one or more servers 210 as directed by the remote entry point file 212 .
  • the data network 206 includes at least a portion of the Internet.
  • the clients 204 can vary with application but generally are computing devices that have memory storage (e.g., both volatile and non-volatile). Often, the clients 204 are personal computers or other computing devices.
  • FIG. 3 is a flow diagram of a client-side remote entry point retrieval process 300 according to one embodiment of the invention.
  • the client-side remote entry point retrieval process 300 can be performed on a client computer, such as the client computer 250 shown in FIG. 7A .
  • the client-side remote entry point retrieval process 300 begins with a decision 303 that determines whether an operation being performed at the client computer uses a remote entry point.
  • the operation is typically one of many different operations that can be performed by a client application operating on the client computer.
  • the client application is a media management application.
  • the operation being performed can be initiated by a user control provided on a graphical user interface for the client application.
  • the user controls provided on the graphical user interface can be, for example, a text box, a radio button, or other user control.
  • a remote entry point can be, for example, a uniform resource locator (URL) or an Internet protocol (IP) address (with or without sub-domain or path).
  • URL uniform resource locator
  • IP Internet protocol
  • a decision 305 determines whether a remote entry point file having the remote entry point is stored on the client computer. If the decision 305 indicates that the remote entry point file is stored on the client computer, then the stored remote entry point file is accessed 307 in order to retrieve 309 the remote entry point associated with the operation. Once the remote entry point associated with the operation has been retrieved 309 , the client-side remote entry point retrieval process 300 directs 311 the operation to a remote server in accordance with the remote entry point and the remote entry point retrieval process 300 ends. As such, the operation being performed by the client application can communicate with the appropriate remote server (or server application thereon).
  • the client-side remote entry point retrieval process 300 makes a request 315 for the remote entry point file from a remote server computer.
  • a decision 317 determines whether the remote entry point file has been received.
  • the client-side remote entry point retrieval process 300 returns to repeat the decision 317 until the remote entry point file is received.
  • the remote entry point file is stored 319 on the client computer and the client-side remote entry point retrieval process 300 returns to decision 305 and subsequent blocks.
  • FIG. 4 is a flow diagram of a server-side remote entry point file retrieval process 400 in accordance with one embodiment of the invention.
  • the server-side remote entry point retrieval process 400 can be performed on a server computer, such as any of the servers shown in FIG. 2 .
  • the server-side remote entry point file retrieval process 400 begins with a decision 403 that determines whether a request for a remote entry point file has been received. If no request has been received, the server-side remote entry point file retrieval process 400 returns to repeat the decision 403 .
  • the server computer can await a request for a remote entry point file from a client computer.
  • decision 403 determines that a request has been received
  • the remote entry point file is retrieved 405 at or by the server computer. Thereafter, the remote entry point file is transmitted 407 to the requesting client computer. Following the operation 407 , the server-side remote entry point file process 400 ends.
  • a client application can perform non-secure or secure communication with remote servers.
  • the secure communications can use a secure protocol, such as https or secure sockets layer techniques for security.
  • the remote server can be referred to as a secure server when secure communications are used with client applications.
  • secure communications can be used for a user login because any communication of a user's private data (e.g., password) should be protected.
  • FIG. 5 is a flow diagram of a client-side secure/non-secure remote entry point retrieval process 500 in accordance with one embodiment of the invention.
  • the client-side secure/non-secure remote entry point retrieval process 500 can be performed on a client computer, such as the client computer 250 shown in FIG. 7A .
  • the client-side secure/non-secure remote entry point file retrieval process 500 begins with a decision 503 that determines whether an operation being performed at the client computer uses a remote entry point.
  • the operation is typically one of many different operations that can be performed by a client application operating on the client computer.
  • the client application is a media management application.
  • the operation being performed can be initiated by a user control provided on a graphical user interface for the client application.
  • the user controls provided on the graphical user interface can be, for example, a text box, a radio button, or other user control.
  • a remote entry point can be, for example, a uniform resource locator (URL) or an internet protocol (IP) address (with or without sub-domain or path).
  • URL uniform resource locator
  • IP internet protocol
  • a decision 505 determines whether the operation being performed uses a secure remote entry point or a non-secure entry point. If the operation uses a secure remote entry point, then a decision 507 determines whether the secure remote entry point file having the remote entry point is stored on the client computer. If the decision 507 determines that the secure remote entry point file is not stored on the client computer, then the client-side secure/non-secure remote entry point file retrieval process 500 makes a request 509 for a secure remote entry point file from a remote server computer. Thereafter, a decision 511 determines whether the secure remote entry point file has been received.
  • the client-side secure/non-secure remote entry point process 500 returns to repeat the decision 511 until the secure remote entry point file has been received.
  • the secure remote entry point file is stored 513 on the client computer and the client-side secure/non-secure remote entry point file retrieval process 500 proceeds to access 515 the stored remote entry point file, retrieve 517 the remote entry point associated with the operation, and then direct 519 the operation to a remote server in accordance with the remote entry point. Thereafter, the client-side secure/non-secure remote entry point file retrieval process 500 ends.
  • decision 507 determines that the secure remote entry point file is stored on the client computer
  • the secure/non-secure remote entry point retrieval process 500 continues directly to operation 515 and subsequent blocks.
  • a decision 521 determines whether the non-secure remote entry point file is stored on the client computer. If decision 521 determines that the secure remote entry point file is stored on the client computer, then client-side secure/non-secure remote entry point file retrieval process 500 continues on to operation 515 and subsequent blocks. Alternatively, if the decision 521 determines that the non-secure remote entry point file is not stored on the client computer, then the client-side secure/non-secure remote entry point file retrieval process 500 makes a request 523 for the non-secure remote entry point file from a remote server computer.
  • the remote server computer can be the same or different than the remote server computer used at operation 509 .
  • a decision 525 determines whether the non-secure remote entry point file has been received. If the non-secure remote entry point file has not yet been received, the client-side secure/non-secure remote entry point file retrieval process 500 returns to repeat the decision 525 until the non-secure remote entry point file has been received. Once the decision 525 determines that the non-secure remote entry point file has been received, then the non-secure remote entry point file is stored on the client computer and the client-side secure/non-secure remote entry point file retrieval process 500 continues to operation 515 and subsequent blocks.
  • FIG. 6 is a flow diagram of a server-side secure/non-secure remote entry point file retrieval process 600 in accordance with one embodiment of the invention.
  • the server-side secure/non-secure remote entry point retrieval process 600 can be performed on a server computer, such as any of the servers shown in FIG. 2 .
  • the server-side secure/non-secure remote entry point file retrieval process 600 begins with a decision 603 that determines whether a request for a remote entry point file has been received. If no request has been received, the server-side secure/non-secure remote entry point file retrieval process 600 returns to repeat the decision 603 .
  • the server computer can await a request for a remote entry point file from a client computer.
  • a decision 605 determines whether a secure or non-secure remote entry point file has been requested. If a secure remote entry point file has been requested, then the server-side secure/non-secure entry point retrieval process 600 retrieves 607 a secure remote entry point file.
  • a non-secure remote entry point file is retrieved 607 .
  • the retrieval 607 of the secure remote entry point file or the retrieval 611 of the non-secure remote entry point file can be performed by or at the server computer. Following the retrieval 607 and 611 , the retrieved remote entry point file is transmitted 609 to the requesting client computer. Following the operation 609 , the server-side secure/non-secure remote entry point file retrieval process 600 ends.
  • a client application invokes an operation
  • the operation may utilize a remote entry point to direct performance of some or all of the operation to a remote server.
  • the nature or type of operation using remote entry points can vary with client application.
  • a client application is a media management application.
  • iTunesTM produced by and available from Apple Inc. of Cupertino, Calif.
  • operations associated with a media management application can, for example, include search, browse, buy, login, customer service, etc.
  • a search operation via a client application is described below according to one embodiment of the invention. Referring back to FIG.
  • the program control 105 may be implemented as a text box, wherein a user enters text (i.e., a search string) into the text box and then initiates a search for files on a remote server that match the text.
  • a user enters text (i.e., a search string) into the text box and then initiates a search for files on a remote server that match the text.
  • the user enters a search string into the aforementioned text box and instructs the client application to perform the search by pressing the enter key or clicking on a search button, for example.
  • the client application attempts to carry out the search according to the user's instructions.
  • the search function is determined to require a remote entry point, which the client application must obtain before the search can proceed.
  • the client can obtain the needed remote entry point by, for example, one of the methods described in reference to FIGS. 3 or 5 in order to locate the remote server that it will use in order to perform the search.
  • An exemplary remote entry point, provided in a URL format is as follows.
  • FIG. 7A shows a computer system 725 that includes a display monitor 728 having a single or multi-screen displays 730 (or multiple displays), cabinet 732 , keyboard 734 , and mouse 736 .
  • Cabinet 732 houses a drive 738 , such as a CD-ROM or floppy drive, system memory and a hard drive (see FIG. 7A ) which may be utilized to store and retrieve software programs incorporating computer code that implements the present invention, data for use with the invention, and the like.
  • CD-ROM 740 is shown as an exemplary computer readable storage medium, other computer readable storage media including floppy disk, tape, flash memory, system memory, and hard drive may be utilized.
  • an operating system for the computer system 725 is provided in the system memory, the hard drive, the CD-ROM 740 or other computer readable storage medium and serves to incorporate the computer code that implements the invention.
  • FIG. 7B shows a system block diagram of a computer system 750 used to execute the software of an embodiment of the invention.
  • computer system 750 includes display monitor 728 and keyboard 734 , and mouse 736 .
  • Computer system 725 further includes subsystems such as a central processor 751 , system memory 753 , fixed storage 755 (e.g., hard drive), removable storage 757 (e.g., CD-ROM drive), display adapter 759 , sound card 761 , speakers 763 , and network interface 765 .
  • the operating system and client application are normally, but not necessarily, resident in the system memory 753 during its execution.
  • Other computer systems suitable for use with the invention may include additional subsystem or fewer subsystems.
  • another computer system could include more than one processor 751 (i.e., a multi-processor system) or one or more levels of a cache memory.
  • the system bus architecture of computer system 725 is represented by arrows 767 .
  • arrows 767 are illustrative of any interconnection scheme serving to link the subsystems.
  • a local bus could be utilized to connect the central processor to the system memory and display adapter.
  • Computer system 725 shown in FIG. 7B is but an example of a computer system suitable for use with the invention.
  • Other computer architectures having different configurations of subsystems may also be utilized.
  • the invention is preferably implemented by software, but can also be implemented in hardware or a combination of hardware and software.
  • the invention can also be embodied as computer readable code on a computer readable medium.
  • the computer readable medium is any data storage device that can store data which can thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, CD-ROMs, DVDs, magnetic tape, optical data storage devices, and carrier waves.
  • the computer readable medium can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • One advantage of the invention is that an application using a remote entry point file does not require remote entry points to be hard-coded, thus allowing for flexibility as to which remote server will be used for a particular operation at any given time.
  • Another advantage of the invention is that a remote entry point file may be generated dynamically upon request from a client computer, thereby better enabling network managers to balance server-load among several remote servers.
  • Still another advantage of the invention is the possibility of having entry point files tailored specifically according to geographical location of the client computer, thus using remote servers that are closer in proximity to the client computers.

Abstract

A method for communicating between a client application and one or more servers is disclosed. In one embodiment, it is first determined whether a particular client application operation is the type of operation that requires a remote entry point. If a remote entry point is needed, the client application obtains a remote entry point file from a remote server computer and retrieves the remote entry point required by the client application operation such that it can direct the operation to the proper remote server.

Description

    CROSS-REFERENCE TO OTHER APPLICATION
  • This application is a divisional application of U.S. patent application Ser. No. 10/833,387, filed Apr. 27, 2004, entitled “METHOD AND SYSTEM FOR RETRIEVAL AND USAGE OF REMOTE ENTRY POINTS”, which is herein incorporated by reference.
  • BACKGROUND OF THE INVENTION
  • 1. Field of the Invention
  • The present invention relates to client-server computer environments and, more specifically, to interactions between client applications (e.g., media management applications) and server computers.
  • 2. Description of the Related Art
  • Media players, such as digital media players, are specialized portable computing devices that store and present (e.g., play, display) digital media (e.g., music, videos, or images). Often media players are small hand-held devices with limited media storage capacity and limited media management capability. As a result, media players typically associate with a host computer. The host computer can utilize an application resident on the host computer to perform media management for the host computer and the media player, such management including purchasing of media items, downloading purchased media items, and transfer of the media items and their attributes between the host computer and the media player. One such media management application is iTunes™, produced by and available from Apple Inc. of Cupertino, Calif. An example of a popular media player is an iPod™ which is also produced by and available from Apple Inc.
  • In designing a media management application, decisions must be made regarding how to implement various features such as searching, browsing, previewing, purchasing, and delivering media items. Many of these features may be hard coded into the application or, alternately, they may be associated with a server application.
  • However, it can be difficult to predict in advance which specific servers are going to be used to run the various server applications. Hard coding of addresses to specific server computers directly into an application is not desirable, given that servers may go down, addresses changed or otherwise become inaccessible. In addition, hard coding of addresses to specific servers in an application is problematic because any changes in the addresses requires that the application be altered through a program update or reinstallation in order for the application to properly interact with servers whose addresses have changed.
  • Thus, there is a need for improved techniques to implement a client application, such as a media management application, whereby access to server application is able to be altered without code changes to the client applications.
  • SUMMARY OF THE INVENTION
  • The invention pertains to improved techniques for communicating between a client application operating on a client computer and one or more server computers. The improved techniques enable remote entry points on remote servers to be flexibly assigned and utilized at client applications without code changes at the client applications.
  • The invention can be implemented in numerous ways, including as a method, system, device, apparatus, graphical user interface, or computer readable medium. Several embodiments of the invention are discussed below.
  • According to one embodiment of the invention, a client application operating on a client computer can check if a client application operation requires a remote entry point. Upon determining that a remote entry point is required, the client computer can obtain a set of remote entry points for at least one remote server computer. The remote entry point associated with the client application operation can then be retrieved from the set of remote entry points and the client application operation is directed to a remote server in accordance with the retrieved remote entry point.
  • According to another embodiment of the invention, a server computer receives a request from a client computer for a set of remote entry points. The server computer can retrieve an appropriate set of remote entry points and then transmits them to the client computer.
  • According to another embodiment of the invention, a computer-implemented method for communicating between a client application operating on a client computer and a plurality of remote server computers can, for example, include at least the acts of: determining if a client application operation requires a remote entry point; and determining whether the client application operation requires a secure entry point. If it is determined that the client application operation requires a remote entry point and it is determined that a secure entry point is not required, then: requesting a non-secure entry point file from a remote server computer; receiving the non-secure entry point file from the remote server computer; and storing the non-secure entry point file on the client computer. Alternatively, if it is determined that the client application operation requires a remote entry point and it is determined that a secure entry point is required, then: requesting a secure entry point file from the remote server computer; receiving the secure entry point file from the remote server computer; and storing the secure entry point file on the client computer.
  • According to another embodiment of the invention, a computer implemented method can securely communicate between a client application operating on a client computer and a plurality of server computers. The computer implemented method can, for example, include at least the acts of: determining if a client application operation requires a secure remote entry point; obtaining, at the client computer, a set of secure remote entry points for at least one remote server computer; retrieving a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and directing the client application operation to the remote server in accordance with the particular secure remote entry point.
  • According to another embodiment of the invention, a computer-implemented method for delivering a set of remote entry points from a server computer to a client computer can, for example, include at least the acts of: receiving, at the server computer, a request from a client computer for a set of secure remote entry points; retrieving, at the server computer, the set of secure remote entry points; and transmitting the set of secure remote entry points to the client computer.
  • According to another embodiment of the invention, a system for communicating between a client computer and a plurality of server computers can, for example, include at least: a client computer including at least a processor, volatile memory and a storage disk drive; and a plurality of server computers. The client computer can communicate with the server computer via a data network. The client computer can perform a client application and in doing so the processor can execute computer program code. The computer program code can operate to at least: determine if a client application operation requires a secure remote entry point; obtain, at the client computer, a set of secure remote entry points for at least one remote server computer; retrieve a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and direct the client application operation to the remote server in accordance with the particular secure remote entry point.
  • According to still another embodiment of the invention, a computer readable medium including at least executable computer program code stored thereon for communicating between a client application operating on a client computer and at least one server computer can, for example, include at least: computer code for receiving, at a server computer, a request from a client computer for at least one secure remote entry point; computer code for retrieving, at the server computer, the at least one secure remote entry point; and computer code for transmitting the at least one secure remote entry point to the requesting client computer.
  • Other aspects and advantages of the invention will become apparent from the following detailed description taken in conjunction with the accompanying drawings which illustrate, by way of example, the principles of the invention.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, wherein like reference numerals designate like structural elements, and in which:
  • FIG. 1 is a block diagram of a generic application window according to one embodiment of the invention.
  • FIG. 2 is a block diagram of a computer network according to one embodiment of the invention.
  • FIG. 3 is a flow diagram of a client remote entry point retrieval process according to one embodiment of the invention.
  • FIG. 4 is a flow diagram of a server-side remote entry point file retrieval process in accordance with one embodiment of the invention.
  • FIG. 5 is a flow diagram of a secure remote entry point retrieval process in accordance with one embodiment of the invention.
  • FIG. 6 is a flow diagram of a server-side secure remote entry point file retrieval process in accordance with one embodiment of the invention.
  • FIG. 7A shows a computer system according to one embodiment of the invention.
  • FIG. 7B is a system block diagram of a computer system used to execute the software of an embodiment of the invention.
  • DETAILED DESCRIPTION OF THE INVENTION
  • The invention pertains to improved techniques for communicating between a client application operating on a client computer and one or more server computers. The improved techniques enable remote entry points on remote servers to be flexibly assigned and utilized at client applications without code changes at the client applications.
  • FIG. 1 is a block diagram of a generic application window 100 according to one embodiment of the invention. The generic application window 100 is produced by a client application operating on a client computer and contains one or more program controls 105. The program controls 105 are a means for the client application to obtain input from the user and/or to request information to be displayed for the user. As an example, the program controls 105 can be user interface components, such as text boxes, menus and hyperlinks. These program controls 105 are associated with operations of the client application. The operations, although associated with the client application, at least partially rely on interaction with another computer, such as a remote server. The client computer couples to the other computer via the Internet or some other suitable network. The generic application window 100 also contains one or more display areas 110 which may be used to display text and/or graphics.
  • One example of a client application is iTunes™, which is produced by and available from Apple Inc. of Cupertino, Calif. The iTunes™ application can produce a graphical user interface that resembles the generic application window 100 containing several program controls 105. The iTunes™ application can be referred to as a media management application for various media items. The media items can pertain to audio items (e.g., audio files or songs, such as for music or audiobooks), video items (e.g., video files or movies), or image items (e.g., photos). The program controls 105 for the iTunes™ application might pertain to operations, such as, search, browse, login, buy, or might be a hyperlink to a remote server. In any case, once an operation is activated or initiated at the iTunes™ application, the iTunes™ application executes the associated operation, which can require access to remote server computers as described in reference to FIGS. 2-6, discussed below.
  • FIG. 2 is a block diagram of a computer network 200 according to one embodiment of the invention. The computer network 200 includes one or more servers 210. Typically, the computer network 200 would include a plurality of different clients 204. Each client 204 includes a client application 208. The client application 208 is an application program (e.g., software application) that operates on the client 204, which is a computing device. The client 204 is coupled to the server 202 through a data network 206. Hence, any of the clients 204 can request remote entry point file 212 from the server 210′ such that it is locally accessible to client application 208. In one embodiment, the remote entry point file, once retrieved from the server 210′, can be stored in volatile memory at the client 204. Once the client application 208 has access to remote entry point file 212, it can then access any one of the one or more servers 210 as directed by the remote entry point file 212. In one embodiment, the data network 206 includes at least a portion of the Internet. The clients 204 can vary with application but generally are computing devices that have memory storage (e.g., both volatile and non-volatile). Often, the clients 204 are personal computers or other computing devices.
  • FIG. 3 is a flow diagram of a client-side remote entry point retrieval process 300 according to one embodiment of the invention. The client-side remote entry point retrieval process 300 can be performed on a client computer, such as the client computer 250 shown in FIG. 7A.
  • The client-side remote entry point retrieval process 300 begins with a decision 303 that determines whether an operation being performed at the client computer uses a remote entry point. The operation is typically one of many different operations that can be performed by a client application operating on the client computer. In one implementation, the client application is a media management application. The operation being performed can be initiated by a user control provided on a graphical user interface for the client application. For example, the user controls provided on the graphical user interface can be, for example, a text box, a radio button, or other user control. A remote entry point can be, for example, a uniform resource locator (URL) or an Internet protocol (IP) address (with or without sub-domain or path). When the decision 303 determines that an entry point is not used, then the operation is performed 313 at the client computer and the process ends without any usage of remote entry points.
  • On the other hand, if the decision 303 determines that the operation uses a remote entry point, then a decision 305 determines whether a remote entry point file having the remote entry point is stored on the client computer. If the decision 305 indicates that the remote entry point file is stored on the client computer, then the stored remote entry point file is accessed 307 in order to retrieve 309 the remote entry point associated with the operation. Once the remote entry point associated with the operation has been retrieved 309, the client-side remote entry point retrieval process 300 directs 311 the operation to a remote server in accordance with the remote entry point and the remote entry point retrieval process 300 ends. As such, the operation being performed by the client application can communicate with the appropriate remote server (or server application thereon).
  • Alternatively, if the decision 305 determines that the remote entry point file is not stored on the client computer, then the client-side remote entry point retrieval process 300 makes a request 315 for the remote entry point file from a remote server computer. Next, a decision 317 determines whether the remote entry point file has been received. When the decision 317 determines that the remote entry point file has not yet been received, the client-side remote entry point retrieval process 300 returns to repeat the decision 317 until the remote entry point file is received. When the decision 317 determines that the remote entry point file has been received, the remote entry point file is stored 319 on the client computer and the client-side remote entry point retrieval process 300 returns to decision 305 and subsequent blocks.
  • FIG. 4 is a flow diagram of a server-side remote entry point file retrieval process 400 in accordance with one embodiment of the invention. The server-side remote entry point retrieval process 400 can be performed on a server computer, such as any of the servers shown in FIG. 2. The server-side remote entry point file retrieval process 400 begins with a decision 403 that determines whether a request for a remote entry point file has been received. If no request has been received, the server-side remote entry point file retrieval process 400 returns to repeat the decision 403. Here, the server computer can await a request for a remote entry point file from a client computer. When decision 403 determines that a request has been received, the remote entry point file is retrieved 405 at or by the server computer. Thereafter, the remote entry point file is transmitted 407 to the requesting client computer. Following the operation 407, the server-side remote entry point file process 400 ends.
  • In one embodiment, there can be multiple sets of remote entry points that a client application might use to interact with a remote server. Each of these sets of remote entry points can be provided as a file containing a list of remote entry points. As an example, a client application operating on a client machine can perform non-secure or secure communication with remote servers. For example, the secure communications can use a secure protocol, such as https or secure sockets layer techniques for security. The remote server can be referred to as a secure server when secure communications are used with client applications. For example, secure communications can be used for a user login because any communication of a user's private data (e.g., password) should be protected.
  • FIG. 5 is a flow diagram of a client-side secure/non-secure remote entry point retrieval process 500 in accordance with one embodiment of the invention. The client-side secure/non-secure remote entry point retrieval process 500 can be performed on a client computer, such as the client computer 250 shown in FIG. 7A.
  • The client-side secure/non-secure remote entry point file retrieval process 500 begins with a decision 503 that determines whether an operation being performed at the client computer uses a remote entry point. The operation is typically one of many different operations that can be performed by a client application operating on the client computer. In one implementation, the client application is a media management application. The operation being performed can be initiated by a user control provided on a graphical user interface for the client application. For example, the user controls provided on the graphical user interface can be, for example, a text box, a radio button, or other user control. A remote entry point can be, for example, a uniform resource locator (URL) or an internet protocol (IP) address (with or without sub-domain or path). When the decision 503 determines that a remote entry point is not used, then the operation is performed 504 and the secure/non-secure remote entry point retrieval process 500 ends without any usage of remote entry points.
  • On the other hand, if decision 503 determines that the operation uses a remote entry point, then a decision 505 determines whether the operation being performed uses a secure remote entry point or a non-secure entry point. If the operation uses a secure remote entry point, then a decision 507 determines whether the secure remote entry point file having the remote entry point is stored on the client computer. If the decision 507 determines that the secure remote entry point file is not stored on the client computer, then the client-side secure/non-secure remote entry point file retrieval process 500 makes a request 509 for a secure remote entry point file from a remote server computer. Thereafter, a decision 511 determines whether the secure remote entry point file has been received. When the decision 511 determines that the secure remote entry point file has not yet been received, the client-side secure/non-secure remote entry point process 500 returns to repeat the decision 511 until the secure remote entry point file has been received. Once the decision 511 determines that the secure remote entry point file has been received, the secure remote entry point file is stored 513 on the client computer and the client-side secure/non-secure remote entry point file retrieval process 500 proceeds to access 515 the stored remote entry point file, retrieve 517 the remote entry point associated with the operation, and then direct 519 the operation to a remote server in accordance with the remote entry point. Thereafter, the client-side secure/non-secure remote entry point file retrieval process 500 ends. Alternatively, if decision 507 determines that the secure remote entry point file is stored on the client computer, the secure/non-secure remote entry point retrieval process 500 continues directly to operation 515 and subsequent blocks.
  • On the other hand, if the decision 505 determines that the operation uses a non-secure remote entry point, then a decision 521 determines whether the non-secure remote entry point file is stored on the client computer. If decision 521 determines that the secure remote entry point file is stored on the client computer, then client-side secure/non-secure remote entry point file retrieval process 500 continues on to operation 515 and subsequent blocks. Alternatively, if the decision 521 determines that the non-secure remote entry point file is not stored on the client computer, then the client-side secure/non-secure remote entry point file retrieval process 500 makes a request 523 for the non-secure remote entry point file from a remote server computer. Here, the remote server computer can be the same or different than the remote server computer used at operation 509. After making the request 523, a decision 525 determines whether the non-secure remote entry point file has been received. If the non-secure remote entry point file has not yet been received, the client-side secure/non-secure remote entry point file retrieval process 500 returns to repeat the decision 525 until the non-secure remote entry point file has been received. Once the decision 525 determines that the non-secure remote entry point file has been received, then the non-secure remote entry point file is stored on the client computer and the client-side secure/non-secure remote entry point file retrieval process 500 continues to operation 515 and subsequent blocks.
  • FIG. 6 is a flow diagram of a server-side secure/non-secure remote entry point file retrieval process 600 in accordance with one embodiment of the invention. The server-side secure/non-secure remote entry point retrieval process 600 can be performed on a server computer, such as any of the servers shown in FIG. 2.
  • The server-side secure/non-secure remote entry point file retrieval process 600 begins with a decision 603 that determines whether a request for a remote entry point file has been received. If no request has been received, the server-side secure/non-secure remote entry point file retrieval process 600 returns to repeat the decision 603. Here, the server computer can await a request for a remote entry point file from a client computer. When decision 603 determines that a request has been received, a decision 605 determines whether a secure or non-secure remote entry point file has been requested. If a secure remote entry point file has been requested, then the server-side secure/non-secure entry point retrieval process 600 retrieves 607 a secure remote entry point file. Alternatively, if the decision 605 determines that a non-secure remote entry point file has been requested, then a non-secure remote entry point file is retrieved 607. The retrieval 607 of the secure remote entry point file or the retrieval 611 of the non-secure remote entry point file can be performed by or at the server computer. Following the retrieval 607 and 611, the retrieved remote entry point file is transmitted 609 to the requesting client computer. Following the operation 609, the server-side secure/non-secure remote entry point file retrieval process 600 ends.
  • As noted above, when a client application invokes an operation, the operation may utilize a remote entry point to direct performance of some or all of the operation to a remote server. The nature or type of operation using remote entry points can vary with client application. One example of a client application is a media management application. For example, one representative media management application is iTunes™, produced by and available from Apple Inc. of Cupertino, Calif. Examples of operations associated with a media management application that could utilize remote entry points can, for example, include search, browse, buy, login, customer service, etc. By way of example, a search operation via a client application is described below according to one embodiment of the invention. Referring back to FIG. 1, the program control 105 may be implemented as a text box, wherein a user enters text (i.e., a search string) into the text box and then initiates a search for files on a remote server that match the text. In this case, the user enters a search string into the aforementioned text box and instructs the client application to perform the search by pressing the enter key or clicking on a search button, for example. The client application attempts to carry out the search according to the user's instructions. In one implementation of the invention, the search function is determined to require a remote entry point, which the client application must obtain before the search can proceed. The client can obtain the needed remote entry point by, for example, one of the methods described in reference to FIGS. 3 or 5 in order to locate the remote server that it will use in order to perform the search. An exemplary remote entry point, provided in a URL format, is as follows.
    • search<string>http://server.domain.com/DirectAction/search</string>
      In this example, “search” is the type of operation and the associated remote entry point is “http://server.domain.com/DirectAction/search”. The search string is passed to the remote server according to the remote entry point, where the search is performed. The appropriate information is passed back to the requesting client application such that the results are displayed to the user.
  • FIG. 7A shows a computer system 725 that includes a display monitor 728 having a single or multi-screen displays 730 (or multiple displays), cabinet 732, keyboard 734, and mouse 736. Cabinet 732 houses a drive 738, such as a CD-ROM or floppy drive, system memory and a hard drive (see FIG. 7A) which may be utilized to store and retrieve software programs incorporating computer code that implements the present invention, data for use with the invention, and the like. Although CD-ROM 740 is shown as an exemplary computer readable storage medium, other computer readable storage media including floppy disk, tape, flash memory, system memory, and hard drive may be utilized. In one implementation, an operating system for the computer system 725 is provided in the system memory, the hard drive, the CD-ROM 740 or other computer readable storage medium and serves to incorporate the computer code that implements the invention.
  • FIG. 7B shows a system block diagram of a computer system 750 used to execute the software of an embodiment of the invention. As in FIG. 7A, computer system 750 includes display monitor 728 and keyboard 734, and mouse 736. Computer system 725 further includes subsystems such as a central processor 751, system memory 753, fixed storage 755 (e.g., hard drive), removable storage 757 (e.g., CD-ROM drive), display adapter 759, sound card 761, speakers 763, and network interface 765. The operating system and client application are normally, but not necessarily, resident in the system memory 753 during its execution. Other computer systems suitable for use with the invention may include additional subsystem or fewer subsystems. For example, another computer system could include more than one processor 751 (i.e., a multi-processor system) or one or more levels of a cache memory.
  • The system bus architecture of computer system 725 is represented by arrows 767. However, these arrows are illustrative of any interconnection scheme serving to link the subsystems. For example, a local bus could be utilized to connect the central processor to the system memory and display adapter. Computer system 725 shown in FIG. 7B is but an example of a computer system suitable for use with the invention. Other computer architectures having different configurations of subsystems may also be utilized.
  • The various aspects, features, embodiments or implementations of the invention described above can be used alone or in various combinations.
  • The invention is preferably implemented by software, but can also be implemented in hardware or a combination of hardware and software. The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, CD-ROMs, DVDs, magnetic tape, optical data storage devices, and carrier waves. The computer readable medium can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • The advantages of the invention are numerous. Different embodiments or implementations may, but need not, yield one or more of the following advantages. One advantage of the invention is that an application using a remote entry point file does not require remote entry points to be hard-coded, thus allowing for flexibility as to which remote server will be used for a particular operation at any given time. Another advantage of the invention is that a remote entry point file may be generated dynamically upon request from a client computer, thereby better enabling network managers to balance server-load among several remote servers. Still another advantage of the invention is the possibility of having entry point files tailored specifically according to geographical location of the client computer, thus using remote servers that are closer in proximity to the client computers.
  • The many features and advantages of the present invention are apparent from the written description and, thus, it is intended by the appended claims to cover all such features and advantages of the invention. Further, since numerous modifications and changes will readily occur to those skilled in the art, the invention should not be limited to the exact construction and operation as illustrated and described. Hence, all suitable modifications and equivalents may be resorted to as falling within the scope of the invention.

Claims (24)

1. A computer-implemented method for communicating between a client application operating on a client computer and a plurality of remote server computers, comprising:
determining if a client application operation requires a remote entry point;
determining whether the client application operation requires a secure entry point;
if it is determined that the client application operation requires a remote entry point and it is determined that a secure entry point is not required, then:
requesting a non-secure entry point file from a remote server computer;
receiving the non-secure entry point file from the remote server computer; and
storing the non-secure entry point file on the client computer;
if it is determined that the client application operation requires a remote entry point and it is determined that a secure entry point is required, then:
requesting a secure entry point file from the remote server computer;
receiving the secure entry point file from the remote server computer; and
storing the secure entry point file on the client computer.
2. A computer-implemented method of claim 27, further comprising:
accessing the stored secure or non-secure remote entry point file;
retrieving the remote entry point or the secure entry point associated with the client application operation; and
directing the client application operation to a remote server computer in accordance with the remote entry point or the secure entry point.
3. A computer implemented method for securely communicating between a client application operating on a client computer and a plurality of server computers, comprising:
determining if a client application operation requires a secure remote entry point;
obtaining, at the client computer, a set of secure remote entry points for at least one remote server computer;
retrieving a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and
directing the client application operation to the remote server in accordance with the particular secure remote entry point.
4. A computer-implemented method as recited in claim 3, wherein the secure remote entry points in the set of secure remote entry points pertaining to different operations that are able to be performed at the least one remote server computer.
5. A computer-implemented method as recited in claim 3, wherein said obtaining comprises:
requesting the set of secure remote entry points from a remote server computer; and
receiving the set of secure remote entry points from the remote server computer.
6. A computer-implemented method as recited in claim 5, wherein said obtaining further comprises:
storing the set of secure remote entry points on the client computer.
7. A computer-implemented method as recited in claim 6, wherein said storing operates to store the set of secure remote entry points in volatile memory at the client computer.
8. A computer-implemented method as recited in claim 7, wherein said obtaining further comprises:
determining whether the set of secure remote entry points is already stored in the volatile memory at the client computer; and
receiving the set of secure remote entry points from the volatile memory at the client computer when said determining determines that the set of secure remote entry points is already stored in the volatile memory at the client computer.
9. A computer-implemented method as recited in claim 3, wherein said obtaining further comprises:
determining whether the set of secure remote entry points is already stored at the client computer and is valid; and
receiving the set of secure remote entry points from the client computer when said determining determines that the set of secure remote entry points is already stored and is valid at the client computer.
10. A computer-implemented method as recited in claim 3, wherein the set of secure remote entry points is provided as an entry point file.
11. A computer-implemented method as recited in claim 3, wherein the set of secure remote entry points includes at least a list of URLs.
12. A computer-implemented method as recited in claim 3, wherein the client application operation is a secure operation.
13. A computer-implemented method as recited in claim 3, wherein the client application is a media management application.
14. A computer-implemented method as recited in claim 3, wherein said retrieving comprises:
searching through the set of secure remote entry points to locate the particular secure remote entry point that has an attribute that matches the client application operation; and
retrieving the particular secure remote entry point that has been identified by said searching.
15. A computer-implemented method as recited in claim 14, wherein said searching uses text string matching to locate the particular secure remote entry point.
16. A computer-implemented method as recited in claim 3, wherein the set of secure remote entry points is provided as an entry point file.
17. A computer-implemented method for delivering a set of remote entry points from a server computer to a client computer, comprising:
receiving, at the server computer, a request from a client computer for a set of secure remote entry points;
retrieving, at the server computer, the set of secure remote entry points; and
transmitting the set of secure remote entry points to the client computer.
18. A computer-implemented method as recited in claim 17, wherein the client computer operates a media management application that utilizes the set of secure remote entry points to interact with one or more server computers.
19. A computer-implemented method as recited in claim 17, wherein the set of remote entry points is provided as an entry point file, and wherein the set of remote entry points includes at least a list of URLs.
20. A computer-implemented method as recited in claim 17, wherein said retrieving comprises dynamically generating the set of secure remote entry points at the server computer upon receiving the request for the set of remote entry points.
21. A system for communicating between a client computer and a plurality of server computers, comprising:
a client computer including at least a processor, volatile memory and a storage disk drive; and
a plurality of server computers,
wherein said client computer can communicate with said server computer via a data network, and
wherein said client computer performs a client application and in doing so said processor executes computer program code, said computer program code operates to at least:
determine if a client application operation requires a secure remote entry point;
obtaining, at said client computer, a set of secure remote entry points for at least one remote server computer;
retrieve a particular secure remote entry point from the set of secure remote entry points, the particular secure remote entry point being associated with the client application operation; and
direct the client application operation to the remote server in accordance with the particular secure remote entry point.
22. A system as recited in claim 21, wherein the set of secure remote entry points is stored at said client computer only in the volatile memory.
23. A computer readable medium including at least executable computer program code stored thereon for communicating between a client application operating on a client computer and at least one server computer, comprising:
computer code for receiving, at a server computer, a request from a client computer for at least one secure remote entry point;
computer code for retrieving, at the server computer, the at least one secure remote entry point; and
computer code for transmitting the at least one secure remote entry point to the requesting client computer.
24. A computer readable medium as recited in claim 23, wherein the at least one remote entry point being at least one of a plurality of remote entry points pertaining to different operations that are able to be performed at the server computer.
US12/335,399 2004-04-27 2008-12-15 Method and System for Retrieval and Usage of Remote Entry Points Abandoned US20090094346A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/335,399 US20090094346A1 (en) 2004-04-27 2008-12-15 Method and System for Retrieval and Usage of Remote Entry Points

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/833,387 US7480700B2 (en) 2004-04-27 2004-04-27 Method and system for retrieval and usage of remote entry points
US12/335,399 US20090094346A1 (en) 2004-04-27 2008-12-15 Method and System for Retrieval and Usage of Remote Entry Points

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/833,387 Division US7480700B2 (en) 2004-04-27 2004-04-27 Method and system for retrieval and usage of remote entry points

Publications (1)

Publication Number Publication Date
US20090094346A1 true US20090094346A1 (en) 2009-04-09

Family

ID=35758717

Family Applications (2)

Application Number Title Priority Date Filing Date
US10/833,387 Active 2026-12-21 US7480700B2 (en) 2004-04-27 2004-04-27 Method and system for retrieval and usage of remote entry points
US12/335,399 Abandoned US20090094346A1 (en) 2004-04-27 2008-12-15 Method and System for Retrieval and Usage of Remote Entry Points

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US10/833,387 Active 2026-12-21 US7480700B2 (en) 2004-04-27 2004-04-27 Method and system for retrieval and usage of remote entry points

Country Status (1)

Country Link
US (2) US7480700B2 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7480700B2 (en) * 2004-04-27 2009-01-20 Apple Inc. Method and system for retrieval and usage of remote entry points
AU2010201379B2 (en) * 2010-04-07 2012-02-23 Limelight Networks, Inc. System and method for delivery of content objects
US8352323B2 (en) * 2007-11-30 2013-01-08 Blaze Mobile, Inc. Conducting an online payment transaction using an NFC enabled mobile communication device
US8244874B1 (en) 2011-09-26 2012-08-14 Limelight Networks, Inc. Edge-based resource spin-up for cloud computing

Citations (42)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5774668A (en) * 1995-06-07 1998-06-30 Microsoft Corporation System for on-line service in which gateway computer uses service map which includes loading condition of servers broadcasted by application servers for load balancing
US6006269A (en) * 1998-03-11 1999-12-21 Hewlett-Packard Company Admission control system with messages admitted or deferred for re-submission at a later time on a priority basis
US6006333A (en) * 1996-03-13 1999-12-21 Sun Microsystems, Inc. Password helper using a client-side master password which automatically presents the appropriate server-side password to a particular remote server
US6185567B1 (en) * 1998-05-29 2001-02-06 The Trustees Of The University Of Pennsylvania Authenticated access to internet based research and data services
US6243738B1 (en) * 1998-04-06 2001-06-05 National Instruments Corporation Data acquisition system which includes remote access to data acquisition devices
US6269395B1 (en) * 1998-12-21 2001-07-31 Nortel Networks Limited Method and system in a computer-based system for providing access to services associated with different access points
US20010011238A1 (en) * 1998-03-04 2001-08-02 Martin Forest Eberhard Digital rights management system
US6336137B1 (en) * 2000-03-31 2002-01-01 Siebel Systems, Inc. Web client-server system and method for incompatible page markup and presentation languages
US20020105578A1 (en) * 2001-02-03 2002-08-08 Andrew Arthur Hunter Tracking system
US20020111942A1 (en) * 1998-11-16 2002-08-15 Punch Networks Corporation Method and system for providing remote access to the facilities of a server computer
US6490624B1 (en) * 1998-07-10 2002-12-03 Entrust, Inc. Session management in a stateless network system
US6510464B1 (en) * 1999-12-14 2003-01-21 Verizon Corporate Services Group Inc. Secure gateway having routing feature
US20030046587A1 (en) * 2001-09-05 2003-03-06 Satyam Bheemarasetti Secure remote access using enterprise peer networks
US20030084169A1 (en) * 2001-10-31 2003-05-01 Min Zhu System and method for accessing a target computer from a remote location using a remote computer
US6732176B1 (en) * 1999-11-03 2004-05-04 Wayport, Inc. Distributed network communication system which enables multiple network providers to use a common distributed network infrastructure
US6763371B1 (en) * 1999-05-10 2004-07-13 Telefonaktiebolaget Lm Ericsson (Publ) Method and apparatus for collaborative communication in a communication network
US20040162876A1 (en) * 2003-02-14 2004-08-19 Whale Communications Ltd. System and method for providing conditional access to server-based applications from remote access devices
US20040198220A1 (en) * 2002-08-02 2004-10-07 Robert Whelan Managed roaming for WLANS
US20040236745A1 (en) * 2003-05-22 2004-11-25 International Business Machines Corporation Distributed filesystem network security extension
US20040268451A1 (en) * 2003-04-25 2004-12-30 Apple Computer, Inc. Graphical user interface for browsing, searching and presenting media items
US20050021478A1 (en) * 2003-04-25 2005-01-27 Apple Computer, Inc. Method and system for network-based purchase and distribution of media
US20050050345A1 (en) * 2003-04-25 2005-03-03 Apple Computer, Inc. Method and system for secure network-based distribution of content
US6874152B2 (en) * 2000-04-19 2005-03-29 Nowavision, Llc System for accessing content by virtual remote control through mapping channel codes to network addresses
US6892225B1 (en) * 2000-07-19 2005-05-10 Fusionone, Inc. Agent system for a secure remote access system
US20050177580A1 (en) * 2004-02-11 2005-08-11 Hilbert David M. System and method for customized document selection
US7000107B2 (en) * 2000-09-30 2006-02-14 Microsoft Corporation System and method for using dynamic web components to remotely control the security state of web pages
US7020097B2 (en) * 2000-12-30 2006-03-28 Electronics And Telecommunications Research Institute Adaptive wireless network system comprising central optimizer and method thereof
US7146638B2 (en) * 2002-06-27 2006-12-05 International Business Machines Corporation Firewall protocol providing additional information
US20070076671A1 (en) * 2005-09-30 2007-04-05 Cisco Technology, Inc. System and method for network infrastructure driven context setup to facilitate roaming
US7206806B2 (en) * 2001-05-30 2007-04-17 Pineau Richard A Method and system for remote utilizing a mobile device to share data objects
US20070180320A1 (en) * 2006-01-13 2007-08-02 Nokia Corporation Apparatus, method and computer program product providing system information advertisement extension for dynamic networks
US7257642B1 (en) * 1999-11-11 2007-08-14 Surp Communication Solutions Ltd. Channel load balancing
US7295524B1 (en) * 2003-02-18 2007-11-13 Airwave Wireless, Inc Methods, apparatuses and systems facilitating management of airspace in wireless computer network environments
US20080008140A1 (en) * 2006-07-05 2008-01-10 Mika Forssell Conditional utilization of private short-range wireless networks for service provision and mobility
US20080119177A1 (en) * 2006-09-15 2008-05-22 Speedus Corp. Metadata Content Delivery System for Wireless Networks
US7480700B2 (en) * 2004-04-27 2009-01-20 Apple Inc. Method and system for retrieval and usage of remote entry points
US7525938B2 (en) * 2003-12-17 2009-04-28 Tuija Hurtta Session control in a communication system
US7546576B2 (en) * 2001-06-15 2009-06-09 Lightsurf Technology, Inc. Software framework for web-based applications
US7620997B2 (en) * 2003-12-22 2009-11-17 Lenovo (Singapore) Pte. Ltd. System and method for controlling network access in wireless environment
US7631084B2 (en) * 2001-11-02 2009-12-08 Juniper Networks, Inc. Method and system for providing secure access to private networks with client redirection
US7672879B1 (en) * 1998-12-08 2010-03-02 Yodlee.Com, Inc. Interactive activity interface for managing personal data and performing transactions over a data packet network
US7701912B2 (en) * 2000-04-18 2010-04-20 Cisco Technology, Inc. System and method for concurrently utilizing multiple system identifiers

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6003030A (en) * 1995-06-07 1999-12-14 Intervu, Inc. System and method for optimized storage and retrieval of data on a distributed computer network

Patent Citations (44)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5774668A (en) * 1995-06-07 1998-06-30 Microsoft Corporation System for on-line service in which gateway computer uses service map which includes loading condition of servers broadcasted by application servers for load balancing
US6006333A (en) * 1996-03-13 1999-12-21 Sun Microsystems, Inc. Password helper using a client-side master password which automatically presents the appropriate server-side password to a particular remote server
US20010011238A1 (en) * 1998-03-04 2001-08-02 Martin Forest Eberhard Digital rights management system
US6006269A (en) * 1998-03-11 1999-12-21 Hewlett-Packard Company Admission control system with messages admitted or deferred for re-submission at a later time on a priority basis
US6243738B1 (en) * 1998-04-06 2001-06-05 National Instruments Corporation Data acquisition system which includes remote access to data acquisition devices
US6185567B1 (en) * 1998-05-29 2001-02-06 The Trustees Of The University Of Pennsylvania Authenticated access to internet based research and data services
US6490624B1 (en) * 1998-07-10 2002-12-03 Entrust, Inc. Session management in a stateless network system
US20020111942A1 (en) * 1998-11-16 2002-08-15 Punch Networks Corporation Method and system for providing remote access to the facilities of a server computer
US7672879B1 (en) * 1998-12-08 2010-03-02 Yodlee.Com, Inc. Interactive activity interface for managing personal data and performing transactions over a data packet network
US6269395B1 (en) * 1998-12-21 2001-07-31 Nortel Networks Limited Method and system in a computer-based system for providing access to services associated with different access points
US6763371B1 (en) * 1999-05-10 2004-07-13 Telefonaktiebolaget Lm Ericsson (Publ) Method and apparatus for collaborative communication in a communication network
US6732176B1 (en) * 1999-11-03 2004-05-04 Wayport, Inc. Distributed network communication system which enables multiple network providers to use a common distributed network infrastructure
US7257642B1 (en) * 1999-11-11 2007-08-14 Surp Communication Solutions Ltd. Channel load balancing
US6510464B1 (en) * 1999-12-14 2003-01-21 Verizon Corporate Services Group Inc. Secure gateway having routing feature
US6336137B1 (en) * 2000-03-31 2002-01-01 Siebel Systems, Inc. Web client-server system and method for incompatible page markup and presentation languages
US7701912B2 (en) * 2000-04-18 2010-04-20 Cisco Technology, Inc. System and method for concurrently utilizing multiple system identifiers
US6874152B2 (en) * 2000-04-19 2005-03-29 Nowavision, Llc System for accessing content by virtual remote control through mapping channel codes to network addresses
US6892225B1 (en) * 2000-07-19 2005-05-10 Fusionone, Inc. Agent system for a secure remote access system
US7000107B2 (en) * 2000-09-30 2006-02-14 Microsoft Corporation System and method for using dynamic web components to remotely control the security state of web pages
US7020097B2 (en) * 2000-12-30 2006-03-28 Electronics And Telecommunications Research Institute Adaptive wireless network system comprising central optimizer and method thereof
US20020105578A1 (en) * 2001-02-03 2002-08-08 Andrew Arthur Hunter Tracking system
US7206806B2 (en) * 2001-05-30 2007-04-17 Pineau Richard A Method and system for remote utilizing a mobile device to share data objects
US7546576B2 (en) * 2001-06-15 2009-06-09 Lightsurf Technology, Inc. Software framework for web-based applications
US20030046587A1 (en) * 2001-09-05 2003-03-06 Satyam Bheemarasetti Secure remote access using enterprise peer networks
US20030084169A1 (en) * 2001-10-31 2003-05-01 Min Zhu System and method for accessing a target computer from a remote location using a remote computer
US7631084B2 (en) * 2001-11-02 2009-12-08 Juniper Networks, Inc. Method and system for providing secure access to private networks with client redirection
US7146638B2 (en) * 2002-06-27 2006-12-05 International Business Machines Corporation Firewall protocol providing additional information
US20040198220A1 (en) * 2002-08-02 2004-10-07 Robert Whelan Managed roaming for WLANS
US7606242B2 (en) * 2002-08-02 2009-10-20 Wavelink Corporation Managed roaming for WLANS
US20040162876A1 (en) * 2003-02-14 2004-08-19 Whale Communications Ltd. System and method for providing conditional access to server-based applications from remote access devices
US7295524B1 (en) * 2003-02-18 2007-11-13 Airwave Wireless, Inc Methods, apparatuses and systems facilitating management of airspace in wireless computer network environments
US20050050345A1 (en) * 2003-04-25 2005-03-03 Apple Computer, Inc. Method and system for secure network-based distribution of content
US20040268451A1 (en) * 2003-04-25 2004-12-30 Apple Computer, Inc. Graphical user interface for browsing, searching and presenting media items
US20050021478A1 (en) * 2003-04-25 2005-01-27 Apple Computer, Inc. Method and system for network-based purchase and distribution of media
US20040236745A1 (en) * 2003-05-22 2004-11-25 International Business Machines Corporation Distributed filesystem network security extension
US7525938B2 (en) * 2003-12-17 2009-04-28 Tuija Hurtta Session control in a communication system
US7620997B2 (en) * 2003-12-22 2009-11-17 Lenovo (Singapore) Pte. Ltd. System and method for controlling network access in wireless environment
US20050177580A1 (en) * 2004-02-11 2005-08-11 Hilbert David M. System and method for customized document selection
US7480700B2 (en) * 2004-04-27 2009-01-20 Apple Inc. Method and system for retrieval and usage of remote entry points
US20070076671A1 (en) * 2005-09-30 2007-04-05 Cisco Technology, Inc. System and method for network infrastructure driven context setup to facilitate roaming
US20070180320A1 (en) * 2006-01-13 2007-08-02 Nokia Corporation Apparatus, method and computer program product providing system information advertisement extension for dynamic networks
US7747267B2 (en) * 2006-01-13 2010-06-29 Nokia Corporation Apparatus, method and computer program product providing system information advertisement extension for dynamic networks
US20080008140A1 (en) * 2006-07-05 2008-01-10 Mika Forssell Conditional utilization of private short-range wireless networks for service provision and mobility
US20080119177A1 (en) * 2006-09-15 2008-05-22 Speedus Corp. Metadata Content Delivery System for Wireless Networks

Also Published As

Publication number Publication date
US7480700B2 (en) 2009-01-20
US20060031383A1 (en) 2006-02-09

Similar Documents

Publication Publication Date Title
US10860734B2 (en) Remote data access techniques for portable devices
CN1559040B (en) Selection of content in response to communication environment
US7483958B1 (en) Methods and apparatuses for sharing media content, libraries and playlists
US6859878B1 (en) Universal userid and password management for internet connected devices
US6996599B1 (en) System and method providing multi-tier applications architecture
JP4335559B2 (en) Method and apparatus for peer-to-peer file sharing
US6038603A (en) Processing customized uniform resource locators
EP1410261B1 (en) Method and apparatus for peer-to-peer services
US9380022B2 (en) System and method for managing content variations in a content deliver cache
US7908270B2 (en) System and method for managing access to media assets
US20060174327A1 (en) Apparatus and method for a personal cookie repository service for cookie management among multiple devices
US20030009518A1 (en) Method and apparatus for peer-to-peer services
US20070294237A1 (en) Enterprise-Wide Configuration Management Database Searches
US8311225B2 (en) Scalable key archival
WO2003091889A1 (en) Collaboration server, collaboration system, session management method thereof, and program
US20090094346A1 (en) Method and System for Retrieval and Usage of Remote Entry Points
CN109522462A (en) A kind of cloud querying method, device, equipment and storage medium based on block chain
US20080301003A1 (en) System for Online Buying
US7448032B2 (en) Method and apparatus for integration of URL into standard file systems
JP2004126908A (en) Data storage system, data management method, and data storage medium
JP2008525867A (en) Method and system for providing content to an offline mobile storage device
US20100107090A1 (en) Remote linking to media asset groups
JP2004062814A (en) Content reference system, content reference method, and computer program
KR100601366B1 (en) System and method for offering digital contents using the URL and computer readable record medium on which a program therefor is recorded
US8521806B2 (en) Initiating a file download by a first electrical device through a second electrical device

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION