Rename ModestToolbarDimmingRules to ModestWindowDimmingRules and
[modest] / src / modest-tny-account-store.h
index 9081753..3f1f52f 100644 (file)
@@ -75,11 +75,15 @@ 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_NAME,
        MODEST_TNY_ACCOUNT_STORE_QUERY_URL,
 } ModestTnyAccountStoreQueryType;
 
@@ -126,7 +130,7 @@ TnyAccount* modest_tny_account_store_get_tny_account_by  (ModestTnyAccountStore
  * 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_server_account (ModestTnyAccountStore *self,
                                                         const gchar *account_name,
@@ -147,6 +151,9 @@ TnyAccount* modest_tny_account_store_get_server_account (ModestTnyAccountStore *
 TnyAccount* modest_tny_account_store_get_transport_account_for_open_connection (ModestTnyAccountStore *self,
                                                                                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
  * @self: a TnyAccountStore instance
@@ -163,18 +170,67 @@ TnySessionCamel*    modest_tny_account_store_get_session    (TnyAccountStore *se
  * 
  * Get the user-visible local folders account.
  **/
-TnyAccount * modest_tny_account_store_get_local_folders_account (TnyAccountStore *self);
+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/<account-name>/.
+ * Get the mmc folders account.
+ *
+ * Returns: a #TnyAccount, or %NULL if no mmc account is available now.
+ */
+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
+ */
+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);
 
 G_END_DECLS
 
 #endif /* __MODEST_TNY_ACCOUNT_STORE_H__ */
-