2012-04-10 01:16:47 +00:00
|
|
|
# Install and maintain Gerrit Code Review.
|
|
|
|
# params:
|
|
|
|
# virtual_hostname:
|
|
|
|
# used in the Apache virtual host, eg., review.example.com
|
|
|
|
# canonicalweburl:
|
|
|
|
# Used in the Gerrit config to generate links, eg., https://review.example.com/
|
|
|
|
# ssl_cert_file:
|
|
|
|
# ssl_key_file:
|
|
|
|
# Used in the Apache virtual host to specify the SSL cert and key files.
|
|
|
|
# ssl_chain_file:
|
|
|
|
# Optional, if you have an intermediate cert Apache should serve.
|
|
|
|
# openidssourl:
|
|
|
|
# The URL to use for OpenID in SSO mode.
|
|
|
|
# email:
|
|
|
|
# The email address Gerrit should use when sending mail.
|
2012-05-29 18:12:35 +00:00
|
|
|
# database_poollimit:
|
|
|
|
# container_heaplimit:
|
|
|
|
# core_packedgitopenfiles:
|
|
|
|
# core_packedgitlimit:
|
|
|
|
# core_packedgitwindowsize:
|
|
|
|
# sshd_threads:
|
|
|
|
# httpd_acceptorthreads:
|
|
|
|
# httpd_minthreads:
|
|
|
|
# httpd_maxthreads:
|
2012-07-03 06:38:51 -07:00
|
|
|
# httpd_maxwait:
|
2012-05-29 18:12:35 +00:00
|
|
|
# Gerrit configuration options; see Gerrit docs.
|
2012-04-10 01:16:47 +00:00
|
|
|
# commentlinks:
|
|
|
|
# A list of regexes Gerrit should hyperlink.
|
|
|
|
# war:
|
|
|
|
# The URL of the Gerrit WAR that should be downloaded and installed.
|
|
|
|
# Note that only the final component is used for comparing to the most
|
|
|
|
# recently installed WAR. In other words, if you update the war from:
|
|
|
|
#
|
2012-07-06 12:48:38 -05:00
|
|
|
# http://tarballs.openstack.org/ci/gerrit.war
|
2012-04-10 01:16:47 +00:00
|
|
|
# to:
|
|
|
|
# http://somewhereelse.example.com/gerrit.war
|
|
|
|
#
|
|
|
|
# Gerrit won't be updated unless you delete gerrit.war from
|
|
|
|
# ~gerrit2/gerrit-wars. But if you change the URL from:
|
|
|
|
#
|
2012-07-06 12:48:38 -05:00
|
|
|
# http://tarballs.openstack.org/ci/gerrit-2.2.2.war
|
2012-04-10 01:16:47 +00:00
|
|
|
# to:
|
2012-07-06 12:48:38 -05:00
|
|
|
# http://tarballs.openstack.org/ci/gerrit-2.3.0.war
|
2012-04-10 01:16:47 +00:00
|
|
|
# Gerrit will be upgraded on the next puppet run.
|
2012-07-23 11:34:36 -05:00
|
|
|
# testmode:
|
|
|
|
# Set this to true to disable cron jobs and replication,
|
|
|
|
# which can interfere with testing.
|
2012-04-10 01:16:47 +00:00
|
|
|
# TODO: move apache configuration to another module
|
|
|
|
# TODO: move mysql configuration to another module
|
|
|
|
# TODO: make more gerrit options configurable here
|
|
|
|
|
2012-07-23 11:34:36 -05:00
|
|
|
class gerrit($virtual_hostname=$fqdn,
|
|
|
|
$canonicalweburl="https://$fqdn/",
|
2012-04-10 01:16:47 +00:00
|
|
|
$ssl_cert_file='',
|
|
|
|
$ssl_key_file='',
|
|
|
|
$ssl_chain_file='',
|
|
|
|
$openidssourl="https://login.launchpad.net/+openid",
|
|
|
|
$email='',
|
2012-05-29 18:12:35 +00:00
|
|
|
$database_poollimit='',
|
|
|
|
$container_heaplimit='',
|
|
|
|
$core_packedgitopenfiles='',
|
|
|
|
$core_packedgitlimit='',
|
|
|
|
$core_packedgitwindowsize='',
|
|
|
|
$sshd_threads='',
|
|
|
|
$httpd_acceptorthreads='',
|
|
|
|
$httpd_minthreads='',
|
|
|
|
$httpd_maxthreads='',
|
2012-07-03 06:38:51 -07:00
|
|
|
$httpd_maxwait='',
|
2012-07-23 09:50:18 -05:00
|
|
|
$commentlinks = [],
|
2012-05-17 14:53:01 +01:00
|
|
|
$war,
|
|
|
|
$script_user,
|
|
|
|
$script_key_file,
|
2012-06-25 13:26:46 -07:00
|
|
|
$enable_melody = 'false',
|
2012-07-19 17:17:29 -07:00
|
|
|
$melody_session = 'false',
|
|
|
|
$mysql_password,
|
2012-07-23 11:34:36 -05:00
|
|
|
$email_private_key,
|
|
|
|
$testmode=false
|
|
|
|
) {
|
2012-04-10 01:16:47 +00:00
|
|
|
|
2012-03-06 13:37:46 +00:00
|
|
|
user { "gerrit2":
|
|
|
|
ensure => present,
|
|
|
|
comment => "Gerrit",
|
|
|
|
home => "/home/gerrit2",
|
|
|
|
shell => "/bin/bash",
|
|
|
|
gid => "gerrit2",
|
|
|
|
managehome => true,
|
|
|
|
require => Group["gerrit2"]
|
|
|
|
}
|
|
|
|
|
|
|
|
group { "gerrit2":
|
|
|
|
ensure => present
|
|
|
|
}
|
|
|
|
|
2012-04-10 01:16:47 +00:00
|
|
|
$packages = ["gitweb",
|
|
|
|
"openjdk-6-jre-headless",
|
|
|
|
"mysql-server",
|
|
|
|
"apache2"]
|
|
|
|
|
|
|
|
package { $packages:
|
2012-06-05 22:59:46 +00:00
|
|
|
ensure => present,
|
2011-08-12 22:16:46 +00:00
|
|
|
}
|
2012-04-10 01:16:47 +00:00
|
|
|
|
2012-04-05 20:15:19 +00:00
|
|
|
file { "/var/log/gerrit":
|
|
|
|
ensure => "directory",
|
|
|
|
owner => 'gerrit2'
|
|
|
|
}
|
|
|
|
|
2012-04-10 01:16:47 +00:00
|
|
|
# Prepare gerrit directories. Even though some of these would be created
|
|
|
|
# by the init command, we can go ahead and create them now and populate them.
|
|
|
|
# That way the config files are already in place before init runs.
|
2012-03-06 13:37:46 +00:00
|
|
|
|
2012-04-05 20:15:19 +00:00
|
|
|
file { "/home/gerrit2/review_site":
|
2012-03-06 13:37:46 +00:00
|
|
|
ensure => "directory",
|
|
|
|
owner => "gerrit2",
|
|
|
|
require => User["gerrit2"]
|
|
|
|
}
|
|
|
|
|
2012-04-05 20:15:19 +00:00
|
|
|
file { "/home/gerrit2/review_site/etc":
|
|
|
|
ensure => "directory",
|
|
|
|
owner => "gerrit2",
|
|
|
|
require => File["/home/gerrit2/review_site"]
|
|
|
|
}
|
|
|
|
|
2012-04-10 01:16:47 +00:00
|
|
|
file { "/home/gerrit2/review_site/bin":
|
|
|
|
ensure => "directory",
|
|
|
|
owner => "gerrit2",
|
|
|
|
require => File["/home/gerrit2/review_site"]
|
|
|
|
}
|
|
|
|
|
2012-07-23 11:34:36 -05:00
|
|
|
file { "/home/gerrit2/review_site/static":
|
2012-04-05 20:15:19 +00:00
|
|
|
ensure => "directory",
|
|
|
|
owner => "gerrit2",
|
|
|
|
require => File["/home/gerrit2/review_site"]
|
|
|
|
}
|
|
|
|
|
2012-07-23 11:34:36 -05:00
|
|
|
file { "/home/gerrit2/review_site/hooks":
|
2012-04-05 20:15:19 +00:00
|
|
|
ensure => "directory",
|
|
|
|
owner => "gerrit2",
|
|
|
|
require => File["/home/gerrit2/review_site"]
|
2012-03-06 13:37:46 +00:00
|
|
|
}
|
|
|
|
|
2012-04-10 01:16:47 +00:00
|
|
|
# Skip replication if we're in test mode
|
|
|
|
if ($testmode == false) {
|
2012-07-23 11:34:36 -05:00
|
|
|
# TODO: This file needs to be templated with a boolean around
|
|
|
|
# enabling replication to github. Also, the local repos need
|
|
|
|
# to be managed in here when we get project creation handled
|
2012-04-10 01:16:47 +00:00
|
|
|
file { '/home/gerrit2/review_site/etc/replication.config':
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
mode => 444,
|
|
|
|
ensure => 'present',
|
|
|
|
source => 'puppet:///modules/gerrit/replication.config',
|
|
|
|
replace => 'true',
|
|
|
|
require => File["/home/gerrit2/review_site/etc"]
|
|
|
|
}
|
2012-03-06 13:37:46 +00:00
|
|
|
}
|
|
|
|
|
2012-04-24 07:36:24 -07:00
|
|
|
# Gerrit sets these permissions in 'init'; don't fight them.
|
2012-03-06 13:37:46 +00:00
|
|
|
file { '/home/gerrit2/review_site/etc/gerrit.config':
|
2012-04-24 07:36:24 -07:00
|
|
|
owner => 'gerrit2',
|
|
|
|
group => 'gerrit2',
|
|
|
|
mode => 644,
|
2012-03-06 13:37:46 +00:00
|
|
|
ensure => 'present',
|
|
|
|
content => template('gerrit/gerrit.config.erb'),
|
|
|
|
replace => 'true',
|
|
|
|
require => File["/home/gerrit2/review_site/etc"]
|
|
|
|
}
|
|
|
|
|
2012-04-10 01:16:47 +00:00
|
|
|
# Secret files.
|
|
|
|
|
2012-04-24 07:36:24 -07:00
|
|
|
# Gerrit sets these permissions in 'init'; don't fight them. If
|
|
|
|
# these permissions aren't set correctly, gerrit init will write a
|
|
|
|
# new secure.config file and lose the mysql password.
|
2012-04-10 01:16:47 +00:00
|
|
|
file { '/home/gerrit2/review_site/etc/secure.config':
|
2012-04-24 07:36:24 -07:00
|
|
|
owner => 'gerrit2',
|
2012-04-10 01:16:47 +00:00
|
|
|
group => 'gerrit2',
|
2012-04-24 07:36:24 -07:00
|
|
|
mode => 600,
|
2012-04-10 01:16:47 +00:00
|
|
|
ensure => 'present',
|
2012-07-19 17:17:29 -07:00
|
|
|
content => template('gerrit/secure.config.erb'),
|
2012-04-10 01:16:47 +00:00
|
|
|
replace => 'true',
|
|
|
|
require => File["/home/gerrit2/review_site/etc"]
|
|
|
|
}
|
|
|
|
|
|
|
|
# Set up MySQL.
|
|
|
|
# We should probably have or use a puppet module to manage mysql, and then
|
|
|
|
# use that to satisfy the requirements that gerrit has.
|
|
|
|
|
|
|
|
exec { "gerrit-mysql":
|
|
|
|
creates => "/var/lib/mysql/reviewdb/",
|
|
|
|
command => "/usr/bin/mysql --defaults-file=/etc/mysql/debian.cnf -e \"\
|
2012-07-19 17:17:29 -07:00
|
|
|
CREATE USER 'gerrit2'@'localhost' IDENTIFIED BY '${mysql_password}';\
|
2012-04-10 01:16:47 +00:00
|
|
|
CREATE DATABASE reviewdb;\
|
|
|
|
ALTER DATABASE reviewdb charset=latin1;\
|
|
|
|
GRANT ALL ON reviewdb.* TO 'gerrit2'@'localhost';\
|
|
|
|
FLUSH PRIVILEGES;\"",
|
2012-07-19 17:17:29 -07:00
|
|
|
require => Package["mysql-server"],
|
2012-04-10 01:16:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file { "/etc/mysql/my.cnf":
|
|
|
|
source => 'puppet:///modules/gerrit/my.cnf',
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
ensure => 'present',
|
|
|
|
replace => 'true',
|
|
|
|
mode => 444,
|
|
|
|
require => Package["mysql-server"],
|
|
|
|
}
|
|
|
|
|
|
|
|
# Set up apache. This should also be a separate, generalized module.
|
|
|
|
|
|
|
|
file { "/etc/apache2/sites-available/gerrit":
|
|
|
|
content => template('gerrit/gerrit.vhost.erb'),
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
ensure => 'present',
|
|
|
|
replace => 'true',
|
|
|
|
mode => 444,
|
|
|
|
require => Package["apache2"],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { "/etc/apache2/sites-enabled/gerrit":
|
|
|
|
ensure => link,
|
|
|
|
target => '/etc/apache2/sites-available/gerrit',
|
|
|
|
require => [
|
|
|
|
File['/etc/apache2/sites-available/gerrit'],
|
|
|
|
File['/etc/apache2/mods-enabled/ssl.conf'],
|
|
|
|
File['/etc/apache2/mods-enabled/ssl.load'],
|
|
|
|
File['/etc/apache2/mods-enabled/rewrite.load'],
|
|
|
|
File['/etc/apache2/mods-enabled/proxy.conf'],
|
|
|
|
File['/etc/apache2/mods-enabled/proxy.load'],
|
|
|
|
File['/etc/apache2/mods-enabled/proxy_http.load'],
|
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/sites-enabled/000-default':
|
|
|
|
require => File['/etc/apache2/sites-available/gerrit'],
|
|
|
|
ensure => absent,
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/ssl.conf':
|
|
|
|
target => '/etc/apache2/mods-available/ssl.conf',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/ssl.load':
|
|
|
|
target => '/etc/apache2/mods-available/ssl.load',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/rewrite.load':
|
|
|
|
target => '/etc/apache2/mods-available/rewrite.load',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/proxy.conf':
|
|
|
|
target => '/etc/apache2/mods-available/proxy.conf',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/proxy.load':
|
|
|
|
target => '/etc/apache2/mods-available/proxy.load',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/etc/apache2/mods-enabled/proxy_http.load':
|
|
|
|
target => '/etc/apache2/mods-available/proxy_http.load',
|
|
|
|
ensure => link,
|
|
|
|
require => Package['apache2'],
|
|
|
|
}
|
|
|
|
|
|
|
|
exec { "gracefully restart apache":
|
|
|
|
subscribe => [ File["/etc/apache2/sites-available/gerrit"]],
|
|
|
|
refreshonly => true,
|
|
|
|
path => "/bin:/usr/bin:/usr/sbin",
|
|
|
|
command => "apache2ctl graceful",
|
|
|
|
}
|
|
|
|
|
|
|
|
# Install Gerrit itself.
|
|
|
|
|
2012-07-06 12:48:38 -05:00
|
|
|
# The Gerrit WAR is specified as a url like 'http://tarballs.openstack.org/ci/gerrit-2.2.2-363-gd0a67ce.war'
|
2012-04-10 01:16:47 +00:00
|
|
|
# Set $basewar so that we can work with filenames like gerrit-2.2.2-363-gd0a67ce.war'.
|
|
|
|
|
|
|
|
if $war =~ /.*\/(.*)/ {
|
|
|
|
$basewar = $1
|
|
|
|
} else {
|
|
|
|
$basewar = $war
|
|
|
|
}
|
|
|
|
|
|
|
|
# This directory is used to download and cache gerrit war files.
|
|
|
|
# That way the download and install steps are kept separate.
|
|
|
|
file { "/home/gerrit2/gerrit-wars":
|
|
|
|
ensure => "directory",
|
|
|
|
require => User["gerrit2"]
|
|
|
|
}
|
|
|
|
|
|
|
|
# If we don't already have the specified WAR, download it.
|
|
|
|
exec { "download:$war":
|
|
|
|
command => "/usr/bin/wget $war -O /home/gerrit2/gerrit-wars/$basewar",
|
|
|
|
creates => "/home/gerrit2/gerrit-wars/$basewar",
|
|
|
|
require => File["/home/gerrit2/gerrit-wars"],
|
|
|
|
}
|
|
|
|
|
|
|
|
# If gerrit.war isn't the same as $basewar, install it.
|
|
|
|
file { "/home/gerrit2/review_site/bin/gerrit.war":
|
|
|
|
source => "file:///home/gerrit2/gerrit-wars/$basewar",
|
|
|
|
require => Exec["download:$war"],
|
|
|
|
ensure => present,
|
|
|
|
replace => 'true',
|
2012-06-06 10:06:46 -07:00
|
|
|
# user, group, and mode have to be set this way to avoid retriggering gerrit-init on every run
|
2012-04-10 01:16:47 +00:00
|
|
|
# because gerrit init sets them this way
|
|
|
|
owner => 'gerrit2',
|
2012-06-06 10:06:46 -07:00
|
|
|
group => 'gerrit2',
|
2012-04-10 01:16:47 +00:00
|
|
|
mode => 644,
|
|
|
|
}
|
|
|
|
|
|
|
|
# If gerrit.war was just installed, run the Gerrit "init" command.
|
|
|
|
# Stop is included here because it may not be running or the init
|
|
|
|
# script may not exist, and in those cases, we don't care if it fails.
|
|
|
|
# Running the init script as the gerrit2 user _does_ work.
|
|
|
|
exec { "gerrit-init":
|
|
|
|
user => 'gerrit2',
|
|
|
|
command => "/etc/init.d/gerrit stop; /usr/bin/java -jar /home/gerrit2/review_site/bin/gerrit.war init -d /home/gerrit2/review_site --batch --no-auto-start",
|
|
|
|
subscribe => File["/home/gerrit2/review_site/bin/gerrit.war"],
|
|
|
|
refreshonly => true,
|
|
|
|
require => [Package["openjdk-6-jre-headless"],
|
|
|
|
User["gerrit2"],
|
|
|
|
Exec["gerrit-mysql"],
|
|
|
|
File["/etc/mysql/my.cnf"], # For innodb default tables
|
|
|
|
File["/home/gerrit2/review_site/etc/gerrit.config"],
|
|
|
|
File["/home/gerrit2/review_site/etc/secure.config"]],
|
|
|
|
notify => Exec["gerrit-start"],
|
|
|
|
}
|
|
|
|
|
|
|
|
# Symlink the init script.
|
|
|
|
file { "/etc/init.d/gerrit":
|
|
|
|
ensure => link,
|
|
|
|
target => '/home/gerrit2/review_site/bin/gerrit.sh',
|
|
|
|
require => Exec['gerrit-init'],
|
|
|
|
}
|
|
|
|
|
|
|
|
# The init script requires the path to gerrit to be set.
|
|
|
|
file { "/etc/default/gerritcodereview":
|
|
|
|
source => 'puppet:///modules/gerrit/gerritcodereview.default',
|
|
|
|
ensure => present,
|
|
|
|
replace => 'true',
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
mode => 444,
|
|
|
|
}
|
|
|
|
|
|
|
|
# Make sure the init script starts on boot.
|
|
|
|
file { ['/etc/rc0.d/K10gerrit',
|
|
|
|
'/etc/rc1.d/K10gerrit',
|
|
|
|
'/etc/rc2.d/S90gerrit',
|
|
|
|
'/etc/rc3.d/S90gerrit',
|
|
|
|
'/etc/rc4.d/S90gerrit',
|
|
|
|
'/etc/rc5.d/S90gerrit',
|
|
|
|
'/etc/rc6.d/K10gerrit']:
|
|
|
|
ensure => link,
|
|
|
|
target => '/etc/init.d/gerrit',
|
|
|
|
require => File['/etc/init.d/gerrit'],
|
|
|
|
}
|
|
|
|
|
|
|
|
exec { "gerrit-start":
|
|
|
|
command => '/etc/init.d/gerrit start',
|
|
|
|
require => File['/etc/init.d/gerrit'],
|
|
|
|
refreshonly => true,
|
|
|
|
}
|
2012-05-01 17:11:48 -04:00
|
|
|
|
|
|
|
file { '/usr/local/gerrit':
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
mode => 755,
|
|
|
|
ensure => 'directory',
|
|
|
|
}
|
|
|
|
|
|
|
|
file { '/usr/local/gerrit/scripts':
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
mode => 755,
|
|
|
|
ensure => 'directory',
|
|
|
|
recurse => true,
|
|
|
|
require => File['/usr/local/gerrit'],
|
|
|
|
source => [
|
|
|
|
"puppet:///modules/gerrit/scripts",
|
|
|
|
],
|
|
|
|
}
|
2011-08-05 23:00:46 +00:00
|
|
|
}
|