2012-03-29 14:39:59 -07:00
|
|
|
#
|
|
|
|
# implements mysql backend for keystone
|
|
|
|
#
|
2012-04-06 15:48:05 -07:00
|
|
|
# This class can be used to create tables, users and grant
|
|
|
|
# privelege for a mysql keystone database.
|
|
|
|
#
|
2012-10-31 12:33:09 -07:00
|
|
|
# == parameters
|
2012-04-06 15:48:05 -07:00
|
|
|
#
|
|
|
|
# [password] Password that will be used for the keystone db user.
|
|
|
|
# Optional. Defaults to: 'keystone_default_password'
|
|
|
|
#
|
|
|
|
# [dbname] Name of keystone database. Optional. Defaults to keystone.
|
|
|
|
#
|
2013-09-10 22:54:49 -07:00
|
|
|
# [user] Name of keystone user. Optional. Defaults to keystone.
|
2012-04-06 15:48:05 -07:00
|
|
|
#
|
|
|
|
# [host] Host where user should be allowed all priveleges for database.
|
|
|
|
# Optional. Defaults to 127.0.0.1.
|
|
|
|
#
|
2012-04-17 17:16:48 +02:00
|
|
|
# [allowed_hosts] Hosts allowed to use the database
|
2012-04-06 15:48:05 -07:00
|
|
|
#
|
2014-02-26 22:31:47 +11:00
|
|
|
# [*mysql_module*]
|
|
|
|
# (optional) The mysql puppet module version to use
|
|
|
|
# Tested versions include 0.9 and 2.2
|
|
|
|
# Default to '0.9'
|
|
|
|
#
|
2012-04-06 15:48:05 -07:00
|
|
|
# == Dependencies
|
|
|
|
# Class['mysql::server']
|
|
|
|
#
|
|
|
|
# == Examples
|
|
|
|
# == Authors
|
|
|
|
#
|
|
|
|
# Dan Bode dan@puppetlabs.com
|
|
|
|
#
|
|
|
|
# == Copyright
|
|
|
|
#
|
|
|
|
# Copyright 2012 Puppetlabs Inc, unless otherwise noted.
|
|
|
|
#
|
2012-04-21 21:52:11 -07:00
|
|
|
class keystone::db::mysql(
|
2012-10-14 11:51:45 -07:00
|
|
|
$password,
|
2012-03-29 14:39:59 -07:00
|
|
|
$dbname = 'keystone',
|
2013-09-10 22:54:49 -07:00
|
|
|
$user = 'keystone',
|
2012-03-29 14:39:59 -07:00
|
|
|
$host = '127.0.0.1',
|
2012-05-16 09:31:37 -05:00
|
|
|
$charset = 'latin1',
|
2014-02-26 22:31:47 +11:00
|
|
|
$collate = 'latin1_swedish_ci',
|
|
|
|
$mysql_module = '0.9',
|
2012-03-29 14:39:59 -07:00
|
|
|
$allowed_hosts = undef
|
|
|
|
) {
|
|
|
|
|
2013-07-01 17:03:01 -04:00
|
|
|
Class['keystone::db::mysql'] -> Exec<| title == 'keystone-manage db_sync' |>
|
2012-04-21 21:52:11 -07:00
|
|
|
Class['keystone::db::mysql'] -> Service<| title == 'keystone' |>
|
2012-10-14 11:52:08 -07:00
|
|
|
Mysql::Db[$dbname] ~> Exec<| title == 'keystone-manage db_sync' |>
|
2012-04-09 23:43:27 -07:00
|
|
|
|
2014-02-26 22:31:47 +11:00
|
|
|
if ($mysql_module >= 2.2) {
|
|
|
|
mysql::db { $dbname:
|
|
|
|
user => $user,
|
|
|
|
password => $password,
|
|
|
|
host => $host,
|
|
|
|
charset => $charset,
|
|
|
|
collate => $collate,
|
|
|
|
require => Service['mysql'],
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
require mysql::python
|
2012-03-29 14:39:59 -07:00
|
|
|
|
2014-02-26 22:31:47 +11:00
|
|
|
mysql::db { $dbname:
|
|
|
|
user => $user,
|
|
|
|
password => $password,
|
|
|
|
host => $host,
|
|
|
|
charset => $charset,
|
|
|
|
require => Class['mysql::config'],
|
|
|
|
}
|
2012-03-29 14:39:59 -07:00
|
|
|
}
|
|
|
|
|
2013-07-30 18:03:22 +08:00
|
|
|
# Check allowed_hosts to avoid duplicate resource declarations
|
|
|
|
if is_array($allowed_hosts) and delete($allowed_hosts,$host) != [] {
|
|
|
|
$real_allowed_hosts = delete($allowed_hosts,$host)
|
|
|
|
} elsif is_string($allowed_hosts) and ($allowed_hosts != $host) {
|
|
|
|
$real_allowed_hosts = $allowed_hosts
|
|
|
|
}
|
|
|
|
|
|
|
|
if $real_allowed_hosts {
|
|
|
|
keystone::db::mysql::host_access { $real_allowed_hosts:
|
2014-02-26 22:31:47 +11:00
|
|
|
user => $user,
|
|
|
|
password => $password,
|
|
|
|
database => $dbname,
|
|
|
|
mysql_module => $mysql_module,
|
2012-04-17 17:16:48 +02:00
|
|
|
}
|
2013-05-08 14:13:17 -07:00
|
|
|
|
2014-03-26 17:46:01 -07:00
|
|
|
Keystone::Db::Mysql::Host_access[$real_allowed_hosts] -> Exec<| title == 'keystone-manage db_sync' |>
|
2013-05-08 14:13:17 -07:00
|
|
|
|
2012-04-05 23:53:18 -07:00
|
|
|
}
|
|
|
|
|
2012-03-29 14:39:59 -07:00
|
|
|
}
|