| Top |  |  |  |  | 
| CamelServiceConnectionStatus | connection-status | Read | 
| gchar * | display-name | Read / Write / Construct | 
| gchar * | password | Read / Write / Construct | 
| gpointer | provider | Read / Write / Construct Only | 
| GProxyResolver * | proxy-resolver | Read / Write | 
| CamelSession * | session | Read / Write / Construct Only | 
| CamelSettings * | settings | Read / Write / Construct | 
| gchar * | uid | Read / Write / Construct Only | 
| struct | CamelService | 
| #define | CAMEL_SERVICE_ERROR | 
| enum | CamelServiceError | 
| CamelServiceAuthType | |
| enum | CamelServiceConnectionStatus | 
| enum | CamelAuthenticationResult | 
void
camel_service_migrate_files (CamelService *service);
Performs any necessary file migrations for service
.  This should be
called after installing or configuring the service
's CamelSettings,
since it requires building a URL string for service
.
Since: 3.4
CamelURL *
camel_service_new_camel_url (CamelService *service);
Returns a new CamelURL representing service
.
Free the returned CamelURL with camel_url_free().
Since: 3.2
CamelServiceConnectionStatus
camel_service_get_connection_status (CamelService *service);
Returns the connection status for service
.
Since: 3.2
const gchar *
camel_service_get_display_name (CamelService *service);
Returns the display name for service
, or NULL if service
 has not
been given a display name.  The display name is intended for use in
a user interface and should generally be given a user-defined name.
Compare this with camel_service_get_name(), which returns a built-in
description of the type of service (IMAP, SMTP, etc.).
Since: 3.2
gchar *
camel_service_dup_display_name (CamelService *service);
Thread-safe variation of camel_service_get_display_name().
Use this function when accessing service
 from multiple threads.
The returned string should be freed with g_free() when no longer needed.
Since: 3.12
void camel_service_set_display_name (CamelService *service,const gchar *display_name);
Assigns a UTF-8 display name to service
.  The display name is intended
for use in a user interface and should generally be given a user-defined
name.
Compare this with camel_service_get_name(), which returns a built-in
description of the type of service (IMAP, SMTP, etc.).
Since: 3.2
const gchar *
camel_service_get_password (CamelService *service);
Returns the password for service
.  Some SASL mechanisms use this
when attempting to authenticate.
Since: 3.4
gchar *
camel_service_dup_password (CamelService *service);
Thread-safe variation of camel_service_get_password().
Use this function when accessing service
 from multiple threads.
The returned string should be freed with g_free() when no longer needed.
Since: 3.12
void camel_service_set_password (CamelService *service,const gchar *password);
Sets the password for service
.  Use this function to cache the password
in memory after obtaining it through camel_session_get_password().  Some
SASL mechanisms use this when attempting to authenticate.
Since: 3.4
const gchar *
camel_service_get_user_data_dir (CamelService *service);
Returns the base directory under which to store user-specific data
for service
.  The directory is formed by appending the directory
returned by camel_session_get_user_data_dir() with the service's
“uid” value.
Since: 3.2
const gchar *
camel_service_get_user_cache_dir (CamelService *service);
Returns the base directory under which to store cache data
for service
.  The directory is formed by appending the directory
returned by camel_session_get_user_cache_dir() with the service's
“uid” value.
Since: 3.4
gchar * camel_service_get_name (CamelService *service,gboolean brief);
This gets the name of the service in a "friendly" (suitable for
humans) form. If brief
 is TRUE, this should be a brief description
such as for use in the folder tree. If brief
 is FALSE, it should
