System and method for social network trust assessment

Information

  • Patent Grant
  • 8739296
  • Patent Number
    8,739,296
  • Date Filed
    Monday, July 30, 2012
    12 years ago
  • Date Issued
    Tuesday, May 27, 2014
    10 years ago
Abstract
A first user's trust level with regard to a second user can be determined by providing questions to the second user, with the questions based on a previously-collected knowledge base including information about the first user. The information about the first user may be partitioned into levels of trust, and the second user's responses to the questions may be evaluated to determine which level of trust the second user is entitled to. The knowledge base may be assembled by prompting the first user for information and/or by scanning or otherwise collecting already-existing data about the first user. The knowledge base and/or trust assessment may be distributed across a network, and in some embodiments the knowledge base or parts thereof is distributed to other users according to the trust level of those users.
Description
FIELD OF THE INVENTION

The present invention relates generally to computer networks, including systems and methods and systems for determining trust between users of devices in such networks.


BACKGROUND OF THE INVENTION

Determining whether or not a user can be trusted remains a persistent problem in computer-related fields. For example, a first user may wish to limit access to content, computer, network, or other resources on the basis of how much the first user trusts potential accessing users. However, the first user may not have the time or resources to personally evaluate or determine the degree of trustworthiness with regard to other users, especially with regard to content or other resources that are made widely available.


Presently-existing systems attempt to provide information to guide user trust assessment. For instance, many systems use community-wide ratings of users such as “reputation” and “karma.” Other systems rely on references, referrals, recommendations, and/or other descriptive indicators to allow users to categorize and evaluate other users.


Data obtained from analyzing social networks may provide another avenue for determining whether or not a user can be trusted. Generally speaking, a “social network” refers to a group of persons or other entities (“members”) linked to one another through one or more types of social connections. Social networks are also commonly referred to as “friend-of-a-friend” networks, although social networks may of course include or consist entirely of entities linked by social connections other than friendship. For example, a social network can include members linked to one another by connections including common friendship, place or field of employment, place of education, place of residence, membership in a club or other group, or common hobbies or topical interests. Many social networking systems attempt to provide computer-based tools for maintaining, enhancing, and creating social networks.


For example, social networking web sites provide users with web space to create a profile and link to various other users designated as “friends.” See, for example, http://www.myspace.com, http://www.facebook.com, and http://www.friendster.com. Users of such sites can post messages and other content to web pages accessible to various parties of their choosing (for example, to “friends only” or to the public at large). Social networking sites may also utilize instant messaging and online chat rooms that allow for near-instantaneous communication between users.


Some presently-existing social network systems implement trust evaluation based on degree of separation. Other presently-existing systems may use combinations of social network analysis and recommendations or reputation functionality.


Computer based systems may provide for some degree of automated user verification, as well. For example, many online services, such as those providing web-based e-mail functionality, allow a user to verify his or her identity in the event of a lost password by answering one or more verification questions.


A need remains for improved methods and systems for trust assessment that may be wholly or partially automated.


SUMMARY OF THE INVENTION

Objects and advantages of the present invention will be apparent to one of skill in the art upon careful review of the disclosure. Such objects and advantages include providing systems and methods for semi- or fully-automated trust assessment.


Embodiments of the presently-disclosed systems and methods for trust assessment allow for a first user's trust level regarding a second user to be determined on a basis specific to both the first and second users, rather than solely on external factors or metrics. The trust assessments are specific for a number of reasons that will be apparent upon further review of the disclosure. Such reasons include the fact that, in the presently-disclosed technology, the trust assessments are based (at least in part) on determining the second user's knowledge about the first user. Additional reasons include the fact that, in the presently-disclosed technology, the trust assessments are based (at least in part) on the second user's own responses, and not solely upon information about the second user provided by third parties.


The remainder of this disclosure refers to various “users.” In this disclosure, a “requesting user” is a user (or other party) that wishes to determine the level of trust that a “target user” holds with regard to a “second user.” In many of the examples discussed herein, the various users are individuals each associated with one or more computing devices. However, the methods and systems disclosed herein are applicable to situations other than those solely involving individuals, and so one of skill in the art should appreciate that a “user” may in fact comprise other entities, including groups of individuals.


A method of determining trust can include receiving a request for a target user's trust level with regard to a second user and accessing trust assessment data from one or more knowledge bases. The request may be received from any entity, including the second user, an entity acting on behalf of the second user, and a third party entity or user interested in the relationship between the target user and the second user. The trust assessment data may include personal data and/or other data specific to the target user, and may be partitioned or divided into categories corresponding to various levels of trust.


Using the trust assessment data, the second user is interrogated with one or more trust assessment questions or prompts. Based on the interrogation results, trust assessment result data is generated and stored in a computer-readable form. The trust assessment data may include a trust level that is computed based on response data received from the second user while the second user is interrogated.


For example, a trust level may be computed by determining if the responses from the second user match stored items about the target user, thereby proving (or disproving) that the second user knows information about the target user. Based on the second user's responses, the second user can be assigned a trust level corresponding to the level associated with the known information. For example, if each stored item is associated with a trust level, the second user may be assigned the highest trust level assigned to any of the stored items that are matched by the second user's responses. In some embodiments, the trust level associated with the second user may be adjusted, and so assigned trust levels will not always directly correspond to the trust levels in the knowledge base on a one-to-one basis. Furthermore, the second user's responses may be evaluated in multiple ways, including whether their responses are correct/incorrect, but also using more sophisticated analysis and/or matching.


For example, the second user may be prompted to answer a plurality of questions. Each question, for instance, may be associated with a number of points that correspond to a trust level. Alternatively, each answer may provide credit for a certain number of points. The second user's responses to the questions may be scored, in any suitable fashion, for example, using neural networks and/or expert systems. Evaluating the responses to the questions may include giving partial credit depending upon the degree of correctness in the second user's answer(s). The resulting scores may be used in a calculation to determine a trust level. For example, the scores may be summed, averaged, or otherwise manipulated to determine an aggregate score, which is then cross-referenced to a trust level.


In some embodiments, trust assessment sessions may proceed based on information other than data about the target user. For example, at least some trust assessment questions may be based on stored items about a pseudo-target user. The pseudo-target user may comprise a member of the target user's social network, and may be directly designated by the target user. Alternatively, one or more pseudo-target users may be chosen automatically by the system based on user preferences and specifications.


For instance, if a second user cannot correctly identify any information about a target user, the trust assessment process may change so as to include questions about a pseudo-target user drawn from one or more knowledge bases associated with the pseudo-target user. The scoring and/or the trust assessment process may be altered based on the relationship between the target user and the pseudo-target user. For instance, the calculated trust level of the second user with regard to the pseudo-target user may be adjusted, for purposes of the target user, based at least in part on the relationship between the target user and pseudo target user as defined in the data from the social network system.


The trust assessment question(s) or prompt(s) may be generated at the time the request is made. Alternatively or additionally, the trust assessment question(s) or prompts may be specified beforehand and stored in the knowledge base. The knowledge base may contain multiple questions or variants thereof, and interrogating the second user can include presenting all or some of the questions.


The trust assessment session may proceed down multiple alternative paths based on user preferences. For example, multiple knowledge bases may be utilized for generating questions(s) or prompt(s) and determining results. The particular knowledge base that is used may be based on one or more factors, including, for example, classification of the second user into one or more groups, the second user's progress in the trust assessment session, and trust assessment data and metadata regarding prior interactions between the second user and the trust assessment system. Users may be classified by any suitable parameters or combinations of parameters, including, for example, on the basis of the resource or content the second user wishes to access, the second user's relationship to the target user, results of prior trust assessments of the second user by other users, and other prior trust assessment activity by the second user.


For example, certain second users may be subjected to one type of trust assessment session with different questions and requirements for achieving trust levels, while certain other second users are subjected to another type of trust assessment session. Similarly, the knowledge base used and/or trust assessment session progress may be changed, for example, for a second user based on the second user's responses and other interaction (question response time, trust level progression, etc.) with the trust assessment system.


The method can further comprise interaction with the target user. For example, in some embodiments, the method includes sending one or more messages to the target user about the trust assessment session. The target user may be provided with the trust assessment result data including the computed trust level. The method may further include modifying the trust level based on feedback from the target user. For instance, the target user may recognize the second user upon receipt of the notification message and adjust the trust level upward or downward from the computed level. In other embodiments, the target user may steer or otherwise direct the trust assessment session(s) while such session(s) are in progress. For example, the target user may specify a certain line of questioning and/or knowledge base to be used in an ongoing trust assessment session.


The trust assessment request may include at least one result address and one or more exit criteria. The exit criteria may specify conditions or results that should be met or otherwise considered during the trust assessment session. For example, the exit criteria may specify a minimal trust level. Once the computed trust level for the second user meets or exceeds the minimal trust level, the session may be discontinued. As a further example, the exit criteria may specify a time limit for responses to interrogation. For instance, if the second user does not answer one or more questions within a specified time limit and/or reach a certain trust level within a specified time limit, the trust assessment session may be discontinued, or the resulting trust level and/or trust assessment result data may be modified to note the occurrence of the time-out.


A trust assessment system can include at least one knowledge base stored in one or more computer readable media, with each knowledge base including a plurality of data items associated with a particular target user, and each data item in each knowledge base associated with a trust level. A trust assessment system may also include at least one computing device including a network interface, the at least one computing device configured to access one or more computer-readable media and execute instructions directing the computing device to perform actions including: receive a trust assessment request, determine, from data included in the trust assessment request, a specified target user and a second user, access a plurality of data items associated with the specified target user, each data item associated with a trust level, interrogate the second user using the accessed data items, receive response data from the second user, determine the extent to which the second user's response data matches at least one data item, and, based on the interrogation results, assign a trust level to the second user based on the trust level associated with the at least one matched data item.


The trust assessment system may comprise a single server or multiple servers. Trust assessment system functionality may be partially or entirely distributed across a network, as well.


A method of assembling a trust assessment knowledge base can include collecting personal information regarding a target user. The information may be collected by prompting the target user and/or by analyzing metadata (and other data) associated with the user. For example, information about a target user may be collected by accessing data stored by one or more social networking systems. The data may be used to determine relationships between the target user and other users and other information about the target user to define information to be included in the knowledge base. For example, collected social network data may include information such as relationship definitions, calculations or other parameters describing relationships (e.g., degrees of separation), relationship history, communication history and frequency, and content sharing history and frequency. Other social network data and metadata may be used, as well.


After or while information is collected, the information may be partitioned into a plurality of trust levels. For example, the target user may be prompted to assign trust levels to the information. Partitioning can include sorting the information into default trust levels based on classification of similar information by users other than the target user. The target user may then accept or alter the default trust levels. One of skill in the art will recognize that “partitioning” refers to logical partitioning and not necessarily physical partitioning:


Assembling the knowledge base can further include associating one or more trust assessment questions with the personal information. The questions can be stored in the knowledge base or in any other suitable form.


Once the knowledge base has been assembled and partitioned into levels, it can be stored in any suitable computer-readable medium. In some embodiments, the data may be distributed to multiple networked computing devices. Each device may maintain all or part of the knowledge base. For example, one device may maintain a first part of the knowledge base while another part of the knowledge base is maintained by another device. The parts of the knowledge base may be mutually exclusive, or may partially or fully overlap. For instance, the portion of the knowledge base containing high-trust-level information may kept at one or more computing devices associated with the target user, while less-sensitive portions of the knowledge base are distributed to other computing devices.


In additional embodiments, a target user's knowledge base may be distributed across one or more social networks including the target user. In some embodiments, the distribution of the knowledge base may be based on the target user's trust level for the various members of the social network receiving the knowledge base. For example, highly-trusted members may be allowed to maintain portions of the knowledge base including high-trust-level data while less-trusted members maintain only low-trust-level data.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

