Sha256: 85e1b0686d130d4daa465f79db30ec3fc01fe2617ac04b4846c976da9c0cd5f2

Contents?: true

Size: 1.66 KB

Versions: 1

Compression:

Stored size: 1.66 KB

Contents

# Description: Chef-Vault EncryptRotateKeys class
# Copyright 2013, 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'
require 'chef-vault'

class EncryptRotateKeys < Chef::Knife
  deps do
    require 'chef/search/query'
    require File.expand_path('../mixin/compat', __FILE__)
    require File.expand_path('../mixin/helper', __FILE__)
    include ChefVault::Mixin::KnifeCompat
    include ChefVault::Mixin::Helper
  end

  banner "knife encrypt rotate keys VAULT ITEM --mode MODE"

  option :mode,
    :short => '-M MODE',
    :long => '--mode MODE',
    :description => 'Chef mode to run in default - solo'

  def run
    vault = @name_args[0]
    item = @name_args[1]

    if vault && item
      set_mode(config[:mode])

      begin
        item = ChefVault::Item.load(vault, item)
        item.rotate_keys!
      rescue ChefVault::Exceptions::KeysNotFound,
             ChefVault::Exceptions::ItemNotFound

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

  def show_usage
    super
    exit 1
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
chef-vault-2.1.0 lib/chef/knife/encrypt_rotate_keys.rb