Fixes leak 13/26
[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  * libmodest_dbus_client_open_account:
110  * @osso_context: a valid osso_context instance
111  * @account_id: the unique ID of one account
112  *
113  * Starts Modest showing the account that is specified as
114  * parametter. Note that this only makes sense when the folder view is
115  * showing just one account
116  *
117  * Returns: TRUE upon success, FALSE otherwise
118  */
119 gboolean  libmodest_dbus_client_open_account (osso_context_t *osso_context,
120                                               const gchar *account_id);
121
122
123 /*
124  * below: functions specific to osso-global-search; not useful for other clients.
125  * 
126  */ 
127
128 typedef enum {
129
130         MODEST_DBUS_SEARCH_SUBJECT   = (1 << 0),
131         MODEST_DBUS_SEARCH_SENDER    = (1 << 1),
132         MODEST_DBUS_SEARCH_RECIPIENT = (1 << 2),
133         MODEST_DBUS_SEARCH_SIZE      = (1 << 3),
134         MODEST_DBUS_SEARCH_BODY      = (1 << 6)
135
136 } ModestDBusSearchFlags;
137
138 typedef struct {
139         gchar     *msgid; /* E.g. the URI of the message. */
140         gchar     *subject;
141         gchar     *folder; /* The name, not the URI. */
142         gchar     *sender;
143         guint64    msize;
144         gboolean   has_attachment;
145         gboolean   is_unread;
146         gint64     timestamp;            
147 } ModestSearchHit;
148
149
150 void modest_search_hit_list_free (GList *hits);
151
152
153 gboolean libmodest_dbus_client_search            (osso_context_t          *osso_ctx,
154                                                   const gchar             *query,
155                                                   const gchar             *folder,
156                                                   time_t                   start_date,
157                                                   time_t                   end_date,
158                                                   guint32                  min_size,
159                                                   ModestDBusSearchFlags    flags,
160                                                   GList                  **hits);
161
162 gboolean libmodest_dbus_client_delete_message   (osso_context_t   *osso_ctx,
163                                                  const char       *msg_uri);
164
165
166 typedef struct {
167         gchar     *folder_uri;
168         gchar     *folder_name;  
169 } ModestFolderResult;
170
171 gboolean libmodest_dbus_client_get_folders (osso_context_t *osso_ctx, GList **folders); 
172
173 void modest_folder_result_list_free (GList *folders);
174
175                                                 
176                                                         
177 #endif /* __LIBMODEST_DBUS_CLIENT_H__ */