1 /* Copyright (c) 2006, Nokia Corporation
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
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.
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.
30 #include <string.h> /* for strcmp */
31 #include <modest-protocol-registry.h>
32 #include <modest-runtime.h>
33 #include "modest-presets.h"
36 /* Include config.h so that _() works: */
41 #define MODEST_PRESETS_KEY_NAME "Name"
42 #define MODEST_PRESETS_KEY_DOMAIN "Domain"
43 #define MODEST_PRESETS_KEY_MCC "MCC"
44 #define MODEST_PRESETS_KEY_INCOMING "IncomingMailServer"
45 #define MODEST_PRESETS_KEY_INCOMING_SECURITY "IncomingSecurity"
46 #define MODEST_PRESETS_KEY_OUTGOING "OutgoingMailServer"
47 #define MODEST_PRESETS_KEY_MAILBOX_TYPE "MailboxType"
48 #define MODEST_PRESETS_KEY_APOP "APOPSecureLogin"
49 #define MODEST_PRESETS_KEY_SECURE_SMTP "SecureSmtp"
50 #define MODEST_PRESETS_KEY_SMTP_PORT "SmtpPort"
54 modest_presets_new (const gchar *presetfile)
56 ModestPresets *presets = NULL;
59 g_return_val_if_fail (presetfile, NULL);
61 presets = g_new (ModestPresets, 1);
62 presets->keyfile = g_key_file_new ();
64 if (!presets->keyfile) {
65 g_printerr ("modest: cannot instantiate GKeyFile\n");
70 if (!g_key_file_load_from_file (presets->keyfile, presetfile,
71 G_KEY_FILE_NONE, &err)) {
72 g_printerr ("modest: cannot open keyfile from %s:\n %s\n", presetfile,
73 err ? err->message : "unknown reason");
83 modest_presets_get_providers (ModestPresets *self, guint mcc,
84 gboolean include_globals, gchar ***provider_ids)
86 gchar **all_providers = NULL;
87 gchar **all_provider_ids = NULL;
88 gchar **filtered = NULL;
89 gchar **filtered_ids = NULL;
93 g_return_val_if_fail (self && self->keyfile, NULL);
95 /* Get all the provider IDs: */
96 all_provider_ids = g_key_file_get_groups (self->keyfile, NULL);
97 len = g_strv_length(all_provider_ids);
99 /* Get the names for all these providers: */
100 all_providers = g_new0(gchar*, len + 1); /* Provider names. */
101 for (i=0; i != len; ++i) {
102 const gchar * provider_id = all_provider_ids[i];
104 gchar* name = g_key_file_get_string(self->keyfile, provider_id,
105 MODEST_PRESETS_KEY_NAME, NULL);
107 /* Be forgiving of missing names.
108 * If we use NULL then we will null-terminate the array.
113 all_providers[i] = name;
116 all_providers[i] = NULL;
119 /* return *all* providers? */
121 if (mcc == 0 && include_globals) {
122 *provider_ids = all_provider_ids;
123 return all_providers;
127 /* nope: filter them */
129 filtered = g_new0(gchar*, len + 1); /* Provider names. */
130 filtered_ids = g_new0(gchar*, len + 1); /* Provider IDs */
132 for (i=0, j=0; i != len; ++i) {
135 this_mcc = g_key_file_get_integer (self->keyfile, all_provider_ids[i],
136 MODEST_PRESETS_KEY_MCC, &err);
138 g_strfreev (all_providers);
139 g_strfreev (all_provider_ids);
140 g_strfreev (filtered);
141 g_strfreev (filtered_ids);
143 g_printerr ("modest: error parsing keyfile: %s\n", err->message);
149 if (this_mcc == mcc || (this_mcc == 0 && include_globals)) {
150 filtered[j] = all_providers[i];
151 filtered_ids[j] = all_provider_ids[i];
153 filtered[j] = NULL; /* the array must be NULL-terminated */
154 filtered_ids[j] = NULL; /* the array must be NULL-terminated */
156 all_providers[i] = NULL; /* g_strfreev: leave it alone */
157 all_provider_ids[i] = NULL; /* g_strfreev: leave it alone */
161 g_strfreev (all_providers);
162 g_strfreev (all_provider_ids);
164 *provider_ids = filtered_ids;
170 modest_presets_get_server (ModestPresets *self, const gchar *provider_id,
171 gboolean incoming_server)
173 g_return_val_if_fail (self && self->keyfile, NULL);
174 g_return_val_if_fail (provider_id, NULL);
176 return g_key_file_get_string (self->keyfile, provider_id,
178 MODEST_PRESETS_KEY_INCOMING :
179 MODEST_PRESETS_KEY_OUTGOING,
184 modest_presets_get_domain (ModestPresets *self,
185 const gchar *provider_id)
187 g_return_val_if_fail (self && self->keyfile, NULL);
188 g_return_val_if_fail (provider_id, NULL);
190 return g_key_file_get_string (self->keyfile, provider_id,
191 MODEST_PRESETS_KEY_DOMAIN,
199 modest_presets_get_info_server_type (ModestPresets *self,
200 const gchar *provider_id,
201 gboolean incoming_server)
203 ModestProtocolType protocol_type = MODEST_PROTOCOL_REGISTRY_TYPE_INVALID;
204 ModestProtocolRegistry *protocol_registry;
205 ModestProtocol *protocol;
208 g_return_val_if_fail (self && self->keyfile, 0);
209 protocol_registry = modest_runtime_get_protocol_registry ();
211 if (incoming_server) {
212 val = g_key_file_get_string (self->keyfile, provider_id,
213 MODEST_PRESETS_KEY_INCOMING, NULL);
215 return protocol_type;
218 val = g_key_file_get_string (self->keyfile, provider_id,
219 MODEST_PRESETS_KEY_MAILBOX_TYPE,NULL);
221 protocol = modest_protocol_registry_get_protocol_by_name (protocol_registry, MODEST_PROTOCOL_REGISTRY_STORE_PROTOCOLS, val);
222 if (protocol == NULL)
223 return protocol_type;
224 protocol_type = modest_protocol_get_type_id (protocol);
226 val = g_key_file_get_string (self->keyfile, provider_id,
227 MODEST_PRESETS_KEY_OUTGOING, NULL);
229 return protocol_type;
231 protocol_type = MODEST_PROTOCOLS_TRANSPORT_SMTP;
236 /* g_message ("provider id: %s, server type: %d", provider_id, info); */
237 return protocol_type;
243 modest_presets_get_info_server_security (ModestPresets *self, const gchar *provider_id,
244 gboolean incoming_server)
246 ModestProtocolType protocol_type = MODEST_PROTOCOLS_CONNECTION_NONE;
249 g_return_val_if_fail (self && self->keyfile, MODEST_PROTOCOLS_CONNECTION_NONE);
251 if (incoming_server) {
252 val = g_key_file_get_string (self->keyfile, provider_id,
253 MODEST_PRESETS_KEY_INCOMING, NULL);
257 val = g_key_file_get_string (self->keyfile, provider_id,
258 MODEST_PRESETS_KEY_INCOMING_SECURITY, NULL);
259 if (val && ((strcmp (val, "1") == 0) || (strcmp (val, "2") == 0))) {
260 protocol_type = MODEST_PROTOCOLS_CONNECTION_SSL;
264 } else /* outgoing: */ {
265 val = g_key_file_get_string (self->keyfile, provider_id,
266 MODEST_PRESETS_KEY_OUTGOING, NULL);
270 val = g_key_file_get_string (self->keyfile, provider_id,
271 MODEST_PRESETS_KEY_SECURE_SMTP, NULL);
272 /* printf("debug: %s: provider_id=%s, secure-smtp val=%s\n", __FUNCTION__, provider_id, val); */
273 if (val && strcmp(val,"true") == 0)
274 protocol_type = MODEST_PROTOCOLS_CONNECTION_SSL;
279 return protocol_type;
283 modest_presets_get_info_server_use_alternate_port (ModestPresets *self, const gchar *provider_id,
284 gboolean incoming_server)
286 gboolean result = FALSE;
289 g_return_val_if_fail (self && self->keyfile, MODEST_PROTOCOLS_CONNECTION_NONE);
291 if (incoming_server) {
292 val = g_key_file_get_string (self->keyfile, provider_id,
293 MODEST_PRESETS_KEY_INCOMING, NULL);
297 val = g_key_file_get_string (self->keyfile, provider_id,
298 MODEST_PRESETS_KEY_INCOMING_SECURITY, NULL);
299 if (val && (strcmp (val, "2") == 0)) {
310 modest_presets_get_info_server_auth (ModestPresets *self, const gchar *provider_id,
311 gboolean incoming_server)
313 ModestProtocolType protocol_type = MODEST_PROTOCOLS_AUTH_NONE;
316 g_return_val_if_fail (self && self->keyfile, MODEST_PROTOCOLS_AUTH_NONE);
318 if (incoming_server) {
319 val = g_key_file_get_string (self->keyfile, provider_id,
320 MODEST_PRESETS_KEY_INCOMING, NULL);
323 val = g_key_file_get_string (self->keyfile, provider_id,
324 MODEST_PRESETS_KEY_APOP, NULL);
325 if (val && strcmp(val, "true") == 0)
326 protocol_type = MODEST_PROTOCOLS_AUTH_PASSWORD;
330 } else /* outgoing: */ {
331 val = g_key_file_get_string (self->keyfile, provider_id,
332 MODEST_PRESETS_KEY_OUTGOING, NULL);
336 val = g_key_file_get_string (self->keyfile, provider_id,
337 MODEST_PRESETS_KEY_SECURE_SMTP, NULL);
338 /* printf("debug: %s: provider_id=%s, secure-smtp val=%s\n", __FUNCTION__, provider_id, val); */
339 if (val && strcmp(val,"true") == 0)
340 protocol_type = MODEST_PROTOCOLS_AUTH_PASSWORD;
345 return protocol_type;
349 * at the moment, this only for mac.com, which have a special SMTP port
352 modest_presets_get_port (ModestPresets *self, const gchar* provider_id,
353 gboolean incoming_server)
357 g_return_val_if_fail (self && self->keyfile, 0);
360 port = 0; /* not used yet */
362 port = (guint)g_key_file_get_integer (self->keyfile, provider_id,
363 MODEST_PRESETS_KEY_SMTP_PORT, NULL);
373 modest_presets_destroy (ModestPresets *self)
378 g_key_file_free (self->keyfile);
379 self->keyfile = NULL;