ruby-terraform 0.65.0.pre.10 → 0.65.0.pre.15
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +18 -10
- data/README.md +2 -19
- data/lib/ruby_terraform.rb +691 -18
- data/lib/ruby_terraform/commands/apply.rb +75 -1
- data/lib/ruby_terraform/commands/base.rb +18 -15
- data/lib/ruby_terraform/commands/destroy.rb +67 -1
- data/lib/ruby_terraform/commands/force_unlock.rb +28 -0
- data/lib/ruby_terraform/commands/format.rb +39 -0
- data/lib/ruby_terraform/commands/get.rb +31 -0
- data/lib/ruby_terraform/commands/graph.rb +38 -0
- data/lib/ruby_terraform/commands/import.rb +95 -1
- data/lib/ruby_terraform/commands/init.rb +72 -1
- data/lib/ruby_terraform/commands/login.rb +24 -0
- data/lib/ruby_terraform/commands/logout.rb +21 -0
- data/lib/ruby_terraform/commands/output.rb +34 -4
- data/lib/ruby_terraform/commands/plan.rb +67 -1
- data/lib/ruby_terraform/commands/providers.rb +22 -0
- data/lib/ruby_terraform/commands/providers_lock.rb +66 -0
- data/lib/ruby_terraform/commands/providers_mirror.rb +42 -0
- data/lib/ruby_terraform/commands/taint.rb +2 -1
- data/lib/ruby_terraform/options.rb +25 -3
- data/lib/ruby_terraform/options/common.rb +1 -0
- data/lib/ruby_terraform/options/definition.rb +172 -0
- data/lib/ruby_terraform/options/definitions.rb +103 -0
- data/lib/ruby_terraform/options/factory.rb +10 -102
- data/lib/ruby_terraform/options/name.rb +11 -19
- data/lib/ruby_terraform/options/types.rb +27 -0
- data/lib/ruby_terraform/options/types/base.rb +6 -13
- data/lib/ruby_terraform/options/types/flag.rb +1 -3
- data/lib/ruby_terraform/options/types/standard.rb +1 -27
- data/lib/ruby_terraform/options/values.rb +38 -0
- data/lib/ruby_terraform/options/values/base.rb +15 -0
- data/lib/ruby_terraform/options/values/boolean.rb +13 -11
- data/lib/ruby_terraform/options/values/complex.rb +19 -0
- data/lib/ruby_terraform/options/values/key_value.rb +21 -0
- data/lib/ruby_terraform/options/values/string.rb +17 -0
- data/lib/ruby_terraform/version.rb +1 -1
- data/ruby_terraform.gemspec +3 -1
- metadata +40 -5
- data/lib/ruby_terraform/options/types/boolean.rb +0 -18
@@ -1,118 +1,26 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require_relative 'name'
|
4
|
-
require_relative 'types/boolean'
|
5
|
-
require_relative 'types/flag'
|
6
|
-
require_relative 'types/standard'
|
7
4
|
|
8
5
|
module RubyTerraform
|
9
6
|
module Options
|
10
7
|
class Factory
|
11
|
-
|
12
|
-
|
13
|
-
%w[
|
14
|
-
-var
|
15
|
-
-target
|
16
|
-
-var-file
|
17
|
-
-platform
|
18
|
-
]
|
19
|
-
).freeze
|
20
|
-
|
21
|
-
BOOLEAN_OPTIONS =
|
22
|
-
Set.new(
|
23
|
-
%w[
|
24
|
-
-auto-approve
|
25
|
-
-backend
|
26
|
-
-get
|
27
|
-
-get-plugins
|
28
|
-
-input
|
29
|
-
-list
|
30
|
-
-lock
|
31
|
-
-refresh
|
32
|
-
-upgrade
|
33
|
-
-verify-plugins
|
34
|
-
-write
|
35
|
-
]
|
36
|
-
).freeze
|
37
|
-
|
38
|
-
FLAG_OPTIONS =
|
39
|
-
Set.new(
|
40
|
-
%w[
|
41
|
-
-allow-missing
|
42
|
-
-allow-missing-config
|
43
|
-
-check
|
44
|
-
-compact-warnings
|
45
|
-
-destroy
|
46
|
-
-detailed-exitcode
|
47
|
-
-diff
|
48
|
-
-draw-cycles
|
49
|
-
-force
|
50
|
-
-force-copy
|
51
|
-
-ignore-remote-version
|
52
|
-
-json
|
53
|
-
-no-color
|
54
|
-
-raw
|
55
|
-
-reconfigure
|
56
|
-
-recursive
|
57
|
-
-update
|
58
|
-
]
|
59
|
-
).freeze
|
60
|
-
|
61
|
-
OVERRIDE_OPTIONS =
|
62
|
-
{
|
63
|
-
config: :directory,
|
64
|
-
out: :plan
|
65
|
-
}.freeze
|
66
|
-
|
67
|
-
def self.from(names, parameters)
|
68
|
-
new(names, parameters).from
|
69
|
-
end
|
70
|
-
|
71
|
-
private_class_method :new
|
72
|
-
|
73
|
-
def initialize(names, parameters)
|
74
|
-
@names = names.map { |name| Name.new(name) }
|
75
|
-
@parameters = parameters
|
8
|
+
def initialize(definitions)
|
9
|
+
@definitions = definitions
|
76
10
|
end
|
77
11
|
|
78
|
-
def
|
79
|
-
names
|
80
|
-
|
81
|
-
|
12
|
+
def resolve(names, parameters)
|
13
|
+
names
|
14
|
+
.map { |name| Name.new(name) }
|
15
|
+
.inject([]) do |options, name|
|
16
|
+
options + resolve_name(name, parameters)
|
17
|
+
end
|
82
18
|
end
|
83
19
|
|
84
20
|
private
|
85
21
|
|
86
|
-
|
87
|
-
|
88
|
-
def options_from_name(name)
|
89
|
-
return plural_options(name) if PLURAL_OPTIONS.include?(name)
|
90
|
-
return boolean_option(name) if BOOLEAN_OPTIONS.include?(name)
|
91
|
-
return flag_option(name) if FLAG_OPTIONS.include?(name)
|
92
|
-
return override_option(name) if OVERRIDE_OPTIONS.key?(name.as_key)
|
93
|
-
|
94
|
-
standard_option(name, name.as_key)
|
95
|
-
end
|
96
|
-
|
97
|
-
def boolean_option(name)
|
98
|
-
[Types::Boolean.new(name.to_s, parameters[name.as_key])]
|
99
|
-
end
|
100
|
-
|
101
|
-
def flag_option(name)
|
102
|
-
[Types::Flag.new(name.to_s, parameters[name.as_key])]
|
103
|
-
end
|
104
|
-
|
105
|
-
def standard_option(name, hash_key)
|
106
|
-
[Types::Standard.new(name.to_s, parameters[hash_key])]
|
107
|
-
end
|
108
|
-
|
109
|
-
def override_option(name)
|
110
|
-
standard_option(name, OVERRIDE_OPTIONS[name.as_key])
|
111
|
-
end
|
112
|
-
|
113
|
-
def plural_options(name)
|
114
|
-
standard_option(name.to_s, name.as_key) +
|
115
|
-
standard_option(name.to_s, name.as_plural_key)
|
22
|
+
def resolve_name(name, parameters)
|
23
|
+
@definitions.find { |d| d.matches?(name) }.build(parameters)
|
116
24
|
end
|
117
25
|
end
|
118
26
|
end
|
@@ -1,21 +1,21 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
require 'immutable-struct'
|
4
|
+
|
3
5
|
module RubyTerraform
|
4
6
|
module Options
|
5
|
-
class Name
|
7
|
+
class Name < ImmutableStruct.new(:name)
|
6
8
|
def initialize(name)
|
7
|
-
|
8
|
-
end
|
9
|
-
|
10
|
-
def without_prefix
|
11
|
-
@name[0] == '-' ? @name[1..] : @name
|
9
|
+
super(name: name.to_s)
|
12
10
|
end
|
13
11
|
|
14
|
-
def
|
12
|
+
def name
|
15
13
|
"-#{without_prefix}"
|
16
14
|
end
|
17
15
|
|
18
|
-
|
16
|
+
alias to_s name
|
17
|
+
|
18
|
+
def as_singular_key
|
19
19
|
snake_case.to_sym
|
20
20
|
end
|
21
21
|
|
@@ -23,20 +23,12 @@ module RubyTerraform
|
|
23
23
|
"#{snake_case}s".to_sym
|
24
24
|
end
|
25
25
|
|
26
|
-
|
27
|
-
to_s == other
|
28
|
-
end
|
29
|
-
|
30
|
-
def eql?(other)
|
31
|
-
to_s == other
|
32
|
-
end
|
26
|
+
private
|
33
27
|
|
34
|
-
def
|
35
|
-
|
28
|
+
def without_prefix
|
29
|
+
@name.sub(/^-+/, '')
|
36
30
|
end
|
37
31
|
|
38
|
-
private
|
39
|
-
|
40
32
|
def snake_case
|
41
33
|
without_prefix.gsub('-', '_')
|
42
34
|
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative 'types/base'
|
4
|
+
require_relative 'types/standard'
|
5
|
+
require_relative 'types/flag'
|
6
|
+
|
7
|
+
module RubyTerraform
|
8
|
+
module Options
|
9
|
+
module Types
|
10
|
+
def self.standard(name, value, **opts)
|
11
|
+
Standard.new(name, value, **opts)
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.flag(name, value)
|
15
|
+
Flag.new(name, value)
|
16
|
+
end
|
17
|
+
|
18
|
+
def self.resolve(type)
|
19
|
+
case type
|
20
|
+
when :standard then Types::Standard
|
21
|
+
when :flag then Types::Flag
|
22
|
+
else type
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -1,24 +1,17 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
require 'immutable-struct'
|
4
|
+
|
3
5
|
module RubyTerraform
|
4
6
|
module Options
|
5
7
|
module Types
|
6
|
-
class Base
|
7
|
-
def initialize(name, value)
|
8
|
-
|
9
|
-
coerce_value(value)
|
8
|
+
class Base < ImmutableStruct.new(:name, :value, :separator)
|
9
|
+
def initialize(name, value, **opts)
|
10
|
+
super(name: name, value: value, separator: opts[:separator])
|
10
11
|
end
|
11
12
|
|
12
13
|
def apply(_builder)
|
13
|
-
raise '
|
14
|
-
end
|
15
|
-
|
16
|
-
private
|
17
|
-
|
18
|
-
attr_reader :name, :value
|
19
|
-
|
20
|
-
def coerce_value(value)
|
21
|
-
@value = value
|
14
|
+
raise 'Not implemented.'
|
22
15
|
end
|
23
16
|
end
|
24
17
|
end
|
@@ -9,33 +9,7 @@ module RubyTerraform
|
|
9
9
|
module Types
|
10
10
|
class Standard < Base
|
11
11
|
def apply(builder)
|
12
|
-
|
13
|
-
apply_hash(builder)
|
14
|
-
elsif value.respond_to?(:each)
|
15
|
-
apply_array(builder)
|
16
|
-
else
|
17
|
-
builder.with_option(name, value)
|
18
|
-
end
|
19
|
-
end
|
20
|
-
|
21
|
-
private
|
22
|
-
|
23
|
-
def apply_hash(builder)
|
24
|
-
builder.with_repeated_option(
|
25
|
-
name,
|
26
|
-
value.map do |hash_key, hash_value|
|
27
|
-
"'#{hash_key}=#{as_string(hash_value)}'"
|
28
|
-
end,
|
29
|
-
separator: ' '
|
30
|
-
)
|
31
|
-
end
|
32
|
-
|
33
|
-
def apply_array(builder)
|
34
|
-
builder.with_repeated_option(name, value)
|
35
|
-
end
|
36
|
-
|
37
|
-
def as_string(value)
|
38
|
-
value.is_a?(String) ? value : JSON.generate(value)
|
12
|
+
builder.with_option(name, value.render, separator: separator)
|
39
13
|
end
|
40
14
|
end
|
41
15
|
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative 'values/boolean'
|
4
|
+
require_relative 'values/string'
|
5
|
+
require_relative 'values/complex'
|
6
|
+
require_relative 'values/key_value'
|
7
|
+
|
8
|
+
module RubyTerraform
|
9
|
+
module Options
|
10
|
+
module Values
|
11
|
+
def self.boolean(value)
|
12
|
+
Boolean.new(value)
|
13
|
+
end
|
14
|
+
|
15
|
+
def self.string(value)
|
16
|
+
String.new(value)
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.complex(value)
|
20
|
+
Complex.new(value)
|
21
|
+
end
|
22
|
+
|
23
|
+
def self.key_value(key, value)
|
24
|
+
KeyValue.new(key, value)
|
25
|
+
end
|
26
|
+
|
27
|
+
def self.resolve(type)
|
28
|
+
case type
|
29
|
+
when :string then Values::String
|
30
|
+
when :boolean then Values::Boolean
|
31
|
+
when :complex then Values::Complex
|
32
|
+
when :key_value then Values::KeyValue
|
33
|
+
else type
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -1,23 +1,25 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
require_relative 'base'
|
4
|
+
|
3
5
|
module RubyTerraform
|
4
6
|
module Options
|
5
7
|
module Values
|
6
|
-
|
7
|
-
def
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
private
|
12
|
-
|
13
|
-
def to_boolean(value)
|
14
|
-
return nil if value.nil?
|
15
|
-
return value if a_boolean?(value)
|
16
|
-
return true if true_as_string?(value)
|
8
|
+
class Boolean < Base
|
9
|
+
def resolve
|
10
|
+
return nil if @value.nil?
|
11
|
+
return @value if a_boolean?(@value)
|
12
|
+
return true if true_as_string?(@value)
|
17
13
|
|
18
14
|
false
|
19
15
|
end
|
20
16
|
|
17
|
+
def render
|
18
|
+
resolve.nil? ? nil : resolve.to_s
|
19
|
+
end
|
20
|
+
|
21
|
+
private
|
22
|
+
|
21
23
|
def a_boolean?(value)
|
22
24
|
value.is_a?(TrueClass) || value.is_a?(FalseClass)
|
23
25
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative 'base'
|
4
|
+
|
5
|
+
module RubyTerraform
|
6
|
+
module Options
|
7
|
+
module Values
|
8
|
+
class Complex < Base
|
9
|
+
def resolve
|
10
|
+
@value
|
11
|
+
end
|
12
|
+
|
13
|
+
def render
|
14
|
+
@value.is_a?(::String) ? @value : JSON.generate(value)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RubyTerraform
|
4
|
+
module Options
|
5
|
+
module Values
|
6
|
+
class KeyValue < ImmutableStruct.new(:key, :value)
|
7
|
+
def initialize(key, value)
|
8
|
+
super(key: key, value: value)
|
9
|
+
end
|
10
|
+
|
11
|
+
def resolve
|
12
|
+
{ key => value.resolve }
|
13
|
+
end
|
14
|
+
|
15
|
+
def render
|
16
|
+
"'#{key}=#{value.render}'"
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|