-
Notifications
You must be signed in to change notification settings - Fork 25
/
CollectoryGrailsPlugin.groovy
115 lines (92 loc) · 4.21 KB
/
CollectoryGrailsPlugin.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import org.codehaus.groovy.grails.context.support.PluginAwareResourceBundleMessageSource
import au.org.ala.collectory.ExtendedPluginAwareResourceBundleMessageSource
import grails.util.Environment
class CollectoryGrailsPlugin {
def grailsApplication
def dataLoaderService
def authenticateService
// the plugin version
def version = "1.9.12-SNAPSHOT"
// the version or versions of Grails the plugin is designed for
def grailsVersion = "2.5 > *"
// resources that are excluded from plugin packaging
def pluginExcludes = [
//"grails-app/views/error.gsp"
]
def title = "Collectory Plugin" // Headline display name of the plugin
def author = "Alan Lin"
def authorEmail = "[email protected]"
def description = '''\
A Grails plugin to provide the core functionality for collection and displaying biodiversity data from
collectory web services. Data access is via JSON REST web services
from the ALA collectory app (no local DB is required for this app).
'''
// URL to the plugin's documentation
def documentation = "https://github.com/AtlasOfLivingAustralia/collectory-plugin"
// License: one of 'APACHE', 'GPL2', 'GPL3'
def license = "MPL2"
// Details of company behind the plugin (if there is one)
def organization = [ name: "Atlas of Living Australia", url: "https://www.ala.org.au/" ]
// Any additional developers beyond the author specified above.
def developers = [
[ name: "Dave Martin", email: "[email protected]" ],
[ name: "Nick dos Remedios", email: "[email protected]" ]
]
// Location of the plugin's issue tracker.
def issueManagement = [ system: "Github Issues", url: "https://github.com/AtlasOfLivingAustralia/collectory-plugin/issues" ]
// Online location of the plugin's browseable source code.
def scm = [ url: "https://github.com/AtlasOfLivingAustralia/collectory-plugin" ]
def loadAfter = ['alaBootstrap3']
def doWithWebDescriptor = { xml -> }
def doWithSpring = {
def config = application.config
// UTF-8 encoding
config.grails.views.default.codec = "html"
config.grails.views.gsp.encoding = "UTF-8"
config.grails.converters.encoding = "UTF-8"
// EhCache settings
if (!config.grails.cache.config) {
config.grails.cache.config = {
defaults {1
eternal false
overflowToDisk false
maxElementsInMemory 10000
timeToLiveSeconds 3600
}
cache {
name 'collectoryCache'
timeToLiveSeconds (3600 * 24) // day
}
cache {
name 'longTermCache'
timeToLiveSeconds (3600 * 24 * 7) // week
}
}
}
// Apache proxyPass & cached-resources seems to mangle image URLs in plugins, so we exclude caching it
application.config.grails.resources.mappers.hashandcache.excludes = ["**/images/*.*"]
def loadConfig = new ConfigSlurper(Environment.current.name).parse(application.classLoader.loadClass("defaultConfig"))
application.config = loadConfig.merge(config) // client app will now override the defaultConfig version
def beanconf = springConfig.getBeanConfig('messageSource')
def beandef = beanconf ? beanconf.beanDefinition : springConfig.getBeanDefinition('messageSource')
if (beandef?.beanClassName == PluginAwareResourceBundleMessageSource.class.canonicalName) {
//just change the target class of the bean, maintaining all configurations.
beandef.beanClassName = ExtendedPluginAwareResourceBundleMessageSource.class.canonicalName
}
messageSource(ExtendedPluginAwareResourceBundleMessageSource) {
basenames = ["WEB-INF/grails-app/i18n/messages"] as String[]
cacheSeconds = (60 * 60 * 6) // 6 hours
useCodeAsDefaultMessage = false
}
}
def doWithDynamicMethods = { ctx ->
}
def doWithApplicationContext = {ctx ->
}
def onChange = { event ->
}
def onConfigChange = { event ->
}
def onShutdown = { event ->
}
}