X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-tny-account-store.h;h=1ed6d50bb08825ab204c8515fa17dbb1e7266d00;hp=17018a3ba0334187a926a5963b608ea33f377145;hb=33b5d84fbaaf8dd4eafe4176dba08213c046463f;hpb=40e92875620a12ce1d34126c9a9c6bce97b21e6c diff --git a/src/modest-tny-account-store.h b/src/modest-tny-account-store.h index 17018a3..1ed6d50 100644 --- a/src/modest-tny-account-store.h +++ b/src/modest-tny-account-store.h @@ -41,6 +41,7 @@ #include #include #include +#include /* other include files */ @@ -75,8 +76,19 @@ struct _ModestTnyAccountStoreClass { gboolean *remember, gboolean *cancel, gpointer user_data); + + /* Signals */ + void (*account_changed) (TnyAccountStore *self, TnyAccount *account); + void (*account_inserted) (TnyAccountStore *self, TnyAccount *account); + void (*account_removed) (TnyAccountStore *self, TnyAccount *account); }; +typedef enum { + MODEST_TNY_ACCOUNT_STORE_QUERY_ID, + MODEST_TNY_ACCOUNT_STORE_QUERY_URL, +} ModestTnyAccountStoreQueryType; + + /** * modest_tny_account_store_get_type: * @@ -97,33 +109,34 @@ ModestTnyAccountStore* modest_tny_account_store_new (ModestAccountMgr *accoun /** - * modest_tny_account_store_get_account_by_id + * modest_tny_account_store_get_account_by * @self: a ModestTnyAccountStore instance * @id: some ID * - * get the account with the given ID or NULL if it's not found + * get the account with the given str or NULL if it's not found * * Returns: the tnyaccount or NULL, * g_object_unref when it's no longer needed */ -TnyAccount* modest_tny_account_store_get_tny_account_by_id (ModestTnyAccountStore *self, - const gchar *id); +TnyAccount* modest_tny_account_store_get_tny_account_by (ModestTnyAccountStore *self, + ModestTnyAccountStoreQueryType type, + const gchar *str); /** - * modest_tny_account_store_get_tny_account_by_account + * modest_tny_account_store_get_server_account * @self: a ModestTnyAccountStore instance - * @account_name: an account name - * @type: the tny account type + * @account_name: a modest account name + * @type: the tny account type (#TNY_ACCOUNT_TYPE_STORE or #TNY_ACCOUNT_TYPE_STORE) * * Get the tny account corresponding to one of the server_accounts for account with @account_name * * Returns: the tnyaccount for the server account or NULL in case it's not found or error, - * g_object_unref when it's no longer needed + * g_object_unref when it's no longer needed. TODO: Check that callers are unreffing. */ -TnyAccount* modest_tny_account_store_get_tny_account_by_account (ModestTnyAccountStore *self, - const gchar *account_name, - TnyAccountType type); - +TnyAccount* modest_tny_account_store_get_server_account (ModestTnyAccountStore *self, + const gchar *account_name, + TnyAccountType type); + /** * modest_tny_account_store_get_transport_account_for_open_connection * @self: a ModestTnyAccountStore instance @@ -137,7 +150,10 @@ TnyAccount* modest_tny_account_store_get_tny_account_by_account (ModestTnyAccoun * g_object_unref when it's no longer needed */ TnyAccount* modest_tny_account_store_get_transport_account_for_open_connection (ModestTnyAccountStore *self, - const gchar *account_name); + const gchar *account_name); + +TnyAccount* modest_tny_account_store_get_smtp_specific_transport_account_for_open_connection (ModestTnyAccountStore *self, + const gchar *account_name); /** * tny_account_store_get_session @@ -150,17 +166,87 @@ TnyAccount* modest_tny_account_store_get_transport_account_for_open_connection ( */ TnySessionCamel* modest_tny_account_store_get_session (TnyAccountStore *self); +/** modest_tny_account_store_get_local_folders_account: + * @self: a TnyAccountStore instance + * + * Get the user-visible local folders account. It returns a new + * reference so the caller must unref it when no longer needed + **/ +TnyAccount * modest_tny_account_store_get_local_folders_account (ModestTnyAccountStore *self); -/** modest_tny_account_is_virtual_local_folders: - * @self A TnyAccount. +/** + * modest_tny_account_store_get_mmc_folders_account: + * @self: a TnyAccountStore instance * - * A convenience function to identify whether TnyAccount - * is the virtual local folders account, containing the folders from local_folders/ - * and the outboxes from outboxes//. + * Get the mmc folders account. + * + * Returns: a #TnyAccount, or %NULL if no mmc account is available + * now. It returns a new reference so the caller must unref it when no + * longer needed + */ +TnyAccount * modest_tny_account_store_get_mmc_folders_account (ModestTnyAccountStore *self); + +/** modest_tny_account_store_forget_already_asked: + * @self: a TnyAccountStore instance + * @account: the account to forget the already asked status for + * + * Forget the already asked status of an account + **/ +void modest_tny_account_store_forget_already_asked (ModestTnyAccountStore *self, TnyAccount *account); + +/** + * modest_tny_account_store_find_msg_in_outboxes: + * @self: a #ModestTnyAccountStore + * @uri: the uri of the message + * @ac_out: output attribute, %NULL, or the #TnyAccount of the message + * + * finds a message in the set of outboxes, using the uri. + * + * Returns: %NULL or a #TnyMsg **/ -gboolean modest_tny_account_is_virtual_local_folders (TnyAccount *self); +TnyMsg *modest_tny_account_store_find_msg_in_outboxes (ModestTnyAccountStore *self, + const gchar *uri, + TnyAccount **ac_out); + + +/** + * modest_tny_account_store_get_transport_account_from_outbox_header: + * @self: a #ModestTnyAccountStore + * @header: a #TnyHeader + * + * Gets the transport account from a header that is in the outbox + * + * Returns: %NULL or a %TnyTransportAccount. Returns a new reference + * so the caller must unref it when no longer needed + */ +TnyTransportAccount * modest_tny_account_store_get_transport_account_from_outbox_header(ModestTnyAccountStore *self, + TnyHeader *header); + +/** + * modest_tny_account_store_new_connection_specific_transport_account: + * @self: a #ModestTnyAccountStore + * @name: the name of the connection specific smtp transport account + * + * Creates a connection specific transport account and put it in the merged outbox + * + * Returns: the new #TnyTransportAccount + */ +TnyTransportAccount * modest_tny_account_store_new_connection_specific_transport_account (ModestTnyAccountStore *self, + const gchar *name); + +/** + * modest_tny_account_store_show_account_settings_dialog: + * @self: a #ModestTnyAccountStore + * @account_name: a string + * + * obtains (if already created) or creates (and shows) the settings dialog for + * @account_name + * + * Returns: a #ModesAccountSettingsDialog + */ +GtkWidget *modest_tny_account_store_show_account_settings_dialog (ModestTnyAccountStore *self, + const gchar *account_name); G_END_DECLS #endif /* __MODEST_TNY_ACCOUNT_STORE_H__ */ -