class Chef::Knife::VaultUpdate

Public Instance Methods

run() click to toggle source
# File lib/chef/knife/vault_update.rb, line 65
def run
  vault = @name_args[0]
  item = @name_args[1]
  values = @name_args[2]
  search = config[:search]
  json_file = config[:json]
  file = config[:file]
  clean = config[:clean]
  keys_mode = config[:keys_mode]

  set_mode(config[:vault_mode])

  if vault && item && ((values || json_file || file) || (search || clients || admins) || (keys_mode))
    begin
      vault_item = ChefVault::Item.load(vault, item)

      # Keys management first
      if clean
        vault_clients = vault_item.get_clients.clone.sort
        vault_clients.each do |client|
          ui.info "Deleting #{client}"
          vault_item.delete_client(client)
        end
      end

      vault_item.search(search) if search
      vault_item.clients if search
      vault_item.clients(clients) if clients
      vault_item.admins(admins) if admins

      # Save only the keys if no value is provided, otherwise save the item
      if values || json_file || file
        merge_values(values, json_file).each do |key, value|
          vault_item[key] = value
        end

        if file
          vault_item["file-name"] = File.basename(file)
          vault_item["file-content"] = File.open(file, &:read)
        end

        vault_item.save
      else
        vault_item.save_keys
      end

    rescue ChefVault::Exceptions::KeysNotFound,
           ChefVault::Exceptions::ItemNotFound
      raise ChefVault::Exceptions::ItemNotFound,
        "#{vault}/#{item} does not exist, "\
        "use 'knife vault create' to create."
    end

    if keys_mode
      vault_item.mode(keys_mode)
      vault_item.save_keys
    end
  else
    show_usage
  end
end