Azure extension for Grails Spring Security OAuth plugin
Add the following plugin definition to your BuildConfig:
// ...
plugins {
// ...
compile ':spring-security-oauth:2.0.2'
compile ':spring-security-oauth-azure:0.3.1'
// ...
}
Add to your Config.groovy:
def appName = grails.util.Metadata.current.'app.name'
def baseURL = grails.serverURL ?: "http://127.0.0.1:${System.getProperty('server.port', '8080')}/${appName}"
oauth {
// ...
providers {
// ...
azure {
api = org.grails.plugin.springsecurity.oauth.GoogleApi20
key = 'azure_ad_clientID'
secret = 'azure_ad_secretKey'
tenant = 'azure_tenant_UUID'
successUri = '/oauth/azure/success'
failureUri = '/oauth/azure/error'
callback = "${baseURL}/oauth/azure/callback"
scope = 'User.Read'
groupMap = ["AZURE_AD_GROUP1":"ROLE_USER","AZURE_AD_GROUP2":"ROLE_IMPORT"]
}
// ...
}
}
The majority of these config setttings should be self-explanatory, but of interest is the groupMap property. This maps Azure AD group names to locally defined application roles. These translations will be applied when the OAuth authority values are set from the Azure AD user assignments. If you are creating users from the OAuth login, then these authority values will be added to the users roles.
Add the following to Config.groovy if you want to use Secured annotations together with Spring security. All references to InterceptUrlMap should be removed.
grails.plugin.springsecurity.securityConfigType = 'Annotation'
grails.plugin.springsecurity.controllerAnnotations.staticRules = [
'/': ['permitAll'],
'/index': ['permitAll'],
'/index.gsp': ['permitAll'],
'/login/**': ['permitAll'],
'/assets/**': ['permitAll'],
'/**/js/**': ['permitAll'],
'/**/css/**': ['permitAll'],
'/**/images/**': ['permitAll'],
'/**/favicon.ico': ['permitAll'],
'/oauth/**': ['permitAll'],
'/springSecurityOAuth/**': ['permitAll']
]
In your view you can use the taglib exposed from this plugin and from OAuth plugin to create links and to know if the user is authenticated with a given provider:
<oauth:connect provider="azure" id="azure-connect-link">Azure</oauth:connect>
Logged in with azure?
<s2o:ifLoggedInWith provider="azure">yes</s2o:ifLoggedInWith>
<s2o:ifNotLoggedInWith provider="azure">no</s2o:ifNotLoggedInWith>
You can look at bagage's sample app.
Copyright 2012-2014 Mihai Cazacu, Enrico Comiti and Alexey Zhokhov under the Apache License, Version 2.0. Azure AD interface (C) 2016 Accenture Federal Services