New virtual method modest_account_protocol_decode_part_to_stream, to
[modest] / src / modest-account-protocol.h
index f2b2aa0..b7989d3 100644 (file)
@@ -62,6 +62,13 @@ typedef enum {
 
 typedef void (*ModestAccountProtocolCheckSupportFunc) (ModestAccountProtocol *self, 
                                                       gboolean supported, gpointer userdata);
+typedef void (*ModestAccountProtocolSaveRemoteDraftCallback) (ModestAccountProtocol *self,
+                                                             GError *error,
+                                                             const gchar *account_id,
+                                                             TnyMsg *new_remote_msg,
+                                                             TnyMsg *new_msg,
+                                                             TnyMsg *old_msg,
+                                                             gpointer userdata);
 
 
 struct _ModestAccountProtocol {
@@ -86,13 +93,19 @@ struct _ModestAccountProtocolClass {
        const GdkPixbuf * (*get_icon) (ModestAccountProtocol *self, ModestAccountProtocolIconType icon_type, 
                                       GObject *object, guint icon_size);
        gchar * (*get_service_name) (ModestAccountProtocol *self, const gchar *account_id, const gchar *mailbox);
+       const GdkPixbuf * (*get_service_icon) (ModestAccountProtocol *self, const gchar *account_id, const gchar *mailbox, guint icon_size);
+       void (*save_remote_draft) (ModestAccountProtocol *self, 
+                                  const gchar *account_id, TnyMsg *new_msg, TnyMsg *old_msg,
+                                  ModestAccountProtocolSaveRemoteDraftCallback callback,
+                                  gpointer userdata);
+       void (*cancel_check_support) (ModestAccountProtocol *self);
+       void (*wizard_finished) (ModestAccountProtocol *self);
+       gboolean (*decode_part_to_stream) (ModestAccountProtocol *protocol,
+                                          TnyMimePart *part,
+                                          TnyStream *stream,
+                                          GError *error);
 
        /* Padding for future expansions */
-       void (*_reserved2) (void);
-       void (*_reserved3) (void);
-       void (*_reserved4) (void);
-       void (*_reserved5) (void);
-       void (*_reserved6) (void);
        void (*_reserved7) (void);
        void (*_reserved8) (void);
        void (*_reserved9) (void);
@@ -337,6 +350,26 @@ ModestWizardDialogResponseOverrideFunc modest_account_protocol_get_wizard_respon
 void modest_account_protocol_check_support (ModestAccountProtocol *self, 
                                            ModestAccountProtocolCheckSupportFunc func, 
                                            gpointer userdata);
+
+/**
+ * modest_account_protocol_cancel_check_support:
+ * @self: a #ModestAccountProtocol
+ *
+ * This method requests that the check support requests running should be
+ * immediately cancelled. Once this happens, is_supported should return %FALSE
+ * until a new succesful check_support request is finished.
+ */
+void modest_account_protocol_cancel_check_support (ModestAccountProtocol *self);
+
+/**
+ * modest_account_protocol_wizard_finished:
+ * @self: a #ModestAccountProtocol
+ *
+ * Method that let protocol know if the wizard has finished, for the case it's
+ * needed to do some stuff after check_support.
+ */
+void modest_account_protocol_wizard_finished (ModestAccountProtocol *self);
+
 /**
  * modest_account_protocol_is_supported:
  * @self: a #ModestAccountProtocol
@@ -419,6 +452,61 @@ gchar *modest_account_protocol_get_service_name (ModestAccountProtocol *self,
                                                 const gchar *account_id,
                                                 const gchar *mailbox);
 
+/**
+ * modest_account_protocol_get_service_icon:
+ * @self: a #ModestAccountProtocol
+ * @account_id: a transport account name
+ * @mailbox: a mailbox
+ *
+ * Obtain the service icon for the account and mailbox.
+ *
+ * Returns: a protocol owned #GdkPixbuf
+ */
+const GdkPixbuf *modest_account_protocol_get_service_icon (ModestAccountProtocol *self,
+                                                          const gchar *account_id,
+                                                          const gchar *mailbox,
+                                                          guint icon_size);
+
+/**
+ * modest_account_protocol_save_remote_draft:
+ * @self: a #ModestAccountProtocol
+ * @account_id: a transport account_name
+ * @new_msg: the newly created message in local storage.
+ * @old_msg: the old message
+ * @callback: the code that should be executed on finishing the remote message saving
+ * @userdata: a #gpointer
+ *
+ * Saves the just-saved to local draft, into a remote storage.
+ */
+void modest_account_protocol_save_remote_draft (ModestAccountProtocol *self,
+                                                   const gchar *account_id,
+                                                   TnyMsg *new_msg,
+                                                   TnyMsg *old_msg,
+                                                   ModestAccountProtocolSaveRemoteDraftCallback callback,
+                                                   gpointer userdata);
+
+/**
+ * modest_account_protocol_decode_part_to_stream:
+ * @self: a #ModestAccountProtocol
+ * @part: a #TnyMimePart
+ * @stream: a #TnyStream
+ * @error: a #GError
+ *
+ * This virtual method delegates on the account protocol to decode @part
+ * into @stream. It just allows the provider to decode it as it needs
+ * (i.e. when the original message has a fake attachment, and provider
+ * can return the real attachment).
+ *
+ * Returns: %TRUE if @protocol does the decode operation, %FALSE if modest
+ * should do it.
+ */
+gboolean
+modest_account_protocol_decode_part_to_stream (ModestAccountProtocol *protocol,
+                                               TnyMimePart *part,
+                                               TnyStream *stream,
+                                               GError *error);
+
+
 
 G_END_DECLS