cfn-guardian 0.6.6 → 0.6.11

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6f1339a9ee76341525bd679f5682800ed34387de43601f92d21c9ad4b66021d7
4
- data.tar.gz: 683b16c8373348dbdc1bb2a678631ffebd4c08e787bd41746c3b05374cc1c721
3
+ metadata.gz: bc62d2d0be60b4f28ab5da32207415340db06de99ee00f2a326174903e2d7a8b
4
+ data.tar.gz: d6bf90ce725692e2396ed0e337a4cd773f3b187402e2d1ab081f219bc1898c85
5
5
  SHA512:
6
- metadata.gz: d5bee032c069e3995094fe772946fb64ccd929d0817bfbac830e9170af989996178f2fd466ef07400450ac6b8ae8d50bf7cf671b6a28e45cab9d9af487f68642
7
- data.tar.gz: ea60eea9cc8fb21677234b04a37a60c772191a8f1a39c330af7c44c7c595e0f84927b04d29658618d1aef2625b090013f6940fb3afe8d3b9e493c5f0d24fb36a
6
+ metadata.gz: d9b1c3ad0dc61891ca602b2156fbd523cdccc77296d6d959a420e66d2dfbcd449983160f11e8c33b4f4380e56930eacde37f35e0d048935b5aaf969736f2fd9a
7
+ data.tar.gz: 657b0c5a4eb265e58a36173157b1850a41a6d311d471fe5f9363d18b25420d97126c219057cd22cd6b1a4456140da5abdaa539969e8ce9b6759f54808653876a
data/Dockerfile CHANGED
@@ -1,6 +1,6 @@
1
1
  FROM ruby:2.7-alpine
2
2
 
3
- ARG GUARDIAN_VERSION="0.2.2"
3
+ ARG GUARDIAN_VERSION="0.6.9"
4
4
 
5
5
  COPY . /src
6
6
 
@@ -16,4 +16,4 @@ RUN addgroup -g 1000 guardian && \
16
16
 
17
17
  USER guardian
18
18
 
19
- RUN cfndsl -u 11.5.0
19
+ RUN cfndsl -u 11.5.0
@@ -0,0 +1,18 @@
1
+ # ECS Container Instance Check
2
+
3
+ Source: https://github.com/base2Services/aws-lambda-ecs-container-instance-check
4
+
5
+ Checks the agent status of a ECS container instance for a ECS cluster.
6
+ This check and alarms are created by default when a ECS cluster resource is specified in the config.
7
+
8
+ ```yaml
9
+ Resources:
10
+ ECSCluster:
11
+ - Id: my-cluster
12
+
13
+ Templates:
14
+ ECSCluster:
15
+ # override the alarm defaults
16
+ ECSContianerInstancesDisconnected:
17
+ ...
18
+ ```
data/docs/overview.md CHANGED
@@ -14,6 +14,7 @@
14
14
  7. [SQL](custom_checks/sql.md)
15
15
  8. [TLS](custom_checks/tls.md)
16
16
  9. [Azure File Check](custom_checks/azure_file_check.md)
17
+ 10. [ECS Container Instance Check](custom_checks/ecs_container_instance_check.md)
17
18
  5. [Event Subscriptions](event_subscriptions.md)
18
19
  6. [Notifiers](notifiers.md)
19
20
  7. [Maintenance Mode](maintenance_mode.md)
@@ -16,6 +16,7 @@ require 'cfnguardian/resources/dynamodb_table'
16
16
  require 'cfnguardian/resources/ec2_instance'
17
17
  require 'cfnguardian/resources/ecs_cluster'
18
18
  require 'cfnguardian/resources/ecs_service'
19
+ require 'cfnguardian/resources/eks_container_insights'
19
20
  require 'cfnguardian/resources/elastic_file_system'
20
21
  require 'cfnguardian/resources/elasticache_replication_group'
21
22
  require 'cfnguardian/resources/elastic_loadbalancer'
@@ -40,9 +41,13 @@ require 'cfnguardian/resources/amazonmq_rabbitmq'
40
41
  require 'cfnguardian/resources/batch'
41
42
  require 'cfnguardian/resources/glue'
42
43
  require 'cfnguardian/resources/step_functions'
44
+ require 'cfnguardian/resources/vpn_tunnel'
45
+ require 'cfnguardian/resources/vpn_connection'
46
+ require 'cfnguardian/resources/elastic_search'
43
47
  require 'cfnguardian/version'
44
48
  require 'cfnguardian/error'
45
49
 
50
+
46
51
  module CfnGuardian
47
52
  class Compile
48
53
  include Logging
@@ -8,7 +8,7 @@ Resources:
8
8
  Node: Default
9
9
  AmazonMQRabbitMQQueue:
10
10
  - Id: Default
11
- Queue: Default
11
+ Broker: Default
12
12
  Vhost: Default
13
13
  ApiGateway:
14
14
  - Id: Default
@@ -28,12 +28,20 @@ Resources:
28
28
  ECSCluster:
29
29
  - Id: Default
30
30
  ECSService:
31
+ - Id: Default
32
+ Cluster: Default
33
+ EKSContainerInsightsCluster:
34
+ - Id: Default
35
+ EKSContainerInsightsNamespace:
31
36
  - Id: Default
32
37
  Cluster: Default
33
38
  ElasticFileSystem:
34
39
  - Id: Default
35
40
  ElasticLoadBalancer:
36
41
  - Id: Default
42
+ ElasticSearch:
43
+ - Id: Default
44
+ - Domain: Default
37
45
  ElastiCacheReplicationGroup:
38
46
  - Id: Default
39
47
  Http:
@@ -100,4 +108,8 @@ Resources:
100
108
  Query: Default
101
109
  SQSQueue:
102
110
  - Id: Default
111
+ VPNTunnel:
112
+ - Id: Default
113
+ VPNConnection:
114
+ - Id: Default
103
115
 
@@ -122,8 +122,8 @@ module CfnGuardian
122
122
  @group = 'AmazonMQRabbitMQQueue'
123
123
  @namespace = 'AWS/AmazonMQ'
124
124
  @dimensions = {
125
- Broker: resource['Id'],
126
- Queue: resource['Queue'],
125
+ Broker: resource['Broker'],
126
+ Queue: resource['Id'],
127
127
  VirtualHost: resource['Vhost']
128
128
  }
129
129
  end
@@ -203,7 +203,28 @@ module CfnGuardian
203
203
  }
204
204
  end
205
205
  end
206
+
207
+ class EKSContainerInsightsClusterAlarm < BaseAlarm
208
+ def initialize(resource)
209
+ super(resource)
210
+ @group = 'EKSContainerInsightsCluster'
211
+ @namespace = 'ContainerInsights'
212
+ @dimensions = { ClusterName: resource['Id'] }
213
+ end
214
+ end
206
215
 
216
+ class EKSContainerInsightsNamespaceAlarm < BaseAlarm
217
+ def initialize(resource)
218
+ super(resource)
219
+ @group = 'EKSContainerInsightsNamespace'
220
+ @namespace = 'ContainerInsights'
221
+ @dimensions = {
222
+ ClusterName: resource['Cluster'],
223
+ Namespace: resource['Id']
224
+ }
225
+ end
226
+ end
227
+
207
228
  class ElastiCacheReplicationGroupAlarm < BaseAlarm
208
229
  def initialize(resource)
209
230
  super(resource)
@@ -212,6 +233,21 @@ module CfnGuardian
212
233
  @dimensions = { CacheClusterId: resource['Id'] }
213
234
  end
214
235
  end
236
+
237
+ class ElasticSearchAlarm < BaseAlarm
238
+ def initialize(resource)
239
+ super(resource)
240
+ @group = 'ElasticSearch'
241
+ @namespace = 'AWS/ElasticSearch'
242
+ @dimensions = { DomainName: resource['Domain'], ClientId: resource['Id']}
243
+ @comparison_operator = 'GreaterThanThreshold'
244
+ @threshold = 1
245
+ @evaluation_periods = 5
246
+ @treat_missing_data = 'breaching'
247
+ @period = 60
248
+ @data_points_to_alarm = 1
249
+ end
250
+ end
215
251
 
