f9a39de95aa686b9c6726a32b7661e33c942d687
[mirror/dsa-puppet.git] / 3rdparty / modules / stdlib / lib / puppet / parser / functions / load_module_metadata.rb
1 #
2 # load_module_metadata.rb
3 #
4 module Puppet::Parser::Functions
5   newfunction(:load_module_metadata, :type => :rvalue, :doc => <<-DOC
6     This function loads the metadata of a given module.
7   DOC
8              ) do |args|
9     raise(Puppet::ParseError, 'load_module_metadata(): Wrong number of arguments, expects one or two') unless [1, 2].include?(args.size)
10     mod = args[0]
11     allow_empty_metadata = args[1]
12     module_path = function_get_module_path([mod])
13     metadata_json = File.join(module_path, 'metadata.json')
14
15     metadata_exists = File.exists?(metadata_json) # rubocop:disable Lint/DeprecatedClassMethods : Changing to .exist? breaks the code
16     if metadata_exists
17       metadata = PSON.load(File.read(metadata_json))
18     else
19       metadata = {}
20       raise(Puppet::ParseError, "load_module_metadata(): No metadata.json file for module #{mod}") unless allow_empty_metadata
21     end
22
23     return metadata
24   end
25 end