91 lines
2.6 KiB
ObjectPascal
91 lines
2.6 KiB
ObjectPascal
![]() |
# == Definition: openstacklib::db::mysql
|
||
|
#
|
||
|
# This resource configures a mysql database for an OpenStack service
|
||
|
#
|
||
|
# == Parameters:
|
||
|
#
|
||
|
# [*password_hash*]
|
||
|
# Password hash to use for the database user for this service;
|
||
|
# string; required
|
||
|
#
|
||
|
# [*dbname*]
|
||
|
# The name of the database
|
||
|
# string; optional; default to the $title of the resource, i.e. 'nova'
|
||
|
#
|
||
|
# [*user*]
|
||
|
# The database user to create;
|
||
|
# string; optional; default to the $title of the resource, i.e. 'nova'
|
||
|
#
|
||
|
# [*host*]
|
||
|
# The IP address or hostname of the user in mysql_grant;
|
||
|
# string; optional; default to '127.0.0.1'
|
||
|
#
|
||
|
# [*charset*]
|
||
|
# The charset to use for the database;
|
||
|
# string; optional; default to 'utf8'
|
||
|
#
|
||
|
# [*collate*]
|
||
|
# The collate to use for the database;
|
||
|
# string; optional; default to 'utf8_unicode_ci'
|
||
|
#
|
||
|
# [*allowed_hosts*]
|
||
|
# Additional hosts that are allowed to access this database;
|
||
|
# array or string; optional; default to undef
|
||
|
#
|
||
|
# [*privileges*]
|
||
|
# Privileges given to the database user;
|
||
|
# string or array of strings; optional; default to 'ALL'
|
||
|
|
||
|
define openstacklib::db::mysql (
|
||
|
$password_hash,
|
||
|
$dbname = $title,
|
||
|
$user = $title,
|
||
|
$host = '127.0.0.1',
|
||
|
$charset = 'utf8',
|
||
|
$collate = 'utf8_unicode_ci',
|
||
|
$allowed_hosts = undef,
|
||
|
$privileges = 'ALL',
|
||
|
) {
|
||
|
|
||
|
include ::mysql::client
|
||
|
|
||
|
mysql_database { $dbname:
|
||
|
ensure => present,
|
||
|
charset => $charset,
|
||
|
collate => $collate,
|
||
|
require => [ Class['mysql::server'], Class['mysql::client'] ],
|
||
|
}
|
||
|
|
||
|
mysql_user { "${user}@${host}":
|
||
|
ensure => present,
|
||
|
password_hash => $password_hash,
|
||
|
require => Class['mysql::server'],
|
||
|
}
|
||
|
|
||
|
mysql_grant { "${user}@${host}/${dbname}.*":
|
||
|
privileges => $privileges,
|
||
|
user => "${user}@${host}",
|
||
|
table => "${dbname}.*",
|
||
|
require => [Mysql_database[$dbname], Mysql_user["${user}@${host}"], Class['mysql::server'] ],
|
||
|
}
|
||
|
|
||
|
# 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)
|
||
|
$unique_real_allowed_hosts = prefix($real_allowed_hosts, "${dbname}_")
|
||
|
} elsif is_string($allowed_hosts) and ($allowed_hosts != $host) {
|
||
|
$real_allowed_hosts = $allowed_hosts
|
||
|
$unique_real_allowed_hosts = "${dbname}_${real_allowed_hosts}"
|
||
|
}
|
||
|
|
||
|
if $real_allowed_hosts {
|
||
|
openstacklib::db::mysql::host_access { $unique_real_allowed_hosts:
|
||
|
user => $user,
|
||
|
password_hash => $password_hash,
|
||
|
database => $dbname,
|
||
|
privileges => $privileges,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|