# # Author:: Matt Ray () # Copyright:: Copyright (c) 2012-2016 Chef Software, Inc. # 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. require "ohai/mixin/ec2_metadata" Ohai.plugin(:Openstack) do provides "openstack" include Ohai::Mixin::Ec2Metadata def collect_openstack_metadata(addr = Ohai::Mixin::Ec2Metadata::EC2_METADATA_ADDR, api_version = "2013-04-04") path = "/openstack/#{api_version}/meta_data.json" uri = "http://#{addr}#{path}" begin response = http_client.get_response(URI.parse(uri), nil, nil) case response.code when "200" FFI_Yajl::Parser.parse(response.body) when "404" Ohai::Log.debug("Encountered 404 response retreiving OpenStack specific metadata path: #{path} ; continuing.") nil else raise "Encountered error retrieving OpenStack specific metadata (#{path} returned #{response.code} response)" end rescue => e Ohai::Log.debug("Encountered error retrieving OpenStack specific metadata (#{uri}), due to #{e.class}") nil end end collect_data do # Adds openstack Mash if hint?("openstack") || hint?("hp") Ohai::Log.debug("ohai openstack") if can_metadata_connect?(Ohai::Mixin::Ec2Metadata::EC2_METADATA_ADDR, 80) openstack Mash.new Ohai::Log.debug("connecting to the OpenStack metadata service") fetch_metadata.each { |k, v| openstack[k] = v } if hint?("hp") openstack["provider"] = "hp" else openstack["provider"] = "openstack" Ohai::Log.debug("connecting to the OpenStack specific metadata service") openstack["metadata"] = collect_openstack_metadata end else Ohai::Log.debug("unable to connect to the OpenStack metadata service") end else Ohai::Log.debug("NOT ohai openstack") end end end