Я пытаюсь создать простой проект Grails 3 и застрял с чем-то очень простым. Поэтому я хочу, чтобы мои свойства источника данных поступали из параметров VM, которые я установил в своей IntelliJ IDE. Перед тем как в Grails 2.x, я использовал, чтобы сделать что-то вроде:конвертировать конфигурационный файл application.yml в application.groovy в Grails 3.x
environments {
development{
//Database connection properties
def dbserver = System.properties.getProperty('dbserver')
def dbport = System.properties.getProperty('dbport')
............
dataSource {
url: "jdbc:sqlserver://${dbserver}:${dbport};databaseName=${dbname}
}
}
Теперь у меня есть application.yml, как получить доступ к «System.properties» и вставить ее в YML? Я прочитал, что мы можем использовать вместо application.groovy если YML не поддерживает его, в этом случае это то, что application.groovy выглядит следующим образом:
grails {
profile = 'web'
codegen {
defaultPackage = 'defPack'
}
}
info {
app {
name = '@[email protected]'
version = '@[email protected]'
grailsVersion = '@[email protected]'
}
}
spring {
groovy {
template['check-template-location'] = false
}
}
hibernate {
naming_strategy = 'org.hibernate.cfg.DefaultNamingStrategy'
cache {
queries = false
}
}
grails {
mime {
disable {
accept {
header {
userAgents = ['Gecko', 'WebKit', 'Presto', 'Trident']
}
}
}
types {
all = '*/*'
atom = 'application/atom+xml'
css = 'text/css'
csv = 'text/csv'
form = 'application/x-www-form-urlencoded'
html = ['text/html', 'application/xhtml+xml']
js = 'text/javascript'
json = ['application/json', 'text/json']
multipartForm = 'multipart/form-data'
rss = 'application/rss+xml'
text = 'text/plain'
hal = ['application/hal+json', 'application/hal+xml']
xml = ['text/xml', 'application/xml']
}
}
urlmapping {
cache {
maxsize = 1000
}
}
controllers {
defaultScope = 'singleton'
}
converters {
encoding = 'UTF-8'
}
views {
default { codec = 'html' }
gsp {
encoding = 'UTF-8'
htmlcodec = 'xml'
codecs {
expression = 'html'
scriptlets = 'html'
taglib = 'none'
staticparts = 'none'
}
}
}
}
dataSource {
pooled = true
jmxExport = true
driverClassName = 'com.microsoft.sqlserver.jdbc.SQLServerDriver'
dbCreate = ''
username = 'someUsername'
password = 'somePass'
}
environments {
development {
dataSource {
url = 'jdbc:sqlserver://localhost:1234;databaseName=someDbName;'
}
}
}
Спасибо.
UPDATE:
application.groovy не принимаются, по умолчанию, даже когда я удалил application.yml
В последней части, вы должны были бы процитировать их: 'userAgents = [ 'Gecko', 'WebKit'] ' –
@IanRoberts, спасибо, я обновлю свой пост. –