Multimedia aggregation in an online social network

Information

  • Patent Grant
  • 9817797
  • Patent Number
    9,817,797
  • Date Filed
    Friday, August 10, 2012
    12 years ago
  • Date Issued
    Tuesday, November 14, 2017
    7 years ago
Abstract
Multimedia content is featured on user pages of an online social network using embed codes that are generated using a configuration file associated with the source ID for the multimedia content and a content ID for the multimedia content. The configuration file, the source ID and the content ID are stored locally by the online social network so that any changes to the embed codes can be made by changing the configuration file associated with the source and regenerating the embed codes. By managing multimedia content in this manner, greater control can be exercised by the online social network over the multimedia content that are featured on its user pages.
Description
FIELD OF THE INVENTION

The present invention generally relates to processing of online social network data, and more particularly, to a method and system for managing multimedia content appearing on user pages of an online social network.


DESCRIPTION OF RELATED ART

Over the past several years, the amount of multimedia content available online has increased dramatically. With access to cheap storage and higher bandwidths, photo sharing sites and video sharing sites have become widely used. Sharing personal photos with families and friends through one of these photo sharing sites is now commonplace. The explosion in video sharing is not so much attributable to the sharing of personal video created by the user but the sharing of video created by another person that the user finds particularly funny, interesting or informative.


Video sharing is often done through e-mail. Typically, after viewing a video, the user inputs e-mail addresses of those persons with whom the user would like to share the video. In response, the video sharing site sends an e-mail to such persons with a hyperlink to the video. The person receiving the e-mail can access the hyperlink to view the video and share the video with other persons in the same manner. Video viewership can increase very rapidly in this manner.


A less intrusive way of sharing video is through a profile or landing page a user maintains at an online social network. When a user finds a video that is particularly funny, interesting or informative, the user features that video on his or her landing page at the online social network. As people visit the user's landing page at the online social network, they can watch the video from the user's landing page although the actual video feed is from a third party source.


As more and more users at online social networks feature videos and other multimedia content on their landing pages, the task of managing them has become a challenge to online social networks. One major reason for the difficulty in managing such multimedia content is that much of it are not stored locally by the online social networks but are streamed from servers that host the multimedia content when they are accessed for viewing


SUMMARY

The present invention provides a method and system for managing multimedia content that appear on various user pages of an online social network. According to embodiments of the present invention, when multimedia content from a third party source is selected by a user to be featured on his or her profile or landing page, source ID and content ID corresponding to the featured multimedia content are stored locally in a database managed by the online social network, and an embed code for accessing the featured multimedia content is generated using the source ID and the content ID. The source ID is an identifier of the third party source of the multimedia content and is associated with a configuration file that is used in generating the embed code. The content ID is an identifier for the multimedia content used by the third party source and is used as an input parameter when generating the embed code with the configuration file.


By managing multimedia content in accordance with embodiments of the present invention, greater control can be exercised by the online social network over the multimedia content that are featured in the landing pages of its users. For example, inappropriate content can be filtered easily by searching for the source ID and content ID corresponding to the inappropriate content and flagging them so that the embed code for such content will not be generated. Blocking an entire site is even easier. It just requires a change to the configuration file corresponding to that site so that a web page displaying a message such as “Access to the URL ****.com is not permitted.” can be generated in place of the embed code. As another example, invalid links that are caused by URL changes implemented by the source of the multimedia content can be fixed easily by making the appropriate correction to such source's configuration file. After the correction is made to the configuration file, all embed codes generated using this configuration, file will have the correct URL.


A first embodiment of the present invention is directed to a method for generating a web page, e.g., a landing page of a user of an online social network, that includes a multimedia section in which multimedia content from a third party source can be displayed. The method includes the steps of receiving a user selection of multimedia content of a third party source that is to be added to the multimedia section, storing a source ID associated with the third party source, storing a content ID associated with the multimedia content, generating an embed code for the multimedia content using the source ID and the content ID, and generating the web page including the multimedia section using the embed code. The embed code may be generated by executing a configuration file associated with the source ID, wherein the configuration file specifies the format of the embed code and the location of the third party source (e.g., its URL) associated with the source ID.


A second embodiment of the present invention is directed to a method for generating a web page for a user of the online social network, e.g., the user's landing page, based on third party multimedia content aggregated by other users of the online social network. The method includes the steps of retrieving source IDs and content IDs of multimedia content aggregated by other users of the online social network, selecting at least one multimedia content aggregated by the other users of the online social network, generating an embed code for the selected multimedia content using its source ID and the content ID, and generating the web page using the embed code. The embed code may be generated by executing a configuration file associated with the source ID, wherein the configuration file specifies the format of the embed code and the location of the third party source associated with the source ID. The multimedia content may be selected based on its popularity with other users of the online social network who are related to the user of the online social network by N degrees of separation or less.


