|  |  |  | Evolution API Reference: libebook, the Addressbook Library |  | 
|---|---|---|---|---|
                    EBook;
EBook*              e_book_new                          (ESource *source,
                                                         GError **error);
EBook*              e_book_new_default_addressbook      (GError **error);
EBook*              e_book_new_from_uri                 (const char *uri,
                                                         GError **error);
EBook*              e_book_new_system_addressbook       (GError **error);
gboolean            e_book_set_default_addressbook      (EBook *book,
                                                         GError **error);
gboolean            e_book_set_default_source           (ESource *source,
                                                         GError **error);
gboolean            e_book_remove                       (EBook *book,
                                                         GError **error);
gboolean            e_book_open                         (EBook *book,
                                                         gboolean only_if_exists,
                                                         GError **error);
gboolean            e_book_get_supported_fields         (EBook *book,
                                                         GList **fields,
                                                         GError **error);
gboolean            e_book_get_supported_auth_methods   (EBook *book,
                                                         GList **auth_methods,
                                                         GError **error);
gboolean            e_book_get_required_fields          (EBook *book,
                                                         GList **fields,
                                                         GError **error);
ESource*            e_book_get_source                   (EBook *book);
gboolean            e_book_is_online                    (EBook *book);
gboolean            e_book_is_opened                    (EBook *book);
gboolean            e_book_authenticate_user            (EBook *book,
                                                         const char *user,
                                                         const char *passwd,
                                                         const char *auth_method,
                                                         GError **error);
gboolean            e_book_get_contact                  (EBook *book,
                                                         const char *id,
                                                         EContact **contact,
                                                         GError **error);
gboolean            e_book_remove_contact               (EBook *book,
                                                         const char *id,
                                                         GError **error);
gboolean            e_book_remove_contacts              (EBook *book,
                                                         GList *ids,
                                                         GError **error);
gboolean            e_book_add_contact                  (EBook *book,
                                                         EContact *contact,
                                                         GError **error);
gboolean            e_book_commit_contact               (EBook *book,
                                                         EContact *contact,
                                                         GError **error);
gboolean            e_book_get_book_view                (EBook *book,
                                                         EBookQuery *query,
                                                         GList *requested_fields,
                                                         int max_results,
                                                         EBookView **book_view,
                                                         GError **error);
gboolean            e_book_get_contacts                 (EBook *book,
                                                         EBookQuery *query,
                                                         GList **contacts,
                                                         GError **error);
gboolean            e_book_get_changes                  (EBook *book,
                                                         char *changeid,
                                                         GList **changes,
                                                         GError **error);
void                e_book_free_change_list             (GList *change_list);
const char*         e_book_get_uri                      (EBook *book);
const char*         e_book_get_static_capabilities      (EBook *book,
                                                         GError **error);
gboolean            e_book_check_static_capability      (EBook *book,
                                                         const char *cap);
gboolean            e_book_is_writable                  (EBook *book);
gboolean            e_book_cancel                       (EBook *book,
                                                         GError **error);
gboolean            e_book_get_self                     (EContact **contact,
                                                         EBook **book,
                                                         GError **error);
gboolean            e_book_set_self                     (EBook *book,
                                                         EContact *contact,
                                                         GError **error);
gboolean            e_book_is_self                      (EContact *contact);
gboolean            e_book_get_addressbooks             (ESourceList **addressbook_sources,
                                                         GError **error);
void                (*EBookCallback)                    (EBook *book,
                                                         EBookStatus status,
                                                         gpointer closure);
void                (*EBookOpenProgressCallback)        (EBook *book,
                                                         const char *status_message,
                                                         short percent ,
                                                         gpointer closure);
void                (*EBookIdCallback)                  (EBook *book,
                                                         EBookStatus status,
                                                         const char *id,
                                                         gpointer closure);
void                (*EBookEListCallback)               (EBook *book,
                                                         EBookStatus status,
                                                         EList *list,
                                                         gpointer closure);
void                (*EBookListCallback)                (EBook *book,
                                                         EBookStatus status,
                                                         GList *list,
                                                         gpointer closure);
void                (*EBookContactCallback)             (EBook *book,
                                                         EBookStatus status,
                                                         EContact *contact,
                                                         gpointer closure);
void                (*EBookBookViewCallback)            (EBook *book,
                                                         EBookStatus status,
                                                         EBookView *book_view,
                                                         gpointer closure);
