commit - 9490382715e2690d547c0e39a55e555e770fa222
commit + 9876f5c928084f0fb34d70055f2aca8930156349
blob - f8bd67bb4429af7e6e4cf0da96cd8a19494370fd
blob + 1d5ec71a3f3e3984541903b9bc33830dc2a613bc
--- src/Makefile.am
+++ src/Makefile.am
oauth2.c \
partial_download.c \
password.c \
- password_gtk.c \
passwordstore.c \
pop.c \
prefs_account.c \
oauth2.h \
partial_download.h \
password.h \
- password_gtk.h \
passwordstore.h \
pop.h \
prefs_account.h \
blob - 7db688cb0cee34ae5ba0f83277012923653f3536
blob + c03e52a04f020ca42e13c1f59f8c0b8186c3b86e
--- src/addressbook.c
+++ src/addressbook.c
#include "codeconv.h"
#include "about.h"
#include "addr_compl.h"
-#include "password.h"
#include "mgutils.h"
#include "addressitem.h"
blob - 30498fda04c2607f3b7b88d907647dabb54d6cc5
blob + d46ab1a9ae7e57e6f38fec28aad04fe5f5a56c03
--- src/gtk/inputdialog.c
+++ src/gtk/inputdialog.c
is_pass = TRUE;
gtk_entry_set_visibility(GTK_ENTRY(entry), FALSE);
- if (prefs_common.passphrase_dialog_msg_title_switch)
- return input_dialog_open(message, title, NULL, default_string, FALSE, NULL);
- else
- return input_dialog_open(title, message, NULL, default_string, FALSE, NULL);
+ return input_dialog_open(title, message, NULL, default_string, FALSE, NULL);
}
gchar *input_dialog_with_invisible_checkbtn(const gchar *title, const gchar *message,
is_pass = TRUE;
gtk_entry_set_visibility(GTK_ENTRY(entry), FALSE);
- if (prefs_common.passphrase_dialog_msg_title_switch)
- return input_dialog_open(message, title, checkbtn_label,
- default_string, (checkbtn_state? *checkbtn_state:FALSE),
- checkbtn_state);
- else
- return input_dialog_open(title, message, checkbtn_label,
- default_string, (checkbtn_state? *checkbtn_state:FALSE),
- checkbtn_state);
+ return input_dialog_open(title, message, checkbtn_label,
+ default_string, (checkbtn_state? *checkbtn_state:FALSE),
+ checkbtn_state);
}
gchar *input_dialog_combo(const gchar *title, const gchar *message,
blob - 85e90780d4fdacec8a8d03b0510b10943115da00
blob + 79ca3e232da2014e58882b50b1e2d91fab6c5148
--- src/mainwindow.c
+++ src/mainwindow.c
static void forget_session_passwords_cb (GtkAction *action,
gpointer data );
-static void forget_primary_passphrase_cb (GtkAction *action,
- gpointer data );
static gboolean mainwindow_focus_in_event (GtkWidget *widget,
GdkEventFocus *focus,
gpointer data);
/* {"Tools/---", NULL, "---", NULL, NULL, NULL }, */
{"Tools/ForgetSessionPasswords", NULL, N_("_Forget all session passwords"), NULL, NULL, G_CALLBACK(forget_session_passwords_cb) },
- {"Tools/ForgetPrimaryPassphrase", NULL, N_("Forget _primary passphrase"), NULL, NULL, G_CALLBACK(forget_primary_passphrase_cb) },
/* Configuration menu */
{"Configuration/ChangeAccount", NULL, N_("C_hange current account"), NULL, NULL, NULL },
MENUITEM_ADDUI_MANAGER(mainwin->ui_manager, "/Menu/Tools", "NetworkLog", "Tools/NetworkLog", GTK_UI_MANAGER_MENUITEM)
MENUITEM_ADDUI_MANAGER(mainwin->ui_manager, "/Menu/Tools", "Separator8", "Tools/---", GTK_UI_MANAGER_SEPARATOR)
MENUITEM_ADDUI_MANAGER(mainwin->ui_manager, "/Menu/Tools", "ForgetSessionPasswords", "Tools/ForgetSessionPasswords", GTK_UI_MANAGER_MENUITEM)
- MENUITEM_ADDUI_MANAGER(mainwin->ui_manager, "/Menu/Tools", "ForgetPrimaryPassphrase", "Tools/ForgetPrimaryPassphrase", GTK_UI_MANAGER_MENUITEM)
MENUITEM_ADDUI_MANAGER(mainwin->ui_manager, "/Menu/Tools", "Separator9", "Tools/---", GTK_UI_MANAGER_SEPARATOR)
/* Configuration menu */
}
}
- if (primary_passphrase_is_entered()) {
- UPDATE_STATE(M_MASTER_PASSPHRASE);
- }
-
#undef UPDATE_STATE
return state;
SET_SENSITIVE("Menu/Tools/Execute", M_DELAY_EXEC);
SET_SENSITIVE("Menu/Tools/Expunge", M_DELETED_EXISTS);
SET_SENSITIVE("Menu/Tools/ForgetSessionPasswords", M_SESSION_PASSWORDS);
- SET_SENSITIVE("Menu/Tools/ForgetPrimaryPassphrase", M_MASTER_PASSPHRASE);
SET_SENSITIVE("Menu/Tools/DeleteDuplicates/SelFolder", M_MSG_EXIST, M_ALLOW_DELETE);
SET_SENSITIVE("Menu/Configuration", M_UNLOCKED);
fgtn), fgtn, accs);
}
-static void forget_primary_passphrase_cb(GtkAction *action, gpointer data)
-{
- MainWindow *mainwin = (MainWindow *)data;
-
- main_window_lock(mainwin);
- primary_passphrase_forget();
- main_window_unlock(mainwin);
-}
-
void mainwindow_learn (MainWindow *mainwin, gboolean is_spam)
{
summary_mark_as_spam(mainwin->summaryview, is_spam, NULL);
blob - cc9f245c9006ceae319818e56295cd7aed99c021
blob + 72b4d919e2b44659661156a64033786478d9a634
--- src/password.c
+++ src/password.c
#include "passwordstore.h"
#include "prefs_common.h"
-static gchar *_primary_passphrase = NULL;
-
/* Length of stored key derivation, before base64. */
#define KD_LENGTH 64
return NULL;
}
-const gchar *primary_passphrase()
-{
- gchar *input;
- gboolean end = FALSE;
-
- if (!prefs_common_get_prefs()->use_primary_passphrase) {
- return PASSCRYPT_KEY;
- }
-
- if (_primary_passphrase != NULL) {
- debug_print("Primary passphrase is in memory, offering it.\n");
- return _primary_passphrase;
- }
-
- while (!end) {
- input = input_dialog_with_invisible(_("Input primary passphrase"),
- _("Input primary passphrase"), NULL);
-
- if (input == NULL) {
- debug_print("Cancel pressed at primary passphrase dialog.\n");
- break;
- }
-
- if (primary_passphrase_is_correct(input)) {
- debug_print("Entered primary passphrase seems to be correct, remembering it.\n");
- _primary_passphrase = input;
- end = TRUE;
- } else {
- alertpanel_error(_("Incorrect primary passphrase."));
- }
- }
-
- return _primary_passphrase;
-}
-
-gboolean primary_passphrase_is_set()
-{
- if (prefs_common_get_prefs()->primary_passphrase == NULL
- || strlen(prefs_common_get_prefs()->primary_passphrase) == 0)
- return FALSE;
-
- return TRUE;
-}
-
-gboolean primary_passphrase_is_correct(const gchar *input)
-{
- guchar *kd, *input_kd;
- gchar **tokens;
- gchar *stored_kd = prefs_common_get_prefs()->primary_passphrase;
- gsize kd_len;
- guint rounds = 0;
- gint ret;
-
- g_return_val_if_fail(stored_kd != NULL && strlen(stored_kd) > 0, FALSE);
- g_return_val_if_fail(input != NULL, FALSE);
-
- tokens = g_strsplit_set(stored_kd, "{}", 3);
- if (tokens[0] == NULL ||
- strlen(tokens[0]) != 0 || /* nothing before { */
- tokens[1] == NULL ||
- strncmp(tokens[1], "PBKDF2-HMAC-SHA1,", 17) || /* correct tag */
- strlen(tokens[1]) <= 17 || /* something after , */
- (rounds = atoi(tokens[1] + 17)) <= 0 || /* valid rounds # */
- tokens[2] == NULL ||
- strlen(tokens[2]) == 0) { /* string continues after } */
- debug_print("Mangled primary_passphrase format in config, can not use it.\n");
- g_strfreev(tokens);
- return FALSE;
- }
-
- stored_kd = tokens[2];
- kd = g_base64_decode(stored_kd, &kd_len); /* should be 64 */
- g_strfreev(tokens);
-
- if (kd_len != KD_LENGTH) {
- debug_print("primary_passphrase is %"G_GSIZE_FORMAT" bytes long, should be %d.\n",
- kd_len, KD_LENGTH);
- g_free(kd);
- return FALSE;
- }
-
- input_kd = _make_key_deriv(input, rounds, KD_LENGTH);
- ret = memcmp(kd, input_kd, kd_len);
-
- g_free(input_kd);
- g_free(kd);
-
- if (ret == 0)
- return TRUE;
-
- return FALSE;
-}
-
-gboolean primary_passphrase_is_entered()
-{
- return (_primary_passphrase == NULL) ? FALSE : TRUE;
-}
-
-void primary_passphrase_forget()
-{
- /* If primary passphrase is currently in memory (entered by user),
- * get rid of it. User will have to enter the new one again. */
- if (_primary_passphrase != NULL) {
- memset(_primary_passphrase, 0, strlen(_primary_passphrase));
- g_free(_primary_passphrase);
- _primary_passphrase = NULL;
- }
-}
-
-void primary_passphrase_change(const gchar *oldp, const gchar *newp)
-{
- guchar *kd;
- gchar *base64_kd;
- guint rounds = prefs_common_get_prefs()->primary_passphrase_pbkdf2_rounds;
-
- g_return_if_fail(rounds > 0);
-
- if (oldp == NULL) {
- /* If oldp is NULL, make sure the user has to enter the
- * current primary passphrase before being able to change it. */
- primary_passphrase_forget();
- oldp = primary_passphrase();
- }
- g_return_if_fail(oldp != NULL);
-
- /* Update primary passphrase hash in prefs */
- if (prefs_common_get_prefs()->primary_passphrase != NULL)
- g_free(prefs_common_get_prefs()->primary_passphrase);
-
- if (newp != NULL) {
- debug_print("Storing key derivation of new primary passphrase\n");
- kd = _make_key_deriv(newp, rounds, KD_LENGTH);
- base64_kd = g_base64_encode(kd, 64);
- prefs_common_get_prefs()->primary_passphrase =
- g_strdup_printf("{PBKDF2-HMAC-SHA1,%d}%s", rounds, base64_kd);
- g_free(kd);
- g_free(base64_kd);
- } else {
- debug_print("Setting primary_passphrase to NULL\n");
- prefs_common_get_prefs()->primary_passphrase = NULL;
- }
-
- /* Now go over all accounts, reencrypting their passwords using
- * the new primary passphrase. */
-
- if (oldp == NULL)
- oldp = PASSCRYPT_KEY;
- if (newp == NULL)
- newp = PASSCRYPT_KEY;
-
- debug_print("Reencrypting all account passwords...\n");
- passwd_store_reencrypt_all(oldp, newp);
-
- primary_passphrase_forget();
-}
-
-/* Decryption is still needed for supporting migration of old
- * configurations to newer encryption mechanisms. */
-gchar *password_decrypt_old(const gchar *password)
-{
- if (!password || strlen(password) == 0) {
- return NULL;
- }
-
- if (*password != '!' || strlen(password) < 2) {
- return NULL;
- }
-
- gsize len;
- gchar *decrypted = g_base64_decode(password + 1, &len);
-
- passcrypt_decrypt(decrypted, len);
- return decrypted;
-}
-
#define BUFSIZE 128
/* Since we can't count on having GnuTLS new enough to have
}
if (encryption_passphrase == NULL)
- encryption_passphrase = primary_passphrase();
+ encryption_passphrase = PASSCRYPT_KEY;
return password_encrypt_real(password, encryption_passphrase);
}
return NULL;
}
- /* First, check if the password was possibly decrypted using old,
- * obsolete method */
- if (*password == '!') {
- debug_print("Trying to decrypt password using the old method...\n");
- return password_decrypt_old(password);
- }
-
/* Try available crypto backend */
if (decryption_passphrase == NULL)
- decryption_passphrase = primary_passphrase();
+ decryption_passphrase = PASSCRYPT_KEY;
if (*password == '{') {
debug_print("Trying to decrypt password...\n");
blob - 85bc4be4e50fdbec4a40b611d26f4c772f12e2a8
blob + bcf4d06004b030e34b243f50d59417d9b93d0c92
--- src/password.h
+++ src/password.h
#include <glib.h>
-/* Returns a pointer to primary passphrase, asking the user
- * if necessary. Do not free the return value. */
-const gchar *primary_passphrase();
-
-/* Returns TRUE if there is a primary passphrase set in preferences. */
-gboolean primary_passphrase_is_set();
-/* Returns TRUE if input contains correct primary passphrase, as set
- * in preferences. */
-gboolean primary_passphrase_is_correct(const gchar *input);
-/* Returns TRUE if primary passphrase is entered (unlocked). */
-gboolean primary_passphrase_is_entered();
-/* Removes (locks) primary passphrase, if it was entered previously
- * in current session. */
-void primary_passphrase_forget();
-
-/* Changes primary passphrase. Also triggers reencryption of all stored
- * passwords using the new primary passphrase.
- * oldp - old primary passphrase; if NULL, it will be retrieved using
- * primary_passphrase()
- * newp - new primary passphrase */
-void primary_passphrase_change(const gchar *oldp, const gchar *newp);
-
gchar *password_encrypt_gnutls(const gchar *password,
const gchar *encryption_passphrase);
gchar *password_decrypt_gnutls(const gchar *password,
blob - 814c14ed5f42005e2892ab0dbeb9178e4e4ddfe6 (mode 644)
blob + /dev/null
--- src/password_gtk.c
+++ /dev/null
-/*
- * Claws Mail -- a GTK based, lightweight, and fast e-mail client
- * Copyright (C) 2016-2025 the Claws Mail team and Andrej Kacian
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#ifdef HAVE_CONFIG_H
-#include "config.h"
-#include "claws-features.h"
-#endif
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-
-#include "common/utils.h"
-#include "gtk/manage_window.h"
-#include "gtk/gtkutils.h"
-#include "account.h"
-#include "alertpanel.h"
-#include "password.h"
-#include "prefs_common.h"
-
-static void entry_activated(GtkEntry *entry, gpointer user_data)
-{
- const gchar *text = gtk_entry_get_text(entry);
-
- if (strlen(text) > 0)
- gtk_widget_grab_focus(GTK_WIDGET(user_data));
-}
-
-struct _ctx {
- gboolean done;
- GtkWidget *dialog;
- GtkWidget *entry_old;
- GtkWidget *entry_new1;
- GtkWidget *entry_new2;
-};
-
-static void ok_button_clicked(GtkButton *button, gpointer user_data)
-{
- struct _ctx *ctx = (struct _ctx *)user_data;
- const gchar *old = NULL;
- const gchar *new1 = gtk_entry_get_text(GTK_ENTRY(ctx->entry_new1));
- const gchar *new2 = gtk_entry_get_text(GTK_ENTRY(ctx->entry_new2));
-
- debug_print("OK button activated\n");
-
- /* Now we check the new passphrase - same in both entries. */
- if (strcmp(new1, new2)) {
- debug_print("passphrases do not match\n");
- alertpanel_warning(_("New passphrases do not match, try again."));
- gtk_entry_set_text(GTK_ENTRY(ctx->entry_new1), "");
- gtk_entry_set_text(GTK_ENTRY(ctx->entry_new2), "");
- gtk_widget_grab_focus(ctx->entry_new1);
- return;
- }
-
- /* If there is an existing primary passphrase, check for its correctness
- * in entry_old. */
- if (primary_passphrase_is_set()
- && ((old = gtk_entry_get_text(GTK_ENTRY(ctx->entry_old))) == NULL
- || strlen(old) == 0 || !primary_passphrase_is_correct(old))) {
- debug_print("old passphrase incorrect\n");
- alertpanel_warning(_("Incorrect old primary passphrase entered, try again."));
- gtk_entry_set_text(GTK_ENTRY(ctx->entry_old), "");
- gtk_widget_grab_focus(ctx->entry_old);
- return;
- }
-
- primary_passphrase_change(old, new1);
-
- ctx->done = TRUE;
- gtk_widget_destroy(ctx->dialog);
- ctx->dialog = NULL;
-}
-
-static void cancel_button_clicked(GtkButton *button, gpointer user_data)
-{
- struct _ctx *ctx = (struct _ctx *)user_data;
- ctx->done = TRUE;
- gtk_widget_destroy(ctx->dialog);
- ctx->dialog = NULL;
-}
-
-static void dialog_destroy(GtkWidget *widget, gpointer user_data)
-{
- struct _ctx *ctx = (struct _ctx *)user_data;
- ctx->done = TRUE;
- ctx->dialog = NULL;
-}
-
-void primary_passphrase_change_dialog()
-{
- static PangoFontDescription *font_desc;
- GtkWidget *dialog;
- GtkWidget *vbox, *hbox;
- GtkWidget *icon, *table, *label, *sep;
- GtkWidget *msg_title;
- GtkWidget *entry_old, *entry_new1, *entry_new2;
- GtkWidget *ok_button, *cancel_button;
- struct _ctx *ctx;
-
- dialog = gtk_dialog_new();
-
- gtk_window_set_resizable(GTK_WINDOW(dialog), FALSE);
- gtk_window_set_default_size(GTK_WINDOW(dialog), 375, 100);
- gtk_window_set_title(GTK_WINDOW(dialog), "");
-
- MANAGE_WINDOW_SIGNALS_CONNECT(dialog);
-
- vbox = gtk_dialog_get_content_area(GTK_DIALOG(dialog));
- gtk_box_set_spacing(GTK_BOX(vbox), 14);
- hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 12);
- gtk_container_set_border_width(GTK_CONTAINER(hbox), 5);
- gtk_widget_show(hbox);
- gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
-
- icon = gtk_image_new_from_icon_name("dialog-password-symbolic",
- GTK_ICON_SIZE_DIALOG);
- gtk_widget_set_halign(icon, GTK_ALIGN_CENTER);
- gtk_widget_set_valign(icon, GTK_ALIGN_START);
- gtk_box_pack_start(GTK_BOX(hbox), icon, FALSE, FALSE, 0);
-
- vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 12);
- gtk_box_pack_start(GTK_BOX(hbox), vbox, TRUE, TRUE, 0);
- gtk_widget_show(vbox);
-
- msg_title = gtk_label_new(_("Changing primary passphrase"));
- gtk_label_set_xalign(GTK_LABEL(msg_title), 0.0);
- gtk_label_set_justify(GTK_LABEL(msg_title), GTK_JUSTIFY_LEFT);
- gtk_label_set_use_markup (GTK_LABEL (msg_title), TRUE);
- gtk_box_pack_start(GTK_BOX(vbox), msg_title, FALSE, FALSE, 0);
- gtk_label_set_line_wrap(GTK_LABEL(msg_title), TRUE);
- if (!font_desc) {
- gint size;
-
- size = pango_font_description_get_size
- (gtk_widget_get_style(msg_title)->font_desc);
- font_desc = pango_font_description_new();
- pango_font_description_set_weight
- (font_desc, PANGO_WEIGHT_BOLD);
- pango_font_description_set_size
- (font_desc, size * PANGO_SCALE_LARGE);
- }
- if (font_desc)
- gtk_widget_override_font(msg_title, font_desc);
-
- label = gtk_label_new(
- _("If a primary passphrase is currently active, it\n"
- "needs to be entered.")
- );
- gtk_label_set_xalign(GTK_LABEL(label), 0.0);
- gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
- gtk_widget_show(label);
-
- table = gtk_grid_new();
- gtk_grid_set_row_spacing(GTK_GRID(table), 8);
- gtk_grid_set_column_spacing(GTK_GRID(table), 8);
-
- /* Old passphrase */
- label = gtk_label_new(_("Old passphrase"));
- gtk_label_set_xalign(GTK_LABEL(label), 0.0);
- gtk_grid_attach(GTK_GRID(table), label, 0, 0, 1, 1);
-
- entry_old = gtk_entry_new();
- gtk_entry_set_visibility(GTK_ENTRY(entry_old), FALSE);
- gtk_grid_attach(GTK_GRID(table), entry_old, 1, 0, 1, 1);
- gtk_widget_set_hexpand(entry_old, TRUE);
- gtk_widget_set_halign(entry_old, GTK_ALIGN_FILL);
-
- /* Separator */
- sep = gtk_separator_new(GTK_ORIENTATION_HORIZONTAL);
- g_object_set (sep, "margin", 8, NULL);
- gtk_grid_attach(GTK_GRID(table), sep, 0, 1, 2, 1);
-
- /* New passphrase */
- label = gtk_label_new(_("New passphrase"));
- gtk_label_set_xalign(GTK_LABEL(label), 0.0);
- gtk_grid_attach(GTK_GRID(table), label, 0, 2, 1, 1);
-
- entry_new1 = gtk_entry_new();
- gtk_entry_set_visibility(GTK_ENTRY(entry_new1), FALSE);
- gtk_grid_attach(GTK_GRID(table), entry_new1, 1, 2, 1, 1);
- gtk_widget_set_hexpand(entry_new1, TRUE);
- gtk_widget_set_halign(entry_new1, GTK_ALIGN_FILL);
-
- /* New passphrase again */
- label = gtk_label_new(_("Confirm passphrase"));
- gtk_label_set_xalign(GTK_LABEL(label), 0.0);
- gtk_grid_attach(GTK_GRID(table), label, 0, 3, 1, 1);
-
- entry_new2 = gtk_entry_new();
- gtk_entry_set_visibility(GTK_ENTRY(entry_new2), FALSE);
- gtk_grid_attach(GTK_GRID(table), entry_new2, 1, 3, 1, 1);
- gtk_widget_set_hexpand(entry_new2, TRUE);
- gtk_widget_set_halign(entry_new2, GTK_ALIGN_FILL);
-
- gtk_box_pack_start(GTK_BOX(vbox), table, FALSE, FALSE, 0);
-
- cancel_button = gtk_dialog_add_button(GTK_DIALOG(dialog), _("_Cancel"),
- GTK_RESPONSE_NONE);
- ok_button = gtk_dialog_add_button(GTK_DIALOG(dialog),_("_OK"),
- GTK_RESPONSE_NONE);
- gtk_widget_grab_default(ok_button);
-
- /* If no primary passphrase is set, disable the "old passphrase" entry */
- if (!primary_passphrase_is_set())
- gtk_widget_set_sensitive(entry_old, FALSE);
-
- g_signal_connect(G_OBJECT(entry_old), "activate",
- G_CALLBACK(entry_activated), entry_new1);
- g_signal_connect(G_OBJECT(entry_new1), "activate",
- G_CALLBACK(entry_activated), entry_new2);
- gtk_entry_set_activates_default(GTK_ENTRY(entry_new2), TRUE);
-
- ctx = g_new(struct _ctx, 1);
- ctx->done = FALSE;
- ctx->dialog = dialog;
- ctx->entry_old = entry_old;
- ctx->entry_new1 = entry_new1;
- ctx->entry_new2 = entry_new2;
-
- g_signal_connect(G_OBJECT(ok_button), "clicked",
- G_CALLBACK(ok_button_clicked), ctx);
- g_signal_connect(G_OBJECT(cancel_button), "clicked",
- G_CALLBACK(cancel_button_clicked), ctx);
-
- g_signal_connect(G_OBJECT(dialog), "destroy",
- G_CALLBACK(dialog_destroy), ctx);
-
- gtk_widget_show_all(gtk_dialog_get_content_area(GTK_DIALOG(dialog)));
- gtk_window_present(GTK_WINDOW(dialog));
-
- gtk_window_set_modal(GTK_WINDOW(dialog), TRUE);
- manage_window_set_transient(GTK_WINDOW(dialog));
-
- while (!ctx->done)
- gtk_main_iteration();
-
- if (ctx->dialog != NULL)
- gtk_widget_destroy(ctx->dialog);
-
- GTK_EVENTS_FLUSH();
-
- g_free(ctx);
-}
blob - d096f3502789973e2c6255bc43728f167d2c34db (mode 644)
blob + /dev/null
--- src/password_gtk.h
+++ /dev/null
-/*
- * Claws Mail -- a GTK based, lightweight, and fast e-mail client
- * Copyright (C) 2016 Claws Mail team
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
-
-#ifndef __PASSWORD_GTK_H
-#define __PASSWORD_GTK_H
-
-void primary_passphrase_change_dialog();
-
-#endif /* __PASSWORD_GTK_H */
blob - 14a1c6906dc6867f55f74d8ced3dc956a7d1f963
blob + 83f06df55dfc118e9b761d16664d5737bacaa555
--- src/prefs_common.c
+++ src/prefs_common.c
{"address_search_wildcard", "TRUE", &prefs_common.address_search_wildcard, P_BOOL,
NULL, NULL, NULL},
{"enable_avatars", "3", &prefs_common.enable_avatars, P_INT, NULL, NULL, NULL},
- {"use_master_passphrase", FALSE, &prefs_common.use_primary_passphrase, P_BOOL, NULL, NULL, NULL },
{"master_passphrase", "", &prefs_common.primary_passphrase, P_STRING, NULL, NULL, NULL },
{"master_passphrase_salt", "", &prefs_common.primary_passphrase_salt, P_STRING, NULL, NULL, NULL },
{"master_passphrase_pbkdf2_rounds", "50000", &prefs_common.primary_passphrase_pbkdf2_rounds, P_INT, NULL, NULL, NULL},
{"qs_press_timeout", "500", &prefs_common.qs_press_timeout, P_INT,
NULL, NULL, NULL},
- {"passphrase_dialog_msg_title_switch", "FALSE", &prefs_common.passphrase_dialog_msg_title_switch,
- P_BOOL, NULL, NULL, NULL},
-
{"mainwin_toolbar_always_enable_actions", "FALSE", &prefs_common.mainwin_toolbar_always_enable_actions, P_BOOL,
NULL, NULL, NULL},
blob - 89a0f59847dc279c0aef933e9c44535303c4c45a
blob + a0b3145887e02706050fba38419df0a345a96907
--- src/prefs_common.h
+++ src/prefs_common.h
gchar *primary_passphrase_salt;
guint primary_passphrase_pbkdf2_rounds;
- gboolean passphrase_dialog_msg_title_switch;
gboolean mainwin_toolbar_always_enable_actions;
/* Proxy */
blob - 6e793ece389408be8855c105e61f7c196629b1e4
blob + 35924188cbcde96cd130c2ba066fce01e81dc9a1
--- src/prefs_other.c
+++ src/prefs_other.c
#include "gtk/gtkutils.h"
#include "gtk/prefswindow.h"
#include "combobox.h"
-#include "password.h"
-#include "password_gtk.h"
#include "manage_window.h"
#ifdef HAVE_LIBETPAN
GtkWidget *checkbtn_real_time_sync;
GtkWidget *entry_attach_save_chmod;
GtkWidget *checkbtn_transhdr;
- GtkWidget *checkbtn_use_passphrase;
} OtherPage;
-static void prefs_change_primary_passphrase(GtkButton *button, gpointer data);
-
struct KeyBind {
const gchar *accel_path;
const gchar *accel_key;
GtkWidget *label_attach_save_chmod;
GtkWidget *entry_attach_save_chmod;
- GtkWidget *vbox_passphrase;
- GtkWidget *frame_passphrase;
- GtkWidget *checkbtn_use_passphrase;
- GtkWidget *button_change_passphrase;
-
vbox1 = gtk_box_new(GTK_ORIENTATION_VERTICAL, VSPACING);
gtk_widget_show (vbox1);
gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
g_free(buf);
}
- vbox_passphrase = gtkut_get_options_frame(vbox1, &frame_passphrase, _("Primary passphrase"));
-
- PACK_CHECK_BUTTON(vbox_passphrase, checkbtn_use_passphrase,
- _("Use a primary passphrase"));
-
- CLAWS_SET_TIP(checkbtn_use_passphrase,
- _("If checked, your saved account passwords will be protected "
- "by a primary passphrase. If no primary passphrase is set, "
- "you will be prompted to set one"));
-
- button_change_passphrase = gtk_button_new_with_label(
- _("Change primary passphrase"));
- gtk_widget_show (button_change_passphrase);
- hbox1 = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 8);
- gtk_widget_show (hbox1);
- gtk_box_pack_start (GTK_BOX (vbox_passphrase), hbox1, FALSE, FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox1), button_change_passphrase,
- FALSE, FALSE, 0);
- SET_TOGGLE_SENSITIVITY (checkbtn_use_passphrase, button_change_passphrase);
- g_signal_connect (G_OBJECT (button_change_passphrase), "clicked",
- G_CALLBACK (prefs_change_primary_passphrase), NULL);
-
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_addaddrbyclick),
prefs_common.add_address_by_click);
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_confonexit),
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_real_time_sync),
prefs_common.real_time_sync);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_use_passphrase),
- prefs_common.use_primary_passphrase);
- gtk_widget_set_sensitive(button_change_passphrase,
- prefs_common.use_primary_passphrase);
-
prefs_other->keys_preset_hbox = keys_preset_hbox;
prefs_other->keys_preset_combo = keys_preset_combo;
prefs_other->checkbtn_addaddrbyclick = checkbtn_addaddrbyclick;
prefs_other->checkbtn_askonfilter = checkbtn_askonfilter;
prefs_other->checkbtn_real_time_sync = checkbtn_real_time_sync;
prefs_other->entry_attach_save_chmod = entry_attach_save_chmod;
- prefs_other->checkbtn_use_passphrase = checkbtn_use_passphrase;
prefs_other->page.widget = vbox1;
}
prefs_keybind_preset_changed(GTK_COMBO_BOX(page->keys_preset_combo));
- /* If we're disabling use of primary passphrase, we need to reencrypt
- * all account passwords with hardcoded key. */
- if (!gtk_toggle_button_get_active(
- GTK_TOGGLE_BUTTON(page->checkbtn_use_passphrase))
- && primary_passphrase_is_set()) {
- primary_passphrase_change(NULL, NULL);
-
- /* In case user did not finish the passphrase change process
- * (e.g. did not enter a correct current primary passphrase),
- * we need to enable the "use primary passphrase" checkbox again,
- * since the old primary passphrase is still valid. */
- if (primary_passphrase_is_set()) {
- gtk_toggle_button_set_active(
- GTK_TOGGLE_BUTTON(page->checkbtn_use_passphrase), TRUE);
- }
- }
-
- if (gtk_toggle_button_get_active(
- GTK_TOGGLE_BUTTON(page->checkbtn_use_passphrase))
- && !primary_passphrase_is_set()) {
- primary_passphrase_change_dialog();
-
- /* In case user cancelled the passphrase change dialog, we need
- * to disable the "use primary passphrase" checkbox. */
- if (!primary_passphrase_is_set()) {
- gtk_toggle_button_set_active(
- GTK_TOGGLE_BUTTON(page->checkbtn_use_passphrase), FALSE);
- }
- }
-
- prefs_common.use_primary_passphrase =
- gtk_toggle_button_get_active(
- GTK_TOGGLE_BUTTON(page->checkbtn_use_passphrase));
-
gtk_enable_accels = gtk_toggle_button_get_active(
GTK_TOGGLE_BUTTON(page->checkbtn_gtk_enable_accels));
prefs_gtk_unregister_page((PrefsPage *) prefs_other);
g_free(prefs_other);
}
-
-void prefs_change_primary_passphrase(GtkButton *button, gpointer data)
-{
- primary_passphrase_change_dialog();
-}