be a more complete and mostly unambiguous description.
CamelProvider *
camel_service_get_provider (CamelService *service);
Gets the CamelProvider associated with the service.
GProxyResolver *
camel_service_ref_proxy_resolver (CamelService *service);
Returns the GProxyResolver for service
.  If an application needs to
override this, it should do so prior to calling functions on service
that may require a network connection.
The returned GProxyResolver is referenced for thread-safety and must
be unreferenced with g_object_unref() when finished with it.
Since: 3.12
void camel_service_set_proxy_resolver (CamelService *service,GProxyResolver *proxy_resolver);
Sets the GProxyResolver for service
.  If an application needs to
override this, it should do so prior to calling functions on service
that may require a network connection.
Since: 3.12
struct _CamelSession *
camel_service_ref_session (CamelService *service);
Returns the CamelSession associated with the service.
The returned CamelSession is referenced for thread-safety.  Unreference
the CamelSession with g_object_unref() when finished with it.
Since: 3.8
CamelSettings *
camel_service_ref_settings (CamelService *service);
Returns the CamelSettings instance associated with the service.
The returned CamelSettings is referenced for thread-safety and must
be unreferenced with g_object_unref() when finished with it.
Since: 3.6
void camel_service_set_settings (CamelService *service,CamelSettings *settings);
Associates a new CamelSettings instance with the service.
The settings
 instance must match the settings type defined in
CamelServiceClass.  If settings
 is NULL, a new CamelSettings
instance of the appropriate type is created with all properties
set to defaults.
Since: 3.2
const gchar *
camel_service_get_uid (CamelService *service);
Gets the unique identifier string associated with the service.
Since: 3.2
void camel_service_queue_task (CamelService *service,GTask *task,GTaskThreadFunc task_func);
Adds task
 to a queue of waiting tasks with the same source object.
Queued tasks execute one at a time in the order they were added.  When
task
 reaches the front of the queue, it will be dispatched by invoking
task_func
 in a separate thread.  If task
 is cancelled while queued,
it will complete immediately with an appropriate error.
This is primarily intended for use by CamelStore, CamelTransport and CamelFolder to achieve ordered invocation of synchronous class methods.
Since: 3.12
gboolean camel_service_connect_sync (CamelService *service,GCancellable *cancellable,GError **error);
Connects service
 to a remote server using the information in its
