forked from buzzsurfr/VpcSubnetIpMonitor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplate.yaml
49 lines (49 loc) · 1.4 KB
/
template.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Serverless Specification template describing your function.
Resources:
VpcSubnetIpMonitor:
Type: 'AWS::Serverless::Function'
DependsOn:
- MonitorRole
Properties:
Handler: VpcSubnetIpMonitor/index.handler
Runtime: nodejs6.10
Description: ''
MemorySize: 128
Timeout: 5
Role: !GetAtt MonitorRole.Arn
Events:
CheckSubnetsScheduledEvent:
Type: Schedule
Properties:
Schedule: rate(5 minutes)
VpcSubnetIpMonitorExecutionPolicy:
Type: 'AWS::IAM::Policy'
DependsOn:
- MonitorRole
Properties:
PolicyName: VpcSubnetIpMonitorExecutionPolicy
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Action:
- 'cloudwatch:PutMetricData'
- 'ec2:DescribeSubnets'
Resource: '*'
Roles:
- Ref: "MonitorRole"
MonitorRole:
Type: 'AWS::IAM::Role'
Properties:
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Principal:
Service: lambda.amazonaws.com
Action: 'sts:AssumeRole'
ManagedPolicyArns:
- arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole
RoleName: VpcSubnetIpMonitorRole