-
Notifications
You must be signed in to change notification settings - Fork 0
/
serverless.yml
71 lines (66 loc) · 1.77 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
org: th3n0m4d
app: big-mouth
service: big-mouth
frameworkVersion: "2"
provider:
name: aws
runtime: nodejs14.x
stage: dev
region: eu-central-1
lambdaHashingVersion: 20201221
environment:
DYNAMO_TABLE_NAME: ${self:custom.restaurantsTableName}
API_ROOT_URL: https://r0241vmogb.execute-api.eu-central-1.amazonaws.com/dev/api/
REGION: ${param:region}
ACCESS_KEY_ID: ${param:accessKeyId}
SECRET_ACCESS_KEY: ${param:secretAccessKey}
custom:
restaurantsTableName: Restaurants
bundle:
copyFiles: # Copy any additional files to the generated package
- from: "static/*" # Where the files are currently
to: "./"
plugins:
- serverless-iam-roles-per-function
- serverless-bundle
- serverless-offline
resources:
Resources:
RestaurantsTable:
Type: AWS::DynamoDB::Table
Properties:
TableName: ${self:custom.restaurantsTableName}
AttributeDefinitions:
- AttributeName: name
AttributeType: S
KeySchema:
- AttributeName: name
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 1
WriteCapacityUnits: 1
functions:
# Static Html pages
index:
handler: functions/home.index
events:
- http:
path: /
method: GET
# API
getRestaurants:
handler: functions/api.getRestaurants
events:
- http:
path: /api/restaurants
method: GET
authorizer: aws_iam
iamRoleStatements:
- Effect: Allow
Action:
- "dynamodb:Scan"
Resource: !GetAtt RestaurantsTable.Arn
- Effect: Allow
Action: execute-api:Invoke
# Apply policy to all stages and regions for this endpoint
Resource: arn:aws:execute-api:*:*:*/*/GET/api/restaurants