-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathtemplate.yaml
171 lines (156 loc) · 4.75 KB
/
template.yaml
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
AWSTemplateFormatVersion: "2010-09-09"
Transform: AWS::Serverless-2016-10-31
Description: SAM Template for serverless WebSocket chat example
# More info about Globals: https://github.com/awslabs/serverless-application-model/blob/master/docs/globals.rst
Globals:
Function:
Timeout: 3
CodeUri: websocket_demo/
MemorySize: 1024
Runtime: python3.8
Environment:
Variables:
DYNAMO_TABLE_NAME: !Ref ConnectionsTable
Resources:
ConnectionsTable:
Type: AWS::DynamoDB::Table
Properties:
BillingMode: PAY_PER_REQUEST
AttributeDefinitions:
- AttributeName: pk
AttributeType: S
- AttributeName: epoch
AttributeType: N
KeySchema:
- AttributeName: pk
KeyType: HASH
- AttributeName: epoch
KeyType: RANGE
WebSocketApi:
Type: AWS::ApiGatewayV2::Api
Properties:
Name: MyWebSocketApi
ProtocolType: WEBSOCKET
RouteSelectionExpression: $request.body.action
ConnectRoute:
Type: AWS::ApiGatewayV2::Route
Properties:
ApiId: !Ref WebSocketApi
RouteKey: $connect
OperationName: ConnectRoute
Target: !Join
- "/"
- - "integrations"
- !Ref ConnectInteg
ConnectInteg:
Type: AWS::ApiGatewayV2::Integration
Properties:
ApiId: !Ref WebSocketApi
Description: Connect Integration
IntegrationType: AWS_PROXY
IntegrationUri:
Fn::Sub: arn:aws:apigateway:${AWS::Region}:lambda:path/2015-03-31/functions/${OnConnectFunction.Arn}/invocations
DisConnectRoute:
Type: AWS::ApiGatewayV2::Route
Properties:
ApiId: !Ref WebSocketApi
RouteKey: $disconnect
OperationName: DisConnectRoute
Target: !Join
- "/"
- - "integrations"
- !Ref DisConnectInteg
DisConnectInteg:
Type: AWS::ApiGatewayV2::Integration
Properties:
ApiId: !Ref WebSocketApi
Description: DisConnect Integration
IntegrationType: AWS_PROXY
IntegrationUri:
Fn::Sub: arn:aws:apigateway:${AWS::Region}:lambda:path/2015-03-31/functions/${OnDisConnectFunction.Arn}/invocations
DefaultRoute:
Type: AWS::ApiGatewayV2::Route
Properties:
ApiId: !Ref WebSocketApi
ApiKeyRequired: false
RouteKey: $default
OperationName: DefaultRoute
AuthorizationType: NONE
Target: !Join
- "/"
- - "integrations"
- !Ref DefaultInteg
DefaultInteg:
Type: AWS::ApiGatewayV2::Integration
Properties:
ApiId: !Ref WebSocketApi
Description: Default Integration
IntegrationType: AWS_PROXY
IntegrationUri:
Fn::Sub: arn:aws:apigateway:${AWS::Region}:lambda:path/2015-03-31/functions/${OnDefaultFunction.Arn}/invocations
OnConnectFunction:
Type: AWS::Serverless::Function
Properties:
Handler: handler.connect
Policies:
- DynamoDBCrudPolicy:
TableName: !Ref ConnectionsTable
OnDisConnectFunction:
Type: AWS::Serverless::Function
Properties:
Handler: handler.disconnect
Policies:
- DynamoDBCrudPolicy:
TableName: !Ref ConnectionsTable
OnDefaultFunction:
Type: AWS::Serverless::Function
Properties:
Handler: handler.default
Policies:
- DynamoDBCrudPolicy:
TableName: !Ref ConnectionsTable
- Statement:
- Sid: ManageWebSocketConnectionsPolicy
Effect: Allow
Action:
- execute-api:ManageConnections
Resource: !Sub
- "arn:aws:execute-api:${AWS::Region}:${AWS::AccountId}:${API_ID}/Prod/POST/@connections/*"
- API_ID: !Ref WebSocketApi
OnConnectPermission:
Type: AWS::Lambda::Permission
Properties:
Action: lambda:InvokeFunction
FunctionName: !Ref OnConnectFunction
Principal: apigateway.amazonaws.com
OnDisConnectPermission:
Type: AWS::Lambda::Permission
Properties:
Action: lambda:InvokeFunction
FunctionName: !Ref OnDisConnectFunction
Principal: apigateway.amazonaws.com
OnDefaultPermission:
Type: AWS::Lambda::Permission
Properties:
Action: lambda:InvokeFunction
FunctionName: !Ref OnDefaultFunction
Principal: apigateway.amazonaws.com
Deployment:
Type: AWS::ApiGatewayV2::Deployment
DependsOn: ConnectRoute
Properties:
ApiId: !Ref WebSocketApi
Stage:
Type: AWS::ApiGatewayV2::Stage
Properties:
StageName: Prod
Description: Prod Stage
DeploymentId: !Ref Deployment
ApiId: !Ref WebSocketApi
Outputs:
WebSocketURI:
Description: "The WSS Protocol URI to connect to"
Value: !Sub
- "wss://${API_ID}.execute-api.${AWS::Region}.amazonaws.com/${STAGE}"
- API_ID: !Ref WebSocketApi
STAGE: !Ref "Stage"