This repository was archived by the owner on Nov 9, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathfunction.yaml
More file actions
205 lines (174 loc) · 5.09 KB
/
function.yaml
File metadata and controls
205 lines (174 loc) · 5.09 KB
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
---
AWSTemplateFormatVersion: 2010-09-09
Description: 'git LFS: Lambda function'
Metadata:
AWS::CloudFormation::Interface:
ParameterLabels:
GitHubOwner:
default: Owner
GitHubRepo:
default: Repo
HandlerFunction:
default: Function
HandlerModule:
default: Module
LargeFileStoreBucketName:
default: Bucket
LargeFileStorageClass:
default: Storage class
Policies:
default: IAM policies
PythonVersion:
default: Python version
ParameterGroups:
-
Label: Lambda
Parameters:
- PythonVersion
- Layers
- Policies
-
Label: glawit
Parameters:
- HandlerModule
- HandlerFunction
-
Label: GitHub
Parameters:
- GitHubOwner
- GitHubRepo
-
Label: LFS store
Parameters:
- LargeFileStoreBucketName
- LargeFileStorageClass
Parameters:
ApiPaginationMax:
Type: Number
MinValue: 2
Default: 50
ApiPaginationMin:
Type: Number
MinValue: 1
Default: 15
GitHubOwner:
Type: String
GitHubRepo:
Type: String
HandlerFunction:
Description: Name of the API handler function to invoke; usually, the HTTP method in lowercase.
Type: String
HandlerModule:
Description: Name of the glawit module that contains the API handler function to invoke.
Type: String
LargeFileStorageClass:
Description: S3 storage class to use for large file objects.
Type: String
AllowedValues:
- DEEP_ARCHIVE
- GLACIER
- INTELLIGENT_TIERING
- ONEZONE_IA
- REDUCED_REDUNDANCY
- STANDARD
- STANDARD_IA
LargeFileStoreBucketName:
Description: Name of the S3 bucket where large files are stored.
Type: String
Layers:
Description: ARNs of Lambda layers to add to the function's execution environment.
Type: CommaDelimitedList
LockTable:
Description: Name of the DynamoDB table where git LFS locks are registered.
Type: String
Policies:
Description: ARNs of IAM managed policies to attach to the function's role.
Type: CommaDelimitedList
PythonVersion:
Description: Python version to use.
Type: String
Default: '3.7'
Resources:
Function:
Type: AWS::Lambda::Function
Properties:
Code:
ZipFile:
Fn::Sub: |
import glawit.interface.apigw.handler
import glawit.core.api.${HandlerModule}
handler = glawit.interface.apigw.handler.bind_entry_point(
glawit.core.api.${HandlerModule}.${HandlerFunction},
)
Description: git LFS API handler
Environment:
Variables:
API_PAGINATION_MAX:
Ref: ApiPaginationMax
API_PAGINATION_MIN:
Ref: ApiPaginationMin
GITHUB_OWNER:
Ref: GitHubOwner
GITHUB_REPO:
Ref: GitHubRepo
LOCKTABLE:
Ref: LockTable
STORAGE_CLASS:
Ref: LargeFileStorageClass
STORE_BUCKET:
Ref: LargeFileStoreBucketName
Handler: index.handler
Layers:
Ref: Layers
MemorySize: 128
Role:
Fn::GetAtt:
- FunctionRole
- Arn
Runtime:
Fn::Sub: python${PythonVersion}
Timeout: 50
FunctionRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Version: 2012-10-17
Statement:
-
Principal:
Service:
- lambda.amazonaws.com
Action:
- sts:AssumeRole
Effect: Allow
ManagedPolicyArns:
Ref: Policies
Policies:
-
# FIXME
PolicyName: logs
PolicyDocument:
Version: 2012-10-17
Statement:
-
Sid: FIXME # FIXME
Action:
- logs:CreateLogGroup
- logs:CreateLogStream
- logs:PutLogEvents
Resource:
- '*'
-
Fn::Sub: arn:${AWS::Partition}:logs:${AWS::Region}:${AWS::AccountId}:log-group:/aws/lambda/*:*
Effect: Allow
Outputs:
FunctionArn:
Description: ARN of the Lambda function.
Value:
Fn::GetAtt:
- Function
- Arn
FunctionName:
Description: Name of the Lambda function.
Value:
Ref: Function