216
252
  class ElasticLoadBalancerAlarm < BaseAlarm
217
253
  def initialize(resource)
@@ -445,6 +481,28 @@ module CfnGuardian
445
481
  @dimensions = { StorageAccount: resource['Id'], StorageContainer: resource['Container'] }
446
482
  end
447
483
  end
448
-
484
+
485
+ class VPNTunnelAlarm < BaseAlarm
486
+ def initialize(resource)
487
+ super(resource)
488
+ @group = 'VPNTunnel'
489
+ @namespace = 'AWS/VPN'
490
+ @dimensions = {
491
+ TunnelIpAddress: resource['Id']
492
+ }
493
+ end
494
+ end
495
+
496
+ class VPNConnectionAlarm < BaseAlarm
497
+ def initialize(resource)
498
+ super(resource)
499
+ @group = 'VPNConnection'
500
+ @namespace = 'AWS/VPN'
501
+ @dimensions = {
502
+ VpnId: resource['Id']
503
+ }
504
+ end
505
+ end
506
+
449
507
  end
450
508
  end
@@ -107,5 +107,7 @@ module CfnGuardian
107
107
  class NetworkTargetGroupEventSubscription < BaseEventSubscription; end
108
108
  class RedshiftClusterEventSubscription < BaseEventSubscription; end
109
109
  class StepFunctionsSubscription < BaseEventSubscription; end
110
+ class VPNTunnelEventSubscription < BaseEventSubscription; end
111
+ class VPNConnectionEventSubscription < BaseEventSubscription; end
110
112
  end
111
113
  end
@@ -17,6 +17,17 @@ module CfnGuardian
17
17
  alarm.threshold = 90
18
18
  alarm.evaluation_periods = 10
19
19
  @alarms.push(alarm)
20
+
21
+ alarm = CfnGuardian::Models::Ec2InstanceAlarm.new(@resource)
22
+ alarm.name = 'CPUCreditBalanceLow'
23
+ alarm.metric_name = 'CPUCreditBalance'
24
+ alarm.comparison_operator = 'LessThanThreshold'
25
+ alarm.statistic = 'Minimum'
26
+ alarm.threshold = 100
27
+ alarm.evaluation_periods = 5
28
+ alarm.treat_missing_data = 'notBreaching'
29
+ alarm.datapoints_to_alarm = 5
30
+ @alarms.push(alarm)
20
31
  end
21
32
 
22
33
  def default_event_subscriptions()
