diff options
author | makefu <github@syntax-fehler.de> | 2017-09-19 16:38:07 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2017-09-19 16:38:07 +0200 |
commit | cfca733473620e1b7be7e62a96f20958fedf9068 (patch) | |
tree | 4d69217c6c292e6524c05ce0ffa36ac209c6cad9 /lass/2configs/git.nix | |
parent | 21c284a2c7b4fcb330f0c90ccd773f65f78721aa (diff) | |
parent | e822f88199f11fe75e2a38a0e5f9806a8c9ba5cf (diff) |
Merge remote-tracking branch 'lass/master'
Diffstat (limited to 'lass/2configs/git.nix')
-rw-r--r-- | lass/2configs/git.nix | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/lass/2configs/git.nix b/lass/2configs/git.nix index 7bce93ae1..3991acadc 100644 --- a/lass/2configs/git.nix +++ b/lass/2configs/git.nix @@ -14,7 +14,7 @@ let root-desc = "keep calm and engage"; }; }; - repos = mapAttrs (_: s: removeAttrs s ["collaborators"]) repos; + repos = repos; rules = rules; }; @@ -87,8 +87,8 @@ let public = true; }; - make-restricted-repo = name: { collaborators ? [], announce ? false, hooks ? {}, ... }: { - inherit collaborators name; + make-restricted-repo = name: { admins ? [], collaborators ? [], announce ? false, hooks ? {}, ... }: { + inherit admins collaborators name; public = false; hooks = optionalAttrs announce { post-receive = pkgs.git-hooks.irc-announce { @@ -111,15 +111,20 @@ let repo = [ repo ]; perm = push "refs/*" [ non-fast-forward create delete merge ]; } ++ - optional repo.public { - user = attrValues config.krebs.users; + optional (length (repo.admins or []) > 0) { + user = repo.admins; repo = [ repo ]; - perm = fetch; + perm = push "refs/*" [ non-fast-forward create delete merge ]; } ++ optional (length (repo.collaborators or []) > 0) { user = repo.collaborators; repo = [ repo ]; perm = fetch; + } ++ + optional repo.public { + user = attrValues config.krebs.users; + repo = [ repo ]; + perm = fetch; }; in out |