X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-tny-account.h;h=2e4b0565f2e67998ab8b7f32f19f637834314891;hp=a0c50b31627a2e56e91190ac67e1d46ed71cd035;hb=6d11595dfdc07450d9a48bff06a0544ca03a3d56;hpb=ecfab159b04553dfa45f3f2cf2771a72264433f6 diff --git a/src/modest-tny-account.h b/src/modest-tny-account.h index a0c50b3..2e4b056 100644 --- a/src/modest-tny-account.h +++ b/src/modest-tny-account.h @@ -38,32 +38,77 @@ #include #include #include +#include G_BEGIN_DECLS /** * modest_tny_account_new_from_account: * @account_mgr: a valid account mgr instance - * @account_name: the account name for which to create a corresponding tny account + * @account_name: the modest account name for which to create a corresponding tny account of the given type. * @type: the type of account to create (TNY_ACCOUNT_TYPE_STORE or TNY_ACCOUNT_TYPE_TRANSPORT) + * @session: a tny camel session + * @get_pass_func: the get-password function + * @forget_pass_func: the forget-password function * * get a tnyaccount corresponding to the server_accounts (store or transport) for this account. * NOTE: this function does not set the camel session or the get/forget password functions * * Returns: a new TnyAccount or NULL in case of error. */ -TnyAccount* modest_tny_account_new_from_account (ModestAccountMgr *account_mgr, - const gchar *account_name, TnyAccountType type); +TnyAccount* +modest_tny_account_new_from_account (ModestAccountMgr *account_mgr, const gchar *account_name, + TnyAccountType type, + TnySessionCamel *session, + TnyGetPassFunc get_pass_func, + TnyForgetPassFunc forget_pass_func); +/** + * modest_tny_account_new_for_local_folders: + * @account_mgr: a valid account mgr instance + * @session: a tny camel session + * @location_filepath: The location at which the local-folders directory exists, or NULL to specify $HOME. + * + * get the local folders (pseudo) account; you should only need one such account. + * + * Returns: a new local folders TnyAccount or NULL in case of error. + */ +TnyAccount* modest_tny_account_new_for_local_folders (ModestAccountMgr *account_mgr, + TnySessionCamel *session, + const gchar* location_filepath); +/** + * modest_tny_account_new_for_per_account_local_outbox_folder: + * @account_mgr: a valid account mgr instance + * @account_name: a modest account name. + * @session: a tny camel session + * + * get the per-account local outbox folder (pseudo) account. + * + * Returns: a new per-account local outbox folder TnyAccount or NULL in case of error. + */ +TnyAccount* modest_tny_account_new_for_per_account_local_outbox_folder ( + ModestAccountMgr *account_mgr, const gchar* account_name, + TnySessionCamel *session); /** + * modest_tny_account_new_from_server_account_name: + * @account_mgr: a valid account mgr instance + * @server_account_name: the name of a server account in the configuration system. + * + * Returns: a new TnyAccount or NULL in case of error. + */ +TnyAccount* +modest_tny_account_new_from_server_account_name (ModestAccountMgr *account_mgr, + const gchar* server_account_name); + +/** * modest_tny_account_get_special_folder: * @self: a TnyAccount * @special_type: the special folder to get * - * get the special (Inbox,Outbox,Sent,Draft etc.) folder for this account + * get the special (Inbox,Outbox,Sent,Draft etc.) folder for this server account's parent modest account. * Note: currently, the implementation will always return a local folder for this. * This can be changed later to return really account-specific special folders, * such as (for example) server-side Sent/Junk mail for IMAP accounts @@ -74,6 +119,50 @@ TnyAccount* modest_tny_account_new_from_account (ModestAccountMgr *account_mgr, TnyFolder* modest_tny_account_get_special_folder (TnyAccount *self, TnyFolderType special_type); + +/** + * modest_tny_folder_store_get_folder_count: + * @self: a #TnyFolderStore + * + * gets the number of folders of the account + * + * Returns: the number of folder, or -1 in case of error + **/ +gint modest_tny_folder_store_get_folder_count (TnyFolderStore *self); + +/** + * modest_tny_folder_store_get_message_count: + * @self: + * + * gets the number of messages in the account + * + * Returns: the number of messages, or -1 in case of error + **/ +gint modest_tny_folder_store_get_message_count (TnyFolderStore *self); + +/** + * modest_tny_folder_store_get_local_size: + * @self: + * + * gets the total size occupied by the account in the local storage + * device + * + * Returns: the total size in bytes, or -1 in case of error + **/ +gint modest_tny_folder_store_get_local_size (TnyFolderStore *self); + +/** modest_tny_account_get_parent_modest_account_name_for_server_account: + * Get the name of the parent modest account of which the server account is a part. + */ +const gchar* modest_tny_account_get_parent_modest_account_name_for_server_account (TnyAccount *self); + +/** modest_tny_account_set_parent_modest_account_name_for_server_account: + * Set the name of the parent modest account of which the server account is a part, + * so it can be retrieved later with + * modest_tny_account_get_parent_modest_account_name_for_server_account(). + */ +void modest_tny_account_set_parent_modest_account_name_for_server_account (TnyAccount *self, const gchar* parent_modest_acount_name); + G_END_DECLS #endif /* __MODEST_TNY_ACCOUNT_H__*/