class LicenseAcceptance::Strategy::File

Read and write marker files that show acceptance.

def accepted?(product_relationship)

license acceptance files.
For all the given products in the product set, search all possible locations for the
def accepted?(product_relationship)
  searching = [product_relationship.parent] + product_relationship.children
  missing_licenses = searching.clone
  logger.debug("Searching for the following licenses: #{missing_licenses.map(&:id)}")
  searching.each do |product|
    found = false
    config.license_locations.each do |loc|
      f = ::File.join(loc, product.filename)
      if ::File.exist?(f)
        found = true
        logger.debug("Found license #{product.filename} at #{f}")
        missing_licenses.delete(product)
        break
      end
    end
    break if missing_licenses.empty?
  end
  logger.debug("Missing licenses remaining: #{missing_licenses.map(&:id)}")
  missing_licenses
end

def initialize(config)

def initialize(config)
  @config = config
end

def persist(product_relationship, missing_licenses)

def persist(product_relationship, missing_licenses)
  parent = product_relationship.parent
  parent_version = product_relationship.parent_version
  root_dir = config.persist_location
  if !Dir.exist?(root_dir)
    begin
      FileUtils.mkdir_p(root_dir)
    rescue StandardError => e
      msg = "Could not create license directory #{root_dir}"
      logger.info "#{msg}\n\t#{e.message}\n\t#{e.backtrace.join("\n\t")}"
      return [e]
    end
  end
  errs = []
  if missing_licenses.include?(parent)
    err = persist_license(root_dir, parent, parent, parent_version)
    errs << err unless err.nil?
  end
  product_relationship.children.each do |child|
    if missing_licenses.include?(child)
      err = persist_license(root_dir, child, parent, parent_version)
      errs << err unless err.nil?
    end
  end
  return errs
end

def persist_license(folder_path, product, parent, parent_version)

def persist_license(folder_path, product, parent, parent_version)
  path = ::File.join(folder_path, product.filename)
  logger.info("Persisting a license for #{product.pretty_name} at path #{path}")
  ::File.open(path, ::File::WRONLY | ::File::CREAT | ::File::EXCL) do |license_file|
    contents = {
      id: product.id,
      name: product.pretty_name,
      date_accepted: INVOCATION_TIME.iso8601,
      accepting_product: parent.id,
      accepting_product_version: parent_version,
      user: Etc.getlogin,
      file_format: 1,
    }
    contents = Hash[contents.map { |k, v| [k.to_s, v] }]
    license_file << YAML.dump(contents)
  end
  return nil
rescue StandardError => e
  msg = "Could not persist license to #{path}"
  logger.info "#{msg}\n\t#{e.message}\n\t#{e.backtrace.join("\n\t")}"
  return e
end