-
Notifications
You must be signed in to change notification settings - Fork 0
/
serverless.yml
87 lines (73 loc) · 1.8 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
service: poc-1-product-sync-serveless
frameworkVersion: "3"
provider:
name: aws
runtime: nodejs18.x
stage: dev
region: us-east-1
functions:
createPorduct:
handler: src/handler.createProduct
role: ${env:IAM_ROLE}
events:
- http:
method: post
path: force-sync
getProductData:
handler: src/products.getProduct
events:
- http:
method: post
path: get-product
triggerDynamoDB:
handler: src/handler.getDynamoTableData
role: ${env:IAM_ROLE}
events:
- stream:
type: dynamodb
arn: !GetAtt [productTable, StreamArn]
saveDataFromSQSToElastic:
handler: src/handler.saveToElastic
role: ${env:IAM_ROLE}
events:
- sqs:
arn: !GetAtt MyQueue.Arn
plugins:
- serverless-offline
- serverless-dotenv-plugin
resources:
Resources:
productTable:
Type: AWS::DynamoDB::Table
Properties:
TableName: ${env:TABLE_NAME}
BillingMode: PAY_PER_REQUEST
AttributeDefinitions:
- AttributeName: productId
AttributeType: S
KeySchema:
- AttributeName: productId
KeyType: HASH
StreamSpecification:
StreamViewType: NEW_IMAGE
MyKafkaCluster:
Type: AWS::MSK::Cluster
Properties:
BrokerNodeGroupInfo:
InstanceType: kafka.t3.small
ClientSubnets:
- subnet-0404893c8635c986f
- subnet-080c262d4748c9ed5
ClusterName: my-kafka-cluster
KafkaVersion: 2.2.1
NumberOfBrokerNodes: 2
MyQueue:
Type: AWS::SQS::Queue
Properties:
QueueName: product-topic
VisibilityTimeout: 30
MaximumMessageSize: 2048
MessageRetentionPeriod: 345600
package:
individually: true
useDotenv: true