Systems and methods to provide server side profile information

Information

  • Patent Grant
  • 9760866
  • Patent Number
    9,760,866
  • Date Filed
    Tuesday, December 15, 2009
    15 years ago
  • Date Issued
    Tuesday, September 12, 2017
    7 years ago
Abstract
Systems and methods to provide server side profile information. An LDAP server is provisioned for each user of a plurality of users. Profile information is received. The profile information is stored in a database associated with the LDAP server. Via the LDAP server, a suggestion from the profile information is provided in response to a partial entry provided by the user to a first client associated with the user.
Description
FIELD OF THE TECHNOLOGY

At least some embodiments of the disclosure relate to client applications in general and, more particularly but not limited to, provision of profile information from a server to a client application.


BACKGROUND

Many systems and applications have been developed to allow people to communicate with each other. Such systems and applications may provide communication via emails, instant messages, text messages, web/online postings, etc.


Some applications have been developed to organize address information for users. For example, an address application may store information about a plurality of persons. For each of the persons, the address application may store the name of the person, the email address of the person, the street address of the person, the IM address of the person, the web page address of the person, phone numbers of the person, etc.


SUMMARY OF THE DESCRIPTION

Systems and methods are provided to provide server side profile information. Some embodiments are summarized in this section.


In one embodiment, a computer implemented method includes: provisioning, via a computing device, an LDAP server for each user of a plurality of users; receiving profile information; storing the profile information in a database associated with the LDAP server; and providing, via the LDAP server, a suggestion from the profile information in response to a partial entry provided by the user to a first client associated with the user.


The disclosure includes methods and apparatuses which perform these methods, including data processing systems which perform these methods, and computer readable media containing instructions which when executed on data processing systems cause the systems to perform these methods.


Other features will be apparent from the accompanying drawings and from the detailed description which follows.





BRIEF DESCRIPTION OF THE DRAWINGS

The embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.



FIG. 1 shows a user terminal to provide assistance in address input according to one embodiment.



FIG. 2 illustrates a profile of a person according to one embodiment.



FIG. 3 illustrates a system to obtain data for a profile according to one embodiment.



FIG. 4 illustrates a user interface to provide assistance in address input according to one embodiment.



FIG. 5 illustrates another user interface to provide assistance in address input according to one embodiment.



FIG. 6 shows a system to provide server side profile information according to one embodiment.



FIG. 7 shows a screen of an enhanced client according to one embodiment.



FIG. 8 shows a screen related to packaging of a data file according to one embodiment.



FIG. 9 shows a screen providing configuration settings data according to one embodiment.



FIG. 10 shows a screen to allow a user to manually enter configuration settings data according to one embodiment.



FIG. 11 shows a screen of a client according to one embodiment.



FIG. 12 shows a display of a suggestion served by an LDAP server and a suggestion provided by a client according to one embodiment.



FIG. 13 shows a display of a suggestion served by an LDAP server according to one embodiment.



FIG. 14 shows a method to provide a suggestion to a client according to one embodiment.



FIG. 15 shows a data processing system, which can be used in various embodiments.





DETAILED DESCRIPTION

The following description and drawings are illustrative and are not to be construed as limiting. Numerous specific details are described to provide a thorough understanding. However, in certain instances, well known or conventional details are not described in order to avoid obscuring the description. References to one or an embodiment in the present disclosure are not necessarily references to the same embodiment; and, such references mean at least one.


Reference in this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosure. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Moreover, various features are described which may be exhibited by some embodiments and not by others. Similarly, various requirements are described which may be requirements for some embodiments but not other embodiments.


In one embodiment, a user terminal is configured to provide assistance for the completion of inputting an address. While the user is typing to provide an input to specify an address for a message, the user terminal uses the incomplete input that has been provided to an address field so far by the user to identify one or more options or suggestions to complete the input, and thus allows the user to complete the input by selecting one.


In one embodiment, the user terminal is configured to search a profile set to search for a portion of the candidates that matches the incomplete input provided by the user. The profile set contains information about a plurality of persons, to whom the user may or may not have previously sent a message.



FIG. 1 shows a user terminal to provide assistance in address input according to one embodiment. The user terminal may be implemented as a personal computer, a web enabled television set, a personal digital assistant (PDA), or a mobile phone, using special purpose hardware (Application-Specific Integrated Circuit (ASIC) or Field-Programmable Gate Array (FPGA)), software and a general purpose processor, or a combination of special purpose hardware and software. Thus, the disclosure is not limited to a particular implementation.


In FIG. 1, the user terminal (101) is configured to store the messages (115) received at the user terminal (101) and the messages (117) sent from the user terminal (101). The user terminal (101) includes a message viewer (123) which can be used to display a message selected from the received messages (115) or selected from the sent messages (117).


In FIG. 1, the user terminal (101) further includes a message composer (121) which is configured to present a user interface to facilitate the composition of an outgoing message.


In one embodiment, the user terminal (101) is configured to generate an address set (111) based on the addresses that have been specified in the message composer (121) for one or more previously sent messages (117). When an address is used in the message composer (121) to specify a recipient of a message, the address is added to the address set (111), if the address is not already in the address set (111).


In one embodiment, the message composer (121) uses the address set (111) to suggest candidates for the completion of an input when the user is typing an address. For example, when the characters typed in an address field are the same as the first characters in a number of email addresses in the address set (111), the message composer (121) displays the email addresses as possible candidates for the completion of the input.


In one embodiment, the user terminal (101) further includes a profile presenter (125), which can provide suggestions for completion based on the profile set (113) maintained by the profile builder (119).


In one embodiment, the profile builder (119) is configured to extract profile data of various persons based on the received messages (115) and the sent messages (117). The profile builder (119) can extract information about persons not only from the headers of the messages where the senders and the recipients of the messages are specified, but also from the bodies of the messages and from other online sources, such as online directories, social networking websites, web pages, result pages found by search engines, etc.


Since the profile builder (119) obtains the profile data for various persons referenced in the messages (115 and 117), the profile set (113) is more comprehensive than the address set (111).


In one embodiment, the profile builder (119) is configured to scan the received messages (115) and the sent messages (117) for email addresses and names associated with the email addresses. The profile builder (119) generates a profile for each person identified to create the profile set (113). When new messages are received or sent, the profile set (113) is updated based on the new messages.


In some embodiments, the profile builder (119) may further identify persons based on scanning the received messages (115) and the sent messages (117) for phone numbers, names, addresses, etc.


In some embodiments, as discussed in more detail below, some or all of the components (111-125) in the user terminal (101) may be hosted on a server or platform remote to the user terminal (101) (e.g., accessible via a website and a web browser) in addition to or instead of being implemented in the user terminal (101). For example, in one embodiment, in addition to the user terminal (101), the profile set (113) may be hosted on a remote server or platform, and accessible via a web site. As another example, in one embodiment, the received messages (115) and the sent messages (117) may be hosted on a web site; and the user can use a web browser to view a selected one of the messages (115 and 117).


For example, the profile builder (119) may be configured to communicate with the server to extract the profile set (113) from the messages (115 and 117) hosted on the server. Alternatively, the profiler builder (119) may also be hosted on the server to build the profile set (113) on the server.



FIG. 2 illustrates a profile of a person according to one embodiment. In FIG. 2, the profile (131) includes various fields, such as the name (141) of the person, a photo image (142) of the person, one or more phone numbers of the person (143), address information (144) (e.g., email address, IM address, street address), business information (145) (e.g., employer, work address, job title), the date and time of the last message received from the person (146), the date and time of the last message sent to the person (147), the total number of messages received from the person (148), the total number of messages sent to the person (149), etc.


In one embodiment, the profile builder (119) obtains at least some of the information for the fields from the received messages (115) or the sent messages (117) to identify the person, and then uses other information sources to obtain the data for the other fields in an automated way to collect the profile information on behalf of the user.


For example, the profile builder (119) may use social networks, search engines, photo services, etc. to obtain the photo (142), the business information (145), etc.



FIG. 3 illustrates a system to obtain data for a profile according to one embodiment. In FIG. 3, under the control of the profile builder (119), the user terminal (101) may communicate with various servers in an automated way to extract data for the profile (131) over the network (151). The network (151) may include a local area network, a cellular telecommunications network, a wireless wide area network, a wireless local area network, a wireless personal area network, an intranet, and/or Internet.


In one embodiment, the user terminal (101) communicates with the message server (162) to receive and send the messages (115 and 117).


In one embodiment, after the profile builder (119) extracts from the messages (115 or 117) certain information (e.g., an email address, an IM user name, a phone number, and/or a name) about a person, the profile builder (119) uses the extracted information to query various servers to obtain further information (e.g., photo (142), phone number (143), address information (144), and/or business information (145)) about the person to create the profile (131).


For example, the user terminal (101) may query a web search engine (163), an online directory (164), a social network server (165), a business website (166), a personal website (167), a media sharing website (168), a map and direction web site (169), an online retailer (152), a travel website (153), a location website (155), and/or other servers. Information that can be used as search criteria include names, screen names, social network profile names, social network profile URLs, physical addresses, website URLs, email addresses, or telephone numbers. Information that is collected as a result of these queries may be used in future searches to identify additional information that may be used to create a person profile.


For example, the user terminal (101) may receive an email sent by a person via the message server (162). The profile builder (119) of the user terminal (101) is configured to perform a search using the web search engine (163) with the email address of the person as the search criteria. The search engine (163) may return a search result that includes the phone number (143) of the person. The profile builder (119) extracts the phone number (143) from the search result and stores the phone number (143) as part of the profile (131) of the person. The search engine (163) may also return the URL for or link to a personal website (167) belonging to the person. The personal website (167) may contain additional information about the person that may be used to create a person profile, such as additional contact information or biographical information.


In another example, the email address belonging to the person may include an extension (or domain name) for a company. The profile builder (119) of the user terminal (101) is configured to perform a search using the search engine (163) with the email extension (or domain name) as the search criteria. A result returned by the search may be a business website (166). The profile builder (119) of the user terminal (101) is further configured to search the business website (166) to obtain information relevant to the profile (131) of the person. For example, a web page on the business website (166) may contain additional information about the person that may be used to create a person profile, such as business information (145), additional contact information or biographical information.


In another example, the profile builder (119) of the user terminal (101) is configured to perform a search using an online directory (164) (e.g., a person search directory, a yellow page directory) with the name (141) of the person or other contact information as the search criteria. The online directory (164) may return search results that include additional contact information and other information that may be used for the profile (131) of the person.


In another example, the user terminal (101) may receive an email sent by the person via the message server (162). The email may contain a social network user name for the person. The profile builder (119) of the user terminal (101) is configured to extract this social network user name from the email and use it to access the social network server (165). A webpage on the social network server (165) may contain additional contact information and other information that may be extracted and used by the profile builder (119) to create the profile (131) of the person. The webpage on the social network server (165) may also contain additional contacts that may be associated with the person in the profile (131). For example, persons on the friends list of the webpage on the social network server (165), or persons who have posted comments or messages on the social network server (165) may be listed as contacts in a contact network for the person.


In another example, a search performed using the search engine (163) may return a URL or link for a media sharing website (168) (e.g., for sharing photos or videos). The media sharing website (168) may store profile information about the person. Thus, the profile builder (119) of the user terminal (101) can extract additional contact information or biographical information from the media sharing website (168) for the creation of the profile (131) of the person. For example, a profile belonging to the person on a video sharing website may include an instant message screen name (user name) for the person. This screen name may be extracted and displayed as part of the profile (131) of the person.


In one embodiment, information extracted from communications between the person and other users may also be used to update profile information on a social network server (165) or other websites. For example, the profile builder (119) of the user terminal (101) may detect that the person has primarily used email address “david@foo.com” in recent communications, whereas the profile of the person on the social network server (165) shows his email address as “david@bar.com.” The profile builder (119) of the user terminal (101) can share the new email address of the person with the social network server (165) to allow the social network server (165) to automatically update the corresponding information about the person, or to suggest the person to make an update based on this changed behavior detected by the profile builder (119) of the user terminal (101).


In one embodiment, the profile builder (119) of the user terminal (101) can also extract information about the person from the travel website (153) and the online retailer (152) for the creation of the profile (131) of the person. For example, after an email containing information about a flight itinerary is received in the user terminal (101), the profile builder (119) of the user terminal (101) may extract a flight number or other information about a flight from the email. The profile builder (119) of user terminal (101) then queries the travel website (153) using the flight number or other flight information as search criteria. Information about the flight, such as the destination city or the departure city, expected departure time, expected arrival time, expected delays, weather in the destination city, weather in the departure city, or any changes to the flight may be used as part of the profile (131) of the person.


In another example, an email containing information about an item or service that the second user is interested in purchasing may be received in the user terminal (101). The profile builder (119) of user terminal (101) is configured to query one or more search engines, websites, or on-line retailers (152) to determine which retailer or website has the best price or currently has the item in stock or the service available. This information is extracted by the profile builder (119) and displayed by the profile presenter (125) as part of the profile (131) of the person.


In one embodiment, the profile builder (119) of the user terminal (101) can also extract information from a map and direction website (169) and location servers (155) as part of the profile (131) of the person. For example, the person may own a GPS unit, cell phone, or other device that is capable of transmitting the person's current physical location to the location server (155), which allows other users to access the person's current location information. If the user of the user terminal (101) has permission to view the location information of the person, the profile builder (119) of the user terminal (101) may access the location server (155) over the network (151) to receive location information about the person. This location information can be displayed as part of a person profile.


The profile builder (119) of the user terminal (101) may also access the map and direction website (169) to create a map of the current location of the person, or to generate directions to the current location of the person. The map or directions may be displayed by the profile presenter (125) as part of the profile (131) of the person. The map and direction website (169) may also be used to generate a map or directions to one or more known street addresses of the person, such as a work address or home address. The map or directions can be displayed by the profile presenter (125) as part of the profile (131) of the person.



FIG. 4 illustrates a user interface to provide assistance in address input according to one embodiment. In FIG. 4, the user interface (201) is configured for composing an outgoing message. The user interface (201) includes entries to specify the addresses of the recipients of the message. For example, the entry box (203) is configured to receive the email address of an outgoing email, which may be sent from the user terminal (101) via the message server (162).


In one embodiment, when the entry box (203) detects a change in the content received in the entry box (203) (e.g., a keystroke is received in the entry box (203), as the user types a letter on a keyboard to provide an input), the profile presenter (125) determines a set of suggestions for the completion of the input in the entry box (203). The profile presenter (125) uses the incomplete input in the entry box (203) as a search criterion to find from the profile set (113) a set of suggestions for the complete address input. The suggestions are presented in the window (205) as a selectable list.


In one embodiment, when the message composer (121) has an existing, native mechanism for displaying suggestions (e.g., making suggestions based on address set (111)), the profile presenter (125) can be configured as an add-on module to display these suggestions as well and to hide the native mechanism of the message composer (121) for displaying suggestions.


In FIG. 4, the item (209) on the top of the list is highlighted; and the user may select the highlighted item (209) with a keystroke (e.g., pressing Tab key, Enter key, Home, End, PgUp, PgDown, etc.). The user may use the arrow keys to move the highlight up or down the list to highlight a different item, or provide additional input in the entry box (203) to cause the profile presenter (125) to update the suggestions in the window (205). The user may also use the cursor (207) to select an item using a cursor control, such as a mouse, a track ball, a touch pad, a touch screen, etc.


In one embodiment, when the message composer (121) has an existing, native mechanism that uses these keys for the display of suggestions, the profile presenter (125) configured as an add-on module can hide these keystrokes from the native mechanism. For example, the


In one embodiment, after an item is selected from the list presented in the suggestion window (205), the address represented by the item is inserted by the profile presenter (125) into the entry box (203) to replace the corresponding portion that is used to suggest the selected item; and the suggestion window (205) is closed automatically.


In some embodiments, the message composer (121) may be configured to perform post-processing, such as name checking, on the inserted text in the entry box (203) a few moments after the text has been inserted. The insertion by the profile presenter (125) is performed in a way that allows such post-processing by the message composer (121) to continue functioning. For example, if the message composer (121) loses focus or activation, it starts post-processing the entries in the textbox. The profile presenter (125) is configure temporarily prevent this from happening while the suggestion window (205) is visible and causes this to happen when the suggestion window (205) is closed. To hide the suggestion window (205), the suggestion window (205) is configured as a topmost window that is initially not activated. The Outlook textbox window is subclassed via a code-injection mechanism to temporarily preventing it from getting “kill focus” messages (e.g., through intercepting such messages, and then throwing them away). After the suggestion window (205) becomes invisible, the profile presenter (125) sets the focus back to the textbox window and causes the post-processing to be performed.


For example, in FIG. 4, the incomplete input “Graf” is received in the entry box (203). The cursor “|” in the entry box (203) indicates the insertion point for subsequent keystrokes received in the user terminal (101). While the entry box (203) is expecting additional input from the user, the profile presenter (125) uses the incomplete input “Graf” to identify a set of suggestions, such as mgraf@gmail.com for Mary Graf, ericg@yahoo.com for Eric Grafstrom, graffiti@hotmail.com for Steve Curtis, graffiti@pacbell.net for SFPD, etc., based on the profile set (113) established by the profile builder (119).


In one embodiment, the suggestions are identified by matching the incomplete input with names, addresses and/or other profile data of the persons in the profile set (113). The incomplete input may match the beginning of a last name, the beginning of a first name, the beginning of the name of an organization, the beginning of a domain name of an email address, the beginning of the top level domain name of an email address, the beginning of the email prefix, the beginning of a word in the job title (or the beginning of the job title), the beginning of the city of the person, etc. In some embodiments, when an email prefix contains one or more separators, such as “_” or “.” or “-”, the email prefix is broken down into segments or chunks; and the incomplete input may be match the beginning of any of the segments or chunks. When there is a match, the person can be selected as a candidate for the suggestions. Thus, the searching for a match is not limited to matching the beginning of an address that the user has previously typed for a previous outgoing message.


In FIG. 4, the top item, mgraf@gmail.com for Mary Graf, is highlighted and can be selected by pressing the Tab key or the Enter key. Alternatively, the user may select the second item, ericg@yahoo.com for Eric Grafstrom, by pressing a mouse button while the cursor (207) is over the second item. The profile presenter (125) is configured to use the selected address to replace the incomplete input “Graf” received in the entry box (203).


In FIG. 4, if the user further types a letter “f”, the profile presenter (125) will use the incomplete input “Graff” to eliminate some suggestions (e.g., mgraf@gmail.com for Mary Graf, ericg@yahoo.com for Eric Grafstrom) and update the list in the suggestion window (205).


Thus, the profile presenter (125) uses the profile set (113) to identify suggestions based on incomplete input provided in the entry box (203) and to allow the user to select a suggestion to complete the input.



FIG. 4 illustrates an example in which the suggestion window (205) is presented to provide suggestions for the completion of an address input in the “To” field of the user interface (201) for composing an outgoing message. Similar suggestions can be provided when the user is typing in other fields that are configured to receive address inputs, such as the “CC” field, or “BCC” field, of a user interface for composing an outgoing email message. Further, the suggestions can be provided when the user is typing in other types of user interfaces that are configured to receive address inputs, such as a user interface to edit a contact entry, a profile page, etc. Thus, the invention is not limited to the user interface for composing an email message.



FIG. 5 illustrates another user interface to provide assistance in address input according to one embodiment.


In FIG. 5, the suggestions are presented as two parts. The part above the separator (211) is identified from the address set (111) and the part below the separator (211) is identified from the profile set (113).


In one embodiment, the address set (111) is generated by collecting the addresses that have been previously specified in the address fields of the message composer (121) of the user terminal (101). In one embodiment, the suggestion above the separator (211) is identified by matching the incomplete input “Graf” with the starting letters of the addresses in the address set (111). The addresses in the address set (111) that have the leading characters “graf” are selected to generate the suggestions above the separator (211).


In one embodiment, the message composer (121) has an existing, native mechanism for displaying suggestions (e.g., making suggestions based on address set (111)). The profile presenter (125) is configured to obtain the suggestions from the native mechanism (e.g., via scraping, inspecting, querying, etc.) and displays the suggestions above the separator (121).


In one embodiment, the suggestions presented above the separator (211) are identified by the message composer (121). The profile presenter (125) obtains the suggestions from the message composer (121), presents the suggestions in the suggestion window (205), hide the suggestions the message composer (121) would have shown (and thus prevents the message composer (121) from presenting the suggestions in a separate window).


In another embodiment, the profile presenter (125) shows the suggestions based on the profile set (113) in one suggestion window; the message composer (121) shows the suggestions in a different suggestion window; and the profile presenter (125) aligns its suggestion window with the suggestion window of the message composer (121) so that the two suggestion windows appear like two panels of a large window. Alternatively, the profile presenter (125) presents its suggestion window over the suggestion window of the message composer (121) (to cover up and thus effectively disable the suggestion window of the message composer (121)). In one embodiment, the profile presenter (125) causes the suggestion window of the message composer (121) to be invisible on subsequent invocations to hide the suggestion window of the message composer (121).


In another embodiment, the profile presenter (125) uses the address set (111) to identify the suggestions presented above the separator (211) in the suggestion window (205), using the same approach the suggestion window of the message composer (121) would use.


In one embodiment, the profile presenter (125) includes an auto suggest manager. The auto suggest manager can turn on or turn off the feature of auto suggestions generated based on the profile set (113) in accordance with the preferences of the user. The auto suggest manager provides encapsulation, providing an easy interface for external applications to use the auto suggest feature without understanding its implementation. It provides a mechanisms to add the auto suggest feature to a new window (message, contact, etc.), to “clean up” or remove the auto suggest feature from a window or all windows, to allow logging of auto suggest state and problems, and to determine any special preferences the user may have set in the native client (e.g., Outlook).


In one embodiment, the profile presenter (125) includes a suggestion window (205) that presents a dialog box or a list box to show the suggested results. The profile presenter (125) includes a view controller to show or hide the suggestion window (205). The view controller also positions the suggestion window (205) in the correct location (which varies as the user types in text), participates in “hiding” the suggestion window (205) from the native application (e.g., Outlook) so that the native application is not aware of the existence of the suggestion window (205), and notify other modules of navigation commands (PgUp, PgDown, etc.) and user selections. When a selection or keyboard command (e.g., arrow keys, tab return) related to the suggestions occurs, the suggestion window (205) (or a keyboard hook or the inspector controller, discussed below) provides messages to the view controller for processing.


In one embodiment, the profile presenter (125) further includes a result controller, which decides what results to show and when. After the profile presenter (125) detects that the user is typing in an address field (e.g., To, CC, or BCC fields of a window to compose an email), the result controller uses the incomplete input as a search criterion to search for the suggestions based on the profile set (113) and/or based on the address set (111). The view controller causes the display of the suggestion window (205) to show the search results. If the user selects a suggestion from the window (205), the address corresponding to the user selection is put into the address field.


In one embodiment, the profile presenter (125) is implemented as an add-on module for an existing communications client, such as Microsoft Outlook, which can make suggestions by selecting from the address set (111) the email addresses that start with the incomplete input typed by the user in the address field. The suggestion window (205) of the profile presenter (125) subclasses the suggestion window of the existing communications client; and the profile presenter (125) hides the suggestion window of the existing communications client and creates a keyboard hook as wells as a subclass mechanism using code-injection to intercept keyboard messages and other messages sent to the hidden suggestion window of the existing communications client to prevent it from processing these keys (e.g. PgUp, PgDown, Tab, Return), and also to cause it to process fake keystrokes or other messages (e.g. to implement “delete” functionality”). In one embodiment, the keyboard hook is a global WH_KEYBOARD_LL hook; in another embodiment, the keyboard hook is a WH_KEYBOARD hook. In one embodiment, the profile presenter (125) creates only one such keyboard hook per thread (especially for the WH_KEYBOARD hook).


In one embodiment, the result controller is configured to handle a rapidly typing user, by stopping a previous search and then starting a new search. For example, if a search for suggestions is started based on the initial input “er” and before the suggestions are displayed the user further typed “ic” to provide the input “eric”, the result controller stops the search for suggestions based on “er” and starts a new search for suggestions based on “eric”.


In one embodiment, an inspector controller is used to hook the functionalities of the profile presenter (125) with the existing communications client, which may be the message composer (121) in one embodiment. When a window for the message composer (121) is constructed and shown, the inspector controller determines whether the user is typing in a field (e.g., entry box (203)) that is configured to receive an address. If the user is typing in an address field, the inspector controller instantiates a keyboard hook to obtain what the user types in the address field to allow the profile presenter (125) to generate the suggestions based on the profile set (113).


In one embodiment, the inspector controller determines if the window should have auto suggest functionality. Read-only windows or unsupported type of windows should not have the auto suggest functionality. The inspector controller then searches for suitable textboxes (using a “Control Calculation mechanism”) that should have auto suggest functionality attached to them. Since the native client (e.g., Outlook) has many configurations (“use Word Editor”, use “RTF Editor”, etc.), different mechanisms are used and a fallback mechanism in case the initial search for a suitable window fails, and in some cases, additional code injection is required because the native client (e.g., Outlook) uses a different process for different windows. The inspector controller uses a “SetProp” mechanism to “remember” which windows have already been subclassed so that auto suggest functionality is correctly added to the newest window. Additionally, the inspector controller keeps track of which textbox (To, Cc, Bcc, etc.) the user is currently using. The inspector controller also is responsible for putting the user's selection (from the dialog) into the selected textbox control. The inspector controller also watches for various windows message in the various subclassed windows (e.g. Activation, Focus, Keyboard), “hiding” (or “eating”) some of these message from the native client (e.g., Outlook) so as not to break other existing functionality of the native client (e.g., Outlook), and using others to notify the view controller that it should hide or show or change the suggestion window (205). In addition to the subclass of the “TextBox” and “Outlook AutoSuggest” window, the main composer window is subclassed as well, and may subclass others in the future. Note that this subclassing mechanism is implemented using code injection and could in the future also be implemented using other mechanisms. Code injection “injects” our code into another program (e.g. Outlook or Word) while it is running.


In one embodiment, the inspector controller subclasses the textbox (and also the parent window) into which the user is typing to receive the keys typed by the user, generate requests for new suggestions in response to keys typed by the user, scroll through the suggestions (e.g., when the user presses arrow keys), indicate a selection by the user (e.g., when the user presses Tab or Enter key) (some embodiments use subclass, some embodiments keyboard hook), the profile presenter (125) hide these keystrokes from the native client (e.g., Outlook window) (by “eating” or consuming the messages), and hide the suggestion window (205) when the keyboard focus is moved out of the textbox or user has activated another application or user has finished selection. The inspector controller instantiates the view controller to process the user input and subclasses the suggestion window of the message composer (121) to create the suggestion window (205). The inspector controller (or the keyboard hook) contacts the view controller to process the user inputs when various keys are received in the textbox in which the user is typing.


In one embodiment, a window driver is used to work with the message composer (121) to obtain current caret position (the position of the text insertion point indicator). In response to the requests from the inspector controller and the suggestion window (205), the window driver may selectively block messages from being passed on to other windows. When a selection is made, the window driver is configured to replace the incomplete input in the address field with the address corresponding to the selection.


In one embodiment, the profile presenter (125) is implemented as an add-on module to a native client, such as Outlook. The Outlook textbox windows are in some cases “rich edit controls” which allow other controls to be embedded in them. The profile presenter (125) walk both the text and these embedded COM controls using COM (also known as OLE or ActiveX programming) to determine where the user is currently entering text (ignoring any other text or embedded controls before or after the current email address) so that the profile presenter (125) can correctly determine where the current user's entry begins and ends, what text to use to create suggestions for, and also which part of the text (or embedded controls) to replace.


In one embodiment, the profile presenter (125) uses a person-centric approach to identify the suggestions. The partial input (e.g., “Graf” received in the entry box (203)) is used to match the names of the persons to identify the persons in the profile set (113) (e.g., the first name, the last name, the nickname, etc.). The profile presenter (125) sorts the matched persons based on a relationship score determined from the statistical data derived at least in part from the received messages (115) and the sent messages (117).


In one embodiment, after receiving one or more letters that are typed in by an end user in an entry box configured to receive an address for an outgoing message, the profile presenter (125) determines whether the one or more letters match part of a name in the profile set (113). If there is a match (or more than one match), the profile presenter (125) retrieves the addresses associated with the matched name(s), sorts the addresses, and presents the addresses for selection in suggestion window (205).


In one embodiment, if there is no name that matches the one or more letters, the profile presenter (125) determines whether the one or more letters match part of an address in the profile set (113). If there is a match (or more than one match), the profile presenter (125) retrieves the matched address(es), sorts the addresses, and presents the addresses for selection in suggestion window (205).


Thus, the user can input the names of the recipient to cause the profile presenter (125) to identify the persons with names matching the input to select the person and thus select the address of the person. The names of the recipient do not have to be part of the addresses to be matched and suggested.


In one embodiment, when a person has multiple addresses, the suggestion window (205) shows multiple suggestions for the addresses presented with the name of the person.


In another embodiment, when a person has multiple addresses, the suggestion window (205) shows one entry to suggest the person. If the person is selected, the suggestion window (205) is then updated to show a list of addresses of the person. If the user selects one or more addresses, the profile presenter (125) replaces the name of the person with the selected address(es) of the person; if the user does not select any of the multiple addresses, the profile presenter (125) replaces the name of the person with all of the multiple addresses. In one embodiment, if the user does not select any of the multiple addresses of the person, the profile presenter (125) replaces the name of the person with the top ranked address of the person in the To field and inserts the other addresses of the person in the CC or BCC field (or uses the top ranked address without using the other addresses of the person).


In one embodiment, the profile presenter (125) attempts to first match names of the persons in the profile set (113) and, if there is no match in names, then match addresses of the persons in the profile set (113).


In another embodiments, the profile presenter (125) may perform a search to match the beginning of a number of fields in the profile set (113), such as, different fields of names of the persons in the profile set (113), different segments of email addresses of the persons in the profile set (113), the names of cities (or states or countries) of the persons in the profile set (113), different words in the street addresses of the persons in the profile set (113), different words of job titles of the persons in the profile set (113), screen names of the persons in the profile set (113), etc. Examples of different fields of names include first name, last name, middle name, nick name, etc. Examples of different segments of email addresses include segments or chunks of an email prefix separated by a separator, such as “-”, “.”, or “_”, different levels of domain names of an email address, etc. In some embodiments, the names of the persons are as part of the email addresses. In some embodiments, the names are from fields separated from the email addresses.


When the profile presenter (125) searches different types of fields, a match in different types of fields may be weighted differently. For example, a match in a name field may be given a first weight (e.g., 10), a match in an email prefix segment may be given a second weight (e.g., 8), a match in the top level domain name may be given a third weight (e.g., 1), and a match in other domain names (e.g., second level domain name, or lower level domain names) may be given a fourth weight (e.g., 2), etc. When a person or an address has multiple matches in different fields, the weights for the multiple matches may be added to compute the weight for the person or address. Alternatively, the highest weight for the multiple matches can be selected as the weight for the person or address. The weights for the matched persons or addresses can be used to sort the persons or addresses for selection of up to a predetermined number of suggestions for presentation to the user. For example, the weights can be applied to the relevancy scores of the matched persons or addresses to determine relevancy scores for suggesting the persons or addresses; and the profile presenter (125) selects up to a predetermined number of matched persons or addresses that have the highest relevancy scores for suggesting the persons or addresses.


In FIGS. 4 and 5, the suggestions presented based on the profile set (113) are shown as a list of entries, where a typical entry includes the name and the address of the person. However, in other embodiments, the entries may further include other information, such as a photo image of the person, a job title of the person, a business association of the person, etc. In some embodiments, other details of the profile of the person are shown in a separate window when the cursor is positioned and remains positioned on the entry for the person (e.g., hovering over the entry).


In one embodiment, the profile presenter (125) ranks the persons for the suggestions to complete the address input, based on the relevancy index between the suggested persons and the user of the user terminal (101). When dealing with long lists of contacts, such a relevancy index helps users find the most relevant contacts first.


In one embodiment, the profile builder (119) scans the messages (115 and 117) to capture the addresses of the senders and recipients of the messages (115 and 117). Each of the captured addresses is stored in an index file. When one of those addresses is seen in a header that describes the recipients and senders, the score for the address is increased by a predetermined amount (e.g., 1). In some embodiments, the profile builder (119) further scans the body of the messages (115 and 117) to identify additional addresses.


In some embodiments, different weights/amounts are given to the score when the addresses are used in different fields (e.g., From, Reply-To, To, CC, and BCC fields of emails). For example, an amount of 3 may be given to the score when an address is found in a field that identifies the sender of the message (e.g., From or Reply-To fields of emails received by the user of the user terminal (101)); and an amount of 1 may be given to the score when the address is found in a field that identifies the recipient of the message (e.g., To, CC, and BCC fields of emails sent from the user of the user terminal (101)).


In some embodiments, the same amount is given to the score regardless of the type of fields in which the address is used (e.g., From, Reply-To, To, CC, and BCC fields of emails).


In some embodiments, the length of the elapsed time period since receipt of the message is further used to determine the amount given to the score. The occurrence of an address in a recent message can be given more weight than the occurrence of the address in a message received/sent earlier than the recent message.


Thus, after the messages (115 and 117) are processed, each of the addresses has a relevancy score. The higher the score, the more relevant the address is to the user of the user terminal (101).


In some embodiments, the relevancy score is computed from the data in the profile (131), such as the total number of messages received from the person (148), the total number of messages sent to the person (149), etc. In some embodiments, the number of messages are counted based on the types of fields in which the addresses appear and the time periods in which the messages are sent or received.


In one embodiment, the profile builder (119) further groups the addresses by the names of the corresponding persons. Each person having a name in the profile set (113) may have one or more addresses. In one embodiment, the scores for the addresses of the person are summed to generate a score for the person. Thus, the higher the score, the more relevant the person is to the user of the user terminal (101).


In one embodiment, when the suggestions are presented as a list of addresses, the scores for the addresses are used to sort the addresses. When the suggestions are presented as a list of persons, the scores for the persons are used to sort the list of names of the persons.


In another embodiment, the suggestions are presented as a list of addresses grouped according to the persons. The addresses for each person are grouped together and sorted within the group based on the scores of the emails. The groups are sorted according to the scores of the persons.


In one embodiment, the profile presenter (125) selects up to a predetermined number (e.g., 10) of candidates, after sorting the candidates for the suggestions based on the relevancy scores. The selected candidates are presented in the suggestion window (205) to help the user. Less relevant candidates are not presented in the suggestion window (205).


While some of the embodiments are discussed here in the context of composing an email message, the techniques disclosed here can also be applied to the specifying of address information for instant messaging, text messaging, dialing a phone number, etc. Instead of matching the incomplete input to the exact address, the profile presenter (125) can match the incomplete input with identifiers of the persons in the profile set (113) to identify the persons as the basis for suggestions. Examples of identifiers include nickname, first name, last name, company name, domain name, user name, screen name, phone number, etc. In one embodiment, the suggestions are searched and presented in the form of suggested persons and thus, the suggestions are person-centric.


In some embodiments, the user terminal (101) may include different communication components that require address information for different types of communications, such as email, instant messages, text messages, phone calls, etc. The profile presenter (125) may use the profile set (113) to generate the suggested candidates for completing an address input for the different types of communications.


In some embodiments, the relevancy score is computed for the person without considering the type of communications. In other embodiments, the addresses having the same type as the address to be suggested are given more weight than other types of addresses. For example, when ranking the persons for suggesting addresses for instant messaging, the addresses for instant messaging may be given more weight than addresses for other types of communications, such as email, phone calls, etc. Thus, for different types of communications, the profile presenter (125) may suggest different lists of persons based on the same profile set (113) and the same incomplete input.


In one embodiment, the profile builder (119) scans a set of messages (115 and 117) to identify addresses of senders of the messages and addresses of recipients of the messages in an automatic way, for example, when the profile builder (119) is installed and/or when the messages (115 and 117) are received or sent.


The profile builder (119) identifies the names of persons at the addresses to create profiles (131) for the persons, based on scanning the messages (115 and 117) and/or querying other data sources in an automated way, such as the web search engine (163), online directory (164), social network server (165), and other websites.


In one embodiment, the profile builder (119) computes a relevancy score for each of the addresses based on a number of messages in which the addresses are used and types of fields in which the addresses are used in the messages. For example, instances where an address is used to specify a recipient of a message sent from the user of the user terminal (101) may be given more weight than instances where the address is used to specify a sender of a message received by the user of the user terminal (101).


In one embodiment, the profile builder (119) also computes a relevancy score for each of the persons based on the relevancy score of the addresses of each person.


In one embodiment, in response to an incomplete input in an address field, the profile presenter (125) identifies a set of persons by matching the incomplete input with names of the persons and/or the addresses of the persons. The profile presenter (125) sorts the addresses of the identified persons according to the relevancy scores of the persons and/or the relevancy scores of the addresses, and selects and presents up to a predetermined number of suggestions from the sorted addresses. In response to a user selection of one of the suggestions, the profile presenter (125) replaces the incomplete input with the user selected address.



FIG. 6 illustrates a system (600) having an enhanced client 1 (630), an enhanced client 2 (640), clients (650a-n), web application (660), web application (670), and a platform (610). The components in FIG. 6 communicate over a network (680). In one embodiment, the network (680) is the network (151).


The enhanced client 1 (630) is a client application that runs on the user terminal (101) of a particular user, and provides the functionality of the components (111-125). The enhanced client 1 (630) may include any software utility or client application that provides for management of messages, address books, contact information, and calendars including, for example, those provided by Microsoft (e.g., Outlook), RIM (e.g., Blackberry), and other organizations. In one embodiment, the enhanced client 1 (630) may include other types of software utilities and client applications.


In one embodiment, the enhanced client 2 (640) may include the same types of software utilities and client applications as the enhanced client 1 (630).


The enhanced client 1 (630) includes a database (634), an indexing engine (632), and a passive address book (PAB) 1 (636). The database (634) may include contact information in a native data format of the client application, including, for example, received messages (115), sent messages (117), and contact information manually entered by a user of the user terminal (101). In one embodiment, the database (634) may include information in the address set (111).


The indexing engine (632) extracts, processes, and indexes information from the database (634), and stores the information in the PAB 1 (636). In one embodiment, the indexing engine (632) is, or may include, the profile builder (119). In one embodiment, the profile information in the PAB 1 (636) may include information in the profile set (113). In this regard, the PAB 1 (636) contains profile information about persons obtained from the headers of sent messages and received messages that are manually entered as well as information automatically obtained from the bodies of messages and various online sources. In one embodiment, the functionality of the indexing engine (632) and the PAB 1 (636) may be provided by an add-on utility to a base client application.


In one embodiment, the enhanced client 1 (630), as well as the platform (610) via the indexing engines (618a) and (618c), may additionally extract profile information over the network (680) from a separate web application (670) (e.g., Google account of the user) of a remote server by a custom communications protocol between the enhanced client 1 (630) and the web application (670). In one embodiment, the enhanced client 1 (630)), as well as the platform (610) via the indexing engines (618a) and (618c), may extract profile information over the network (680) from a separate web application (660) (e.g., Yahoo account of the user) of a remote server via an API (662) with which to extract the profile information from the web application (600). The profile information is stored in the PAB 1 (636).


The enhanced client 1 (630) communicates with the platform (610) over the network (680). In one embodiment, the platform (610) is a server or server farm. The platform (610) includes an XDF sync server (612), an indexing engine (618a), a PAB 1 (616a), and an LDAP server 1 (614a). The indexing engine (618a), the PAB 1 (616a), and the LDAP server 1 (614a) are associated with the user of the enhanced client 1 (630) and the enhanced client 2 (640). In one embodiment, the indexing engine (618a), the PAB 1 (616a), and the LDAP server 1 (614a) are provided for the user or group of users. An indexing engine (618c), a PAB N (616c), and an LDAP server N (614c) of the platform (610) are provided for a different Nth user or group of users.


The information in the PAB 1 (636) of the enhanced client 1 (630) may be uploaded to the platform (610) and synchronized with the information in the PAB 1 (616a) in the platform (610). During a synchronization process, the profile information in the PAB 1 (636) may be used to create and package a data file. In one embodiment, the data file is formatted in JSON. The data file may contain a plurality of entries with each entry having profile information for various individuals including, for example, name, email address, phone number, title, position, employer, social network account identification, as well as any other desirable profile information. After the data file is packaged, the enhanced client 1 (630) provides the data file to the XDF sync server (612). The XDF sync server (612) analyzes the profile information in the PAB 1 (616a). If the PAB 1 (616a) has no profile information, the XDF sync server (612) copies the information from the data file into the PAB 1 (616a). If the PAB 1 (616a) already has profile information, the XDF sync server (612) synchronizes the information from the data file with the profile information in the PAB 1 (616a) to generate synchronized profile information and to accordingly update the PAB 1 (616a). In one embodiment, the synchronization process occurs automatically and regularly. In one embodiment, the user may initiate the synchronization process.


In one embodiment, the information in the PAB 1 (616a) of the platform (610) may be downloaded (i.e., served) to the enhanced client 1 (630) and synchronized with the information in the PAB 1 (636) in the enhanced client 1 (630). During a synchronization process, the information in the PAB 1 (636) may be used to create and package a data file. In one embodiment, the data file is formatted in JSON. The data file may contain a plurality of entries with each entry having profile information for various individuals including, for example, name, email address, phone number, title, position, employer, social network account identification, as well as any other desirable profile information. After the data file is packaged, the enhanced client 1 (630) provides the data file to the XDF sync server (612). The XDF sync server (612) analyzes the profile information in the PAB 1 (616a) and compares it with the data file. The platform (610) generates a new data file reflecting the results of the comparison between the profile information in the PAB 1 (616a) and the data file created from the PAB 1 (636). The new data file is provided to the enhanced client 1 (630) and the stored in the PAB 1 (636).


The enhanced client 2 (640) is another exemplary client application that runs on the user terminal (101) of a different device for the user, and also provides the functionality of the components (111-125). In one embodiment, the enhanced client 1 (630) and the enhanced client 2 (640) are different client applications that run on different user terminals (101). The enhanced client 2 (640) includes a database (644), an indexing engine (642), and a PAB 1 (646). With respect to the synchronization process and communication with the LDAP server 1 (614a), the operation of the enhanced client 2 (640) is similar to the operation of the enhanced client 1 (630), as described herein. Thus, the description of the enhanced client 1 (630) and its operation applies, as is appropriate, to the enhanced client 2 (640) and its operation, and vice versa.


In one embodiment, updates to the PAB 1 (636) of the enhanced client 1 (630) may be propagated to the enhanced client 2 (640), and vice versa. For example, an update to the PAB 1 (636) of the enhanced client 1 (630) may be uploaded to the platform (610) during a synchronization process. During a synchronization process between the platform (610) and the enhanced client 2 (640), the update may be downloaded to the enhanced client 2 (640).


The clients (650a-n) are client applications that runs on the user terminal (101) of the user. In one embodiment, the clients (650a-n) are all configured to have LDAP support. The clients (650a-n) may include any software utility or client application that provides for management of messages, address books, contact information, and calendars including, for example, those provided by Microsoft (e.g., Outlook), Apple (e.g., mail and address book applications for iPhone; mail.app and address book for Mac; OS X, etc.), RIM (e.g., Blackberry), and other organizations. In one embodiment, the clients (650a-n) may include other types of software utilities and client applications. A local database (not shown) for each of the clients (650a-n) may include information in a native data format of the client application, including, for example, received messages (115), sent messages (117), and contact information manually entered by a user of the user terminal (101). In one embodiment, unlike the enhanced client 1 (630) and the enhanced client 2 (640), the clients (650a-n) of the user do not include a PAB 1.


In one embodiment, an LDAP server of the platform (610) may separately store data for multiple users supported by the platform (610). For example, to communicate with the clients (650a-n) of the user, the platform (610) includes the LDAP server 1 (614a) for the user or a group of users. The platform (610) includes the LDAP server N (614c) for the Nth user or group of users supported by the platform (610). In one embodiment, separate LDAP servers may be partitioned in the platform (610) by using OpenLDAP Software and/or other LDAP or directory-service software. In one embodiment, the LDAP server 1 (614a) is provisioned to the user after the enhanced client 1 (630) has synchronized the profile information in the PAB 1 (636) with the PAB 1 (616a) of the platform (610). In one embodiment, the user may be provided access to more than one LDAP server and the profile information in the corresponding PABs. In one embodiment, the platform (610) may include a dedicated LDAP server for every user supported by the platform (610).


As discussed in more detail below, the LDAP server 1 (614a) may be accessed by the user through LDAP configuration settings unique to the user. In one embodiment, login information of each user when provided to the platform (610) permits the user to access only the LDAP server 1 (614a), and associated profile information in the PAB 1 (616a), so that the profile information in the PAB 1 (616a) serves as a private data repository for the user. After the LDAP configuration settings for the user are provided to the platform, the platform (610) may provide (i.e., serve) profile information from the PAB 1 (616a) via the LDAP server 1 (614a) during use by the user of any of the clients (650a-n). For example, when the user provides a partial entry of contact information in a field of the client (650), the LDAP server 1 (614a) may provide profile information to the client (650) as a suggestion for the partial entry.



FIG. 7 illustrates an exemplary screen (700) of the enhanced client 1 (630) of the user. The user interface (700) includes a panel (702) that reflects the ability of the enhanced client 1 (630) to perform the functionality of the components (111-125). The panel (702) includes a search box (704) to perform searches against the PAB 1 (636). The panel (702) includes a profile section (706) that provides information about a contact of interest to the user. The panel (702) includes an actions section (708) to allow the user to perform various actions, such as request a phone number of the contact, schedule time with the contact, and email the contact. The panel (702) includes a utilities section (710) to allow the user to, for example, see the network of the contact, and view conversations, files exchanged, and appointments of the user.



FIG. 8 illustrates a screen 800 of the enhanced client 1 (630) having a pop-up window (802) that indicates the packaging of a data file in a synchronization process between the enhanced client 1 (630) and the platform (610). In one embodiment, the synchronization process is automatically initiated. In one embodiment, the synchronization process may be initiated by the user or by the platform (610) or both. As part of the synchronization process, the profile information in the PAB 1 (636) may be used to create and package a data file to provide to the XDF sync server (612). In FIG. 8, the process of packaging the data file is indicated to the user via the pop-up window (802). Once the packaging is complete, the data file is provided to the platform (610) to continue the synchronization process so that the profile information in the PAB 1 (636) of the enhanced client 1 (630) may be provided to the PAB 1 (616a) of the platform (610), as discussed above.



FIG. 9 illustrates an exemplary screen (900) of the client (650) to configure the client (650) to allow communication with the LDAP server 1 (614a) that supports the user. In one embodiment, the screen (900) is dynamically generated for the user after log in to the platform (610). Before configuration of the clients (650a-n), the LDAP server 1 (614a) has already been provisioned to the user. The screen (900) includes an automatic configuration section (902) that allows the user to click on a link (904) to automatically configure the settings related to the LDAP server 1 (614a) for the particular client (650) through use of a configuration file. In the illustrated embodiment, clicking on the link (904) automatically configures the client (650) for the LDAP server 1 (614a) when the client (650) is the iPhone. In one embodiment, other links may be provided to automatically configure the additional or alternate clients (605a-n) for the LDAP server 1 (614a).


The screen (900) also includes a configuration settings section (906). The configuration settings section (906) includes configuration settings data to allow communications with the LDAP server 1 (614a). The configuration settings data is to be manually entered by the user into the clients (650a-n) that may not have an associated link to automatically perform the configuration. In one embodiment, the configurations settings data is obtained from the configuration settings section (906), which includes a server field (908), a port field (910), an SSL field (912), a search base field (914), a scope field (916), an authentication field (918), a user name field (920), and a password field (922). The server field (908) indicates a DNS name or an IP address for a particular server associated with the platform (610). The port field (910) indicates a port number to which the client (650) will connect. The SSL field (912) indicates whether SSL will be used. The search base field (914) indicates the search base DN at or below which entries will be matched against a search operation. The scope field (916) indicates level of subtree of entries that should be considered when processing the search operation. The authentication field (918) indicates whether the access to the LDAP server 1 (614a) requires authentication. The user name field (920) indicates the user name assigned to the user. The password field (922) indicates the password of the user. In one embodiment, the user name and the password may be unique to each user.


In one embodiment, the values provided for the fields of the configuration setting section (906) may be different from those described and illustrated. In one embodiment, the configuration settings data and thus the configuration setting section (906) may contain additional or fewer fields. In one embodiment, the set of values in the fields of the configuration setting section (906) may be unique to each user.



FIG. 10 illustrates a window (1001) of a screen (1000) of the client (650) to allow the user to manually enter the configuration settings data so that the client (650) is configured to communicate with the LDAP server 1 (614a). The window (1001) includes a name field (1002), a server field (1004), a port field (1006), an SSL field (1008), a search base field (1010), a scope field (1012), an authentication field (1014), a user name field (1016), and a password field (1018). The name field (1002) indicates the name of the LDAP server 1 (614a) to which the client (650) will connect. As shown in FIG. 10, the configuration settings data have been manually entered into their respective fields of the window (1001) by the user. The user may click on a save button (1020) to save the entered configuration settings data. The user may click on a cancel button (1022) to exit from the window (1001).



FIG. 11 illustrates a screen (1100) of the client (650). In the illustrated embodiment, the client (650) is a mail application (e.g., mail.app). In one embodiment, the client (650) is another client application. When a new message button (1102) is clicked on by the user, a new message screen (1200) is displayed by the client (650), as shown in FIG. 12. The new message screen (1200) includes a To: field (1202), a Cc: field (1205), and a suggestion window (1207) that extends from the To: field (1202). In the illustrated embodiment, the user has provided the partial entry “Joe” in the To: field (1202) to address a message to a desired contact. Based on the partial entry “Joe”, the client (650) provides a first suggestion (1204) of “Joe Britton <brittonj@yahoo-inc.com>” in the To: field (1202) as contact information potentially desired by the user. The first suggestion (1204) also appears in the suggestion window (1207). The first suggestion (1204) is provided by the local database of the client (650).


Based on the partial entry of “Joe”, a second suggestion (1208) of “‘Joe Davis (Xobni)’<joe.davis@metova.com> as profile information potentially desired by the user also appears in a second position in the suggestion window (1207). The second suggestion (1208) is provided from the LDAP server 1 (614a). In this way, the suggestion of contact information as the user enters data in a field of the client (650) may be supplemented by the LDAP server 1 (614a) even when, in contrast to the enhanced client 1 (630), the client (650) does not have a PAB 1.


In the illustrated embodiment, contact information provided by the LDAP server 1 (614a) is displayed below contact information provided by the local database of the client (650). In one embodiment, the profile information provided by the LDAP server 1 (614a) is sometimes or always displayed above contact information provided by the local database of the client (650).


In one embodiment, the profile information provided by the LDAP server 1 (614a), when displayed, is marked in any manner (e.g., “Xobni”) to indicate the LDAP server 1 (614a) as its source. In one embodiment, the contact information provided by the local database of the client (650), when displayed, is marked in any manner to indicate the local database as its source. In one embodiment, the source of contact information and profile information, when displayed, is not indicated.



FIG. 13 illustrates a new message screen (1300) of the client (650). The new message screen (1300) includes a Cc: field (1302). In one embodiment, the new message screen (1300) is the new message screen (1200) after the selection of a contact desired by the user in the To: field (1202). In the illustrated embodiment, the user has provided the partial entry “La Donna” in the Cc: field (1302). Based on the partial entry “La Donna”, the local database of the client (650) does not provide any suggestions as contact information potentially desired by the user. However, based on the partial entry “La Donna”, the LDAP server 1 (614a) provides a suggestion (1304) of “La Donna Higgins (Xobni) <ladonna.higgins@xobni.com>” as profile information potentially desired by the user. The suggestion (1304) appears in the Cc: field (1302). Thus, even when the local database of the client (650) fails to provide suggested contact information, the LDAP server 1 (614a) may succeed in providing profile information to the client (650) to display as a suggestion for the user.



FIG. 14 shows a flow chart (1400) for the client (650) to receive profile information from the LDAP server 1 (614a). In (1402), an LDAP server is provisioned for each user of a plurality of users. In (1404), profile information is received. In (1406), the profile information is stored in a database associated with the LDAP server. In (1408), via the LDAP server, a suggestion from the profile information is provided in response to a partial entry provided by the user to a first client associated with the user.


Some embodiments of the enhanced client 1 (630, the enhanced client 2 (640), and the clients (650a-n), and screens thereof, have been described above. In other embodiments, the client (650) may be any other client application with functionality for messaging, mail, contacts, calendaring, and/or other utilities.


In one embodiment, the enhanced client 1 (630) has been described as having the database (634) and the PAB 1 (636). In one embodiment, the information in the database (634) and the PAB 1 (636) are not identical. In one embodiment, the information in the database (634) and the PAB 1 (636) overlap with at least some identity. In one embodiment, the information in the database (634) and the PAB 1 (636) may be contained in one database with a stored indication as to the source of contact information and profile information as the database (634) or the PAB 1 (636).


In one embodiment, indications about the source for particular profile information in the PAB 1 may be stored in the PAB 1 and associated with the particular profile information.


In one embodiment, the PAB 1 (636), the PAB 1 (616a), and the PAB 1 (646) contain identical profile information after appropriate synchronization.


In one embodiment, the enhanced client 1 (630) has been described as providing the profile information of the PAB 1 (636) to the PAB 1 (616a) via the XDF sync server (612) and, in turn, serving profile information via the LDAP server 1 (614a) to the client (650). In one embodiment, the profile information from the LDAP server 1 (614a) may not come from the enhanced client 1 (630) or the enhanced client 2 (640). In one embodiment, the profile information, via the indexing engine (618a) in the platform (610), may be provided from the web application (670), the web application (660), and/or other sources that are not the enhanced client 1 (630) or the enhanced client 2 (640). The profile information may then be provided to the client (650) from the PAB 1 (616a) via the LDAP server 1 (614a).


In one embodiment, the LDAP server 1 (614a) is used to “pull” profile information from the LDAP server 1 (614a) to the client (650), as discussed above. In one embodiment, the LDAP server 1 (614a) may also be used to “push” data from the enhanced client 1 (630) and the enhanced client 2 (640). Rather than communicate with the XDF sync server (612), the enhanced client 1 (630) and the enhanced client 2 (640) communicate with and provide profile information to the LDAP server 1 (614a). The LDAP server (614a) synchronizes the profile information from the enhanced client 1 (630) and the enhanced client 2 (640) with the profile information in the PAB 1 (616a).


In one embodiment, the clients (650a-n) support LDAP. In one embodiment, the clients (650a-n) may support additional or alternate standard or open communication protocols other than LDAP. In one embodiment, another standard or open communication protocol other than LDAP may be additionally or alternately implemented in the platform (610) to support communications with the clients (650a-n).


In one embodiment, the LDAP server 1 (614a) through the LDAP server N (614c) may be implemented to provide open, standard access to contact information in social networks, such as Facebook, Myspace, and Linked-In.



FIG. 15 shows a data processing system, which can be used in various embodiments. While FIG. 15 illustrates various components of a computer system, it is not intended to represent any particular architecture or manner of interconnecting the components. Some embodiments may use other systems that have fewer or more components than those shown in FIG. 15.


In one embodiment, the user terminal (101) can be implemented as a data processing system, with fewer or more components, as illustrated in FIG. 15. When one or more components of the user terminal (101) are implemented on one or more remote servers, the servers can be implemented as a data processing system, with fewer or more components, as illustrated in FIG. 15.


In FIG. 15, the data processing system (1501) includes an inter-connect (1502) (e.g., bus and system core logic), which interconnects a microprocessor(s) (1503) and memory (1508). The microprocessor (1503) is coupled to cache memory (1504) in the example of FIG. 15.


The inter-connect (1502) interconnects the microprocessor(s) (1503) and the memory (1508) together and also interconnects them to a display controller, display device (1507), and to peripheral devices such as input/output (I/O) devices (1505) through an input/output controller(s) (1506).


Typical I/O devices include mice, keyboards, modems, network interfaces, printers, scanners, video cameras and other devices which are well known in the art. In some embodiments, when the data processing system is a server system, some of the I/O devices, such as printer, scanner, mice, and/or keyboards, are optional.


The inter-connect (1502) may include one or more buses connected to one another through various bridges, controllers and/or adapters. In one embodiment, the I/O controller (1506) includes a USB (Universal Serial Bus) adapter for controlling USB peripherals, and/or an IEEE-1394 bus adapter for controlling IEEE-1394 peripherals.


The memory (1508) may include ROM (Read Only Memory), volatile RAM (Random Access Memory), and non-volatile memory, such as hard drive, flash memory, etc.


Volatile RAM is typically implemented as dynamic RAM (DRAM) which requires power continually in order to refresh or maintain the data in the memory. Non-volatile memory is typically a magnetic hard drive, a magnetic optical drive, an optical drive (e.g., a DVD RAM), or other type of memory system which maintains data even after power is removed from the system. The non-volatile memory may also be a random access memory.


The non-volatile memory can be a local device coupled directly to the rest of the components in the data processing system. A non-volatile memory that is remote from the system, such as a network storage device coupled to the data processing system through a network interface such as a modem or Ethernet interface, can also be used.


In this description, various functions and operations may be described as being performed by or caused by software code to simplify description. However, those skilled in the art will recognize that what is meant by such expressions is that the functions result from execution of the code/instructions by a processor, such as a microprocessor. Alternatively, or in combination, the functions and operations can be implemented using special purpose circuitry, with or without software instructions, such as using Application-Specific Integrated Circuit (ASIC) or Field-Programmable Gate Array (FPGA). Embodiments can be implemented using hardwired circuitry without software instructions, or in combination with software instructions. Thus, the techniques are limited neither to any specific combination of hardware circuitry and software, nor to any particular source for the instructions executed by the data processing system.


While some embodiments can be implemented in fully functioning computers and computer systems, various embodiments are capable of being distributed as a computing product in a variety of forms and are capable of being applied regardless of the particular type of machine or computer-readable media used to actually effect the distribution.


At least some aspects disclosed can be embodied, at least in part, in software. That is, the techniques may be carried out in a computer system or other data processing system in response to its processor, such as a microprocessor, executing sequences of instructions contained in a memory, such as ROM, volatile RAM, non-volatile memory, cache or a remote storage device.


Routines executed to implement the embodiments may be implemented as part of an operating system or a specific application, component, program, object, module or sequence of instructions referred to as “computer programs.” The computer programs typically include one or more instructions set at various times in various memory and storage devices in a computer, and that, when read and executed by one or more processors in a computer, cause the computer to perform operations necessary to execute elements involving the various aspects.


A machine readable medium can be used to store software and data which when executed by a data processing system causes the system to perform various methods. The executable software and data may be stored in various places including for example ROM, volatile RAM, non-volatile memory and/or cache. Portions of this software and/or data may be stored in any one of these storage devices. Further, the data and instructions can be obtained from centralized servers or peer to peer networks. Different portions of the data and instructions can be obtained from different centralized servers and/or peer to peer networks at different times and in different communication sessions or in a same communication session. The data and instructions can be obtained in entirety prior to the execution of the applications. Alternatively, portions of the data and instructions can be obtained dynamically, just in time, when needed for execution. Thus, it is not required that the data and instructions be on a machine readable medium in entirety at a particular instance of time.


Examples of computer-readable media include but are not limited to recordable and non-recordable type media such as volatile and non-volatile memory devices, read only memory (ROM), random access memory (RAM), flash memory devices, floppy and other removable disks, magnetic disk storage media, optical storage media (e.g., Compact Disk Read-Only Memory (CD ROMS), Digital Versatile Disks (DVDs), etc.), among others. The computer-readable media may store the instructions.


The instructions may also be embodied in digital and analog communication links for electrical, optical, acoustical or other forms of propagated signals, such as carrier waves, infrared signals, digital signals, etc. However, propagated signals, such as carrier waves, infrared signals, digital signals, etc. are not tangible machine readable medium and are not configured to store instructions.


In general, a tangible machine readable medium includes any apparatus that provides (i.e., stores and/or transmits) information in a form accessible by a machine (e.g., a computer, network device, personal digital assistant, manufacturing tool, any device with a set of one or more processors, etc.).


In various embodiments, hardwired circuitry may be used in combination with software instructions to implement the techniques. Thus, the techniques are neither limited to any specific combination of hardware circuitry and software nor to any particular source for the instructions executed by the data processing system.


Although some of the drawings illustrate a number of operations in a particular order, operations which are not order dependent may be reordered and other operations may be combined or broken out. While some reordering or other groupings are specifically mentioned, others will be apparent to those of ordinary skill in the art and so do not present an exhaustive list of alternatives. Moreover, it should be recognized that the stages could be implemented in hardware, firmware, software or any combination thereof.


In the foregoing specification, the disclosure has been described with reference to specific exemplary embodiments thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.

Claims
  • 1. A method, comprising: provisioning, via a computing device, a lightweight directory access protocol (LDAP) server for each user of a plurality of users including a first user;receiving profile information, the profile information obtained from received messages and sent messages of the plurality of users;storing the profile information in a database associated with the LDAP server, wherein the profile information is stored as a plurality of profiles, each profile for a single person, each profile comprising information obtained from a social network server, and each profile having a relevancy score; andproviding, via the LDAP server, a plurality of suggestions from the profile information in response to a partial entry provided by the first user to a first client associated with the first user, the providing comprising selecting the suggestions based on relevancy scores of the plurality of profiles, and the plurality of suggestions supplementing a first suggestion provided, in response to the partial entry, locally from the first client, the plurality of suggestions to be marked with a visual indicator when displayed for viewing by a user on a user interface of the first client to indicate the LDAP server as its source, and the first suggestion provided locally to be displayed in a top position of the user interface relative to a lower position for display of the plurality of suggestions provided via the LDAP server, wherein each of the suggestions provided from the LDAP server is marked with the visual indicator, and the top position is above the lower position.
  • 2. The method of claim 1, wherein a server platform comprises the LDAP server.
  • 3. The method of claim 1, wherein a server platform comprises the database.
  • 4. The method of claim 1, wherein the first client supports LDAP.
  • 5. The method of claim 1, wherein the receiving comprises obtaining the profile information from a second client associated with the first user.
  • 6. The method of claim 5, further comprising synchronizing the profile information from the second client and the profile information in the database associated with the LDAP server to generate synchronized profile information.
  • 7. The method of claim 6, further comprising storing the synchronized profile information in the database associated with the LDAP server.
  • 8. The method of claim 6, further comprising synchronizing the synchronized profile information and profile information from a third client associated with the first user.
  • 9. The method of claim 1, wherein the receiving comprises obtaining the profile information from a web application provided by a remote server.
  • 10. The method of claim 9, further comprising synchronizing the profile information from the web application and the profile information in the database associated with the LDAP server to generate synchronized profile information.
  • 11. The method of claim 10, further comprising storing the synchronized profile information in the database associated with the LDAP server.
  • 12. The method of claim 1, wherein the receiving includes obtaining from a remote source, connected over a network, the profile information.
  • 13. The method of claim 1, wherein the receiving includes obtaining a packaged data file.
  • 14. The method of claim 1, further comprising synchronizing profile information from a remote source, connected over a network, and the profile information in the database associated with the LDAP server.
  • 15. The method of claim 1, further comprising synchronizing, via the LDAP server, the profile information from a remote source, connected over a network, and the profile information in the database associated with the LDAP server.
  • 16. The method of claim 15, wherein the remote source is a second client associated with the first user.
  • 17. The method of claim 1, further comprising providing configuration settings data to allow the first user to configure the first client for communication with the LDAP server.
  • 18. The method of claim 1, further comprising providing a configuration file to allow the first user to automatically configure the first client for communication with the LDAP server.
  • 19. A system, comprising: at least one processor; andmemory storing instructions configured to instruct the at least one processor to: provision a lightweight directory access protocol (LDAP) server for each user of a plurality of users including a first user;receive profile information, the profile information obtained from received messages and sent messages of the plurality of users;store the profile information in a database associated with the LDAP server, the profile information to be stored as a plurality of profiles, each profile being for a single person, each profile comprising information obtained from a social network server, and each profile having a relevancy score; andprovide, via the LDAP server, a plurality of suggestions from the profile information in response to a partial entry provided by the first user to a first client associated with the first user, the providing comprising selecting the suggestions based on relevancy scores of the plurality of profiles, and the plurality of suggestions supplementing a first suggestion provided locally from the first client, the plurality of suggestions to be marked with a visual indicator when displayed for viewing by a user on a user interface of the first client to indicate the LDAP server as its source, and the first suggestion to be displayed in a top position of the user interface relative to a lower position for display of the plurality of suggestions, wherein each of the suggestions provided from the LDAP server is marked with the visual indicator, the first suggestion provided locally from the first client is not marked with the visual indicator, and the top position is above the lower position.
  • 20. A non-transitory machine readable storage media storing a set of instructions, the instructions when executed causing at least one processor to: provision a lightweight directory access protocol (LDAP) server for each user of a plurality of users including a first user;receive profile information, the profile information obtained from received messages and sent messages of the plurality of users;store the profile information in a database associated with the LDAP server, wherein the profile information is stored as a plurality of profiles, each profile for a single person, and each profile having a relevancy score; andprovide, via the LDAP server, a plurality of suggestions from the profile information in response to a partial entry provided by the first user to a first client associated with the first user, the providing comprising selecting the suggestions based on relevancy scores of the plurality of profiles, and the plurality of suggestions supplementing a first suggestion provided locally from the first client, the plurality of suggestions to be marked with a visual indicator when displayed for viewing on the first client to indicate the LDAP server as its source, and the first suggestion to be displayed in a top position relative to a lower position for display of the plurality of suggestions, wherein each of the suggestions provided from the LDAP server is marked with the visual indicator, and the top position is above the lower position.
US Referenced Citations (463)
Number Name Date Kind
5396647 Thompson et al. Mar 1995 A
5610915 Elliott et al. Mar 1997 A
5966714 Huang et al. Oct 1999 A
6020884 MacNaughton et al. Feb 2000 A
6285999 Page Sep 2001 B1
6321187 Squier et al. Nov 2001 B1
6385644 Devine et al. May 2002 B1
6484196 Maurille Nov 2002 B1
6502131 Vaid Dec 2002 B1
6510453 Apfel et al. Jan 2003 B1
6560620 Ching May 2003 B1
6594654 Salam et al. Jul 2003 B1
6606744 Mikurak Aug 2003 B1
6721748 Knight et al. Apr 2004 B1
6816850 Culliss Nov 2004 B2
6931419 Lindquist Aug 2005 B1
6952805 Tafoya et al. Oct 2005 B1
6996777 Hiipakka Feb 2006 B2
7003724 Newman Feb 2006 B2
7058892 MacNaughton et al. Jun 2006 B1
7076533 Knox et al. Jul 2006 B1
7085745 Klug Aug 2006 B2
7103806 Horvitz Sep 2006 B1
7149985 Crosby Dec 2006 B1
7181518 Matsumoto et al. Feb 2007 B1
7185065 Holtzman et al. Feb 2007 B1
7237009 Fung et al. Jun 2007 B1
7246045 Rappaport et al. Jul 2007 B1
7328242 McCarthy et al. Feb 2008 B1
7359894 Liebman et al. Apr 2008 B1
7383307 Kirkland et al. Jun 2008 B2
7444323 Martinez et al. Oct 2008 B2
7475109 Fletcher et al. Jan 2009 B1
7475113 Stolze Jan 2009 B2
7478361 Peteanu et al. Jan 2009 B2
7512788 Choi et al. Mar 2009 B2
7512814 Chen et al. Mar 2009 B2
7536384 Venkataraman et al. May 2009 B2
7539676 Aravamudan May 2009 B2
7580363 Sorvari et al. Aug 2009 B2
7593995 He et al. Sep 2009 B1
7610341 Daniell Oct 2009 B2
7620407 Donald et al. Nov 2009 B1
7624103 Wiegering et al. Nov 2009 B2
7627598 Burke Dec 2009 B1
7634463 Katragadda et al. Dec 2009 B1
7639157 Whitley et al. Dec 2009 B1
7653695 Flury et al. Jan 2010 B2
7692653 Petro et al. Apr 2010 B1
7702730 Spataro et al. Apr 2010 B2
7707249 Spataro et al. Apr 2010 B2
7707509 Naono et al. Apr 2010 B2
7716140 Nielsen et al. May 2010 B1
7720916 Fisher et al. May 2010 B2
7725492 Sittig May 2010 B2
7743051 Kashyap et al. Jun 2010 B1
7752081 Calabria Jul 2010 B2
7756895 Emigh Jul 2010 B1
7756935 Gaucas Jul 2010 B2
7761436 Norton et al. Jul 2010 B2
7788260 Lunt Aug 2010 B2
7805492 Thatcher Sep 2010 B1
7818396 Dolin et al. Oct 2010 B2
7827208 Bosworth Nov 2010 B2
7827265 Cheever et al. Nov 2010 B2
7831692 French et al. Nov 2010 B2
7836045 Schachter Nov 2010 B2
7836132 Qureshi et al. Nov 2010 B2
7836134 Pantalone Nov 2010 B2
7849141 Bellegarda et al. Dec 2010 B1
7849142 Clegg et al. Dec 2010 B2
7853602 Gorti et al. Dec 2010 B2
7853881 Aly Assal et al. Dec 2010 B1
7870197 Lewis et al. Jan 2011 B2
7899806 Aravamudan Mar 2011 B2
7899871 Kumar et al. Mar 2011 B1
7908647 Polis et al. Mar 2011 B1
7949627 Aravamudan May 2011 B2
7970832 Perry, Jr. et al. Jun 2011 B2
7979569 Eisner et al. Jul 2011 B2
7991764 Rathod Aug 2011 B2
7996456 Gross Aug 2011 B2
8005806 Rupp et al. Aug 2011 B2
8055715 Bensky et al. Nov 2011 B2
8073928 Dolin et al. Dec 2011 B2
8086676 Palahnuk et al. Dec 2011 B2
8112437 Katragadda et al. Feb 2012 B1
8140566 Boerries et al. Mar 2012 B2
8161122 Sood et al. Apr 2012 B2
8200808 Ishida Jun 2012 B2
8204897 Djabarov et al. Jun 2012 B1
8284783 Maufer et al. Oct 2012 B1
8291019 Rochelle et al. Oct 2012 B1
8296179 Rennison Oct 2012 B1
8316315 Portnoy et al. Nov 2012 B2
8392409 Kashyap et al. Mar 2013 B1
8423545 Cort et al. Apr 2013 B2
8443441 Stolfo et al. May 2013 B2
8452745 Ramakrishna May 2013 B2
8463872 Pounds et al. Jun 2013 B2
8468168 Brezina et al. Jun 2013 B2
8495045 Wolf et al. Jul 2013 B2
8510389 Gurajada et al. Aug 2013 B1
8522257 Rupp et al. Aug 2013 B2
8549412 Brezina et al. Oct 2013 B2
8566306 Jones Oct 2013 B2
8600343 Brezina et al. Dec 2013 B2
8620935 Rubin et al. Dec 2013 B2
8661002 Smith et al. Feb 2014 B2
8706652 Yang et al. Apr 2014 B2
8745060 Brezina et al. Jun 2014 B2
8793625 Rhee et al. Jul 2014 B2
8818995 Guha Aug 2014 B1
8924956 Smith Dec 2014 B2
9009065 Reis et al. Apr 2015 B2
9020938 Cort et al. Apr 2015 B2
9058366 Brezina et al. Jun 2015 B2
9195969 Bau et al. Nov 2015 B2
9235848 Gourley et al. Jan 2016 B1
9275118 Brezina et al. Mar 2016 B2
9298783 Brezina et al. Mar 2016 B2
20010022792 Maeno et al. Sep 2001 A1
20010037407 Dragulev et al. Nov 2001 A1
20010049628 Icho Dec 2001 A1
20020007310 Long Jan 2002 A1
20020016818 Kirani et al. Feb 2002 A1
20020024536 Kahan et al. Feb 2002 A1
20020049751 Chen et al. Apr 2002 A1
20020054587 Baker et al. May 2002 A1
20020059402 Belanger May 2002 A1
20020059418 Bird et al. May 2002 A1
20020059425 Belfiore et al. May 2002 A1
20020073011 Brattain et al. Jun 2002 A1
20020073058 Kremer et al. Jun 2002 A1
20020076004 Brockenbrough et al. Jun 2002 A1
20020087647 Quine et al. Jul 2002 A1
20020091777 Schwartz Jul 2002 A1
20020103873 Ramanathan et al. Aug 2002 A1
20020103879 Mondragon Aug 2002 A1
20020107991 Maguire et al. Aug 2002 A1
20020116396 Somers et al. Aug 2002 A1
20020143871 Meyer et al. Oct 2002 A1
20020152216 Bouthors Oct 2002 A1
20020194502 Sheth et al. Dec 2002 A1
20030028525 Santos et al. Feb 2003 A1
20030037116 Nolan et al. Feb 2003 A1
20030114956 Cullen et al. Jun 2003 A1
20030120608 Pereyra Jun 2003 A1
20030142125 Salmimaa et al. Jul 2003 A1
20030167324 Farnham et al. Sep 2003 A1
20030204439 Cullen, III Oct 2003 A1
20030217106 Adar et al. Nov 2003 A1
20030220835 Barnes, Jr. Nov 2003 A1
20030220978 Rhodes Nov 2003 A1
20030220989 Tsuji et al. Nov 2003 A1
20030233419 Beringer Dec 2003 A1
20040002903 Stolfo et al. Jan 2004 A1
20040015554 Wilson Jan 2004 A1
20040034537 Gengarella et al. Feb 2004 A1
20040039630 Begole et al. Feb 2004 A1
20040056901 March et al. Mar 2004 A1
20040068545 Daniell et al. Apr 2004 A1
20040073616 Fellenstein et al. Apr 2004 A1
20040078443 Malik Apr 2004 A1
20040078444 Malik Apr 2004 A1
20040078445 Malik Apr 2004 A1
20040100497 Quillen et al. May 2004 A1
20040122904 Kim Jun 2004 A1
20040128355 Chao et al. Jul 2004 A1
20040128356 Bernstein et al. Jul 2004 A1
20040133809 Dahl et al. Jul 2004 A1
20040153504 Hutchinson et al. Aug 2004 A1
20040162878 Lewis et al. Aug 2004 A1
20040174964 Koch Sep 2004 A1
20040177048 Klug Sep 2004 A1
20040186851 Jhingan et al. Sep 2004 A1
20040202117 Wilson et al. Oct 2004 A1
20040205002 Layton Oct 2004 A1
20040215726 Arning et al. Oct 2004 A1
20040236749 Cortright et al. Nov 2004 A1
20040260756 Forstall et al. Dec 2004 A1
20040268229 Paoli et al. Dec 2004 A1
20050027699 Awadallah Feb 2005 A1
20050027779 Schinner Feb 2005 A1
20050038687 Galdes Feb 2005 A1
20050049896 Giunta Mar 2005 A1
20050055639 Fogg Mar 2005 A1
20050060638 Mathew et al. Mar 2005 A1
20050076090 Thuerk Apr 2005 A1
20050076221 Olkin et al. Apr 2005 A1
20050080868 Malik Apr 2005 A1
20050090911 Ingargiola et al. Apr 2005 A1
20050091272 Smith et al. Apr 2005 A1
20050091314 Blagsvedt et al. Apr 2005 A1
20050091401 Keohane et al. Apr 2005 A1
20050102361 Winjum et al. May 2005 A1
20050108273 Brebner May 2005 A1
20050138070 Huberman et al. Jun 2005 A1
20050138631 Bellotti et al. Jun 2005 A1
20050149620 Kirkland et al. Jul 2005 A1
20050159970 Buyukkokten et al. Jul 2005 A1
20050164704 Winsor Jul 2005 A1
20050165584 Boody et al. Jul 2005 A1
20050165893 Feinberg et al. Jul 2005 A1
20050172234 Chuchla Aug 2005 A1
20050188028 Brown et al. Aug 2005 A1
20050198159 Kirsch Sep 2005 A1
20050198299 Beck et al. Sep 2005 A1
20050198305 Pezaris et al. Sep 2005 A1
20050204009 Hazarika et al. Sep 2005 A1
20050213511 Reece et al. Sep 2005 A1
20050216300 Appelman et al. Sep 2005 A1
20050222890 Cheng et al. Oct 2005 A1
20050228881 Reasor et al. Oct 2005 A1
20050228899 Wendkos et al. Oct 2005 A1
20050235224 Arend et al. Oct 2005 A1
20050278317 Gross et al. Dec 2005 A1
20050278321 Vailaya Dec 2005 A1
20060004713 Korte et al. Jan 2006 A1
20060004892 Lunt Jan 2006 A1
20060004914 Kelly et al. Jan 2006 A1
20060015533 Wolf et al. Jan 2006 A1
20060020398 Vernon et al. Jan 2006 A1
20060031340 Mathew et al. Feb 2006 A1
20060031775 Sattler et al. Feb 2006 A1
20060047747 Erickson et al. Mar 2006 A1
20060053199 Pricken et al. Mar 2006 A1
20060056015 Nishiyama Mar 2006 A1
20060059151 Martinez et al. Mar 2006 A1
20060059238 Slater et al. Mar 2006 A1
20060064434 Gilbert et al. Mar 2006 A1
20060065733 Lee et al. Mar 2006 A1
20060075046 Yozell-Epstein et al. Apr 2006 A1
20060085752 Beadle et al. Apr 2006 A1
20060095502 Lewis et al. May 2006 A1
20060101285 Chen et al. May 2006 A1
20060101350 Scott May 2006 A1
20060106793 Liang May 2006 A1
20060123357 Okamura Jun 2006 A1
20060129844 Oshikiri Jun 2006 A1
20060136494 Oh Jun 2006 A1
20060168073 Kogan et al. Jul 2006 A1
20060173824 Bensky et al. Aug 2006 A1
20060173961 Turski et al. Aug 2006 A1
20060179415 Cadiz et al. Aug 2006 A1
20060195361 Rosenberg Aug 2006 A1
20060195474 Cadiz et al. Aug 2006 A1
20060195785 Portnoy et al. Aug 2006 A1
20060217116 Cassett et al. Sep 2006 A1
20060224675 Fox et al. Oct 2006 A1
20060242536 Yokokawa et al. Oct 2006 A1
20060242609 Potter et al. Oct 2006 A1
20060248151 Belakovskiy et al. Nov 2006 A1
20060256008 Rosenberg Nov 2006 A1
20060271630 Bensky et al. Nov 2006 A1
20060281447 Lewis et al. Dec 2006 A1
20060282303 Hale et al. Dec 2006 A1
20070005702 Tokuda et al. Jan 2007 A1
20070005715 LeVasseur et al. Jan 2007 A1
20070005750 Lunt et al. Jan 2007 A1
20070011367 Scott et al. Jan 2007 A1
20070016647 Gupta et al. Jan 2007 A1
20070022447 Arseneau et al. Jan 2007 A1
20070060328 Zrike et al. Mar 2007 A1
20070071187 Apreutesei et al. Mar 2007 A1
20070073652 Taboada Mar 2007 A1
20070078884 Ott Apr 2007 A1
20070083651 Ishida Apr 2007 A1
20070088687 Bromm et al. Apr 2007 A1
20070106780 Farnham et al. May 2007 A1
20070112761 Xu et al. May 2007 A1
20070115991 Ramani et al. May 2007 A1
20070123222 Cox et al. May 2007 A1
20070124432 Holtzman et al. May 2007 A1
20070129977 Forney Jun 2007 A1
20070130527 Kim Jun 2007 A1
20070135110 Athale et al. Jun 2007 A1
20070143414 Daigle Jun 2007 A1
20070156732 Surendran et al. Jul 2007 A1
20070174432 Rhee et al. Jul 2007 A1
20070177717 Owens et al. Aug 2007 A1
20070185844 Schachter Aug 2007 A1
20070192490 Minhas Aug 2007 A1
20070198500 Lucovsky Aug 2007 A1
20070203991 Fisher et al. Aug 2007 A1
20070208802 Barman et al. Sep 2007 A1
20070214141 Sittig Sep 2007 A1
20070218900 Abhyanker Sep 2007 A1
20070244881 Cha et al. Oct 2007 A1
20070255794 Coutts Nov 2007 A1
20070266001 Williams et al. Nov 2007 A1
20070271527 Paas et al. Nov 2007 A1
20070273517 Govind Nov 2007 A1
20070282956 Staats Dec 2007 A1
20070288578 Pantalone Dec 2007 A1
20070294428 Guy et al. Dec 2007 A1
20080005247 Khoo Jan 2008 A9
20080005249 Hart Jan 2008 A1
20080010460 Schuschan Jan 2008 A1
20080031241 Toebes et al. Feb 2008 A1
20080037721 Yao et al. Feb 2008 A1
20080040370 Bosworth Feb 2008 A1
20080040474 Zuckerberg Feb 2008 A1
20080040475 Bosworth Feb 2008 A1
20080055263 Lemay et al. Mar 2008 A1
20080056269 Madhani et al. Mar 2008 A1
20080059428 Kinder Mar 2008 A1
20080065701 Lindstrom et al. Mar 2008 A1
20080071872 Gross Mar 2008 A1
20080077614 Roy Mar 2008 A1
20080104052 Ryan et al. May 2008 A1
20080113674 Baig May 2008 A1
20080114758 Rupp et al. May 2008 A1
20080119201 Kolber et al. May 2008 A1
20080120411 Eberle May 2008 A1
20080122796 Jobs et al. May 2008 A1
20080147639 Hartman et al. Jun 2008 A1
20080147810 Kumar et al. Jun 2008 A1
20080154751 Miles Jun 2008 A1
20080162347 Wagner Jul 2008 A1
20080162649 Lee et al. Jul 2008 A1
20080162651 Madnani Jul 2008 A1
20080163164 Chowdhary et al. Jul 2008 A1
20080170158 Jung et al. Jul 2008 A1
20080172362 Shacham et al. Jul 2008 A1
20080172464 Thattai et al. Jul 2008 A1
20080183832 Kirkland et al. Jul 2008 A1
20080201304 Sue Aug 2008 A1
20080216092 Serlet Sep 2008 A1
20080220752 Forstall et al. Sep 2008 A1
20080222279 Cioffi et al. Sep 2008 A1
20080222546 Mudd et al. Sep 2008 A1
20080235353 Cheever et al. Sep 2008 A1
20080235681 Barnett Sep 2008 A1
20080242277 Chen et al. Oct 2008 A1
20080243841 Bonnet et al. Oct 2008 A1
20080261569 Britt et al. Oct 2008 A1
20080270939 Mueller Oct 2008 A1
20080275748 John Nov 2008 A1
20080290987 Li Nov 2008 A1
20080293403 Quon et al. Nov 2008 A1
20080301166 Sugiyama et al. Dec 2008 A1
20080301175 Applebaum et al. Dec 2008 A1
20080301245 Estrada et al. Dec 2008 A1
20080307046 Baek et al. Dec 2008 A1
20080307066 Amidon et al. Dec 2008 A1
20080313650 Arnquist Dec 2008 A1
20080320417 Begley et al. Dec 2008 A1
20090005076 Forstall et al. Jan 2009 A1
20090010353 She et al. Jan 2009 A1
20090012806 Ricordi et al. Jan 2009 A1
20090029674 Brezina et al. Jan 2009 A1
20090030872 Brezina et al. Jan 2009 A1
20090030919 Brezina et al. Jan 2009 A1
20090030933 Brezina et al. Jan 2009 A1
20090030940 Brezina et al. Jan 2009 A1
20090031232 Brezina et al. Jan 2009 A1
20090031244 Brezina et al. Jan 2009 A1
20090031245 Brezina et al. Jan 2009 A1
20090037541 Wilson Feb 2009 A1
20090048994 Applebaum et al. Feb 2009 A1
20090054091 van Wijk et al. Feb 2009 A1
20090070412 D'Angelo Mar 2009 A1
20090077026 Yanagihara Mar 2009 A1
20090106415 Brezina et al. Apr 2009 A1
20090106676 Brezina et al. Apr 2009 A1
20090111495 Sjolin et al. Apr 2009 A1
20090112678 Luzardo Apr 2009 A1
20090119678 Shih May 2009 A1
20090125321 Charlebois et al. May 2009 A1
20090125462 Krishnaswamy et al. May 2009 A1
20090125517 Krishnaswamy et al. May 2009 A1
20090125585 Krishnaswamy et al. May 2009 A1
20090150251 Zhitomirsky Jun 2009 A1
20090156170 Rossano et al. Jun 2009 A1
20090157717 Palahnuk et al. Jun 2009 A1
20090171930 Vaughan et al. Jul 2009 A1
20090174680 Anzures et al. Jul 2009 A1
20090177754 Brezina et al. Jul 2009 A1
20090182788 Chung et al. Jul 2009 A1
20090187991 Freericks et al. Jul 2009 A1
20090191899 Wilson et al. Jul 2009 A1
20090198688 Venkataraman et al. Aug 2009 A1
20090213088 Hardy et al. Aug 2009 A1
20090216847 Krishnaswamy et al. Aug 2009 A1
20090228555 Joviak et al. Sep 2009 A1
20090234815 Boerries et al. Sep 2009 A1
20090249198 Davis et al. Oct 2009 A1
20090271370 Jagadish et al. Oct 2009 A1
20090276713 Eddy Nov 2009 A1
20090300546 Kwok et al. Dec 2009 A1
20090300596 Tyhurst et al. Dec 2009 A1
20090306981 Cromack et al. Dec 2009 A1
20090313573 Paek et al. Dec 2009 A1
20090319329 Aggarwal et al. Dec 2009 A1
20090327226 Brito et al. Dec 2009 A1
20100009332 Yaskin et al. Jan 2010 A1
20100030715 Eustice et al. Feb 2010 A1
20100049534 Whitnah Feb 2010 A1
20100057859 Shen et al. Mar 2010 A1
20100062753 Wen et al. Mar 2010 A1
20100077041 Cowan et al. Mar 2010 A1
20100082693 Hugg et al. Apr 2010 A1
20100094869 Ebanks Apr 2010 A1
20100094911 Bird Apr 2010 A1
20100131447 Creutz et al. May 2010 A1
20100153832 Markus et al. Jun 2010 A1
20100161729 Leblanc et al. Jun 2010 A1
20100164957 Lindsay Jul 2010 A1
20100169327 Lindsay Jul 2010 A1
20100174784 Levey et al. Jul 2010 A1
20100185610 Lunt Jul 2010 A1
20100191844 He et al. Jul 2010 A1
20100216509 Riemer et al. Aug 2010 A1
20100228560 Balasaygun et al. Sep 2010 A1
20100229096 Maiocco et al. Sep 2010 A1
20100229157 Ergan et al. Sep 2010 A1
20100229223 Shepard Sep 2010 A1
20100235375 Sidhu et al. Sep 2010 A1
20100241579 Bassett et al. Sep 2010 A1
20100250682 Goldberg et al. Sep 2010 A1
20100273456 Wolovitz et al. Oct 2010 A1
20100281535 Perry, Jr. et al. Nov 2010 A1
20100306185 Smith Dec 2010 A1
20100330972 Angiolillo Dec 2010 A1
20110010423 Thatcher et al. Jan 2011 A1
20110035451 Smith et al. Feb 2011 A1
20110040726 Crosbie et al. Feb 2011 A1
20110087969 Hein et al. Apr 2011 A1
20110119593 Jacobson et al. May 2011 A1
20110145219 Cierniak et al. Jun 2011 A1
20110173547 Lewis et al. Jul 2011 A1
20110191337 Cort Aug 2011 A1
20110191340 Cort Aug 2011 A1
20110191717 Cort et al. Aug 2011 A1
20110191768 Smith Aug 2011 A1
20110196802 Ellis et al. Aug 2011 A1
20110225293 Rathod Sep 2011 A1
20110276396 Rathod Nov 2011 A1
20110282905 Polis et al. Nov 2011 A1
20110291933 Holzer et al. Dec 2011 A1
20110298701 Holzer et al. Dec 2011 A1
20120011204 Morin et al. Jan 2012 A1
20120017158 Maguire et al. Jan 2012 A1
20120036254 Onuma Feb 2012 A1
20120054681 Cort Mar 2012 A1
20120060102 Shohfi et al. Mar 2012 A1
20120150979 Monaco Jun 2012 A1
20120246065 Yarvis et al. Sep 2012 A1
20120259834 Broder et al. Oct 2012 A1
20130080915 Lewis et al. Mar 2013 A1
20130091288 Shalunov et al. Apr 2013 A1
20130262477 Monaco et al. Oct 2013 A1
20140087687 Brezina et al. Mar 2014 A1
20140095433 Cort et al. Apr 2014 A1
20140100861 Ledet Apr 2014 A1
20140115086 Chebiyyam Apr 2014 A1
20140207761 Brezina et al. Jul 2014 A1
20140214981 Mallet et al. Jul 2014 A1
20140280097 Lee et al. Sep 2014 A1
20140287786 Bayraktar et al. Sep 2014 A1
20160070787 Brezina et al. Mar 2016 A1
20160182661 Brezina et al. Jun 2016 A1
Foreign Referenced Citations (13)
Number Date Country
0944002 Sep 1999 EP
2003006116 Jan 2003 JP
2007249307 Sep 2007 JP
20060056015 May 2006 KR
1020090068819 Jun 2009 KR
1020090112257 Oct 2009 KR
1020090115239 Nov 2009 KR
1020020060386 Aug 2012 KR
03098515 Nov 2003 WO
2007037875 Apr 2007 WO
2007143232 Dec 2007 WO
2012082886 Jun 2012 WO
2012082929 Jun 2012 WO
Non-Patent Literature Citations (29)
Entry
Carvalho, Vitor R. et al., “Ranking Users for Intelligent Message Addressing,” Proceedings of the 30th European Conference on Information Retrieval, Glasgow, England, Mar. 30-Apr. 3, 2008, pp. 321-333.
Elsayed, Tamer et al., “Personal Name Resolution in Email: A Heuristic Approach,” University of Maryland Technical Report No. TR-LAMP-150, Mar. 17, 2008.
Microsoft Corporation, “About AutoComplete name suggesting,” located at http://office.microsoft.com/en-us/outlook/HP063766471033.aspx, 2003.
Bernstein, Michael S. et al., “Enhancing Directed Content Sharing on the Web,” Proceedings of the 28th International Conference on Human Factors in Computing Systems, Atlanta, GA, Apr. 10-15, 2010, pp. 971-980.
International Patent Application PCT/US10/34782, International Search Report, Dec. 22, 2010.
International Patent Application PCT/US10/34782, Written Opinion, Dec. 22, 2010.
International Patent Application PCT/US10/35405, International Search Report and Written Opinion, Jan. 3, 2011.
International Patent Application PCT/US10/56560, International Search Report and Written Opinion, Jun. 21 2011.
International Patent Application PCT/US12/043523, International Search Report and Written Opinion, Nov. 28, 2012.
Oberhaus, Kristin, “Look for Cues: Targeting Without Personally Identifiable Information,” W3i, LLC blog entry located at http://blog.w3i.com/2009/09/03/looking-for-cues-targeting-without-personally-identifiable-information/, Sep. 3, 2009.
W3i, LLC, “Advertiser Feedback System (AFS),” company product description. Sep. 22, 2009.
Wikimedia Foundation, Inc., “Machine Learning,” Wikipedia encyclopedia entry located at http://en.wikipedia.org/wiki/Machine—learning, Jan. 30, 2011.
Android-Tips.com, “Android Tips & Tricks: How to Import Contacts into Android Phone,” located at http://android-tips.com/how-to-import-contacts-into-android/, Nov. 17, 2008 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
Culotta, Aron et al., “Extracting Social Networks and Contact Information from Email and the Web,” Proceedings of the First Conference on Email and Anti-Spam (CEAS), Mountain View, CA, Jul. 30-31, 2004 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
European Patent Application No. 11849271.9, Extended Search Report, Apr. 3, 2014.
European Patent Application No. 12801970.0, Extended Search Report, Oct. 23, 2014.
European Patent Application 12801998.1, Extended Search Report, Feb. 10, 2015.
Extended European Search Report, EP 10 78 3783, dated Mar. 24, 2014.
Fitzpatrick, Brad, “AddressBooker,” Github Social Coding, located at http://addressbooker.appspot.com/, Nov. 28, 2008 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
Google Inc. “OpenSocial Tutorial,” located at http://code.google.com/apis/opensocial/articles/tutorial/tutorial-0.8.html, Aug. 2008.
Google Inc., “Automatic Updating of Contacts,” Gmail help forum, located at http://74.125.4.16/support/forum/p/gmail/thread?tid=03f7b692150d9242&hl=en, Apr. 27, 2009 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
Hillebrand, Tim, “Plaxo: The Smart Auto Update Address Book,” Smart Phone Mag, located at http://www.smartphonemag.com/cms/blogs/9/plaxo—the—smart—auto—update—address—book, Nov. 6, 2006 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
International Patent Application PCT/US10/52081, International Search Report and Written Opinion, May 20, 2011.
International Patent Application PCT/US11/64958, International Search Report and Written Opinion, Jul. 31, 2012.
International Patent Application PCT/US2011/064892, International Search Report and Written Opinion, Aug. 22, 2012.
International Patent Application PCT/US2012/043507, International Search Report and Written Opinion, Jan. 3, 2013.
OpenSocial Foundation, “Social Application Tutorial (v0.9),” located at http://wiki.opensocial.org/index.php?title=Social—Application—Tutorial, accessed Oct. 8, 2010.
PCWorld Communications, Inc., “Your Contacts Are Forever: Self-Updating Address Book,” located at http://www.pcworld.com/article/48192/your—contacts—are—forever—selfupdating—address—book.html, May 1, 2001 (document provided includes third-party comments submitted under the USPTO PeerToPatent program).
Provisional U.S. Appl. No. 61/407,018, filed Oct. 27, 2010.
Related Publications (1)
Number Date Country
20110145192 A1 Jun 2011 US