This repository has been archived by the owner on Feb 5, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patheaeGrailsPlugin.groovy
93 lines (76 loc) · 3.47 KB
/
eaeGrailsPlugin.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
class eaeGrailsPlugin {
// the plugin version
def version = "1.0"
// the version or versions of Grails the plugin is designed for
def grailsVersion = "2.3 > *"
// resources that are excluded from plugin packaging
def pluginExcludes = [
"grails-app/views/error.gsp"
]
// TODO Fill in these fields
def title = "eAE" // Headline display name of the plugin
def author = "Axel Oehmichen"
def authorEmail = "ao1011@imperial.ac.uk"
def description =
'''
This plugin aims at providing a connection between tranSMART and the eTRIKS Analytical Environement
'''
// URL to the plugin's documentation
def documentation = ""
// Extra (optional) plugin metadata
// License: one of 'APACHE', 'GPL2', 'GPL3'
def license = "APACHE"
// Details of company behind the plugin (if there is one)
def organization = [ name: "eTRIKS", url: "https://www.etriks.org/" ]
// Any additional developers beyond the author specified above.
// def developers = [ [ name: "Joe Bloggs", email: "joe@bloggs.net" ]]
// Location of the plugin's issue tracker.
// def issueManagement = [ system: "JIRA", url: "http://jira.grails.org/browse/GPMYPLUGIN" ]
// Online location of the plugin's browseable source code.
// def scm = [ url: "http://svn.codehaus.org/grails-plugins/" ]
def doWithWebDescriptor = { xml ->
// TODO Implement additions to web.xml (optional), this event occurs before
}
def doWithSpring = {
dataQueryService(eae.plugin.DataQueryService) {
studiesResourceService = ref('studiesResourceService')
conceptsResourceService = ref('conceptsResourceService')
clinicalDataResourceService = ref('clinicalDataResourceService')
dataSource = ref('dataSource')
i2b2HelperService = ref('i2b2HelperService')
}
}
def doWithDynamicMethods = { ctx ->
// TODO Implement registering dynamic methods to classes (optional)
}
def doWithApplicationContext = { ctx ->
// TODO Implement post initialization spring config (optional)
// Set the scripts to executable
def eaeFileSystemName = ctx.getBean('pluginManager').allPlugins.sort({ it.name.toUpperCase() }).find { it.fileSystemName ==~ /eae-\w.\w/}
String path = ctx.servletContext.getRealPath("") + '/plugins/'+ eaeFileSystemName.fileSystemName.toString() + '/Scripts/eae'
File scriptsFolder = new File(path);
if(scriptsFolder.exists() && scriptsFolder.isDirectory()){
File[] files = scriptsFolder.listFiles();
for (File file : files) {
if (file.isFile()) {
if(!file.canExecute()){
file.setExecutable(true)
}
}
}
}
println("Bootstrapping Completed. Scripts are executable.")
}
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'.
}
def onShutdown = { event ->
// TODO Implement code that is executed when the application shuts down (optional)
}
}