]> git.notmuchmail.org Git - notmuch/blob - doc/man1/notmuch-insert.rst
b22be863dc351fe4a5a56844e3829a4a6f75dec0
[notmuch] / doc / man1 / notmuch-insert.rst
1 ==============
2 notmuch-insert
3 ==============
4
5 SYNOPSIS
6 ========
7
8 **notmuch** **insert** [option ...] [+<*tag*>|-<*tag*> ...]
9
10 DESCRIPTION
11 ===========
12
13 **notmuch insert** reads a message from standard input and delivers it
14 into the maildir directory given by configuration option
15 **database.path**, then incorporates the message into the notmuch
16 database. It is an alternative to using a separate tool to deliver the
17 message then running **notmuch new** afterwards.
18
19 The new message will be tagged with the tags specified by the
20 **new.tags** configuration option, then by operations specified on the
21 command-line: tags prefixed by '+' are added while those prefixed by '-'
22 are removed.
23
24 If the new message is a duplicate of an existing message in the database
25 (it has same Message-ID), it will be added to the maildir folder and
26 notmuch database, but the tags will not be changed.
27
28 The **insert** command supports hooks. See **notmuch-hooks(5)** for
29 more details on hooks.
30
31 Option arguments must appear before any tag operation arguments.
32 Supported options for **insert** include
33
34     ``--folder=<``\ folder\ **>**
35         Deliver the message to the specified folder, relative to the
36         top-level directory given by the value of **database.path**. The
37         default is the empty string, which means delivering to the
38         top-level directory.
39
40     ``--create-folder``
41         Try to create the folder named by the ``--folder`` option, if it
42         does not exist. Otherwise the folder must already exist for mail
43         delivery to succeed.
44
45     ``--keep``
46         Keep the message file if indexing fails, and keep the message
47         indexed if applying tags or maildir flag synchronization
48         fails. Ignore these errors and return exit status 0 to
49         indicate successful mail delivery.
50
51     ``--no-hooks``
52         Prevent hooks from being run.
53
54     ``--decrypt=(true|auto|false)``
55
56         If ``true`` and the message is encrypted, try to decrypt the
57         message while indexing.  If ``auto``, and notmuch already
58         knows about a session key for the message, it will try
59         decrypting using that session key but will not try to access
60         the user's secret keys.  If decryption is successful, index
61         the cleartext itself.  Either way, the message is always
62         stored to disk in its original form (ciphertext).
63
64         Be aware that the index is likely sufficient to reconstruct
65         the cleartext of the message itself, so please ensure that the
66         notmuch message index is adequately protected. DO NOT USE
67         ``--decrypt=true`` without considering the security of
68         your index.
69
70         See also ``index.decrypt`` in **notmuch-config(1)**.
71
72 EXIT STATUS
73 ===========
74
75 This command returns exit status 0 on successful mail delivery,
76 non-zero otherwise. The default is to indicate failed mail delivery on
77 any errors, including message file delivery to the filesystem, message
78 indexing to Notmuch database, changing tags, and synchronizing tags to
79 maildir flags. The ``--keep`` option may be used to settle for
80 successful message file delivery.
81
82 This command supports the following special exit status code for
83 errors most likely to be temporary in nature, e.g. failure to get a
84 database write lock.
85
86 ``75 (EX_TEMPFAIL)``
87     A temporary failure occurred; the user is invited to retry.
88
89 The exit status of the **post-insert** hook does not affect the exit
90 status of the **insert** command.
91
92 SEE ALSO
93 ========
94
95 **notmuch(1)**,
96 **notmuch-config(1)**,
97 **notmuch-count(1)**,
98 **notmuch-dump(1)**,
99 **notmuch-hooks(5)**,
100 **notmuch-reply(1)**,
101 **notmuch-restore(1)**,
102 **notmuch-search(1)**,
103 **notmuch-search-terms(7)**,
104 **notmuch-show(1)**,
105 **notmuch-tag(1)**