-
Notifications
You must be signed in to change notification settings - Fork 17
/
serverless.yml
119 lines (116 loc) · 3.32 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
service: kinesis-stream-fanout
provider:
name: aws
runtime: nodejs6.10
functions:
processPositive:
handler: lambda/handler.processPositive
timeout: 10
events:
- stream:
type: kinesis
batchSize: 100
startingPosition: TRIM_HORIZON
enabled: true
arn:
Fn::GetAtt:
- PositiveTransactionsStream
- Arn
processNegative:
handler: lambda/handler.processNegative
timeout: 10
events:
- stream:
type: kinesis
batchSize: 100
startingPosition: TRIM_HORIZON
enabled: true
arn:
Fn::GetAtt:
- NegativeTransactionsStream
- Arn
resources:
Resources:
TransactionsStream:
Type: AWS::Kinesis::Stream
Properties:
Name: Transactions
ShardCount: 1
PositiveTransactionsStream:
Type: AWS::Kinesis::Stream
Properties:
Name: PositiveTransactions
ShardCount: 1
NegativeTransactionsStream:
Type: AWS::Kinesis::Stream
Properties:
Name: NegativeTransactions
ShardCount: 1
KinesisAnalyticsIAMRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
- Sid: 'KinesisAnalyticsAssumeRole'
Effect: Allow
Principal:
Service: kinesisanalytics.amazonaws.com
Action: 'sts:AssumeRole'
Policies:
- PolicyName: kinesis-stream-fanout-kinesis-analytics
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: "Allow"
Action:
- "kinesis:DescribeStream"
- "kinesis:GetShardIterator"
- "kinesis:GetRecords"
Resource:
'Fn::GetAtt':
- TransactionsStream
- Arn
- Effect: "Allow"
Action:
- "kinesis:DescribeStream"
- "kinesis:PutRecord"
- "kinesis:PutRecords"
Resource:
'Fn::GetAtt':
- PositiveTransactionsStream
- Arn
- Effect: "Allow"
Action:
- "kinesis:DescribeStream"
- "kinesis:PutRecord"
- "kinesis:PutRecords"
Resource:
'Fn::GetAtt':
- NegativeTransactionsStream
- Arn
Outputs:
TransactionsStreamARN:
Description: Transactions Kinesis Stream ARN
Value:
'Fn::GetAtt':
- TransactionsStream
- Arn
PositiveTransactionsStreamARN:
Description: Positive Transactions Kinesis Stream ARN
Value:
'Fn::GetAtt':
- PositiveTransactionsStream
- Arn
NegativeTransactionsStreamARN:
Description: Negative Transactions Kinesis Stream ARN
Value:
'Fn::GetAtt':
- NegativeTransactionsStream
- Arn
KinesisAnalyticsIAMRoleARN:
Description: IAM Role ARN for Kinesis Analytics
Value:
'Fn::GetAtt':
- KinesisAnalyticsIAMRole
- Arn