Class: SecretConfig::CLI

Inherits:
Object
  • Object
show all
Defined in:
lib/secret_config/cli.rb

Constant Summary collapse

PROVIDERS =
%i[ssm].freeze

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(argv) ⇒ CLI

Returns a new instance of CLI.



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/secret_config/cli.rb', line 24

def initialize(argv)
  @export       = false
  @import       = false
  @path         = nil
  @key_id       = nil
  @region       = ENV['AWS_REGION']
  @provider     = :ssm
  @random_size  = 32
  @no_filter    = false
  @prune        = false
  @replace      = false
  @copy_path    = nil
  @show_version = false
  @console      = false
  @diff         = false

  if argv.empty?
    puts parser
    exit(-10)
  end
  parser.parse!(argv)
end

Instance Attribute Details

#consoleObject (readonly)

Returns the value of attribute console.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def console
  @console
end

#copy_pathObject (readonly)

Returns the value of attribute copy_path.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def copy_path
  @copy_path
end

#diffObject (readonly)

Returns the value of attribute diff.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def diff
  @diff
end

#exportObject (readonly)

Returns the value of attribute export.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def export
  @export
end

#importObject (readonly)

Returns the value of attribute import.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def import
  @import
end

#key_idObject (readonly)

Returns the value of attribute key_id.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def key_id
  @key_id
end

#no_filterObject (readonly)

Returns the value of attribute no_filter.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def no_filter
  @no_filter
end

#overwriteObject (readonly)

Returns the value of attribute overwrite.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def overwrite
  @overwrite
end

#pathObject (readonly)

Returns the value of attribute path.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def path
  @path
end

#providerObject (readonly)

Returns the value of attribute provider.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def provider
  @provider
end

#pruneObject (readonly)

Returns the value of attribute prune.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def prune
  @prune
end

#random_sizeObject (readonly)

Returns the value of attribute random_size.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def random_size
  @random_size
end

#regionObject (readonly)

Returns the value of attribute region.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def region
  @region
end

#show_versionObject (readonly)

Returns the value of attribute show_version.



11
12
13
# File 'lib/secret_config/cli.rb', line 11

def show_version
  @show_version
end

Class Method Details

.run!(argv) ⇒ Object



20
21
22
# File 'lib/secret_config/cli.rb', line 20

def self.run!(argv)
  new(argv).run!
end

Instance Method Details

#parserObject



68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
# File 'lib/secret_config/cli.rb', line 68

def parser
  @parser ||= OptionParser.new do |opts|
    opts.banner = <<~BANNER
      Secret Config v#{VERSION}

        For more information, see: https://rocketjob.github.io/secret_config/

      secret_config [options]
    BANNER

    opts.on '-e', '--export [FILE_NAME]', 'Export configuration to a file or stdout if no file_name supplied.' do |file_name|
      @export = file_name || STDOUT
    end

    opts.on '-i', '--import [FILE_NAME]', 'Import configuration from a file or stdin if no file_name supplied.' do |file_name|
      @import = file_name || STDIN
    end

    opts.on '--copy SOURCE_PATH', 'Import configuration from a file or stdin if no file_name supplied.' do |path|
      @copy_path = path
    end

    opts.on '--diff [FILE_NAME]', 'Compare configuration from a file or stdin if no file_name supplied.' do |file_name|
      @diff = file_name
    end

    opts.on '-c', '--console', 'Start interactive console.' do
      @console = true
    end

    opts.on '-p', '--path PATH', 'Path to import from / export to.' do |path|
      @path = path
    end

    opts.on '--provider PROVIDER', 'Provider to use. [ssm | file]. Default: ssm' do |provider|
      @provider = provider.to_sym
    end

    opts.on '--no-filter', 'Do not filter passwords and keys.' do
      @no_filter = true
    end

    opts.on '--prune', 'During import delete all existing keys for which there is no key in the import file.' do
      @prune = true
    end

    opts.on '--key_id KEY_ID', 'Encrypt config settings with this AWS KMS key id. Default: AWS Default key.' do |key_id|
      @key_id = key_id
    end

    opts.on '--key_alias KEY_ALIAS', 'Encrypt config settings with this AWS KMS alias.' do |key_alias|
      if key_alias =~ /^alias\//
        @key_id = key_alias
      else
        @key_id = "alias/#{key_alias}"
      end
    end

    opts.on '--region REGION', 'AWS Region to use. Default: AWS_REGION env var.' do |region|
      @region = region
    end

    opts.on '--random_size INTEGER', Integer, 'Size to use when generating random values. Whenever $random is encountered during an import. Default: 32' do |region|
      @random_size = random_size
    end

    opts.on '-v', '--version', 'Display Symmetric Encryption version.' do
      @show_version = true
    end

    opts.on('-h', '--help', 'Prints this help.') do
      puts opts
      exit
    end
  end
end

#run!Object



47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/secret_config/cli.rb', line 47

def run!
  if show_version
    puts "Secret Config v#{VERSION}"
    puts "Region: #{region}"
  elsif console
    run_console
  elsif export
    run_export(export, filtered: !no_filter)
  elsif import && prune
    run_import_and_prune(import)
  elsif import
    run_import(import)
  elsif copy_path
    run_copy(copy_path, path)
  elsif diff
    run_diff(diff)
  else
    puts parser
  end
end