-
Notifications
You must be signed in to change notification settings - Fork 0
/
serverless.yml
123 lines (117 loc) · 2.57 KB
/
serverless.yml
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
service: who-is-it
provider:
name: aws
runtime: go1.x
environment:
Bucket: !Ref Storage
Table: !Ref Table
Region: eu-west-1
stage: main
region: eu-west-1
iamRoleStatements:
- Effect: "Allow"
Action:
- "rekognition:RecognizeCelebrities"
Resource: "*"
- Effect: "Allow"
Action:
- "dynamodb:Scan"
- "dynamodb:UpdateItem"
Resource:
- !GetAtt Table.Arn
- Effect: "Allow"
Action:
- "s3:PutObject"
- "s3:PutObjectAcl"
Resource:
- Fn::Join:
- ""
- - "arn:aws:s3:::"
- "Ref": "Storage"
- "/*"
- Fn::Join:
- ""
- - "arn:aws:s3:::"
- "Ref": "Storage"
- Effect: "Allow"
Action:
- "s3:ListBucket"
Resource:
{
"Fn::Join":
["", ["arn:aws:s3:::", { "Ref": "ServerlessDeploymentBucket" }]],
}
- Effect: "Allow"
Action:
- "s3:PutObject"
Resource:
Fn::Join:
- ""
- - "arn:aws:s3:::"
- "Ref": "ServerlessDeploymentBucket"
- "/*"
package:
exclude:
- ./**
include:
- ./bin/**
functions:
image-upload:
handler: bin/image-upload
events:
- http:
path: celeb
method: post
image-created:
handler: bin/image-created
reservedConcurrency: 4
events:
- sqs:
batchSize: 1
arn:
Fn::GetAtt:
- Queue
- Arn
get-celebs:
handler: bin/get-celebs
events:
- http:
path: celeb
method: get
resources:
Resources:
Storage:
Type: AWS::S3::Bucket
Properties:
NotificationConfiguration:
QueueConfigurations:
- Event: s3:ObjectCreated:*
Queue: !GetAtt Queue.Arn
Table:
Type: AWS::DynamoDB::Table
Properties:
AttributeDefinitions:
- AttributeName: ID
AttributeType: S
KeySchema:
- AttributeName: ID
KeyType: HASH
BillingMode: PAY_PER_REQUEST
Queue:
Type: AWS::SQS::Queue
Properties:
VisibilityTimeout: 120
QueuePolicy:
Type: AWS::SQS::QueuePolicy
Properties:
Queues:
- !Ref Queue
PolicyDocument:
Id: "SQSPolicy"
Version: "2012-10-17"
Statement:
- Effect: Allow
Principal:
Service: "s3.amazonaws.com"
Action: "sqs:SendMessage"
Resource: !GetAtt Queue.Arn