-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplate.yaml
45 lines (45 loc) · 1.55 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
Transform: 'AWS::Serverless-2016-10-31'
Parameters:
AWSLightsail:
Description: "A microservice for AWS Lightsail."
Type: "String"
OriginUrl:
Description: "The origin url to allow CORS requests from. This will be the base URL of your static SAM website."
Type: "String"
Resources:
LightsailLambdaTrustRole:
Description: Creating service role in IAM for AWS Lambda
Type: AWS::IAM::Role
Properties:
RoleName: lightsailLambdaRole
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [lambda.amazonaws.com]
Action: sts:AssumeRole
Path: /
Policies:
- PolicyName: lightsailLambdaRolePolicy
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Action: ["lightsail:StartInstance", "lightsail:StopInstance", "lightsail:GetInstanceState"]
Resource: ["*"]
LightsailMicroservice:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Role: !GetAtt LightsailLambdaTrustRole.Arn
Runtime: nodejs8.10
CodeUri: ./
Environment:
Variables:
ORIGIN_URL: !Ref OriginUrl
Events:
GetResource:
Type: Api
Properties:
Path: /lightsail
Method: get