summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Ipsum <richardipsum@fastmail.co.uk>2017-08-01 23:22:48 +0100
committerRichard Maw <richard.maw@gmail.com>2017-08-03 14:26:13 +0100
commit0440e6e4bd2b616552c611f2b118cfeb23b2b0ac (patch)
treea270413c508983b4c837f33a96878a445d167542
parentbb5c609cc07e6a7f3d876fec0f7ca5de590ac447 (diff)
downloadgitano-0440e6e4bd2b616552c611f2b118cfeb23b2b0ac.tar.gz
ruleset: project.readers and project.writers
-rw-r--r--skel/gitano-admin/rules/defines.lace4
-rw-r--r--skel/gitano-admin/rules/project.lace6
2 files changed, 10 insertions, 0 deletions
diff --git a/skel/gitano-admin/rules/defines.lace b/skel/gitano-admin/rules/defines.lace
index 6043bac..ec3fbd1 100644
--- a/skel/gitano-admin/rules/defines.lace
+++ b/skel/gitano-admin/rules/defines.lace
@@ -112,3 +112,7 @@ define op_is_normal anyof op_fastforward op_createref op_deleteref
define is_admin_repo repository exact gitano-admin
define is_gitano_ref ref prefix refs/gitano/
define is_admin_ref ref exact refs/gitano/admin
+
+# Project readers and writers
+define is_project_reader config/project/readers exact ${user}
+define is_project_writer config/project/writers exact ${user}
diff --git a/skel/gitano-admin/rules/project.lace b/skel/gitano-admin/rules/project.lace
index aafa17c..3bcaf7e 100644
--- a/skel/gitano-admin/rules/project.lace
+++ b/skel/gitano-admin/rules/project.lace
@@ -28,6 +28,12 @@
#
# Core project administration rules
+allow "User is project reader" op_read is_project_reader
+
+allow "User is project writer" op_read is_project_writer
+allow "User is project writer" op_write is_project_writer
+allow "User is project writer" op_is_normal is_project_writer
+
# Admins already got allowed, so this is for non-admin users only
allow "Owners can always read and write" op_is_basic is_owner