A full and enabling disclosure including the best mode of practicing the appended claims and directed to one of ordinary skill in the art is set forth more particularly in the remainder of the specification. The specification makes reference to the appended figures, in which:



FIG. 1 is a diagram illustrating an example of interactions with an exemplary trust assessment system;



FIG. 2 is a diagram illustrating a second example of interactions with a trust assessment system;



FIG. 3 is a flowchart illustrating exemplary steps performed by a trust assessment system;



FIG. 4 is a flowchart illustrating exemplary steps performed by a trust assessment system in determining a trust level; and



FIG. 5 is a diagram illustrating a plurality of networked computing devices and associated users utilizing a trust assessment system.





Use of like reference numerals in different features is intended to illustrate like or analogous components.


DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Reference will now be made in detail to various and alternative exemplary embodiments and to the accompanying drawings, with like numerals representing substantially identical structural elements. Each example is provided by way of explanation, and not as a limitation. In fact, it will be apparent to those skilled in the art that modifications and variations can be made without departing from the scope or spirit of the disclosure and claims. For instance, features illustrated or described as part of one embodiment may be used on another embodiment to yield a still further embodiment. Thus, it is intended that the present disclosure includes modifications and variations as come within the scope of the appended claims and their equivalents.


The technology discussed herein makes reference to servers, databases, software applications, and other computer-based systems, as well as actions taken and information sent to and from such systems. One of ordinary skill in the art will recognize the inherent flexibility of computer-based systems allows for a great variety of possible configurations, combinations, and divisions of tasks and functionality between and among components. For instance, server processes discussed herein may be implemented using a single server or multiple servers working in combination. Databases and applications may be implemented on a single system or distributed across multiple systems. Distributed components may operate sequentially or in parallel. When data is obtained or accessed between a first and second computer system or component thereof, the actual data may travel between the systems directly or indirectly. For example, if a first computer accesses a file or data from a second computer, the access may involve one or more intermediary computers, proxies, and the like. The actual file or data may move between the computers, or one computer may provide a pointer or metafile that the second computer uses to access the actual data from a computer other than the first computer, for instance.


The present disclosure also makes reference to the relay of communicated data over a network such as the Internet. It should be appreciated that such network communications may also occur over alternative networks such as a dial-in network, a local area network (LAN), wide area network (WAN), public switched telephone network (PSTN), the Internet, intranet or Ethernet type networks and others over any combination of hard-wired or wireless communication links.


The various computer systems discussed herein are not limited to any particular hardware architecture or configuration. Any suitable programming, scripting, or other type of language or combinations of languages may be used to implement the teachings contained herein. Embodiments of the methods and systems set forth herein may be implemented by one or more general-purpose or customized computing devices accessing software instructions rendered in a computer-readable form. Embodiments of the methods and systems set forth herein may also be implemented by hard-wired logic or other circuitry, including, but not limited to application-specific circuits. Of course, combinations of computer-executed software and hard-wired logic may be suitable, as well.


Embodiments of the methods disclosed herein may be executed by one or more suitable computing devices. Such devices may access one or more computer-readable media that embody computer-readable instructions which, when executed by at least one computer, cause the at least one computer to implement one or more embodiments of the methods disclosed herein. Furthermore, components of the presently-disclosed technology, such as knowledge bases and data stores, may be implemented using one or more computer-readable media. Any suitable computer-readable medium or media may be used, including diskettes, drives, and other magnetic-based storage media, optical storage media, including disks (including CD-ROMS, DVD-ROMS, and variants thereof), flash, RAM, ROM, and other memory devices, and the like.


The present disclosure provides several examples of trust assessment with regard to allowing access to content, such as digital photos. However, one of ordinary skill in the art will understand that the principles and teachings contained herein are applicable not only to content sharing, but are also applicable to any other suitable situation in which access to a resource involves a networked computer.



FIG. 1 is a diagram illustrating a plurality of users 18, 20, and 22 and their interactions with an exemplary trust assessment system 10. In this example, trust assessment system 10 includes one or more trust assessment server(s) 12 which may comprise any suitable computing device or combinations of devices. Server(s) 12 have access to computer-readable data stores including one or more knowledge bases 14 and one or more stores 16. Knowledge base 14 comprises a plurality of stored data items regarding a target user, with the data items partitioned or otherwise associated with various levels or degrees of trust. Store 16 includes additional data used in the trust assessment process and user support, including scoring algorithms, trust assessment session transcripts, user classification and interrogation routine handling parameters, access and security parameters, data for interfacing with other systems, and other logs and trust assessment session and system metadata.


Knowledge base 14 and store 16 comprise any suitable computer-readable medium or media, and, in some embodiments, all data is combined and stored in knowledge base 14. As will be discussed in detail below, the trust assessment system 10 may be distributed across multiple computing devices or may comprise a single server. Therefore, knowledge base 14 and store 16 may be located in any location so long as both are accessible to the server(s) 12. Of course, one of skill in the art will recognize that server(s) 12 have access to additional resources including operating systems, system memory, network interfaces, and any other components needed to implement the computer-based systems and methods of the presently-disclosed technology.


Requesting user 18 represents any individual, group, system, or other entity that wishes to obtain information about the relationship between target user 20 and second user 22. Trust assessment system 10 acts in response to trust assessment request 50 and operates to provide requesting user 18 with trust assessment result data 54, the result data including one or more descriptions of the level of trust that target user 20 holds with regard to second user 22.


The level of trust may be determined by trust assessment system 10 via interrogation prompts and responses 56 directed to second user 22 that provide system 10 with a basis for determining the extent of second user 22's knowledge about target user 20. Data about target user 20 stored in knowledge base 14 is partitioned into various levels of trust. By comparing second user 22's knowledge to the data stored in the knowledge base, the trust assessment system can determine a trust level by, for example, matching the trust level for second user 22 to the trust level of the data in the knowledge base. For example, a particular target user 20 may classify items of personal information stored in knowledge base 14 as set forth in the table below:









TABLE 1







Exemplary Data Items from Knowledge Base and


Associated Trust Level










Information about
Associated



User 20
Trust Level







birthplace
Low



pet's name
Medium



location and date
High



of marriage










Trust assessment system 10 may prompt a second user 22 with various questions or other directions to provide information about target user 20. If second user 22 is able to name only the target user's birthplace, the trust level assigned to the second user will be “low.” If second user 22 can name the target user's pet's name, the assigned trust level will be “medium,” while if second user 22 knows the location and date of target user 20's marriage, the assigned trust level will be “high.” As will be discussed below, additional considerations may also impact the final trust level that is assigned to second user 22, and so the trust levels will not always necessarily exactly coincide. Furthermore, one of skill in the art will appreciate that any type and combination of trust level designators may be used, including, but not limited to, textual classifiers and numerical levels.


As is the case with requesting user 18, target user 20 and second user 22 may each comprise an individual, group, or other entity. Furthermore, the respective roles of the users may overlap in certain circumstances—for example, either of target user 20 or second user 22 may also have reason to inquire as to target user 20's trust level of second user 22 and thereby function as the “requesting user.” For example, requesting user 18 could be an entity interested in whether a target group trusts an individual or another group. User 18 may comprise a group or another entity. As will be discussed below, user 18 may alternatively comprise a computer system controlling access to content or other network resources.


Requesting user 18 provides one or more trust assessment requests 50 to trust assessment system 10. A trust assessment request includes at least a specification of a target user and a second user, but may include multiple target users and/or multiple second users. Furthermore, a trust assessment request may contain additional information. For example, the trust assessment request may further specify exit criteria that must be met during the trust assessment session. Depending upon the exit criteria, the trust assessment result data 54 and/or the interrogation process may be altered. Request 50 may further include network addresses, such as uniform resource locators (URLs), IP addresses, e-mail addresses, and/or other designators. In one embodiment, request 50 includes a result URL and a completion URL, with the result URL directing where trust assessment system 10 sends the trust assessment result data and the completion URL specifying where trust assessment system 10 sends second user 22 after trust assessment is complete. Although FIG. 1 depicts trust assessment result data 54 returning only to requesting user 18, the data may be returned to other users, systems, or entities in addition to or other than requesting user 18.



FIG. 1 also illustrates connection 52 between trust assessment system 10 and target user 20. In some embodiments, trust assessment system 10 may be configured to provide one or more messages or notifications to target user 20 about the trust assessment session. For example, target user 20 may receive an email, instant message, or other notification of the trust assessment session progress and the identity of second user 22. Target user 20 may be provided with the trust level that is determined by trust assessment system 10 and may adjust the assigned trust level upward or downward. Trust assessment system 10 may also provide functionality for target user 20 to log in to the system or otherwise view and adjust determined trust levels for various second users. For example, if a target user 20 determines a second user 22 is untrustworthy, the target user 20 may log in to the system and manually adjust second user 22's trust level downward.


Connection 52 may also represent feedback provided to a target user 20 while the interrogation of second user 22 is in progress. For example, the target user may specify one or more events that trigger target user 20's involvement in the trust assessment process as it occurs. The degree of involvement can vary from observation to direct interaction in the trust assessment process. For example, the target user may be able to suspend the trust assessment session and contact the second user directly, if desired. Alternatively, the target user may be able to guide the selection of questions, scoring of questions, calculation of trust level, and other aspects of the interrogation and overall trust assessment process.


Observation/guidance of trust assessments may be carried out via messages exchanged between the target user and trust assessment system over connection 52, such as IM, SMS, and the like. Alternatively or additionally, connection 52 may represent one or more other connections between the target user and trust assessment system. For example, server(s) 12 (and/or other devices associated with the trust assessment system) may provide login functionality whereby a target user can access web pages or other renderings of one or more trust assessment sessions in progress. For example, the page may show trust assessment transcripts, question scores/and or trust levels, and options for tuning the trust assessment process and results.



FIG. 2 illustrates an exemplary system that utilizes trust assessment system 10 in the context of content distribution. Second user 22 may wish to use content sharing system 23 to access content produced by or otherwise under the control of target user 20 (not shown). For example, content sharing system 23 may comprise a peer-to-peer (P2P), centralized, hybrid P2P, or other system for sharing digital assets, including, for example, user photographs. Target user 20 may have provided digital photographs for sharing via content sharing system 23 subject to controls or limitations on distribution based on levels of trust. Accordingly, when content sharing system 23 receives second user 22's request 60 for content, content sharing system 23 acts as a requesting user and sends a trust assessment request 50 to trust assessment system 10. Trust assessment system 10 may be an entirely separate service, but may alternatively be partially or wholly incorporated into the content sharing system 23. Second user 22 is interrogated at 56 by prompts and/or questions in a manner specified by target user 20. In this example, the interrogation is carried out by trust assessment system 10 via content sharing system 23. For example, content sharing system 23 may act as a proxy for trust assessment system 10 in all or some parts of the trust assessment session. Alternatively, trust assessment system 10 may connect directly to second user 22 for all or part of the interrogation session.


In any event, trust assessment system 10 determines target user 20's level of trust with regard to second user 22 and provides trust assessment result data 54 to content sharing system 23. Based on the trust assessment result data 54, content sharing system 23 may then provide content to second user 22 as shown at 62. If the trust assessment result data indicates that second user 22 is not sufficiently trusted by target user 20, no content may be provided, for example. The particular handling and actions taken upon receipt of trust assessment result data will vary according to the system or other recipient of such data, and examples included herein that detail actions taken based on trust assessment result data are not intended to be limiting.


Exemplary trust assessment sessions and additional activities performed in an exemplary trust assessment system will now be discussed using FIGS. 1-2 in conjunction with the flowcharts of FIGS. 3-4.



FIG. 3 is a flowchart illustrating exemplary steps in an initial process carried out by a trust assessment system such as trust assessment system 10 upon receipt of a trust assessment request. Initially, at step 100, one or more trust assessment requests 50 are received by the trust assessment system. The trust assessment request preferably contains data identifying a target user 20 and a second user 22. The request may further include network addresses for providing trust assessment result data and/or data to be used in redirecting second user 22 after the trust assessment is completed. Furthermore, request 50 may also include various exit criteria or parameters that influence the trust assessment process, as will be discussed in detail below.


At step 102, based on the identification of second user 22, the system may first check to see if a trust assessment level or other data is already available with regard to target user 20's trust level of second user 22. Trust assessment result data from previous sessions may be stored by trust assessment system 10, which may advantageously avoid subjecting second user 22 to repeated trust assessment sessions. However, previously-determined trust assessment results may be unsuitable for a variety of reasons. For example, a prior trust assessment may be out of date or applicable in one context but not another. Accordingly, at step 102, the trust assessment system validates any previously-available trust assessment data for the user 20/user 22 pair. If such data is available and suitable for use, then at step 106 the data may be provided as trust assessment result data 54.


Stored records of past trust assessment sessions may be advantageous in situations in which a second user has previously undergone trust assessment. For example, a second user 22 may have undergone a trust assessment session with regard to a target user 20 and achieved a certain level of trust adequate for prior interaction. However, sometime after that, second user 22 may undertake activity that requires a higher trust level. Trust assessment system 10 may include support for such situations by allowing second user 22 to resume a previous trust assessment session or otherwise receive “credit” for a previously-achieved trust level by skipping ahead in the trust assessment process. Trust assessment system 10 may maintain audit records, trust assessment session transcripts, and other data in addition to stored records of trust levels and use any or all of such data to determine the starting point for second user 22. In some embodiments, when determining a target user's trust level of a second user, the trust assessment system may rely at least in part on prior trust assessment results from other target users with regard to that second user. Examples of such embodiments will be discussed later in this disclosure.


The second user may be identified to the trust assessment system in any suitable fashion. For example, the trust assessment system may support login or other identification schemes for second users. Alternatively, session identifiers such as cookies may be set so that the trust assessment system can “recognize” a second user for trust assessment purposes without necessarily identifying the second user.


Validation parameters for validating prior trust assessment results may be set by target user 20 (or other administrative users) in any suitable fashion. For example, the trust assessment system 10 may provide configuration settings that allow target user 20 to specify time periods during which results will remain valid, and/or to specify how to handle partial trust assessment session results. Alternatively, target user 20 may specify result validation parameters as part of interacting with systems such as content sharing system 23 that utilize trust assessment system 10. For example, content sharing system 23 may be configurable such that parameters reflective of target user 20's preferences are included as part of trust assessment request 50 sent by content sharing system 23.


However, if a valid trust assessment level (or other data) is not found at step 102, then at step 104 a trust assessment session is initiated with second user 22. Based on the results of the trust assessment session, trust assessment result data 54 is then provided at step 106. Additionally, the newly-generated trust assessment result data may be stored and associated with second user 22 for possible use in later trust assessment situations.



FIG. 4 is a flowchart showing exemplary steps in a trust assessment session. Trust assessment system 10 establishes a connection with second user 22 over a secure communication channel to begin interrogating second user 22. For example, trust assessment system 10 may be configured to interact with second user 22 through a secure HTTP session using a web browser. Of course, in alternative embodiments, any other types of communication channels could be used. At step 200, the trust assessment system provides one or more questions and/or prompts to second user 22, with the question(s) and/or prompt(s) associated with information about target user 20 stored in knowledge base 14. The initial question(s) and/or prompt(s) may be selected by assigning a baseline trust level to second user 22. In some circumstances, the baseline trust level may be zero or some other indicator for a second user who has no valid trust level at the beginning of the session. However, as discussed elsewhere in this disclosure, the trust assessment system may provide for users who have undergone previous trust assessment sessions to start out at another level, such as a previously-achieved level.


The number of question(s) or prompt(s) may be varied and any suitable type or format may be used. For example, the system may use multiple choice questions, true-or-false questions, fill-in-the-blank questions, matching questions, or combinations thereof. Alternatively or additionally, the trust assessment session may include a prompt and a text area instructing second user 22 to type or otherwise input whatever information second user 22 knows about target user 20. Multiple choice questions may be specified in any form, including those where there is one correct answer, no correct answer (i.e. the “right” answer is “none of the above”) and those in which there are multiple correct answers.


The order in which questions are presented may be varied. In some embodiments, the order of questioning is based on the trust level of the associated information, for example, moving from lower trust levels to higher trust levels. Alternatively, the order of questioning may be randomized. Each trust level may have one or more questions, and depending upon target user preferences, all or some of the questions may be required before the second user can advance to another trust level. Additionally, each item of information may have several alternative question forms. In additional embodiments, the order in which questions are presented may be varied as part of event-based path selections as the interrogation proceeds, as will be discussed later in this disclosure.


At step 202, the system awaits a response from second user 22. As was mentioned above, request 50 may include one or more exit criteria including a time limit for responses. Use of a time limit is optional, but may be advantageous in certain contexts. Given enough time, an interrogated user could conceivably circumvent portions of the trust assessment process, for example by researching a target user via internet searches, user profiles, and other information services. Use of a time limit may prevent interrogated users such as second user 22 from accessing outside resources in order to answer questions about target users. For example, a target user or content sharing system employed by a target user may share content on the basis of user trust levels and specify that a requisite trust level must be reached and/or trust assessment questions are answered within time frame included in request 50. Alternatively or additionally, such a time limit or time limits may be specified by a target user during setup of trust assessment system 10.


If the time limit or limits are not met at step 202, then at step 203 the trust assessment session enters a time-out state. The end result of a time-out may include invalidating or discounting the value of the second user's answer(s) and/or ending the trust assessment session entirely.


Assuming a response is received in time, the response is evaluated at step 204 by comparing the second user 22's response data to the knowledge base data about target user 20. For example, second user 22's response may be checked against the knowledge base to determine whether or not it is appropriate to the question that was presented. The required degree of precision may be varied according to the target user's preferences and the question or prompt type. For example, the trust assessment system may require an exact match for multiple choice or true-or-false question types, but may allow for “close” answers to fill-in-the-blank questions or freeform responses. Fill-in-the-blank answers, freeform response, and other response types may be evaluated using expert systems, for example, to determine how “correct” the responses are. At step 205, the system may address the consequences of an “incorrect” response. This may include adjusting the trust level, presenting a different question, or ending the trust assessment session entirely.


Based on the evaluation, at step 206 the trust level for second user 22 is adjusted to the appropriate level. The trust level for second user 22 may be set to an initial default level and adjusted upward (or downward) based on the evaluated responses. In the most basic embodiment, if second user 22's response matches information associated with a particular trust level, second user 22 is assigned the trust level associated with the matched information. However, variations and adjustments may be introduced, including averaging, weighing, or otherwise considering response results for multiple questions at the same trust level, response times, number of tries, and other factors. If second user 22 is unsuccessful in answering any trust assessment questions or does not complete the session, the assigned trust level may be “zero,” “NULL,” or some other appropriate indicator of a failed trust assessment. Although not discussed in detail herein, the system could support negative trust levels, for example, in the case of gross mismatches in answers.


Step 208 represents another alternative action which may be included in a trust assessment session utilizing exit criteria. Exit criteria included in request 50 may include a target trust level for the trust assessment session. For example, a target user 20 sharing content in system 23 may utilize a trust scale ranging from a minimum of (0) to a maximum of (V) and set a minimal trust level of (II) to access certain resources. In this case, target user 20 is not concerned whether a user has a trust level of (III), (IV), or (V), so long as the level is not (0) or (I). Accordingly, at step 208, the system checks to see if the specified minimal trust level has been met. In this example, the trust assessment question(s)/prompt(s) are presented on a level-by-level basis, and so if the minimal trust level has not been met, the process loops back to step 200. If the minimal trust level has been met or exceeded, however, the system progresses to step 210. Specifying an exit trust level is that the system avoids revealing trust questions at levels higher than required. Such a feature may be especially advantageous with regard to high-trust-level questions, where even the question may provide clues that could later be used to circumvent the system. The target trust level may comprise a minimum or even maximum level, range of levels, or any other suitable specification of conditions. Trust levels may be designated in any suitable manner, including alphanumeric levels, scores or ranges, grades, colors, descriptive identifiers, and so on.


Although presented in these examples as an iterative process, the trust assessment session may comprise other formats, as well. For example, questions pertaining to a plurality of different trust levels, or all questions for an entire session may be presented at once. As noted above, a freeform response may be prompted and analyzed in place of one or more questions for determining whether a user meets one or more levels of trust.


In some of the examples above, a specific trust level is associated with an item of information and, if the item of information is shown to be known to the second user, the second user is assigned the trust level. However, trust levels may be determined in other ways as well. For example, the trust assessment questions may be scored and the collective scores analyzed to determine the degree of trust. For example, the scores for each question may be added into a lump sum, with different trust levels specified as ranges (e.g. “low”: 0-33; “medium”: 34-66; “high”: 66-100; “highest”: 100 and above). Ranges may overlap, of course.


In embodiments utilizing aggregated (or otherwise-calculated) scores, each item of information about the target user can be associated with a particular number of points or other indicators of trust level. For example, some questions, such as high-trust-level questions, could be worth more points than others, such as low-trust-level questions. Additionally, the system may be configured such that scoring of questions could provide for partial credit. For instance, if a second user can specify some, but not all, of a target user's address correctly, the second user may receive partial credit for the question depending upon the accuracy of the answer. The system may score questions using artificial intelligence, such as neural networks and expert systems. As a further example, certain answer selections may be worth more points than others.


Trust assessment system 10 may provide as much or as little feedback as desired to second user 22 before, during, and after a trust assessment session. For example, in some embodiments, second user 22 is given no indication of either the required trust level to access a resource or the adequacy of his answers during the trust assessment process. In other embodiments, second user 22 may be provided an indication of the trust level required to access a resource and/or second user 22's current trust level (if any). Although second user 22 may be given feedback during the trust assessment process (such as indicators of progress in trust level or indicators of whether an answer is right, wrong, or close), such feedback could aid in circumventing the system through research and/or skilled guessing and accordingly may not be preferable in some circumstances.


Once a trust level has been determined, the trust level can be included in trust assessment result data that is provided at step 210 in accordance with the request, for example, by providing the data to a specified computing device. The trust assessment data may further include additional information such as trust assessment session metadata and/or responses to any other inquiries included with the trust assessment requests.



FIG. 1 illustrates an exemplary trust assessment system 10 comprising one or more servers 12 with access to data stores including one or more knowledge bases 14 along with additional store(s) 16 including trust level identifiers, system information, and session transcripts. One of skill in the art will appreciate that the physical and logical arrangement of data created, stored, and otherwise used by trust assessment system 10 may be varied. For example, all data used by the system may be stored in a single combined database that is logically divided into multiple data stores, with one store for each user. However, regardless of the data storage layout or architecture, the data in each knowledge base 14 stores personal information about a potential target user, with each user's personal information separated into a plurality of trust levels by associating each item of information with a trust level identifier.


Knowledge base 14 may be assembled in a variety of ways. For example, trust assessment system 10 may assist each target user 20 in developing a knowledge base. Using, for instance, wizards, expert systems, or other AI (artificial intelligence) routines, trust assessment system 10 may prompt target user 20 for personal information across various common topics. For example, the system may provide questions such as: “What is your mother's maiden name?”; “What is your occupation?”; “What is your address?”; and so forth. Information provided in response to such common-topic prompts may be associated with default trust levels, for example, by analyzing the trust levels assigned to that information by other target users.