@@ -0,0 +1,99 @@
1
+ module CfnGuardian::Resource
2
+ class EKSContainerInsightsCluster < Base
3
+
4
+ def default_alarms
5
+
6
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
7
+ alarm.name = 'NodeCpuUtilisationBase'
8
+ alarm.metric_name = 'node_cpu_utilization'
9
+ alarm.comparison_operator = 'GreaterThanThreshold'
10
+ alarm.statistic = 'Maximum'
11
+ alarm.threshold = 75
12
+ alarm.evaluation_periods = 60
13
+ alarm.alarm_action = 'Warning'
14
+ @alarms.push(alarm)
15
+
16
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
17
+ alarm.name = 'NodeCpuUtilisationSpike'
18
+ alarm.metric_name = 'node_cpu_utilization'
19
+ alarm.comparison_operator = 'GreaterThanThreshold'
20
+ alarm.statistic = 'Maximum'
21
+ alarm.threshold = 95
22
+ alarm.evaluation_periods = 5
23
+ @alarms.push(alarm)
24
+
25
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
26
+ alarm.name = 'NodeFileSystemUtilisationCrit'
27
+ alarm.metric_name = 'node_filesystem_utilization'
28
+ alarm.comparison_operator = 'GreaterThanThreshold'
29
+ alarm.statistic = 'Maximum'
30
+ alarm.threshold = 90
31
+ alarm.evaluation_periods = 1
32
+ @alarms.push(alarm)
33
+
34
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
35
+ alarm.name = 'NodeFileSystemUtilisationWarning'
36
+ alarm.metric_name = 'node_filesystem_utilization'
37
+ alarm.comparison_operator = 'GreaterThanThreshold'
38
+ alarm.statistic = 'Maximum'
39
+ alarm.threshold = 75
40
+ alarm.evaluation_periods = 1
41
+ alarm.alarm_action = 'Warning'
42
+ @alarms.push(alarm)
43
+
44
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
45
+ alarm.name = 'NodeMemoryUtilisationBase'
46
+ alarm.metric_name = 'node_memory_utilization'
47
+ alarm.comparison_operator = 'GreaterThanThreshold'
48
+ alarm.statistic = 'Maximum'
49
+ alarm.threshold = 80
50
+ alarm.evaluation_periods = 60
51
+ alarm.alarm_action = 'Warning'
52
+ @alarms.push(alarm)
53
+
54
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
55
+ alarm.name = 'NodeMemoryUtilisationSpike'
56
+ alarm.metric_name = 'node_memory_utilization'
57
+ alarm.comparison_operator = 'GreaterThanThreshold'
58
+ alarm.statistic = 'Maximum'
59
+ alarm.threshold = 90
60
+ alarm.evaluation_periods = 5
61
+ @alarms.push(alarm)
62
+
63
+ alarm = CfnGuardian::Models::EKSContainerInsightsClusterAlarm.new(@resource)
64
+ alarm.name = 'ClusterFailedNodeCount'
65
+ alarm.metric_name = 'cluster_failed_node_count'
66
+ alarm.comparison_operator = 'GreaterThanThreshold'
67
+ alarm.statistic = 'Minimum'
68
+ alarm.threshold = 0
69
+ alarm.evaluation_periods = 1
70
+ @alarms.push(alarm)
71
+
72
+ end
73
+ end
74
+
75
+ class EKSContainerInsightsNamespace < Base
76
+
77
+ def default_alarms
78
+
79
+ alarm = CfnGuardian::Models::EKSContainerInsightsNamespaceAlarm.new(@resource)
80
+ alarm.name = 'PodCpuUtilisation'
81
+ alarm.metric_name = 'pod_cpu_utilization'
82
+ alarm.comparison_operator = 'GreaterThanThreshold'
83
+ alarm.statistic = 'Maximum'
84
+ alarm.threshold = 90
85
+ alarm.evaluation_periods = 5
86
+ @alarms.push(alarm)
87
+
88
+ alarm = CfnGuardian::Models::EKSContainerInsightsNamespaceAlarm.new(@resource)
89
+ alarm.name = 'PodMemoryUtilisation'
90
+ alarm.metric_name = 'pod_memory_utilization'
91
+ alarm.comparison_operator = 'GreaterThanThreshold'
92
+ alarm.statistic = 'Maximum'
93
+ alarm.threshold = 90
94
+ alarm.evaluation_periods = 5
95
+ @alarms.push(alarm)
96
+
97
+ end
98
+ end
99
+ end
@@ -11,6 +11,17 @@ module CfnGuardian
11
11
  alarm.evaluation_periods = 5
12
12
  alarm.statistic = 'Minimum'
13
13
  @alarms.push(alarm)
14
+
15
+ alarm = CfnGuardian::Models::ElasticFileSystemAlarm.new(@resource)
16
+ alarm.name = 'BurstCreditBalanceLow'
17
+ alarm.metric_name = 'BurstCreditBalance'
18
+ alarm.comparison_operator = 'LessThanThreshold'
19
+ alarm.statistic = 'Minimum'
20
+ alarm.threshold = 1000000000000
21
+ alarm.evaluation_periods = 5
22
+ alarm.treat_missing_data = 'notBreaching'
23
+ alarm.datapoints_to_alarm = 5
24
+ @alarms.push(alarm)
14
25
  end
15
26
  end
16
27
  end
