source: trunk/grails-app/conf/SecurityConfig.groovy @ 147

Last change on this file since 147 was 147, checked in by gav, 15 years ago

Re-install class-diagram from local svn build with patch to allow war deployment.
Class-diagram overrides removed from Config.groovy since these have all been included upstream.
Tidy comments in SecurityConfig?.groovy
Some work on adding assignedPerson work flow and PersonController?.
Add navAlt and filterPane search to Person and TaskProcedure?.

File size: 3.2 KB
Line 
1security {
2
3    def authenticateService
4
5        // See DefaultSecurityConfig.groovy for all settable/overridable properties
6
7        active = true
8
9        loginUserDomainClass = "Person"
10    userName = 'loginName'
11    password = 'password'
12    enabled = 'isActive'
13
14        authorityDomainClass = "Authority"
15
16    // Required if we want to run "grails generate-manager"
17    // Which recreates the controller and views, so save the views!
18//     requestMapClass = 'Requestmap'
19
20    // The whole application relies on controllerAnnotations and the static rules bellow.
21    useRequestMapDomainClass = false
22    useControllerAnnotations = true
23
24    // Set true especially if used across the internet.
25    forceHttps = 'false'
26
27    // Pessimistic locking, deny access to all URLs that don't
28    // have an applicable URL-Role configuration.
29    // This forces us to set an annotation, static rule or
30    // extend BaseController and prevents accidentally leaving pages open.
31    controllerAnnotationsRejectIfNoRule = true
32
33    // Static rules for controllers, actions and urls.
34    // Since we are using pessimistic locking we have to set some things
35    // here but most security should be set in the controllers.
36    controllerAnnotationStaticRules = [
37    '/': ['IS_AUTHENTICATED_FULLY'],
38    '/index.gsp': ['IS_AUTHENTICATED_FULLY'],
39    '/css/*': ['IS_AUTHENTICATED_ANONYMOUSLY'],
40    '/images/**': ['IS_AUTHENTICATED_ANONYMOUSLY'],
41    '/js/**': ['IS_AUTHENTICATED_ANONYMOUSLY'],
42    '/plugins/**': ['IS_AUTHENTICATED_FULLY'],
43    '/classDiagram*': ['IS_AUTHENTICATED_FULLY'],
44    '/classDiagram/**': ['IS_AUTHENTICATED_FULLY'],
45    '/login*': ['IS_AUTHENTICATED_ANONYMOUSLY'],
46    '/login/**': ['IS_AUTHENTICATED_ANONYMOUSLY'],
47    '/logout*': ['IS_AUTHENTICATED_FULLY'],
48    '/logout/**': ['IS_AUTHENTICATED_FULLY']
49    ]
50
51    // Always call the welcome action so that bookmarks are not used, a
52    // welcome message can be populated and the sessionTimeout can be set.
53    defaultTargetUrl = '/appCore/welcome'
54    alwaysUseDefaultTargetUrl = true
55
56    // User caching, turned this off so that password changes take effect.
57    // It would appear that user is still in the session as logout/login
58    // is still required for role changes to take effect.
59    // If this option causes high database load try:
60    //  import org.acegisecurity.providers.dao.DaoAuthenticationProvider
61    //  import org.acegisecurity.context.SecurityContextHolder
62    //  DaoAuthenticationProvider daoAuthenticationProvider
63    //  def user = SecurityContextHolder.context.authentication.principal.username
64    //  daoAuthenticationProvider.userCache.removeUserFromCache(user)
65    //  in logout controller and perhaps on password change and role change.
66    cacheUsers = false
67
68//    // Listen for events and run the closure(s) that follow.
69//    // Unfortunately the session is not available yet so many things can't be done here, use a defaultTargetUrl and controller.
70//    useSecurityEventListener = true
71//
72//    onAuthenticationSuccessEvent = { e, appCtx ->
73//        def p = e.source.principal
74//        def personInstance = Person.findByLoginName(p.username)
75//        println p.username
76//        println personInstance.loginName
77//        println personInstance.firstName
78//    }
79
80}
Note: See TracBrowser for help on using the repository browser.