Sha256: 3d63c8826a8e9142ebc6b4389cc60f2e884bc0037d254630bf50bb15957dd97d

Contents?: true

Size: 1.84 KB

Versions: 7

Compression:

Stored size: 1.84 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 "chef/knife/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

7 entries across 7 versions & 1 rubygems

Version Path
chef-vault-3.4.0.pre.pre430 lib/chef/knife/vault_refresh.rb
chef-vault-3.4.0.pre.pre427 lib/chef/knife/vault_refresh.rb
chef-vault-3.4.0.pre.pre420 lib/chef/knife/vault_refresh.rb
chef-vault-3.4.0.pre.pre417 lib/chef/knife/vault_refresh.rb
chef-vault-3.3.0 lib/chef/knife/vault_refresh.rb
chef-vault-3.3.0.pre.pre415 lib/chef/knife/vault_refresh.rb
chef-vault-3.3.0.pre.pre416 lib/chef/knife/vault_refresh.rb