org.cristalise.dsl.entity.RoleDelegate.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cristalise-dsl Show documentation
Show all versions of cristalise-dsl Show documentation
CRISTAL-iSE Domain Specific Language module for bootstrapping and funtional testing
The newest version!
/**
* This file is part of the CRISTAL-iSE kernel.
* Copyright (c) 2001-2015 The CRISTAL Consortium. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 3 of the License, or (at
* your option) any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; with out even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*
* http://www.fsf.org/licensing/licenses/lgpl.html
*/
package org.cristalise.dsl.entity
import org.cristalise.kernel.entity.imports.ImportRole
import groovy.transform.CompileStatic
/**
*
*/
@CompileStatic
class RoleDelegate {
String namespace
List roles = new ArrayList<>()
public RoleDelegate(String ns) {
namespace = ns
}
public void processClosure(Closure cl) {
assert cl
cl.delegate = this
cl.resolveStrategy = Closure.DELEGATE_FIRST
cl()
}
public void Role(Map attrs, Closure cl = null) {
assert attrs && attrs.name
if (!attrs.jobList) attrs.jobList = false
def role = new ImportRole()
role.namespace = namespace
role.name = attrs.name
role.jobList = attrs.jobList
roles.add(role)
if (cl) {
cl.delegate = this
cl.resolveStrategy = Closure.DELEGATE_FIRST
cl()
}
}
public void Permission(String p) {
roles[roles.size()-1].permissions.add(p)
}
public void Permission(Map args) {
assert args.domain && args.actions && args.targets, 'domain:actions:targets triplet must be set'
roles[roles.size()-1].permissions.add("${args.domain}:${args.actions}:${args.targets}".toString())
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy