Class: PDK::Module::Metadata

Inherits:
Object
  • Object
show all
Defined in:
lib/pdk/module/metadata.rb

Constant Summary collapse

OPERATING_SYSTEMS =
{
  'RedHat based Linux' => [
    {
      'operatingsystem'        => 'CentOS',
      'operatingsystemrelease' => ['7'],
    },
    {
      'operatingsystem'        => 'OracleLinux',
      'operatingsystemrelease' => ['7'],
    },
    {
      'operatingsystem'        => 'RedHat',
      'operatingsystemrelease' => ['8'],
    },
    {
      'operatingsystem'        => 'Scientific',
      'operatingsystemrelease' => ['7'],
    },
  ],
  'Debian based Linux' => [
    {
      'operatingsystem'        => 'Debian',
      'operatingsystemrelease' => ['9'],
    },
    {
      'operatingsystem'        => 'Ubuntu',
      'operatingsystemrelease' => ['18.04'],
    },
  ],
  'Fedora' => {
    'operatingsystem'        => 'Fedora',
    'operatingsystemrelease' => ['29'],
  },
  'OSX' => {
    'operatingsystem'        => 'Darwin',
    'operatingsystemrelease' => ['16'],
  },
  'SLES' => {
    'operatingsystem'        => 'SLES',
    'operatingsystemrelease' => ['15'],
  },
  'Solaris' => {
    'operatingsystem'        => 'Solaris',
    'operatingsystemrelease' => ['11'],
  },
  'Windows' => {
    'operatingsystem'        => 'windows',
    'operatingsystemrelease' => %w[2019 10],
  },
}.freeze
DEFAULT_OPERATING_SYSTEMS =
[
  'RedHat based Linux',
  'Debian based Linux',
  'Windows',
].freeze
DEFAULTS =
{
  'name'          => nil,
  'version'       => '0.1.0',
  'author'        => nil,
  'summary'       => '',
  'license'       => 'Apache-2.0',
  'source'        => '',
  'project_page'  => nil,
  'issues_url'    => nil,
  'dependencies'  => [],
  'data_provider' => nil,
  'operatingsystem_support' => DEFAULT_OPERATING_SYSTEMS.map { |os_name|
    OPERATING_SYSTEMS[os_name]
  }.flatten,
  'requirements' => [
    { 'name' => 'puppet', 'version_requirement' => '>= 4.10.0 < 7.0.0' },
  ],
}.freeze

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(params = {}) ⇒ Metadata

Returns a new instance of Metadata.



84
85
86
87
# File 'lib/pdk/module/metadata.rb', line 84

def initialize(params = {})
  @data = DEFAULTS.dup
  update!(params) if params
end

Instance Attribute Details

#dataObject

Returns the value of attribute data.



6
7
8
# File 'lib/pdk/module/metadata.rb', line 6

def data
  @data
end

Class Method Details

.from_file(metadata_json_path) ⇒ Object



89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# File 'lib/pdk/module/metadata.rb', line 89

def self.from_file()
  if .nil?
    raise ArgumentError, _('Cannot read metadata from file: no path to file was given.')
  end

  unless PDK::Util::Filesystem.file?()
    raise ArgumentError, _("'%{file}' does not exist or is not a file.") % { file:  }
  end

  unless PDK::Util::Filesystem.readable?()
    raise ArgumentError, _("Unable to open '%{file}' for reading.") % { file:  }
  end

  require 'json'
  begin
    data = JSON.parse(PDK::Util::Filesystem.read_file())
  rescue JSON::JSONError => e
    raise ArgumentError, _('Invalid JSON in metadata.json: %{msg}') % { msg: e.message }
  end

  require 'pdk/util'
  data['template-url'] = PDK::Util::TemplateURI.default_template_uri. if PDK::Util.package_install? && data['template-url'] == PDK::Util::TemplateURI::PACKAGED_TEMPLATE_KEYWORD
  new(data)
end

Instance Method Details

#forge_ready?Boolean

Returns:

  • (Boolean)


131
132
133
# File 'lib/pdk/module/metadata.rb', line 131

def forge_ready?
  missing_fields.empty?
end

#interview_for_forge!Object



135
136
137
138
139
# File 'lib/pdk/module/metadata.rb', line 135

def interview_for_forge!
  require 'pdk/generate/module'

  PDK::Generate::Module.module_interview(self, only_ask: missing_fields)
end

#missing_fieldsObject



160
161
162
163
# File 'lib/pdk/module/metadata.rb', line 160

def missing_fields
  fields = DEFAULTS.keys - %w[data_provider requirements dependencies]
  fields.select { |key| @data[key].nil? || @data[key].empty? }
end

#puppet_requirementObject



154
155
156
157
158
# File 'lib/pdk/module/metadata.rb', line 154

def puppet_requirement
  @data['requirements'].find do |r|
    r.key?('name') && r['name'] == 'puppet'
  end
end

#to_jsonObject



121
122
123
124
125
# File 'lib/pdk/module/metadata.rb', line 121

def to_json
  require 'json'

  JSON.pretty_generate(@data.dup.delete_if { |_key, value| value.nil? })
end

#update!(data) ⇒ Object



114
115
116
117
118
119
# File 'lib/pdk/module/metadata.rb', line 114

def update!(data)
  # TODO: validate all data
  process_name(data) if data['name']
  @data.merge!(data)
  self
end

#validate_puppet_version_requirement!Object

Raises:

  • (ArgumentError)


141
142
143
144
145
146
147
148
149
150
151
152
# File 'lib/pdk/module/metadata.rb', line 141

def validate_puppet_version_requirement!
  msgs = {
    no_reqs:       _('Module metadata does not contain any requirements.'),
    no_puppet_req: _('Module metadata does not contain a "puppet" requirement.'),
    no_puppet_ver: _('The "puppet" requirement in module metadata does not specify a "version_requirement".'),
  }

  raise ArgumentError, msgs[:no_reqs] unless @data.key?('requirements')
  raise ArgumentError, msgs[:no_puppet_req] if puppet_requirement.nil?
  raise ArgumentError, msgs[:no_puppet_ver] unless puppet_requirement.key?('version_requirement')
  raise ArgumentError, msgs[:no_puppet_ver] if puppet_requirement['version_requirement'].empty?
end

#write!(path) ⇒ Object



127
128
129
# File 'lib/pdk/module/metadata.rb', line 127

def write!(path)
  PDK::Util::Filesystem.write_file(path, to_json)
end