|Publication number||US8001187 B2|
|Application number||US 10/612,632|
|Publication date||Aug 16, 2011|
|Filing date||Jul 1, 2003|
|Priority date||Jul 1, 2003|
|Also published as||EP2360600A1, US20050004985, US20050004995|
|Publication number||10612632, 612632, US 8001187 B2, US 8001187B2, US-B2-8001187, US8001187 B2, US8001187B2|
|Original Assignee||Apple Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (64), Non-Patent Citations (6), Referenced by (33), Classifications (22), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
This invention pertains to peer chat networks in general, and more particularly, to sharing active content and related information with another peer.
2. Description of Related Art
Instant messaging has recently emerged as a powerful communications model for both business and personal communications. Instant messaging software applications such as Apple Computer's iChat™, America Online's Instant Messenger™, Microsoft Corp.'s MSN Messenger™, and others allow users to communicate instantly with other users over a peer network. These applications permit users to track other users that are currently logged in and to send them real time text messages. Users typically maintain a contact or buddy list of preferred contacts that are friends, family, co-workers, or others having common interests, etc. The buddy list allows simple, albeit limited, access to the preferred contacts.
One problem with existing instant messaging applications is that they limit the real time information shared between a user and a contact to, for example, text messages, simple graphic files, and static file transfers. Significantly, current instant messaging applications do not allow users of a peer to directly and easily share information about active content on the peer. The instant messaging applications lack the software architecture to track active content in applications on a common peer, and lack the network communications architecture to share active content with other peers on the network.
Active content includes files that a user is currently accessing, such as music files the user is currently listening to, movies the user is currently watching, and other multimedia content the user is currently experiencing, or the like. Active files can also include other files that are open on the user's computer and in use by an application, such as a multimedia player like Apple Computer's iTunes™. Thus, if a user is listening to a music file on his computer, those contacts he may be currently instant messaging cannot hear that same file at the same time. Likewise, if the user were watching a movie, the instant messaging contacts would not be able to view the movie as well.
At best, in order to share such files, the sender must close the file (or make a copy of it), and then transfer the file via a file transfer function of the instant messaging application or as an attachment to an email sent by an email application, or a user can send a URL to a file if its available on the Internet. This process is not real time sharing of active content, but is essentially copying the static file (or a reference to it) from one computer to another. Further, neither approach provides the recipient with real time updates such as a change in active content, nor do they synchronize the recipient's version with the portion of the active content currently available to the sender, for example, the portion of a multimedia file being viewed by the sender. Moreover, many multimedia files are not well suited for emailing because of their large size.
Furthermore, there is no network architecture to automatically enhance the recipient's use of the user's active content information. Typically, a recipient of a static content file has to undertake additional manual steps to obtain such additional information. Again, if a user is listening to a music file, the user's instant messaging contacts, even those currently in a chat session, would not have direct access to information or meta-data such as the song's name, artist, album art, liner notes, or the like. More generally, there is no way for a one user of an instant messaging application to retrieve supplemental information about the active content in use on another user's computer from a database. Similarly, such instant messaging contacts of the user cannot today easily or directly purchase or preview a copy of active content within the instant messenger.
Another problem with existing messenger applications is that they are typically stand-alone applications that provide only messaging functionality. However, users often multitask between several applications on a single desktop, and typically have an instant messaging application running concurrently with other applications, such as word processors, spreadsheets, graphics applications, media applications, and the like. Thus, users must toggle between the instant messaging application to communicate with their contacts and other active applications to perform tasks such as playing back multimedia or surfing web sites, performing word processing, and the like.
Accordingly, there is a need to enhance application and network communication architecture of instant messengers to enable real time active content sharing. The solution should provide supplemental information, real time streaming or previewing, and enable a transaction for the recipient to obtain its own copy of the active content.
The present invention allows instant messaging applications in a peer network to share active content. A sender peer includes an application module to activate content from a file in a content repository. The application module may be a media player, a word processor, or other application for activating content. The active content is preferably a multimedia file, which may be incorporated in a word processing document, or other data file capable of execution in the application module. A chat module of the sender peer includes a daemon to track application modules and poll each application module for its current active content file, and its current display of the active content file. The chat module shares active content with a remotely located recipient peer through a network by sending active content information collected by the daemon, such as a unique identifier. The recipient peer includes a chat module to receive and output active content information, such as integrating the active content information into the chat module graphical user interface (GUI) display.
In one embodiment, a content enhancement server includes a content supplement database to provide supplements to shared active content to the recipient peer. Supplemental information can include descriptive information about the active content, meta-data, or additional information, such as name, creator, content descriptions, related files and so forth (e.g., a CD containing the active media, a graphic file of the artist, a preview, or transactional information to obtain a copy). In another embodiment, the content supplement database stores previews of active content for streaming to the recipient peer.
The content enhancement server may also include a content transaction module to enable a transaction based on the shared active content. The content enhancement server, for example, enables a purchase a copy of a shared music file. In another embodiment, the content transaction module serves as a gateway to third-party databases with available products by using application program interfaces to search the third-party databases and generate a list of available products.
In another embodiment of the system, the sender peer substantially synchronously streams active content to the recipient peer. The sender peer includes a server module and the recipient peer includes a client module that together negotiate streaming parameters for shared active content. The recipient peer's active content executing in the receiving application module correlates to the sender peer's active content executing in the sending application module.
Other embodiments include a method of active content sharing, a method of streaming shared active content, a method of enabling a transaction related to the active content, and a method of retrieving supplemental information about the active content.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the invention. The field of networking is such that many different variations of the illustrated and described features of the invention are possible. Those skilled in the art will undoubtedly appreciate that the invention can be practiced without some specific details described below, and indeed will see that many other variations and embodiments of the invention can be practiced while still satisfying the teachings of the invention. Further, those of skill in the art of networking appreciate the large variety of different networking protocols, topologies, transports, and the like that can be used to establish networked communications between computers. Accordingly, the present invention should not be understood as being limited to the specific example implementation described below.
Active content, as used herein, refers to a data file in current use at a peer. The data file in use may be media content such as an audio or video file being played back in a media player, text, graphics, or numeric content such as a document, spreadsheet, code file, graphics file, or any other file having data representing content that is capable of perception by a user at the peer. Shared active content refers to active content made available to other peers on the network by sending the peers active content information. Active content information may be meta-data about the data file (e.g., size, title, author, location, date, content list), an auxiliary data file related to the data file (e.g., unique identifier, associated graphics, text, references to other files), transaction information, or any other information directly or indirectly related to the content.
The sender peer 110 activates the content and sends active content information and synchronized active content streams to other peers on the network 145. In general, a peer is some type of computing device (physical or virtual), such as a computer, a telephone, set top box, a network appliance, or any device capable of connecting to the network 145 and receiving active content. As would be known to one of ordinary skill in the art, having the benefit of this disclosure, a sender peer 110 and/or a recipient peer 120 may comprise computer readable program storage devices. The sender peer 110 and/or a recipient peer 120, as would be known to one of ordinary skill in the art, having the benefit of this disclosure, may comprise computer readable program storage devices such as floppy disk drives, compact disc read-only memory (CD-ROM) devices, digital video disc (DVD) devices, universal serial bus (USB) storage devices, flash drives, tape drives, external storage devices, and/or the like, along with their respective media. In one embodiment, the sender peer 110 serves as a network gateway for an ancillary device 150 with active content that is wirelessly connected to the peer. For example, an MP3 player or a digital video recorder having active content may be networked to the peer, which in turn, shares the MP3 player's active content and related information with peers on the network 145. Further embodiments of the sender peer and methods operating therein are discussed below.
The recipient peer 120 receives and outputs active content information from other peers and the content enhancement server 130, and streamed active content. The recipient peer 120 may be any embodiment of the first peer, so output may be displayed in a GUI. However, in other embodiments, the second peer is a thin version of the first peer in that it has the capability to receive information about the active content, but not necessarily to activate a stream of the active content itself. For example, a telephone having the chat module (e.g., an SMS compatible text messaging module) may not have the multimedia player needed to activate streamed content. Further embodiments of the second peer and methods operating therein are discussed below.
The enhanced content server 130 provides supplemental information about active content information to the recipient peer 120, and enables related transactions. The enhanced content server 130 may be software, hardware, or a combination, residing on a network destination. The enhanced content server 130 may be part of a central peer server, or part of an independent third-party server compatible with the peer-to-peer protocol used by the peers in the system 100 such as iTunes Music Store. Further embodiments of the enhanced content server 130 and methods operating therein are discussed below.
In one example of the system 100, two users, one at the sender peer 110 and one at the recipient peer 120 exchange text messages through iChat, while the sender user also listens to an MP3 with iTunes. The receiver user notices active content information concerning the sender user's active media content (i.e., the MP3 in use) on the receiver user's iTunes and turns the conversation towards that song. The receiver user consequentially decides to preview the music, initiating a stream from the sender peer 110 to the recipient peer 120. Ultimately, the sender user purchases a copy from the iTunes Music Store.
The network 145 transports data packets containing information about active content information between, e.g., the sender peer 110, the recipient peer 120, and the enhanced content server 130. The network 145 may be a data network, a telephone network, or any other type of network capable of transporting data. The data may be video, audio, information, or otherwise. The network 145 can be public or private, including both wired and wireless portions, send data in packets or through circuits, and use communications protocols such as IP (Internet Protocol) or ATM (Asynchronous Transfer Mechanism). Combinations of the previous and variations of network communication are within the scope of the present invention since it is transport independent.
Examples of alternative embodiments of the system 100 include, an embodiment having more than two peers, an embodiment having peers without the auxiliary content server, and an embodiment having peers communicatively coupled through a first network 145 and one of the peers communicatively coupled to the auxiliary content server through a second network 145. In particular,
The chat module 210 sends and receives active content and related information. The chat module 210 connects to a centralized messenger service located on the network 145 to set-up communication with other peers. The centralized messenger service may be Apple Computer Inc.'s iChat™, America Online's AIM™, or the like. Peers can communicate with each other, with their messages passing through the messenger service, or directly with each other independently of the centralized messenger server. The chat module 210 may periodically communicate with the centralized messenger service to update communication with other peers such as setting-up connections with new peers and changing communication addresses of existing peers. Although the present embodiment utilizes a chat module 210 to share the active content, other embodiments may integrate active content sharing into different peer-to-peer communications modules such as an FTP module or other file sharing application.
Additionally, the chat module 210 may include a daemon to track and poll the application modules 220 to determine if there is active content. The chat module 210 also determines the real time output of active content. In other words, if a video file is playing back in a media player, the chat module 210 determines which video frame, point in time, or other location indicator is currently active in the application module 220. The chat module 210 sends active content and related information to other peers. In one embodiment, certain active content may be precluded from sharing according to parameters set by the user such as content containing confidential information.
The application module 220 further includes active content. The application module 220 may be application software, hardware, or a combination such as a media player, a word processor, or the like. To activate the data file, the application module 220 opens at least a portion of the data file and progresses through the data file either sequentially or otherwise. For example, a media player may load a portion of an audio file into a buffer representing the next ten seconds of audio playback. In another example, an e-book viewer may load an entire e-book file into a buffer to display portions of text in a window according to the window's size.
The content repository 230 stores data files that are activated by the application module 220. The content repository 230 may be a hard disk, flash memory, random access memory, or any device capable of non-volatile or volatile storage of data files. The data files contain data in any useful format, such .mpg, .wma, .omg, gif, .mp3, .doc, .txt, .pdf, or any format capable of execution by the application module 220. In one embodiment, the content repository 230 is networked to the sender peer 110 such as a personal digital assistant with data files connected to the peer via the Bluetooth wireless communications protocol.
The communications module 310 provides a communications pathway for the chat module 210 to transmit messages, and to share active content through a peer-to-peer network. The communications module 310 logs-in to the centralized chat server and establishes point-to-point communication with other peers by exchanging network addresses such as IP addresses. The communications module 310 may further comprise a network interface, appropriate protocol stack, an operating system or port control, a peer network software, or and application software.
The server/client module 320 sends active content information for output at the other peers, and likewise receives active content information from other peers for local output. Additionally, the server/client module 320 performs synchronized data streaming of the active content. Synchronization, however, may be substantially synchronized since the operation is dependent on network load, streaming parameters, and other conditions. The server/client module 320 may be an FTP server, a desktop sharing server, an audio/video server, or any other device capable of sending and receiving active content through a network.
The content information database 330 stores information about active content shared with other peers. Active content information may be a meta-data about the data file such as its size, an auxiliary data file related to the data file such a unique identifier, related image file, content title, content source, or any other information directly or indirectly related to the content. The content information database 330 is queried with an identifier such as an MP3 ID tag received from, e.g., the chat module 210 or the application module 220. In response, the content information database 330 makes matching information available, such as the MP3 content title. The information can be displayed at the sender peer 110, sent to the recipient peer 120 for display, or sent to the content enhancement server 130.
In one embodiment, a unique identifier comprises an active content fingerprint such as a hash key or wavelet. The hash key can be determined from an algorithm implementing a mathematical transform on binary data such as SHA-1 or CRC32. The unique identifier may be used by the recipient peer 120 to retrieve locally stored active content information related to the file, or sent to the content enhancement server 130 to retrieve active content supplements.
The GUI module 340 provides a user interface of the chat module 210 and receives user commands related to active content. In the recipient peer 120, the GUI module 340 integrates the active content information into the chat module's 210 user interface as discussed below in regards to
The representation of Peer 1 includes information about active content 412 at Peer 1. Specifically, an icon indicates that the user of Peer 1 is listening to a song by Simon Posford titled “Dorset Perception.” In response to selecting the icon, the chat module 210 initiates an active content stream as described below.
The representation of Peer 2 does not include information about active content at Peer 2. In one embodiment, Peer 2 does not send information about active content because, for example, there is no currently active content at Peer 2 or because Peer 2 has is not configured to share active content with the recipient peer 120. In another embodiment, the chat module 210 does not display received active content information because, for example, the recipient peer 120 is not capable of receiving an active content stream, or not capable of activating streamed content.
The representation of Peer 3 includes an icon indicating that the active content 432 at Peer 3 is a movie titled “The Third Man,” and that this movie is available for purchase. In response to selecting the icon, the chat module 210 initiates a transaction as described below.
An advantage of this embodiment is that users of a peer can see real time active content information of other peers on the network, at least some of which, they may share an interest in the active information.
The application module display 470 further includes an active content display 471 to output the content currently available to a peer. For example, the display can show active video content in response to that same content being displayed on the sender peer's 110 active content display.
The chat module display 460 further includes a representation of Peer 1 and a chat session 462. Peer 1 is preferably a peer having active content compatible with the application module 220. The chat session 462 is disposed within the user interface to allow access to messaging while viewing active content. Advantageously, the peer user need not toggle between application windows when messaging a peer about shared active content.
The content supplement database 520 queries file descriptions to provide the recipient peer 120 with data files related to shared active content or active content that are stored in the content supplement database 520. The data files may be similar to the files stored in the content information database 330 and the content repository 230, or more loosely related to the shared active content such as data files of advertisements. Accordingly, a query for a music artist may return a new book about the artist or their latest CD. The query may use a unique identifier such as a hash key if available. In one embodiment, the content supplement database 520 streams the shared content for the sender peer 110, for example, to reduce the sender peer's 110 load or to control access to shared active content. One form of control is to allow previews of a predetermined time.
The content transaction module 530 facilitates transactions with the recipient peer 120 such as a purchasing active content. The content transaction module 530 includes a database of available products. The products identified by a tag received from the recipient peer 120. The content transaction module 530 receives an order for the product and stores a resulting transaction ticket.
In another embodiment, the content transaction module 530 enables transactions between the recipient peer 120 and third-party retailers. The content transaction module 530 sends queries to several third-party databases according to the third party's application program interface. Based on the results, the content transaction module 530 generates a list of products with hyperlinks to third-party web sites containing the products. The content transaction module 530 also stores each third-party web site impression and click-through from the hyperlink list.
Thus, the recipient peer 120 is able to automatically access supplemental information about shared active content and is easily able to obtain a copy of active content or a related product.
Next, the recipient and sender peers 110, 120 establish 615 a peer-to-peer connection to enable direct communication. Each peer sends a list of contacts or other parameter to the log-in server 510 for identifying preferred peers. The log-in 510 server returns a list of logged-in contacts with network addresses. The log-in server 510 also notifies other relevant peers that new peers have joined the network 145.
The sender peer 110 initiates 611 the application module 220. In one embodiment, the application module 220 and the chat module 210 are integrated into a single application, so both modules are initiated at the same time (e.g.,
The sender peer 110 sends 625 active content information to the recipient peer 120 chat module 210. The recipient peer 120 may display or otherwise output the active content information, or request 616 supplemental information related to the active content from the content enhancement server 130. To check the content enhancement server 130, the recipient peer 120 sends an identifier such as a tag or title.
The content supplement database 520 searches 630 its files using a query based on the identifier for the shared active content. The query may be filtered by additional terms such as only pictures or only advertisements. If a unique identifier of the active content is available, such as a hash key, the query results are more determinative. Otherwise, the content supplement database 520 ranks the query results and sends 636 the supplemental active content information to the recipient peer 120 for display. In one embodiment, the content supplement database 520 saves peer-specific queries to use as parameters in future queries.
In another embodiment, the content supplement database 510 searches third party databases by sending a query using the application programming interface of the outside database. Based on matching the queries to database descriptions, the content enhancement database determines which databases to search. The content supplement database 510 ranks the results and generates a list of hyperlinks corresponding to third party websites containing the results. The content supplement database 510 may additionally store hyperlink impressions or click-throughs from the list.
The recipient peer 120 displays 621 the active content information in its user interface. In one embodiment, the recipient peer 120 may implement local preferences by running a local ranking of the received results or by filtering certain results. The peer may also elect to request a transaction from the with the content enhancement server 130 as discussed with respect to
In response to the sender peer 110 changing 613 active content in the application module 220, the sender peer 110 sends 635 updated active content information to the recipient peer 120. The recipient peer 120 displays 622 updated active content information, or supplemental active content information in the chat module 210 user interface.
The recipient peer 120 sends 716 the identifier to the content enhancement server 130 to query a database in the content transaction database. In the example of a purchase transaction, the database query returns a opportunity to purchase, for example, an MP3 or CD containing a song or a DVD containing a movie. The database query may also send 726 related transaction options such as an option to purchase clothing designed by a queried music artist. The content transaction database ranks the query results and sends a list of transaction opportunities to the recipient peer 120 for display. The results may be displayed as hyperlinks or objects in a java applet.
The recipient peer 120 sends 736 a transaction selection such as a request to purchase a content source to the content transaction module 530 of the content enhancement server 130. In another embodiment, the content transaction module 530 requests further information from the recipient peer 120 user such as payment and shipping information.
Once the transaction terms are completed, the content transaction module 530 sends 746 a request for a transaction confirmation to the user. The transaction is completed when the recipient peer 120 sends 756 a transaction confirmation to the content transaction module 520.
Next, the sender peer 110 and recipient peer 120 negotiate 825 stream parameters such as stream speed. Essentially, the sender peer's server/client module 320 and recipient peer's server/client module 320 provide a direct communication link by exchanging port numbers for the application modules 220. Additionally, the peers may assess local preferences, network 145 traffic load, and bandwidth requirements of the shared active content.
The server/client module 320 in the sender peer 110 synchronously streams the shared active content to the recipient peer 120. The recipient peer 120 determines which application modules 220 are compatible with the file type and initiates an application module 220. In one embodiment, if the file type is compatible with several application module 220s, the recipient peer 120 presents the user with a choice of application module 220s for activating the file.
The recipient peer 120 application module 220 activates the shared active content in the application module 220. The application module 220 may display or otherwise output the shared active content when a minimum amount of data has been received, buffer a certain amount of data, or wait until the entire file has been transferred.
The recipient peer 120 application module 220 sends shared active content information such as a change in display of the file, a change of shared active content, or termination of active content altogether.
In summary, the present invention allows the users of instant messenger to share active content with other users in the system 100, and to facilitate commerce. The chat module 210 uses a robust application and network communication architecture to share active content information with other peers in the system 100. Moreover, the sender peer 110 can send substantially synchronous streams or previews of active content to the recipient peer 120, which automatically activates the stream in a compatible application module 220. Furthermore, the content enhancement server 130 provides preview streams of active content, supplemental active content information, and enables transactions related to shared active content.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US6161132 *||Aug 24, 1999||Dec 12, 2000||Cddb, Inc.||System for synchronizing playback of recordings and display by networked computer systems|
|US6385596 *||Feb 6, 1998||May 7, 2002||Liquid Audio, Inc.||Secure online music distribution system|
|US6519639 *||Jul 21, 1999||Feb 11, 2003||Microsoft Corporation||System and method for activity monitoring and reporting in a computer network|
|US6583806||Apr 7, 1997||Jun 24, 2003||Collaboration Properties, Inc.||Videoconferencing hardware|
|US6629082 *||Jul 6, 1999||Sep 30, 2003||W.R. Hambrecht & Co.||Auction system and method for pricing and allocation during capital formation|
|US6631412 *||Dec 20, 2002||Oct 7, 2003||Microsoft Corporation||System and method for activity monitoring and reporting in a computer network|
|US6697840 *||Feb 29, 2000||Feb 24, 2004||Lucent Technologies Inc.||Presence awareness in collaborative systems|
|US6754904 *||Dec 30, 1999||Jun 22, 2004||America Online, Inc.||Informing network users of television programming viewed by other network users|
|US6757732 *||Mar 16, 2000||Jun 29, 2004||Nortel Networks Limited||Text-based communications over a data network|
|US6772335 *||Dec 6, 2001||Aug 3, 2004||Xerox Corporation||Multimedia coordination system|
|US6865599 *||Sep 3, 2002||Mar 8, 2005||Chenglin Zhang||Browser-to-browser, dom-based, peer-to-peer communication with delta synchronization|
|US6868403 *||Mar 9, 2000||Mar 15, 2005||Microsoft Corporation||Secure online music distribution system|
|US6920478 *||May 2, 2001||Jul 19, 2005||Chikka Pte Ltd.||Method and system for tracking the online status of active users of an internet-based instant messaging system|
|US7062533 *||Sep 20, 2001||Jun 13, 2006||International Business Machines Corporation||Specifying monitored user participation in messaging sessions|
|US7080030 *||Feb 27, 2002||Jul 18, 2006||Digonex Technologies, Inc.||Digital online exchange|
|US7080139 *||Apr 24, 2001||Jul 18, 2006||Fatbubble, Inc||Method and apparatus for selectively sharing and passively tracking communication device experiences|
|US7124164 *||Apr 17, 2001||Oct 17, 2006||Chemtob Helen J||Method and apparatus for providing group interaction via communications networks|
|US7152093||Nov 26, 2003||Dec 19, 2006||Collaboration Properties, Inc.||System for real-time communication between plural users|
|US7171473 *||Nov 9, 2000||Jan 30, 2007||Planet Exchange, Inc.||System using HTTP protocol for maintaining and updating on-line presence information of new user in user table and group table|
|US7188143 *||Jul 2, 2003||Mar 6, 2007||Yahoo! Inc.||Messenger-controlled applications in an instant messaging environment|
|US7203294 *||Aug 6, 2002||Apr 10, 2007||At&T Corp.||System and method for dynamically routing communications|
|US7206809||Nov 26, 2003||Apr 17, 2007||Collaboration Properties, Inc.||Method for real-time communication between plural users|
|US7249147 *||Apr 4, 2003||Jul 24, 2007||Gibson Guitar Corp.||Combination compact disc recorder and player system|
|US7263497 *||Apr 9, 1999||Aug 28, 2007||Microsoft Corporation||Secure online music distribution system|
|US7386798 *||Dec 30, 2002||Jun 10, 2008||Aol Llc||Sharing on-line media experiences|
|US7412470||Sep 8, 2004||Aug 12, 2008||Matsushita Electric Industrial Co., Ltd.||Arithmetic processing apparatus|
|US7433921||Nov 26, 2003||Oct 7, 2008||Avistar Communications Corporation||System for real-time communication between plural users|
|US7519667 *||Apr 16, 2002||Apr 14, 2009||Microsoft Corporation||Method and system for integrating instant messaging, streaming audio and audio playback|
|US20020143944 *||Jan 22, 2002||Oct 3, 2002||Traversat Bernard A.||Advertisements for peer-to-peer computing resources|
|US20020147810 *||Jan 22, 2002||Oct 10, 2002||Traversat Bernard A.||Peer-to-peer resource resolution|
|US20020156893 *||Jun 5, 2002||Oct 24, 2002||Eric Pouyoul||System and method for dynamic, transparent migration of services|
|US20020169893 *||May 9, 2001||Nov 14, 2002||Li-Han Chen||System and method for computer data synchronization|
|US20030041108 *||Aug 22, 2001||Feb 27, 2003||Henrick Robert F.||Enhancement of communications by peer-to-peer collaborative web browsing|
|US20030041141 *||Oct 3, 2002||Feb 27, 2003||Abdelaziz Mohamed M.||Peer-to-peer presence detection|
|US20030078969 *||Oct 19, 2001||Apr 24, 2003||Wavexpress, Inc.||Synchronous control of media in a peer-to-peer network|
|US20030105820 *||May 24, 2002||Jun 5, 2003||Jeffrey Haims||Method and apparatus for facilitating online communication|
|US20030208543 *||Jul 25, 2001||Nov 6, 2003||Noel Enete||Video messaging|
|US20030225834 *||May 31, 2002||Dec 4, 2003||Microsoft Corporation||Systems and methods for sharing dynamic content among a plurality of online co-users|
|US20030225836 *||May 31, 2002||Dec 4, 2003||Oliver Lee||Systems and methods for shared browsing among a plurality of online co-users|
|US20040003090 *||Jun 28, 2002||Jan 1, 2004||Douglas Deeds||Peer-to-peer media sharing|
|US20040019497 *||Dec 4, 2002||Jan 29, 2004||Volk Andrew R.||Method and system for providing listener-requested music over a network|
|US20040039781 *||Aug 16, 2002||Feb 26, 2004||Lavallee David Anthony||Peer-to-peer content sharing method and system|
|US20040054740 *||Apr 7, 2003||Mar 18, 2004||Daigle Brian K.||Extending functionality of instant messaging (IM) systems|
|US20040193680 *||Mar 31, 2003||Sep 30, 2004||Simon Gibbs||Method and apparatus for extending protected content access with peer to peer applications|
|US20040199514 *||Apr 2, 2003||Oct 7, 2004||Ira Rosenblatt||Techniques for facilitating item sharing|
|US20040199663||Jun 18, 2003||Oct 7, 2004||Horvitz Eric J.||Harnessing information about the timing of a user's client-server interactions to enhance messaging and collaboration services|
|US20040205175 *||Mar 11, 2003||Oct 14, 2004||Kammerer Stephen J.||Communications system for monitoring user interactivity|
|US20040215731 *||Jul 2, 2003||Oct 28, 2004||Tzann-En Szeto Christopher||Messenger-controlled applications in an instant messaging environment|
|US20040221299 *||Mar 31, 2003||Nov 4, 2004||Simon Gibbs||Method and apparatus for developing interface protocols for peer to peer applications|
|US20040223485 *||May 6, 2003||Nov 11, 2004||Sbc Knowledge Ventures, L.P.||Adaptive notification delivery in a multi-device environment|
|US20040230659 *||Mar 12, 2004||Nov 18, 2004||Chase Michael John||Systems and methods of media messaging|
|US20040231003 *||Jun 21, 2004||Nov 18, 2004||America Online, Inc., A Delaware Corporation||Informing network users of television programming viewed by other network users|
|US20050005008 *||Jul 29, 2003||Jan 6, 2005||Glasser Daniel S.||System and method for activity monitoring and reporting in a computer network|
|US20050086311 *||Dec 30, 2003||Apr 21, 2005||Noel Enete||Regulating self-disclosure for video messenger|
|US20050108392 *||Nov 19, 2004||May 19, 2005||Microsoft Corporation||System and method for activity monitoring and reporting in a computer network|
|US20050188016 *||Nov 25, 2003||Aug 25, 2005||Subramanyam Vdaygiri||Method and system for off-line, on-line, and instant-message-based multimedia collaboration|
|US20050192874 *||Oct 22, 2004||Sep 1, 2005||First Data Corporation||System for maintaining party and communication point data|
|US20050193094 *||Feb 17, 2005||Sep 1, 2005||Apple Computer, Inc.||Graphical user interface for browsing, searching and presenting media items|
|US20060019702 *||Jul 1, 2002||Jan 26, 2006||Akseli Anttila||System and method for distributing promotion messages to a communication terminal|
|US20060168142 *||Dec 29, 2005||Jul 27, 2006||Juszkiewicz Henry E||Music distribution system|
|US20070097885 *||Dec 18, 2006||May 3, 2007||Traversat Bernard A||Peer-to-Peer Communication Pipes|
|US20070189489 *||Mar 30, 2007||Aug 16, 2007||Carnazza James M||System and method for dynamically routing communications|
|US20080154967 *||Mar 7, 2008||Jun 26, 2008||Aol Llc||Sharing on-line media experiences|
|WO2003050659A2 *||Dec 11, 2002||Jun 19, 2003||Gore Cedric J||Methods and systems for media distributed networking|
|1||*||Ant's Eye View, "Microsoft Aims at Youth With Threedegrees", Feb. 18, 2003.|
|2||International Search Report and Written Opinion, PCT/US04/21516, Apr. 8, 2005.|
|3||*||Joe Wilcox, CNET, "Can Microsoft catch the teen spirit", Feb. 20,2003.|
|4||*||Micrsoft Computer Dictionary Fifth Edition, "definition of virtual device", 2002.|
|5||*||Safari Books Online, used to show publish date of "Microsoft Computer Dictionary, Fifth Edition" Jul. 1, 2008.|
|6||*||Steven Levy, NEWSWEEK, "Microsoft gets a clue from its Kiddie Corps", Feb. 24, 2003.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US8244707 *||Jan 15, 2010||Aug 14, 2012||Hulu Llc||Method and apparatus for providing supplemental video content for third party websites|
|US8301596||Jun 24, 2010||Oct 30, 2012||Hulu Llc||Method and apparatus for providing supplemental video content for third party websites|
|US8661010||Jul 31, 2012||Feb 25, 2014||Hulu, LLC||Method and apparatus for providing supplemental video content for third party websites|
|US8788589||Mar 24, 2010||Jul 22, 2014||Watchitoo, Inc.||System and method for coordinating simultaneous edits of shared digital data|
|US8904009 *||Feb 10, 2012||Dec 2, 2014||Amazon Technologies, Inc.||Dynamic content delivery|
|US9098832||Nov 15, 2005||Aug 4, 2015||Qurio Holdings, Inc.||System and method for recording a photo chat session|
|US9270715||Jun 16, 2014||Feb 23, 2016||Newrow, Inc.||System and method for coordinating display of shared video data|
|US9495338||Jan 28, 2010||Nov 15, 2016||Amazon Technologies, Inc.||Content distribution network|
|US9515949||Oct 24, 2013||Dec 6, 2016||Amazon Technologies, Inc.||Managing content delivery network service providers|
|US9525659||Sep 4, 2012||Dec 20, 2016||Amazon Technologies, Inc.||Request routing utilizing point of presence load information|
|US9544394||Nov 19, 2014||Jan 10, 2017||Amazon Technologies, Inc.||Network resource identification|
|US9571389||Apr 28, 2014||Feb 14, 2017||Amazon Technologies, Inc.||Request routing based on class|
|US9590946||Jan 21, 2016||Mar 7, 2017||Amazon Technologies, Inc.||Managing content delivery network service providers|
|US9608957||Apr 9, 2015||Mar 28, 2017||Amazon Technologies, Inc.||Request routing using network computing components|
|US9621660||Apr 26, 2016||Apr 11, 2017||Amazon Technologies, Inc.||Locality based content distribution|
|US9628554||Dec 1, 2014||Apr 18, 2017||Amazon Technologies, Inc.||Dynamic content delivery|
|US9712325||Jul 15, 2015||Jul 18, 2017||Amazon Technologies, Inc.||Managing secure content in a content delivery network|
|US9712484||Sep 28, 2010||Jul 18, 2017||Amazon Technologies, Inc.||Managing request routing information utilizing client identifiers|
|US9734472||May 19, 2014||Aug 15, 2017||Amazon Technologies, Inc.||Request routing utilizing cost information|
|US9742795||Sep 24, 2015||Aug 22, 2017||Amazon Technologies, Inc.||Mitigating network attacks|
|US20090327917 *||Apr 30, 2008||Dec 31, 2009||Anne Aaron||Sharing of information over a communication network|
|US20090327918 *||Apr 30, 2008||Dec 31, 2009||Anne Aaron||Formatting information for transmission over a communication network|
|US20100138746 *||Jul 20, 2008||Jun 3, 2010||Rony Zarom||System and method for synchronized video sharing|
|US20100174783 *||Mar 24, 2010||Jul 8, 2010||Rony Zarom||System and method for coordinating simultaneous edits of shared digital data|
|US20100318571 *||Jun 16, 2009||Dec 16, 2010||Leah Pearlman||Selective Content Accessibility in a Social Network|
|US20110082902 *||Oct 1, 2009||Apr 7, 2011||Apple Inc.||Systems and methods for providing media pools in a communications network|
|US20110179010 *||Jan 15, 2010||Jul 21, 2011||Hulu Llc||Method and apparatus for providing supplemental video content for third party websites|
|US20110179357 *||Jun 24, 2010||Jul 21, 2011||Hulu Llc||Method and apparatus for providing supplemental video content for third party websites|
|US20120324544 *||Mar 15, 2011||Dec 20, 2012||Dai Kanetomo||Information processing apparatus, terminal apparatus and information processing method|
|US20130151993 *||Oct 24, 2012||Jun 13, 2013||Research In Motion Limited||System and Method for Sharing Electronic News Items|
|US20140324992 *||Apr 28, 2013||Oct 30, 2014||Xiaolong ZHANG||Method and device for prompting to select new file|
|US20150143351 *||Jan 23, 2015||May 21, 2015||Numecent Holdings, Inc.||Streaming from a Media Device|
|WO2014200621A1 *||Apr 25, 2014||Dec 18, 2014||Evernote Corporation||Initializing chat sessions by pointing to content|
|International Classification||H04L12/18, H04L12/58, H04L29/08, G06F15/16|
|Cooperative Classification||H04L67/1068, H04L67/24, H04L69/329, H04L67/1093, H04L67/104, H04L12/1822, H04L12/1813, H04L51/04|
|European Classification||H04L29/08A7, H04L29/08N23, H04L29/08N9P, H04L12/18D2, H04L12/18D, H04L12/58B, H04L29/08N9P2C, H04L29/08N9P8C, H04L51/04|
|Jul 1, 2003||AS||Assignment|
Owner name: APPLE COMPUTER, INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:STOCHOSKY, MICHAEL;REEL/FRAME:014267/0425
Effective date: 20030630
|Jul 18, 2007||AS||Assignment|
Owner name: APPLE INC., CALIFORNIA
Free format text: CHANGE OF NAME;ASSIGNOR:APPLE COMPUTER, INC.;REEL/FRAME:019570/0044
Effective date: 20070109
|Feb 4, 2015||FPAY||Fee payment|
Year of fee payment: 4