A third embodiment of the present invention is directed to a web server computer for an online social network. The web server computer includes a local database that stores content for a plurality of users of the online social network, the content for each of the users including profile information and pointers to third party multimedia content, and a processing unit that is programmed to generate a landing page for each of the users with the profile information and at least one pointer to third party multimedia content. Each of the pointers to third party multimedia content includes a source ID associated with a source of the third party multimedia content and a content ID associated with the third party multimedia content, and the landing page includes an embed code for the third party multimedia content that is generated using the source ID and the content ID.





BRIEF DESCRIPTION OF THE DRAWINGS

So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.



FIG. 1 is a diagram that graphically represents the relationships between users of an online social network;



FIG. 2 is a block diagram illustrating components of a system for managing an online social network and connections to this system from a third party server and client computers;



FIG. 3 is a schematic illustration of an example of a landing page for a particular user and external content sources for the landing page;



FIG. 4 is a schematic illustration of a user landing page that has been generated in accordance with an embodiment of the present invention;



FIG. 5 is a flow diagram that illustrates the steps carried out to generate a web page that includes embed codes for multimedia content; and



FIG. 6 is a schematic illustration of a user landing page that has been generated in accordance with another embodiment of the present invention.





DESCRIPTION OF PARTICULAR EMBODIMENTS


FIG. 1 is a graph representation of a social network centered on a given individual (ME). Other users of this social network include A-U whose position, relative to ME's, is referred to by the degree of separation between ME and each other user. Friends of ME, which includes A, B, and C, are separated from ME by one degree of separation (1 d/s). A friend of a friend of ME is separated from ME by 2 d/s. As shown, D, E, F, G, and H are each separated from ME by 2 d/s. A friend of a friend of a friend of ME is separated from ME by 3 d/s. FIG. 1 depicts all nodes separated from ME by more than 3 degrees of separation as belonging to the category ALL.


Degrees of separation in a social network are defined relative to an individual. For example, in ME's social network, H and ME are separated by 2 d/s, whereas in G's social network, H and G are separated by only 1 d/s. Accordingly, each individual will have their own set of first, second and third degree relationships.


As those skilled in the art understand, an individual's social network may be extended to include nodes to an Nth degree of separation. As the number of degrees increases beyond three, however, the number of nodes typically grows at an explosive rate and quickly begins to mirror the ALL set.



FIG. 2 is a block diagram illustrating a system 250 for creating and managing an online social network. The system 250 represents one example embodiment of a system for creating and managing an online social network, and includes an application server 251 and one or more graph servers 252. As known in the art, a server is a computer having a processing unit and system memory that is programmed to carry out certain functions. The system 250 is connected to a network 260, e.g., the Internet, and accessible over the network by a plurality of remote computers (only three of which are shown), collectively designated as 270, and a third party server 280 that manage its user database 285 and communicate with the system 250 through an application programming interface (API) 290 provided by the system 250. The system 250 is connected to other third party servers (some of which communicate with the system 250 through APIs provided by the system 250) but, for simplicity, they are not shown in FIG. 2.


The application server 251 manages a user database 254, a relationship database 255, a search database 256, and other databases 257. The user database 254 contains profile information for each of the user in the online social network managed by the system 250. The profile information may include, among other things: a unique user identifier (user ID), name, age, gender, location, hometown, references to image files, listing of interests, attributes, and the like. The user database 254 also contains information about groups (e.g., organizations, school alumni associations, family, etc.) that users have defined. The group information may include, among other things: a unique group identifier (group ID), name, description of the group, and members of the group. The relationship database 255 stores for each user, the user IDs of all users with whom the user has a direct relationship, i.e., direct friends of the user who are users of the online social network. In addition, the contents of the user database 254 are indexed and optimized for search, and stored in the search database 256. The other databases 257 may include a multimedia content database and a database for storing testimonials and various other information commonly stored in online social networks and communities. The user database 254, the relationship database 255, the search database 256, and the other databases 257 are updated to reflect inputs of new user information and edits of existing user information that are made through the remote computers 270.


The application server 251 also manages the information exchange requests that it receives from the remote computers 270 over the Internet. The graph servers 252 receive a query from the application server 251, process the query and return the query results to the application server 251. The graph servers 252 manage a representation of the social network for all users in the member database. The graph servers 252 have a dedicated memory device 253, such as a random access memory (RAM), in which an adjacency list that indicates all first degree relationships in the social network is stored. The graph servers 252 respond to requests from application server 251 to identify relationships and the degree of separation between users of the online social network. The application server 251 is further configured to receive data feeds, e.g., RSS feeds, from a third party server 280 through an application programming interface (API) 290 that third parties may use to send data to the application server 251 for storage in one of the databases managed by the application server 251.


