1 /* Copyright (c) 2008, 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.
32 #include "modest-utils.h"
33 #include "modest-runtime.h"
34 #include "modest-platform.h"
35 #include "modest-security-options-view.h"
36 #include "modest-security-options-view-priv.h"
37 #ifdef MODEST_TOOLKIT_HILDON2
38 #include "modest-serversecurity-picker.h"
39 #include "modest-secureauth-picker.h"
40 #include <modest-hildon-includes.h>
42 #include "widgets/modest-serversecurity-combo-box.h"
43 #include "widgets/modest-secureauth-combo-box.h"
48 MISSING_MANDATORY_DATA_SIGNAL,
52 static guint signals[LAST_SIGNAL] = {0};
55 modest_security_options_view_load_settings (ModestSecurityOptionsView* self,
56 ModestAccountSettings *settings)
58 ModestSecurityOptionsViewPrivate *priv;
59 ModestServerAccountSettings *server_settings;
60 ModestProtocolType server_proto, secure_protocol, secure_auth;
62 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
64 /* Save initial settings */
65 if (self->type == MODEST_SECURITY_OPTIONS_INCOMING)
66 server_settings = modest_account_settings_get_store_settings (settings);
68 server_settings = modest_account_settings_get_transport_settings (settings);
70 server_proto = modest_server_account_settings_get_protocol (server_settings);
71 secure_protocol = modest_server_account_settings_get_security_protocol (server_settings);
72 secure_auth = modest_server_account_settings_get_auth_protocol (server_settings);
74 priv->initial_state.security = secure_protocol;
75 priv->initial_state.auth = secure_auth;
76 priv->initial_state.port = modest_server_account_settings_get_port (server_settings);
79 modest_security_options_view_set_server_type (self, server_proto);
80 #ifdef MODEST_TOOLKIT_HILDON2
81 modest_serversecurity_picker_set_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view), secure_protocol);
83 modest_serversecurity_combo_box_set_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view), secure_protocol);
86 /* update_incoming_server_title (dialog, dialog->incoming_protocol); */
88 /* Username and password */
89 if (priv->full && self->type == MODEST_SECURITY_OPTIONS_OUTGOING) {
90 priv->initial_state.user =
91 modest_server_account_settings_get_username (server_settings);
92 priv->initial_state.pwd =
93 modest_server_account_settings_get_password (server_settings);
95 if (priv->initial_state.user)
96 gtk_entry_set_text(GTK_ENTRY (priv->user_entry),
97 priv->initial_state.user);
98 if (priv->initial_state.pwd)
99 gtk_entry_set_text(GTK_ENTRY (priv->pwd_entry),
100 priv->initial_state.pwd);
104 if (self->type == MODEST_SECURITY_OPTIONS_INCOMING) {
105 /* Active the authentication checkbox */
106 if (modest_protocol_registry_protocol_type_is_secure (modest_runtime_get_protocol_registry (),
108 modest_togglable_set_active (priv->auth_view,
111 #ifdef MODEST_TOOLKIT_HILDON2
112 modest_secureauth_picker_set_active_secureauth (
113 MODEST_SECUREAUTH_PICKER (priv->auth_view), secure_auth);
115 modest_secureauth_combo_box_set_active_secureauth (
116 MODEST_SECUREAUTH_COMBO_BOX (priv->auth_view), secure_auth);
120 MODEST_SECURITY_OPTIONS_VIEW_GET_CLASS (self)->load_settings (self, settings);
123 g_object_unref (server_settings);
127 modest_security_options_view_save_settings (ModestSecurityOptionsView* self,
128 ModestAccountSettings *settings)
130 ModestServerAccountSettings *server_settings;
131 ModestProtocolType security_proto, auth_protocol;
132 ModestSecurityOptionsViewPrivate *priv;
133 ModestProtocolRegistry *proto_registry;
135 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
136 proto_registry = modest_runtime_get_protocol_registry ();
138 if (self->type == MODEST_SECURITY_OPTIONS_INCOMING)
139 server_settings = modest_account_settings_get_store_settings (settings);
141 server_settings = modest_account_settings_get_transport_settings (settings);
144 security_proto = MODEST_PROTOCOLS_CONNECTION_NONE;
145 auth_protocol = MODEST_PROTOCOLS_AUTH_NONE;
148 #ifdef MODEST_TOOLKIT_HILDON2
149 security_proto = modest_serversecurity_picker_get_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view));
151 security_proto = modest_serversecurity_combo_box_get_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view));
154 if (self->type == MODEST_SECURITY_OPTIONS_INCOMING) {
155 if (modest_togglable_get_active (priv->auth_view)) {
156 if (!modest_protocol_registry_protocol_type_is_secure (proto_registry,
159 /* auth_protocol = check_first_supported_auth_method (self); */
160 auth_protocol = MODEST_PROTOCOLS_AUTH_PASSWORD;
162 auth_protocol = MODEST_PROTOCOLS_AUTH_PASSWORD;
166 #ifdef MODEST_TOOLKIT_HILDON2
167 auth_protocol = modest_secureauth_picker_get_active_secureauth (
168 MODEST_SECUREAUTH_PICKER (priv->auth_view));
170 auth_protocol = modest_secureauth_combo_box_get_active_secureauth (
171 MODEST_SECUREAUTH_COMBO_BOX (priv->auth_view));
176 modest_server_account_settings_set_security_protocol (server_settings,
178 modest_server_account_settings_set_auth_protocol (server_settings,
181 if (priv->full && self->type == MODEST_SECURITY_OPTIONS_OUTGOING) {
182 const gchar *username, *password;
184 username = gtk_entry_get_text (GTK_ENTRY (priv->user_entry));
185 password = gtk_entry_get_text (GTK_ENTRY (priv->pwd_entry));
187 modest_server_account_settings_set_username (server_settings, username);
188 modest_server_account_settings_set_password (server_settings, password);
191 MODEST_SECURITY_OPTIONS_VIEW_GET_CLASS (self)->save_settings (self, settings);
195 g_object_unref (server_settings);
199 modest_security_options_view_set_server_type (ModestSecurityOptionsView* self,
200 ModestProtocolType server_type)
202 ModestSecurityOptionsViewPrivate *priv;
203 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
205 #ifdef MODEST_TOOLKIT_HILDON2
206 modest_serversecurity_picker_fill (MODEST_SERVERSECURITY_PICKER (priv->security_view), server_type);
207 modest_serversecurity_picker_set_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view),
208 MODEST_PROTOCOLS_CONNECTION_NONE);
210 modest_serversecurity_combo_box_fill (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view), server_type);
211 modest_serversecurity_combo_box_set_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view),
212 MODEST_PROTOCOLS_CONNECTION_NONE);
217 get_current_state (ModestSecurityOptionsView* self,
218 ModestSecurityOptionsState *state)
220 ModestSecurityOptionsViewPrivate *priv;
221 ModestProtocolRegistry *proto_registry;
223 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
224 proto_registry = modest_runtime_get_protocol_registry ();
227 #ifdef MODEST_TOOLKIT_HILDON2
229 modest_serversecurity_picker_get_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view));
231 modest_serversecurity_picker_get_active_serversecurity_port (MODEST_SERVERSECURITY_PICKER (priv->security_view));
234 modest_serversecurity_combo_box_get_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view));
236 modest_serversecurity_combo_box_get_active_serversecurity_port (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view));
240 if (self->type == MODEST_SECURITY_OPTIONS_OUTGOING) {
241 #ifdef MODEST_TOOLKIT_HILDON2
242 state->auth = modest_secureauth_picker_get_active_secureauth (MODEST_SECUREAUTH_PICKER (priv->auth_view));
244 state->auth = modest_secureauth_combo_box_get_active_secureauth (MODEST_SECUREAUTH_COMBO_BOX (priv->auth_view));
249 if (modest_togglable_get_active (priv->auth_view))
250 state->auth = priv->initial_state.auth;
252 state->auth = MODEST_PROTOCOLS_AUTH_NONE;
257 modest_security_options_view_changed (ModestSecurityOptionsView* self,
258 ModestAccountSettings *settings)
260 ModestSecurityOptionsViewPrivate *priv;
261 ModestSecurityOptionsState state = {0};
263 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
265 get_current_state (self, &state);
267 if (state.security != priv->initial_state.security ||
268 state.auth != priv->initial_state.auth)
271 if (priv->full && self->type == MODEST_SECURITY_OPTIONS_OUTGOING) {
272 const gchar *username, *password;
274 username = gtk_entry_get_text (GTK_ENTRY (priv->user_entry));
275 password = gtk_entry_get_text (GTK_ENTRY (priv->pwd_entry));
277 if (!priv->initial_state.user && strcmp (username, ""))
279 if (!priv->initial_state.pwd && strcmp (password, ""))
282 if ((priv->initial_state.user &&
283 strcmp (priv->initial_state.user, username)) ||
284 (priv->initial_state.pwd &&
285 strcmp (priv->initial_state.pwd, password)))
290 return MODEST_SECURITY_OPTIONS_VIEW_GET_CLASS (self)->changed (self, settings);
294 modest_security_options_view_enable_changes (ModestSecurityOptionsView* self,
297 ModestSecurityOptionsViewPrivate *priv;
299 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
300 gtk_widget_set_sensitive (priv->port_view, enable);
301 gtk_widget_set_sensitive (priv->security_view, enable);
305 modest_security_options_view_auth_check (ModestSecurityOptionsView* self)
307 ModestSecurityOptionsViewPrivate *priv;
308 ModestProtocolType security_incoming_type;
309 gboolean auth_active, is_secure;
310 ModestProtocolRegistry *protocol_registry;
312 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
313 protocol_registry = modest_runtime_get_protocol_registry ();
315 /* Check if the server supports secure authentication */
316 #ifdef MODEST_TOOLKIT_HILDON2
317 security_incoming_type =
318 modest_serversecurity_picker_get_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view));
320 security_incoming_type =
321 modest_serversecurity_combo_box_get_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view));
325 modest_togglable_get_active (priv->auth_view);
327 modest_protocol_registry_protocol_type_has_tag (protocol_registry,
328 security_incoming_type,
329 MODEST_PROTOCOL_REGISTRY_SECURE_PROTOCOLS);
331 if (auth_active && !is_secure)
338 modest_security_options_view_get_connection_protocol (ModestSecurityOptionsView *self)
340 ModestSecurityOptionsViewPrivate *priv;
342 g_return_val_if_fail (MODEST_IS_SECURITY_OPTIONS_VIEW (self), MODEST_PROTOCOL_REGISTRY_TYPE_INVALID);
343 priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
345 #ifdef MODEST_TOOLKIT_HILDON2
346 return modest_serversecurity_picker_get_active_serversecurity (MODEST_SERVERSECURITY_PICKER (priv->security_view));
348 return modest_serversecurity_combo_box_get_active_serversecurity (MODEST_SERVERSECURITY_COMBO_BOX (priv->security_view));
353 modest_security_options_view_init (ModestSecurityOptionsView *self)
355 ModestSecurityOptionsViewPrivate *priv = MODEST_SECURITY_OPTIONS_VIEW_GET_PRIVATE (self);
357 memset (&(priv->initial_state), 0, sizeof (ModestSecurityOptionsState));
359 priv->security_view = NULL;
360 priv->port_view = NULL;
361 priv->auth_view = NULL;
362 priv->user_entry = NULL;
363 priv->pwd_entry = NULL;
365 priv->changed = FALSE;
369 modest_security_options_view_class_init (ModestSecurityOptionsViewClass *klass)
371 GObjectClass *gobject_class = (GObjectClass*) klass;
373 g_type_class_add_private (gobject_class, sizeof (ModestSecurityOptionsViewPrivate));
375 /* Register signals */
376 signals[MISSING_MANDATORY_DATA_SIGNAL] =
377 g_signal_new ("missing_mandatory_data",
378 MODEST_TYPE_SECURITY_OPTIONS_VIEW,
380 G_STRUCT_OFFSET(ModestSecurityOptionsViewClass, missing_mandatory_data),
382 g_cclosure_marshal_VOID__BOOLEAN,
383 G_TYPE_NONE, 1, G_TYPE_BOOLEAN);
386 /* Type definition */
387 G_DEFINE_ABSTRACT_TYPE (ModestSecurityOptionsView,
388 modest_security_options_view,