cumulus-aws 0.11.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (173) hide show
  1. checksums.yaml +15 -0
  2. data/.gitignore +3 -0
  3. data/.travis.yml +12 -0
  4. data/Gemfile +4 -0
  5. data/Gemfile.lock +29 -0
  6. data/LICENSE +202 -0
  7. data/README.md +41 -0
  8. data/autocomplete +137 -0
  9. data/bin/cumulus +658 -0
  10. data/cumulus +2 -0
  11. data/cumulus-aws.gemspec +20 -0
  12. data/lib/autoscaling/AutoScaling.rb +40 -0
  13. data/lib/autoscaling/loader/Loader.rb +56 -0
  14. data/lib/autoscaling/manager/Manager.rb +360 -0
  15. data/lib/autoscaling/models/AlarmConfig.rb +165 -0
  16. data/lib/autoscaling/models/AlarmDiff.rb +172 -0
  17. data/lib/autoscaling/models/AutoScalingDiff.rb +178 -0
  18. data/lib/autoscaling/models/GroupConfig.rb +330 -0
  19. data/lib/autoscaling/models/PolicyConfig.rb +135 -0
  20. data/lib/autoscaling/models/PolicyDiff.rb +73 -0
  21. data/lib/autoscaling/models/ScheduledActionDiff.rb +53 -0
  22. data/lib/autoscaling/models/ScheduledConfig.rb +96 -0
  23. data/lib/aws_extensions/ec2/DhcpOptions.rb +41 -0
  24. data/lib/aws_extensions/ec2/Instance.rb +29 -0
  25. data/lib/aws_extensions/ec2/NetworkAcl.rb +25 -0
  26. data/lib/aws_extensions/ec2/NetworkInterface.rb +14 -0
  27. data/lib/aws_extensions/ec2/RouteTable.rb +26 -0
  28. data/lib/aws_extensions/ec2/SecurityGroup.rb +16 -0
  29. data/lib/aws_extensions/ec2/Subnet.rb +28 -0
  30. data/lib/aws_extensions/ec2/Volume.rb +24 -0
  31. data/lib/aws_extensions/ec2/Vpc.rb +14 -0
  32. data/lib/aws_extensions/ec2/VpcEndpoint.rb +11 -0
  33. data/lib/aws_extensions/elb/BackendServerDescription.rb +12 -0
  34. data/lib/aws_extensions/elb/PolicyDescription.rb +14 -0
  35. data/lib/aws_extensions/kinesis/StreamDescription.rb +12 -0
  36. data/lib/aws_extensions/route53/AliasTarget.rb +21 -0
  37. data/lib/aws_extensions/s3/Bucket.rb +33 -0
  38. data/lib/aws_extensions/s3/BucketAcl.rb +28 -0
  39. data/lib/aws_extensions/s3/BucketCors.rb +17 -0
  40. data/lib/aws_extensions/s3/BucketLifecycle.rb +21 -0
  41. data/lib/aws_extensions/s3/BucketLogging.rb +18 -0
  42. data/lib/aws_extensions/s3/BucketNotification.rb +23 -0
  43. data/lib/aws_extensions/s3/BucketPolicy.rb +18 -0
  44. data/lib/aws_extensions/s3/BucketTagging.rb +15 -0
  45. data/lib/aws_extensions/s3/BucketVersioning.rb +14 -0
  46. data/lib/aws_extensions/s3/BucketWebsite.rb +49 -0
  47. data/lib/aws_extensions/s3/CORSRule.rb +27 -0
  48. data/lib/aws_extensions/s3/ReplicationConfiguration.rb +22 -0
  49. data/lib/cloudfront/CloudFront.rb +83 -0
  50. data/lib/cloudfront/loader/Loader.rb +31 -0
  51. data/lib/cloudfront/manager/Manager.rb +183 -0
  52. data/lib/cloudfront/models/CacheBehaviorConfig.rb +237 -0
  53. data/lib/cloudfront/models/CacheBehaviorDiff.rb +211 -0
  54. data/lib/cloudfront/models/CustomOriginConfig.rb +51 -0
  55. data/lib/cloudfront/models/CustomOriginDiff.rb +74 -0
  56. data/lib/cloudfront/models/DistributionConfig.rb +183 -0
  57. data/lib/cloudfront/models/DistributionDiff.rb +131 -0
  58. data/lib/cloudfront/models/InvalidationConfig.rb +37 -0
  59. data/lib/cloudfront/models/OriginConfig.rb +144 -0
  60. data/lib/cloudfront/models/OriginDiff.rb +86 -0
  61. data/lib/cloudfront/models/OriginSslProtocols.rb +28 -0
  62. data/lib/cloudfront/models/OriginSslProtocolsDiff.rb +39 -0
  63. data/lib/common/BaseLoader.rb +80 -0
  64. data/lib/common/manager/Manager.rb +148 -0
  65. data/lib/common/models/Diff.rb +114 -0
  66. data/lib/common/models/ListChange.rb +21 -0
  67. data/lib/common/models/TagsDiff.rb +55 -0
  68. data/lib/common/models/UTCTimeSource.rb +17 -0
  69. data/lib/conf/Configuration.rb +365 -0
  70. data/lib/ec2/EC2.rb +503 -0
  71. data/lib/ec2/IPProtocolMapping.rb +165 -0
  72. data/lib/ec2/loaders/EbsLoader.rb +19 -0
  73. data/lib/ec2/loaders/InstanceLoader.rb +32 -0
  74. data/lib/ec2/managers/EbsManager.rb +176 -0
  75. data/lib/ec2/managers/InstanceManager.rb +509 -0
  76. data/lib/ec2/models/EbsGroupConfig.rb +133 -0
  77. data/lib/ec2/models/EbsGroupDiff.rb +48 -0
  78. data/lib/ec2/models/InstanceConfig.rb +202 -0
  79. data/lib/ec2/models/InstanceDiff.rb +95 -0
  80. data/lib/elb/ELB.rb +148 -0
  81. data/lib/elb/loader/Loader.rb +65 -0
  82. data/lib/elb/manager/Manager.rb +581 -0
  83. data/lib/elb/models/AccessLogConfig.rb +82 -0
  84. data/lib/elb/models/AccessLogDiff.rb +47 -0
  85. data/lib/elb/models/HealthCheckConfig.rb +91 -0
  86. data/lib/elb/models/HealthCheckDiff.rb +50 -0
  87. data/lib/elb/models/ListenerConfig.rb +99 -0
  88. data/lib/elb/models/ListenerDiff.rb +91 -0
  89. data/lib/elb/models/LoadBalancerConfig.rb +239 -0
  90. data/lib/elb/models/LoadBalancerDiff.rb +265 -0
  91. data/lib/iam/IAM.rb +36 -0
  92. data/lib/iam/loader/Loader.rb +117 -0
  93. data/lib/iam/manager/IamGroups.rb +98 -0
  94. data/lib/iam/manager/IamResource.rb +288 -0
  95. data/lib/iam/manager/IamRoles.rb +112 -0
  96. data/lib/iam/manager/IamUsers.rb +54 -0
  97. data/lib/iam/manager/Manager.rb +29 -0
  98. data/lib/iam/migration/AssumeRoleUnifier.rb +34 -0
  99. data/lib/iam/migration/PolicyUnifier.rb +90 -0
  100. data/lib/iam/models/GroupConfig.rb +40 -0
  101. data/lib/iam/models/IamDiff.rb +132 -0
  102. data/lib/iam/models/PolicyConfig.rb +67 -0
  103. data/lib/iam/models/ResourceWithPolicy.rb +208 -0
  104. data/lib/iam/models/RoleConfig.rb +53 -0
  105. data/lib/iam/models/StatementConfig.rb +35 -0
  106. data/lib/iam/models/UserConfig.rb +21 -0
  107. data/lib/kinesis/Kinesis.rb +94 -0
  108. data/lib/kinesis/loader/Loader.rb +19 -0
  109. data/lib/kinesis/manager/Manager.rb +206 -0
  110. data/lib/kinesis/models/StreamConfig.rb +75 -0
  111. data/lib/kinesis/models/StreamDiff.rb +58 -0
  112. data/lib/lambda/Lambda.rb +41 -0
  113. data/lib/route53/loader/Loader.rb +32 -0
  114. data/lib/route53/manager/Manager.rb +241 -0
  115. data/lib/route53/models/AliasTarget.rb +86 -0
  116. data/lib/route53/models/RecordConfig.rb +178 -0
  117. data/lib/route53/models/RecordDiff.rb +140 -0
  118. data/lib/route53/models/Vpc.rb +24 -0
  119. data/lib/route53/models/ZoneConfig.rb +156 -0
  120. data/lib/route53/models/ZoneDiff.rb +118 -0
  121. data/lib/s3/S3.rb +89 -0
  122. data/lib/s3/loader/Loader.rb +66 -0
  123. data/lib/s3/manager/Manager.rb +296 -0
  124. data/lib/s3/models/BucketConfig.rb +321 -0
  125. data/lib/s3/models/BucketDiff.rb +167 -0
  126. data/lib/s3/models/GrantConfig.rb +189 -0
  127. data/lib/s3/models/GrantDiff.rb +50 -0
  128. data/lib/s3/models/LifecycleConfig.rb +142 -0
  129. data/lib/s3/models/LifecycleDiff.rb +46 -0
  130. data/lib/s3/models/LoggingConfig.rb +81 -0
  131. data/lib/s3/models/NotificationConfig.rb +157 -0
  132. data/lib/s3/models/NotificationDiff.rb +62 -0
  133. data/lib/s3/models/ReplicationConfig.rb +133 -0
  134. data/lib/s3/models/ReplicationDiff.rb +60 -0
  135. data/lib/s3/models/WebsiteConfig.rb +107 -0
  136. data/lib/security/SecurityGroups.rb +39 -0
  137. data/lib/security/loader/Loader.rb +94 -0
  138. data/lib/security/manager/Manager.rb +246 -0
  139. data/lib/security/models/RuleConfig.rb +161 -0
  140. data/lib/security/models/RuleDiff.rb +72 -0
  141. data/lib/security/models/RuleMigration.rb +127 -0
  142. data/lib/security/models/SecurityGroupConfig.rb +172 -0
  143. data/lib/security/models/SecurityGroupDiff.rb +112 -0
  144. data/lib/sns/SNS.rb +40 -0
  145. data/lib/sqs/SQS.rb +62 -0
  146. data/lib/sqs/loader/Loader.rb +34 -0
  147. data/lib/sqs/manager/Manager.rb +128 -0
  148. data/lib/sqs/models/DeadLetterConfig.rb +70 -0
  149. data/lib/sqs/models/DeadLetterDiff.rb +35 -0
  150. data/lib/sqs/models/QueueConfig.rb +115 -0
  151. data/lib/sqs/models/QueueDiff.rb +89 -0
  152. data/lib/util/Colors.rb +111 -0
  153. data/lib/util/StatusCodes.rb +51 -0
  154. data/lib/vpc/loader/Loader.rb +73 -0
  155. data/lib/vpc/manager/Manager.rb +954 -0
  156. data/lib/vpc/models/AclEntryConfig.rb +150 -0
  157. data/lib/vpc/models/AclEntryDiff.rb +54 -0
  158. data/lib/vpc/models/DhcpConfig.rb +100 -0
  159. data/lib/vpc/models/DhcpDiff.rb +90 -0
  160. data/lib/vpc/models/EndpointConfig.rb +76 -0
  161. data/lib/vpc/models/EndpointDiff.rb +69 -0
  162. data/lib/vpc/models/NetworkAclConfig.rb +87 -0
  163. data/lib/vpc/models/NetworkAclDiff.rb +116 -0
  164. data/lib/vpc/models/RouteConfig.rb +82 -0
  165. data/lib/vpc/models/RouteDiff.rb +50 -0
  166. data/lib/vpc/models/RouteTableConfig.rb +92 -0
  167. data/lib/vpc/models/RouteTableDiff.rb +101 -0
  168. data/lib/vpc/models/SubnetConfig.rb +113 -0
  169. data/lib/vpc/models/SubnetDiff.rb +78 -0
  170. data/lib/vpc/models/VpcConfig.rb +173 -0
  171. data/lib/vpc/models/VpcDiff.rb +315 -0
  172. data/rakefile.rb +8 -0
  173. metadata +245 -0
@@ -0,0 +1,315 @@
1
+ require "common/models/Diff"
2
+ require "common/models/ListChange"
3
+ require "common/models/TagsDiff"
4
+ require "vpc/models/SubnetDiff"
5
+ require "vpc/models/RouteTableDiff"
6
+ require "vpc/models/EndpointDiff"
7
+ require "vpc/models/NetworkAclDiff"
8
+ require "ec2/EC2"
9
+ require "util/Colors"
10
+
11
+ module Cumulus
12
+ module VPC
13
+ # Public: The types of changes that can be made to a VPC
14
+ module VpcChange
15
+ include Common::DiffChange
16
+
17
+ CIDR = Common::DiffChange.next_change_id
18
+ TENANCY = Common::DiffChange.next_change_id
19
+ DHCP = Common::DiffChange.next_change_id
20
+ ROUTE_TABLES = Common::DiffChange.next_change_id
21
+ ENDPOINTS = Common::DiffChange.next_change_id
22
+ ADDRESSES = Common::DiffChange.next_change_id
23
+ NETWORK_ACLS = Common::DiffChange.next_change_id
24
+ SUBNETS = Common::DiffChange.next_change_id
25
+ TAGS = Common::DiffChange.next_change_id
26
+ end
27
+
28
+ # Public: Represents a single difference between local configuration and AWS configuration
29
+ class VpcDiff < Common::Diff
30
+ include VpcChange
31
+ include Common::TagsDiff
32
+
33
+ def self.subnets(aws, local)
34
+ aws_name_subnets = Hash[aws.map { |subnet| [subnet.name || subnet.subnet_id, subnet] }]
35
+ local_name_subnets = Hash[local.map { |subnet| [subnet.name, subnet] }]
36
+
37
+ added = local_name_subnets.reject { |k, v| aws_name_subnets.has_key? k }
38
+ removed = aws_name_subnets.reject { |k, v| local_name_subnets.has_key? k }
39
+ modified = local_name_subnets.select { |k, v| aws_name_subnets.has_key? k }
40
+
41
+ added_diffs = Hash[added.map { |subnet_name, subnet| [subnet_name, SubnetDiff.added(subnet)] }]
42
+ removed_diffs = Hash[removed.map { |subnet_name, subnet| [subnet_name, SubnetDiff.unmanaged(subnet)] }]
43
+ modified_diffs = Hash[modified.map do |subnet_name, subnet|
44
+ aws_subnet = aws_name_subnets[subnet_name]
45
+ subnet_diffs = subnet.diff(aws_subnet)
46
+ if !subnet_diffs.empty?
47
+ [subnet_name, SubnetDiff.modified(aws_subnet, subnet, subnet_diffs)]
48
+ end
49
+ end.reject { |v| v.nil? }]
50
+
51
+ if !added_diffs.empty? or !removed_diffs.empty? or !modified_diffs.empty?
52
+ diff = VpcDiff.new(SUBNETS, aws, local)
53
+ diff.changes = Common::ListChange.new(added_diffs, removed_diffs, modified_diffs)
54
+ diff
55
+ end
56
+ end
57
+
58
+ def self.dhcp(aws, local)
59
+ dhcp_diffs = if !aws and local
60
+ [DhcpDiff.added(local)]
61
+ elsif !local and aws
62
+ [DhcpDiff.unmanaged(aws)]
63
+ elsif local and aws
64
+ local.diff(aws)
65
+ end
66
+
67
+ if dhcp_diffs and !dhcp_diffs.empty?
68
+ diff = VpcDiff.new(DHCP, aws, local)
69
+ diff.changes = dhcp_diffs
70
+ diff
71
+ end
72
+ end
73
+
74
+ def self.route_tables(aws, local)
75
+ aws_name_route_tables = Hash[aws.map { |rt| [rt.name || rt.route_table_id, rt] }]
76
+ local_name_route_tables = Hash[local.map { |rt| [rt.name, rt] }]
77
+
78
+ added = local_name_route_tables.reject { |k, v| aws_name_route_tables.has_key? k }
79
+ removed = aws_name_route_tables.reject { |k, v| local_name_route_tables.has_key? k }
80
+ modified = local_name_route_tables.select { |k, v| aws_name_route_tables.has_key? k }
81
+
82
+ added_diffs = Hash[added.map { |rt_name, rt| [rt_name, RouteTableDiff.added(rt)]}]
83
+ removed_diffs = Hash[removed.map { |rt_name, rt| [rt_name, RouteTableDiff.unmanaged(rt)]}]
84
+ modified_diffs = Hash[modified.map do |rt_name, rt|
85
+ aws_rt = aws_name_route_tables[rt_name]
86
+ rt_diffs = rt.diff(aws_rt)
87
+ if !rt_diffs.empty?
88
+ [rt_name, RouteTableDiff.modified(aws_rt, rt, rt_diffs)]
89
+ end
90
+ end.reject { |v| v.nil? }]
91
+
92
+ if !added_diffs.empty? or !removed_diffs.empty? or !modified_diffs.empty?
93
+ diff = VpcDiff.new(ROUTE_TABLES, aws, local)
94
+ diff.changes = Common::ListChange.new(added_diffs, removed_diffs, modified_diffs)
95
+ diff
96
+ end
97
+ end
98
+
99
+ def self.endpoints(aws, local)
100
+ aws_service_endpoints = Hash[aws.map { |e| [e.service_name, e] }]
101
+ local_service_endpoints = Hash[local.map { |e| [e.service_name, e] }]
102
+
103
+ added = local_service_endpoints.reject { |k, v| aws_service_endpoints.has_key? k }
104
+ removed = aws_service_endpoints.reject { |k, v| local_service_endpoints.has_key? k }
105
+ modified = local_service_endpoints.select { |k, v| aws_service_endpoints.has_key? k }
106
+
107
+ added_diffs = Hash[added.map { |service_name, endpoint| [service_name, EndpointDiff.added(endpoint)]}]
108
+ removed_diffs = Hash[removed.map { |service_name, endpoint| [service_name, EndpointDiff.unmanaged(endpoint)]}]
109
+ modified_diffs = Hash[modified.map do |service_name, endpoint|
110
+ aws_endpoint = aws_service_endpoints[service_name]
111
+ endpoint_diffs = endpoint.diff(aws_endpoint)
112
+ if !endpoint_diffs.empty?
113
+ [service_name, EndpointDiff.modified(aws_endpoint, endpoint, endpoint_diffs)]
114
+ end
115
+ end.reject { |v| v.nil? }]
116
+
117
+ if !added_diffs.empty? or !removed_diffs.empty? or !modified_diffs.empty?
118
+ diff = VpcDiff.new(ENDPOINTS, aws, local)
119
+ diff.changes = Common::ListChange.new(added_diffs, removed_diffs, modified_diffs)
120
+ diff
121
+ end
122
+ end
123
+
124
+ AddressChange = Struct.new(:aws_name, :aws, :local_name, :local)
125
+ def self.address_associations(aws, local)
126
+ any_addresses = local.select { |ip, key| key.downcase == "any" }
127
+
128
+ # Map the aws and local public ips to network interface
129
+ aws_addresses = Hash[aws.map { |addr| [addr.public_ip, EC2::id_network_interfaces[addr.network_interface_id]] }]
130
+
131
+ local_addresses = Hash[local.map do |ip, key|
132
+ interface = EC2::named_network_interfaces[key]
133
+
134
+ if interface.nil?
135
+ if key.downcase == "any"
136
+ interface = "any"
137
+ else
138
+ puts Colors.red("Config error: no network interface exists for #{key}")
139
+ exit 1
140
+ end
141
+ end
142
+
143
+ [ip, interface]
144
+ end].reject { |k, v| v.nil? }
145
+
146
+ added = local_addresses.reject { |k, v| aws_addresses.has_key? k }
147
+ added_names = Hash[added.map do |ip, interface|
148
+ name = if interface == "any"
149
+ "any"
150
+ else
151
+ interface.name || interface.network_interface_id
152
+ end
153
+ [ip, AddressChange.new(nil, nil, name, interface)]
154
+ end]
155
+
156
+ removed = aws_addresses.reject { |k, v| local_addresses.has_key? k }
157
+ removed_names = Hash[removed.map { |ip, interface| [ip, AddressChange.new(interface.name || interface.network_interface_id, interface, nil, nil)] }]
158
+
159
+ modified = local_addresses.reject { |_, v| v == "any" }.select { |k, v| aws_addresses.has_key? k and aws_addresses[k].network_interface_id != v.network_interface_id }
160
+ modified_changes = Hash[modified.map do |ip, local_interface|
161
+ aws_interface = aws_addresses[ip]
162
+ aws_name = aws_interface.name || aws_interface.network_interface_id
163
+ local_name = local_interface.name || local_interface.network_interface_id
164
+ [ip, AddressChange.new(aws_name, aws_interface, local_name, local_interface)]
165
+ end]
166
+
167
+ if !added_names.empty? or !removed_names.empty? or !modified_changes.empty?
168
+ diff = VpcDiff.new(ADDRESSES, aws, local_addresses)
169
+ diff.changes = Common::ListChange.new(added_names, removed_names, modified_changes)
170
+ diff
171
+ end
172
+ end
173
+
174
+ def self.network_acls(aws, local)
175
+ aws_network_acl_names = Hash[aws.map { |acl| [acl.name || acl.network_acl_id, acl] }]
176
+ local_network_acl_names = Hash[local.map { |acl| [acl.name, acl] }]
177
+
178
+ added = local_network_acl_names.reject { |k, v| aws_network_acl_names.has_key? k }
179
+ removed = aws_network_acl_names.reject { |k, v| local_network_acl_names.has_key? k }
180
+ modified = local_network_acl_names.select { |k, v| aws_network_acl_names.has_key? k }
181
+
182
+ added_diffs = Hash[added.map { |name, acl| [name, NetworkAclDiff.added(acl)] }]
183
+ removed_diffs = Hash[removed.map { |name, acl| [name, NetworkAclDiff.unmanaged(acl)] }]
184
+ modified_diffs = Hash[modified.map do |name, acl|
185
+ aws_acl = aws_network_acl_names[name]
186
+ acl_diffs = acl.diff(aws_acl)
187
+ if !acl_diffs.empty?
188
+ [name, NetworkAclDiff.modified(aws_acl, acl, acl_diffs)]
189
+ end
190
+ end.reject { |v| v.nil? }]
191
+
192
+ if !added_diffs.empty? or !removed_diffs.empty? or !modified_diffs.empty?
193
+ diff = VpcDiff.new(NETWORK_ACLS, aws, local)
194
+ diff.changes = Common::ListChange.new(added_diffs, removed_diffs, modified_diffs)
195
+ diff
196
+ end
197
+ end
198
+
199
+ def local_tags
200
+ @local
201
+ end
202
+
203
+ def aws_tags
204
+ @aws
205
+ end
206
+
207
+ def asset_type
208
+ "Virtual Private Cloud"
209
+ end
210
+
211
+ def aws_name
212
+ @aws.name || @aws.vpc_id
213
+ end
214
+
215
+ def diff_string
216
+ case @type
217
+ when CIDR
218
+ [
219
+ "CIDR Block:",
220
+ Colors.aws_changes("\tAWS - #{aws}"),
221
+ Colors.local_changes("\tLocal - #{local}"),
222
+ ].join("\n")
223
+ when TENANCY
224
+ [
225
+ "Tenancy:",
226
+ Colors.aws_changes("\tAWS - #{aws}"),
227
+ Colors.local_changes("\tLocal - #{local}"),
228
+ ].join("\n")
229
+ when SUBNETS
230
+ [
231
+ "Subnets:",
232
+ @changes.removed.map { |s, _| Colors.unmanaged("\t#{s} is not managed by Cumulus") },
233
+ @changes.added.map { |s, _| Colors.added("\t#{s} will be created") },
234
+ @changes.modified.map do |subnet_name, diff|
235
+ [
236
+ "\t#{subnet_name}:",
237
+ diff.changes.map do |diff|
238
+ diff.to_s.lines.map { |l| "\t\t#{l}".chomp("\n") }
239
+ end
240
+ ]
241
+ end
242
+ ].flatten.join("\n")
243
+ when DHCP
244
+ [
245
+ "DHCP Options:",
246
+ if !@aws
247
+ Colors.added(
248
+ JSON.pretty_generate(@local.to_hash).lines.map { |l| "\t#{l}".chomp("\n") }.join("\n")
249
+ )
250
+ elsif !@local
251
+ Colors.unmanaged("\tChanging DHCP options to default")
252
+ else
253
+ @changes.map do |diff|
254
+ diff.to_s.lines.map { |l| "\t#{l}".chomp("\n") }
255
+ end
256
+ end
257
+ ].flatten.join("\n")
258
+ when ROUTE_TABLES
259
+ [
260
+ "Route Tables:",
261
+ @changes.removed.map { |r, _| Colors.unmanaged("\t#{r} will be deleted") },
262
+ @changes.added.map { |r, _| Colors.added("\t#{r} will be created") },
263
+ @changes.modified.map do |rt_name, diff|
264
+ [
265
+ "\t#{rt_name}:",
266
+ diff.changes.map do |diff|
267
+ diff.to_s.lines.map { |l| "\t\t#{l}".chomp("\n") }
268
+ end
269
+ ]
270
+ end
271
+ ].flatten.join("\n")
272
+ when ENDPOINTS
273
+ [
274
+ "Endpoints:",
275
+ @changes.removed.map { |e, _| Colors.unmanaged("\t#{e} will be deleted") },
276
+ @changes.added.map { |e, _| Colors.added("\t#{e} will be created") },
277
+ @changes.modified.map do |endpoint_name, diff|
278
+ [
279
+ "\t#{endpoint_name}:",
280
+ diff.changes.map do |diff|
281
+ diff.to_s.lines.map { |l| "\t\t#{l}".chomp("\n") }
282
+ end
283
+ ]
284
+ end
285
+ ].flatten.join("\n")
286
+ when ADDRESSES
287
+ [
288
+ "Address Associations:",
289
+ @changes.removed.map { |ip, addr_change| Colors.unmanaged("\t#{ip} will be disassociated from #{addr_change.aws_name}") },
290
+ @changes.added.map { |ip, addr_change| Colors.added("\t#{ip} will be associated to #{addr_change.local_name}") },
291
+ @changes.modified.map do |ip, addr_change|
292
+ "\t#{ip} will be changed from #{addr_change.aws_name} to #{addr_change.local_name}"
293
+ end
294
+ ].flatten.join("\n")
295
+ when NETWORK_ACLS
296
+ [
297
+ "Network ACLs:",
298
+ @changes.removed.map { |acl_name, _| Colors.unmanaged("\t#{acl_name} will be deleted") },
299
+ @changes.added.map { |acl_name, _| Colors.added("\t#{acl_name} will be created") },
300
+ @changes.modified.map do |acl_name, diff|
301
+ [
302
+ "\t#{acl_name}:",
303
+ diff.changes.map do |diff|
304
+ diff.to_s.lines.map { |l| "\t\t#{l}".chomp("\n") }
305
+ end
306
+ ]
307
+ end
308
+ ].flatten.join("\n")
309
+ when TAGS
310
+ tags_diff_string
311
+ end
312
+ end
313
+ end
314
+ end
315
+ end
@@ -0,0 +1,8 @@
1
+ require "bundler/gem_tasks"
2
+
3
+ task :default => :spec
4
+
5
+ task :spec do
6
+ puts "Running tests... \n"
7
+ puts "Tests have not been written yet :("
8
+ end
metadata ADDED
@@ -0,0 +1,245 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: cumulus-aws
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.11.1
5
+ platform: ruby
6
+ authors:
7
+ - Keilan Jackson
8
+ - Mark Siebert
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2016-06-17 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: aws-sdk
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - '='
19
+ - !ruby/object:Gem::Version
20
+ version: 2.2.8
21
+ type: :runtime
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - '='
26
+ - !ruby/object:Gem::Version
27
+ version: 2.2.8
28
+ - !ruby/object:Gem::Dependency
29
+ name: parse-cron
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - ~>
33
+ - !ruby/object:Gem::Version
34
+ version: 0.1.4
35
+ type: :runtime
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ~>
40
+ - !ruby/object:Gem::Version
41
+ version: 0.1.4
42
+ description: Cumulus allows you to manage your AWS infrastructure by creating JSON
43
+ configuration files that describe your AWS resources.
44
+ email: cumulus@lucidchart.com
45
+ executables:
46
+ - cumulus
47
+ extensions: []
48
+ extra_rdoc_files: []
49
+ files:
50
+ - .gitignore
51
+ - .travis.yml
52
+ - Gemfile
53
+ - Gemfile.lock
54
+ - LICENSE
55
+ - README.md
56
+ - autocomplete
57
+ - bin/cumulus
58
+ - cumulus
59
+ - cumulus-aws.gemspec
60
+ - lib/autoscaling/AutoScaling.rb
61
+ - lib/autoscaling/loader/Loader.rb
62
+ - lib/autoscaling/manager/Manager.rb
63
+ - lib/autoscaling/models/AlarmConfig.rb
64
+ - lib/autoscaling/models/AlarmDiff.rb
65
+ - lib/autoscaling/models/AutoScalingDiff.rb
66
+ - lib/autoscaling/models/GroupConfig.rb
67
+ - lib/autoscaling/models/PolicyConfig.rb
68
+ - lib/autoscaling/models/PolicyDiff.rb
69
+ - lib/autoscaling/models/ScheduledActionDiff.rb
70
+ - lib/autoscaling/models/ScheduledConfig.rb
71
+ - lib/aws_extensions/ec2/DhcpOptions.rb
72
+ - lib/aws_extensions/ec2/Instance.rb
73
+ - lib/aws_extensions/ec2/NetworkAcl.rb
74
+ - lib/aws_extensions/ec2/NetworkInterface.rb
75
+ - lib/aws_extensions/ec2/RouteTable.rb
76
+ - lib/aws_extensions/ec2/SecurityGroup.rb
77
+ - lib/aws_extensions/ec2/Subnet.rb
78
+ - lib/aws_extensions/ec2/Volume.rb
79
+ - lib/aws_extensions/ec2/Vpc.rb
80
+ - lib/aws_extensions/ec2/VpcEndpoint.rb
81
+ - lib/aws_extensions/elb/BackendServerDescription.rb
82
+ - lib/aws_extensions/elb/PolicyDescription.rb
83
+ - lib/aws_extensions/kinesis/StreamDescription.rb
84
+ - lib/aws_extensions/route53/AliasTarget.rb
85
+ - lib/aws_extensions/s3/Bucket.rb
86
+ - lib/aws_extensions/s3/BucketAcl.rb
87
+ - lib/aws_extensions/s3/BucketCors.rb
88
+ - lib/aws_extensions/s3/BucketLifecycle.rb
89
+ - lib/aws_extensions/s3/BucketLogging.rb
90
+ - lib/aws_extensions/s3/BucketNotification.rb
91
+ - lib/aws_extensions/s3/BucketPolicy.rb
92
+ - lib/aws_extensions/s3/BucketTagging.rb
93
+ - lib/aws_extensions/s3/BucketVersioning.rb
94
+ - lib/aws_extensions/s3/BucketWebsite.rb
95
+ - lib/aws_extensions/s3/CORSRule.rb
96
+ - lib/aws_extensions/s3/ReplicationConfiguration.rb
97
+ - lib/cloudfront/CloudFront.rb
98
+ - lib/cloudfront/loader/Loader.rb
99
+ - lib/cloudfront/manager/Manager.rb
100
+ - lib/cloudfront/models/CacheBehaviorConfig.rb
101
+ - lib/cloudfront/models/CacheBehaviorDiff.rb
102
+ - lib/cloudfront/models/CustomOriginConfig.rb
103
+ - lib/cloudfront/models/CustomOriginDiff.rb
104
+ - lib/cloudfront/models/DistributionConfig.rb
105
+ - lib/cloudfront/models/DistributionDiff.rb
106
+ - lib/cloudfront/models/InvalidationConfig.rb
107
+ - lib/cloudfront/models/OriginConfig.rb
108
+ - lib/cloudfront/models/OriginDiff.rb
109
+ - lib/cloudfront/models/OriginSslProtocols.rb
110
+ - lib/cloudfront/models/OriginSslProtocolsDiff.rb
111
+ - lib/common/BaseLoader.rb
112
+ - lib/common/manager/Manager.rb
113
+ - lib/common/models/Diff.rb
114
+ - lib/common/models/ListChange.rb
115
+ - lib/common/models/TagsDiff.rb
116
+ - lib/common/models/UTCTimeSource.rb
117
+ - lib/conf/Configuration.rb
118
+ - lib/ec2/EC2.rb
119
+ - lib/ec2/IPProtocolMapping.rb
120
+ - lib/ec2/loaders/EbsLoader.rb
121
+ - lib/ec2/loaders/InstanceLoader.rb
122
+ - lib/ec2/managers/EbsManager.rb
123
+ - lib/ec2/managers/InstanceManager.rb
124
+ - lib/ec2/models/EbsGroupConfig.rb
125
+ - lib/ec2/models/EbsGroupDiff.rb
126
+ - lib/ec2/models/InstanceConfig.rb
127
+ - lib/ec2/models/InstanceDiff.rb
128
+ - lib/elb/ELB.rb
129
+ - lib/elb/loader/Loader.rb
130
+ - lib/elb/manager/Manager.rb
131
+ - lib/elb/models/AccessLogConfig.rb
132
+ - lib/elb/models/AccessLogDiff.rb
133
+ - lib/elb/models/HealthCheckConfig.rb
134
+ - lib/elb/models/HealthCheckDiff.rb
135
+ - lib/elb/models/ListenerConfig.rb
136
+ - lib/elb/models/ListenerDiff.rb
137
+ - lib/elb/models/LoadBalancerConfig.rb
138
+ - lib/elb/models/LoadBalancerDiff.rb
139
+ - lib/iam/IAM.rb
140
+ - lib/iam/loader/Loader.rb
141
+ - lib/iam/manager/IamGroups.rb
142
+ - lib/iam/manager/IamResource.rb
143
+ - lib/iam/manager/IamRoles.rb
144
+ - lib/iam/manager/IamUsers.rb
145
+ - lib/iam/manager/Manager.rb
146
+ - lib/iam/migration/AssumeRoleUnifier.rb
147
+ - lib/iam/migration/PolicyUnifier.rb
148
+ - lib/iam/models/GroupConfig.rb
149
+ - lib/iam/models/IamDiff.rb
150
+ - lib/iam/models/PolicyConfig.rb
151
+ - lib/iam/models/ResourceWithPolicy.rb
152
+ - lib/iam/models/RoleConfig.rb
153
+ - lib/iam/models/StatementConfig.rb
154
+ - lib/iam/models/UserConfig.rb
155
+ - lib/kinesis/Kinesis.rb
156
+ - lib/kinesis/loader/Loader.rb
157
+ - lib/kinesis/manager/Manager.rb
158
+ - lib/kinesis/models/StreamConfig.rb
159
+ - lib/kinesis/models/StreamDiff.rb
160
+ - lib/lambda/Lambda.rb
161
+ - lib/route53/loader/Loader.rb
162
+ - lib/route53/manager/Manager.rb
163
+ - lib/route53/models/AliasTarget.rb
164
+ - lib/route53/models/RecordConfig.rb
165
+ - lib/route53/models/RecordDiff.rb
166
+ - lib/route53/models/Vpc.rb
167
+ - lib/route53/models/ZoneConfig.rb
168
+ - lib/route53/models/ZoneDiff.rb
169
+ - lib/s3/S3.rb
170
+ - lib/s3/loader/Loader.rb
171
+ - lib/s3/manager/Manager.rb
172
+ - lib/s3/models/BucketConfig.rb
173
+ - lib/s3/models/BucketDiff.rb
174
+ - lib/s3/models/GrantConfig.rb
175
+ - lib/s3/models/GrantDiff.rb
176
+ - lib/s3/models/LifecycleConfig.rb
177
+ - lib/s3/models/LifecycleDiff.rb
178
+ - lib/s3/models/LoggingConfig.rb
179
+ - lib/s3/models/NotificationConfig.rb
180
+ - lib/s3/models/NotificationDiff.rb
181
+ - lib/s3/models/ReplicationConfig.rb
182
+ - lib/s3/models/ReplicationDiff.rb
183
+ - lib/s3/models/WebsiteConfig.rb
184
+ - lib/security/SecurityGroups.rb
185
+ - lib/security/loader/Loader.rb
186
+ - lib/security/manager/Manager.rb
187
+ - lib/security/models/RuleConfig.rb
188
+ - lib/security/models/RuleDiff.rb
189
+ - lib/security/models/RuleMigration.rb
190
+ - lib/security/models/SecurityGroupConfig.rb
191
+ - lib/security/models/SecurityGroupDiff.rb
192
+ - lib/sns/SNS.rb
193
+ - lib/sqs/SQS.rb
194
+ - lib/sqs/loader/Loader.rb
195
+ - lib/sqs/manager/Manager.rb
196
+ - lib/sqs/models/DeadLetterConfig.rb
197
+ - lib/sqs/models/DeadLetterDiff.rb
198
+ - lib/sqs/models/QueueConfig.rb
199
+ - lib/sqs/models/QueueDiff.rb
200
+ - lib/util/Colors.rb
201
+ - lib/util/StatusCodes.rb
202
+ - lib/vpc/loader/Loader.rb
203
+ - lib/vpc/manager/Manager.rb
204
+ - lib/vpc/models/AclEntryConfig.rb
205
+ - lib/vpc/models/AclEntryDiff.rb
206
+ - lib/vpc/models/DhcpConfig.rb
207
+ - lib/vpc/models/DhcpDiff.rb
208
+ - lib/vpc/models/EndpointConfig.rb
209
+ - lib/vpc/models/EndpointDiff.rb
210
+ - lib/vpc/models/NetworkAclConfig.rb
211
+ - lib/vpc/models/NetworkAclDiff.rb
212
+ - lib/vpc/models/RouteConfig.rb
213
+ - lib/vpc/models/RouteDiff.rb
214
+ - lib/vpc/models/RouteTableConfig.rb
215
+ - lib/vpc/models/RouteTableDiff.rb
216
+ - lib/vpc/models/SubnetConfig.rb
217
+ - lib/vpc/models/SubnetDiff.rb
218
+ - lib/vpc/models/VpcConfig.rb
219
+ - lib/vpc/models/VpcDiff.rb
220
+ - rakefile.rb
221
+ homepage: http://lucidsoftware.github.io/cumulus/
222
+ licenses:
223
+ - Apache-2.0
224
+ metadata: {}
225
+ post_install_message:
226
+ rdoc_options: []
227
+ require_paths:
228
+ - lib
229
+ required_ruby_version: !ruby/object:Gem::Requirement
230
+ requirements:
231
+ - - ! '>='
232
+ - !ruby/object:Gem::Version
233
+ version: '0'
234
+ required_rubygems_version: !ruby/object:Gem::Requirement
235
+ requirements:
236
+ - - ! '>='
237
+ - !ruby/object:Gem::Version
238
+ version: '0'
239
+ requirements: []
240
+ rubyforge_project:
241
+ rubygems_version: 2.4.5
242
+ signing_key:
243
+ specification_version: 4
244
+ summary: AWS Configuration Manager
245
+ test_files: []