All Downloads are FREE. Search and download functionalities are using the official Maven repository.

groovity.portal.lib.adminPolicy.grvt Maven / Gradle / Ivy

There is a newer version: 2.1.0-beta.1
Show newest version
/*******************************************************************************
 * © 2018 Disney | ABC Television Group
 *
 * Licensed under the Apache License, Version 2.0 (the "Apache License")
 * with the following modification; you may not use this file except in
 * compliance with the Apache License and the following modification to it:
 * Section 6. Trademarks. is deleted and replaced with:
 *
 * 6. Trademarks. This License does not grant permission to use the trade
 *     names, trademarks, service marks, or product names of the Licensor
 *     and its affiliates, except as required to comply with Section 4(c) of
 *     the License and to reproduce the content of the NOTICE file.
 *
 * You may obtain a copy of the Apache License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the Apache License with the above modification is
 * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied. See the Apache License for the specific
 * language governing permissions and limitations under the Apache License.
 *******************************************************************************/
/**
 * Custom auth policy to gate access to logged in users with root level "admin" role
 */
static web=[
	auth:{
		request ->
		def rval = [authenticated:false,authorized:false]
		if(request.userPrincipal){
			rval.authenticated = true;
			def uri = request.URI
			def qi = uri.indexOf('?')
			if(qi>0){
				uri = uri.substring(0,qi)
			}
			if(request.userPrincipal.hasRole(request.session, uri, ['admin'])){
				rval.authorized = true
			}
		}
		rval
	},
	cors:[
		origins:(System.getProperty('groovity.cluster.corsOrigin') ?: '*'),
		headers:["Signature","X-Date"],
		maxAge:300	
	]
]

//we'll install this custom policy so portal admins can access cluster admin tools
static init(){
	System.setProperty('groovity.servlet.admin.ui.policy','/groovity/portal/lib/adminPolicy');
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy