class openstack_project::jenkins ( $jenkins_jobs_password, $manage_jenkins_jobs = true, $ssl_cert_file_contents = '', $ssl_key_file_contents = '', $ssl_chain_file_contents = '', $sysadmins = [], ) { class { 'openstack_project::server': iptables_public_tcp_ports => [80, 443, 4155], sysadmins => $sysadmins, } $vhost_name = 'jenkins.openstack.org' class { '::jenkins::master': vhost_name => $vhost_name, serveradmin => 'webmaster@openstack.org', logo => 'openstack.png', ssl_cert_file => '/etc/ssl/certs/jenkins.openstack.org.pem', ssl_key_file => '/etc/ssl/private/jenkins.openstack.org.key', ssl_chain_file => '/etc/ssl/certs/intermediate.pem', ssl_cert_file_contents => $ssl_cert_file_contents, ssl_key_file_contents => $ssl_key_file_contents, ssl_chain_file_contents => $ssl_chain_file_contents, } if $manage_jenkins_jobs == true { class { '::jenkins::job_builder': url => "https://${vhost_name}/", username => 'gerrig', # This is not a typo, well it isn't anymore. password => $jenkins_jobs_password, } file { '/etc/jenkins_jobs/config': ensure => directory, owner => 'root', group => 'root', mode => '0755', recurse => true, source => 'puppet:///modules/openstack_project/jenkins_job_builder/config', notify => Exec['jenkins_jobs_update'], } file { '/etc/default/jenkins': ensure => present, source => 'puppet:///modules/openstack_project/jenkins/jenkins.default', } } }