D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
td-agent
/
embedded
/
lib
/
ruby
/
gems
/
2.1.0
/
gems
/
ohai-6.20.0
/
lib
/
ohai
/
plugins
/
Filename :
rackspace.rb
back
Copy
# # Author:: Cary Penniman (<cary@rightscale.com>) # License:: Apache License, Version 2.0 # # 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. provides "rackspace" require_plugin "kernel" require_plugin "network" # Checks for matching rackspace kernel name # # === Return # true:: If kernel name matches # false:: Otherwise def has_rackspace_kernel? kernel[:release].split('-').last.eql?("rscloud") end # Checks for rackspace provider attribute # # === Return # true:: If rackspace provider attribute found # false:: Otherwise def has_rackspace_metadata? status, stdout, stderr = run_command(:no_status_check => true, :command => "xenstore-read vm-data/provider_data/provider") if status == 0 stdout.strip.downcase == 'rackspace' end rescue Ohai::Exceptions::Exec false end # Identifies the rackspace cloud # # === Return # true:: If the rackspace cloud can be identified # false:: Otherwise def looks_like_rackspace? hint?('rackspace') || has_rackspace_metadata? || has_rackspace_kernel? end # Names rackspace ip address # # === Parameters # name<Symbol>:: Use :public_ip or :private_ip # eth<Symbol>:: Interface name of public or private ip def get_ip_address(name, eth) network[:interfaces][eth][:addresses].each do |key, info| if info['family'] == 'inet' rackspace[name] = key break # break when we found an address end end end # Names rackspace ipv6 address for interface # # === Parameters # name<Symbol>:: Use :public_ip or :private_ip # eth<Symbol>:: Interface name of public or private ip def get_global_ipv6_address(name, eth) network[:interfaces][eth][:addresses].each do |key, info| # check if we got an ipv6 address and if its in global scope if info['family'] == 'inet6' && info['scope'] == 'Global' rackspace[name] = key break # break when we found an address end end end # Get the rackspace region # def get_region() status, stdout, stderr = run_command(:no_status_check => true, :command => "xenstore-ls vm-data/provider_data") if status == 0 stdout.split("\n").each do |line| rackspace[:region] = line.split[2].delete('\"') if line =~ /^region/ end end rescue Ohai::Exceptions::Exec Ohai::Log.debug("Unable to find xenstore-ls, cannot capture region information for Rackspace cloud") end # Adds rackspace Mash if looks_like_rackspace? rackspace Mash.new get_ip_address(:public_ip, :eth0) get_ip_address(:private_ip, :eth1) get_region() # public_ip + private_ip are deprecated in favor of public_ipv4 and local_ipv4 to standardize. rackspace[:public_ipv4] = rackspace[:public_ip] get_global_ipv6_address(:public_ipv6, :eth0) rackspace[:public_hostname] = "#{rackspace[:public_ip].gsub('.','-')}.static.cloud-ips.com" rackspace[:local_ipv4] = rackspace[:private_ip] get_global_ipv6_address(:local_ipv6, :eth1) rackspace[:local_hostname] = hostname end