@@ -0,0 +1,137 @@
1
+ module CfnGuardian::Resource
2
+ class ElasticSearch < Base
3
+
4
+ def default_alarms
5
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
6
+ alarm.name = 'NodeCount'
7
+ alarm.metric_name = 'Nodes'
8
+ alarm.threshold = 3
9
+ alarm.evaluation_periods = 1440 # 24 hours
10
+ alarm.data_points_to_alarm = 1
11
+ alarm.comparison_operator = 'LessThanOrEqualToThreshold'
12
+ alarm.alarm_action = 'Critical'
13
+ alarm.enabled = false
14
+ @alarms.push(alarm)
15
+
16
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
17
+ alarm.name = 'JVMMemoryPressureWarning'
18
+ alarm.metric_name = 'JVMMemoryPressure'
19
+ alarm.threshold = 72
20
+ alarm.evaluation_periods = 5
21
+ alarm.data_points_to_alarm = 3
22
+ alarm.alarm_action = 'Warning'
23
+ @alarms.push(alarm)
24
+
25
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
26
+ alarm.name = 'JVMMemoryPressureCrit'
27
+ alarm.metric_name = 'JVMMemoryPressure'
28
+ alarm.threshold = 92
29
+ alarm.evaluation_periods = 5
30
+ alarm.alarm_action = 'Critical'
31
+ @alarms.push(alarm)
32
+
33
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
34
+ alarm.name = 'ClusterIndexWritesBlocked'
35
+ alarm.metric_name = 'ClusterIndexWritesBlocked'
36
+ alarm.threshold = 1
37
+ alarm.evaluation_periods = 5
38
+ alarm.alarm_action = 'Critical'
39
+ @alarms.push(alarm)
40
+
41
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
42
+ alarm.name = 'MasterNodeCPUUtilisationWarning'
43
+ alarm.metric_name = 'MasterCPUUtilization'
44
+ alarm.threshold = 75
45
+ alarm.evaluation_periods = 60
46
+ alarm.alarm_action = 'Warning'
47
+ @alarms.push(alarm)
48
+
49
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
50
+ alarm.name = 'MasterNodeCPUUtilisationCrit'
51
+ alarm.metric_name = 'MasterCPUUtilization'
52
+ alarm.threshold = 95
53
+ alarm.evaluation_periods = 10
54
+ alarm.alarm_action = 'Critical'
55
+ @alarms.push(alarm)
56
+
57
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
58
+ alarm.name = 'FreeStorageSpaceWarning'
59
+ alarm.metric_name = 'FreeStorageSpace'
60
+ alarm.threshold = 50000
61
+ alarm.evaluation_periods = 1
62
+ alarm.alarm_action = 'Warning'
63
+ alarm.statistic = 'Minimum'
64
+ @alarms.push(alarm)
65
+
66
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
67
+ alarm.name = 'FreeStorageSpaceCrit'
68
+ alarm.metric_name = 'FreeStorageSpace'
69
+ alarm.threshold = 25000
70
+ alarm.evaluation_periods = 1
71
+ alarm.alarm_action = 'Critical'
72
+ @alarms.push(alarm)
73
+
74
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
75
+ alarm.name = 'CPUUtilizationWarning'
76
+ alarm.metric_name = 'CPUUtilization'
77
+ alarm.threshold = 75
78
+ alarm.evaluation_periods = 15
79
+ alarm.data_points_to_alarm = 3
80
+ alarm.alarm_action = 'Warning'
81
+ alarm.statistic = 'Average'
82
+ @alarms.push(alarm)
83
+
84
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
85
+ alarm.name = 'CPUUtilizationCrit'
86
+ alarm.metric_name = 'CPUUtilization'
87
+ alarm.threshold = 95
88
+ alarm.evaluation_periods = 5
89
+ alarm.data_points_to_alarm = 3
90
+ alarm.alarm_action = 'Critical'
91
+ alarm.statistic = 'Average'
92
+ @alarms.push(alarm)
93
+
94
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
95
+ alarm.name = 'KMSKeyError'
96
+ alarm.metric_name = 'KMSKeyError'
97
+ alarm.threshold = 1
98
+ alarm.evaluation_periods = 1
99
+ alarm.alarm_action = 'Warning'
100
+ alarm.statistic = 'Minimum'
101
+ alarm.comparison_operator = 'GreaterThanOrEqualToThreshold'
102
+ @alarms.push(alarm)
103
+
104
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
105
+ alarm.name = 'KMSKeyInaccessible'
106
+ alarm.metric_name = 'KMSKeyInaccessible'
107
+ alarm.threshold = 1
108
+ alarm.evaluation_periods = 1
109
+ alarm.alarm_action = 'Critical'
110
+ alarm.statistic = 'Minimum'
111
+ alarm.comparison_operator = 'GreaterThanOrEqualToThreshold'
112
+ alarm.enabled = false
113
+ @alarms.push(alarm)
114
+
115
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
116
+ alarm.name = 'ClusterStatusRed'
117
+ alarm.metric_name = 'ClusterStatus.red'
118
+ alarm.threshold = 1
119
+ alarm.evaluation_periods = 1
120
+ alarm.alarm_action = 'Critical'
121
+ alarm.statistic = 'Minimum'
122
+ alarm.comparison_operator = 'GreaterThanOrEqualToThreshold'
123
+ @alarms.push(alarm)
124
+
125
+ alarm = CfnGuardian::Models::ElasticSearchAlarm.new(@resource)
126
+ alarm.name = 'ClusterStatusYellow'
127
+ alarm.metric_name = 'ClusterStatus.yellow'
128
+ alarm.threshold = 1
129
+ alarm.evaluation_periods = 1
130
+ alarm.alarm_action = 'Warning'
131
+ alarm.statistic = 'Minimum'
132
+ alarm.comparison_operator = 'GreaterThanOrEqualToThreshold'
133
+ @alarms.push(alarm)
134
+
135
+ end
136
+ end
137
+ end
@@ -1,14 +1,14 @@
1
1
  module CfnGuardian::Resource