In the embodiments of the present invention described below, users are respectively operating the remote computers 270 that are programmed to execute web browser programs, and access the web pages managed by the application server 251 using the web browser programs. The web pages that are displayed to a user are transmitted from the application server 251 to that user's remote computer and processed by the web browser program stored in that user's remote computer for display through the monitor of that user's remote computer.



FIG. 3 schematically illustrates a web page that functions as a profile or landing page for a particular user in an online social network and external content sources for the landing page. This landing page can be accessed several ways. First, it can be accessed from within the online social network by the user when the user logs into the online social network and navigates to this web page or by other users who clicks on a user ID or an image associated with this user. Second, it can be accessed directly by typing in the associated URL into a web browser. Third, this page may be opened up to web crawlers of search engines and accessed when a user clicks on a search result that is hyperlinked to this page.


The web page shown in FIG. 3 includes multiple sections that contain different categories of content associated with the user. The user's profile information is provided in section 310. A list of the user's friends in the online social network and hyperlinks to their landing pages are provided in section 315. Section 320 displays the user's blog. In this example, the user is maintaining a blog at an external web site 361, e.g., Xanga.com, and the content of his or her blog is supplied from the external web site using an RSS feed. In a similar manner, the content of the user's pictures that is displayed in section 330 is supplied from an external web site 362 (e.g., Flickr) using an RSS feed, and the content of the user's videos that is displayed in section 340 is supplied from an external web site 363 (e.g., YouTube) using an RSS feed.


As a way to minimize the number of times an external web site is accessed for the necessary RSS feeds, all RSS feeds from external web sites are stored in a cache storage unit 350. All RSS feeds are also assigned a minimum lifetime and a maximum lifetime. When a landing page of a user is accessed and the landing page contains sections that rely on RSS feeds, the lifetime of each such RSS feed is checked. If it is below its minimum lifetime, the last cached version of the RSS feed is accessed. If it has exceeded the minimum lifetime, a query is issued to the external web site for the latest information. On a global basis, whenever an RSS feed reaches its maximum lifetime, a query is issued to the external web site for the latest information.


The query that is issued to an external web site for content associated with a user includes the user ID and password of that user as proof that access to the user's account maintained by the external web site is authorized. The user ID and password are provided by the user when the user sets up his or her landing page to retrieve content from external web sites through RSS feeds. The issued query is kept hidden at the user level and preferably encoded or encrypted so that the user ID and password contained in the query can be kept confidential.



FIG. 4 schematically illustrates a user landing page that has been generated in accordance with an embodiment of the present invention. The web page depicted in FIG. 4 is the same as the web page depicted in FIG. 3 except that the user video section is generated differently. In the embodiment of FIG. 4, the videos that are featured in section 440 are not stored in the cache storage unit 350 but are streamed in from an external, third party source. Thus, when a user clicks on a video thumbnail image 441, 442, or 443 to view the video, the video is not supplied from the cache storage unit 350 but is streamed directly from a corresponding one of external video sites 451, 452, 453. The direct streaming from the external video sites 451, 452, 453 is enabled using embed codes having the following general format:


<embed src=“http://videosite.com/vid.swf?id=12345”></embed>.


The embed codes that enable direct streaming from the external video sites 451, 452, 453 are typically made available by the external video sites 451, 452, 453 for pasting into the HTML file corresponding to a user's landing page, such as the one shown in FIG. 4. The process may even be automated so that the embed code is automatically pasted into the HTML file corresponding to a user's landing page. This would occur, for example, when a user visits an external video site, views a video at the external video site, and indicates that he or she would like to add the video to his or her landing page at an online social network.


In the embodiments of the present invention, embed codes for video files are generated from a source ID (which identifies the external source of the video file) and a content ID (which is an identifier of the video file used by the external source) using configuration files having the following general format:


videosite=<embed src=“http://videosite.com/vid.swf?id=% ID %”></embed>.


The parameter “% ID %” signifies a variable field into which the content ID is inserted. The source ID points to the configuration file to use, because different configuration files are provided for different external video sites. For example, each of videosite1, videosite2 and videosite3 has its own configuration file, as shown below:


videosite1=<embed src=“http://videosite1.com/vid.swf?id=% ID %”></embed>


videosite2=<embed src=“http://videosite2.com/vid.swf?id=% ID %”></embed>


videosite3=<embed src=“http://videosite3.com/vid.swf?id=% ID %”></embed>


As an example, if the source ID=“videosite3” and the content ID=“51515” for a video file, the embed code corresponding to that video file would be generated as:


<embed src=“http://videosite3.com/vid.swf?id=51515”></embed>.



FIG. 5 is a flow diagram that illustrates the steps carried out to generate an HTML file that includes embed codes for the user's videos. In the flow diagram of FIG. 5, steps 510-518 are carried out by the server computer of the external video site and steps 520-524 are carried out by the server computer of the online social network. Referring back to FIG. 2, the server computer of the online social network corresponds to the system 250 and the server computer of the external video site corresponds to the third party server 250 connected to a database 285 and configured with an API 290 that is provided by the online social network.