Alternatively, a target user may also provide personal information other than that associated with common topics. For instance, as part of the knowledge base assembly process, the target user may be given the option to enter in other user-generated information. Uncommon information may be especially useful for target users who wish to prevent educated guessing, for example, by specifying highly idiosyncratic information for use in very high trust level situations.


Another alternative information gathering strategy includes scanning metadata. The trust assessment system may utilize any source or combination of sources to obtain user, system, and/or content metadata. For example, trust assessment system 10 may access devices or computer system resources (such as user and system logs) associated with the target user to help identify topics and information related to the target user. The information scanned may include content play lists, web browsing history, call logs, IM or other communication transcripts, and the like. For example, if the trust assessment system is incorporated as a component in a content sharing system, the trust assessment system may monitor message traffic between users. The gathered/scanned information may be processed into any suitable format and presented to the target user for verification and alteration, if desired. For instance, if the metadata scan includes analyzing music playlists, the trust assessment system may determine a target user's supposed favorite song and present the system's “guess” for confirmation before inclusion in the knowledge base for the target user.


A still further source of knowledge base information may be found in a target user's social network. For example, a target user's knowledge base may comprise information about the target user's social network. Such information may be entered by the target user; alternatively or additionally, trust assessment system 10 may access a social network system to obtain relationship data and other information (such as profiles) about a target user's friends, relatives, co-workers, and other contacts. Of course, trust assessment system 10 may be implemented as a portion of a social network system as well and may be able to access such information without interfacing with an external resource. In any event, data about the target user's social network may provide a wealth of information, especially for automatically-generated questions.


For instance, trust assessment system 10 may automatically generate a trust assessment question such as “Who is [the target user]'s closest friend?”, with the answer being determined based on analyzing degrees of separation, amount of content shared within the social network, frequency of communication, and so on. The particulars of how the trust assessment system defines such questions and defines the “correct” answers may be specified by the target user as rule sets, preferences, and other parameters. Continuing with the above example, a target user may specify to the system that the “closest” friend may be defined on the basis of content sharing or distance in a social network, and provide that multiple users may meet such criteria (i.e., more than one ‘correct’ answer).


After the information for inclusion in the knowledge base is obtained, it is then separated into various trust levels by target user 20. For example, information based on common topic prompts may be presented alongside “default” trust levels, with target user 20 being given the option to adjust the default level. Trust levels may be specified in any suitable manner, including textual identifiers and numerical scales. In some embodiments, if a target user opts to rearrange levels of certain information, trust assessment system 10 may automatically suggest moving related information.


An optional part of assembling a knowledge base regarding a target user can include generating and associating one or more trust assessment questions for use in the interrogation process. For example, for information provided by a target user that is not a common topic, the target user may be prompted to specify one or more questions that are then stored and associated with the information. Similarly, common topic information and information generated by trust assessment system scans of metadata may be associated with one or more questions. Target users may be presented with the proposed question(s) to allow or disallow use of particular questions or to edit, format, and otherwise alter question text. Target users may also specify their own versions of questions.


In some embodiments, all or some of the questions associated with a target user's information may be generated at the time of a trust assessment session. Similarly, the knowledge base may be updated based on scanned metadata at the time of a trust assessment session and/or at regular intervals to ensure that automatically-generated questions are based on the most current information about the target user, for example.


The trust assessment system may be customized to allow for different interrogation options depending on various parameters. For example, a target user may specify that certain knowledge base information is used to interrogate a first class of second users while different knowledge base information is used to interrogate another class of second users, and so forth. Additionally, the mode or progression of the interrogation and/or response requirements may be varied by user class and/or other parameters. As one of skill in the art will appreciate, second users may be divided into numerous different classes on the basis of numerous parameters and combinations thereof. Generally speaking, the various interrogation questions, paths, and other definitions of the interrogation process may be mapped to user classification parameters as part of the setup process with the target user. The mappings may be stored in any suitable location, including additional store 16 and associated with respective portions of knowledge base 14. Upon receipt of a trust assessment request including a specified parameter, trust assessment server(s) 12 may access the mappings to determine the manner in which the interrogation should proceed. Additionally, in some embodiments, trust assessment session metadata may be monitored by the system to adapt the trust assessment session as it is proceeding (for example, to change the interrogation based on context parameters as discussed below).


For example, a second user may be placed into a class based on the content or other resource that the second user is attempting to access. Certain questions may be keyed to the content—for instance, the target user may specify knowledge base data and interrogation questions so as to quiz second users about the content of camping trip photos or other information that would only be known to a person who participated in the camping trip. The target user can then appropriately configure the content sharing system with data identifying the subject photos as “camping photos.” When a second user requests camping trip photos, the subject matter of the requested content may be relayed as a parameter (such as content=“camping photos”) with the trust assessment request or may be otherwise indicated to the trust assessment system. Based on the parameter, the trust assessment server(s) 12 can initiate an interrogation session specific to the “camping photos” knowledge base content.


As a further example, a second user may be placed into a class based on the second user's position and/or role in a social network relative to the target user. For instance, trust assessment server(s) 12 may interact with one or more social network systems to determine the relationship between the target user and the second user. For example, the target user may specify that second users within a certain degree of separation are subjected to a first line of questioning, while second users outside the specified degree of separation are subjected to a second, more detailed line of questioning. As another example, the social network data may be used to classify users. For example, the target user may specify that second users who are “co-workers” are subjected to different questioning than second users who are “family,” and may specify a still different line of questioning for second users who are “friends.” In such embodiments, trust assessment system 10 may include support for identifying second users, for example, by obtaining a user id (or other identity indicator) from the second user in order to access social network data.


As another example, a second user may be placed into a class based on the context of the second user's interrogation. For example, the interrogation process may vary based on time of day, network address of the second user and/or requesting user (if different), network condition (speed, etc.), mode of access, and the like. Rule sets may change based on determining where the second user is relative to the interrogation process, as well. For example, a target user may designate certain questions as leading to different paths depending upon the answer specified. Depending upon the path, the knowledge base used may change, question formats may change, and/or scoring and trust level determination may be altered.


As a further example, the target user may specify that certain questions are “gateway” questions that take precedence over any other progress in the trust assessment session. For example, a target user may specify multiple interrogation paths, such as prompting second users with an initial classification question (such as a selection prompt of “Are you a co-worker or family member?”). Based on the response, second users will then be interrogated based on a “work” knowledge base or a “family” knowledge base. However, regardless of progress within a particular path, the users must answer a particular question (or set of questions, etc.) to achieve a certain trust level.


As yet another example, a second user may be classified based on interrogation results. For instance, if a second user has repeatedly attempted to access a given resource but has failed, the interrogation questions may change. Similarly, interrogation questions may be varied if a user has incorrectly answered one or more questions. For example, if a user answers several questions incorrectly in a first line of questioning, the system may be configured to start another line of questioning to give the second user another chance. However, if the second user's performance does not improve, the interrogation may be discontinued. In a similar manner, when a second user resumes a prior interrogation session (or attempts to begin a new interrogation session), transcripts, results, and other data pertaining to that second user may be accessed to ensure that the trust assessment system does not present the same questions to the second user.


As noted above, the particular knowledge base, question sets, trust level determinations, and other aspects of the trust assessment process may be varied based on circumstances. In some embodiments, the process may be further varied based on utilizing information about users within the target user's social network. For purposes of clarity, such users are referred to herein as “pseudo-target users.” For example, a particular second user may not be particularly knowledgeable about a target user, but may be a close friend of the target user's best friend. Accordingly, in some circumstances, that second user may be entitled to a greater degree of trust than a complete stranger. Trust assessment system 10 may be configured to address such situations by relying at least in part on knowledge base(s) of pseudo-target users (such as the best friend in the example above) for questions.


The degree to which the trust assessment system 10 relies upon pseudo-target user knowledge bases and the treatment of interrogation results derived from such outside knowledge may be specified by the target user. For example, the target user may provide that other knowledge bases may be consulted based on certain contingencies, such as a particular second user completely failing to demonstrate knowledge of information about the target user. As further example, a target user may provide that a second user answer questions about pseudo target users before answering questions about the target user.


