-
Notifications
You must be signed in to change notification settings - Fork 1
/
ssm-automation-pwsh.yml
94 lines (87 loc) · 3.34 KB
/
ssm-automation-pwsh.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
# Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
# SPDX-License-Identifier: MIT-0
#
# Permission is hereby granted, free of charge, to any person obtaining a copy of this
# software and associated documentation files (the "Software"), to deal in the Software
# without restriction, including without limitation the rights to use, copy, modify,
# merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
# INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
# PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
AWSTemplateFormatVersion: 2010-09-09
Description: Solution that uses SSM Automation to add a tag to an EC2 instance.
Parameters: {}
Resources:
SSMAutomationRole:
Type: AWS::IAM::Role
Properties:
RoleName: "SSM-Automation-Template-Role"
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
- Action:
- sts:AssumeRole
Effect: Allow
Principal:
Service:
- ssm.amazonaws.com
Path: "/"
Policies:
- PolicyName: "SSM-Automation-Template-Policy"
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Action:
- "ec2:*"
Resource: "*"
rPwshSsmAutomation:
Type: AWS::SSM::Document
Properties:
DocumentType: Automation
Name: !Sub "Template-${AWS::Region}"
Content:
description: Template for Running aws execute script that use PowerShell
schemaVersion: '0.3'
assumeRole: !GetAtt SSMAutomationRole.Arn
parameters:
InstanceId:
description: "ID of the Instance."
type: "String"
TagKey:
description: "Enter the Tag Key"
type: "String"
TagValue:
description: "Enter the Tag Value"
type: "String"
AutomationAssumeRole:
default: ""
description: "(Optional) The ARN of the role that allows Automation to perform the actions on your behalf."
type: "String"
mainSteps:
- name: ExecuteCode
action: 'aws:executeScript'
inputs:
Runtime: PowerShell Core 6.0
InputPayload:
instanceId: "{{InstanceId}}"
tagKey: "{{TagKey}}"
tagValue: "{{TagValue}}"
Script: |-
Install-Module AWS.Tools.EC2 -Force
Import-Module AWS.Tools.EC2
$payload = $env:InputPayload | ConvertFrom-Json
$tag = New-Object Amazon.EC2.Model.Tag
$tag.Key = $payload.tagKey
$tag.Value = $payload.tagValue
New-EC2Tag -Resource $payload.instanceId -Tag $tag
Outputs:
AutomationDocument:
Value: !Ref rPwshSsmAutomation
SSMAutomationRole:
Value: !Ref SSMAutomationRole