Andrey Pavlov 70a1c4af19 use specific tag version of refstack for installation.
It's not convenient for development to deploy latest master.
For example we need to commit features in several commits
and we can break something in the middle.
Also we want to implement something by several developers
and in this case we can have invalid code in the middle.

So we need to deploy refstack website with specific
and released (fully implemented and tested) version.
When next version will be released then we up version here.

Change-Id: Ie4459d1d5d3415670237aaeabfd56c8b62da275d
2016-02-16 11:26:08 +03:00

103 lines
2.8 KiB
Puppet

# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
# == Class: refstack::api
#
# This class installs the RefStack API so that it may be run via wsgi.
#
class refstack::api () {
require ::refstack::params
require ::refstack::user
# Import parameters into local scope.
$src_api_root = $::refstack::params::src_api_root
$user = $::refstack::params::user
$group = $::refstack::params::group
# Ensure Git is present
if !defined(Package['git']) {
package { 'git':
ensure => present
}
}
# Ensure python-dev is present
if !defined(Package['python-dev']) {
package { 'python-dev':
ensure => present
}
}
# Ensure OpenSSL is present
if !defined(Package['libssl-dev']) {
package { 'libssl-dev':
ensure => present
}
}
# Create the RefStack configuration directory.
file { '/etc/refstack':
ensure => directory,
owner => $user,
group => $group,
mode => '0755',
}
# Configure the RefStack API.
file { '/etc/refstack/refstack.conf':
ensure => present,
owner => $user,
group => $group,
mode => '0644',
content => template('refstack/refstack.conf.erb'),
require => [
File['/etc/refstack']
]
}
# Download the latest RefStack Source.
vcsrepo { $src_api_root:
ensure => present,
provider => git,
revision => $refstack::params::release_revision,
source => 'https://git.openstack.org/openstack/refstack/',
require => Package['git']
}
# Install RefStack using pip.
exec { 'install-refstack':
command => "pip install ${src_api_root}",
path => '/usr/local/bin:/usr/bin:/bin',
refreshonly => true,
require => Vcsrepo[$src_api_root],
subscribe => Vcsrepo[$src_api_root],
notify => Service['httpd'],
}
# Migrate the database.
exec { 'migrate-refstack-db':
command => 'refstack-manage --config-file /etc/refstack/refstack.conf upgrade --revision head',
path => '/usr/local/bin:/usr/bin:/bin',
refreshonly => true,
subscribe => [
Exec['install-refstack'],
File['/etc/refstack/refstack.conf'],
],
require => [
Exec['install-refstack'],
File['/etc/refstack/refstack.conf'],
],
}
}