blob: 19e85a00644446fc2aad44f345db5b3d7b8f2f00 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
# frozen_string_literal: true
#
# Author:: Serdar Sutay (<serdar@chef.io>)
# Copyright:: Copyright (c) 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 "ffi_yajl" unless defined?(FFI_Yajl)
module Ohai
# Ohai hints are json files on disk that give ohai a hint to things that are often
# difficult to discover like certain clouds. Previously they were used for just about
# every cloud, but we've since discoverd better ways to auto-detect these clouds.
# They are generally dropped off by the knife plugins for those clouds during bootstrap,
# but may also be manually dropped off and consumed by 3rd party plugins.
module Hints
# clear out any known hints in the @hints variable
def self.refresh_hints
@hints = {}
end
# parse the JSON contents of a hint file. Return an empty hash if the file has
# no JSON content
# @param filename [String] the hint file path
def self.parse_hint_file(filename)
json_parser = FFI_Yajl::Parser.new
hash = json_parser.parse(File.read(filename))
hash || {} # hint
# should exist because the file did, even if it didn't
# contain anything
rescue FFI_Yajl::ParseError => e
Ohai::Log.error("Could not parse hint file at #{filename}: #{e.message}")
end
# retrieve hint contents given a hint name. Looks up in @hints variable first. Attempts
# to load from file in config's :hints_path if not already cached. Saves the contents
# to the hash if the file was successfully parsed
# @param name [String] the name of the hint (not the path)
def self.hint?(name)
@hints ||= {}
return @hints[name] if @hints[name]
Ohai.config[:hints_path].each do |path|
filename = File.join(path, "#{name}.json")
next unless File.exist?(filename)
Ohai::Log.trace("Found hint #{name}.json at #{filename}")
@hints[name] = parse_hint_file(filename)
end
Ohai::Log.trace("Did not find hint #{name}.json in the hint path(s): #{Ohai.config[:hints_path].join(", ")} ") unless @hints.key?(name)
@hints[name]
end
end
end
|