cookbook-openstack-network/recipes/common.rb

392 lines
12 KiB
Ruby

#
# Cookbook Name:: openstack-network
# Recipe:: common
#
# Copyright 2013, AT&T
# Copyright 2013, SUSE Linux GmbH
# Copyright 2013, IBM Corp.
#
# 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.
#
['quantum','neutron'].include?(node["openstack"]["compute"]["network"]["service_type"]) || return
require "uri"
class ::Chef::Recipe
include ::Openstack
end
platform_options = node["openstack"]["network"]["platform"]
driver_name = node["openstack"]["network"]["interface_driver"].split('.').last.downcase
main_plugin = node["openstack"]["network"]["interface_driver_map"][driver_name]
core_plugin = node["openstack"]["network"]["core_plugin"]
if node["openstack"]["network"]["syslog"]["use"]
include_recipe "openstack-common::logging"
end
platform_options["nova_network_packages"].each do |pkg|
package pkg do
action :purge
end
end
platform_options["neutron_packages"].each do |pkg|
package pkg do
action :install
end
end
db_type = node['openstack']['db']['network']['db_type']
platform_options["#{db_type}_python_packages"].each do |pkg|
package pkg do
action :install
end
end
directory "/etc/neutron/plugins" do
recursive true
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00700
action :create
end
directory "/var/cache/neutron" do
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00700
action :create
end
directory ::File.dirname node["openstack"]["network"]["api"]["auth"]["cache_dir"] do
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00700
only_if { node["openstack"]["auth"]["strategy"] == "pki" }
end
template "/etc/neutron/rootwrap.conf" do
source "rootwrap.conf.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
end
template "/etc/neutron/policy.json" do
source "policy.json.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
notifies :restart, "service[neutron-server]", :delayed
end
if node["openstack"]["network"]["mq"]["service_type"] == "rabbitmq"
rabbit_server_role = node["openstack"]["network"]["rabbit_server_chef_role"]
if node["openstack"]["network"]["rabbit"]["ha"]
rabbit_hosts = rabbit_servers
end
rabbit_pass = user_password node["openstack"]["network"]["rabbit"]["username"]
end
identity_endpoint = endpoint "identity-api"
identity_admin_endpoint = endpoint "identity-admin"
auth_uri = ::URI.decode identity_endpoint.to_s
db_user = node["openstack"]["network"]["db"]["username"]
db_pass = db_password "neutron"
sql_connection = db_uri("network", db_user, db_pass)
api_endpoint = endpoint "network-api"
service_pass = service_password "openstack-network"
service_tenant_name = node["openstack"]["network"]["service_tenant_name"]
service_user = node["openstack"]["network"]["service_user"]
if node["openstack"]["network"]["api"]["bind_interface"].nil?
bind_address = api_endpoint.host
bind_port = api_endpoint.port
else
bind_address = address_for node["openstack"]["network"]["api"]["bind_interface"]
bind_port = node["openstack"]["network"]["api"]["bind_port"]
end
# retrieve the local interface for tunnels
if node["openstack"]["network"]["openvswitch"]["local_ip_interface"].nil?
local_ip = node["openstack"]["network"]["openvswitch"]["local_ip"]
else
local_ip = address_for node["openstack"]["network"]["openvswitch"]["local_ip_interface"]
end
platform_options["neutron_client_packages"].each do |pkg|
package pkg do
action :upgrade
options platform_options["package_overrides"]
end
end
# all recipes include common.rb, and some servers
# may just be running a subset of agents (like l3_agent)
# and not the api server components, so we ignore restart
# failures here as there may be no neutron-server process
service "neutron-server" do
service_name platform_options["neutron_server_service"]
supports :status => true, :restart => true
ignore_failure true
action :nothing
end
template "/etc/neutron/neutron.conf" do
source "neutron.conf.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:bind_address => bind_address,
:bind_port => bind_port,
:rabbit_hosts => rabbit_hosts,
:rabbit_pass => rabbit_pass,
:core_plugin => core_plugin,
:identity_endpoint => identity_endpoint,
:service_pass => service_pass
)
notifies :restart, "service[neutron-server]", :delayed
end
template "/etc/neutron/api-paste.ini" do
source "api-paste.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00640
variables(
"auth_uri" => auth_uri,
"identity_admin_endpoint" => identity_admin_endpoint,
"identity_endpoint" => identity_endpoint,
"service_pass" => service_pass
)
notifies :restart, "service[neutron-server]", :delayed
end
directory "/etc/neutron/plugins/#{main_plugin}" do
recursive true
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00700
end
# For several plugins, the plugin configuration
# is required by both the neutron-server and
# ancillary services that may be on different
# physical servers like the l3 agent, so we assume
# the plugin configuration is a "common" file
template_file = nil
case main_plugin
when "bigswitch"
template_file = "/etc/neutron/plugins/bigswitch/restproxy.ini"
template "/etc/neutron/plugins/bigswitch/restproxy.ini" do
source "plugins/bigswitch/restproxy.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "brocade"
template_file = "/etc/neutron/plugins/brocade/brocade.ini"
template "/etc/neutron/plugins/brocade/brocade.ini" do
source "plugins/brocade/brocade.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "cisco"
template_file = "/etc/neutron/plugins/cisco/cisco_plugins.ini"
template "/etc/neutron/plugins/cisco/cisco_plugins.ini" do
source "plugins/cisco/cisco_plugins.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "hyperv"
template_file = "/etc/neutron/plugins/hyperv/hyperv_neutron_plugin.ini.erb"
template "/etc/neutron/plugins/hyperv/hyperv_neutron_plugin.ini.erb" do
source "plugins/hyperv/hyperv_neutron_plugin.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "linuxbridge"
template_file = "/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini"
template "/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini" do
source "plugins/linuxbridge/linuxbridge_conf.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
if node.run_list.expand(node.chef_environment).recipes.include?("openstack-network::linuxbridge")
notifies :restart, "service[neutron-plugin-linuxbridge-agent]", :delayed
end
end
when "midonet"
template_file = "/etc/neutron/plugins/metaplugin/metaplugin.ini"
template "/etc/neutron/plugins/metaplugin/metaplugin.ini" do
source "plugins/metaplugin/metaplugin.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "nec"
template_file = "/etc/neutron/plugins/nec/nec.ini"
template "/etc/neutron/plugins/nec/nec.ini" do
source "plugins/nec/nec.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "nicira"
template_file = "/etc/neutron/plugins/nicira/nvp.ini"
template "/etc/neutron/plugins/nicira/nvp.ini" do
source "plugins/nicira/nvp.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "openvswitch"
template_file = "/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini"
template "/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini" do
source "plugins/openvswitch/ovs_neutron_plugin.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection,
:local_ip => local_ip
)
notifies :restart, "service[neutron-server]", :delayed
if node.run_list.expand(node.chef_environment).recipes.include?("openstack-network::openvswitch")
notifies :restart, "service[neutron-plugin-openvswitch-agent]", :delayed
end
end
when "plumgrid"
template_file = "/etc/neutron/plugins/plumgrid/plumgrid.ini"
template "/etc/neutron/plugins/plumgrid/plumgrid.ini" do
source "plugins/plumgrid/plumgrid.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
when "ryu"
template_file = "/etc/neutron/plugins/ryu/ryu.ini"
template "/etc/neutron/plugins/ryu/ryu.ini" do
source "plugins/ryu/ryu.ini.erb"
owner node["openstack"]["network"]["platform"]["user"]
group node["openstack"]["network"]["platform"]["group"]
mode 00644
variables(
:sql_connection => sql_connection
)
notifies :restart, "service[neutron-server]", :delayed
end
end
template "/etc/default/neutron-server" do
source "neutron-server.erb"
owner "root"
group "root"
mode 00644
variables(
:plugin_config => template_file
)
only_if {
node.run_list.expand(node.chef_environment).recipes.include?("openstack-network::server")
platform?(%w{ubuntu debian})
}
end