In step 510, the user navigates to an external video site and selects a video for viewing. In response to this selection, the video is streamed to the user's computer and displayed to the user (step 512). The user's display includes a hyperlink “Post to Friendster.” This hyperlink permits the user to feature this video on the user's landing page at the online social network, Friendster. In step 514, the user selects the hyperlink “Post to Friendster.” In response to this selection, the user is prompted in step 516 for user ID and password corresponding to the user's account at the online social network. Upon submission of this information, the external video site transmits this information along with the particulars of the video file, such as the source ID (which identifies the external video site that is hosting the video file) and the content ID (which is an identifier of the video file used by the external video site) to the online social network, and various other data (step 518). Steps 516 and 518 are carried out using the API 290 provided by the online social network.


In step 520, the online social network authenticates the user ID against the password using the information stored in its user database. If the user ID is authenticated, i.e., the password matches the password for the user ID stored in the user database, the particulars of the video file are stored in the multimedia content database of the online social network along with the user ID (step 522). The following table conceptually illustrates the arrangement of the data that is stored in the multimedia content database.

















User
Source
Content





ID
ID
ID
Thumbnail
Tags
Description







William
videosite1
12345
video1.jpg
funny,
A compilation showing a






dogs
number of funny dog tricks.


William
videosite2
12345
video2.jpg
tennis
An incredible shot executed







by Roger Federer.


William
videosite3
51515
video3.jpg
food,
Hot dog eating contest held






contest
in Honolulu, HI in 2006.


Jeff
videosite2
33221
video4.jpg
soccer
A compilation of incredible







soccer moments.









In the table shown above, each row represents data associated with a single video file. “Source ID” indicates the external video site that is hosting this video file and identifies the configuration file to be used in generating the embed code for this video file. “Content ID” indicates the unique ID used by the external video site to identify this video file and is used as an input parameter when generating the embed code for this video file. “Thumbnail” indicates the memory location of the thumbnail image corresponding to this video file. One or more entries under “Tags” indicate descriptive keywords associated with this video file. The entry under “Description” provides a brief description of the content of this video file. The particulars of the video file that are transmitted from the external video site to the online social network are controlled by the API 290.


When a landing page of a user, such as the one shown in FIG. 4, is generated, it is generated from an HTML file corresponding to the landing page that is stored in the cache storage unit 350. This HTML file includes embed codes corresponding to any third party video that is featured by the user in section 440. In step 524, the embed codes corresponding to the featured third party videos are generated and inserted into the HTML file corresponding to user's landing page. During this generation step, the multimedia content database is checked for video file entries associated with the user that has an update flag set (i.e., equal to 1). For all video file entries that meet these conditions, the embed code corresponding to such entries will be generated using a configuration file identified by that entry's source ID and inserted into the HTML file corresponding to the user's landing page. After the generation step is carried out for the user, the update flag of all video file entries of the user is set to 0.


The generation step may be carried out on-the-fly each time the landing page of the user is requested. It is, however, preferable to carry out the generation step according to a predetermined schedule so as to conserve computational resources. For example, the generation step is not carried out when none of the video file entries associated with the user's landing page has an update flag that is equal to 1, but is carried out when there is at least one video file entry with an update flag that is equal to 1.


When a user selects a third party video for viewing from a web page within the online social network (e.g., a landing page of another user or a video search page), the user may watch the third party video at the web page within the online social network without navigating to the third party's web site. When the user does this, a hyperlink “Add to Profile” appears alongside the video display. This hyperlink permits the user to feature the video he or she is watching on the user's landing page. In response to this selection, the source ID, the content ID, and the particulars of this video file are stored in the multimedia content database of the online social network along with the user ID of this user.



FIG. 6 schematically illustrates a user landing page that has been generated in accordance with another embodiment of the present invention. The web page depicted in FIG. 6 is the same as the web page depicted in FIG. 4 except it has an additional section 610 that features one or more videos 611 that have been determined to be popular with other users of the online social network who are related to the user by N degrees of separation or less, where N is typically 1 or 2 but can be any positive integer. The videos 611 that are featured in section 610 are generated in the same manner as the videos that are featured in section 440. The differences between the featured videos in section 610 and the featured videos in section 440 are: (1) the featured location on the landing page, and (2) the decision criteria that are used by the online social network in determining whether or not to feature the video.


In the simplest implementation, a single video is featured in section 610 and this video represents the video that is the most popular with first degree friends of the user (i.e., those users who are one degree of separation away). The popularity may be based on their adoption (most often added to a landing page) or their viewership (most often viewed), or a combination of the two. When two or more videos are featured in section 610, the videos may be featured in the order of their rank with only the top N videos featured (where N can be any plural integer).


