notmuch-mutt: replace shell pipeline with internal pipe processing
[notmuch] / lib / indexopts.c
1 /* indexopts.c - options for indexing messages (currently a stub)
2  *
3  * Copyright © 2017 Daniel Kahn Gillmor
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program.  If not, see https://www.gnu.org/licenses/ .
17  *
18  * Author: Daniel Kahn Gillmor <dkg@fifthhorseman.net>
19  */
20
21 #include "notmuch-private.h"
22
23 notmuch_indexopts_t *
24 notmuch_database_get_default_indexopts (notmuch_database_t *db)
25 {
26     notmuch_indexopts_t *ret = talloc_zero (db, notmuch_indexopts_t);
27
28     if (! ret)
29         return ret;
30     ret->crypto.decrypt = NOTMUCH_DECRYPT_AUTO;
31
32     char *decrypt_policy;
33     notmuch_status_t err = notmuch_database_get_config (db, "index.decrypt", &decrypt_policy);
34     if (err)
35         return ret;
36
37     if (decrypt_policy) {
38         if ((! (strcasecmp (decrypt_policy, "true"))) ||
39             (! (strcasecmp (decrypt_policy, "yes"))) ||
40             (! (strcasecmp (decrypt_policy, "1"))))
41             notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_TRUE);
42         else if ((! (strcasecmp (decrypt_policy, "false"))) ||
43                  (! (strcasecmp (decrypt_policy, "no"))) ||
44                  (! (strcasecmp (decrypt_policy, "0"))))
45             notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_FALSE);
46         else if (! strcasecmp (decrypt_policy, "nostash"))
47             notmuch_indexopts_set_decrypt_policy (ret, NOTMUCH_DECRYPT_NOSTASH);
48     }
49
50     free (decrypt_policy);
51     return ret;
52 }
53
54 notmuch_status_t
55 notmuch_indexopts_set_decrypt_policy (notmuch_indexopts_t *indexopts,
56                                       notmuch_decryption_policy_t decrypt_policy)
57 {
58     if (! indexopts)
59         return NOTMUCH_STATUS_NULL_POINTER;
60     indexopts->crypto.decrypt = decrypt_policy;
61     return NOTMUCH_STATUS_SUCCESS;
62 }
63
64 notmuch_decryption_policy_t
65 notmuch_indexopts_get_decrypt_policy (const notmuch_indexopts_t *indexopts)
66 {
67     if (! indexopts)
68         return false;
69     return indexopts->crypto.decrypt;
70 }
71
72 void
73 notmuch_indexopts_destroy (notmuch_indexopts_t *indexopts)
74 {
75     talloc_free (indexopts);
76 }