mbsync: Adds extraConfig.{local|remote}

... to be able to limit the number of mails to be retrieved.
local refers to the "store" configuration, remote to the "channel".
This commit is contained in:
Matthieu Coudron 2018-09-02 14:58:54 +09:00
parent 4d870f665b
commit 9d9d826054
2 changed files with 43 additions and 12 deletions

View file

@ -2,6 +2,9 @@
with lib; with lib;
let
extraConfigType = with lib.types; attrsOf (either (either str int) bool);
in
{ {
options.mbsync = { options.mbsync = {
enable = mkEnableOption "synchronization using mbsync"; enable = mkEnableOption "synchronization using mbsync";
@ -53,5 +56,27 @@ with lib;
Pattern of mailboxes to synchronize. Pattern of mailboxes to synchronize.
''; '';
}; };
extraConfig.local = mkOption {
type = extraConfigType;
default = {};
description = ''
Per store extra config.
'';
};
extraConfig.remote = mkOption {
type = extraConfigType;
default = {};
example = literalExample ''
{
MaxMessages = 10000;
MaxSize = 1m;
};
'';
description = ''
Per channel extra config.
'';
};
}; };
} }

View file

@ -33,10 +33,13 @@ let
genSection = header: entries: genSection = header: entries:
let let
escapeValue = escape [ "\"" ]; escapeValue = escape [ "\"" ];
hasSpace = v: builtins.match ".* .*" v != null;
genValue = v: genValue = v:
if isList v if isList v
then concatMapStringsSep " " genValue v then concatMapStringsSep " " genValue v
else "\"${escapeValue v}\""; else if isInt v then toString v
else if (hasSpace v) then "\"${escapeValue v}\""
else v;
in in
'' ''
${header} ${header}
@ -70,19 +73,22 @@ let
Inbox = "${maildir.absPath}/${folders.inbox}"; Inbox = "${maildir.absPath}/${folders.inbox}";
SubFolders = "Verbatim"; SubFolders = "Verbatim";
} }
// // optionalAttrs (mbsync.flatten != null) { Flatten = mbsync.flatten; }
optionalAttrs (mbsync.flatten != null) { Flatten = mbsync.flatten; } // mbsync.extraConfig.local
) )
+ "\n" + "\n"
+ genSection "Channel ${name}" { + genSection "Channel ${name}" (
Master = ":${name}-remote:"; {
Slave = ":${name}-local:"; Master = ":${name}-remote:";
Patterns = mbsync.patterns; Slave = ":${name}-local:";
Create = masterSlaveMapping.${mbsync.create}; Patterns = mbsync.patterns;
Remove = masterSlaveMapping.${mbsync.remove}; Create = masterSlaveMapping.${mbsync.create};
Expunge = masterSlaveMapping.${mbsync.expunge}; Remove = masterSlaveMapping.${mbsync.remove};
SyncState = "*"; Expunge = masterSlaveMapping.${mbsync.expunge};
} SyncState = "*";
}
// mbsync.extraConfig.remote
)
+ "\n"; + "\n";
genGroupConfig = name: channels: genGroupConfig = name: channels: