| Top |  |  |  |  | 
| gchar * | cache-dir | Read / Write | 
| GProxyResolver * | proxy-resolver | Read | 
| ESourceRegistry * | registry | Read / Write / Construct Only | 
| gboolean | writable | Read / Write | 
This is the main server facing API for interfacing with addressbook backends, addressbook backends must implement methods on this class.
const gchar *
e_book_backend_get_cache_dir (EBookBackend *backend);
Returns the cache directory path used by backend
.
Since: 2.32
gchar *
e_book_backend_dup_cache_dir (EBookBackend *backend);
Thread-safe variation of e_book_backend_get_cache_dir().
Use this function when accessing backend
 from multiple threads.
The returned string should be freed with g_free() when no longer needed.
Since: 3.10
void e_book_backend_set_cache_dir (EBookBackend *backend,const gchar *cache_dir);
Sets the cache directory path for use by backend
.
Note that EBookBackend is initialized with a default cache directory path which should suffice for most cases. Backends should not override the default path without good reason.
Since: 2.32
EDataBook *
e_book_backend_ref_data_book (EBookBackend *backend);
Returns the EDataBook for backend
.  The EDataBook is essentially
the glue between incoming D-Bus requests and backend
's native API.
An EDataBook should be set only once after backend
 is first created.
If an EDataBook has not yet been set, the function returns NULL.
The returned EDataBook is referenced for thread-safety and must be
unreferenced with g_object_unref() when finished with it.
Since: 3.10
void e_book_backend_set_data_book (EBookBackend *backend,EDataBook *data_book);
Sets the EDataBook for backend
.  The EDataBook is essentially the
glue between incoming D-Bus requests and backend
's native API.
An EDataBook should be set only once after backend
 is first created.
Since: 3.10
GProxyResolver *
e_book_backend_ref_proxy_resolver (EBookBackend *backend);
Returns the GProxyResolver for backend
 (if applicable), as indicated
by the “proxy-uid” of backend
's “source”
or one of its ancestors.
The returned GProxyResolver is referenced for thread-safety and must
be unreferenced with g_object_unref() when finished with it.
Since: 3.12
ESourceRegistry *
e_book_backend_get_registry (EBookBackend *backend);
Returns the data source registry to which “source” belongs.
Since: 3.6
gboolean
e_book_backend_get_writable (EBookBackend *backend);
Returns whether backend
 will accept changes to its data content.
Since: 3.8
void e_book_backend_set_writable (EBookBackend *backend,gboolean writable);
Sets whether backend
 will accept changes to its data content.
Since: 3.8
gboolean
e_book_backend_is_opened (EBookBackend *backend);
Checks if backend
's storage has been opened (and
authenticated, if necessary) and the backend itself
is ready for accessing. This property is changed automatically
after the backend
 is successfully opened.