Treatment of the results of interrogations based on pseudo-target user information may be varied, as well. For example, a target user may use the pseudo-target user's designated levels or scoring rules. Alternatively, the target user may modify the results based on the relationship between the target user and pseudo-target user. Such relationship information could be derived, for example, by reference to a social network system. For example, assume that a pseudo-target user provides a knowledge base and a set of questions to be scored on a scale from 0 to 100. A second user is interrogated on behalf of a target user using the pseudo-target user's knowledge base and questions and achieves a score of 77. For the pseudo-target user, such a score may correspond to a “high” trust level. However, the target user may discount the score (or amplify the score) based on who the pseudo-target user is. For example, after scoring the questions, the trust assessment system may discount the score by a factor based on the degree of separation between the target user and pseudo-target user so (from the target user's point of view) that the score of 77 corresponds to a “medium” trust level.


Of course, a particular target user may utilize other information from pseudo target users, such as questions, trust assessment interrogation routines and preferences, and the like. Furthermore, a target user may restrict or prohibit the use of any knowledge base or other information from use by outside users. For example, a target user may designate certain portions of a knowledge base as only usable on behalf of close friends, with other portions of the knowledge base off-limits to outsiders entirely.


An additional type of information associated with pseudo-target user that may be utilized includes the pseudo-target user's trust levels of various second users. As was noted above, during trust assessments, second users may be assigned a “zero” trust level in some circumstances, but in other circumstances, a second user may be provided with an initial nonzero trust level. Trust assessment system 10 may be configured to cross-reference determined trust levels and social network information to provide for a second user to receive credit for the trust of pseudo-target users, such as a target user's friends, co-workers, family, and the like.


For example, upon receipt of a trust assessment request regarding a second user, trust assessment server(s) 12 may be configured to initially check certain of a target user's social network contacts for calculated trust levels. Based on the calculated trust levels and the relationship(s) between the target user and the pseudo-target user(s), one or more pseudo-target users' previously-calculated trust level(s) with regard to the second user may be adjusted for purposes of the target user. The target user may provide for such trust levels to be amplified, discounted, or otherwise handled differently, or may provide for no special treatment in such situations.


Trust assessment system 10 may provide additional functionality with regard to a target user's knowledge base. For example, the system may support later alterations and maintenance through allowing a target user to login and adjust trust levels associated with information, add or delete personal information, alter trust assessment questions, and review logs and trust assessment session transcripts. Also, as part of the setup process, trust assessment system 10 may grade or otherwise evaluate the security of information provided by a target user. For example, the system may include analysis routines that indicate to a target user whether or not the target user's information is too general, or if specified answers are too specific for practical use.



FIG. 5 illustrates an exemplary alternative embodiment of a trust assessment system. In this example, the trust assessment system 10 is distributed across a social network including target user 20. Target user 20's social network includes users 24, 26, 28, and 30. FIG. 5 also illustrates a plurality of computing devices associated with several users in the social network. Target user 20 utilizes machine 21, social network user 24 utilizes device 25, social network user 26 utilizes device 27, and social network user 30 utilizes device 31. Social network user 28 may also utilize one or more computing devices for participation in the social network, but his device(s) are not shown. Second user 22 will, of course, interact with the trust assessment system via one or more computing devices (also not shown).



FIG. 5 also illustrates an exemplary embodiment of a social network server 12, denoted in FIG. 5 as server 12-1. Social network server 12-1 has access to knowledge base 14, which, as will be detailed further below, can be distributed to certain of the members of target user 20's social network. As was noted above, social network server 12-1 also has access to other resources including additional store 16 (not shown in FIG. 5); the additional resources may also be distributed across the social network or in any other suitable manner. For example, the trust assessment session transcripts, data defining trust assessment levels and associating target user data items with such levels, interrogation questions, interrogation response evaluation metrics, and the like may be distributed. The distribution of additional store 16 may be wholly independent of the distribution of knowledge base 14; of course, alternatively, portions of store 16, knowledge base 14 and/or any other components holding related data may be distributed together.


Server 12-1 may comprise one or more computing devices that supervise the trust assessment process and interact with second user 22. Furthermore, in the event the requesting user is a different entity from second user 22, server(s) 12-1 may interact with any such requesting user(s). In the example illustrated in FIG. 5, the trust assessment server functionality is provided by one or more separate computing devices 12 that are accessible across the social network. Although shown as connected to device 31, the other devices in the network may each maintain or create one or more direct or indirect paths to device 12.


One of skill in the art will note that server(s) 12-1 may represent a central server, a server proxy, or even server functionality distributed across the social network. For instance, if the members of the social network are participating in file sharing using a P2P application, each computing device such as 21, 25, 31, and 27 may include trust assessment server functionality which determines the level of 20 trust of any outside user (i.e. second user 22) attempting to access P2P network resources. Alternatively, computing devices in the P2P network may access (either directly or indirectly) one or more separate trust assessment servers 12-1 or other P2P network resources acting as servers. However, for ease of illustration, FIG. 5 shows server functionality provided by a separate device.


In the example shown in FIG. 5, knowledge base 14 is distributed across the social network. In this example, knowledge base 14 contains items of information associated with target user 20. However, one of skill in the art will recognize that each member of the social network may have its own knowledge base, with each member's knowledge base distributed accordingly. Computing devices acting as social network server(s) 12-1 interact with requesting users 18 and second users 22. However, server(s) 12-1 may have limited access to the contents of knowledge base 14. For example, users of the system may specify that highly personal/confidential information is to be stored at one or more local machines and not in a central server. Accordingly, each user may maintain a local knowledge base containing at least some, or possibly all, of their personal information. A local instance of all or part of target user 20's knowledge base 14 is illustrated in FIG. 5 at 14a. Distribution of the personal information may advantageously avoid consolidation of personal information and attendant security risks such as identity theft and/or data loss.


For example, target user 20 may specify that high-level personal information is stored at device 21 in knowledge store 14a. However, low-level personal information may be maintained at server 12-1. When interrogating a second user 22, server 12-1 may initially use locally-stored data. If the trust assessment session/interrogation requires access to higher-level data that is not stored locally, server 12-1 may turn to device 21. For example, server 12-1 may initiate a secured link to device 21 to access information needed for higher-level trust assessment. Alternatively, the entire trust assessment session may be handed over to device 21. The handoff may be limited to the high-trust-level assessment, with device 21 returning the trust assessment session to server 12-1 for completion, or may provide for device 21 to complete the trust assessment session and provide the results to server 12 for storage, logging, audit purposes, and the like.


Still further alternative exemplary embodiments distribute server functionality and/or user knowledge bases across the social network. For instance, server 12 may include a limited or reduced knowledge base 14 with regard to user 20 as in the previous example, with user 20 maintaining highly confidential personal data at his local device 21 in knowledge base 14a. However, portions of user 20's knowledge base may be distributed across his social network. For instance, user 20 may trust users 24 and 26 with some, but not all, of user 20's personal information. Accordingly, such information could be stored in knowledge bases 14b and 14d on devices 25 and 27, respectively. User 20 may also trust user 30, and so some of user 20's knowledge base could also be stored in distributed knowledge base component 14c on device 31. The division and distribution of knowledge bases could itself be based on assessed trust levels. Furthermore, the distribution may result in various users maintaining identical portions, partially overlapping portions, or wholly distinct portions of knowledge base 14.


Operation of such a distributed system could proceed as set forth in the examples above with regard to device 21. Server 12-1 may handle part of a trust assessment session and access and/or hand off trust assessment sessions to appropriate distributed components for completion. For example, each level of trust may be handled by a member of the social network having the requisite level of trust, with the trust assessment sessions moving closer to target user 20 as the second user 22's trust level progresses. As an alternative to a complete hand-oft, server 12-1 may coordinate activity among one or more distributed components.


In any of the above-illustrated distributed environments, server 12-1 or any devices acting in that capacity can maintain data specifying the network locations of the distributed resource(s). For instance, the locally-accessible knowledge base 14 may comprise network addresses specifying which machine(s) to access in order to obtain trust assessment questions and data. In some embodiments, server 12-1 may simply act as a gateway and immediately hand off trust assessment and other inquiries regarding trust assessment system 10 (e.g., knowledge base adjustments, audit trails) to another device in the network. The trust assessment system 10 may be further configured so that hand-offs are one way only as the trust assessment session proceeds up the scale of trust levels. Using such a configuration, users associated with particular computing devices could be prevented from determining which devices maintain additional knowledge base items (other than those devices immediately adjacent in network, of course).


Any of the above-discussed embodiments may utilize one or more virtual peers. Generally speaking, the virtual peer(s) may be used to hide the true trust assessment server 12 (12-1) and/or any other computing devices providing trust assessment functionality from interrogated users and requesting users. For example, several users may each maintain respective knowledge bases and conduct trust assessment sessions by way of their respective computing devices. However, the respective computing devices may be interfaced with a single virtual peer such that the requesting and/or interrogated user(s) are not aware of the true device which is conducting the trust assessment session(s) and hosting the knowledge bases. In some such embodiments, trust assessment server 12 (12-1) itself exists only as a virtual peer which, as noted above, hands off trust assessment sessions to the appropriate user computing device(s). Exemplary embodiments of virtual peers are discussed in currently-pending U.S. patent application Ser. Nos. 11/536,868, 11/536,888, and 11/536,912, all filed Sep. 29, 2006 and assigned to Qurio Holdings, Inc.


Additional security measures may be implemented to protect the contents of knowledge base 14 regardless of type or extent of distribution. For example, access to knowledge base 14 may be controlled through use of any suitable security method, such as requiring a digital signature or encryption key for access.


One of skill in the art will recognize that distribution of knowledge base(s) to a computing device will entail the use of one or more applications, processes, etc. running on the computing device. For example, the computing device may receive a process configured to operate as a distributed component of software running on server 12 (12-1). Alternatively, helper applications, processes, and the like may be included as part of a trust assessment client program, for instance, or even an operating system. Alternatively, for embodiments in which the trust assessment system is integrated into one or more communication systems, the helper applications/processes may be incorporated into one or more client applications associated with such system(s). For example, a P2P content sharing system that includes trust assessment functionality may include knowledge base distribution functionality in P2P client applications. Similar functionality may be included in client applications, processes, and components for situations in which trust assessment server 12 (12-1)'s functionality is delegated to other devices.


EXAMPLE

The following scenario is set forth for purposes of illustration and example only. In this example, a target user 20 provides content, such as digital photos, for sharing via a content sharing system such as system 23 illustrated in FIG. 2. In this example, the content sharing system provides previews of shared photos, but allows users to control access to the actual photo by trust level. Although this example refers to server 12, one of skill in the art will recognize that server 12-1 and/or other embodiments of trust assessment server(s) are equally usable, including distributed embodiments.


As an initial matter, target user 20 sets up his trust assessment preferences and knowledge base by logging into the trust assessment system (or, by logging into the content sharing system if the trust assessment system is included as a component therein). Assuming target user 20 has not previously configured a knowledge base, he is then prompted to enter personal information. Exemplary prompts from the trust assessment system and target user 20's answers are listed below:









TABLE 2







Exemplary System Prompts and Target User Responses











Target User



System Prompt
20's Response







What is your place of birth?
Raleigh, NC



What is your birth date?
Feb. 29, 1980



What is your pet's name?
Spot



What is your current address?
1313 Mockingbird Way










After target user 20 has provided personal information, the trust assessment system then prompts target user 20 to classify the information into trust levels. In this exemplary system, the trust levels range from (O-Complete Stranger), (I-Near Stranger), (II-Acquaintance), (III-Friend) up to (IV-Trusted Friend). The system may also include an additional supervisory trust level such as (V-Self). The trust assessment system may suggest trust levels based on other users' classifications. For example, if most users classify the information provided in response to the “address” prompt as (I-Near Stranger), it may suggest that trust level for confirmation. Target user 20's classification results are listed below:









TABLE 3







Exemplary System Prompts, Target User Responses, and Trust Levels










Target User 20's



System Prompt
Response
Trust Level





What is your place of birth?
Raleigh, NC
III—Friend


What is your birth date?
Feb. 29, 1980
II—Acquaintance


What is your pet's name?
Spot
III—Friend


What is your current
1313 Mockingbird Way
I—Near Stranger


address?









The trust assessment system may note that target user 20 has not classified any information that could be used to qualify other users at level (IV-Trusted Friend). Therefore, the system may prompt target user 20 for additional information. In some embodiments, the trust assessment system may prompt target user 20 with suggested questions for trust level (IV-Trusted Friend) based on the type of data other users of the trust assessment system associated with level IV information. Alternatively or additionally; target user 20 may be given the option to provide information that is not based on a pre-generated question or prompt. For instance, in this example, assume that target user 20 specifies his lucky number (forty-two) and associates that item with trust level (IV-Trusted Friend).


The trust assessment system may then generate questions to be associated with each item of information. For the custom information (the lucky number), target user 20 may be prompted to input the question into the system; target user 20 provides for a prompt stating “Enter [target user 20's] lucky number.” Furthermore, target user 20 may input custom questions for each item or alter the pre-generated questions. In some systems, items of information associated with commonly-used information, such as information provided in response to trust assessment system prompts, may rely on pre-generated questions that are accessed at the time of a trust assessment session.


In this example, assume target user 20 specifies that all of his information may be presented as multiple-choice questions except for his “lucky number” question, which must receive an exact textual match and accepts the pre-generated question formatting. Furthermore, target user 20 specifies that his address and birth date must be provided within 30 seconds.


Target user 20's items of personal information are stored as a knowledge base, with the items associated with the specified trust levels and questions. Based on privacy concerns, target user 20 specifies that his knowledge base is not to be stored on the central server, but may be distributed to users based on trust level. Since target user 20 is the only user known to the system at setup time, the trust assessment system uploads target user 20's knowledge base to his local machine and registers data indicating target user 20's network address.


Target user 20 then specifies trust level-based limitations on his shared content. In the content sharing system of this example, the content sharing server controls access to full versions of photos by acting as a proxy for requests for shared content. The content sharing server provides previews of target user 20's photos and screens requests for the full content by trust level. If a user who wishes to view a photo is sufficiently trusted, the user receives a reference to the actual photo. Target user 20 specifies the following settings for three shared photos, with one photo having two different versions:









TABLE 4







Target User 20's Sharing Trust Preferences










Photo File
Required Trust Level







001.jpg
0 (All may access)



002.jpg (full resolution)
III and above



002.jpg (reduced resolution)
II and above



003.jpg
IV and above










With target user 20's knowledge base assembled and trust level parameters associated with his shared content, operation of the exemplary embodiment of the trust assessment system will now be discussed with regard to trust assessments. For instance, target user 20 may participate in a social network such as the one shown in FIG. 5 and comprising target user 20, 24, 26, 28, and 30. Assume that target user 20 notifies social network users 24 and 30 of the shared photos. Each of users 24 and 30 may undergo trust assessment in order to view the shared photos, except for photo “001.jpg,” which requires no trust level for access.


User 30 may wish to view photo “002.jpg” at full resolution. Accordingly, user 30 contacts the content sharing system and requests access. Based on target user 20's sharing preferences, the content sharing system sends a trust assessment request 50-1 to trust assessment server 12. In this example, the trust assessment request includes the following parameters:









TABLE 5







Exemplary Trust Assessment Request 50-1










Request 50-1 Parameter
Value







Target User
user 20



Second User
user 30



Minimal Trust level
III



Result URL
(content sharing system address)



Completion URL
(reference to photo 002.jpg)










Trust assessment server 12 receives request 50-1 and searches previously-stored trust levels for any data regarding target user 20's trust level with regard to user 30. Since no such data is available, the trust assessment server initiates a trust assessment session. User 30 is directed to a secured link with trust assessment server 12. In this example, the trust assessment session is conducted by server 12 initially using data accessed from the distributed knowledge base 14a via a secured link to machine 21 (i.e. user 20's computing device). However, in an alternative embodiment, server 12 may hand off all or part of the trust assessment session to machine 21.


Server 12 initially prompts user 30 to select the correct address for target user 20 from a multiple-choice list. Since target user 20 specified a time limit for this question, if user 30 does not make a selection within 30 seconds, the trust assessment session ends. Assuming user 30 selects “1313 Mockingbird Lane,” trust assessment server increments user 30's trust level to level (I). User 30 is then prompted to select target user 20's date of birth from another multiple-choice list, again with a time limit. If user 30 selects the correct answer, his trust level is incremented to level (II). Then, user 30 is presented with one of the questions corresponding to level (III). In this example, target user 20 has specified that one question is to be selected at random. However, other options could have included presenting both questions and requiring both to be answered correctly, or one of the two to be answered correctly. In this case, the “date of birth” question is presented, and user 30 selects the correct date.


Since trust level (III) is the level required to access the desired resource (photo 002.jpg), user 30 exits the trust assessment process and is redirected to an address to access photo002.jpg. In this example, trust assessment server 12 redirects user 30 based on the redirection data included in the trust assessment request. However, in other embodiments, trust assessment server 12 may return the trust level to the appropriate content sharing system resource(s) and redirect user 30 to the resource(s) so such resource(s) could handle the redirection of user 30 to the content. Additionally, user 30's trust level is stored in a form accessible to trust assessment server 12 for use in later requests (if appropriate). For instance, if target user 20 has not provided for expiration of trust assessment results, user 30 may request content such as photo002.jpg (reduced resolution) without having to undergo trust assessment again.


Additionally, target user 20 has provided that elements of his knowledge base can be distributed to trusted members of his social network. Accordingly, data comprising store 14c is transferred to computing device 31. For example, machine 21 may push data to device 31 over a secure link. Store 14c can contain a portion of target user 20's data items. In this embodiment, store 14c contains all data items at trust level (III) and below. However, in alternate configurations, store 14c could be limited to fewer levels of information.


Sometime later, User 24 may wish to view photo “003.jpg.” Accordingly, user 24 contacts the content sharing system and requests access. Based on target user 20's sharing preferences, the content sharing system sends a trust assessment request 50-2 to trust assessment server 12. In this example, the trust assessment request includes the following parameters:









TABLE 6







Exemplary Trust Assessment Request 50-2










Request 50-2 Parameter
Value







Target User
user 20



Second User
user 24



Minimal Trust Level
IV



Result URL
(content sharing system address)



Completion URL
(reference to photo 003.jpg)










Trust assessment server 12 receives request 50-2 and searches previously-stored trust levels for any data regarding target user 20's trust level with regard to user 24. Since no such data is available, the trust assessment server initiates a trust assessment session. In this example, the trust assessment session is conducted by server 12 initially using data from the distributed knowledge base 14c via a secured link to machine 31 (i.e. user 30's computing device). However, in an alternative embodiment, server 12 may hand off all or part of the trust assessment session to machine 31. If machine 31 is unavailable, server 12 may turn to an alternate resource, such as machine 21 which includes access to store 14a.