2
2
  class RedshiftCluster < Base
3
-
4
- def default_alarms
3
+
4
+ def default_alarms
5
5
  alarm = CfnGuardian::Models::RedshiftClusterAlarm.new(@resource)
6
6
  alarm.name = 'CPUUtilizationHighSpike'
7
7
  alarm.metric_name = 'CPUUtilization'
8
8
  alarm.threshold = 95
9
9
  alarm.evaluation_periods = 10
10
10
  @alarms.push(alarm)
11
-
11
+
12
12
  alarm = CfnGuardian::Models::RedshiftClusterAlarm.new(@resource)
13
13
  alarm.name = 'CPUUtilizationHighBase'
14
14
  alarm.metric_name = 'CPUUtilization'
@@ -16,7 +16,7 @@ module CfnGuardian::Resource
16
16
  alarm.evaluation_periods = 60
17
17
  alarm.alarm_action = 'Warning'
18
18
  @alarms.push(alarm)
19
-
19
+
20
20
  alarm = CfnGuardian::Models::RedshiftClusterAlarm.new(@resource)
21
21
  alarm.name = 'UnHealthyCluster'
22
22
  alarm.metric_name = 'HealthStatus'
@@ -24,7 +24,24 @@ module CfnGuardian::Resource
24
24
  alarm.threshold = 1
25
25
  alarm.evaluation_periods = 10
26
26
  @alarms.push(alarm)
27
+
28
+ alarm = CfnGuardian::Models::RedshiftClusterAlarm.new(@resource)
29
+ alarm.name = 'DiskSpaceUsedCrit'
30
+ alarm.metric_name = 'PercentageDiskSpaceUsed'
31
+ alarm.comparison_operator = 'GreaterThanThreshold'
32
+ alarm.threshold = 90
33
+ alarm.evaluation_periods = 10
34
+ @alarms.push(alarm)
35
+
36
+ alarm = CfnGuardian::Models::RedshiftClusterAlarm.new(@resource)
37
+ alarm.name = 'DiskSpaceUsedWarm'
38
+ alarm.metric_name = 'PercentageDiskSpaceUsed'
39
+ alarm.comparison_operator = 'GreaterThanThreshold'
40
+ alarm.threshold = 80
41
+ alarm.evaluation_periods = 10
42
+ alarm.alarm_action = 'Warning'
43
+ @alarms.push(alarm)
27
44
  end
28
-
45
+
29
46
  end
30
47
  end
