Add ability to skip mysql user/grants
Previously if you wanted to use the openstack::db::mysql for to create a database and use the same user for multiple databases, the catalog would fail due to a duplicate mysql_user definition. This change adds the ability to disable the user creation as well as the grant if the user does not need it. Change-Id: Id04a622cc900254fe60bc257a9e42d16c676bf40 Related-Bug: 1649341
This commit is contained in:
@@ -35,7 +35,17 @@
|
|||||||
# [*privileges*]
|
# [*privileges*]
|
||||||
# Privileges given to the database user;
|
# Privileges given to the database user;
|
||||||
# string or array of strings; optional; default to 'ALL'
|
# string or array of strings; optional; default to 'ALL'
|
||||||
|
#
|
||||||
|
# [*create_user*]
|
||||||
|
# Flag to allow for the skipping of the user as part of the database setup.
|
||||||
|
# Set to false to skip the user creation.
|
||||||
|
# Defaults to true.
|
||||||
|
#
|
||||||
|
# [*create_grant*]
|
||||||
|
# Flag to allow for the skipping of the user grants as part of the database
|
||||||
|
# setup. Set to false to skip the user creation.
|
||||||
|
# Defaults to true.
|
||||||
|
#
|
||||||
define openstacklib::db::mysql (
|
define openstacklib::db::mysql (
|
||||||
$password_hash,
|
$password_hash,
|
||||||
$dbname = $title,
|
$dbname = $title,
|
||||||
@@ -45,6 +55,8 @@ define openstacklib::db::mysql (
|
|||||||
$collate = 'utf8_general_ci',
|
$collate = 'utf8_general_ci',
|
||||||
$allowed_hosts = [],
|
$allowed_hosts = [],
|
||||||
$privileges = 'ALL',
|
$privileges = 'ALL',
|
||||||
|
$create_user = true,
|
||||||
|
$create_grant = true,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include ::mysql::server
|
include ::mysql::server
|
||||||
@@ -57,13 +69,17 @@ define openstacklib::db::mysql (
|
|||||||
require => [ Class['mysql::server'], Class['mysql::client'] ],
|
require => [ Class['mysql::server'], Class['mysql::client'] ],
|
||||||
}
|
}
|
||||||
|
|
||||||
$allowed_hosts_list = unique(concat(any2array($allowed_hosts), [$host]))
|
if $create_user or $create_grant {
|
||||||
$real_allowed_hosts = prefix($allowed_hosts_list, "${dbname}_")
|
$allowed_hosts_list = unique(concat(any2array($allowed_hosts), [$host]))
|
||||||
|
$real_allowed_hosts = prefix($allowed_hosts_list, "${dbname}_")
|
||||||
|
|
||||||
openstacklib::db::mysql::host_access { $real_allowed_hosts:
|
openstacklib::db::mysql::host_access { $real_allowed_hosts:
|
||||||
user => $user,
|
user => $user,
|
||||||
password_hash => $password_hash,
|
password_hash => $password_hash,
|
||||||
database => $dbname,
|
database => $dbname,
|
||||||
privileges => $privileges,
|
privileges => $privileges,
|
||||||
|
create_user => $create_user,
|
||||||
|
create_grant => $create_grant,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,25 +17,41 @@
|
|||||||
# [*privileges*]
|
# [*privileges*]
|
||||||
# the privileges to grant to this user
|
# the privileges to grant to this user
|
||||||
#
|
#
|
||||||
|
# [*create_user*]
|
||||||
|
# Flag to allow for the skipping of the user as part of the database setup.
|
||||||
|
# Set to false to skip the user creation.
|
||||||
|
# Defaults to true.
|
||||||
|
#
|
||||||
|
# [*create_grant*]
|
||||||
|
# Flag to allow for the skipping of the user grants as part of the database
|
||||||
|
# setup. Set to false to skip the user creation.
|
||||||
|
# Defaults to true.
|
||||||
|
#
|
||||||
define openstacklib::db::mysql::host_access (
|
define openstacklib::db::mysql::host_access (
|
||||||
$user,
|
$user,
|
||||||
$password_hash,
|
$password_hash,
|
||||||
$database,
|
$database,
|
||||||
$privileges,
|
$privileges,
|
||||||
|
$create_user = true,
|
||||||
|
$create_grant = true,
|
||||||
) {
|
) {
|
||||||
validate_re($title, '_', 'Title must be $dbname_$host')
|
validate_re($title, '_', 'Title must be $dbname_$host')
|
||||||
|
|
||||||
$host = inline_template('<%= @title.split("_").last.downcase %>')
|
$host = inline_template('<%= @title.split("_").last.downcase %>')
|
||||||
|
|
||||||
mysql_user { "${user}@${host}":
|
if $create_user {
|
||||||
password_hash => $password_hash,
|
mysql_user { "${user}@${host}":
|
||||||
require => Mysql_database[$database],
|
password_hash => $password_hash,
|
||||||
|
require => Mysql_database[$database],
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mysql_grant { "${user}@${host}/${database}.*":
|
if $create_grant {
|
||||||
privileges => $privileges,
|
mysql_grant { "${user}@${host}/${database}.*":
|
||||||
table => "${database}.*",
|
privileges => $privileges,
|
||||||
require => Mysql_user["${user}@${host}"],
|
table => "${database}.*",
|
||||||
user => "${user}@${host}",
|
require => Mysql_user["${user}@${host}"],
|
||||||
|
user => "${user}@${host}",
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- Add the ability to skip the mysql user and/or grant creation as part of the
|
||||||
|
openstack::db::mysql resource.
|
||||||
|
fixes:
|
||||||
|
- openstack::db::mysql could not be used to create multiple databases
|
||||||
|
with the same user/password for access due to a duplicate mysql_user
|
||||||
|
resource declaration. Now the user and/or grant creation process can be
|
||||||
|
skipped if they already exist.
|
@@ -30,6 +30,60 @@ describe 'openstacklib::db::mysql::host_access' do
|
|||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with skipping user creation' do
|
||||||
|
let (:title) { 'nova_10.0.0.1' }
|
||||||
|
let :params do
|
||||||
|
{ :user => 'foobar',
|
||||||
|
:password_hash => 'AA1420F182E88B9E5F874F6FBE7459291E8F4601',
|
||||||
|
:database => 'nova',
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:create_user => false,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to_not contain_mysql_user("#{params[:user]}@10.0.0.1") }
|
||||||
|
|
||||||
|
it { is_expected.to contain_mysql_grant("#{params[:user]}@10.0.0.1/#{params[:database]}.*").with(
|
||||||
|
:user => "#{params[:user]}@10.0.0.1",
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:table => "#{params[:database]}.*"
|
||||||
|
)}
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with skipping grant creation' do
|
||||||
|
let (:title) { 'nova_10.0.0.1' }
|
||||||
|
let :params do
|
||||||
|
{ :user => 'foobar',
|
||||||
|
:password_hash => 'AA1420F182E88B9E5F874F6FBE7459291E8F4601',
|
||||||
|
:database => 'nova',
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:create_grant => false,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to contain_mysql_user("#{params[:user]}@10.0.0.1").with(
|
||||||
|
:password_hash => params[:password_hash]
|
||||||
|
)}
|
||||||
|
|
||||||
|
it { is_expected.to_not contain_mysql_grant("#{params[:user]}@10.0.0.1/#{params[:database]}.*") }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with skipping user and grant creation' do
|
||||||
|
let (:title) { 'nova_10.0.0.1' }
|
||||||
|
let :params do
|
||||||
|
{ :user => 'foobar',
|
||||||
|
:password_hash => 'AA1420F182E88B9E5F874F6FBE7459291E8F4601',
|
||||||
|
:database => 'nova',
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:create_user => false,
|
||||||
|
:create_grant => false,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to_not contain_mysql_user("#{params[:user]}@10.0.0.1") }
|
||||||
|
|
||||||
|
it { is_expected.to_not contain_mysql_grant("#{params[:user]}@10.0.0.1/#{params[:database]}.*") }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
on_supported_os({
|
on_supported_os({
|
||||||
|
@@ -40,9 +40,11 @@ describe 'openstacklib::db::mysql' do
|
|||||||
:collate => 'utf8_general_ci'
|
:collate => 'utf8_general_ci'
|
||||||
)}
|
)}
|
||||||
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{params[:dbname]}_127.0.0.1").with(
|
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{params[:dbname]}_127.0.0.1").with(
|
||||||
:user => title,
|
:user => title,
|
||||||
:database => params[:dbname],
|
:database => params[:dbname],
|
||||||
:privileges => 'ALL'
|
:privileges => 'ALL',
|
||||||
|
:create_user => true,
|
||||||
|
:create_grant => true,
|
||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -56,9 +58,11 @@ describe 'openstacklib::db::mysql' do
|
|||||||
:collate => 'utf8_general_ci'
|
:collate => 'utf8_general_ci'
|
||||||
)}
|
)}
|
||||||
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{title}_127.0.0.1").with(
|
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{title}_127.0.0.1").with(
|
||||||
:user => params[:user],
|
:user => params[:user],
|
||||||
:database => title,
|
:database => title,
|
||||||
:privileges => 'ALL',
|
:privileges => 'ALL',
|
||||||
|
:create_user => true,
|
||||||
|
:create_grant => true,
|
||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -143,6 +147,55 @@ describe 'openstacklib::db::mysql' do
|
|||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with skipping user creation' do
|
||||||
|
let :params do
|
||||||
|
{ :create_user => false }.merge(required_params)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to contain_mysql_database(title).with(
|
||||||
|
:charset => 'utf8',
|
||||||
|
:collate => 'utf8_general_ci'
|
||||||
|
)}
|
||||||
|
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{title}_127.0.0.1").with(
|
||||||
|
:user => title,
|
||||||
|
:database => title,
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:create_user => false,
|
||||||
|
:create_grant => true,
|
||||||
|
)}
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with skipping grant creation' do
|
||||||
|
let :params do
|
||||||
|
{ :create_grant => false }.merge(required_params)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to contain_mysql_database(title).with(
|
||||||
|
:charset => 'utf8',
|
||||||
|
:collate => 'utf8_general_ci'
|
||||||
|
)}
|
||||||
|
it { is_expected.to contain_openstacklib__db__mysql__host_access("#{title}_127.0.0.1").with(
|
||||||
|
:user => title,
|
||||||
|
:database => title,
|
||||||
|
:privileges => 'ALL',
|
||||||
|
:create_user => true,
|
||||||
|
:create_grant => false,
|
||||||
|
)}
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with skipping user and grant creation' do
|
||||||
|
let :params do
|
||||||
|
{ :create_user => false,
|
||||||
|
:create_grant => false }.merge(required_params)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { is_expected.to contain_mysql_database(title).with(
|
||||||
|
:charset => 'utf8',
|
||||||
|
:collate => 'utf8_general_ci'
|
||||||
|
)}
|
||||||
|
it { is_expected.to_not contain_openstacklib__db__mysql__host_access("#{title}_127.0.0.1") }
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
on_supported_os({
|
on_supported_os({
|
||||||
|
Reference in New Issue
Block a user