Server 12 initially prompts user 24 to select the correct address for target user 20 from a multiple-choice list. As was the case with user 30, since target user 20 specified a time limit for this question, if user 24 does not make a selection within 30 seconds, the trust assessment session ends. Assuming user 24 selects “1313 Mockingbird Lane,” trust assessment server increments user 24's trust level to level (I). User 24 is then prompted to select user 20's date of birth from another multiple-choice list, again with a time limit. If user 24 selects the correct answer, his trust level is incremented to level (II). Then, user 24 is presented with one of the questions corresponding to level (III). As noted above, target user 20 has specified that one question is to be selected at random. In this case, assuming that user 24 is presented with the multiple choice question “[user 20]'s pet's name is: . . . ” and correctly selects “Spot,” user 24's trust level is incremented to level (III).


In this example, store 14c only contains information up to user 30's trust level-that is, store 14c contains none of target user 20's information beyond level (III). Therefore, trust assessment server 12 initiates a secure link to the full store maintained at 14a on machine 21 (Le. target user 20's computing device). Alternatively, the trust assessment session may be handed off in its entirety to machine 21. User 24 is presented with the prompt “Enter [target user 20]'s favorite number.” Assuming user 24 correctly types “42,” his trust level is incremented to level (IV). Since this is the level required to access the desired resource (photo “003.jpg”), user 24 exits the trust assessment process and is redirected to download photo “003.jpg.” Additionally, user 24's trust level is stored in a form accessible to trust assessment server 12 for use in later requests (if appropriate). For instance, if target user 20 has not provided for expiration of trust assessment results, user 24 may request content such as photo002.jpg (full resolution) without having to undergo trust assessment again. Furthermore, all or part of target user 20's data store may be distributed to knowledge store 14b at machine 25 (i.e. user 24's computing device) for future use in trust assessment sessions.


The above example may be modified in any suitable way, including by incorporating additional features, such as those discussed elsewhere in this disclosure. For example, as part of assembling target user 20's knowledge base, trust assessment server(s) 12 may access one or more social network systems and obtain data regarding target user 20's friends, co-workers and other contacts. If such data indicates that user 26 is target user 20's “closest friend,” the designation may be presented for target user 20 for confirmation and inclusion in the knowledge base. Furthermore, target user 20 may designate the “closest friend” question as a gateway question such that no user can obtain a trust level without correctly identifying the answer (i.e. user 26). Additionally, target user 20 may specify parameters for naming one or more pseudo-target users for alternative interrogation scenarios. For instance, continuing with the example above, target user 20 may specify that data about “closest friends” may be used for some or all of the interrogation process. Continuing with the example above, user 26 may be treated as a pseudo-target user for some trust assessments. Accordingly, if user 28, for example, is unknowledgeable about target user 20, user 28 may nonetheless be entitled to some trust from target user 20 (assuming, of course, that user 28 correctly identifies information about target user 20's closest friend, user 26).


Presently-disclosed examples of trust assessment systems and uses thereof are meant for the purposes of illustration only. Various arrangements and configurations of trust assessment systems may be accessed by and/or integrated with other computer-based systems that require determination of a level of trust between users. Trust assessments may be used to control access to the following, which are provided by way of non-limiting example: P2P groups, digital content and other resources, contact information, communications resources, computing devices, and network resources.


It is appreciated by persons skilled in the art that what has been particularly shown and described above is not meant to be limiting, but instead serves to show and teach various exemplary implementations of the present subject matter. As set forth in the attached claims, the scope of the present invention includes both combinations and sub-combinations of various features discussed herein, along with such variations and modifications as would occur to a person of skill in the art.

Claims
  • 1. A system for determining trust, the system comprising: a non-transitory computer-readable media having a first knowledge base and a second knowledge base different from the first knowledge base stored thereon;a computing device having a processor in communication with the knowledge bases, the computing device configured to: receive a request to establish a relationship between a target user and a second user;access trust assessment data including data associated with the target user based on the relationship between the target user and the second user and a plurality of data items where each data item is associated with a trust level, wherein the trust assessment data is selected from either the first knowledge base or the second knowledge base according to the relationship;interrogate the second user, including presenting, to the second user, at least one trust assessment question based on the trust assessment data where the at least one trust assessment question is based on the relationship between the target user and the second user;receive response data from the second user during the interrogation;score the second user's response to the at least one trust assessment question by comparing the response to the trust assessment data corresponding to the at least one trust assessment question;generate trust assessment result data based on the interrogation results, wherein the computing device is configured to score and assign a trust level during generation of the trust assessment result data; andstore the trust assessment result data.
  • 2. The system as set forth in claim 1, wherein the trust assessment data includes a plurality of data items and each data item is associated with a trust level, the computing device further configured to: receive response data from the second user during the interrogation;determine the extent to which the response data matches at least one data item when generating trust assessment result data; andassign a trust level to the second user based on a highest trust level associated with the at least one matched data item.
  • 3. The system as set forth in claim 1, wherein the trust assessment data includes a plurality of data items, each data item associated with a trust level, wherein the computing device is further configured to: provide a plurality of trust assessment questions to the second user and receive response data from the second user during interrogation;score the second user's response to each of the plurality of questions by comparing the response for each question to the trust assessment data corresponding to that question;aggregate the scores; andassign a trust level to the second user based on the aggregated score, wherein the computing device is configured to score, aggregate, and assign a trust level during generation of the trust assessment result data.
  • 4. The system as set forth in claim 1, wherein the computing device is further configured to: access a plurality of stored trust assessment questions;select at least some of the plurality of trust assessment questions; andpresent the selected questions to the second user where the computing device accesses, selects, and presents the selected questions during interrogation.
  • 5. The system as set forth in claim 4, wherein the second user is classified based at least in part on determining a relationship between the second user and the target user where determining the relationship includes accessing data defining a social network including the second user and the target user.
  • 6. The system as set forth in claim 5, wherein the computing device is further configured to classify where at least some of the plurality of questions are selected based on the classification of the second user.
  • 7. The system as set forth in claim 5, wherein the second user is classified based at least in part on data identifying at least one prior trust assessment session including the second user.
  • 8. The system as set forth in claim 1, wherein the computing device is further configured to: send at least one message to the target user after the interrogation of the second user has commenced; andmodify the target user's trust level of the second user based on data received from the target user in response to the at least one message.
  • 9. The system as set forth in claim 1, wherein the request includes at least one result address and one or more exit criteria and the computing device is further configured to: determine whether the exit criteria are satisfied during generation of the trust assessment result data; andsend data including the trust assessment result data to the at least one result address, wherein the exit criteria include an exit trust level and the exit criteria are satisfied once the computed trust level meets or exceeds the exit trust level.
  • 10. The system as set forth in claim 1, wherein the computing device is associated with a peer-to-peer network.
  • 11. The system as set forth in claim 1, wherein the target user and the second user have a pre-existing relationship and the computing device is further configured to: establish the relationship between the target user and the second user based on the pre-existing relationship.
CROSS-REFERENCE TO RELATED APPLICATION

The present application is a continuation of U.S. Ser. No. 13/008,535, filed on Jan. 18, 2011, now U.S. Pat. No. 8,276,207, which issued on Sep. 25, 2012, which was a continuation of U.S. Ser. No. 11/636,910, file on Dec. 11, 2006, now U.S. Pat. No. 7,886,334, which issued on Feb. 8, 2011, the disclosures of both applications are hereby incorporated by reference in its entirety; therefore, the present application claims priority to both the application and patent.

US Referenced Citations (350)
Number Name Date Kind
5220657 Bly et al. Jun 1993 A
5517617 Sathaye et al. May 1996 A
5537586 Amram et al. Jul 1996 A
5629980 Stefik et al. May 1997 A
5717923 Dedrick Feb 1998 A
5749081 Whiteis May 1998 A
5754939 Herz et al. May 1998 A
5867799 Lang et al. Feb 1999 A
5884035 Butman et al. Mar 1999 A
5983214 Lang et al. Nov 1999 A
6073138 de l'Etraz et al. Jun 2000 A
6088702 Plantz et al. Jul 2000 A
6092049 Chislenko et al. Jul 2000 A
6151624 Teare et al. Nov 2000 A
6195696 Baber et al. Feb 2001 B1
6260069 Anglin Jul 2001 B1
6275819 Carter Aug 2001 B1
6301609 Aravamudan et al. Oct 2001 B1
6308175 Lang et al. Oct 2001 B1
6311194 Sheth et al. Oct 2001 B1
6314409 Schneck et al. Nov 2001 B2
6327590 Chidlovskii et al. Dec 2001 B1
6338086 Curtis et al. Jan 2002 B1
6374290 Scharber et al. Apr 2002 B1
6385619 Eichstaedt et al. May 2002 B1
6389409 Horovitz et al. May 2002 B1
6389541 Patterson May 2002 B1
6421439 Liffick Jul 2002 B1
6438579 Hosken Aug 2002 B1
6442693 Sandgren et al. Aug 2002 B1
6463433 Baclawski Oct 2002 B1
6480885 Olivier Nov 2002 B1
6493703 Knight et al. Dec 2002 B1
6498795 Zhang et al. Dec 2002 B1
6519629 Harvey et al. Feb 2003 B2
6525747 Bezos Feb 2003 B1
6526411 Ward Feb 2003 B1
6539375 Kawasaki Mar 2003 B2
6553367 Horovitz et al. Apr 2003 B2
6560578 Eldering May 2003 B2
6567122 Anderson et al. May 2003 B1
6577607 Mitts et al. Jun 2003 B1
6581072 Mathur et al. Jun 2003 B1
6594693 Borwankar Jul 2003 B1
6606644 Ford et al. Aug 2003 B1
6629100 Morris et al. Sep 2003 B2
6630944 Kakuta et al. Oct 2003 B1
6631098 Chang et al. Oct 2003 B2
6651086 Manber et al. Nov 2003 B1
6654735 Eichstaedt et al. Nov 2003 B1
6687732 Bector et al. Feb 2004 B1
6701362 Subramonian et al. Mar 2004 B1
6745178 Emens et al. Jun 2004 B1
6748420 Quatrano et al. Jun 2004 B1
6757517 Chang Jun 2004 B2
6772160 Cho et al. Aug 2004 B2
6785704 McCanne Aug 2004 B1
6816906 Icken et al. Nov 2004 B1
6829569 Drucker et al. Dec 2004 B1
6832245 Isaacs et al. Dec 2004 B1
6839680 Liu et al. Jan 2005 B1
6854069 Kampe et al. Feb 2005 B2
6859807 Knight et al. Feb 2005 B1
6917944 Prasad et al. Jul 2005 B1
6957193 Stefik et al. Oct 2005 B2
6959290 Stefik et al. Oct 2005 B2
6970444 Chwieseni et al. Nov 2005 B2
6970840 Yu et al. Nov 2005 B1
6988096 Gupta et al. Jan 2006 B2
6988127 Matsuda et al. Jan 2006 B2
6993564 Whitten, II Jan 2006 B2
7006999 Huberman et al. Feb 2006 B1
7016307 Vasudev et al. Mar 2006 B2
7024391 Burich Apr 2006 B2
7039639 Brezin et al. May 2006 B2
7043644 DeBruine May 2006 B2
7047202 Jaipuria et al. May 2006 B2
7047406 Schleicher et al. May 2006 B2
7051003 Kobata et al. May 2006 B1
7054900 Goldston May 2006 B1
7058606 Stefik et al. Jun 2006 B2
7058897 Matsuda Jun 2006 B2
7069308 Abrams Jun 2006 B2
7069318 Burbeck et al. Jun 2006 B2
7092952 Wilens Aug 2006 B1
7103634 Ullmann et al. Sep 2006 B1
7107317 Demsky et al. Sep 2006 B2
7117254 Lunt et al. Oct 2006 B2
7120681 Frelechoux et al. Oct 2006 B2
7150030 Eldering et al. Dec 2006 B1
7302429 Wanker Nov 2007 B1
7313399 Rhee et al. Dec 2007 B2
7370015 Gvily May 2008 B2
7526458 Flinn et al. Apr 2009 B2
7594244 Scholl et al. Sep 2009 B2
7685135 Brooke et al. Mar 2010 B2
7689556 Garg et al. Mar 2010 B2
7698301 Lourdeaux Apr 2010 B2
7716220 Michelitsch et al. May 2010 B2
7720916 Fisher et al. May 2010 B2
7860019 Zhang et al. Dec 2010 B2
20010007099 Rau et al. Jul 2001 A1
20010042043 Shear et al. Nov 2001 A1
20020028395 Tanaka et al. Mar 2002 A1
20020032634 Abrams et al. Mar 2002 A1
20020052885 Levy May 2002 A1
20020057284 Dalby et al. May 2002 A1
20020077985 Kobata et al. Jun 2002 A1
20020078206 Boies et al. Jun 2002 A1
20020091556 Fiala et al. Jul 2002 A1
20020091667 Jaipuria et al. Jul 2002 A1
20020091975 Redlich et al. Jul 2002 A1
20020107721 Darwent et al. Aug 2002 A1
20020116466 Trevithick et al. Aug 2002 A1
20020124053 Adams et al. Sep 2002 A1
20020133550 Mears et al. Sep 2002 A1
20020138744 Schleicher et al. Sep 2002 A1
20020152322 Hay Oct 2002 A1
20020156875 Pabla Oct 2002 A1
20020156893 Pouyoul et al. Oct 2002 A1
20020156917 Nye Oct 2002 A1
20020169737 Armstrong et al. Nov 2002 A1
20020178164 Wisniewski Nov 2002 A1
20030002521 Traversat et al. Jan 2003 A1
20030009423 Wang et al. Jan 2003 A1
20030014482 Toyota et al. Jan 2003 A1
20030018582 Yaacovi Jan 2003 A1
20030018968 Avnet Jan 2003 A1
20030028596 Toyota et al. Feb 2003 A1
20030028639 Yamamoto et al. Feb 2003 A1
20030046587 Bheemarasetti et al. Mar 2003 A1
20030050976 Block et al. Mar 2003 A1
20030050977 Puthenkulam et al. Mar 2003 A1
20030055892 Huitema et al. Mar 2003 A1
20030061282 Ebata et al. Mar 2003 A1
20030064693 Sternberg Apr 2003 A1
20030079120 Hearn et al. Apr 2003 A1
20030084162 Johnson et al. May 2003 A1
20030093520 Beesley May 2003 A1
20030101449 Bentolila et al. May 2003 A1
20030105812 Flowers, Jr. et al. Jun 2003 A1
20030112823 Collins et al. Jun 2003 A1
20030120662 Vishik Jun 2003 A1
20030120680 Agrawal et al. Jun 2003 A1
20030135576 Bodin Jul 2003 A1
20030163597 Hellman et al. Aug 2003 A1
20030167324 Farnham et al. Sep 2003 A1
20030171941 Kraenzel et al. Sep 2003 A1
20030172034 Schneck et al. Sep 2003 A1
20030179228 Schreiber et al. Sep 2003 A1
20030182421 Faybishenko et al. Sep 2003 A1
20030185421 Okamoto et al. Oct 2003 A1
20030191814 Tran Oct 2003 A1
20030195851 Ong Oct 2003 A1
20030195924 Franke et al. Oct 2003 A1
20030200190 Adar et al. Oct 2003 A1
20030204605 Hudson et al. Oct 2003 A1
20030212680 Bates et al. Nov 2003 A1
20030220975 Malik Nov 2003 A1
20030220980 Crane Nov 2003 A1
20040015553 Griffin et al. Jan 2004 A1
20040019846 Castellani et al. Jan 2004 A1
20040024719 Adar et al. Feb 2004 A1
20040024720 Fairweather Feb 2004 A1
20040024892 Creswell et al. Feb 2004 A1
20040032393 Brandenberg et al. Feb 2004 A1
20040039913 Kruse Feb 2004 A1
20040044727 Abdelaziz et al. Mar 2004 A1
20040044774 Mangalik et al. Mar 2004 A1
20040054723 Dayal et al. Mar 2004 A1
20040059705 Wittke et al. Mar 2004 A1
20040064416 Peled et al. Apr 2004 A1
20040064568 Arora et al. Apr 2004 A1
20040064693 Pabla et al. Apr 2004 A1
20040073659 Rajsic et al. Apr 2004 A1
20040081105 Shimazaki et al. Apr 2004 A1
20040088325 Elder et al. May 2004 A1
20040103044 Vandewater et al. May 2004 A1
20040122696 Beringer Jun 2004 A1
20040122803 Dom et al. Jun 2004 A1
20040122822 Thompson et al. Jun 2004 A1
20040122855 Ruvolo et al. Jun 2004 A1
20040122958 Wardrop Jun 2004 A1
20040137882 Forsyth Jul 2004 A1
20040148275 Achlioptas Jul 2004 A1
20040148434 Matsubara et al. Jul 2004 A1
20040148503 Sidman Jul 2004 A1
20040162871 Pabla et al. Aug 2004 A1
20040181487 Hanson Sep 2004 A1
20040181540 Jung et al. Sep 2004 A1
20040193680 Gibbs et al. Sep 2004 A1
20040205358 Erickson Oct 2004 A1
20040210535 Erickson Oct 2004 A1
20040215793 Ryan et al. Oct 2004 A1
20040220893 Spivack et al. Nov 2004 A1
20040237045 Meltzer Nov 2004 A1
20040249768 Kontio et al. Dec 2004 A1
20040267625 Feng et al. Dec 2004 A1
20050013298 Srisuresh et al. Jan 2005 A1
20050015357 Shahidi Jan 2005 A1
20050021096 Mower Jan 2005 A1
20050031096 Postrel Feb 2005 A1
20050034107 Kendall et al. Feb 2005 A1
20050044361 Chang et al. Feb 2005 A1
20050044411 Somin et al. Feb 2005 A1
20050052998 Oliver et al. Mar 2005 A1
20050076365 Popov et al. Apr 2005 A1
20050080655 Sengir et al. Apr 2005 A1
20050086300 Yeager et al. Apr 2005 A1
20050091289 Shappell et al. Apr 2005 A1
20050091316 Ponce et al. Apr 2005 A1
20050094313 Kim May 2005 A1
20050097170 Zhu et al. May 2005 A1
20050097320 Golan et al. May 2005 A1
20050114783 Szeto May 2005 A1
20050131762 Bharat et al. Jun 2005 A1
20050138430 Landsman Jun 2005 A1
20050149621 Kirkland et al. Jul 2005 A1
20050154701 Parunak et al. Jul 2005 A1
20050159970 Buyukkokten et al. Jul 2005 A1
20050159998 Buyukkokten et al. Jul 2005 A1
20050163135 Hopkins Jul 2005 A1
20050165715 Farnham et al. Jul 2005 A1
20050165726 Kawell, Jr. et al. Jul 2005 A1
20050171799 Hull et al. Aug 2005 A1
20050171832 Hull et al. Aug 2005 A1
20050171954 Hull et al. Aug 2005 A1
20050171955 Hull et al. Aug 2005 A1
20050172001 Zaner et al. Aug 2005 A1
20050172116 Burch et al. Aug 2005 A1
20050177385 Hull et al. Aug 2005 A1
20050177614 Bourne Aug 2005 A1
20050197846 Pezaris et al. Sep 2005 A1
20050198031 Pezaris et al. Sep 2005 A1
20050198131 Appelman et al. Sep 2005 A1
20050198172 Appelman et al. Sep 2005 A1
20050198290 Berkey et al. Sep 2005 A1
20050198305 Pezaris et al. Sep 2005 A1
20050201290 Vasudev et al. Sep 2005 A1
20050203801 Morgenstern et al. Sep 2005 A1
20050204038 Medvinsky et al. Sep 2005 A1
20050209999 Jou Sep 2005 A1
20050210104 Torvinen Sep 2005 A1
20050210387 Alagappan et al. Sep 2005 A1
20050210409 Jou Sep 2005 A1
20050216300 Appelman et al. Sep 2005 A1
20050216550 Paseman et al. Sep 2005 A1
20050226511 Short Oct 2005 A1
20050229243 Svendsen et al. Oct 2005 A1
20050232423 Horvitz et al. Oct 2005 A1
20050234864 Shapiro Oct 2005 A1
20050235062 Lunt et al. Oct 2005 A1
20050240773 Hilbert et al. Oct 2005 A1
20050243736 Faloutsos et al. Nov 2005 A1
20050246420 Little, II Nov 2005 A1
20050251553 Gottfried Nov 2005 A1
20050256866 Lu et al. Nov 2005 A1
20050256909 Aboulhosn et al. Nov 2005 A1
20050262162 Levy Nov 2005 A1
20050262199 Chen et al. Nov 2005 A1
20050262246 Menon et al. Nov 2005 A1
20050262530 Ruetschi et al. Nov 2005 A1
20050266835 Agrawal et al. Dec 2005 A1
20050267766 Galbreath et al. Dec 2005 A1
20050267940 Galbreath et al. Dec 2005 A1
20050268151 Hunt et al. Dec 2005 A1
20050283497 Nurminen et al. Dec 2005 A1
20050289648 Grobman et al. Dec 2005 A1
20060004789 Lunt et al. Jan 2006 A1
20060004892 Lunt et al. Jan 2006 A1
20060009994 Hogg et al. Jan 2006 A1
20060010225 Issa Jan 2006 A1
20060015588 Achlioptas et al. Jan 2006 A1
20060020792 Weiss Jan 2006 A1
20060020960 Relan et al. Jan 2006 A1
20060021009 Lunt Jan 2006 A1
20060026235 Schwarz et al. Feb 2006 A1
20060031489 Marcjan Feb 2006 A1
20060031770 McMenamin Feb 2006 A1
20060035766 Towley, III et al. Feb 2006 A1
20060036641 Brydon et al. Feb 2006 A1
20060036766 Baupin et al. Feb 2006 A1
20060041543 Achlioptas Feb 2006 A1
20060042483 Work et al. Mar 2006 A1
20060047839 Tate et al. Mar 2006 A1
20060048059 Etkin Mar 2006 A1
20060053380 Spataro et al. Mar 2006 A1
20060064431 Kishore et al. Mar 2006 A1
20060085248 Arnett et al. Apr 2006 A1
20060085818 Bodlaender et al. Apr 2006 A1
20060089913 Jaipuria et al. Apr 2006 A1
20060090137 Cheng et al. Apr 2006 A1
20060095514 Wang et al. May 2006 A1
20060095792 Hurtado et al. May 2006 A1
20060095976 Torres et al. May 2006 A1
20060107286 Connor et al. May 2006 A1
20060112111 Tseng et al. May 2006 A1
20060117090 Schellingerhout et al. Jun 2006 A1
20060117378 Tam et al. Jun 2006 A1
20060121987 Bortnik et al. Jun 2006 A1
20060121988 Reville et al. Jun 2006 A1
20060123127 Littlefield Jun 2006 A1
20060136419 Brydon et al. Jun 2006 A1
20060136551 Amidon et al. Jun 2006 A1
20060143067 Calabria Jun 2006 A1
20060143068 Calabria Jun 2006 A1
20060143084 Donnelli et al. Jun 2006 A1
20060143183 Goldberg et al. Jun 2006 A1
20060143236 Wu Jun 2006 A1
20060146765 Van De Sluis et al. Jul 2006 A1
20060155813 Dietz et al. Jul 2006 A1
20060161553 Woo Jul 2006 A1
20060167804 Aydar et al. Jul 2006 A1
20060167855 Ishikawa et al. Jul 2006 A1
20060168022 Levin et al. Jul 2006 A1
20060173838 Garg et al. Aug 2006 A1
20060173957 Robinson et al. Aug 2006 A1
20060173963 Roseway et al. Aug 2006 A1
20060184464 Tseng et al. Aug 2006 A1
20060184997 La Rotonda et al. Aug 2006 A1
20060187858 Kenichi et al. Aug 2006 A1
20060190281 Kott et al. Aug 2006 A1
20060190524 Bethke et al. Aug 2006 A1
20060190536 Strong et al. Aug 2006 A1
20060195441 Julia et al. Aug 2006 A1
20060195462 Rogers Aug 2006 A1
20060200434 Flinn et al. Sep 2006 A1
20060200435 Flinn et al. Sep 2006 A1
20060209727 Jennings, III et al. Sep 2006 A1
20060218153 Voon et al. Sep 2006 A1
20060218225 Hee Voon et al. Sep 2006 A1
20060218577 Goodman et al. Sep 2006 A1
20060242581 Manion et al. Oct 2006 A1
20060248458 Li Nov 2006 A1
20060248573 Pannu et al. Nov 2006 A1
20060259733 Yamazaki et al. Nov 2006 A1
20060267940 Groom et al. Nov 2006 A1
20060272015 Frank et al. Nov 2006 A1
20060288041 Plastina et al. Dec 2006 A1
20070028000 Ebbesen et al. Feb 2007 A1
20070179945 Marston et al. Aug 2007 A1
20070192294 Ramer et al. Aug 2007 A1
20070192588 Roskind et al. Aug 2007 A1
20070233828 Gilbert Oct 2007 A1
20080016081 MacMillan et al. Jan 2008 A1
20080059992 Amidon et al. Mar 2008 A1
20080062945 Ahuja et al. Mar 2008 A1
20080086759 Colson Apr 2008 A1
20090030943 Kall Jan 2009 A1
20120066167 Fokoue et al. Mar 2012 A1
Foreign Referenced Citations (6)
Number Date Country
1117056 Jul 2001 EP
1338966 Jan 2005 EP
1675060 Jun 2006 EP
2005111760 Nov 2005 WO
2006036165 Apr 2006 WO
2006041425 Apr 2006 WO
Non-Patent Literature Citations (35)
Entry
Brickley, D., et al., “FOAF Vocabulary Specification,” 2005, accessed Feb. 20, 2007, 42 pages, http://xmlns.com/foaf/0.1/.
Golbeck, J., “Papers and Talks—Trust in Web-Based Social Networks,” MindSwap.org, accessed Aug. 7, 2007, 9 pages, http://trust.mindswap.org/papers.shtml.
Kagal, L., et al., “Developing Secure Agent Systems Using Delegation Based Trust Management,” Security of Mobile Multi-Agent Systems Workshop, Published: 2002, 8 pages.
McGuinness, Di., et al., “OWL Web Ontology Language Overview: W3C Recommendation,” W3C, Feb. 10, 2004, 19 pages.
Newman, M.E.J., “The Mathematics of Networks”, Center for the Study of Complex Systems—University of Michigan, 12 pages.
No Author,“Architecture of Windows Media Rights Manager,” Microsoft Corporation, May 2004, accessed Oct. 25, 2006, 5 pages, http://www.microsoft.com/windows/windowsmedia/howto/articles/drmarchitecture.aspx.
No Author, “Dijkstra's algorithm,” Wikipedia, the free encyclopedia, accessed Apr. 10, 2008, 4 pages, http://en.wikipedia.org/wiki/Dijkstra's—algorithm.
No Author, “Friendster—Home”, Friendster.com, accessed Feb. 8, 2007, 2 pages, http://www.friendster.com.
No Author, “Huminity—Social Networking, Chat Software, Create Personal Free Blogs and My Group Blogs!”, accessed Feb. 8, 2007, 1 page, http://www.huminity.com.
No Author, “ICQ.com—community, people search and messaging service,” ICQ, accessed Jan. 16, 2008, 2 pages, http://www.icq.com.
No Author, “myspace.com—a place for friends”, MySpace, accessed Apr. 10, 2008, 2 pages, http://www.myspace.com.
No Author, “News—Gaim 1.5.0,” SourceForge.net, Feb. 2, 2007, Accessed Sep. 6, 2007, 3 pages, http://www.gaim.sourceforge.net.
No Author, “Pidgin: Home,” Pidgin, accessed Jul. 13, 2007, 1 page, http://pidgin.im/pidgin/home/.
No Author, “Semantic Web Trust and Security Resource Guide,” Freie Universit•t Berlin, accessed Aug. 7, 2007, 13 pages, http://sites.wiwiss.fu-berlin.de/suhl/bizer/SWTSGuide/.
No Author, “Welcome to Facebook!”, Facebook, accessed Apr. 10, 2008, 1 page, http:.//www.facebook.com.
No Author, “The Friend of a Friend (FOAF) Project,” FOAF Project, accessed Apr. 26, 2007, 1 page, www.foaf-project.org.
Pretschner, A., et al., “Ontology Based Personalized Search,” Proceedings of the 11th IEEE International Conference on Tools with Artificial Intelligence, Nov. 1999, 8 pages.
Sack, W., “Discourse Diagrams: Interface Design for Very Large-Scale Conversations,” Proceedings of the 33rd Hawaii International Conference on System Sciences, 2000, 10 pages.
Smith, M.A., et al., “Visualization Components for Persistent Conversations,” Proceedings of the SIGCHI Conference on Human Factors in Computing Systems, 2001, 8 pages.
Srinivasan, T., et al., “OPSHNN: Ontology based Personalized Searching Using Hierarchical Neural Networks Evidence Combination,” Proceedings of the Sixth IEEE International Conference on Computer and Information Technology, 2006, 6 pages.
Vitiello Jr., E., “trust—A module for defining trust relationships in FOAF,” Jul. 22, 2002, updated Nov. 19, 2002, 2 pages, http://www.perceive.net/schemas/20021119/trust/default.htm.
Author Unknown, “Centrality”, Wikipedia—the free encyclopedia, Updated Sep. 14, 2007, Retrieved on Sep. 19, 2007, http://en.wikipedia.org/wiki/Centrality, 3 pages.
Author Unknown, “Eigenvector Centrality”, Wikipedia—the free encyclopedia, Updated Sep. 14, 2007, Retrieved on Sep. 19, 2007, http://ermikipedia.org/wiki/Eigenvector—Centrality, 3 pages.
Yang, B., et al., “Designing a Super-Peer Network,” 19th International Conference on Data Engineering, 2003, 15 pages.
Loo, B.T., et al., “The Case for a Hybrid P2P Search Infrastructure”, IPTPS 2004, Feb. 26, 2004, 29 pages, http://www.cs.berkeley.edu/˜boonloo/research/pier/casehybrid—iptps.ppt.
International Search Report for PCT/US07/77047, mailed Jul. 21, 2008, 9 pages.
International Preliminary Report on Patentability for PCT/US2007/077047, mailed Apr. 9, 2009, 5 pages.
First Office Action for Chinese Patent Application No. 200780043475.7, mailed Dec. 21, 2010, 44 pages.
Second Office Action for Chinese Patent Application No. 200780043475.7, mailed Jan. 29, 2012, 18 pages.
Non-Final Office Action for U.S. Appl. No. 11/636,910, mailed Apr. 9, 2010, 14 pages.
Notice of Allowance for U.S. Appl. No. 11/636,910, mailed Oct. 5, 2010, 9 pages.
Non-Final Office Action for U.S. Appl. No. 13/008,535, mailed Oct. 20, 2011, 39 pages.
Final Office Action for U.S. Appl. No. 13/008,535, mailed Jan. 24, 2012, 15 pages.
Notice of Allowance for U.S. Appl. No. 13/008,535, mailed Apr. 6, 2012, 44 pages.
Notice of Allowability for U.S. Appl. No. 13/008,535, mailed Aug. 2, 2012, 8 pages.
Related Publications (1)
Number Date Country
20120291137 A1 Nov 2012 US
Continuations (2)
Number Date Country
Parent 13008535 Jan 2011 US
Child 13561361 US
Parent 11363910 Dec 2006 US
Child 13008535 US