update template
This commit is contained in:
parent
6d755483b2
commit
d25dd5a914
2 changed files with 79 additions and 53 deletions
|
@ -16,13 +16,13 @@ You can also use `t2.micro` instance as your server for your deployment, which i
|
|||
|
||||
> When choosing your username and password, do not enter special characters like `" ' \`.
|
||||
|
||||
Make sure to do this with an **AWS ROOT ACCOUNT** or an **IAM ACCOUNT** with **ADMINISTRATION PRVILEGE**. AWS Cloudformation requires the template file to be store on AWS S3, while a [copy](./MonAug17-production1.0) is available on Github. If you want to make any contributions to this template, make sure to contact me so that I can update the template on S3.
|
||||
Make sure to do this with an **AWS ROOT ACCOUNT** or an **IAM ACCOUNT** with **ADMINISTRATION PRVILEGE**. AWS Cloudformation requires the template file to be store on AWS S3, while a [copy](./cloudformation-template-ipsec) is available on Github. If you want to make any contributions to this template, make sure to contact me so that I can update the template on S3.
|
||||
|
||||
If you are confused about the instance types available, go to the [FAQ](#faqs) section and check out **"Instance Type Selection"**.
|
||||
|
||||
Click the icon below to initiate the launching sequence.
|
||||
|
||||
<a href="https://console.aws.amazon.com/cloudformation/home#/stacks/new?templateURL=https://vpn-tutorial-template.s3.ca-central-1.amazonaws.com/MonAug17-production1.0"><img src="../docs/images/cloudformation-launch-stack-button.png" alt="Deploy to AWS" height="60px"></a>
|
||||
<a href="https://console.aws.amazon.com/cloudformation/home#/stacks/new?templateURL=https://vpn-tutorial-template.s3.ca-central-1.amazonaws.com/cloudformation-template-ipsec"><img src="../docs/images/cloudformation-launch-stack-button.png" alt="Deploy to AWS" height="60px"></a>
|
||||
|
||||
Make sure that the deployment is successful before going to the [Next Step : Configure VPN Clients](../docs/clients.md).
|
||||
|
||||
|
|
|
@ -30,7 +30,6 @@
|
|||
"embeds": [
|
||||
"9d4cbbc2-f521-436d-bb4a-85b82cf22a2a",
|
||||
"464ea4ae-199c-4917-9404-aed674a8615a",
|
||||
"a396f033-d33f-435a-a3e5-6da5107d5571",
|
||||
"ec256f27-66c3-423c-9d98-b9f0f634e7b8",
|
||||
"4731d93c-f3fc-420a-b535-f0b99840f356",
|
||||
"40c2d4e7-f01a-45b2-8878-a06680aa2216"
|
||||
|
@ -111,6 +110,14 @@
|
|||
"parent": "5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"embeds": [],
|
||||
"iscontainedinside": [
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"5198eb6d-da4f-43e2-8a4b-b9bff02b26a2"
|
||||
],
|
||||
"dependson": [
|
||||
|
@ -118,7 +125,6 @@
|
|||
"9d4cbbc2-f521-436d-bb4a-85b82cf22a2a",
|
||||
"99fce86e-18b8-4b1b-a572-7bef3c5cece7",
|
||||
"58a1ab6f-49ac-4ffa-93c7-3f708bf65871",
|
||||
"a396f033-d33f-435a-a3e5-6da5107d5571",
|
||||
"ec256f27-66c3-423c-9d98-b9f0f634e7b8"
|
||||
]
|
||||
},
|
||||
|
@ -151,22 +157,6 @@
|
|||
"0a162613-8f2e-4864-be99-75d946934a4a"
|
||||
]
|
||||
},
|
||||
"a396f033-d33f-435a-a3e5-6da5107d5571": {
|
||||
"size": {
|
||||
"width": 60,
|
||||
"height": 60
|
||||
},
|
||||
"position": {
|
||||
"x": 510,
|
||||
"y": 140
|
||||
},
|
||||
"z": 3,
|
||||
"parent": "5198eb6d-da4f-43e2-8a4b-b9bff02b26a2",
|
||||
"embeds": [],
|
||||
"dependson": [
|
||||
"0a162613-8f2e-4864-be99-75d946934a4a"
|
||||
]
|
||||
},
|
||||
"5bb16646-dc1e-4661-9164-6ecc6848dc83": {
|
||||
"source": {
|
||||
"id": "4731d93c-f3fc-420a-b535-f0b99840f356"
|
||||
|
@ -331,6 +321,54 @@
|
|||
"VpnInstance": {
|
||||
"Type": "AWS::EC2::Instance",
|
||||
"Properties": {
|
||||
"UserData": {
|
||||
"Fn::Base64": {
|
||||
"Fn::Join": [
|
||||
"",
|
||||
[
|
||||
"#!/bin/bash -x\n",
|
||||
"export VPN_IPSEC_PSK='",
|
||||
{
|
||||
"Ref": "VpnIpsecPsk"
|
||||
},
|
||||
"'\n",
|
||||
"export VPN_USER='",
|
||||
{
|
||||
"Ref": "VpnUser"
|
||||
},
|
||||
"'\n",
|
||||
"export VPN_PASSWORD='",
|
||||
{
|
||||
"Ref": "VpnPassword"
|
||||
},
|
||||
"'\n",
|
||||
"wait 60\n",
|
||||
"wget https://git.io/vpnsetup -O vpnsetup.sh && sh vpnsetup.sh &&\n",
|
||||
"/usr/local/bin/cfn-signal",
|
||||
" --stack ",
|
||||
{
|
||||
"Ref": "AWS::StackName"
|
||||
},
|
||||
" --resource VpnInstance",
|
||||
" --region ",
|
||||
{
|
||||
"Ref": "AWS::Region"
|
||||
},
|
||||
" ||\n",
|
||||
"/usr/local/bin/cfn-signal -s false",
|
||||
" --stack ",
|
||||
{
|
||||
"Ref": "AWS::StackName"
|
||||
},
|
||||
" --resource VpnInstance ",
|
||||
" --region ",
|
||||
{
|
||||
"Ref": "AWS::Region"
|
||||
}
|
||||
]
|
||||
]
|
||||
}
|
||||
},
|
||||
"SecurityGroupIds": [
|
||||
{
|
||||
"Fn::GetAtt": [
|
||||
|
@ -345,10 +383,6 @@
|
|||
"AvailabilityZone": {
|
||||
"Fn::Sub": "${AWS::Region}a"
|
||||
},
|
||||
"LaunchTemplate": {
|
||||
"LaunchTemplateName": "InstanceLaunchTemplate",
|
||||
"Version": "1"
|
||||
},
|
||||
"InstanceType": {
|
||||
"Ref": "InstanceType"
|
||||
},
|
||||
|
@ -375,9 +409,13 @@
|
|||
"VpnServerVolume",
|
||||
"KeyPairCreation",
|
||||
"AMIInfoFunction",
|
||||
"InstanceLaunchTemplate",
|
||||
"VpnSecurityGroup"
|
||||
]
|
||||
],
|
||||
"CreationPolicy": {
|
||||
"ResourceSignal": {
|
||||
"Timeout": "PT5M"
|
||||
}
|
||||
}
|
||||
},
|
||||
"VpnSecurityGroup": {
|
||||
"Type": "AWS::EC2::SecurityGroup",
|
||||
|
@ -434,27 +472,6 @@
|
|||
}
|
||||
}
|
||||
},
|
||||
"InstanceLaunchTemplate": {
|
||||
"Type": "AWS::EC2::LaunchTemplate",
|
||||
"Properties": {
|
||||
"LaunchTemplateName": "InstanceLaunchTemplate",
|
||||
"LaunchTemplateData": {
|
||||
"UserData": {
|
||||
"Fn::Base64": {
|
||||
"Fn::Sub": "#!/bin/sh\nexport VPN_IPSEC_PSK='${VpnIpsecPsk}'\nexport VPN_USER='${VpnUser}'\nexport VPN_PASSWORD='${VpnPassword}'\nsleep 60\nwget https://git.io/vpnsetup -O vpnsetup.sh && sh vpnsetup.sh"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"Metadata": {
|
||||
"AWS::CloudFormation::Designer": {
|
||||
"id": "a396f033-d33f-435a-a3e5-6da5107d5571"
|
||||
}
|
||||
},
|
||||
"DependsOn": [
|
||||
"VpnVpc"
|
||||
]
|
||||
},
|
||||
"VpcInternetGateway": {
|
||||
"Type": "AWS::EC2::InternetGateway",
|
||||
"Properties": {},
|
||||
|
@ -760,12 +777,12 @@
|
|||
}
|
||||
},
|
||||
"Outputs": {
|
||||
"EC2PrivateKeyMaterial": {
|
||||
"Description": "The content of your private key for accessing the VPN server via SSH. Save it as a file and use it when you connect to your server via SSH.",
|
||||
"VPNAddress": {
|
||||
"Description": "This is the Public IP of your newly-launched VPN server",
|
||||
"Value": {
|
||||
"Fn::GetAtt": [
|
||||
"KeyPairInfo",
|
||||
"KeyMaterial"
|
||||
"VpnInstance",
|
||||
"PublicIp"
|
||||
]
|
||||
}
|
||||
},
|
||||
|
@ -787,9 +804,18 @@
|
|||
"Ref": "VpnIpsecPsk"
|
||||
}
|
||||
},
|
||||
"EC2PrivateKeyMaterial": {
|
||||
"Description": "The content of your private key for accessing the VPN server via SSH. Save it as a file and use it when you connect to your server via SSH.",
|
||||
"Value": {
|
||||
"Fn::GetAtt": [
|
||||
"KeyPairInfo",
|
||||
"KeyMaterial"
|
||||
]
|
||||
}
|
||||
},
|
||||
"NextStep": {
|
||||
"Description": "Go to this page for what to do after the stack is successfully created.",
|
||||
"Value": "https://github.com/scottpedia"
|
||||
"Description": "Go to this page for how to configure to VPN clients.",
|
||||
"Value": "https://git.io/vpnclients"
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue