|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectcom.skype.api.SkypeObject
com.skype.api.ContactSearch
public class ContactSearch
This class encapsulates functionality for looking up contacts on the Skype network. Contacts can be searched by portion of their name, e-mail address, language preferences, etc.
Contact search is asynchronous. ContactSearch.Submit is a non-blocking function that initiates the search. Upon finding a matching contact, ContactSearch.OnNewResult event gets fired, that gives you the reference to the discovered contact. You can get up to 100 matching contacts per search. Note that you will need to keep a live reference of the ContactSearch object while the search is doing its work.
So, to perform a contact search:
- create a contact search object
- specify search terms and conditions
- submit search
- in ContactSearch.OnNewResult callback, update your UI
- in ContactSearch.OnChange, check for terminal values of P_CONTACT_SEARCH_STATUS and update the UI accordingly.
When the search has done its job, the ContactSearch.P_CONTACT_SEARCH_STATUS property will go to one of the terminal values.
The terminal values are:
- FINISHED - the search has stopped. Note that this does not mean any matches were actually found.
- FAILED - the search has failed.
- EXTENDABLE - this state should be considered the same as FINISHED. The feature of extending long search results is about to be deprecated. It is still possible for search objects to occasionally reach that state, so it should be handled in the UI (as FINISHED), but the extending feature itself should not be implemented in your UI.
There are three methods to create the ContactSearch objects.
A) Skype.CreateIdentitySearch
This method takes a string argument and looks for exact matches against Contact.P_SKYPENAME property. So for example, identity search for "echo" will return 0 results and search for "echo123" will return exactly one.
Identity in this case means skypename - contact search does not work with PSTN type contacts. However, it does work for SKYPE type contacts that have supplied P_PHONE_HOME, P_PHONE_OFFICE or P_PHONE_MOBILE values in their account data. To search for those, you will need to use complex search (see below).
Note that you should always check for boolean return value of the CreateIdentitySearch method. If the user submits a string that is not a valid skypename, the method will return false and the ContactSearchRef argument will return as NULL.
B) Skype.CreateBasicContactSearch
This method takes a string argument and looks for non-exact matches against both P_SKYPENAME and P_FULLNAME properties of the contact. If you intend to implement a simple, one-input search feature - this is the best method for you. The non-exact matching operates similarly to the SQL LIKE condition.
C) Skype.CreateContactSearch
This method enables you to implement advanced contact search, matching against multiple seach criteria. It takes no input arguments and expects search criteria to be added to the already constructed search object.
Criteria can be added with ContactSearch.AddStrTerm and ContactSearch.AddIntTerm methods.
These methods take Contact class porperty ID, condition, and the match pattern as inputs.
Only the following Contact properties can be used for search:
- P_SKYPENAME
- P_FULLNAME
- P_BIRTHDAY (uint)
- P_GENDER (uint: 1-male, 2-female)
- P_LANGUAGES
- P_COUNTRY
- P_PROVINCE
- P_CITY
- P_PHONE_HOME
- P_PHONE_OFFICE
- P_PHONE_MOBILE
- P_EMAILS
- P_HOMEPAGE
- P_ABOUT
String searches are case insensitive, i.e. search for echo123 also matches ECHO123
When adding multiple criteria, default behaviour is that the criterions are additive. I.e. a term skypename == "joe" followed by term country == "us" will result in intersection between all joes and everybody in US.
You can explicitly add an "OR" instead of "AND" between conditions, using the AddOr method.
By default, AND criteria are grouped together, before OR's, so that:
AddTerm(condition1)
AddTerm(condition2)
AddOr()
AddTerm(condition3)
AddTerm(condition4)
will result in the following logical statement:
(condition1 AND condition2) OR (condition3 AND condition4)
However, you can add "global" critera, by using the add_to_subs argument of the AddXX methods.
AddTerm(condition1)
AddTerm(condition2)
AddOr()
AddTerm(condition3)
AddTerm(condition4, add_to_subs=true)
which would result in:
(condition1 AND condition2 AND condition4) OR (condition3 AND condition4)
Every one of the contact properties can only be used once, per search. For example, you cannot create a search for two different P_FULLNAME patterns. The &valid argument will still return tue if you do this, but the last criteria for any given property will override all previous ones. So, a search like this:
cs->AddStrTerm(Contact.P_FULLNAME, ContactSearch.EQ, "John Smith", isValid);
cs->AddOr();
cs->AddStrTerm(Contact.P_FULLNAME, ContactSearch.EQ, "Ivan Sidorov", isValid);
will only return matches for "Ivan Sidorov" and none for "John Smith".
Some of the contact properties are automatically combined for purposes of search.
A search for P_SKYPENAME also returns matches from the P_FULLNAME property and vice versa.
So that this:
cs->AddStrTerm(Contact.P_SKYPENAME, ContactSearch.EQ, "john.smith", isValid);
..and this:
cs->AddStrTerm(Contact.P_FULLNAME, ContactSearch.EQ, "John Smith", isValid);
..and this:
cs->AddStrTerm(Contact.P_SKYPENAME, ContactSearch.EQ, "john.smith", isValid);
cs->AddOr();
cs->AddStrTerm(Contact.P_FULLNAME, ContactSearch.EQ, "John Smith", isValid);
..all search from both the P_FULLNAME and P_SKYPENAME fields.
Before using ContactGroup.Submit to start the search, you should always check whether the search criteria ended up being valid. This you can do with ContactSearch.IsValid method.
As you probably noticed, each of the AddXX methods also return a validity check boolean. However, it is a better practice to do the overall check as well, even if all the individual search criteria ended up looking Ok.
For example, lets take a search for contact's e-mail. This can be done with two different methods. Firstly we can use the ContactSearch.AddEmailTerm method. This method will actually validate whether the input is a valid e-mail address:
cs->AddEmailTerm ("test@test@test", isValid);
will return the isValid argument as false.
However, you can also add the e-mail search criterion as a simple string, like this:
cs->AddStrTerm(Contact.P_EMAILS, ContactSearch.EQ, "test@test@test@", isValid);
in which case the isValid will return true.
However, if you then check entire search object with:
cs->IsValid(isValid);
the isValid will correctly return false.
| Nested Class Summary | |
|---|---|
static class |
ContactSearch.CONDITION
List of available matching conditions that can be used in AddTerm methods. |
static interface |
ContactSearch.ContactSearchListener
|
static class |
ContactSearch.PROPERTY
Properties of the ContactSearch class |
static class |
ContactSearch.STATUS
Possible values for the ContactSearch.P_STATUS property. |
| Field Summary |
|---|
| Fields inherited from class com.skype.api.SkypeObject |
|---|
mObjectId, mPropCache, skype |
| Constructor Summary | |
|---|---|
ContactSearch(int oid,
Skype skype)
|
|
| Method Summary | |
|---|---|
boolean |
AddEmailTerm(java.lang.String email,
boolean add_to_subs)
Adds a search term against Contact.P_EMAILS property and pre-validates the value given in the email argument. |
boolean |
AddIntTerm(int prop,
ContactSearch.CONDITION cond,
int value,
boolean add_to_subs)
Adds a search term to a custom contact search object. |
boolean |
AddLanguageTerm(java.lang.String language,
boolean add_to_subs)
|
boolean |
AddMaxAgeTerm(int max_age_in_years,
boolean add_to_subs)
construct CONTACT_BIRTHDAY term based on current time |
boolean |
AddMinAgeTerm(int min_age_in_years,
boolean add_to_subs)
construct CONTACT_BIRTHDAY term based on current time |
void |
AddOr()
used to group terms (AddTerm(1), AddTerm(2), Or(), AddTerm(3), AddTerm(4), etc) |
boolean |
AddStrTerm(int prop,
ContactSearch.CONDITION cond,
java.lang.String value,
boolean add_to_subs)
Adds a string search term to a custom contact search object. |
void |
Extend()
extend if search is EXTENDABLE |
byte[] |
GetBinProperty(ContactSearch.PROPERTY prop)
|
boolean |
GetBooleanProperty(ContactSearch.PROPERTY prop)
|
int |
GetIntProperty(ContactSearch.PROPERTY prop)
|
java.lang.Object |
GetPropertyAsEnum(int propid)
|
Contact[] |
GetResults(int from,
int count)
result list is dynamically updated |
java.lang.String |
GetStrProperty(ContactSearch.PROPERTY prop)
|
boolean |
IsValid()
checks that terms list is non-empty and does not contain unsupported keys |
static int |
moduleID()
|
void |
Release()
releases results that are not referenced from elsewhere |
void |
Submit()
launch search |
| Methods inherited from class com.skype.api.SkypeObject |
|---|
close, getOid |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Constructor Detail |
|---|
public ContactSearch(int oid,
Skype skype)
| Method Detail |
|---|
public static final int moduleID()
public java.lang.Object GetPropertyAsEnum(int propid)
GetPropertyAsEnum in class SkypeObjectpublic java.lang.String GetStrProperty(ContactSearch.PROPERTY prop)
public int GetIntProperty(ContactSearch.PROPERTY prop)
public boolean GetBooleanProperty(ContactSearch.PROPERTY prop)
public byte[] GetBinProperty(ContactSearch.PROPERTY prop)
public boolean AddMinAgeTerm(int min_age_in_years,
boolean add_to_subs)
min_age_in_years - add_to_subs -
public boolean AddMaxAgeTerm(int max_age_in_years,
boolean add_to_subs)
max_age_in_years - add_to_subs -
public boolean AddEmailTerm(java.lang.String email,
boolean add_to_subs)
email - e-mail addres to search for. add_to_subs - This argument enables you to group conditions. See ContactSearch class details for more information.
public boolean AddLanguageTerm(java.lang.String language,
boolean add_to_subs)
language - add_to_subs -
public boolean AddStrTerm(int prop,
ContactSearch.CONDITION cond,
java.lang.String value,
boolean add_to_subs)
prop - Following Contact class string propkeys can be used for Contact search: cond - Search condition (ContactSearch.CONDITION) value - Value to match against. add_to_subs - This argument enables you to group conditions. See ContactSearch class details for more information.
public boolean AddIntTerm(int prop,
ContactSearch.CONDITION cond,
int value,
boolean add_to_subs)
prop - Propkey to search for. Either Contact.P_BIRTHDAY or Contact.P_GENDER cond - Search condition (ContactSearch.CONDITION) value - Value to match against. add_to_subs - This argument enables you to group conditions. See ContactSearch class details for more information. public void AddOr()
public boolean IsValid()
public void Submit()
public void Extend()
public void Release()
public Contact[] GetResults(int from,
int count)
from - count -
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||