Since: 3.2
gboolean
e_book_backend_is_readonly (EBookBackend *backend);
Checks if we can write to backend
.
Since: 3.2
gchar * e_book_backend_get_backend_property (EBookBackend *backend,const gchar *prop_name);
Obtains the value of the backend property named prop_name
.
Freed the returned string with g_free() when finished with it.
Since: 3.10
gboolean e_book_backend_open_sync (EBookBackend *backend,GCancellable *cancellable,GError **error);
"Opens" the backend
.  Opening a backend is something of an outdated
concept, but the operation is hanging around for a little while longer.
This usually involves some custom initialization logic, and testing of
remote authentication if applicable.
If an error occurs, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_open (EBookBackend *backend,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously "opens" the backend
.  Opening a backend is something of
an outdated concept, but the operation is hanging around for a little
while longer.  This usually involves some custom initialization logic,
and testing of remote authentication if applicable.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_open_finish() to get the result of the operation.
| backend | an EBookBackend | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_open_finish (EBookBackend *backend,GAsyncResult *result,GError **error);
Finishes the operation started with e_book_backend_open().
If an error occurred, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_refresh_sync (EBookBackend *backend,GCancellable *cancellable,GError **error);
Initiates a refresh for backend
, if the backend
 supports refreshing.
The actual refresh operation completes on its own time.  This function
merely initiates the operation.
If an error occurs while initiating the refresh, the function will set
error
 and return FALSE.  If the backend
 does not support refreshing,
the function will set an E_CLIENT_ERROR_NOT_SUPPORTED error and return
FALSE.
| backend | an EBookBackend | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_refresh (EBookBackend *backend,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously initiates a refresh for backend
, if the backend
 supports
refreshing.  The actual refresh operation completes on its own time.  This
function, along with e_book_backend_refresh_finish(), merely initiates the
operation.
Once the refresh is initiated, callback
 will be called.  You can then
call e_book_backend_refresh_finish() to get the result of the initiation.
| backend | an EBookBackend | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_refresh_finish (EBookBackend *backend,GAsyncResult *result,GError **error);
Finishes the refresh initiation started with e_book_backend_refresh().
If an error occurred while initiating the refresh, the function will set
error
 and return FALSE.  If the backend
 does not support refreshing,
the function will set an E_CLIENT_ERROR_NOT_SUPPORTED error and return
FALSE.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_create_contacts_sync (EBookBackend *backend,const gchar * const *vcards,guint32 opflags,GQueue *out_contacts,GCancellable *cancellable,GError **error);
Creates one or more new contacts from vcards
, and deposits an EContact
instance for each newly-created contact in out_contacts
.
The returned EContact instances are referenced for thread-safety and
must be unreferenced with g_object_unref() when finished with them.
If an error occurs, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| vcards | a  | |
| opflags | bit-or of EBookOperationFlags | |
| out_contacts | a GQueue in which to deposit results | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_create_contacts (EBookBackend *backend,const gchar * const *vcards,guint32 opflags,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously creates one or more new contacts from vcards
.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_create_contacts_finish() to get the result of the
operation.
| backend | an EBookBackend | |
| vcards | a  | |
| opflags | bit-or of EBookOperationFlags | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_create_contacts_finish (EBookBackend *backend,GAsyncResult *result,GQueue *out_contacts,GError **error);
Finishes the operation started with e_book_backend_create_contacts().
An EContact instance for each newly-created contact is deposited in
out_contacts
.  The returned EContact instances are referenced for
thread-safety and must be unreferenced with g_object_unref() when
finished with them.
If an error occurred, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| out_contacts | a GQueue in which to deposit results | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_modify_contacts_sync (EBookBackend *backend,const gchar * const *vcards,guint32 opflags,GCancellable *cancellable,GError **error);
Modifies one or more contacts according to vcards
.
If an error occurs, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| vcards | a  | |
| opflags | bit-or of EBookOperationFlags | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_modify_contacts (EBookBackend *backend,const gchar * const *vcards,guint32 opflags,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously modifies one or more contacts according to vcards
.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_modify_contacts_finish() to get the result of the
operation.
| backend | an EBookBackend | |
| vcards | a  | |
| opflags | bit-or of EBookOperationFlags | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_modify_contacts_finish (EBookBackend *backend,GAsyncResult *result,GError **error);
Finishes the operation started with e_book_backend_modify_contacts().
If an error occurred, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_remove_contacts_sync (EBookBackend *backend,const gchar * const *uids,guint32 opflags,GCancellable *cancellable,GError **error);
Removes one or more contacts according to uids
.
If an error occurs, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| uids | a  | |
| opflags | bit-or of EBookOperationFlags | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_remove_contacts (EBookBackend *backend,const gchar * const *uids,guint32 opflags,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously removes one or more contacts according to uids
.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_remove_contacts_finish() to get the result of the
operation.
| backend | an EBookBackend | |
| uids | a  | [array zero-terminated=1] | 
| opflags | bit-or of EBookOperationFlags | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_remove_contacts_finish (EBookBackend *backend,GAsyncResult *result,GError **error);
Finishes the operation started with e_book_backend_remove_contacts().
If an error occurred, the function will set error
 and return FALSE.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| error | return location for a GError, or  | 
Since: 3.10
EContact * e_book_backend_get_contact_sync (EBookBackend *backend,const gchar *uid,GCancellable *cancellable,GError **error);
Obtains an EContact for uid
.
The returned EContact is referenced for thread-safety and must be
unreferenced with g_object_unref() when finished with it.
If an error occurs, the function will set error
 and return NULL.
| backend | an EBookBackend | |
| uid | a contact ID | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_get_contact (EBookBackend *backend,const gchar *uid,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously obtains an EContact for uid
.
When the operation is finished, callback
 will be called.  You can
then call e_book_backend_get_contact_finish() to get the result of the
operation.
| backend | an EBookBackend | |
| uid | a contact ID | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
EContact * e_book_backend_get_contact_finish (EBookBackend *backend,GAsyncResult *result,GError **error);
Finishes the operation started with e_book_backend_get_contact_finish().
The returned EContact is referenced for thread-safety and must be
unreferenced with g_object_unref() when finished with it.
If an error occurred, the function will set error
 and return NULL.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_get_contact_list_sync (EBookBackend *backend,const gchar *query,GQueue *out_contacts,GCancellable *cancellable,GError **error);
Obtains a set of EContact instances which satisfy the criteria specified
in query
, and deposits them in out_contacts
.
The returned EContact instances are referenced for thread-safety and
must be unreferenced with g_object_unref() when finished with them.
If an error occurs, the function will set error
 and return FALSE.
Note that an empty result set does not necessarily imply an error.
| backend | an EBookBackend | |
| query | a search query in S-expression format | |
| out_contacts | a GQueue in which to deposit results | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_get_contact_list (EBookBackend *backend,const gchar *query,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously obtains a set of EContact instances which satisfy the
criteria specified in query
.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_get_contact_list_finish() to get the result of the
operation.
| backend | an EBookBackend | |
| query | a search query in S-expression format | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_get_contact_list_finish (EBookBackend *backend,GAsyncResult *result,GQueue *out_contacts,GError **error);
Finishes the operation started with e_book_backend_get_contact_list().
The matching EContact instances are deposited in out_contacts
.  The
returned EContact instances are referenced for thread-safety and must
be unreferenced with g_object_unref() when finished with them.
If an error occurred, the function will set error
 and return FALSE.
Note that an empty result set does not necessarily imply an error.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| out_contacts | a GQueue in which to deposit results | |
| error | return location for a GError, or  | 
Since: 3.10
gboolean e_book_backend_get_contact_list_uids_sync (EBookBackend *backend,const gchar *query,GQueue *out_uids,GCancellable *cancellable,GError **error);
Obtains a set of ID strings for contacts which satisfy the criteria
specified in query
, and deposits them in out_uids
.
The returned ID strings must be freed with g_free() with finished
with them.
If an error occurs, the function will set error
 and return FALSE.
Note that an empty result set does not necessarily imply an error.
| backend | an EBookBackend | |
| query | a search query in S-expression format | |
| out_uids | a GQueue in which to deposit results | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_get_contact_list_uids (EBookBackend *backend,const gchar *query,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously obtains a set of ID strings for contacts which satisfy
the criteria specified in query
.
When the operation is finished, callback
 will be called.  You can then
call e_book_backend_get_contact_list_uids_finish() to get the result of
the operation.
| backend | an EBookBackend | |
| query | a search query in S-expression format | |
| cancellable | optional GCancellable object, or  | |
| callback | a GAsyncReadyCallback to call when the request is satisfied | |
| user_data | data to pass to the callback function | 
Since: 3.10
gboolean e_book_backend_get_contact_list_uids_finish (EBookBackend *backend,GAsyncResult *result,GQueue *out_uids,GError **error);
Finishes the operation started with
e_book_backend_get_contact_list_uids_finish().
ID strings for the matching contacts are deposited in out_uids
, and
must be freed with g_free() when finished with them.
If an error occurs, the function will set error
 and return FALSE.
Note that an empty result set does not necessarily imply an error.
| backend | an EBookBackend | |
| result | a GAsyncResult | |
| out_uids | a GQueue in which to deposit results | |
| error | return location for a GError, or  | 
Since: 3.10
void e_book_backend_start_view (EBookBackend *backend,EDataBookView *view);
Starts running the query specified by view
, emitting signals for
matching contacts.
void e_book_backend_stop_view (EBookBackend *backend,EDataBookView *view);
Stops running the query specified by view
, emitting no more signals.
void e_book_backend_add_view (EBookBackend *backend,EDataBookView *view);
Adds view
 to backend
 for querying.
void e_book_backend_remove_view (EBookBackend *backend,EDataBookView *view);
Removes view
 from backend
.
GList *
e_book_backend_list_views (EBookBackend *backend);
Returns a list of EDataBookView instances added with
e_book_backend_add_view().
The views returned in the list are referenced for thread-safety.
They must each be unreferenced with g_object_unref() when finished
with them.  Free the returned list itself with g_list_free().
An easy way to free the list properly in one step is as follows:
| 1 | g_list_free_full (list, g_object_unref); | 
Since: 3.8
gboolean (*EBookBackendForeachViewFunc) (EBookBackend *backend,EDataBookView *view,gpointer user_data);
Callback function used by e_book_backend_foreach_view().
Since: 3.34
gboolean e_book_backend_foreach_view (EBookBackend *backend,EBookBackendForeachViewFunc func,gpointer user_data);
Calls func
 for each existing view (as returned by e_book_backend_list_views()).
The func
 can return FALSE to stop early.
| backend | an EBookBackend | |
| func | an EBookBackendForeachViewFunc function to call. | [scope call] | 
| user_data | user data to pass to  | [closure func] | 
Since: 3.34
void e_book_backend_foreach_view_notify_progress (EBookBackend *backend,gboolean only_completed_views,gint percent,const gchar *message);
Notifies each view of the backend
 about progress. When only_completed_views
is TRUE, notifies only completed views.
| backend | an EBookBackend | |
| only_completed_views | whether notify in completed views only | |
| percent | percent complete | |
| message | message describing the operation in progress, or  | [nullable] | 
Since: 3.34
void e_book_backend_notify_update (EBookBackend *backend,const EContact *contact);
Notifies all of backend
's book views about the new or modified
contacts contact
.
e_data_book_respond_create_contacts() and e_data_book_respond_modify_contacts() call this
function for you. You only need to call this from your backend if
contacts are created or modified by another (non-PAS-using) client.
void e_book_backend_notify_remove (EBookBackend *backend,const gchar *id);
Notifies all of backend
's book views that the contact with UID
id
 has been removed.
e_data_book_respond_remove_contacts() calls this function for you. You only need to call this from your backend if contacts are removed by another (non-PAS-using) client.
void
e_book_backend_notify_complete (EBookBackend *backend);
Notifies all of backend
's book views that the current set of
notifications is complete; use this after a series of
e_book_backend_notify_update() and e_book_backend_notify_remove() calls.
void e_book_backend_notify_error (EBookBackend *backend,const gchar *message);
Notifies each backend listener about an error. This is meant to be used for cases where is no GError return possibility, to notify user about an issue.
Since: 3.2
void e_book_backend_notify_property_changed (EBookBackend *backend,const gchar *prop_name,const gchar *prop_value);
Notifies clients about property value change.
| backend | an EBookBackend | |
| prop_name | property name, which changed | |
| prop_value | new property value. | [nullable] | 
Since: 3.2
EDataBookDirect *
e_book_backend_get_direct_book (EBookBackend *backend);
Tries to create an EDataBookDirect for backend
 if
backend supports direct read access.
A new EDataBookDirect object, or NULL if
backend
does not support direct access. 
[transfer full][nullable]
Since: 3.8
void e_book_backend_configure_direct (EBookBackend *backend,const gchar *config);
This method is called on backend
 in direct read access mode.
The config
 argument is the same configuration string which
the same backend reported in the EDataBookDirect returned
by e_book_backend_get_direct_book().
The configuration string is optional and is used to ensure that direct access backends are properly configured to interface with the same data as the running server side backend.
Since: 3.8
gboolean e_book_backend_set_locale (EBookBackend *backend,const gchar *locale,GCancellable *cancellable,GError **error);
Notify the addressbook backend that the current locale has changed, this is important for backends which support ordered result lists which are locale sensitive.
| backend | an EBookBackend | |
| locale | the new locale for the addressbook | |
| cancellable | optional GCancellable object, or  | |
| error | return location for a GError, or  | 
Since: 3.12
gchar *
e_book_backend_dup_locale (EBookBackend *backend);
Fetches a copy of the currently configured locale for the addressbook
 A copy of the currently configured locale for the addressbook.
Free with g_free() when done with it.
Since: 3.12
EDataBookCursor * e_book_backend_create_cursor (EBookBackend *backend,EContactField *sort_fields,EBookCursorSortType *sort_types,guint n_fields,GError **error);
Creates a new EDataBookCursor for the given backend if the backend
has cursor support. If the backend does not support cursors then
an E_CLIENT_ERROR_NOT_SUPPORTED error will be set in error
.
Backends can also refuse to create cursors for some values of sort_fields
and report more specific errors.
The returned cursor belongs to backend
 and should be destroyed
with e_book_backend_delete_cursor() when no longer needed.
| backend | an EBookBackend | |
| sort_fields | the EContactFields to sort by | |
| sort_types | the EBookCursorSortTypes for the sorted fields | |
| n_fields | the number of fields in the  | |
| error | return location for a GError, or  | 
A newly created cursor, the cursor belongs
to the backend and should not be unreffed, or NULL. 
[transfer none]
Since: 3.12
gboolean e_book_backend_delete_cursor (EBookBackend *backend,EDataBookCursor *cursor,GError **error);
Requests backend
 to release and destroy cursor
, this
will trigger an E_CLIENT_ERROR_INVALID_ARG error if cursor
is not owned by backend
.
| backend | an EBookBackend | |
| cursor | the EDataBookCursor to destroy | |
| error | return location for a GError, or  | 
Since: 3.12
GSimpleAsyncResult * e_book_backend_prepare_for_completion (EBookBackend *backend,guint32 opid,GQueue **result_queue);
Obtains the GSimpleAsyncResult for opid
 and sets result_queue
 as a
place to deposit results prior to completing the GSimpleAsyncResult.
This is a temporary function to serve EDataBook's "respond" functions until they can be removed. Nothing else should be calling this function.
| backend | an EBookBackend | |
| opid | an operation ID given to EDataBook | |
| result_queue | return location for a GQueue, or  | 
Since: 3.10
void (*EBookBackendCustomOpFunc) (EBookBackend *book_backend,gpointer user_data,GCancellable *cancellable,GError **error);
A callback prototype being called in a dedicated thread, scheduled
by e_book_backend_schedule_custom_operation().
| book_backend | an EBookBackend | |
| user_data | a function user data, as provided to  | |
| cancellable | an optional GCancellable, as provided to  | |
| error | return location for a GError, or  | 
Since: 3.26
void e_book_backend_schedule_custom_operation (EBookBackend *book_backend,GCancellable *use_cancellable,EBookBackendCustomOpFunc func,gpointer user_data,GDestroyNotify user_data_free);
Schedules user function func
 to be run in a dedicated thread as
a blocking operation.
The function adds its own reference to use_cancellable
, if not NULL.
The error returned from func
 is propagated to client using
e_book_backend_notify_error() function. If it's not desired,
then left the error unchanged and notify about errors manually.
| book_backend | an EBookBackend | |
| use_cancellable | an optional GCancellable to use for  | [nullable] | 
| func | a function to call in a dedicated thread | |
| user_data | user data being passed to  | |
| user_data_free | optional destroy call back for  | [nullable] | 
Since: 3.26
struct EBookBackend;
Contains only private data that should be read and manipulated using the functions below.
struct EBookBackendClass {
	/* Set this to TRUE to use a serial dispatch queue, instead
	 * of a concurrent dispatch queue.  A serial dispatch queue
	 * executes one method at a time in the order in which they
	 * were called.  This is generally slower than a concurrent
	 * dispatch queue, but helps avoid thread-safety issues. */
	gboolean use_serial_dispatch_queue;
	gchar *		(*impl_get_backend_property)
						 (EBookBackend *backend,
						 const gchar *prop_name);
	void		(*impl_open)		(EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable);
	void		(*impl_refresh)		(EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable);
	void		(*impl_create_contacts) (EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar * const *vcards,
						 guint32 opflags); /* bit-or of EBookOperationFlags */
	void		(*impl_modify_contacts) (EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar * const *vcards,
						 guint32 opflags); /* bit-or of EBookOperationFlags */
	void		(*impl_remove_contacts) (EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar * const *uids,
						 guint32 opflags); /* bit-or of EBookOperationFlags */
	void		(*impl_get_contact) (EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar *id);
	void		(*impl_get_contact_list)(EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar *query);
	void		(*impl_get_contact_list_uids)
						(EBookBackend *backend,
						 EDataBook *book,
						 guint32 opid,
						 GCancellable *cancellable,
						 const gchar *query);
	void		(*impl_start_view) (EBookBackend *backend,
						 EDataBookView *view);
	void		(*impl_stop_view) (EBookBackend *backend,
						 EDataBookView *view);
	void		(*impl_notify_update) (EBookBackend *backend,
						 const EContact *contact);
	EDataBookDirect *
			(*impl_get_direct_book) (EBookBackend *backend);
	void		(*impl_configure_direct)(EBookBackend *backend,
						 const gchar *config);
	gboolean (*impl_set_locale) (EBookBackend *backend,
						 const gchar *locale,
						 GCancellable *cancellable,
						 GError **error);
	gchar *		(*impl_dup_locale) (EBookBackend *backend);
	EDataBookCursor *
			(*impl_create_cursor) (EBookBackend *backend,
						 EContactField *sort_fields,
						 EBookCursorSortType *sort_types,
						 guint n_fields,
						 GError **error);
	gboolean (*impl_delete_cursor) (EBookBackend *backend,
						 EDataBookCursor *cursor,
						 GError **error);
	/* Signals */
	void		(*closed)		(EBookBackend *backend,
						 const gchar *sender);
	void		(*shutdown)		(EBookBackend *backend);
	/* Padding for future expansion */
	gpointer reserved_padding[20];
};
Class structure for the EBookBackend class.
These virtual methods must be implemented when writing an addressbook backend.
| Whether a serial dispatch queue should
be used for this backend or not. The default is  | ||
| Fetch a property value by name from the backend | ||
| Open the backend | ||
| Refresh the backend | ||
| Add and store the passed vcards | ||
| Modify the existing contacts using the passed vcards | ||
| Remove the contacts specified by the passed UIDs | ||
| Fetch a contact by UID | ||
| Fetch a list of contacts based on a search expression | ||
| Fetch a list of contact UIDs based on a search expression | ||
| Start up the specified view | ||
| Stop the specified view | ||
| Notify changes which might have occured for a given contact | ||
| For addressbook backends which support Direct Read Access, report some information on how to access the addressbook persistance directly | ||
| For addressbook backends which support Direct Read Access, configure a
backend instantiated on the client side for Direct Read Access, using data
reported from the server via the  | ||
| Store & remember the passed locale setting | ||
| Return the currently set locale setting (must be a string duplicate, for thread safety). | ||
| Create an EDataBookCursor | ||
| Delete an EDataBookCursor previously created by this backend | ||
| A signal notifying that the backend was closed | ||
| A signal notifying that the backend is being shut down | ||
“cache-dir” property  “cache-dir”                gchar *
The backend's cache directory.
Owner: EBookBackend
Flags: Read / Write
Default value: NULL
“proxy-resolver” property  “proxy-resolver”           GProxyResolver *
The proxy resolver for this backend.
Owner: EBookBackend
Flags: Read
“registry” property“registry” ESourceRegistry *
Data source registry.
Owner: EBookBackend
Flags: Read / Write / Construct Only
“closed” signalvoid user_function (EBookBackend *backend, gchar *sender, gpointer user_data)
Emitted when a client destroys its EBookClient for backend
.
| backend | the EBookBackend which emitted the signal | |
| sender | the bus name that invoked the "close" method | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
Since: 3.10
“shutdown” signalvoid user_function (EBookBackend *backend, gpointer user_data)
Emitted when the last client destroys its EBookClient for
backend
.  This signals the backend
 to begin final cleanup
tasks such as synchronizing data to permanent storage.
| backend | the EBookBackend which emitted the signal | |
| user_data | user data set when the signal handler was connected. | 
Flags: Run Last
Since: 3.10