140 lines
4.0 KiB
Puppet
140 lines
4.0 KiB
Puppet
# == Class: openstack_project::jenkins
|
|
#
|
|
class openstack_project::jenkins (
|
|
$vhost_name = $::fqdn,
|
|
$jenkins_jobs_password = '',
|
|
$jenkins_jobs_username = 'gerrig', # This is not a typo, well it isn't anymore.
|
|
$jenkins_git_url = 'https://git.openstack.org/openstack-infra/jenkins-job-builder',
|
|
$jenkins_git_revision = 'master',
|
|
$manage_jenkins_jobs = true,
|
|
$ssl_cert_file = '',
|
|
$ssl_key_file = '',
|
|
$ssl_chain_file = '/etc/ssl/certs/intermediate.pem',
|
|
$ssl_cert_file_contents = '',
|
|
$ssl_key_file_contents = '',
|
|
$ssl_chain_file_contents = '',
|
|
$jenkins_ssh_public_key = $openstack_project::jenkins_ssh_key,
|
|
$jenkins_ssh_private_key = '',
|
|
$zmq_event_receivers = [],
|
|
$sysadmins = [],
|
|
$project_config_repo = '',
|
|
$serveradmin = 'webmaster@openstack.org',
|
|
$logo = 'openstack.png',
|
|
) inherits openstack_project {
|
|
include openstack_project
|
|
|
|
$iptables_rule = regsubst ($zmq_event_receivers, '^(.*)$', '-m state --state NEW -m tcp -p tcp --dport 8888 -s \1 -j ACCEPT')
|
|
class { 'openstack_project::server':
|
|
iptables_public_tcp_ports => [80, 443],
|
|
iptables_rules6 => $iptables_rule,
|
|
iptables_rules4 => $iptables_rule,
|
|
sysadmins => $sysadmins,
|
|
}
|
|
|
|
# Set defaults here because they evaluate variables which you cannot
|
|
# do in the class parameter list.
|
|
if $ssl_cert_file == '' {
|
|
$prv_ssl_cert_file = "/etc/ssl/certs/${vhost_name}.pem"
|
|
}
|
|
else {
|
|
$prv_ssl_cert_file = $ssl_cert_file
|
|
}
|
|
if $ssl_key_file == '' {
|
|
$prv_ssl_key_file = "/etc/ssl/private/${vhost_name}.key"
|
|
}
|
|
else {
|
|
$prv_ssl_key_file = $ssl_key_file
|
|
}
|
|
|
|
class { '::jenkins::master':
|
|
vhost_name => $vhost_name,
|
|
serveradmin => $serveradmin,
|
|
logo => $logo,
|
|
ssl_cert_file => $prv_ssl_cert_file,
|
|
ssl_key_file => $prv_ssl_key_file,
|
|
ssl_chain_file => $ssl_chain_file,
|
|
ssl_cert_file_contents => $ssl_cert_file_contents,
|
|
ssl_key_file_contents => $ssl_key_file_contents,
|
|
ssl_chain_file_contents => $ssl_chain_file_contents,
|
|
jenkins_ssh_private_key => $jenkins_ssh_private_key,
|
|
jenkins_ssh_public_key => $jenkins_ssh_public_key,
|
|
}
|
|
|
|
jenkins::plugin { 'build-timeout':
|
|
version => '1.14',
|
|
}
|
|
jenkins::plugin { 'copyartifact':
|
|
version => '1.22',
|
|
}
|
|
jenkins::plugin { 'dashboard-view':
|
|
version => '2.3',
|
|
}
|
|
jenkins::plugin { 'gearman-plugin':
|
|
version => '0.1.1',
|
|
}
|
|
jenkins::plugin { 'git':
|
|
version => '1.1.23',
|
|
}
|
|
jenkins::plugin { 'greenballs':
|
|
version => '1.12',
|
|
}
|
|
jenkins::plugin { 'extended-read-permission':
|
|
version => '1.0',
|
|
}
|
|
jenkins::plugin { 'zmq-event-publisher':
|
|
version => '0.0.3',
|
|
}
|
|
# TODO(jeblair): release
|
|
# jenkins::plugin { 'scp':
|
|
# version => '1.9',
|
|
# }
|
|
jenkins::plugin { 'jobConfigHistory':
|
|
version => '1.13',
|
|
}
|
|
jenkins::plugin { 'monitoring':
|
|
version => '1.40.0',
|
|
}
|
|
jenkins::plugin { 'nodelabelparameter':
|
|
version => '1.2.1',
|
|
}
|
|
jenkins::plugin { 'notification':
|
|
version => '1.4',
|
|
}
|
|
jenkins::plugin { 'openid':
|
|
version => '1.5',
|
|
}
|
|
jenkins::plugin { 'postbuildscript':
|
|
version => '0.16',
|
|
}
|
|
jenkins::plugin { 'publish-over-ftp':
|
|
version => '1.7',
|
|
}
|
|
jenkins::plugin { 'simple-theme-plugin':
|
|
version => '0.2',
|
|
}
|
|
jenkins::plugin { 'timestamper':
|
|
version => '1.3.1',
|
|
}
|
|
jenkins::plugin { 'token-macro':
|
|
version => '1.5.1',
|
|
}
|
|
|
|
if $manage_jenkins_jobs == true {
|
|
class { 'project_config':
|
|
url => $project_config_repo,
|
|
}
|
|
|
|
class { '::jenkins::job_builder':
|
|
jenkins_jobs_update_timeout => 1200,
|
|
url => "https://${vhost_name}/",
|
|
username => $jenkins_jobs_username,
|
|
password => $jenkins_jobs_password,
|
|
git_revision => $jenkins_git_revision,
|
|
git_url => $jenkins_git_url,
|
|
config_dir =>
|
|
$::project_config::jenkins_job_builder_config_dir,
|
|
require => $::project_config::config_dir,
|
|
}
|
|
}
|
|
}
|