generated from Sage-Bionetworks-IT/lambda-template
-
Notifications
You must be signed in to change notification settings - Fork 2
/
template.yaml
90 lines (84 loc) · 3.43 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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: >
AWS Lambda to scan for and remove unattached EBS volumes
# More info about Globals: https://github.com/awslabs/serverless-application-model/blob/master/docs/globals.rst
Globals:
Function:
Timeout: 300
Parameters:
Schedule:
Description: >
Schedule to execute the lambda, can be a rate or a cron schedule. Format at
https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html
Type: String
Default: cron(0 2 * * ? *) # Run at 2am every night
ConstraintDescription: "Use schedule format: https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html"
MinimumAge:
Description: >
Volumes younger than the specified age will be ignored
Type: String
Default: "5m"
AllowedPattern: "\\d+[smd]"
ConstraintDescription: "Must be an integer suffixed with 's', 'm', or 'd' for seconds, minutes, or days respectively"
Resources:
EbsCleanupFunction:
Type: AWS::Serverless::Function # More info about Function Resource: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#awsserverlessfunction
Properties:
CodeUri: .
Handler: ebs_cleanup/app.lambda_handler
Runtime: python3.9
Role: !GetAtt FunctionRole.Arn
Environment:
Variables:
ebsMinimumAge: !Ref MinimumAge
Events:
NightlyTrigger:
Type: Schedule # More info about Event Source: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#schedule
Properties:
Schedule: !Ref Schedule
ApiTrigger:
Type: Api # More info about API Event Source: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#api
Properties:
Path: /clean
Method: get
FunctionPolicy: # policy to allow scanning and deleting of volumes
Type: AWS::IAM::ManagedPolicy
Properties:
PolicyDocument:
Version: 2012-10-17
Statement:
- Sid: ManageVolumes
Effect: Allow
Resource: "*"
Action:
- ec2:Describe*
- ec2:DeleteVolume
FunctionRole: # execute lambda function with this role
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
- !Ref FunctionPolicy
Outputs:
# ServerlessRestApi is an implicit API created out of Events key under Serverless::Function
# Find out more about other implicit resources you can reference within SAM
# https://github.com/awslabs/serverless-application-model/blob/master/docs/internals/generated_resources.rst#api
EbsCleanupApi:
Description: "API Gateway endpoint URL for Prod stage for EBS Cleanup function"
Value: !Sub "https://${ServerlessRestApi}.execute-api.${AWS::Region}.amazonaws.com/Prod/clean/"
EbsCleanupFunctionArn:
Description: "EBS Cleanup Lambda Function ARN"
Value: !GetAtt EbsCleanupFunction.Arn
EbsCleanupFunctionRoleArn:
Description: "Implicit IAM Role created for EBS Cleanup function"
Value: !GetAtt FunctionRole.Arn