In an alternative implementation, a video's popularity with all users of the online social network, up to a predetermined degree of separation (e.g., 2, 3, or N), is considered. In this implementation, the video's popularity with first degree friends may be weighted more than the video's popularity with second degree friends, and the video's popularity with second degree friends may be weighted more than the video's popularity with third degree friends, and so forth.


By managing multimedia content in accordance with embodiments of the present invention described above, greater control can be exercised by the online social network over the multimedia content that are featured in the landing pages of its users. For example, inappropriate multimedia content can be filtered easily by searching for the source ID and content ID corresponding to the inappropriate multimedia content in the multimedia content database and flagging them so that the next time a user page that features such multimedia content is accessed, the embed code for such multimedia content will not be inserted into that user page.


As another example, an entire site can be blocked. Assuming the source ID for the site to be blocked is videosite4, this can be done by modifying the configuration file associated with that site from: videosite4=<embed

  • src=“http://videosite4.com/vid.swf?id=% ID %”></embed> to: videosite4=<p> Access to the URL videosite4.com is not permitted.</p>


Invalid links that are caused by URL changes implemented by the source of the multimedia content also can be fixed easily with the embodiments of the present invention. For example, if the source of the multimedia content (source ID=videosite5) changes the URL for accessing its videos from videosite5.com/vid.swf?id=xxx to videosite5.com/en/v.swf?id=xxx, the configuration file for videosite5 is changed in a similar manner from: videosite5=<embed

  • src=“http://videosite5.com/vid.swf?id=% ID %”></embed> to: videosite5=<embed
  • src=“http://videosite5.com/en/v.swf?id=% ID %”></embed>


After this change is made to the configuration file, all video file entries having source ID=videosite5 will have their update flags set to 1 so as to cause embed codes for all multimedia content from videosite5 to be regenerated when user pages that feature such multimedia content is subsequently accessed.


In the embodiments of the present invention described above, RSS feeds are described as the mechanism for transmitting content between the third party servers and the server computer of the online social network. Other types of web feeds may be employed with the present invention. Some of these examples include atom feeds and feeds based on the SOAP protocol. Also, the embed codes shown above are HTML embed codes. The present invention is, however, not limited to any particular type of embed codes, and may be practiced with embed codes for any markup language for creation of web pages.


In addition, in the embodiments of the present invention described above, video content that includes video and audio is provided as an example of the multimedia content. In general, multimedia is media that uses multiple forms of information content, and multimedia content is media content that includes multiple forms of information content.


While particular embodiments according to the invention have been illustrated and described above, those skilled in the art understand that the invention can take a variety of forms and embodiments within the scope of the appended claims.

