diff options
| author | Mustapha Lansana <Mustapha.Lansana@windriver.com> | 2014-07-30 20:21:11 -0400 |
|---|---|---|
| committer | Bruce Ashfield <bruce.ashfield@windriver.com> | 2014-09-26 09:09:21 -0400 |
| commit | ef4a3055abee950950c2aac127854eb9e83f2793 (patch) | |
| tree | 47912200c661dc5884ffc1bddd86004eb64c89c3 /meta-openstack | |
| parent | 1675bd0d6c8b7cb69e044a9d75b6ad1d43ce3ccb (diff) | |
| download | meta-cloud-services-ef4a3055abee950950c2aac127854eb9e83f2793.tar.gz | |
deploychef: result of adapting deploychef to openstackchef class
The functionality the following files provide are now implemented in
openstackchef class, they are no longer needed in the deploychef package.
Signed-off-by: Mustapha Lansana <Mustapha.Lansana@windriver.com>
Diffstat (limited to 'meta-openstack')
15 files changed, 0 insertions, 888 deletions
diff --git a/meta-openstack/recipes-support/deploychef/files/chefsolo_default_attribute.rb b/meta-openstack/recipes-support/deploychef/files/chefsolo_default_attribute.rb deleted file mode 100644 index caf5af2..0000000 --- a/meta-openstack/recipes-support/deploychef/files/chefsolo_default_attribute.rb +++ /dev/null | |||
| @@ -1,76 +0,0 @@ | |||
| 1 | # | ||
| 2 | # Copyright (c) 2014 Wind River Systems, Inc. | ||
| 3 | # | ||
| 4 | # Permission is hereby granted, free of charge, to any person obtaining a copy | ||
| 5 | # of this software and associated documentation files (the "Software"), to deal | ||
| 6 | # in the Software without restriction, including without limitation the rights | ||
| 7 | # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
| 8 | # copies of the Software, and to permit persons to whom the Software is | ||
| 9 | # furnished to do so, subject to the following conditions: | ||
| 10 | # | ||
| 11 | # The above copyright notice and this permission notice shall be included in | ||
| 12 | # all copies or substantial portions of the Software. | ||
| 13 | # | ||
| 14 | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 15 | # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 16 | # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
| 17 | # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
| 18 | # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
| 19 | # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
| 20 | # THE SOFTWARE. | ||
| 21 | # | ||
| 22 | # | ||
| 23 | #These are the default values that chef-solo uses | ||
| 24 | #to convert our template files into the respective | ||
| 25 | #configuration and script files we want it to bake. | ||
| 26 | #Note though that Some of which are overwritten in the recipe file(s) | ||
| 27 | |||
| 28 | default["CHEFROOT_DIR"] ="%DEPLOYCHEF_ROOT_DIR%/" | ||
| 29 | default["TEMPLATE_DIR"] ="#{node[:CHEFROOT_DIR]}cookbooks/openstack/templates/default/*" | ||
| 30 | default["ETC_DIR"]= "%SYSCONFDIR%/" | ||
| 31 | default["POSTINSTS_DIR"] ="#{node[:ETC_DIR]}%POSTINSTS_DIR%/" | ||
| 32 | default["NOVA_CONF_DIR"]="#{node[:ETC_DIR]}nova/" | ||
| 33 | default["SWIFT_CONF_DIR"]="#{node[:ETC_DIR]}swift/" | ||
| 34 | default["CEILOMETER_CONF_DIR"]="#{node[:ETC_DIR]}ceilometer/" | ||
| 35 | default["NEUTRON_CONF_DIR"]= "#{node[:ETC_DIR]}neutron/" | ||
| 36 | default["NEUTRON_CORE_PLUGIN"]= "neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2" | ||
| 37 | default["OPENVSWITCH_CONF_DIR"]= "#{node[:NEUTRON_CONF_DIR]}plugins/openvswitch/" | ||
| 38 | default["LINUXBRIDGE_CONF_DIR"]= "#{node[:NEUTRON_CONF_DIR]}plugins/linuxbridge/" | ||
| 39 | default["KEYSTONE_CONF_DIR"]= "#{node[:ETC_DIR]}keystone/" | ||
| 40 | default["CINDER_CONF_DIR"]= "#{node[:ETC_DIR]}cinder/" | ||
| 41 | default["GLANCE_CONF_DIR"]= "#{node[:ETC_DIR]}glance/" | ||
| 42 | default["CEPH_CONF_DIR"]= "#{node[:ETC_DIR]}ceph/" | ||
| 43 | default["DB_DATADIR"]= "#{node[:ETC_DIR]}postgresql/" | ||
| 44 | default["HEAT_CONF_DIR"]= "#{node[:ETC_DIR]}heat/" | ||
| 45 | |||
| 46 | default["INITD_DIR"]= "#{node[:ETC_DIR]}init.d/" | ||
| 47 | default["CONTROLLER_DAEMON"]= "#{node[:INITD_DIR]}nova-api" | ||
| 48 | default["COMPUTE_DAEMON"]= "#{node[:INITD_DIR]}nova-compute" | ||
| 49 | default["NODE_TYPE"]="compute" | ||
| 50 | default["NODE_TYPES"]="compute controller allinone" | ||
| 51 | default["POSTINSTS_SCRIPT"] = "run-postinsts" | ||
| 52 | default["PREINSTS_SCRIPT"] = "service-shutdown" | ||
| 53 | default["AUTH_PROTOCOL"] = "http" | ||
| 54 | default["PRIVATE_IP"] = "127.0.0.1" | ||
| 55 | |||
| 56 | default["CONTROLLER_IP"] = "%CONTROLLER_IP%" | ||
| 57 | default["CONTROLLER_HOST"] = "%CONTROLLER_HOST%" | ||
| 58 | default["COMPUTE_IP"] = "%COMPUTE_IP%" | ||
| 59 | default["COMPUTE_HOST"] = "%COMPUTE_HOST%" | ||
| 60 | default["ADMIN_PASSWORD"] = "%ADMIN_PASSWORD%" | ||
| 61 | default["SERVICE_PASSWORD"] = "%SERVICE_PASSWORD%" | ||
| 62 | default["SERVICE_TENANT_NAME"] ="%SERVICE_TENANT_NAME%" | ||
| 63 | default["SERVICE_USER"] ="%SERVICE_USER%" | ||
| 64 | default["SERVICE_TOKEN"] ="%SERVICE_TOKEN%" | ||
| 65 | default["DEMO_USER"] ="%DEMO_USER%" | ||
| 66 | default["DEMO_PASSWORD"] ="%DEMO_PASSWORD%" | ||
| 67 | default["OS_TENANT_NAME"] ="%OS_TENANT_NAME%" | ||
| 68 | default["OS_USERNAME"] ="%OS_USERNAME%" | ||
| 69 | default["OS_PASSWORD"] ="%OS_PASSWORD%" | ||
| 70 | default["DB_USER"] ="%DB_USER%" | ||
| 71 | default["DB_PASSWORD"] ="%DB_PASSWORD%" | ||
| 72 | default["PUBLIC_IP"] ="#{node[:CONTROLLER_IP]}" | ||
| 73 | default["HOST_NAME"]="#{node[:CONTROLLER_HOSTS]}" | ||
| 74 | default["PUBLIC_DOMAIN"] ="#{node[:CONTROLLER_IP]}/24" | ||
| 75 | |||
| 76 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/chefsolo_default_recipe.rb b/meta-openstack/recipes-support/deploychef/files/chefsolo_default_recipe.rb deleted file mode 100644 index 3c83b23..0000000 --- a/meta-openstack/recipes-support/deploychef/files/chefsolo_default_recipe.rb +++ /dev/null | |||
| @@ -1,264 +0,0 @@ | |||
| 1 | # default.rb | ||
| 2 | # | ||
| 3 | # Copyright (c) 2014 Wind River Systems, Inc. | ||
| 4 | # | ||
| 5 | # Permission is hereby granted, free of charge, to any person obtaining a copy | ||
| 6 | # of this software and associated documentation files (the "Software"), to deal | ||
| 7 | # in the Software without restriction, including without limitation the rights | ||
| 8 | # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
| 9 | # copies of the Software, and to permit persons to whom the Software is | ||
| 10 | # furnished to do so, subject to the following conditions: | ||
| 11 | # | ||
| 12 | # The above copyright notice and this permission notice shall be included in | ||
| 13 | # all copies or substantial portions of the Software. | ||
| 14 | # | ||
| 15 | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 16 | # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 17 | # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
| 18 | # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
| 19 | # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
| 20 | # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
| 21 | # THE SOFTWARE. | ||
| 22 | # | ||
| 23 | # This is our main recipe that chef-solo bakes to configure our openstack deployment | ||
| 24 | domain = node['hostname'] | ||
| 25 | domain += " " + node['platform'] | ||
| 26 | domain += " " + node['platform_version'] | ||
| 27 | domain += " " + node['ipaddress'] | ||
| 28 | log domain do | ||
| 29 | level:info | ||
| 30 | end | ||
| 31 | |||
| 32 | #This function enables us to over-ride the hostname and ipaddress | ||
| 33 | #attributes based on the type of node installation | ||
| 34 | #we are running on. | ||
| 35 | def update_node_info() | ||
| 36 | if File.executable?(node[:CONTROLLER_DAEMON]) and \ | ||
| 37 | File.executable?(node[:COMPUTE_DAEMON]) | ||
| 38 | #All in one installation | ||
| 39 | if node[:ipaddress].length | ||
| 40 | node.default["CONTROLLER_IP"]=node.default["COMPUTE_IP"]=node[:ipaddress] | ||
| 41 | end | ||
| 42 | if node[:hostname].length | ||
| 43 | node.default["CONTROLLER_HOST"]=node.default["COMPUTE_HOST"]=node[:hostname] | ||
| 44 | end | ||
| 45 | node.default["NODE_TYPE"] ="allinone" | ||
| 46 | elsif File.executable?(node[:CONTROLLER_DAEMON]) | ||
| 47 | if node[:ipaddress].length | ||
| 48 | node.default["CONTROLLER_IP"]=node[:ipaddress] | ||
| 49 | end | ||
| 50 | if node[:hostname].length | ||
| 51 | node.default["CONTROLLER_HOST"]=node[:hostname] | ||
| 52 | end | ||
| 53 | node.default["NODE_TYPE"] ="controller" | ||
| 54 | else | ||
| 55 | if node[:ipaddress].length | ||
| 56 | node.default["COMPUTE_IP"]=node[:ipaddress] | ||
| 57 | end | ||
| 58 | if node[:hostname].length | ||
| 59 | node.default["COMPUTE_HOST"]=node[:hostname] | ||
| 60 | end | ||
| 61 | node.default["NODE_TYPE"] ="compute" | ||
| 62 | end | ||
| 63 | |||
| 64 | node.default["PUBLIC_IP"]="#{node[:CONTROLLER_IP]}" | ||
| 65 | node.default["HOST_NAME"]="#{node[:CONTROLLER_HOST]}" | ||
| 66 | node.default["PUBLIC_DOMAIN"]="#{node[:CONTROLLER_IP]}/24" | ||
| 67 | end | ||
| 68 | #This fucntion loops through all the files in the templates | ||
| 69 | #directory and create configuration or scripts files from the | ||
| 70 | #templates using the sets of defined attributes | ||
| 71 | def create_files_from_templates() | ||
| 72 | #Make it easier to move from development environment to target | ||
| 73 | output_dir = node[:POSTINSTS_DIR] | ||
| 74 | template_dir = node[:TEMPLATE_DIR] | ||
| 75 | #See if output directory exist if not create one | ||
| 76 | if not File.directory?(output_dir) | ||
| 77 | execute "Create #{output_dir} directory" do | ||
| 78 | command "mkdir -p #{output_dir}" | ||
| 79 | end | ||
| 80 | end | ||
| 81 | #Get the list of all template files | ||
| 82 | files = Dir.glob(template_dir) | ||
| 83 | #To ensure that the files are executed in increasing order | ||
| 84 | files = files.sort | ||
| 85 | for file in files do | ||
| 86 | #Exclude references to current and parent directory in search | ||
| 87 | next if File.directory?(file) or file == '.' or file == '..' | ||
| 88 | script_file = output_dir + File.basename(file) | ||
| 89 | script_file.gsub!(".erb","") | ||
| 90 | if File.file?(script_file) | ||
| 91 | execute "Delete file #{script_file} if present" do | ||
| 92 | command "rm -rf #{script_file}" | ||
| 93 | end | ||
| 94 | end | ||
| 95 | template script_file do | ||
| 96 | source File.basename(file) | ||
| 97 | mode 0755 | ||
| 98 | owner node[:user] | ||
| 99 | group node[:user] | ||
| 100 | end | ||
| 101 | end | ||
| 102 | end | ||
| 103 | #This function moves the generated configuration files for | ||
| 104 | #the respective modules to the specified module configuration directory | ||
| 105 | #Overwriting the current configuration file in the process | ||
| 106 | def replace_config_files(files, configDir, makeNoneExec=true) | ||
| 107 | #!files.strip | ||
| 108 | #!configDir.strip | ||
| 109 | if files and configDir | ||
| 110 | if not File.directory?(configDir) | ||
| 111 | execute "Create #{configDir}" do | ||
| 112 | command "mkdir -p #{configDir}" | ||
| 113 | end | ||
| 114 | end | ||
| 115 | if files.strip.include?(" ") | ||
| 116 | file_names = files.split | ||
| 117 | file_names.each do | fileName | | ||
| 118 | fileName=fileName.strip | ||
| 119 | if File.file?("#{node[:POSTINSTS_DIR]}#{fileName}") | ||
| 120 | execute "Move #{fileName} to #{configDir} " do | ||
| 121 | command "mv #{node[:POSTINSTS_DIR]}#{fileName} #{configDir}#{fileName}" | ||
| 122 | end | ||
| 123 | if makeNoneExec | ||
| 124 | execute "Remove execution mode on #{fileName}" do | ||
| 125 | command "chmod 0644 #{configDir}#{fileName}" | ||
| 126 | end | ||
| 127 | end | ||
| 128 | end | ||
| 129 | end | ||
| 130 | else | ||
| 131 | #There is only one file in the list | ||
| 132 | files=files.strip | ||
| 133 | if File.file?("#{node[:POSTINSTS_DIR]}#{files}") | ||
| 134 | execute "Move #{files} to #{configDir} " do | ||
| 135 | command "mv #{node[:POSTINSTS_DIR]}#{files} #{configDir}#{files}" | ||
| 136 | end | ||
| 137 | if makeNoneExec | ||
| 138 | execute "Remove execution mode on #{files}" do | ||
| 139 | command "chmod 0644 #{configDir}#{files}" | ||
| 140 | end | ||
| 141 | end | ||
| 142 | end | ||
| 143 | end | ||
| 144 | end | ||
| 145 | end | ||
| 146 | |||
| 147 | #Update hostname and ipaddress to be written to configuration files | ||
| 148 | update_node_info | ||
| 149 | |||
| 150 | #Generate scripts and cofiguration files | ||
| 151 | create_files_from_templates | ||
| 152 | |||
| 153 | #Move the configuration files to /etc/nova directory | ||
| 154 | #and make remove execution modifier from the files | ||
| 155 | novaConfigFiles="nova.conf openrc api-paste.ini deploy.conf" | ||
| 156 | replace_config_files(novaConfigFiles,"#{node[:NOVA_CONF_DIR]}") | ||
| 157 | #Move the configuration files to /etc/swift directory | ||
| 158 | #and remove execution modifier from the files | ||
| 159 | swiftConfigFiles="test.conf dispersion.conf proxy-server.conf" | ||
| 160 | if node[:NODE_TYPE] == "compute" | ||
| 161 | files = swiftConfigFiles.split | ||
| 162 | files.each do | fileName | | ||
| 163 | fileName=fileName.strip | ||
| 164 | fileName ="#{node[:POSTINSTS_DIR]}#{fileName}" | ||
| 165 | if File.file?(fileName) | ||
| 166 | execute "Remove file #{fileName}" do | ||
| 167 | command "rm #{node[:POSTINSTS_DIR]}#{fileName}" | ||
| 168 | end | ||
| 169 | end | ||
| 170 | end | ||
| 171 | else | ||
| 172 | replace_config_files(swiftConfigFiles,"#{node[:SWIFT_CONF_DIR]}") | ||
| 173 | end | ||
| 174 | #Move the configuration files to /etc/neutron directory | ||
| 175 | #and remove execution modifier from the files | ||
| 176 | configFiles="neutron.conf" | ||
| 177 | replace_config_files(configFiles,"#{node[:NEUTRON_CONF_DIR]}") | ||
| 178 | configFiles="linuxbridge_conf.ini" | ||
| 179 | replace_config_files(configFiles,"#{node[:LINUXBRIDGE_CONF_DIR]}") | ||
| 180 | configFiles="ovs_neutron_plugin.ini" | ||
| 181 | replace_config_files(configFiles,"#{node[:OPENVSWITCH_CONF_DIR]}") | ||
| 182 | |||
| 183 | configFiles="ceilometer.conf" | ||
| 184 | replace_config_files(configFiles,"#{node[:CEILOMETER_CONF_DIR]}") | ||
| 185 | |||
| 186 | configFiles="glance-api.conf glance-cache.conf glance-registry.conf" | ||
| 187 | if node[:NODE_TYPE] == "compute" | ||
| 188 | files = configFiles.split | ||
| 189 | files.each do | fileName | | ||
| 190 | if File.file?("#{node[:POSTINSTS_DIR]}#{fileName}") | ||
| 191 | execute "Remove file #{fileName}" do | ||
| 192 | command "rm #{node[:POSTINSTS_DIR]}#{fileName}" | ||
| 193 | end | ||
| 194 | end | ||
| 195 | end | ||
| 196 | else | ||
| 197 | replace_config_files(configFiles,"#{node[:GLANCE_CONF_DIR]}") | ||
| 198 | end | ||
| 199 | |||
| 200 | #Move the postgresql init script and make them executable | ||
| 201 | configFiles="postgresql-init" | ||
| 202 | replace_config_files(configFiles, "#{node[:INITD_DIR]}", false) | ||
| 203 | |||
| 204 | configFiles="ceph.conf" | ||
| 205 | replace_config_files(configFiles, "#{node[:CEPH_CONF_DIR]}") | ||
| 206 | |||
| 207 | configFiles="ceph-setup" | ||
| 208 | if node[:NODE_TYPE] == "compute" | ||
| 209 | if File.file?("#{node[:POSTINSTS_DIR]}#{configFiles}") | ||
| 210 | execute "Remove file #{configFiles}" do | ||
| 211 | command "rm #{node[:POSTINSTS_DIR]}#{configFiles}" | ||
| 212 | end | ||
| 213 | end | ||
| 214 | else | ||
| 215 | replace_config_files(configFiles, "#{node[:INITD_DIR]}", false) | ||
| 216 | end | ||
| 217 | |||
| 218 | configFiles="keystone.conf identity.sh" | ||
| 219 | if node[:NODE_TYPE] == "compute" | ||
| 220 | files = configFiles.split | ||
| 221 | files.each do | fileName | | ||
| 222 | if File.file?("#{node[:POSTINSTS_DIR]}#{fileName}") | ||
| 223 | execute "Remove file #{fileName}" do | ||
| 224 | command "rm #{node[:POSTINSTS_DIR]}#{fileName}" | ||
| 225 | end | ||
| 226 | end | ||
| 227 | end | ||
| 228 | else | ||
| 229 | replace_config_files(configFiles, "#{node[:KEYSTONE_CONF_DIR]}") | ||
| 230 | #Openrc in keystone conf dir is same as that found in nova | ||
| 231 | execute "Copy openrc to #{node[:KEYSTONE_CONF_DIR]}" do | ||
| 232 | command "cp #{node[:NOVA_CONF_DIR]}openrc #{node[:KEYSTONE_CONF_DIR]}" | ||
| 233 | end | ||
| 234 | end | ||
| 235 | #cinder configurations | ||
| 236 | configFiles="api-paste.ini.cinder cinder.conf" | ||
| 237 | replace_config_files(configFiles, "#{node[:CINDER_CONF_DIR]}") | ||
| 238 | |||
| 239 | fileName="#{node[:CINDER_CONF_DIR]}api-paste.ini.cinder" | ||
| 240 | if File.file?(fileName) | ||
| 241 | execute "Rename api-paste.ini.cinder to api-paste.ini" do | ||
| 242 | command "mv #{node[:CINDER_CONF_DIR]}api-paste.ini.cinder #{node[:CINDER_CONF_DIR]}api-paste.ini" | ||
| 243 | end | ||
| 244 | end | ||
| 245 | #heat configuration | ||
| 246 | configFiles="heat.conf" | ||
| 247 | if node[:NODE_TYPE] == "compute" | ||
| 248 | if File.file?("#{node[:POSTINSTS_DIR]}#{configFiles}") | ||
| 249 | execute "Remove file #{configFiles}" do | ||
| 250 | command "rm #{node[:POSTINSTS_DIR]}#{configFiles}" | ||
| 251 | end | ||
| 252 | end | ||
| 253 | else | ||
| 254 | replace_config_files(configFiles, "#{node[:HEAT_CONF_DIR]}") | ||
| 255 | end | ||
| 256 | #Move the hosts file in place | ||
| 257 | configFiles="hosts" | ||
| 258 | replace_config_files(configFiles,"#{node[:ETC_DIR]}") | ||
| 259 | |||
| 260 | =begin | ||
| 261 | service host[:hostname] do | ||
| 262 | action :restart | ||
| 263 | endf | ||
| 264 | =end | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/ceilometer-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/ceilometer-template.inc deleted file mode 100644 index 471ef1e..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/ceilometer-template.inc +++ /dev/null | |||
| @@ -1,19 +0,0 @@ | |||
| 1 | #Ceilometer chefsolo template generation functions | ||
| 2 | |||
| 3 | ceilometer-conf_chefsolo_template() { | ||
| 4 | file_name=$1 | ||
| 5 | if [ -e $file_name ]; then | ||
| 6 | sed "s/^os_password=.*$/os_password=<%=node[:ADMIN_PASSWORD]%>/" -i $file_name | ||
| 7 | sed "s/^os_tenant_name=.*$/os_tenant_name= <%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 8 | sed "s/^auth_host=.*$/auth_host=<%=node[:CONTROLLER_IP]%>/" -i $file_name | ||
| 9 | sed "s/^admin_password=.*$/admin_password= <%=node[:ADMIN_PASSWORD]%>/" -i $file_name | ||
| 10 | sed "s/^admin_tenant_name=.*$/admin_tenant_name= <%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 11 | |||
| 12 | sed "s/^rabbit_host =.*$/rabbit_host = <%=node[:CONTROLLER_IP]%>/" -i $file_name | ||
| 13 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 14 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 15 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 16 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 17 | mv $file_name $file_name$SUFFIX | ||
| 18 | fi | ||
| 19 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/ceph-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/ceph-template.inc deleted file mode 100644 index 2946808..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/ceph-template.inc +++ /dev/null | |||
| @@ -1,26 +0,0 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | #Ceph related chefsolo template functions | ||
| 3 | ceph-conf_chefsolo_template() { | ||
| 4 | file_name=$1 | ||
| 5 | if [ -e $file_name ]; then | ||
| 6 | sed "s/mon initial members =.*$/mon initial members = <%=node[:HOST_NAME]%> /" -i $file_name | ||
| 7 | sed "s/mon host =.*$/mon host = <%=node[:PUBLIC_IP]%>/" -i $file_name | ||
| 8 | |||
| 9 | sed "s:public network =.*/:public network = <%=node[\:CONTROLLER_IP]%>/:" -i $file_name | ||
| 10 | sed "s/mon.$CONTROLLER_HOST/mon.<%=node[:HOST_NAME]%>/" -i $file_name | ||
| 11 | sed "s/host =.*$/host = <%=node[:HOST_NAME]%>/" -i $file_name | ||
| 12 | sed "s#mon addr =.*:#mon addr = <%=node[:PUBLIC_IP]%>:#" -i $file_name | ||
| 13 | sed "s#public addr =.*:#public addr = <%=node[:PUBLIC_IP]%>:#" -i $file_name | ||
| 14 | sed "s#cluster addr =.*:#cluster addr = <%=node[:PRIVATE_IP]%>:#" -i $file_name | ||
| 15 | mv $file_name $file_name$SUFFIX | ||
| 16 | fi | ||
| 17 | } | ||
| 18 | |||
| 19 | ceph-setup_chefsolo_template() { | ||
| 20 | file_name=$1 | ||
| 21 | if [ -e $file_name ]; then | ||
| 22 | sed "s/^HOST_NAME.*$/HOST_NAME= <%=node[:HOST_NAME]%> /" -i $file_name | ||
| 23 | sed "s/^PUBLIC_IP.*$/PUBLIC_IP= <%=node[:PUBLIC_IP]%>/" -i $file_name | ||
| 24 | mv $file_name $file_name$SUFFIX | ||
| 25 | fi | ||
| 26 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/cinder-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/cinder-template.inc deleted file mode 100644 index 4aeb616..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/cinder-template.inc +++ /dev/null | |||
| @@ -1,21 +0,0 @@ | |||
| 1 | #Cinder related configuration functions | ||
| 2 | cinder-conf_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 6 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 7 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 8 | mv $file_name $file_name$SUFFIX | ||
| 9 | fi | ||
| 10 | } | ||
| 11 | |||
| 12 | cinder-api_chefsolo_template() { | ||
| 13 | file_name=$1 | ||
| 14 | if [ -e $file_name ]; then | ||
| 15 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%> /" -i $file_name | ||
| 16 | sed "s/^admin_user =.*$/admin_user = <%=node[:SERVICE_USER]%> /" -i $file_name | ||
| 17 | sed "s/^admin_password =.*$/admin_password = <%=node[:SERVICE_PASSWORD]%> /" -i $file_name | ||
| 18 | mv $file_name $file_name$SUFFIX | ||
| 19 | fi | ||
| 20 | } | ||
| 21 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/constants.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/constants.inc deleted file mode 100644 index 48994d3..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/constants.inc +++ /dev/null | |||
| @@ -1,23 +0,0 @@ | |||
| 1 | #This file is used in the generation of config script | ||
| 2 | CONTROLLER_HOST="%CONTROLLER_HOST%" | ||
| 3 | COMPUTE_HOST="%COMPUTE_HOST%" | ||
| 4 | CONTROLLER_IP="%CONTROLLER_IP%" | ||
| 5 | COMPUTE_IP="%COMPUTE_IP%" | ||
| 6 | |||
| 7 | DB_USER="%DB_USER%" | ||
| 8 | DB_PASSWORD="%DB_PASSWORD%" | ||
| 9 | ADMIN_USER="%ADMIN_USER%" | ||
| 10 | ADMIN_TENANT_NAME="%ADMIN_PASSWORD%" | ||
| 11 | |||
| 12 | ADMIN_PASSWORD="%ADMIN_PASSWORD%" | ||
| 13 | SERVICE_PASSWORD="%SERVICE_PASSWORD%" | ||
| 14 | SERVICE_TENANT_NAME="%SERVICE_TENANT_NAME%" | ||
| 15 | |||
| 16 | SERVICE_USER="%SERVICE_USER%" | ||
| 17 | SERVICE_TOKEN="%SERVICE_TOKEN%" | ||
| 18 | DEMO_USER="%DEMO_USER%" | ||
| 19 | DEMO_PASSWORD="%DEMO_PASSWORD%" | ||
| 20 | |||
| 21 | OS_TENANT_NAME="%OS_TENANT_NAME%" | ||
| 22 | OS_USERNAME="%OS_USERNAME%" | ||
| 23 | OS_PASSWORD="%OS_PASSWORD%" | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/glance-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/glance-template.inc deleted file mode 100644 index cbf3264..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/glance-template.inc +++ /dev/null | |||
| @@ -1,16 +0,0 @@ | |||
| 1 | #Glance related configuration functions | ||
| 2 | glance_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 6 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 7 | sed "s/^swift_store_user =.*$/swift_store_user = <%=node[:SERVICE_TENANT_NAME]%>:glance/" -i $file_name | ||
| 8 | sed "s/^swift_store_key =.*$/swift_store_key = <%=node[:SERVICE_PASSWORD]%> /" -i $file_name | ||
| 9 | |||
| 10 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%> /" -i $file_name | ||
| 11 | sed "s/^admin_user =.*$/admin_user = <%=node[:SERVICE_USER]%> /" -i $file_name | ||
| 12 | sed "s/^admin_password =.*$/admin_password = <%=node[:SERVICE_PASSWORD]%> /" -i $file_name | ||
| 13 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 14 | mv $file_name $file_name$SUFFIX | ||
| 15 | fi | ||
| 16 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/heat-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/heat-template.inc deleted file mode 100644 index 578d2e7..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/heat-template.inc +++ /dev/null | |||
| @@ -1,15 +0,0 @@ | |||
| 1 | #Heat related configuration function(s) | ||
| 2 | heat-conf_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 6 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 7 | sed "s/^auth_host =.*$/auth_host = <%=node[:CONTROLLER_IP]%> /" -i $file_name | ||
| 8 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%> /" -i $file_name | ||
| 9 | sed "s/^admin_password =.*$/admin_password = <%=node[:ADMIN_PASSWORD]%> /" -i $file_name | ||
| 10 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 11 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 12 | mv $file_name $file_name$SUFFIX | ||
| 13 | fi | ||
| 14 | } | ||
| 15 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/hosts-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/hosts-template.inc deleted file mode 100644 index b7690b8..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/hosts-template.inc +++ /dev/null | |||
| @@ -1,10 +0,0 @@ | |||
| 1 | #Hosts related configuration function(s) | ||
| 2 | hosts_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$CONTROLLER_IP.*$/<%=node[:CONTROLLER_IP]%> <%=node[:CONTROLLER_HOST]%>/" -i $file_name | ||
| 6 | sed "s/$COMPUTE_IP*$/<%=node[:COMPUTE_IP]%> <%=node[:COMPUTE_HOST]%>/" -i $file_name | ||
| 7 | mv $file_name $file_name$SUFFIX | ||
| 8 | fi | ||
| 9 | } | ||
| 10 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/keystone-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/keystone-template.inc deleted file mode 100644 index dc43639..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/keystone-template.inc +++ /dev/null | |||
| @@ -1,24 +0,0 @@ | |||
| 1 | #Keystone related configuration functions | ||
| 2 | keystone-conf_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | #keystone.conf related | ||
| 6 | sed "s/^admin_token =.*$/admin_token=<%=node[:SERVICE_TOKEN]%> /" -i $file_name | ||
| 7 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 8 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 9 | mv $file_name $file_name$SUFFIX | ||
| 10 | fi | ||
| 11 | } | ||
| 12 | |||
| 13 | keystone-identity_chefsolo_template() { | ||
| 14 | file_name=$1 | ||
| 15 | if [ -e $file_name ]; then | ||
| 16 | #Identifyy related substitutions | ||
| 17 | sed "s/^export OS_SERVICE_TOKEN.*$/export OS_SERVICE_TOKEN=<%=node[:SERVICE_TOKEN]%>/" \ | ||
| 18 | -i $file_name | ||
| 19 | sed "s/$ADMIN_PASSWORD/<%=node[:ADMIN_PASSWORD]%>/" -i $file_name | ||
| 20 | sed "s/$SERVICE_TENANT_NAME/<%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 21 | sed "s/^KEYSTONE_HOST.*$/KEYSTONE_HOST=<%=node[:CONTROLLER_IP]%> /" -i $file_name | ||
| 22 | mv $file_name $file_name$SUFFIX | ||
| 23 | fi | ||
| 24 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/neutron-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/neutron-template.inc deleted file mode 100644 index 4d10607..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/neutron-template.inc +++ /dev/null | |||
| @@ -1,24 +0,0 @@ | |||
| 1 | #Neutron chefsolo template generation related function(s) | ||
| 2 | neutron-conf_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 6 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 7 | sed "s/^admin_user =.*$/admin_user = <%=node[:SERVICE_USER]%>/" -i $file_name | ||
| 8 | sed "s/^admin_password =.*$/admin_password =<%=node[:SERVICE_PASSWORD]%>/g" -i $file_name | ||
| 9 | sed "s/^rabbit_host =.*$/rabbit_host = <%=node[:CONTROLLER_IP]%>/" -i $file_name | ||
| 10 | mv $file_name $file_name$SUFFIX | ||
| 11 | fi | ||
| 12 | } | ||
| 13 | |||
| 14 | neutron-plugins_chefsolo_template() { | ||
| 15 | file_name=$1 | ||
| 16 | if [ -e $file_name ]; then | ||
| 17 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 18 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 19 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 20 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 21 | mv $file_name $file_name$SUFFIX | ||
| 22 | fi | ||
| 23 | } | ||
| 24 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/nova-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/nova-template.inc deleted file mode 100644 index 74b0d4c..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/nova-template.inc +++ /dev/null | |||
| @@ -1,47 +0,0 @@ | |||
| 1 | #Nova chefsolo template generation functions | ||
| 2 | openrc_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/^export OS_TENANT_NAME=.*$/export OS_TENANT_NAME=<%=node[:OS_TENANT_NAME]%> /" -i $file_name | ||
| 6 | sed "s/^export OS_USERNAME=.*$/export OS_USERNAME=<%=node[:OS_USERNAME]%> /" -i $file_name | ||
| 7 | sed "s/^export OS_PASSWORD=.*$/export OS_PASSWORD=<%=node[:OS_PASSWORD]%> /" -i $file_name | ||
| 8 | sed "s/^export SERVICE_TOKEN=.*$/export SERVICE_TOKEN=<%=node[:SERVICE_TOKEN]%> /" -i $file_name | ||
| 9 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 10 | mv $file_name $file_name$SUFFIX | ||
| 11 | fi | ||
| 12 | } | ||
| 13 | |||
| 14 | nova-conf_chefsolo_template() { | ||
| 15 | file_name=$1 | ||
| 16 | if [ -e $file_name ]; then | ||
| 17 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 18 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 19 | sed "s/$COMPUTE_IP/<%=node[:COMPUTE_IP]%>/g" -i $file_name | ||
| 20 | sed "s/$DB_USER:/<%=node[:DB_USER]%>:/g" -i $file_name | ||
| 21 | sed "s/$DB_PASSWORD@/<%=node[:DB_PASSWORD]%>@/g" -i $file_name | ||
| 22 | mv $file_name $file_name$SUFFIX | ||
| 23 | fi | ||
| 24 | } | ||
| 25 | |||
| 26 | api-paste_chefsolo_template() { | ||
| 27 | file_name=$1 | ||
| 28 | if [ -e $file_name ]; then | ||
| 29 | sed "s/auth_host =.*$/auth_host = <%=node[:CONTROLLER_IP]%> /" -i $file_name | ||
| 30 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%> /" -i $file_name | ||
| 31 | sed "s/^admin_user =.*$/admin_user = <%=node[:SERVICE_USER]%> /" -i $file_name | ||
| 32 | sed "s/^admin_password =.*$/admin_password = <%=node[:SERVICE_PASSWORD]%> /" -i $file_name | ||
| 33 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 34 | mv $file_name $file_name$SUFFIX | ||
| 35 | fi | ||
| 36 | } | ||
| 37 | |||
| 38 | deploy-conf_chefsolo_template() { | ||
| 39 | file_name=$1 | ||
| 40 | if [ -e $file_name ]; then | ||
| 41 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 42 | sed "s/$CONTROLLER_HOST/<%=node[:CONTROLLER_HOST]%>/g" -i $file_name | ||
| 43 | sed "s/$COMPUTE_IP/<%=node[:COMPUTE_IP]%>/g" -i $file_name | ||
| 44 | sed "s/$COMPUTE_HOST/<%=node[:COMPUTE_HOST]%>/g" -i $file_name | ||
| 45 | mv $file_name $file_name$SUFFIX | ||
| 46 | fi | ||
| 47 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/postgresql-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/postgresql-template.inc deleted file mode 100644 index 6022cd2..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/postgresql-template.inc +++ /dev/null | |||
| @@ -1,12 +0,0 @@ | |||
| 1 | #Postgresql chefsolo template generation functions | ||
| 2 | postgresql_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$CONTROLLER_IP/<%=node[:CONTROLLER_IP]%>/g" -i $file_name | ||
| 6 | sed "s/$COMPUTE_IP/<%=node[:COMPUTE_IP]%>/g" -i $file_name | ||
| 7 | sed "s/^DB_USER=.*$/DB_USER=<%=node[:DB_USER]%>/" -i $file_name | ||
| 8 | sed "s/^DB_PASSWORD=.*$/DB_PASSWORD=<%=node[:DB_PASSWORD]%>/" -i $file_name | ||
| 9 | mv $file_name $file_name$SUFFIX | ||
| 10 | fi | ||
| 11 | } | ||
| 12 | |||
diff --git a/meta-openstack/recipes-support/deploychef/files/conf-templates/swift-template.inc b/meta-openstack/recipes-support/deploychef/files/conf-templates/swift-template.inc deleted file mode 100644 index 4a33536..0000000 --- a/meta-openstack/recipes-support/deploychef/files/conf-templates/swift-template.inc +++ /dev/null | |||
| @@ -1,37 +0,0 @@ | |||
| 1 | #Swift chefso template generation functions | ||
| 2 | dispersion-conf_chefsolo_template() { | ||
| 3 | file_name=$1 | ||
| 4 | if [ -e $file_name ]; then | ||
| 5 | sed "s/$SERVICE_TENANT_NAME/<%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 6 | sed "s/$SERVICE_USER/<%=node[:SERVICE_USER]%>/" -i $file_name | ||
| 7 | sed "s/$SERVICE_PASSWORD/<%=node[:SERVICE_PASSWORD]%>/" -i $file_name | ||
| 8 | mv $file_name $file_name$SUFFIX | ||
| 9 | fi | ||
| 10 | } | ||
| 11 | |||
| 12 | test-conf_chefsolo_template() { | ||
| 13 | file_name=$1 | ||
| 14 | if [ -e $file_name ]; then | ||
| 15 | sed "s/^account =.*$/account = <%=node[:ADMIN_TENANT_NAME]%>/" -i $file_name | ||
| 16 | sed "s/^username =.*$/username = <%=node[:ADMIN_USER]%>/" -i $file_name | ||
| 17 | sed "s/^password =.*$/password = <%=node[:ADMIN_PASSWORD]%>/g" -i $file_name | ||
| 18 | |||
| 19 | sed "s/^account2 =.*$/account = <%=node[:SERVICE_TENANT_NAME]%>/" -i $file_name | ||
| 20 | sed "s/^username2 =.*$/username = <%=node[:SERVICE_USER]%>/" -i $file_name | ||
| 21 | sed "s/^password2 =.*$/password = <%=node[:SERVICE_PASSWORD]%>/g" -i $file_name | ||
| 22 | |||
| 23 | sed "s/^username3 =.*$/username = <%=node[:DEMO_USER]%>/" -i $file_name | ||
| 24 | sed "s/^password3 =.*$/password = <%=node[:DEMO_PASSWORD]%>/g" -i $file_name | ||
| 25 | mv $file_name $file_name$SUFFIX | ||
| 26 | fi | ||
| 27 | } | ||
| 28 | |||
| 29 | proxy-server_chefsolo_template() { | ||
| 30 | file_name=$1 | ||
| 31 | if [ -e $file_name ]; then | ||
| 32 | sed "s/^admin_tenant_name =.*$/admin_tenant_name = <%=node[:SERVICE_TENANT_NAME]%> /" -i $file_name | ||
| 33 | sed "s/^admin_user =.*$/admin_user = <%=node[:SERVICE_USER]%> /" -i $file_name | ||
| 34 | sed "s/^admin_password =.*$/admin_password = <%=node[:SERVICE_PASSWORD]%> /" -i $file_name | ||
| 35 | mv $file_name $file_name$SUFFIX | ||
| 36 | fi | ||
| 37 | } | ||
diff --git a/meta-openstack/recipes-support/deploychef/files/generate-templates b/meta-openstack/recipes-support/deploychef/files/generate-templates deleted file mode 100644 index 178c8c3..0000000 --- a/meta-openstack/recipes-support/deploychef/files/generate-templates +++ /dev/null | |||
| @@ -1,274 +0,0 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | #Location of servics configuration files | ||
| 3 | D="%SYSCONFDIR%" | ||
| 4 | TEMPLATES="%DEPLOYCHEF_ROOT_DIR%/cookbooks/openstack/templates/default" | ||
| 5 | #Chefsolo template suffix | ||
| 6 | SUFFIX='.erb' | ||
| 7 | #List of services whose config files needs to be converted to templates | ||
| 8 | service_list="ceph swift nova heat cinder keystone glance neutron ceilometer init.d" | ||
| 9 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/constants.inc | ||
| 10 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/nova-template.inc | ||
| 11 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/ceph-template.inc | ||
| 12 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/swift-template.inc | ||
| 13 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/neutron-template.inc | ||
| 14 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/ceilometer-template.inc | ||
| 15 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/glance-template.inc | ||
| 16 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/postgresql-template.inc | ||
| 17 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/keystone-template.inc | ||
| 18 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/cinder-template.inc | ||
| 19 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/heat-template.inc | ||
| 20 | source %DEPLOYCHEF_ROOT_DIR%/conf-templates/hosts-template.inc | ||
| 21 | |||
| 22 | SRC="${D}/%POSTINSTS_DIR%/" | ||
| 23 | DST=${TEMPLATES} | ||
| 24 | #Copy postinstall scripts and make chefsolo templates | ||
| 25 | postinsts_make_templates(){ | ||
| 26 | for file in $(ls -h ${SRC}); do | ||
| 27 | dst_file=${DST}/$file$SUFFIX | ||
| 28 | install -m 0644 ${SRC}/$file $dst_file | ||
| 29 | sed 's|ADMIN_PASSWORD=.*$|ADMIN_PASSWORD=<%=node[:ADMIN_PASSWORD]%> \\|' -i $dst_file | ||
| 30 | sed 's|SERVICE_PASSWORD=.*$|SERVICE_PASSWORD=<%=node[:SERVICE_PASSWORD]%> \\|' -i $dst_file | ||
| 31 | sed 's|SERVICE_TENANT_NAME=.*$|SERVICE_TENANT_NAME=<%=node[:SERVICE_TENANT_NAME]%> \\|' -i $dst_file | ||
| 32 | sed "s|$CONTROLLER_IP|<%=node[:CONTROLLER_IP]%>|g" -i $dst_file | ||
| 33 | sed "s|$CONTROLLER_HOST|<%=node[:CONTROLLER_HOST]%>|g" -i $dst_file | ||
| 34 | done | ||
| 35 | } | ||
| 36 | |||
| 37 | #These sets of make_*_templates() helper functions | ||
| 38 | #copy the respective configuration files if they | ||
| 39 | #exist and converts them to chefsolo templates | ||
| 40 | etc-hosts_make_templates(){ | ||
| 41 | #Creat template file for /etc/hosts | ||
| 42 | SRC=${D} | ||
| 43 | DST=${TEMPLATES} | ||
| 44 | file_name=hosts | ||
| 45 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 46 | file_name="${DST}/$file_name" | ||
| 47 | hosts_chefsolo_template $file_name | ||
| 48 | } | ||
| 49 | |||
| 50 | make_ceph_templates(){ | ||
| 51 | file_name=ceph.conf | ||
| 52 | if [ -f ${SRC}/$file_name ]; then | ||
| 53 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 54 | file_name="${DST}/$file_name" | ||
| 55 | ceph-conf_chefsolo_template $file_name | ||
| 56 | fi | ||
| 57 | file_name=ceph-setup | ||
| 58 | if [ -f ${SRC}/$file_name ]; then | ||
| 59 | install -m 0644 ${SRC}/../init.d/$file_name ${DST} | ||
| 60 | file_name="${DST}/$file_name" | ||
| 61 | ceph-setup_chefsolo_template $file_name | ||
| 62 | fi | ||
| 63 | } | ||
| 64 | |||
| 65 | make_swift_templates(){ | ||
| 66 | file_name='test.conf' | ||
| 67 | if [ -f ${SRC}/$file_name ]; then | ||
| 68 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 69 | file_name="${DST}/$file_name" | ||
| 70 | test-conf_chefsolo_template $file_name | ||
| 71 | fi | ||
| 72 | |||
| 73 | file_name='dispersion.conf' | ||
| 74 | if [ -f ${SRC}/$file_name ]; then | ||
| 75 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 76 | file_name="${DST}/$file_name" | ||
| 77 | dispersion-conf_chefsolo_template $file_name | ||
| 78 | fi | ||
| 79 | file_name='proxy-server.conf' | ||
| 80 | if [ -f ${SRC}/$file_name ]; then | ||
| 81 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 82 | file_name="${DST}/$file_name" | ||
| 83 | proxy-server_chefsolo_template $file_name | ||
| 84 | fi | ||
| 85 | } | ||
| 86 | |||
| 87 | make_nova_templates(){ | ||
| 88 | file_name=nova.conf | ||
| 89 | if [ -f ${SRC}/$file_name ]; then | ||
| 90 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 91 | file_name="${DST}/$file_name" | ||
| 92 | nova-conf_chefsolo_template $file_name | ||
| 93 | fi | ||
| 94 | file_name=openrc | ||
| 95 | if [ -f ${SRC}/$file_name ]; then | ||
| 96 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 97 | file_name="${DST}/$file_name" | ||
| 98 | openrc_chefsolo_template $file_name | ||
| 99 | fi | ||
| 100 | file_name=api-paste.ini | ||
| 101 | if [ -f ${SRC}/$file_name ]; then | ||
| 102 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 103 | file_name="${DST}/$file_name" | ||
| 104 | api-paste_chefsolo_template $file_name | ||
| 105 | fi | ||
| 106 | |||
| 107 | file_name=deploy.conf | ||
| 108 | if [ -f ${SRC}/$file_name ]; then | ||
| 109 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 110 | file_name="${DST}/$file_name" | ||
| 111 | deploy-conf_chefsolo_template $file_name | ||
| 112 | fi | ||
| 113 | } | ||
| 114 | |||
| 115 | make_neutron_templates(){ | ||
| 116 | file_name=neutron.conf | ||
| 117 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 118 | file_name="${DST}/$file_name" | ||
| 119 | neutron-conf_chefsolo_template $file_name | ||
| 120 | if [ -d ${SRC}/plugins/openvswitch ]; then | ||
| 121 | file_name=ovs_neutron_plugin.ini | ||
| 122 | install -m 0644 ${SRC}/plugins/openvswitch/$file_name ${DST} | ||
| 123 | file_name="${DST}/$file_name" | ||
| 124 | neutron-plugins_chefsolo_template $file_name | ||
| 125 | fi | ||
| 126 | |||
| 127 | if [ -d ${SRC}/plugins/linuxbridge ]; then | ||
| 128 | file_name=linuxbridge_conf.ini | ||
| 129 | install -m 0644 ${SRC}/plugins/linuxbridge/$file_name ${DST} | ||
| 130 | file_name="${DST}/$file_name" | ||
| 131 | neutron-plugins_chefsolo_template $file_name | ||
| 132 | fi | ||
| 133 | } | ||
| 134 | make_heat_templates(){ | ||
| 135 | file_name=heat.conf | ||
| 136 | if [ -f ${SRC}/$file_name ]; then | ||
| 137 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 138 | file_name="${DST}/$file_name" | ||
| 139 | heat-conf_chefsolo_template $file_name | ||
| 140 | fi | ||
| 141 | } | ||
| 142 | |||
| 143 | make_cinder_templates(){ | ||
| 144 | file_name=api-paste.ini | ||
| 145 | if [ -f ${SRC}/$file_name ]; then | ||
| 146 | install -m 0644 ${SRC}/$file_name ${DST}/${file_name}.cinder | ||
| 147 | file_name="${DST}/${file_name}.cinder" | ||
| 148 | cinder-api_chefsolo_template $file_name | ||
| 149 | fi | ||
| 150 | |||
| 151 | file_name=cinder.conf | ||
| 152 | if [ -f ${SRC}/$file_name ]; then | ||
| 153 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 154 | file_name="${DST}/$file_name" | ||
| 155 | cinder-conf_chefsolo_template $file_name | ||
| 156 | fi | ||
| 157 | } | ||
| 158 | make_keystone_templates(){ | ||
| 159 | file_name=keystone.conf | ||
| 160 | if [ -f ${SRC}/$file_name ]; then | ||
| 161 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 162 | file_name="${DST}/$file_name" | ||
| 163 | keystone-conf_chefsolo_template $file_name | ||
| 164 | fi | ||
| 165 | file_name=identity.sh | ||
| 166 | if [ -f ${SRC}/$file_name ]; then | ||
| 167 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 168 | file_name="${DST}/$file_name" | ||
| 169 | keystone-identity_chefsolo_template $file_name | ||
| 170 | fi | ||
| 171 | } | ||
| 172 | make_glance_templates(){ | ||
| 173 | file_name=glance-api.conf | ||
| 174 | if [ -f ${SRC}/$file_name ]; then | ||
| 175 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 176 | file_name="${DST}/$file_name" | ||
| 177 | glance_chefsolo_template $file_name | ||
| 178 | fi | ||
| 179 | |||
| 180 | file_name=glance-cache.conf | ||
| 181 | if [ -f ${SRC}/$file_name ]; then | ||
| 182 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 183 | file_name="${DST}/$file_name" | ||
| 184 | glance_chefsolo_template $file_name | ||
| 185 | fi | ||
| 186 | file_name=glance-registry.conf | ||
| 187 | if [ -f ${SRC}/$file_name ]; then | ||
| 188 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 189 | file_name="${DST}/$file_name" | ||
| 190 | glance_chefsolo_template $file_name | ||
| 191 | fi | ||
| 192 | } | ||
| 193 | |||
| 194 | make_ceilometer_templates(){ | ||
| 195 | |||
| 196 | file_name=ceilometer.conf | ||
| 197 | if [ -f ${SRC}/$file_name ]; then | ||
| 198 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 199 | file_name="${DST}/$file_name" | ||
| 200 | ceilometer-conf_chefsolo_template $file_name | ||
| 201 | fi | ||
| 202 | } | ||
| 203 | |||
| 204 | make_postgresql_templates(){ | ||
| 205 | |||
| 206 | file_name=postgresql-init | ||
| 207 | if [ -f ${SRC}/$file_name ]; then | ||
| 208 | install -m 0644 ${SRC}/$file_name ${DST} | ||
| 209 | file_name="${DST}/$file_name" | ||
| 210 | postgresql_chefsolo_template $file_name | ||
| 211 | fi | ||
| 212 | } | ||
| 213 | |||
| 214 | |||
| 215 | #This function installs the config/script files of services | ||
| 216 | #and converts them into templates. | ||
| 217 | services-conf_make_templates(){ | ||
| 218 | for mod in ${service_list}; do | ||
| 219 | if [ -d ${D}/$mod ]; then | ||
| 220 | SRC=${D}/$mod | ||
| 221 | DST=${TEMPLATES} | ||
| 222 | case $mod in | ||
| 223 | ceph) | ||
| 224 | #Copy ceph configuration files and convert them to templates | ||
| 225 | make_ceph_templates | ||
| 226 | ;; | ||
| 227 | swift) | ||
| 228 | #Copy swift configuration files and convert them into | ||
| 229 | #chefsolo templates | ||
| 230 | make_swift_templates | ||
| 231 | |||
| 232 | ;; | ||
| 233 | nova) | ||
| 234 | #Copy nova configuration files and convert them into | ||
| 235 | #chefsolo templates | ||
| 236 | make_nova_templates | ||
| 237 | ;; | ||
| 238 | neutron) | ||
| 239 | #Copy neutron configuration files and convert them into | ||
| 240 | #chefsolo templates | ||
| 241 | make_neutron_templates | ||
| 242 | ;; | ||
| 243 | heat) | ||
| 244 | make_heat_templates | ||
| 245 | ;; | ||
| 246 | cinder) | ||
| 247 | make_cinder_templates | ||
| 248 | ;; | ||
| 249 | keystone) | ||
| 250 | make_keystone_templates | ||
| 251 | ;; | ||
| 252 | glance) | ||
| 253 | #Copy glance configuration files and convert them into | ||
| 254 | #chefsolo templates | ||
| 255 | make_glance_templates | ||
| 256 | ;; | ||
| 257 | ceilometer) | ||
| 258 | make_ceilometer_templates | ||
| 259 | ;; | ||
| 260 | init.d) | ||
| 261 | make_postgresql_templates | ||
| 262 | ;; | ||
| 263 | *) | ||
| 264 | ;; | ||
| 265 | esac | ||
| 266 | echo "Service present in $mod" | ||
| 267 | fi | ||
| 268 | done | ||
| 269 | } | ||
| 270 | |||
| 271 | install -d ${TEMPLATES} | ||
| 272 | postinsts_make_templates | ||
| 273 | etc-hosts_make_templates | ||
| 274 | services-conf_make_templates | ||
