summaryrefslogtreecommitdiffstats
path: root/doc/wiki/Plugins.VarExpandCrypt.txt
blob: 4bf43d9c5123556439914b7e00df9eec6369cdc5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
var_expand_crypt plugin
=======================

This plugins provides generic encrypt/decrypt facility for var_expand. It
requires functional lib-dcrypt backend. For dovecot-auth process this plugin is
automatically usable.

Syntax
------

---%<-------------------------------------------------------------------------
args=encrypted_value=%{encrypt;key=value,iv=value,noiv=yes,algo=algorithm,format=base64|hex:field}
args=decrypted_value=%{decrypt;key=value,iv=value,noiv=yes,algo=algorithm,format=base64|hex:field}
---%<-------------------------------------------------------------------------

 * key - hex-encoded value
 * iv  - hex-encoded value
 * noiv - whether iv is included in return value
 * algo - algorithm name (defaults to aes-256-cbc)
 * format - return format

decrypt expects input in base64 or hex format.

NOTE: It is usually best to leave iv management to dovecot, and not use iv and
noiv options at all.

Return formats
--------------

Without noiv encrypt returns iv$encrypted$. With noiv, just encrypted data is
returned. Field(s) are encoded using format.

key and iv must be the length required by the given algorithm.

Example
-------

---%<-------------------------------------------------------------------------
%{encrypt;key=f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8:password}
= 93736a0f910df27f89210e096e1d639a$966c2b4f3e7487f6acdb836f8d1dc3e0$
%{decrypt;key=f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8f1f2f3f4f5f6f7f8:encrypted}
= pass
---%<-------------------------------------------------------------------------

(This file was created from the wiki on 2019-06-19 12:42)