guint               e_book_async_open                   (EBook *book,
                                                         gboolean only_if_exists,
                                                         EBookCallback open_response,
                                                         gpointer closure);
guint               e_book_async_remove                 (EBook *book,
                                                         EBookCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_supported_fields   (EBook *book,
                                                         EBookEListCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_supported_auth_methods
                                                        (EBook *book,
                                                         EBookEListCallback cb,
                                                         gpointer closure);
guint               e_book_async_authenticate_user      (EBook *book,
                                                         const char *user,
                                                         const char *passwd,
                                                         const char *auth_method,
                                                         EBookCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_contact            (EBook *book,
                                                         const char *id,
                                                         EBookContactCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_contacts           (EBook *book,
                                                         EBookQuery *query,
                                                         EBookListCallback cb,
                                                         gpointer closure);
guint               e_book_async_remove_contact         (EBook *book,
                                                         EContact *contact,
                                                         EBookCallback cb,
                                                         gpointer closure);
guint               e_book_async_remove_contact_by_id   (EBook *book,
                                                         const char *id,
                                                         EBookCallback cb,
                                                         gpointer closure);
guint               e_book_async_remove_contacts        (EBook *book,
                                                         GList *ids,
                                                         EBookCallback cb,
                                                         gpointer closure);
gboolean            e_book_async_add_contact            (EBook *book,
                                                         EContact *contact,
                                                         EBookIdCallback cb,
                                                         gpointer closure);
guint               e_book_async_commit_contact         (EBook *book,
                                                         EContact *contact,
                                                         EBookCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_book_view          (EBook *book,
                                                         EBookQuery *query,
                                                         GList *requested_fields,
                                                         int max_results,
                                                         EBookBookViewCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_changes            (EBook *book,
                                                         char *changeid,
                                                         EBookListCallback cb,
                                                         gpointer closure);
guint               e_book_async_get_required_fields    (EBook *book,
                                                         EBookEListCallback cb,
                                                         gpointer closure);
"auth-required" : Run Last "backend-died" : Run Last "connection-status" : Run Last "writable-status" : Run Last
Represents a complete addressbook. Event notifications and callbacks go to the EBookListener. Contrast with EBookView, which represents a search of the addressbook.
EBook* e_book_new (ESource *source, GError **error);
Creates a new EBook corresponding to the given source.  There are
only two operations that are valid on this book at this point:
e_book_open(), and e_book_remove().
| 
 | An ESource pointer | 
| 
 | A GError pointer | 
| Returns : | a new but unopened EBook. | 
EBook* e_book_new_default_addressbook (GError **error);
Creates a new EBook corresponding to the user's default addressbook. See the documentation for e_book_new for further information.
| 
 | A GError pointer | 
| Returns : | a new but unopened EBook. | 
EBook* e_book_new_from_uri (const char *uri, GError **error);
Creates a new EBook corresponding to the given uri. See the documentation for e_book_new for further information.
| 
 | the URI to load | 
| 
 | A GError pointer | 
| Returns : | a new but unopened EBook. | 
EBook* e_book_new_system_addressbook (GError **error);
Creates a new EBook corresponding to the user's system addressbook. See the documentation for e_book_new for further information.
| 
 | A GError pointer | 
| Returns : | a new but unopened EBook. | 
gboolean e_book_set_default_addressbook (EBook *book, GError **error);
sets the ESource of the EBook as the "default" addressbook. This is the source that will be loaded in the e_book_get_default_addressbook call.
| 
 | An EBook pointer | 
| 
 | A GError pointer | 
| Returns : | TRUEif the setting was stored in libebook's ESourceList, otherwiseFALSE. | 
gboolean            e_book_set_default_source           (ESource *source,
                                                         GError **error);
sets source as the "default" addressbook.  This is the source that
will be loaded in the e_book_get_default_addressbook call.
| 
 | An ESource pointer | 
| 
 | A GError pointer | 
| Returns : | TRUEif the setting was stored in libebook's ESourceList, otherwiseFALSE. | 
gboolean e_book_remove (EBook *book, GError **error);
Removes the backing data for this EBook. For example, with the file backend this deletes the database file. You cannot get it back!
| 
 | an EBook | 
| 
 | a GError to set on failure | 
| Returns : | TRUEon success,FALSEon failure. | 
gboolean e_book_open (EBook *book, gboolean only_if_exists, GError **error);
Opens the addressbook, making it ready for queries and other operations.
| 
 | an EBook | 
| 
 | if TRUE, fail if this book doesn't already exist, otherwise create it first | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif the book was successfully opened,FALSEotherwise. | 
gboolean e_book_get_supported_fields (EBook *book, GList **fields, GError **error);
Gets a list of fields that can be stored for contacts
in this book. Other fields may be discarded. The list
will contain pointers to allocated strings, and both the
GList and the strings must be freed by the caller.
| 
 | an EBook | 
| 
 | a GList of fields to set on success | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_get_supported_auth_methods (EBook *book, GList **auth_methods, GError **error);
Queries book for the list of authentication methods it supports.
The list will contain pointers to allocated strings, and both the
GList and the strings must be freed by the caller.
| 
 | an EBook | 
| 
 | a GList of auth methods to set on success | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_get_required_fields (EBook *book, GList **fields, GError **error);
Gets a list of fields that are required to be filled in for
all contacts in this book. The list will contain pointers
to allocated strings, and both the GList and the strings
must be freed by the caller.
| 
 | an EBook | 
| 
 | a GList of fields to set on success | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise. | 
ESource* e_book_get_source (EBook *book);
Get the ESource that this book has loaded.
| 
 | an EBook | 
| Returns : | The source. | 
gboolean e_book_is_online (EBook *book);
Check if this book is connected.
| 
 | an EBook | 
| Returns : | TRUEif this book is connected, otherwiseFALSE. | 
gboolean e_book_is_opened (EBook *book);
Check if this book has been opened.
| 
 | and EBook | 
| Returns : | TRUEif this book has been opened, otherwiseFALSE. | 
gboolean e_book_authenticate_user (EBook *book, const char *user, const char *passwd, const char *auth_method, GError **error);
Authenticates user with passwd, using the auth method
auth_method.  auth_method must be one of the authentication
methods returned using e_book_get_supported_auth_methods.
| 
 | an EBook | 
| 
 | a string | 
| 
 | a string | 
| 
 | a string | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_get_contact (EBook *book, const char *id, EContact **contact, GError **error);
Fills in contact with the contents of the vcard in book
corresponding to id.
gboolean e_book_remove_contact (EBook *book, const char *id, GError **error);
Removes the contact with id id from book.
| 
 | an EBook | 
| 
 | a string | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_remove_contacts (EBook *book, GList *ids, GError **error);
Removes the contacts with ids from the list ids from book.  This is
always more efficient than calling e_book_remove_contact_by_id if you
have more than one id to remove, as some backends can implement it
as a batch request.
| 
 | an EBook | 
| 
 | an GList of const char *id's | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_add_contact (EBook *book, EContact *contact, GError **error);
Adds contact to book.
gboolean e_book_commit_contact (EBook *book, EContact *contact, GError **error);
Applies the changes made to contact to the stored version in
book.
gboolean e_book_get_book_view (EBook *book, EBookQuery *query, GList *requested_fields, int max_results, EBookView **book_view, GError **error);
Query book with query, creating a EBookView in book_view with the fields
specified by requested_fields and limited at max_results records. On an
error, error is set and FALSE returned.
| 
 | an EBook | 
| 
 | an EBookQuery | 
| 
 | a GList containing the names of fields to return, or NULL for all | 
| 
 | the maximum number of contacts to show (or 0 for all) | 
| 
 | A EBookView pointer, will be set to the view | 
| 
 | a GError to set on failure | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_get_contacts (EBook *book, EBookQuery *query, GList **contacts, GError **error);
Query book with query, setting contacts to the list of contacts which
matched. On failed, error will be set and FALSE returned.
| 
 | an EBook | 
| 
 | an EBookQuery | 
| 
 | a GList pointer, will be set to the list of contacts | 
| 
 | a GError to set on failure | 
| Returns : | TRUEon success,FALSEotherwise | 
gboolean e_book_get_changes (EBook *book, char *changeid, GList **changes, GError **error);
Get the set of changes since the previous call to e_book_get_changes for a given change ID.
| 
 | an EBook | 
| 
 | the change ID | 
| 
 | return location for a GList of EBookChange items | 
| 
 | a GError to set on failure. | 
| Returns : | TRUE on success, FALSE otherwise | 
void e_book_free_change_list (GList *change_list);
Free the contents of change_list, and the list itself.
| 
 | a GList of EBookChange items | 
const char* e_book_get_uri (EBook *book);
Get the URI that this book has loaded. This string should not be freed.
| 
 | an EBook | 
| Returns : | The URI. | 
const char* e_book_get_static_capabilities (EBook *book, GError **error);
Get the list of capabilities which the backend for this address book supports. This string should not be freed.
| 
 | an EBook | 
| 
 | an GError to set on failure | 
| Returns : | The capabilities list | 
gboolean e_book_check_static_capability (EBook *book, const char *cap);
Check to see if the backend for this address book supports the capability
cap.
| 
 | an EBook | 
| 
 | A capability string | 
| Returns : | TRUEif the backend supportscap,FALSEotherwise. | 
gboolean e_book_is_writable (EBook *book);
Check if this book is writable.
| 
 | an EBook | 
| Returns : | TRUEif this book is writable, otherwiseFALSE. | 
gboolean e_book_cancel (EBook *book, GError **error);
Used to cancel an already running operation on book.  This
function makes a synchronous CORBA to the backend telling it to
cancel the operation.  If the operation wasn't cancellable (either
transiently or permanently) or had already comopleted on the server
side, this function will return E_BOOK_STATUS_COULD_NOT_CANCEL, and
the operation will continue uncancelled.  If the operation could be
cancelled, this function will return E_BOOK_ERROR_OK, and the
blocked e_book function corresponding to current operation will
return with a status of E_BOOK_STATUS_CANCELLED.
| 
 | an EBook | 
| 
 | a GError to set on failure | 
| Returns : | TRUEon success,FALSEotherwise | 
gboolean e_book_get_self (EContact **contact, EBook **book, GError **error);
Get the EContact referring to the user of the address book
and set it in contact and book.
gboolean e_book_set_self (EBook *book, EContact *contact, GError **error);
Specify that contact residing in book is the EContact that
refers to the user of the address book.
gboolean e_book_is_self (EContact *contact);
Check if contact is the user of the address book.
| 
 | an EContact | 
| Returns : | TRUEifcontactis the user,FALSEotherwise. | 
gboolean            e_book_get_addressbooks             (ESourceList **addressbook_sources,
                                                         GError **error);
Populate *addressbook_sources with the list of all sources which have been added to Evolution.
| 
 | A pointer to a ESourceList* to set | 
| 
 | A pointer to a GError* to set on error | 
| Returns : | TRUEifaddressbook_sourceswas set, otherwiseFALSE. | 
void (*EBookCallback) (EBook *book, EBookStatus status, gpointer closure);
| 
 | |
| 
 | |
| 
 | 
void (*EBookOpenProgressCallback) (EBook *book, const char *status_message, short percent , gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void (*EBookIdCallback) (EBook *book, EBookStatus status, const char *id, gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void (*EBookEListCallback) (EBook *book, EBookStatus status, EList *list, gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void (*EBookListCallback) (EBook *book, EBookStatus status, GList *list, gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void (*EBookContactCallback) (EBook *book, EBookStatus status, EContact *contact, gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void (*EBookBookViewCallback) (EBook *book, EBookStatus status, EBookView *book_view, gpointer closure);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
guint e_book_async_open (EBook *book, gboolean only_if_exists, EBookCallback open_response, gpointer closure);
Opens the addressbook, making it ready for queries and other operations. This function does not block.
| 
 | an EBook | 
| 
 | if TRUE, fail if this book doesn't already exist, otherwise create it first | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEif successful,TRUEotherwise. | 
guint e_book_async_remove (EBook *book, EBookCallback cb, gpointer closure);
Remove the backing data for this EBook. For example, with the file backend this deletes the database file. You cannot get it back!
| 
 | an EBook | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEif successful,TRUEotherwise. | 
guint e_book_async_get_supported_fields (EBook *book, EBookEListCallback cb, gpointer closure);
Gets a list of fields that can be stored for contacts
in this book. Other fields may be discarded. This
function does not block.
| 
 | an EBook | 
| 
 | function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUEif successful,FALSEotherwise. | 
guint               e_book_async_get_supported_auth_methods
                                                        (EBook *book,
                                                         EBookEListCallback cb,
                                                         gpointer closure);
Queries book for the list of authentication methods it supports.
This function does not block.
| 
 | an EBook | 
| 
 | function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUEif successful,FALSEotherwise. | 
guint e_book_async_authenticate_user (EBook *book, const char *user, const char *passwd, const char *auth_method, EBookCallback cb, gpointer closure);
Authenticate user with passwd, using the auth method
auth_method. auth_method must be one of the authentication
methods returned using e_book_get_supported_auth_methods.
This function does not block.
| 
 | an EBook | 
| 
 | user name | 
| 
 | password | 
| 
 | string indicating authentication method | 
| 
 | function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEif successful,TRUEotherwise. | 
guint e_book_async_get_contact (EBook *book, const char *id, EBookContactCallback cb, gpointer closure);
Retrieves a contact specified by id from book.
| 
 | an EBook | 
| 
 | a unique string ID specifying the contact | 
| 
 | function to call when operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEif successful,TRUEotherwise | 
guint e_book_async_get_contacts (EBook *book, EBookQuery *query, EBookListCallback cb, gpointer closure);
Query book with query.
| 
 | an EBook | 
| 
 | an EBookQuery | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEon success,TRUEotherwise | 
guint e_book_async_remove_contact (EBook *book, EContact *contact, EBookCallback cb, gpointer closure);
Removes contact from book.
guint e_book_async_remove_contact_by_id (EBook *book, const char *id, EBookCallback cb, gpointer closure);
Removes the contact with id id from book.
| 
 | an EBook | 
| 
 | a unique ID string specifying the contact | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUEif successful,FALSEotherwise | 
guint e_book_async_remove_contacts (EBook *book, GList *ids, EBookCallback cb, gpointer closure);
Removes the contacts with ids from the list ids from book.  This is
always more efficient than calling e_book_remove_contact_by_id() if you
have more than one id to remove, as some backends can implement it
as a batch request.
| 
 | an EBook | 
| 
 | a GList of const char *id's | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUEif successful,FALSEotherwise | 
gboolean e_book_async_add_contact (EBook *book, EContact *contact, EBookIdCallback cb, gpointer closure);
Adds contact to book without blocking.
guint e_book_async_commit_contact (EBook *book, EContact *contact, EBookCallback cb, gpointer closure);
Applies the changes made to contact to the stored version in
book without blocking.
guint e_book_async_get_book_view (EBook *book, EBookQuery *query, GList *requested_fields, int max_results, EBookBookViewCallback cb, gpointer closure);
Query book with query, creating a EBookView with the fields
specified by requested_fields and limited at max_results records.
| 
 | an EBook | 
| 
 | an EBookQuery | 
| 
 | a GList containing the names of fields to return, or NULL for all | 
| 
 | the maximum number of contacts to show (or 0 for all) | 
| 
 | a function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | FALSEif successful,TRUEotherwise | 
guint e_book_async_get_changes (EBook *book, char *changeid, EBookListCallback cb, gpointer closure);
Get the set of changes since the previous call to e_book_async_get_changes for a given change ID.
| 
 | an EBook | 
| 
 | the change ID | 
| 
 | function to call when operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUE on success, FALSE otherwise | 
guint e_book_async_get_required_fields (EBook *book, EBookEListCallback cb, gpointer closure);
Gets a list of fields that are required to be filled in for
all contacts in this book. This function does not block.
| 
 | an EBook | 
| 
 | function to call when the operation finishes | 
| 
 | data to pass to callback function | 
| Returns : | TRUEif the operation was started,FALSEotherwise. | 
"auth-required" signalvoid user_function (EBook *ebook, gpointer user_data) : Run Last
Authentication is required to access this source. You should call e_book_authenticate_user or e_book_async_authenticate_user.
| 
 | the object which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"backend-died" signalvoid user_function (EBook *ebook, gpointer user_data) : Run Last
The backend for this address book has died.
| 
 | the object which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"connection-status" signalvoid user_function (EBook *ebook, gboolean arg1, gpointer user_data) : Run Last
The connection status for this book is being reported.
| 
 | the object which received the signal. | 
| 
 | TRUE if the connection is online, FALSE otherwise. | 
| 
 | user data set when the signal handler was connected. | 
"writable-status" signalvoid user_function (EBook *ebook, gboolean arg1, gpointer user_data) : Run Last
The writable status for this book is being reported.
| 
 | the object which received the signal. | 
| 
 | TRUE if the book is writable, FALSE otherwise. | 
| 
 | user data set when the signal handler was connected. |