Merge "Install newer versions of Zanata"

This commit is contained in:
Jenkins 2017-02-14 18:06:07 +00:00 committed by Gerrit Code Review
commit b83241f180
2 changed files with 89 additions and 41 deletions

View File

@ -22,12 +22,20 @@ class zanata(
$zanata_db_username = 'zanata', $zanata_db_username = 'zanata',
$zanata_db_password, $zanata_db_password,
# For wildfly < 10 the zanata_url below is expected to be a url to a built
# war for wildfly >=10 the expectation is that it is the url to one of the
# published zipfiles that can be overlaid atop the wildfly installation
# dir.
$zanata_wildfly_version = '9.0.1', $zanata_wildfly_version = '9.0.1',
$zanata_wildfly_install_url = 'https://repo1.maven.org/maven2/org/wildfly/wildfly-dist/9.0.1.Final/wildfly-dist-9.0.1.Final.tar.gz', $zanata_wildfly_install_url = 'https://repo1.maven.org/maven2/org/wildfly/wildfly-dist/9.0.1.Final/wildfly-dist-9.0.1.Final.tar.gz',
$zanata_hibernate_url = 'https://sourceforge.net/projects/zanata/files/wildfly/wildfly-8.1.0.Final-module-hibernate-main-4.2.15.Final.zip', $zanata_hibernate_url = 'https://sourceforge.net/projects/zanata/files/wildfly/wildfly-8.1.0.Final-module-hibernate-main-4.2.15.Final.zip',
$zanata_mojarra_url = 'https://sourceforge.net/projects/zanata/files/wildfly/wildfly-8.1.0.Final-module-mojarra-2.1.28.zip', $zanata_mojarra_url = 'https://sourceforge.net/projects/zanata/files/wildfly/wildfly-8.1.0.Final-module-mojarra-2.1.28.zip',
# The default here is to a war file and can be used with wildfly < 10.
# If using wildfly >= 10 an example url would be:
# https://github.com/zanata/zanata-server/releases/download/server-3.9.6/zanata-3.9.6-wildfly.zip
$zanata_url = 'https://sourceforge.net/projects/zanata/files/webapp/zanata-war-3.7.3.war', $zanata_url = 'https://sourceforge.net/projects/zanata/files/webapp/zanata-war-3.7.3.war',
# This should be a sha1 of whatever file is hosted at the url above.
$zanata_checksum = '59f1ac35cce46ba4e46b06a239cd7ab4e10b5528', $zanata_checksum = '59f1ac35cce46ba4e46b06a239cd7ab4e10b5528',
$zanata_default_from_address, $zanata_default_from_address,
@ -46,65 +54,70 @@ class zanata(
$zanata_smtp_ssl = '', $zanata_smtp_ssl = '',
) { ) {
zanata::validate_listener { $zanata_listeners: }
$zanata_file = inline_template('<%= File.basename(@zanata_url) %>') $zanata_file = inline_template('<%= File.basename(@zanata_url) %>')
$zanata_ext = inline_template('<%= File.extname(@zanata_url) %>')
$wildfly_file = inline_template('<%= File.basename(@zanata_wildfly_install_url) %>') $wildfly_file = inline_template('<%= File.basename(@zanata_wildfly_install_url) %>')
$zanata_hibernate_file = inline_template('<%= File.basename(@zanata_hibernate_url) %>') $zanata_hibernate_file = inline_template('<%= File.basename(@zanata_hibernate_url) %>')
$zanata_mojarra_file = inline_template('<%= File.basename(@zanata_mojarra_url) %>') $zanata_mojarra_file = inline_template('<%= File.basename(@zanata_mojarra_url) %>')
zanata::validate_listener { $zanata_listeners:
}
class { '::zanata::wildfly': class { '::zanata::wildfly':
wildfly_version => $zanata_wildfly_version, wildfly_version => $zanata_wildfly_version,
wildfly_install_source => $zanata_wildfly_install_url, wildfly_install_source => $zanata_wildfly_install_url,
} }
package { [
'libmysql-java',
'unzip'
]:
ensure => present,
}
file { $zanata_storage_dir: file { $zanata_storage_dir:
ensure => 'directory', ensure => 'directory',
owner => 'wildfly', owner => 'wildfly',
group => 'wildfly' group => 'wildfly'
} }
package { 'unzip':
ensure => present,
}
include '::archive' include '::archive'
archive { '/opt/wildfly/standalone/deployments/ROOT.war': if ($zanata_ext == '.war') {
ensure => present, # This implies the old wildfly <10 install method of installing wildfly
user => 'wildfly', # then manually injecting deps and the war into the wildfly install.
source => $zanata_url, # You need to make sure you provide a .war file url for zanata when
checksum_type => 'sha1', # using wildfly < 10.
checksum => $zanata_checksum, package { 'libmysql-java':
require => [ ensure => present,
Class['wildfly::install'], }
]
}
# The mysql driver name differs based on the version of the package. Ensure # The mysql driver name differs based on the version of the package. Ensure
# we set it correctly when writing the standalone.xml config file below. # we set it correctly when writing the standalone.xml config file below.
if ($::operatingsystem == 'Ubuntu') and ($::operatingsystemrelease >= '16.04') { # Note that this isn't the name used by files on disk, rather it is some
$mysql_driver_name = 'mysql-connector-java.jar_com.mysql.jdbc.Driver_5_1' # java class lookup name used in the standalone.xml configuration file.
} if ($::operatingsystem == 'Ubuntu') and ($::operatingsystemrelease >= '16.04') {
else { $mysql_driver_name = 'mysql-connector-java.jar_com.mysql.jdbc.Driver_5_1'
$mysql_driver_name = 'mysql-connector-java.jar' }
} else {
$mysql_driver_name = 'mysql-connector-java.jar'
}
file { '/opt/wildfly/standalone/deployments/mysql-connector-java.jar': file { '/opt/wildfly/standalone/deployments/mysql-connector-java.jar':
ensure => 'link', ensure => 'link',
target => '/usr/share/java/mysql-connector-java.jar', target => '/usr/share/java/mysql-connector-java.jar',
require => [ require => [
Package['libmysql-java'], Package['libmysql-java'],
Class['zanata::wildfly'], Class['zanata::wildfly'],
], ],
} }
archive { '/opt/wildfly/standalone/deployments/ROOT.war':
ensure => present,
user => 'wildfly',
source => $zanata_url,
checksum_type => 'sha1',
checksum => $zanata_checksum,
require => [
Class['wildfly::install'],
]
}
if (versioncmp($zanata_wildfly_version, '10.0.0') < 0) {
archive { "/home/wildfly/${zanata_hibernate_file}": archive { "/home/wildfly/${zanata_hibernate_file}":
ensure => present, ensure => present,
user => 'wildfly', user => 'wildfly',
@ -136,7 +149,39 @@ class zanata(
Archive["/home/wildfly/${zanata_hibernate_file}"], Archive["/home/wildfly/${zanata_hibernate_file}"],
], ],
} }
} else { }
elsif ($zanata_ext == '.zip') {
# This implies the newer wildfly >= 10 install method where we install
# wildfly, then unpack the zanata zip file into that install dir which
# gives us all of our deps. You need to make sure you provide a .zip file
# url for zanata when using wildfly >= 10.
archive { "/tmp/${zanata_file}":
ensure => present,
user => 'wildfly',
source => $zanata_url,
extract => true,
extract_path => '/opt/wildfly',
checksum_type => 'sha1',
checksum => $zanata_checksum,
require => [
Class['wildfly::install'],
]
}
file { '/opt/wildfly/standalone/deployments/zanata.war.skipdeploy':
# we don't want to serve at /zanata we want to serve at / so we skip
# deploying with zanata.war and set up ROOT.war below.
ensure => present,
require => Archive["/tmp/${zanata_file}"],
}
file { '/opt/wildfly/standalone/deployments/ROOT.war':
ensure => link,
target => '/opt/wildfly/standalone/deployments/zanata.war',
require => Archive["/tmp/${zanata_file}"],
}
# TODO make this handle wildfly >= 10.
file { '/opt/wildfly/standalone/configuration/standalone.xml': file { '/opt/wildfly/standalone/configuration/standalone.xml':
ensure => present, ensure => present,
notify => Service['wildfly'], notify => Service['wildfly'],
@ -145,11 +190,14 @@ class zanata(
content => template('zanata/wildfly-10-standalone.xml.erb'), content => template('zanata/wildfly-10-standalone.xml.erb'),
require => [ require => [
Class['zanata::wildfly'], Class['zanata::wildfly'],
Archive['/opt/wildfly/standalone/deployments/ROOT.war'], File['/opt/wildfly/standalone/deployments/zanata.war.skipdeploy'],
File['/opt/wildfly/standalone/deployments/ROOT.war'],
], ],
} }
} }
else {
fail('zanata_url must be for a .war or .zip file.')
}
} }
# == Define: zanata::validate_listener # == Define: zanata::validate_listener

View File

@ -195,7 +195,7 @@
<datasource jndi-name="java:jboss/datasources/zanataDatasource" pool-name="zanataDatasource" enabled="true" use-ccm="true"> <datasource jndi-name="java:jboss/datasources/zanataDatasource" pool-name="zanataDatasource" enabled="true" use-ccm="true">
<connection-url>jdbc:mysql://<%= @mysql_host %>:<%= @mysql_port %>/zanata?characterEncoding=UTF-8</connection-url> <connection-url>jdbc:mysql://<%= @mysql_host %>:<%= @mysql_port %>/zanata?characterEncoding=UTF-8</connection-url>
<driver-class>com.mysql.jdbc.Driver</driver-class> <driver-class>com.mysql.jdbc.Driver</driver-class>
<driver><%= @mysql_driver_name %></driver> <driver>mysql-connector-java.jar</driver>
<pool> <pool>
<min-pool-size>0</min-pool-size> <min-pool-size>0</min-pool-size>
<max-pool-size>20</max-pool-size> <max-pool-size>20</max-pool-size>