@@ -0,0 +1,18 @@
1
+ module CfnGuardian::Resource
2
+ class VPNConnection < Base
3
+
4
+ def default_alarms
5
+ alarm = CfnGuardian::Models::VPNConnectionAlarm.new(@resource)
6
+ alarm.name = 'VPNConnectionState'
7
+ alarm.metric_name = 'TunnelState'
8
+ alarm.comparison_operator = 'LessThanThreshold'
9
+ alarm.statistic = 'Average'
10
+ alarm.threshold = 0.5
11
+ alarm.evaluation_periods = 3
12
+ alarm.treat_missing_data = 'breaching'
13
+ alarm.datapoints_to_alarm = 3
14
+ @alarms.push(alarm)
15
+ end
16
+
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ module CfnGuardian::Resource
2
+ class VPNTunnel < Base
3
+
4
+ def default_alarms
5
+ alarm = CfnGuardian::Models::VPNTunnelAlarm.new(@resource)
6
+ alarm.name = 'VPNTunnelState'
7
+ alarm.metric_name = 'TunnelState'
8
+ alarm.comparison_operator = 'LessThanThreshold'
9
+ alarm.statistic = 'Minimum'
10
+ alarm.threshold = 1
11
+ alarm.evaluation_periods = 5
12
+ alarm.treat_missing_data = 'breaching'
13
+ alarm.datapoints_to_alarm = 5
14
+ @alarms.push(alarm)
15
+ end
16
+
17
+ end
18
+ end
@@ -1,4 +1,4 @@
1
1
  module CfnGuardian
2
- VERSION = "0.6.6"
2
+ VERSION = "0.6.11"
3
3
  CHANGE_SET_VERSION = VERSION.gsub('.', '-').freeze
4
4
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: cfn-guardian
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.6.6
4
+ version: 0.6.11
5
5
  platform: ruby
6
6
  authors:
7
7
  - Guslington
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-03-30 00:00:00.000000000 Z
11
+ date: 2021-06-30 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: thor
@@ -238,6 +238,7 @@ files:
238
238
  - docs/composite_alarms.md
239
239
  - docs/custom_checks/azure_file_check.md
240
240
  - docs/custom_checks/domain_expiry.md
241
+ - docs/custom_checks/ecs_container_instance_check.md
241
242
  - docs/custom_checks/http.md
242
243
  - docs/custom_checks/log_group_metric_filters.md
243
244
  - docs/custom_checks/nrpe.md
@@ -284,8 +285,10 @@ files:
284
285
  - lib/cfnguardian/resources/ec2_instance.rb
285
286
  - lib/cfnguardian/resources/ecs_cluster.rb
286
287
  - lib/cfnguardian/resources/ecs_service.rb
288
+ - lib/cfnguardian/resources/eks_container_insights.rb
287
289
  - lib/cfnguardian/resources/elastic_file_system.rb
288
290
  - lib/cfnguardian/resources/elastic_loadbalancer.rb
291
+ - lib/cfnguardian/resources/elastic_search.rb
289
292
  - lib/cfnguardian/resources/elasticache_replication_group.rb
290
293
  - lib/cfnguardian/resources/glue.rb
291
294
  - lib/cfnguardian/resources/http.rb
@@ -306,6 +309,8 @@ files:
306
309
  - lib/cfnguardian/resources/sqs_queue.rb
307
310
  - lib/cfnguardian/resources/step_functions.rb
308
311
  - lib/cfnguardian/resources/tls.rb
312
+ - lib/cfnguardian/resources/vpn_connection.rb
313
+ - lib/cfnguardian/resources/vpn_tunnel.rb
309
314
  - lib/cfnguardian/s3.rb
310
315
  - lib/cfnguardian/stacks/main.rb
311
316
  - lib/cfnguardian/stacks/resources.rb
@@ -334,7 +339,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
334
339
  - !ruby/object:Gem::Version
335
340
  version: '0'
336
341
  requirements: []
337
- rubygems_version: 3.1.4
342
+ rubygems_version: 3.1.6
338
343
  signing_key:
339
344
  specification_version: 4
340
345
  summary: Manages AWS cloudwatch alarms with default templates using cloudformation