* src/maemo/modest-msg-edit-window.c:
[modest] / libmodest-dbus-client / libmodest-dbus-client.h
1 /* Copyright (c) 2007, Nokia Corporation
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  *   notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  *   notice, this list of conditions and the following disclaimer in the
12  *   documentation and/or other materials provided with the distribution.
13  * * Neither the name of the Nokia Corporation nor the names of its
14  *   contributors may be used to endorse or promote products derived from
15  *   this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
18  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
20  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
21  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29
30 #ifndef __LIBMODEST_DBUS_CLIENT_H__
31 #define __LIBMODEST_DBUS_CLIENT_H__
32
33 #include <libosso.h>
34 #include <glib.h>
35 #include <stdio.h>
36
37
38 /**
39  * libmodest_dbus_client_compose_mail:
40  * @osso_context: a valid osso_context instance
41  * @to: the To:-field of the message
42  * @cc: the Cc:-field of the message
43  * @bcc: the Bcc:-field of the message
44  * @subject: the Subject:-field of the message
45  * @body: the body (text) of the message
46  * @attachments: a list of (file://) URIs with the files to attach
47  *
48  * opens a new mail composer with the provided details filled in
49  *  
50  * Returns: TRUE upon success, FALSE otherwise
51  */
52 gboolean libmodest_dbus_client_compose_mail (osso_context_t *osso_context, const gchar *to, 
53                                              const gchar *cc, const gchar *bcc, const gchar* subject,
54                                              const gchar* body, 
55                                              GSList *attachments);
56
57 /**
58  * libmodest_dbus_client_mail_to:
59  * @osso_context: a valid osso_context instance
60  * @mailto_uri: a 'mailto:foo@bar.cuux' URI
61  *
62  * opens a new mail composer with the provided details filled in,
63  * based on a mailto: string. apart from the To:-field (the first arg),
64  * also, cc, bcc, subject and body are supported, ie. "mailto:foo@bar.cuu?subject=test"
65  *  
66  * Returns: TRUE upon success, FALSE otherwise
67  */
68 gboolean libmodest_dbus_client_mail_to (osso_context_t *osso_context, 
69                                         const gchar *mailto_uri);
70
71
72 /**
73  * libmodest_dbus_client_open_message:
74  * @osso_context: a valid osso_context instance
75  * @mail_uri: the unique URI referring to some message
76  *
77  * opens an existing message based on its URI; these URIs are unique pointers
78  * to some message, and are retrieved from modest.
79  *  
80  * Returns: TRUE upon success, FALSE otherwise
81  */
82 gboolean  libmodest_dbus_client_open_message (osso_context_t *osso_context, 
83                                               const gchar *mail_uri);
84
85
86 /**
87  * libmodest_dbus_client_send_and_receive:
88  * @osso_context: a valid osso_context instance
89  *
90  * send/receive messages
91  *  
92  * Returns: TRUE upon success, FALSE otherwise
93  */
94 gboolean libmodest_dbus_client_send_and_receive (osso_context_t *osso_context);
95
96
97
98 /**
99  * libmodest_dbus_client_open_default_inbox:
100  * @osso_context: a valid osso_context instance
101  *
102  * start modest, and open the inbox for the default account
103  *  
104  * Returns: TRUE upon success, FALSE otherwise
105  */
106 gboolean libmodest_dbus_client_open_default_inbox (osso_context_t *osso_context);
107
108
109
110 /*
111  * below: functions specific to osso-global-search; not useful for other clients.
112  * 
113  */ 
114
115 typedef enum {
116
117         MODEST_DBUS_SEARCH_SUBJECT   = (1 << 0),
118         MODEST_DBUS_SEARCH_SENDER    = (1 << 1),
119         MODEST_DBUS_SEARCH_RECIPIENT = (1 << 2),
120         MODEST_DBUS_SEARCH_SIZE      = (1 << 3),
121         MODEST_DBUS_SEARCH_BODY      = (1 << 6)
122
123 } ModestDBusSearchFlags;
124
125 typedef struct {
126         gchar     *msgid; /* E.g. the URI of the message. */
127         gchar     *subject;
128         gchar     *folder; /* The name, not the URI. */
129         gchar     *sender;
130         guint64    msize;
131         gboolean   has_attachment;
132         gboolean   is_unread;
133         gint64     timestamp;            
134 } ModestSearchHit;
135
136
137 void modest_search_hit_list_free (GList *hits);
138
139
140 gboolean libmodest_dbus_client_search            (osso_context_t          *osso_ctx,
141                                                   const gchar             *query,
142                                                   const gchar             *folder,
143                                                   time_t                   start_date,
144                                                   time_t                   end_date,
145                                                   guint32                  min_size,
146                                                   ModestDBusSearchFlags    flags,
147                                                   GList                  **hits);
148
149 gboolean libmodest_dbus_client_delete_message   (osso_context_t   *osso_ctx,
150                                                  const char       *msg_uri);
151
152
153 typedef struct {
154         gchar     *folder_uri;
155         gchar     *folder_name;  
156 } ModestFolderResult;
157
158 gboolean libmodest_dbus_client_get_folders (osso_context_t *osso_ctx, GList **folders); 
159
160 void modest_folder_result_list_free (GList *folders);
161
162                                                 
163                                                         
164 #endif /* __LIBMODEST_DBUS_CLIENT_H__ */