X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-tny-account-store.h;h=239deb44bf6897cd892d6dd7b3888f39126ecfa8;hp=e8f96a69eaf793bd84ff17a1f5a36cd44b3f4426;hb=56bc8a2cdb4cfd5acbc3f1a9abc2d7f00c73e7e9;hpb=434ec10090daec7d9d80c1f419b9113d15d58fd4 diff --git a/src/modest-tny-account-store.h b/src/modest-tny-account-store.h index e8f96a6..239deb4 100644 --- a/src/modest-tny-account-store.h +++ b/src/modest-tny-account-store.h @@ -1,10 +1,47 @@ +/* Copyright (c) 2006, Nokia Corporation + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * * Neither the name of the Nokia Corporation nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER + * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + + /* modest-tny-account-store.h */ -/* insert (c)/licensing information) */ #ifndef __MODEST_TNY_ACCOUNT_STORE_H__ #define __MODEST_TNY_ACCOUNT_STORE_H__ #include +#include +#include +#include +#include +#include +#include +#include + /* other include files */ G_BEGIN_DECLS @@ -12,39 +49,230 @@ G_BEGIN_DECLS /* convenience macros */ #define MODEST_TYPE_TNY_ACCOUNT_STORE (modest_tny_account_store_get_type()) #define MODEST_TNY_ACCOUNT_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MODEST_TYPE_TNY_ACCOUNT_STORE,ModestTnyAccountStore)) -#define MODEST_TNY_ACCOUNT_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass),MODEST_TYPE_TNY_ACCOUNT_STORE,GObject)) +#define MODEST_TNY_ACCOUNT_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass),MODEST_TYPE_TNY_ACCOUNT_STORE,ModestTnyAccountStoreClass)) #define MODEST_IS_TNY_ACCOUNT_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MODEST_TYPE_TNY_ACCOUNT_STORE)) #define MODEST_IS_TNY_ACCOUNT_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MODEST_TYPE_TNY_ACCOUNT_STORE)) #define MODEST_TNY_ACCOUNT_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MODEST_TYPE_TNY_ACCOUNT_STORE,ModestTnyAccountStoreClass)) typedef struct _ModestTnyAccountStore ModestTnyAccountStore; typedef struct _ModestTnyAccountStoreClass ModestTnyAccountStoreClass; +typedef TnyGetPassFunc ModestTnyGetPassFunc; struct _ModestTnyAccountStore { - GObject parent; - /* insert public members, if any */ + GObject parent; }; struct _ModestTnyAccountStoreClass { GObjectClass parent_class; - /* insert signal callback declarations, eg. */ - /* void (* my_event) (ModestTnyAccountStore* obj); */ + + void (*account_update) (ModestTnyAccountStore *self, + const gchar *account_name, + gpointer user_data); + void (*password_requested) (ModestTnyAccountStore *self, + const gchar *server_account_name, + gchar **username, + gchar **password, + 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); }; -/* member functions */ -GType modest_tny_account_store_get_type (void) G_GNUC_CONST; +typedef enum { + MODEST_TNY_ACCOUNT_STORE_QUERY_ID, + MODEST_TNY_ACCOUNT_STORE_QUERY_URL, +} ModestTnyAccountStoreQueryType; + + +/** + * modest_tny_account_store_get_type: + * + * Returns: GType of the account store + */ +GType modest_tny_account_store_get_type (void) G_GNUC_CONST; + +/** + * modest_tny_account_store_new: + * @account_mgr: account manager to use for new account store + * + * creates new (tinymail) account store for account manager modest_acc_mgr + * + * Returns: newly created account store or NULL in case of error + */ +ModestTnyAccountStore* modest_tny_account_store_new (ModestAccountMgr *account_mgr, + TnyDevice *device); + + +/** + * modest_tny_account_store_get_account_by + * @self: a ModestTnyAccountStore instance + * @id: some ID + * + * 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 (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 (#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. TODO: Check that callers are unreffing. + */ +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 + * @account_name: an 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 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_transport_account_for_open_connection (ModestTnyAccountStore *self, + const gchar *account_name); -/* typical parameter-less _new function */ -/* if this is a kind of GtkWidget, it should probably return at GtkWidget*, */ -/* otherwise probably a GObject*. */ -GObject* modest_tny_account_store_new (ModestAccountMgr *modest_acc_mgr); +TnyAccount* modest_tny_account_store_get_smtp_specific_transport_account_for_open_connection (ModestTnyAccountStore *self, + const gchar *account_name); -/* fill in other public functions, eg.: */ -/* void modest_tny_account_store_do_something (ModestTnyAccountStore *self, const gchar* param); */ -/* gboolean modest_tny_account_store_has_foo (ModestTnyAccountStore *self, gint value); */ +/** + * tny_account_store_get_session + * @self: a TnyAccountStore instance + * + * get the tny-camel-session for this account store. Note that this function + * does NOT have the modest_ prefix, as tinymail requires the symbol to be like this... + * + * Returns: a tny-camel-session + */ +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_store_get_mmc_folders_account: + * @self: a TnyAccountStore instance + * + * 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 + **/ +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); + +typedef void (*ModestTnyAccountStoreShutdownCallback) (ModestTnyAccountStore *account_store, gpointer userdata); + +/** + * modest_tny_account_store_shutdown: + * @self: a #ModestTnyAccountStore + * @callback: a #ModestTnyAccountStoreShutdownCallback + * @userdata: a #gpointer + * + * Disconnects all registered accounts (forcing syncs for all of them). + */ +void modest_tny_account_store_shutdown (ModestTnyAccountStore *self, + ModestTnyAccountStoreShutdownCallback callback, + gpointer userdata); + + +/** + * modest_tny_account_store_is_send_mail_blocked: + * @self: a #ModestTnyAccountStore + * + * Tells if we've blocked the send queue flush attempts temporally. This is + * usually done when we're editing an account, to prevent sending mails as + * it can cause problems + * + * Returns: %TRUE if sending mail is blocked + */ +gboolean modest_tny_account_store_is_send_mail_blocked (ModestTnyAccountStore *self); + +/** + * modest_tny_account_store_set_send_mail_blocked: + * @self: a #ModestTnyAccountStore + * @blocked: a #gboolean + * + * Sets as blocked/non blocked the send queue flush attempts temporally. This is + * usually done when we're editing an account, to prevent sending mails as + * it can cause problems + */ +void modest_tny_account_store_set_send_mail_blocked (ModestTnyAccountStore *self, gboolean blocked); + +guint modest_tny_account_store_get_num_remote_accounts (ModestTnyAccountStore *self); G_END_DECLS #endif /* __MODEST_TNY_ACCOUNT_STORE_H__ */ -