Claims
  • 1. A method comprising: receiving, from a remote computer, a search request for a user of an online social network, the search request comprising an identifier associated with the user;determining, by one or more processors associated with one or more servers for the online social network, a match between profile information associated with a first matching user and the identifier of the search request, the profile information being stored in a user database indexed for search;determining, by the one or more processors, one or more secondary matching users in a social graph of the online social network, each secondary matching user being related to the first matching user by N degrees of separation or less, the social graph comprising a plurality of nodes and a plurality of edges connecting the nodes, each of one or more of the nodes being associated with one of a plurality of users of the online social network, each connection between two nodes representing a relationship between the two nodes and establishing a single degree of separation between the two nodes;identifying, by the one or more processors, a plurality of videos shared by users of the online social network selected from the secondary matching users and at least one additional user separate from the secondary matching users;for each of the identified plurality of videos, determining, by the one or more processors, a number of views of the video by the one or more secondary matching users;selecting, by the one or more processors, one or more of the plurality of videos using the number determined for each video;retrieving, by the one or more processors, content information for the first matching user and one or more of the secondary matching users; andsending, to the remote computer, a web page responsive to the search request, the web page comprising the retrieved content information for the first matching user, the retrieved content information for the one or more secondary matching users, and links to the selected one or more videos, wherein the links to the selected one or more videos are arranged within the web page based on relative ranks associated with the selected one or more videos, wherein the rank associated with each of the selected one or more videos is based on the determined number of views of the selected video by the one or more secondary matching users, wherein one of the links is to the video shared by the additional user.
  • 2. The method of claim 1, wherein the content information comprises profile information, group information, multimedia content, social networking content, or any combination thereof,and wherein the web page comprises a landing page for the first matching user, the landing page comprising profile information for the first matching user, information about the one or more secondary matching users, the content information, and social networking information.
  • 3. The method of claim 1, further comprising designating at least one of the selected one or more videos as featured content on the web page.
  • 4. The method of claim 3, wherein designating the at least one of the selected one or more videos as featured content is based on popularity of the particular content with the one or more secondary matching users.
  • 5. The method of claim 4, wherein designating the at least one of the selected one or more videos as featured content comprises weighting the popularity of the selected one or more videos based on a degree of separation between the first matching user and each secondary matching user.
  • 6. The method of claim 1, wherein the links to the selected one or more videos are embed codes.
  • 7. The method of claim 6, wherein each of the embed codes includes a source ID specifying a third-party content source that is external to the social network.
  • 8. The method of claim 1, wherein the identifier of the search request comprises a unique user identifier or a name associated with the user.
  • 9. The method of claim 1, wherein each secondary matching user is further determined based on inputs of new user information or edits of existing user information by the secondary matching user.
  • 10. The method of claim 1, wherein the first matching user is associated with a first item of multimedia content, and wherein each secondary matching user is associated with the first item of multimedia content.
  • 11. The method of claim 10, wherein the retrieved content information for the first matching user and the one or more second matching users comprises the first item of multimedia content.
  • 12. The method of claim 1, wherein the first matching user is associated with a first group identifier, and wherein each secondary matching user is associated with the first group identifier.
  • 13. The method of claim 12, wherein the retrieved content information for the first matching user and the one or more second matching users comprises group information associated with the first group identifier.
  • 14. The method of claim 1, wherein N is one, two, three, or all.
  • 15. The method of claim 1, wherein the web page comprises a search results page comprising one or more search results corresponding to the first matching user and the one or more second matching users.
  • 16. One or more computer-readable non-transitory storage media embodying software operable when executed by one or more computer systems associated with an online social network to: receive, from a remote computer, a search request for a user of the online social network, the search request comprising an identifier associated with the user;determine, by one or more processors associated with the one or more computer systems, a match between profile information associated with a first matching user and the identifier of the search request, the profile information being stored in a user database indexed for search;determine, by the one or more processors, one or more secondary matching users in a social graph of the online social network, each secondary matching user being related to the first matching user by N degrees of separation or less, the social graph comprising a plurality of nodes and a plurality of edges connecting the nodes, each of one or more of the nodes being associated with one of a plurality of users of the online social network, each connection between two nodes representing a relationship between the two nodes and establishing a single degree of separation between the two nodes;identify, by the one or more processors, a plurality of videos shared by users of the online social network selected from the secondary matching users and at least one additional user separate from the secondary matching users;for each of the identified plurality of videos, determine, by the one or more processors, a number of views of the video by the one or more secondary matching users;select, by the one or more processors, one or more of the plurality of videos using the number determined for each video;retrieve, by the one or more processors, content information for the first matching user and one or more of the secondary matching users; andsend, to the remote computer, a web page responsive to the search request, the web page comprising the retrieved content information for the first matching user, the retrieved content information for the one or more secondary matching users, and links to the selected one or more videos, wherein the links to the selected one or more videos are arranged within the web page based on relative ranks associated with the selected one or more videos, wherein the rank associated with each of the selected one or more videos is based on the determined number of views of the selected video by the one or more secondary matching users, wherein one of the links is to the video shared by the additional user.
  • 17. A system comprising: a memory comprising instructions executable by one or more processors associated with one or more servers for an online social network; and the one or more processors coupled to the memory and operable to execute the instructions, the one or more processors being operable when executing the instructions to: receive, from a remote computer, a search request for a user of the online social network, the search request comprising an identifier associated with the user;determine a match between profile information associated with a first matching user and the identifier of the search request, the profile information being stored in a user database indexed for search;determine one or more secondary matching users in a social graph of the online social network, each secondary matching user being related to the first matching user by N degrees of separation or less, the social graph comprising a plurality of nodes and a plurality of edges connecting the nodes, each of one or more of the nodes being associated with one of a plurality of users of the online social network, each connection between two nodes representing a relationship between the two nodes and establishing a single degree of separation between the two nodes;identify a plurality of videos shared by users of the online social network selected from the secondary matching users and at least one additional user separate from the secondary matching users;for each of the identified plurality of videos, determine a number of views of the video by the one or more secondary matching users;select one or more of the plurality of videos using the number determined for each video;retrieve content information for the first matching user and one or more of the secondary matching users; andsend, to the remote computer, a web page responsive to the search request, the web page comprising the retrieved content information for the first matching user, the retrieved content information for the one or more secondary matching users, and links to the selected one or more videos, wherein the links to the selected one or more videos are arranged within the web page based on relative ranks associated with the selected one or more videos, wherein the rank associated with each of the selected one or more videos is based on the determined number of views of the selected video by the one or more secondary matching users, wherein one of the links is to the video shared by the additional user.
RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 12/719,793, filed on Mar. 8, 2010 and titled “Multimedia Aggregation in an Online Social Network,” which is a continuation of U.S. patent application Ser. No. 11/682,678, filed Mar. 6, 2007 and issued as U.S. Pat. No. 7,680,882 on Mar. 16, 2010.

