summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--schemas/types.xsd3
-rw-r--r--src/lib/Bcfg2/Server/Lint/RequiredAttrs.py11
2 files changed, 12 insertions, 2 deletions
diff --git a/schemas/types.xsd b/schemas/types.xsd
index 439321e3d..1055bdf67 100644
--- a/schemas/types.xsd
+++ b/schemas/types.xsd
@@ -119,13 +119,12 @@
<xsd:restriction base="xsd:string">
<xsd:enumeration value="user"/>
<xsd:enumeration value="group"/>
- <xsd:enumeration value="mask"/>
</xsd:restriction>
</xsd:simpleType>
<xsd:complexType name="ACLType">
<xsd:attribute type="ACLTypeEnum" name="type" use="required"/>
- <xsd:attribute type="ACLScopeEnum" name="scope" use="required"/>
+ <xsd:attribute type="ACLScopeEnum" name="scope"/>
<xsd:attribute type="xsd:string" name="perms" use="required"/>
<xsd:attribute type="xsd:string" name="user"/>
<xsd:attribute type="xsd:string" name="group"/>
diff --git a/src/lib/Bcfg2/Server/Lint/RequiredAttrs.py b/src/lib/Bcfg2/Server/Lint/RequiredAttrs.py
index 0976ed9dd..b9a6dc2dc 100644
--- a/src/lib/Bcfg2/Server/Lint/RequiredAttrs.py
+++ b/src/lib/Bcfg2/Server/Lint/RequiredAttrs.py
@@ -70,6 +70,14 @@ class RequiredAttrs(Bcfg2.Server.Lint.ServerPlugin):
when=lambda v: v in ['modified', 'always'],
status=lambda v: v in ['ignore', 'check'],
command=None)},
+ ACL=dict(
+ default=dict(scope=lambda v: v in ['user', 'group'],
+ perms=lambda v: re.match('^([0-7]|[rwx\-]{0,3}',
+ v)),
+ access=dict(scope=lambda v: v in ['user', 'group'],
+ perms=lambda v: re.match('^([0-7]|[rwx\-]{0,3}',
+ v)),
+ mask=dict(perms=lambda v: re.match('^([0-7]|[rwx\-]{0,3}', v))),
Package={None: dict(name=None)},
SELinux=dict(
boolean=dict(name=None,
@@ -192,6 +200,9 @@ class RequiredAttrs(Bcfg2.Server.Lint.ServerPlugin):
required_attrs['major'] = is_device_mode
required_attrs['minor'] = is_device_mode
+ if tag == 'ACL' and 'scope' in required_attrs:
+ required_attrs[entry.get('scope')] = is_username
+
if '__text__' in required_attrs:
del required_attrs['__text__']
if (not entry.text and