mirror of
https://git.notmuchmail.org/git/notmuch
synced 2025-01-24 12:14:24 +01:00
fccebbaeef
Here's the configuration choice for people who want a cleartext index, but don't want stashed session keys. Interestingly, this "nostash" decryption policy is actually the same policy that should be used by "notmuch show" and "notmuch reply", since they never modify the index or database when they are invoked with --decrypt. We take advantage of this parallel to tune the behavior of those programs so that we're not requesting session keys from GnuPG during "show" and "reply" that we would then otherwise just throw away.
75 lines
2.4 KiB
C
75 lines
2.4 KiB
C
/* indexopts.c - options for indexing messages (currently a stub)
|
|
*
|
|
* Copyright © 2017 Daniel Kahn Gillmor
|
|
*
|
|
* 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 https://www.gnu.org/licenses/ .
|
|
*
|
|
* Author: Daniel Kahn Gillmor <dkg@fifthhorseman.net>
|
|
*/
|
|
|
|
#include "notmuch-private.h"
|
|
|
|
notmuch_indexopts_t *
|
|
notmuch_database_get_default_indexopts (notmuch_database_t *db)
|
|
{
|
|
notmuch_indexopts_t *ret = talloc_zero (db, notmuch_indexopts_t);
|
|
if (!ret)
|
|
return ret;
|
|
ret->crypto.decrypt = NOTMUCH_DECRYPT_AUTO;
|
|
|
|
char * decrypt_policy;
|
|
notmuch_status_t err = notmuch_database_get_config (db, "index.decrypt", &decrypt_policy);
|
|
if (err)
|
|
return ret;
|
|
|
|
if (decrypt_policy) {
|
|
if ((!(strcasecmp(decrypt_policy, "true"))) ||
|
|
(!(strcasecmp(decrypt_policy, "yes"))) ||
|
|
(!(strcasecmp(decrypt_policy, "1"))))
|
|
notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_TRUE);
|
|
else if ((!(strcasecmp(decrypt_policy, "false"))) ||
|
|
(!(strcasecmp(decrypt_policy, "no"))) ||
|
|
(!(strcasecmp(decrypt_policy, "0"))))
|
|
notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_FALSE);
|
|
else if (!strcasecmp(decrypt_policy, "nostash"))
|
|
notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_NOSTASH);
|
|
}
|
|
|
|
free (decrypt_policy);
|
|
return ret;
|
|
}
|
|
|
|
notmuch_status_t
|
|
notmuch_indexopts_set_decrypt_policy (notmuch_indexopts_t *indexopts,
|
|
notmuch_decryption_policy_t decrypt_policy)
|
|
{
|
|
if (!indexopts)
|
|
return NOTMUCH_STATUS_NULL_POINTER;
|
|
indexopts->crypto.decrypt = decrypt_policy;
|
|
return NOTMUCH_STATUS_SUCCESS;
|
|
}
|
|
|
|
notmuch_decryption_policy_t
|
|
notmuch_indexopts_get_decrypt_policy (const notmuch_indexopts_t *indexopts)
|
|
{
|
|
if (!indexopts)
|
|
return false;
|
|
return indexopts->crypto.decrypt;
|
|
}
|
|
|
|
void
|
|
notmuch_indexopts_destroy (notmuch_indexopts_t *indexopts)
|
|
{
|
|
talloc_free (indexopts);
|
|
}
|