US Referenced Citations (169)
Number Name Date Kind
5708845 Wistendahl Jan 1998 A
5841970 Tabuki Nov 1998 A
6108655 Schleimer et al. Aug 2000 A
6108703 Leighton et al. Aug 2000 A
6125385 Wies Sep 2000 A
6269369 Robertson Jul 2001 B1
6360249 Courts Mar 2002 B1
6484150 Blinn Nov 2002 B1
6641037 Williams Nov 2003 B2
6751778 Broman Jun 2004 B1
6799199 Segal Sep 2004 B1
6925595 Whitledge Aug 2005 B1
6963850 Bezos Nov 2005 B1
7021534 Kiliccote Apr 2006 B1
7068680 Kaltenmark Jun 2006 B1
7069308 Abrams Jun 2006 B2
7069310 Bartholomew Jun 2006 B1
7072683 King Jul 2006 B2
7080139 Briggs Jul 2006 B1
7095871 Jones Aug 2006 B2
7117254 Lunt Oct 2006 B2
7188153 Lunt Mar 2007 B2
7197544 Wang Mar 2007 B2
7200818 Becker Apr 2007 B2
7269590 Hull Sep 2007 B2
7372976 Rhoads May 2008 B2
7594258 Mao Sep 2009 B2
7603615 Lee Oct 2009 B2
7606865 Kumar Oct 2009 B2
7634466 Rose Dec 2009 B2
7636779 Hayashi Dec 2009 B2
7647306 Rose Jan 2010 B2
7680804 Upendran Mar 2010 B2
7680882 Tiu, Jr. Mar 2010 B2
7685198 Xu Mar 2010 B2
7689682 Eldering Mar 2010 B1
7698380 Amidon Apr 2010 B1
7720835 Ward May 2010 B2
7734631 Richardson Jun 2010 B2
7769819 Lerman Aug 2010 B2
7769827 Girouard Aug 2010 B2
7788183 Romney Aug 2010 B2
7788260 Lunt Aug 2010 B2
7801879 Jones Sep 2010 B2
7866000 Lee Jan 2011 B2
7890501 Lunt Feb 2011 B2
7899808 Fisher Mar 2011 B2
7904511 Ryan et al. Mar 2011 B2
7925973 Allaire Apr 2011 B2
7954058 Kalaboukis May 2011 B2
7962948 Girouard Jun 2011 B1
7966369 Briere Jun 2011 B1
8010458 Galbreath Aug 2011 B2
8010460 Work Aug 2011 B2
8015119 Buyukkokten Sep 2011 B2
8055720 He et al. Nov 2011 B2
8060405 Lawrence Nov 2011 B1
8060463 Spiegel Nov 2011 B1
8069414 Hartwig Nov 2011 B2
8086605 Xu Dec 2011 B2
8117545 Rosenbaum Feb 2012 B2
8132103 Chowdhury Mar 2012 B1
8135610 Bryce Mar 2012 B1
8150979 Oldham Apr 2012 B1
8156176 Lerman Apr 2012 B2
8166058 Xu Apr 2012 B2
8190681 Markus May 2012 B2
8209380 Tiu, Jr. Jun 2012 B2
8214457 Tiu, Jr. Jul 2012 B2
8219134 Maharajh Jul 2012 B2
8250616 Davis Aug 2012 B2
8260882 Kim Sep 2012 B2
8307392 Ahanger Nov 2012 B2
8316237 Felsher Nov 2012 B1
8386469 Reuther Feb 2013 B2
8484203 Clancy Jul 2013 B1
8674823 Contario Mar 2014 B1
8781892 Martinez Jul 2014 B2
9445361 Zyren Sep 2016 B2
20020048368 Gardner Apr 2002 A1
20020059201 Work May 2002 A1
20020091770 Takakura Jul 2002 A1
20020103789 Turnbull Aug 2002 A1
20020131561 Gifford Sep 2002 A1
20020138728 Parfenov Sep 2002 A1
20020138843 Samaan Sep 2002 A1
20030014483 Stevenson Jan 2003 A1
20030061294 Stennicke Mar 2003 A1
20030079120 Hearn Apr 2003 A1
20030191828 Ramanathan Oct 2003 A1
20040088325 Elder May 2004 A1
20040215793 Ryan Oct 2004 A1
20050027820 O'Laughlen Feb 2005 A1
20050171955 Hull Aug 2005 A1
20050216300 Appelman Sep 2005 A1
20050222987 Vadon Oct 2005 A1
20060008256 Khedouri Jan 2006 A1
20060021009 Lunt Jan 2006 A1
20060028689 Perry Feb 2006 A1
20060117378 Tam Jun 2006 A1
20060143183 Goldberg Jun 2006 A1
20060167860 Eliashberg Jul 2006 A1
20060200355 Sideman Sep 2006 A1
20060200390 Ananian Sep 2006 A1
20060208844 Kubo Sep 2006 A1
20060242554 Gerace Oct 2006 A1
20060259589 Lerman Nov 2006 A1
20060259982 Upendran Nov 2006 A1
20060294134 Berkhim Dec 2006 A1
20070022437 Gerken Jan 2007 A1
20070038567 Allaire Feb 2007 A1
20070106627 Srivastava May 2007 A1
20070192703 Unz Aug 2007 A1
20070214180 Crawford Sep 2007 A1
20070220092 Heitzeberg Sep 2007 A1
20070220575 Cooper Sep 2007 A1
20070255785 Hayashi Nov 2007 A1
20070266097 Harik Nov 2007 A1
20070270188 Gupta Nov 2007 A1
20080005125 Gaedeke Jan 2008 A1
20080005282 Gaedcke Jan 2008 A1
20080034060 Fisher, Jr. Feb 2008 A1
20080046471 Moore Feb 2008 A1
20080052371 Partovi Feb 2008 A1
20080071883 Alterman Mar 2008 A1
20080071929 Motte Mar 2008 A1
20080082904 Martinez Apr 2008 A1
20080082905 Martinez Apr 2008 A1
20080098032 Wu Apr 2008 A1
20080103879 Armstrong May 2008 A1
20080103907 Maislos May 2008 A1
20080163059 Craner Jul 2008 A1
20080163317 Mills Jul 2008 A1
20080177860 Khedouri Jul 2008 A1
20080189617 Covell Aug 2008 A1
20080195712 Lin Aug 2008 A1
20080208844 Jenkins Aug 2008 A1
20080208963 Eyal Aug 2008 A1
20080209343 Macadaan Aug 2008 A1
20080214180 Cunningham Sep 2008 A1
20080215426 Guldimann Sep 2008 A1
20080222199 Tiu, Jr. Sep 2008 A1
20080222535 Zrike Sep 2008 A1
20080235589 Shaw Sep 2008 A1
20080244038 Martinez Oct 2008 A1
20080244091 Moore Oct 2008 A1
20080271098 Kalaboukis Oct 2008 A1
20080317439 Wong Dec 2008 A1
20090006192 Martinez Jan 2009 A1
20090049122 Wayne Feb 2009 A1
20090063619 Chijiiwa Mar 2009 A1
20090063973 Payton Mar 2009 A1
20090070412 D'Angelo Mar 2009 A1
20090150947 Soderstrom Jun 2009 A1
20090164271 Johnson Jun 2009 A1
20090271247 Karelinh Oct 2009 A1
20090319518 Koudas Dec 2009 A1
20100094728 Denning Apr 2010 A1
20100121707 Goeldi May 2010 A1
20100162375 Tiu, Jr. Jun 2010 A1
20100312644 Borgs Dec 2010 A1
20110055249 Consuegra Mar 2011 A1
20110158605 Bliss Jun 2011 A1
20110289153 Hull et al. Nov 2011 A1
20110295952 Buyukkokten et al. Dec 2011 A1
20120139737 Gross Jun 2012 A1
20120210353 Wong Aug 2012 A1
20120323903 Tiu, Jr. Dec 2012 A1
20140229835 Ravine Aug 2014 A1
Non-Patent Literature Citations (11)
Entry
U.S. Appl. No. 12/719,793, filed Mar. 8, 2010, Tiu, Jr.
U.S. Appl. No. 13/178,271, filed Jul. 7, 2011, Tiu, Jr.
U.S. Appl. No. 13/337,829, filed Dec. 27, 2011, Tiu, Jr.
U.S. Appl. No. 13/338,046, filed Dec. 27, 2011, Tiu, Jr.
U.S. Appl. No. 13/338,115, filed Dec. 27, 2011, Tiu, Jr.
U.S. Appl. No. 13/478,019, filed May 22, 2012, Tiu, Jr.
U.S. Appl. No. 13/595,547, filed Aug. 27, 2012, Tiu, Jr.
U.S. Appl. No. 13/843,776, filed Mar. 15, 2013, Tiu, Jr.
U.S. Appl. No. 13/861,270, filed Apr. 11, 2013, Tiu, Jr.
Hill, W., et al., “Recommending and Evaluating Choices in a Virtual Community of Use,” Proceedings of CHI, http://wwwl.acm.org/sigs/sigchi/chi95/Electronic/documnts/papers/wch—bdy.htm, 1995.
U.S. Appl. No. 13/930,992, filed Jun. 28, 2013, Tiu.
Related Publications (1)
Number Date Country
20120304050 A1 Nov 2012 US
Continuations (2)
Number Date Country
Parent 12719793 Mar 2010 US
Child 13572177 US
Parent 11682678 Mar 2007 US
Child 12719793 US