org.beangle.security.authz.AbstractRoleBasedAuthorizer.scala Maven / Gradle / Ivy
/*
* Copyright (C) 2005, The Beangle Software.
*
* This program 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 program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without 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 program. If not, see .
*/
package org.beangle.security.authz
import org.beangle.commons.bean.Initializing
import org.beangle.commons.concurrent.Timers
import org.beangle.commons.security.Request
import org.beangle.security.authc.Account
import org.beangle.security.context.SecurityContext
abstract class AbstractRoleBasedAuthorizer extends Authorizer, Initializing {
var domain: AuthorityDomain = AuthorityDomain.empty
var unknownIsProtected: Boolean = true
var refreshSeconds: Int = 5 * 60
override def isPermitted(context: SecurityContext, request: Request): Boolean = {
if (context.root) return true
val resourceName = request.resource.toString
val raOption = domain.authorities.get(resourceName)
raOption match {
case None => if (unknownIsProtected) context.isValid else false
case Some(ra) =>
ra.scope match {
case Scope.Public => true //public
case Scope.Protected => context.isValid //protected
case _ => //private
context.session match {
case Some(session) =>
ra.matches(session.principal.asInstanceOf[Account].authorities)
case None => false
}
}
}
}
override def init(): Unit = {
if refreshSeconds > 0 then Timers.start("Beangle Authority Refresh", refreshSeconds, new DomainFetcher(this))
else Timers.setTimeout(3, () => refresh()) //refresh domain background
}
override def isRoot(user: String): Boolean = {
domain.roots.contains(user)
}
override def refresh(): Unit = {
this.domain = fetchDomain()
}
def fetchDomain(): AuthorityDomain
}
class DomainFetcher(authorizer: Authorizer) extends Runnable {
override def run(): Unit = {
authorizer.refresh()
}
}