Sha256: dcd6753e84218160fa5afab3e88f570441c9044690170ceee65260271e2befd7

Contents?: true

Size: 1.82 KB

Versions: 11

Compression:

Stored size: 1.82 KB

Contents

# Description: Chef-Vault VaultReapply class
# Copyright 2013-15, Nordstrom, Inc.

# 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_relative "vault_base"

class Chef
  class Knife
    class VaultRefresh < Knife
      include Chef::Knife::VaultBase

      banner "knife vault refresh VAULT ITEM"

      option :clean_unknown_clients,
        long: "--clean-unknown-clients",
        description: "Remove unknown clients during refresh"

      option :skip_reencryption,
        long: "--skip-reencryption",
        description: "Skip reencrypt symetrical key for existing clients/admins."

      def run
        vault = @name_args[0]
        item = @name_args[1]
        clean = config[:clean_unknown_clients]
        skip_reencryption = config[:skip_reencryption]

        set_mode(config[:vault_mode])

        if vault && item
          begin
            vault_item = ChefVault::Item.load(vault, item)
            vault_item.skip_reencryption = skip_reencryption
            vault_item.refresh(clean)
          rescue ChefVault::Exceptions::KeysNotFound,
                 ChefVault::Exceptions::ItemNotFound

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

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
chef-vault-4.1.11 lib/chef/knife/vault_refresh.rb
chef-vault-4.1.10 lib/chef/knife/vault_refresh.rb
chef-vault-4.1.5 lib/chef/knife/vault_refresh.rb
chef-vault-4.1.4 lib/chef/knife/vault_refresh.rb
chef-vault-4.1.3 lib/chef/knife/vault_refresh.rb
chef-vault-4.1.0 lib/chef/knife/vault_refresh.rb
chef-vault-4.0.12 lib/chef/knife/vault_refresh.rb
chef-vault-4.0.11 lib/chef/knife/vault_refresh.rb
chef-vault-4.0.10 lib/chef/knife/vault_refresh.rb
chef-vault-4.0.6 lib/chef/knife/vault_refresh.rb
chef-vault-4.0.1 lib/chef/knife/vault_refresh.rb