#include <tny-shared.h>
#include <tny-folder.h>
#include <modest-account-mgr.h>
+#include <modest-tny-local-folders-account.h>
/* other include files */
const gchar *account_name,
gpointer user_data);
void (*password_requested) (ModestTnyAccountStore *self,
- const gchar *account_name,
+ const gchar *server_account_name,
+ gchar **username,
gchar **password,
gboolean *remember,
gboolean *cancel,
gpointer user_data);
-
-
};
+typedef enum {
+ MODEST_TNY_ACCOUNT_STORE_QUERY_ID,
+ MODEST_TNY_ACCOUNT_STORE_QUERY_NAME,
+ MODEST_TNY_ACCOUNT_STORE_QUERY_URL,
+} ModestTnyAccountStoreQueryType;
+
+
/**
* modest_tny_account_store_get_type:
*
*
* Returns: newly created account store or NULL in case of error
*/
-ModestTnyAccountStore* modest_tny_account_store_new (ModestAccountMgr *account_mgr);
+ModestTnyAccountStore* modest_tny_account_store_new (ModestAccountMgr *account_mgr,
+ TnyDevice *device);
/**
- * 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_server_account
+ * @self: a ModestTnyAccountStore instance
+ * @account_name: a modest account name
+ * @type: the tny account type (store or transport)
+ *
+ * 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
+ */
+TnyAccount* modest_tny_account_store_get_server_account (ModestTnyAccountStore *self,
+ const gchar *account_name,
+ TnyAccountType type);
/**
- * modest_tny_account_store_get_tny_account_by_account
+ * modest_tny_account_store_get_transport_account_for_open_connection
* @self: a ModestTnyAccountStore instance
* @account_name: an account name
- * @type: the tny account type
*
- * get the tny account corresponding to one of the server_accounts for account with @account_name
+ * Get the tny account corresponding to the transport server account for the account with @account_name,
+ * returning the connection-specific SMTP-server transport server account if one is specified,
+ * otherwise just returning the regular transport server account.
*
- * Returns: the tnyaccount or NULL in case it's not found or error,
+ * 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
- */
-TnyAccount* modest_tny_account_store_get_tny_account_by_account (ModestTnyAccountStore *self,
- const gchar *account_name,
- TnyAccountType type);
+ */
+TnyAccount* modest_tny_account_store_get_transport_account_for_open_connection (ModestTnyAccountStore *self,
+ const gchar *account_name);
/**
* tny_account_store_get_session
*
* Returns: a tny-camel-session
*/
-TnySessionCamel* tny_account_store_get_session (TnyAccountStore *self);
+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.
+ **/
+TnyAccount * modest_tny_account_store_get_local_folders_account (TnyAccountStore *self);
+
+/** modest_tny_account_is_virtual_local_folders:
+ * @self A TnyAccount.
+ *
+ * A convenience function to identify whether TnyAccount
+ * is the virtual local folders account, containing the folders from local_folders/
+ * and the outboxes from outboxes/<account-name>/.
+ **/
+gboolean modest_tny_account_is_virtual_local_folders (TnyAccount *self);
G_END_DECLS