source: trunk/grails-app/conf/Config.groovy @ 197

Last change on this file since 197 was 197, checked in by gav, 14 years ago

Revamp logging configuration.

File size: 9.7 KB
Line 
1// locations to search for config files that get merged into the main config
2// config files can either be Java properties files or ConfigSlurper scripts
3
4// grails.config.locations = [ "classpath:${appName}-config.properties",
5//                             "classpath:${appName}-config.groovy",
6//                             "file:${userHome}/.grails/${appName}-config.properties",
7//                             "file:${userHome}/.grails/${appName}-config.groovy"]
8
9// if(System.properties["${appName}.config.location"]) {
10//    grails.config.locations << "file:" + System.properties["${appName}.config.location"]
11// }
12grails.mime.file.extensions = true // enables the parsing of file extensions from URLs into the request format
13grails.mime.types = [ html: ['text/html','application/xhtml+xml'],
14                      xml: ['text/xml', 'application/xml'],
15                      text: 'text-plain',
16                      js: 'text/javascript',
17                      rss: 'application/rss+xml',
18                      atom: 'application/atom+xml',
19                      css: 'text/css',
20                      csv: 'text/csv',
21                      pdf: 'application/pdf',
22                      rtf: 'application/rtf',
23                      excel: 'application/vnd.ms-excel',
24                      ods: 'application/vnd.oasis.opendocument.spreadsheet',
25                      all: '*/*',
26                      json: ['application/json','text/json'],
27                      form: 'application/x-www-form-urlencoded',
28                      multipartForm: 'multipart/form-data'
29                    ]
30// The default codec used to encode data with ${}
31grails.views.default.codec="none" // none, html, base64
32grails.views.gsp.encoding="UTF-8"
33grails.converters.encoding="UTF-8"
34
35// enabled native2ascii conversion of i18n properties files
36grails.enable.native2ascii = true
37
38/**
39 * Start of log4j configuration.
40 * Causing this file to reload (e.g. edit/save) may break the appLog destination
41 * and further logs will be written to files or directories like "[:]"
42 * For more info see http://logging.apache.org/log4j/1.2/manual.html
43 * For log levels see http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/Level.html
44 * Basic log levels are ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF
45 */
46def logDirectory = '.'
47
48log4j = {
49    appenders {
50        // Use if we want to prevent creation of a stacktrace.log file.
51        // Beware that since we are using assingment above 'log4j =' this may override things you did not want to.
52        'null' name:'stacktrace'
53
54        // Use this if we want to modify the default appender called 'stdout'.
55        console name:'stdout', layout:pattern(conversionPattern: '[%t] %-5p %c{2} %x - %m%n')
56
57        // Custom log file.
58        rollingFile name:"appLog",
59                        file:"${logDirectory}/${appName}.log".toString(),
60                        maxFileSize:'1MB',
61                        maxBackupIndex:0,
62                        layout:pattern(conversionPattern: '%d{[EEE, dd-MMM-yyyy @ HH:mm:ss.SSS]} [%t] %-5p %c %x - %m%n')
63    }
64
65    // Configure the root logger to output to stdout and appLog appenders.
66    root {
67        error 'stdout','appLog'
68        additivity = true
69    }
70
71    // This is for the builtin stuff and from the default Grails-1.1.1 config.
72    error 'org.codehaus.groovy.grails.web.servlet',  //  controllers
73            'org.codehaus.groovy.grails.web.pages', //  GSP
74            'org.codehaus.groovy.grails.web.sitemesh', //  layouts
75            'org.codehaus.groovy.grails.web.mapping.filter', // URL mapping
76            'org.codehaus.groovy.grails.web.mapping', // URL mapping
77            'org.codehaus.groovy.grails.commons', // core / classloading
78            'org.codehaus.groovy.grails.plugins', // plugins
79            'org.codehaus.groovy.grails.orm.hibernate', // hibernate integration
80            'org.springframework',
81            'org.hibernate'
82
83    warn   'org.mortbay.log' // Jetty
84
85    error "grails.app" // Set the default log level for our app code.
86    info "grails.app.bootstrap" // Set the log level per type and per type.class
87    debug "grails.app.service"
88    debug "grails.app.controller"
89    error "grails.app.service.PersonService"
90    error "grails.app.service.NavigationService"
91}
92
93/**
94 * Environment specific configuration.
95 */
96environments {
97
98    production {
99        grails.serverURL = "http://www.changeme.com" // Set serverURL stem for creating absolute links.
100        log4j {
101            appenders {
102                // Pickup the Tomcat/Catalina logDirectory else use the current dir.
103                def catalinaBase = System.properties.getProperty('catalina.base')
104                logDirectory = catalinaBase ? "${catalinaBase}/logs" : '.'
105
106                rollingFile name:"appLog",
107                                file:"${logDirectory}/${appName}.log".toString(),
108                                maxFileSize:'1MB',
109                                maxBackupIndex:0,
110                                layout:pattern(conversionPattern: '%d{[EEE, dd-MMM-yyyy @ HH:mm:ss.SSS]} [%t] %-5p %c %x - %m%n')
111
112            }
113            error "grails.app" // Set the default log level for our app code.
114            info "grails.app.bootstrap" // Set the log level per type and per type.class
115            warn "grails.app.service"
116            warn "grails.app.controller"
117        }
118    }
119
120    development {
121        grails.serverURL = "http://localhost:8080/${appName}" // Set serverURL stem for creating absolute links.
122    }
123
124    test {
125        grails.serverURL = "http://localhost:8080/${appName}" // Set serverURL stem for creating absolute links.
126    }
127
128} // end environments
129
130/** Navigation plugin menu.
131   * The top level titles are taken from i18n message bundles.
132   * Subitems i18n message bundles are not currently resolving with this plugin.
133   */
134navigation.nav = [
135    [order:10, controller:'appCore', title:'home', action:'start',
136        subItems: [
137            [order:10, controller:'appCore', title:'Start', action:'start', isVisible: { true }],
138            [order:20, controller:'appCore', title:'Manager', action:'manager', isVisible: { authenticateService.ifAnyGranted('ROLE_Manager,ROLE_AppAdmin') }],
139            [order:30, controller:'appCore', title:'Admin', action:'appAdmin', isVisible: { authenticateService.ifAllGranted('ROLE_AppAdmin') }],
140            [order:90, controller:'appCore', title:'Timeout', action:'changeSessionTimeout', isVisible: { params.action == 'changeSessionTimeout' }],
141            [order:91, controller:'appCore', title:'Password', action:'changePassword', isVisible: { params.action == 'changePassword' }],
142        ]
143    ],
144    [order:20, controller:'taskDetailed', title:'tasks', action:'search',
145        subItems: [
146            [order:10, controller:'taskDetailed', title:'Search', action:'search', isVisible: { params.action != 'searchCalendar'}],
147            [order:11, controller:'taskDetailed', title:'Calendar', action:'searchCalendar', isVisible: { params.action == 'searchCalendar' }],
148            [order:20, controller:'taskDetailed', title:'Create', action:'create', isVisible: { true }],
149            [order:90, controller:'taskDetailed', title:'Show', action:'show', isVisible: { params.action == 'show' }],
150            [order:91, controller:'taskDetailed', title:'Edit', action:'edit', isVisible: { params.action == 'edit' }]
151        ]
152    ],
153    [order:30, controller:'inventoryItemDetailed', title:'inventory', action:'search',
154        subItems: [
155            [order:10, controller:'inventoryItemDetailed', title:'Search', action:'search', isVisible: { true }],
156            [order:20, controller:'inventoryItemDetailed', title:'Create', action:'create', isVisible: { true }],
157            [order:90, controller:'inventoryItemDetailed', title:'Show', action:'show', isVisible: { params.action == 'show' }],
158            [order:91, controller:'inventoryItemDetailed', title:'Edit', action:'edit', isVisible: { params.action == 'edit' }]
159        ]
160    ],
161    [order:40, controller:'assetDetailed', title:'assets', action:'search',
162        subItems: [
163            [order:10, controller:'assetDetailed', title:'Search', action:'search', isVisible: { true }],
164            [order:20, controller:'assetDetailed', title:'Create', action:'create', isVisible: { true }],
165            [order:90, controller:'assetDetailed', title:'Show', action:'show', isVisible: { params.action == 'show' }],
166            [order:91, controller:'assetDetailed', title:'Edit', action:'edit', isVisible: { params.action == 'edit' }]
167        ]
168    ]
169]
170
171/** Navigation plugin alternate menu.
172   * The alternate top level titles are not displayed anywhere.
173   * Subitems i18n message bundles are not currently resolving with this plugin.
174   */
175navigation.navAlt = [
176    [order:10, controller:'person', title:'person', action:'list',
177        subItems: [
178            [order:10, controller:'person', title:'Person List', action:'list', isVisible: { true }],
179            [order:20, controller:'person', title:'Create', action:'create', isVisible: { true }],
180            [order:90, controller:'person', title:'Show', action:'show', isVisible: { params.action == 'show' }],
181            [order:91, controller:'person', title:'Edit', action:'edit', isVisible: { params.action == 'edit' }]
182        ]
183    ],
184    [order:20, controller:'taskProcedureDetailed', title:'task', action:'list',
185        subItems: [
186            [order:10, controller:'taskProcedureDetailed', title:'Task Procedure List', action:'list', isVisible: { true }],
187            [order:20, controller:'taskProcedureDetailed', title:'Create', action:'create', isVisible: { true }],
188            [order:90, controller:'taskProcedureDetailed', title:'Show', action:'show', isVisible: { params.action == 'show' }],
189            [order:91, controller:'taskProcedureDetailed', title:'Edit', action:'edit', isVisible: { params.action == 'edit' }]
190        ]
191    ]
192]
Note: See TracBrowser for help on using the repository browser.