-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathJsonRestApiGrailsPlugin.groovy
61 lines (52 loc) · 2.29 KB
/
JsonRestApiGrailsPlugin.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
import org.codehaus.groovy.grails.commons.GrailsClassUtils
import org.grails.plugins.rest.JSONApiRegistry
import org.grails.plugins.rest.JsonRestApiPropertyEditorRegistrar
import org.grails.plugins.rest.JsonDateEditorRegistrar
class JsonRestApiGrailsPlugin {
// the plugin version
def version = "1.0.12-SNAPSHOT"
// the version or versions of Grails the plugin is designed for
def grailsVersion = "1.3.0 > *"
// the other plugins this plugin depends on
def dependsOn = [:]
// resources that are excluded from plugin packaging
def pluginExcludes = [
"grails-app/views/error.gsp"
]
def author = "Matthias Hryniszak"
def authorEmail = "[email protected]"
def title = "JSON RESTful API for GORM"
def description = '''\\
This plugin provides effortless JSON API for GORM classes
'''
// URL to the plugin's documentation
def documentation = "http://grails.org/plugin/json-rest-api"
def doWithWebDescriptor = { xml ->
// TODO Implement additions to web.xml (optional), this event occurs before
}
def doWithSpring = {
jsonRestApiPropertyEditorRegistrar(JsonRestApiPropertyEditorRegistrar, ref("grailsApplication"))
customPropertyEditorRegistrar(JsonDateEditorRegistrar)
}
def doWithDynamicMethods = { ctx ->
application.domainClasses.each { domainClass ->
def resource = domainClass.getStaticPropertyValue('expose', String)
if (resource) {
println "Registering domain class: ${domainClass.fullName} exposed as ${resource} and its plural"
JSONApiRegistry.register(resource, domainClass.fullName)
}
}
}
def doWithApplicationContext = { applicationContext ->
grails.converters.JSON.registerObjectMarshaller(new org.grails.plugins.rest.JSONDomainMarshaller(application))
}
def onChange = { event ->
// TODO Implement code that is executed when any artefact that this plugin is
// watching is modified and reloaded. The event contains: event.source,
// event.application, event.manager, event.ctx, and event.plugin.
}
def onConfigChange = { event ->
// TODO Implement code that is executed when the project configuration changes.
// The event is the same as for 'onChange'.
}
}