/
serverless.yml
73 lines (67 loc) · 1.84 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
frameworkVersion: '2'
service: cloud-function-demo
provider:
lambdaHashingVersion: 20201221
name: aws
stackName: cloud-function-demo-stack
apiName: cloud-function-demo-api
region: us-east-1
runtime: provided
memorySize: 128
timeout: 3
tracing:
lambda: true
apiGateway: true
package:
individually: true
functions:
getSessions:
name: get-sessions
handler: getSessions
role: LambdaDynamoDBReadOnly
package:
artifact: ./target/cloud-function-dynamodb-lambda-0.0.1-SNAPSHOT-native.zip
events:
- http:
integration: lambda
path: /sessions
method: get
request:
parameters:
querystrings:
userId: false
template:
application/json: '{ "userId": "$input.params(''userId'')" }'
resources:
Resources:
LambdaDynamoDBReadOnly:
Type: AWS::IAM::Role
Properties:
RoleName: LambdaDynamoDBReadOnly
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Principal:
Service:
- lambda.amazonaws.com
Action: sts:AssumeRole
ManagedPolicyArns:
- arn:aws:iam::aws:policy/AmazonDynamoDBReadOnlyAccess
- arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole
- arn:aws:iam::aws:policy/AWSXRayDaemonWriteAccess
sessionsTable:
Type: AWS::DynamoDB::Table
Properties:
TableName: sessions
BillingMode: PAY_PER_REQUEST
AttributeDefinitions:
- AttributeName: userId
AttributeType: S
- AttributeName: sessionId
AttributeType: S
KeySchema:
- AttributeName: userId
KeyType: HASH
- AttributeName: sessionId
KeyType: RANGE