8b2319e210
This adds defined anchor points for external modules to hook into the software install, config and service dependency chain. This allows external modules to manage software installation (virtualenv, containers, etc) and service management (pacemaker) without needing rely on resources that may change or be renamed. Change-Id: Idb1332dd498bb3065720f2ccaf68e6b0e9fa80c3
44 lines
979 B
Puppet
44 lines
979 B
Puppet
# == Class: neutron::policy
|
|
#
|
|
# Configure the neutron policies
|
|
#
|
|
# === Parameters
|
|
#
|
|
# [*policies*]
|
|
# (optional) Set of policies to configure for neutron
|
|
# Example :
|
|
# {
|
|
# 'neutron-context_is_admin' => {
|
|
# 'key' => 'context_is_admin',
|
|
# 'value' => 'true'
|
|
# },
|
|
# 'neutron-default' => {
|
|
# 'key' => 'default',
|
|
# 'value' => 'rule:admin_or_owner'
|
|
# }
|
|
# }
|
|
# Defaults to empty hash.
|
|
#
|
|
# [*policy_path*]
|
|
# (optional) Path to the neutron policy.json file
|
|
# Defaults to /etc/neutron/policy.json
|
|
#
|
|
class neutron::policy (
|
|
$policies = {},
|
|
$policy_path = '/etc/neutron/policy.json',
|
|
) {
|
|
|
|
validate_hash($policies)
|
|
|
|
Openstacklib::Policy::Base {
|
|
file_path => $policy_path,
|
|
require => Anchor['neutron::config::begin'],
|
|
notify => Anchor['neutron::config::end'],
|
|
}
|
|
|
|
create_resources('openstacklib::policy::base', $policies)
|
|
|
|
oslo::policy { 'neutron_config': policy_file => $policy_path }
|
|
|
|
}
|