“settings” instance.
If a connect operation is already in progress when this function is called, its results will be reflected in this connect operation.
Since: 3.6
void camel_service_connect (CamelService *service,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously connects service
 to a remote server using the information
in its “settings” instance.
If a connect operation is already in progress when this function is called, its results will be reflected in this connect operation.
If any disconnect operations are in progress when this function is called, they will be cancelled.
When the operation is finished, callback
 will be called.  You can
then call camel_service_connect_finish() to get the result of the
operation.
| service | ||
| io_priority | the I/O priority of the request | |
| 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.6
gboolean camel_service_connect_finish (CamelService *service,GAsyncResult *result,GError **error);
Finishes the operation started with camel_service_connect().
Since: 3.6
gboolean camel_service_disconnect_sync (CamelService *service,gboolean clean,GCancellable *cancellable,GError **error);
Disconnect from the service. If clean
 is FALSE, it should not
try to do any synchronizing or other cleanup of the connection.
If a disconnect operation is already in progress when this function is called, its results will be reflected in this disconnect operation.
If any connect operations are in progress when this function is called, they will be cancelled.
| service | ||
| clean | whether or not to try to disconnect cleanly | |
| cancellable | optional GCancellable object, or  | |
| error | 
Since: 3.6
void camel_service_disconnect (CamelService *service,gboolean clean,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
If a disconnect operation is already in progress when this function is called, its results will be reflected in this disconnect operation.
If any connect operations are in progress when this function is called, they will be cancelled.
When the operation is finished, callback
 will be called.  You can
then call camel_service_disconnect_finish() to get the result of the
operation.
| service | ||
| clean | whether or not to try to disconnect cleanly | |
| io_priority | the I/O priority of the request | |
| 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.6
gboolean camel_service_disconnect_finish (CamelService *service,GAsyncResult *result,GError **error);
Finishes the operation started with camel_service_disconnect().
Since: 3.6
CamelAuthenticationResult camel_service_authenticate_sync (CamelService *service,const gchar *mechanism,GCancellable *cancellable,GError **error);
Attempts to authenticate service
 using mechanism
 and, if necessary,
service
's “password” property.  The function makes only
ONE attempt at authentication and does not loop.
If the authentication attempt completed and the server accepted the credentials, the function returns CAMEL_AUTHENTICATION_ACCEPTED.
If the authentication attempt completed but the server rejected the credentials, the function returns CAMEL_AUTHENTICATION_REJECTED.
If the authentication attempt failed to complete due to a network
communication issue or some other mishap, the function sets error
and returns CAMEL_AUTHENTICATION_ERROR.
Generally this function should only be called from a CamelSession subclass in order to implement its own authentication loop.
| service | ||
| mechanism |  a SASL mechanism name, or  | [nullable] | 
| cancellable | optional GCancellable object, or  | |
| error | 
Since: 3.4
void camel_service_authenticate (CamelService *service,const gchar *mechanism,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously attempts to authenticate service
 using mechanism
 and,
if necessary, service
's “password” property.  The function
makes only ONE attempt at authentication and does not loop.
Generally this function should only be called from a CamelSession subclass in order to implement its own authentication loop.
When the operation is finished, callback
 will be called.  You can
then call camel_service_authenticate_finish() to get the result of
the operation.
| service | ||
| mechanism |  a SASL mechanism name, or  | [nullable] | 
| io_priority | the I/O priority of the request | |
| 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.4
CamelAuthenticationResult camel_service_authenticate_finish (CamelService *service,GAsyncResult *result,GError **error);
Finishes the operation started with camel_service_authenticate().
If the authentication attempt completed and the server accepted the credentials, the function returns CAMEL_AUTHENTICATION_ACCEPTED.
If the authentication attempt completed but the server rejected the credentials, the function returns CAMEL_AUTHENTICATION_REJECTED.
If the authentication attempt failed to complete due to a network
communication issue or some other mishap, the function sets error
and returns CAMEL_AUTHENTICATION_ERROR.
Since: 3.4
GList * camel_service_query_auth_types_sync (CamelService *service,GCancellable *cancellable,GError **error);
Obtains a list of authentication types supported by service
.
Free the returned list with g_list_free().
a list of CamelServiceAuthType structs.
[element-type CamelServiceAuthType][transfer container]
void camel_service_query_auth_types (CamelService *service,gint io_priority,GCancellable *cancellable,GAsyncReadyCallback callback,gpointer user_data);
Asynchronously obtains a list of authentication types supported by
service
.
When the operation is finished, callback
 will be called.  You can
then call camel_service_query_auth_types_finish() to get the result
of the operation.
| service | ||
| io_priority | the I/O priority of the request | |
| 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.2
GList * camel_service_query_auth_types_finish (CamelService *service,GAsyncResult *result,GError **error);
Finishes the operation started with camel_service_query_auth_types().
Free the returned list with g_list_free().
a list of CamelServiceAuthType structs.
[element-type CamelServiceAuthType][transfer container]
Since: 3.2
typedef struct {
	const gchar *name;               /* user-friendly name */
	const gchar *description;
	const gchar *authproto;
	gboolean need_password;   /* needs a password to authenticate */
} CamelServiceAuthType;
Connection status returned by camel_service_get_connection_status().
| CamelService is disconnected from a remote server. | ||
| CamelService is connecting to a remote server. | ||
| CamelService is connected to a remote server. | ||
| CamelService is disconnecting from a remote server. | 
Since: 3.6
“connection-status” property“connection-status” CamelServiceConnectionStatus
The connection status for the service.
Flags: Read
Default value: CAMEL_SERVICE_DISCONNECTED
“display-name” property“display-name” gchar *
The display name for the service.
Flags: Read / Write / Construct
Default value: NULL
“password” property“password” gchar *
The password for the service.
Flags: Read / Write / Construct
Default value: NULL
“provider” property“provider” gpointer
The CamelProvider for the service.
Flags: Read / Write / Construct Only
“proxy-resolver” property“proxy-resolver” GProxyResolver *
The proxy resolver for the service.
Flags: Read / Write
“session” property“session” CamelSession *
A CamelSession instance.
Flags: Read / Write / Construct Only
“settings” property“settings” CamelSettings *
A CamelSettings instance.
Flags: Read / Write / Construct
“uid” property“uid” gchar *
The unique identity of the service.
Flags: Read / Write / Construct Only
Default value: NULL