{
    "AWSTemplateFormatVersion": "2010-09-09",
    "Description": "ArcGIS CloudFormation Template: Provisions a ArcGIS site with Portal for ArcGIS, ArcGIS Server, ArcGIS Data Store and ArcGIS Web Adaptor on an EC2 instance running Windows Server 2012 R2. **WARNING** You will be billed by AWS for the AWS resources if you create a stack from this template.",
    "Mappings" : {
        "RegionMap" : {
      "ap-northeast-1": {
        "en": "ami-0fe7d3357aad18c58"
      },
      "ap-northeast-2": {
        "en": "ami-023f270cb11003c7f"
      },
      "ap-southeast-1": {
        "en": "ami-029f24a0412cfc443"
      },
      "ap-southeast-2": {
        "en": "ami-0ac0301e2336cadb6"
      },
      "eu-central-1": {
        "en": "ami-0740cdc979d775378"
      },
      "eu-west-1": {
        "en": "ami-01068bfb47720d315"
      },
      "sa-east-1": {
        "en": "ami-0bd7dcae924f94e4d"
      },
      "us-east-1": {
        "en": "ami-0e7a61885501b7dc5"
      },
      "us-west-1": {
        "en": "ami-0f07501a860d02fc7"
      },
      "us-west-2": {
        "en": "ami-0f329ba888325911e"
      },
      "ap-south-1": {
        "en": "ami-02648a5230a3e4999"
      }
    }
    },
    "Parameters": {
        "AZ" : {
            "Type" : "AWS::EC2::AvailabilityZone::Name",
            "Description" : "Select availability zone for your VPC subnet"
        },
        "DeploymentBucket": {
            "Description": "S3 bucket for license files and SSL certificates",
            "Type": "String",
            "AllowedPattern": "[a-zA-Z][0-9a-zA-Z-_.]{2,62}",
            "ConstraintDescription": "S3 bucket name must be between 3 and 63 characters and and must start with a letter."
        },
        "DriveSizeRoot": {
            "Default": "100",
            "Description": " The size of the C: Drive in GB. ",
            "Type": "Number",
            "MinValue": "100",
            "MaxValue": "1024",
            "ConstraintDescription": " Must be between 100 and 1024 GB. "
        },
        "DriveSizeData": {
            "Default": "100",
            "Description": " The size of the D: Drive in GB. ",
            "Type": "Number",
            "MinValue": "10",
            "MaxValue": "1024",
            "ConstraintDescription": " Must be between 10 and 1024 GB. "
        },
        "InstanceType": {
            "Description": "The EC2 instance type",
            "Type": "String",
            "AllowedValues": [
                "m3.large", "m3.xlarge", "m3.2xlarge",
                "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge",
                "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge",
                "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge",
                "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge"
            ],
            "Default": "m3.xlarge"
        },
        "KeyName": {
            "Description": "The EC2 KeyPair to allow remote access to the instances",
            "Type": "AWS::EC2::KeyPair::KeyName"
        },
        "ServerLicenseFile": {
            "Description": "ArcGIS for Server authorization file (must be uploaded to DeploymentBucket)",
            "Type": "String",
            "AllowedPattern": "[^\"]{1,1024}",
            "ConstraintDescription": "S3 object key name must be between 1 and 1024 characters."
        },
        "PortalLicenseFile": {
            "Description": "Portal for ArcGIS authorization file (must be uploaded to DeploymentBucket)",
            "Type": "String",
            "AllowedPattern": "[^\"]{1,1024}",
            "ConstraintDescription": "S3 object key name must be between 1 and 1024 characters."
        },
        "SiteAdmin": {
            "Description": "User name for ArcGIS Server site admin and Portal initial admin accounts",
            "Type": "String",
            "Default": "admin",
            "AllowedPattern": "[0-9a-zA-Z.]{4,24}",
            "ConstraintDescription": "User name must be between 4 and 24 characters and can only contain digits 0 through 9, ASCII letters A through Z (uppercase and lowercase), and a dot (.)."
        },
        "SiteAdminPassword": {
            "Description": "Password for the site admin account",
            "Type": "String",
            "NoEcho": "true",
            "AllowedPattern": "[0-9a-zA-Z.]{4,24}",
            "ConstraintDescription": "Password must be between 4 and 24 characters and can only contain digits 0 through 9, ASCII letters A through Z (uppercase and lowercase), and a dot (.)."
        },
        "SiteEIPAllocationID": {
            "Description": "Allocation ID of Elastic IP address for VPC (eipalloc-XXXXXXXX)",
            "Type": "String",
            "AllowedPattern": "eipalloc-.*"
        },
        "SiteDomain": {
            "Description": "The domain name of your ArcGIS site",
            "Type": "String",
            "AllowedPattern": "[^\\\"\/]{1,253}",
            "ConstraintDescription": "The domain name is invalid."
        },
        "SSLCertificateFile": {
            "Description": "SSL certificate file issued to the site domain (must be uploaded to DeploymentBucket)",
            "Type": "String",
            "AllowedPattern": "[^\"]{1,1024}",
            "ConstraintDescription": "S3 object key name must be between 1 and 1024 characters."
        },
        "SSLCertPassword": {
            "Description": "SSL certificate file password",
            "Type": "String",
            "NoEcho": "true",
            "AllowedPattern": "[^\\\"]{1,128}",
            "ConstraintDescription": "Password must be between 1 and 128 characters and must not contain backslashes (\\) or quotation marks (\")."
        }
    },
    "Resources": {
        "VPC": {
            "Type": "AWS::EC2::VPC",
            "Properties": {
                "CidrBlock": "10.0.0.0/16",
                "Tags": [ {
                    "Key": "Name",
                    "Value": {"Ref": "AWS::StackName"}
                }, {
                    "Key": "Application",
                    "Value": "arcgis-allinone-windows-vpc"
                }, {
                    "Key": "Network",
                    "Value": "Public"
                } ]
            }
        },
        "Subnet1": {
            "Type": "AWS::EC2::Subnet",
            "Properties": {
                "VpcId": {"Ref": "VPC"},
                "CidrBlock": "10.0.0.0/24",
                "AvailabilityZone": {"Ref": "AZ"},
                "Tags": [ {
                    "Key": "Name",
                    "Value": {"Fn::Join" : ["", [{"Ref" : "AWS::StackName"}, "-subnet1"]]}
                },{
                    "Key": "Application",
                    "Value": "arcgis-allinone-windows-vpc"
                }, {
                    "Key": "Network",
                    "Value": "Public"
                } ]
            }
        },
        "InternetGateway": {
            "Type": "AWS::EC2::InternetGateway",
            "Properties": {
                "Tags": [ {
                    "Key": "Name",
                    "Value": {"Ref": "AWS::StackName"}
                }, {
                    "Key": "Application",
                    "Value": "arcgis-allinone-windows-vpc"
                }, {
                    "Key": "Network",
                    "Value": "Public"
               } ]
            }
        },
        "AttachGateway": {
            "Type": "AWS::EC2::VPCGatewayAttachment",
            "Properties": {
                "VpcId": {"Ref": "VPC"},
                "InternetGatewayId": {"Ref": "InternetGateway"}
            }
        },
        "RouteTable": {
            "Type": "AWS::EC2::RouteTable",
            "Properties": {
                "VpcId": {"Ref": "VPC"},
                "Tags": [ {
                    "Key": "Name",
                    "Value": {"Ref": "AWS::StackName"}
                }, {
                    "Key": "Application",
                    "Value": "arcgis-allinone-windows-vpc"
                }, {
                    "Key": "Network",
                    "Value": "Public"
                } ]
            }
        },
        "Route": {
            "Type": "AWS::EC2::Route",
            "DependsOn" : "AttachGateway",
            "Properties": {
                "RouteTableId": {"Ref": "RouteTable"},
                "DestinationCidrBlock": "0.0.0.0/0",
                "GatewayId": {"Ref": "InternetGateway"}
            }
        },
        "Subnet1RouteTableAssociation": {
            "Type": "AWS::EC2::SubnetRouteTableAssociation",
            "Properties": {
                "SubnetId": {"Ref": "Subnet1"},
                "RouteTableId": {"Ref": "RouteTable"}
            }
        },
        "EC2SecurityGroup": {
            "Type": "AWS::EC2::SecurityGroup",
            "Properties": {
                "GroupDescription": {"Ref": "AWS::StackName"},
                "VpcId": {"Ref": "VPC"},
                "SecurityGroupIngress": [ {
                    "IpProtocol": "tcp",
                    "FromPort": "80",
                    "ToPort": "80",
                    "CidrIp": "0.0.0.0/0"
                },
                {
                    "IpProtocol": "tcp",
                    "FromPort": "443",
                    "ToPort": "443",
                    "CidrIp": "0.0.0.0/0"
                } ]
            }
        },
        "SecurityGroupIngress" : {
            "Type" : "AWS::EC2::SecurityGroupIngress",
            "Properties" : {
                "GroupId" : {"Ref" : "EC2SecurityGroup"},
                "IpProtocol" : "tcp",
                "FromPort" : "0",
                "ToPort" : "65535",
                "SourceSecurityGroupId" : {"Ref" : "EC2SecurityGroup"}
            }
        },
        "EIPAssociation": {
            "Type": "AWS::EC2::EIPAssociation",
            "DependsOn": "WaitCondition",
            "Properties": {
                "AllocationId": {"Ref": "SiteEIPAllocationID"},
                "InstanceId": {"Ref": "AllInOneEC2Instance"}
            }
        },
        "IAMRole": {
            "Type": "AWS::IAM::Role",
            "Properties": {
                "AssumeRolePolicyDocument": {
                    "Statement": [ {
                        "Effect": "Allow",
                        "Principal": {
                            "Service": [ "ec2.amazonaws.com" ]
                        },
                        "Action": [ "sts:AssumeRole" ]
                    } ]
                },
                "Path": "/"
            }
        },
        "IAMPolicy": {
            "Type": "AWS::IAM::Policy",
            "Properties": {
                "PolicyName": "IAMRole",
                "PolicyDocument": {
                    "Statement": [ {
                        "Action": [ "s3:GetObject", "logs:*" ],
                            "Effect": "Allow",
                            "Resource": [ "arn:aws:s3:::*", "arn:aws:logs:*:*:*" ]
                        }
                    ]
                },
                "Roles": [ {"Ref": "IAMRole"} ]
            }
        },
        "IAMInstanceProfile": {
            "Type": "AWS::IAM::InstanceProfile",
            "Properties": {
                "Path": "/",
                "Roles": [ {"Ref": "IAMRole"} ]
            }
        },
        "AllInOneEC2Instance": {
            "Type": "AWS::EC2::Instance",
            "Properties": {
                "ImageId": {"Fn::FindInMap" : ["RegionMap", {"Ref":"AWS::Region"}, "en"]},
                "InstanceType": {"Ref": "InstanceType"},
                "KeyName": {"Ref": "KeyName"},
                "IamInstanceProfile": {"Ref": "IAMInstanceProfile"},
                "Tags": [ {
                    "Key": "Name",
                    "Value": {"Ref": "AWS::StackName"}
                }, {
                    "Key": "Application",
                    "Value": "arcgis-allinone-windows-vpc"
                }],
                "Monitoring": true,
                "BlockDeviceMappings": [ {
                    "DeviceName": "/dev/sda1",
                    "Ebs": {
                        "VolumeSize": {"Ref": "DriveSizeRoot"},
                        "DeleteOnTermination": true,
                        "VolumeType": "gp2"
                    }
                }, {
                   "DeviceName": "xvdg",
                   "Ebs": {
                        "VolumeSize": {"Ref": "DriveSizeData"},
                        "DeleteOnTermination": true,
                        "VolumeType": "gp2"
                   }
                },{
                    "DeviceName": "xvdca",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcb",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcc",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcd",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdce",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcf",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcg",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdch",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdci",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcj",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdck",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcl",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcm",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcn",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdco",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcp",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcq",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcr",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcs",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdct",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcu",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcv",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcw",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcx",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcy",
                    "NoDevice": {}
                },{
                    "DeviceName": "xvdcz",
                    "NoDevice": {}
                } ],
                "NetworkInterfaces": [ {
                    "PrivateIpAddress": "10.0.0.5",
                    "GroupSet": [ {"Ref": "EC2SecurityGroup"} ],
                    "AssociatePublicIpAddress": "true",
                    "DeviceIndex": "0",
                    "DeleteOnTermination": "true",
                    "SubnetId": {"Ref": "Subnet1"}
                } ],
                "UserData": {
                    "Fn::Base64": {
                        "Fn::Join": [
                            "",
                            [
                                "<powershell>\r\n",
                                "try \r\n",
                                "{  \r\n",
                                "  $stackName   = '", {"Ref": "AWS::StackName"}, "' \r\n",
                                "  $region      = '", {"Ref": "AWS::Region"}, "' \r\n",
                                "  $waitHandle  = '", {"Ref": "WaitHandle"}, "' \r\n",
                                "  $setupScript = 'C:\\chef\\scripts\\esriVMSetup.ps1' \r\n",
                                "  $InstanceName = 'AllInOneEC2Instance' \r\n",
                                "  $NodeJSONPath = 'C:\\\\chef\\\\node.json' \r\n",
                                "  $ChefLogFile  = 'C:\\\\chef\\\\chef-run.log' \r\n",
                                "  $execName = \"cfn-init\" \r\n",
                                "  $execArgs = \"-v -s $stackName -r CloudWatchSettings --region $region\" \r\n",
                                "  Write-Output \"Executing : $execName\" \r\n",
                                "  Write-Output \"Arguments : $execArgs\"  \r\n",
                                "  $process = Start-Process $execName -PassThru -Wait -ArgumentList $execArgs.Split(' ') \r\n",
                                "  if ($process.ExitCode -ne 0) { \r\n",
                                "    throw \"Process 'cfn-init' exit code : $($process.ExitCode)\"   \r\n",
                                "  } \r\n",
                                " \r\n",
                                "  . \"$setupScript\" -n 'EC2UserScriptTask' -s $stackName -r $region -w $waitHandle -i $InstanceName -j $NodeJSONPath -l $ChefLogFile \r\n",
                                "   \r\n",
                                "  Write-Output \"UserScript : completed\"  \r\n",
                                "}   \r\n",
                                "catch  \r\n",
                                "{  \r\n",
                                "  Write-Output \"ERROR: $($_.Exception.Message)\"  \r\n",
                                "  cfn-signal -e 1  -r \"$($_.Exception.Message)\" \"$WaitHandle\"  \r\n",
                                "}  \r\n",
                                "</powershell>\r\n"
                            ]
                        ]
                    }
                }
            },
            "Metadata": {
                "AWS::CloudFormation::Authentication": {
                    "S3AccessCreds": {
                        "type": "S3",
                        "buckets": [ {"Ref": "DeploymentBucket"} ],
                        "roleName": {"Ref": "IAMRole"}
                    }
                },
                "AWS::CloudFormation::Init": {
                    "config": {
                        "commands": {
                            "rename-server-license": {
                                "command": {"Fn::Join": [ "", [ "move C:\\Temp\\server_license.tmp C:\\Temp\\", {"Ref": "ServerLicenseFile"} ] ]}
                            },
                            "rename-portal-license": {
                                "command": {"Fn::Join": [ "", [ "move C:\\Temp\\portal_license.tmp C:\\Temp\\", {"Ref": "PortalLicenseFile"} ] ]}
                            }
                        },
                        "files": {
                            "C:\\Temp\\server_license.tmp": {
                                "source": {"Fn::Join": [ "", [ "https://", {"Ref": "DeploymentBucket"}, ".s3.amazonaws.com/", {"Ref": "ServerLicenseFile"} ] ]},
                                "authentication": "S3AccessCreds"
                            },
                            "C:\\Temp\\portal_license.tmp": {
                                "source": {"Fn::Join": [ "", [ "https://", {"Ref": "DeploymentBucket"}, ".s3.amazonaws.com/", {"Ref": "PortalLicenseFile"} ] ]},
                                "authentication": "S3AccessCreds"
                            },
                            "C:\\Temp\\keystore.pfx": {
                                "source": {"Fn::Join": [ "", [ "https://", {"Ref": "DeploymentBucket"}, ".s3.amazonaws.com/", {"Ref": "SSLCertificateFile"} ] ]},
                                "authentication": "S3AccessCreds"
                            },
                            "C:\\chef\\node.json": {
                                "content": {
                                    "Fn::Join": [
                                        "",
                                        [
                                            "{\r\n",
                                            "  \"arcgis\" : {\r\n",
                                            "    \"version\" : \"10.4.1\",\r\n",
                                            "    \"hosts\" : {\r\n",
                                            "      \"", {"Ref": "SiteDomain"}, "\" : \"10.0.0.5\"\r\n",
                                            "    },\r\n",
                                            "    \"iis\" : {\r\n",
                                            "      \"keystore_file\" : \"C:\\\\Temp\\\\keystore.pfx\",\r\n",
                                            "      \"keystore_password\" : \"", {"Ref": "SSLCertPassword"}, "\"\r\n",
                                            "    },\r\n",
                                            "    \"server\" : {\r\n",
                                            "      \"domain_name\" : \"", {"Ref": "SiteDomain"}, "\",\r\n",
                                            "      \"admin_username\" : \"", {"Ref": "SiteAdmin"}, "\",\r\n",
                                            "      \"admin_password\" : \"", {"Ref": "SiteAdminPassword"}, "\",\r\n",
                                            "      \"directories_root\" : \"D:\\\\arcgisserver\",\r\n",
                                            "      \"authorization_file\" : \"C:\\\\Temp\\\\", {"Ref": "ServerLicenseFile"}, "\"\r\n",
                                            "    },\r\n",
                                            "    \"web_adaptor\" : {\r\n",
                                            "      \"admin_access\" : true\r\n",
                                            "    },\r\n",
                                            "    \"data_store\" : {\r\n",
                                            "      \"data_dir\" : \"D:\\\\arcgisdatastore\"\r\n",
                                            "    },\r\n",
                                            "    \"portal\" : {\r\n",
                                            "      \"domain_name\" : \"", {"Ref": "SiteDomain"}, "\",\r\n",
                                            "      \"private_url\" : \"https://", {"Ref": "SiteDomain"}, "/portal\",\r\n",
                                            "      \"web_context_url\" : \"https://", {"Ref": "SiteDomain"}, "/portal\",\r\n",
                                            "      \"admin_username\" : \"", {"Ref": "SiteAdmin"}, "\",\r\n",
                                            "      \"admin_password\" : \"", {"Ref": "SiteAdminPassword"}, "\",\r\n",
                                            "      \"data_dir\" : \"D:\\\\arcgisportal\",\r\n",
                                            "      \"authorization_file\" : \"C:\\\\Temp\\\\", {"Ref": "PortalLicenseFile"}, "\"\r\n",
                                            "    }\r\n",
                                            "  },\r\n",
                                            "  \"run_list\" : [\r\n",
                                            "    \"recipe[arcgis::system]\",\r\n",
                                            "    \"recipe[arcgis::iis]\",\r\n",
                                            "    \"recipe[arcgis::server]\",\r\n",
                                            "    \"recipe[arcgis::server_wa]\",\r\n",
                                            "    \"recipe[arcgis::datastore]\",\r\n",
                                            "    \"recipe[arcgis::portal]\",\r\n",
                                            "    \"recipe[arcgis::portal_wa]\",\r\n",
                                            "    \"recipe[arcgis::federation]\"]\r\n",
                                            "}\r\n"
                                        ]
                                    ]
                                }
                            }
                        }
                    }
                }
            }
        },
        "EC2InstanceRecoveryAlarm" : {
            "Type" : "AWS::CloudWatch::Alarm",
            "Properties" : {
                "AlarmDescription" : "Trigger a recovery when instance status check fails for 5 consecutive minutes.",
                "MetricName" : "StatusCheckFailed_System",
                "Namespace" : "AWS/EC2",
                "Statistic" : "Minimum",
                "Period" : "60",
                "EvaluationPeriods" : "5",
                "Threshold" : "0",
                "ComparisonOperator" : "GreaterThanThreshold",
                "AlarmActions" : [ {"Fn::Join" : ["", ["arn:aws:automate:", { "Ref" : "AWS::Region" }, ":ec2:recover" ]]} ],
                "Dimensions" : [ {
                    "Name" : "InstanceId",
                    "Value" : {"Ref" : "AllInOneEC2Instance"}
                } ]
            }
        },
        "WaitHandle": {
            "Type": "AWS::CloudFormation::WaitConditionHandle",
            "Properties": {}
        },
        "WaitCondition": {
            "Type": "AWS::CloudFormation::WaitCondition",
            "Properties": {
                "Handle": {"Ref": "WaitHandle"},
                "Timeout": "7200"
            }
        },
        "DeploymentLogs": {
            "Type": "AWS::Logs::LogGroup",
            "DeletionPolicy": "Retain",
            "Properties": {
                "RetentionInDays": 7
            }
        },
        "CloudWatchSettings": {
            "Type": "AWS::Logs::MetricFilter",
            "DeletionPolicy": "Retain",
            "Properties": {
                "LogGroupName": {"Ref": "DeploymentLogs"},
                "FilterPattern": "[level=FATAL, message]",
                "MetricTransformations": [
                    {
                        "MetricValue": "1",
                        "MetricNamespace": "ArcGIS/Deployment",
                        "MetricName": "ErrorCount"
                    }
                ]
            },
            "Metadata": {
                "AWS::CloudFormation::Init": {
                    "config": {
                        "sources": {
                            "C:\\chef": "https://arcgisstore1041.s3.amazonaws.com/5686/cookbooks/arcgis-2.2.1-cookbooks.zip"
                        },
                        "files": {
                            "C:\\Program Files\\Amazon\\Ec2ConfigService\\Settings\\AWS.EC2.Windows.CloudWatch.json": {
                                "content": {
                                    "Fn::Join": [
                                        "",
                                        [
                                            "{\r\n",
                                            "  \"EngineConfiguration\": {\r\n",
                                            "    \"PollInterval\": \"00:00:15\",\r\n",
                                            "    \"Components\": [\r\n",
                                            "    {\r\n",
                                            "      \"Id\": \"CfnInitLogStream\",\r\n",
                                            "      \"FullName\": \"AWS.EC2.Windows.CloudWatch.CloudWatchLogsOutput,AWS.EC2.Windows.CloudWatch\",\r\n",
                                            "      \"Parameters\": {\r\n",
                                            "        \"Region\": \"", {"Ref": "AWS::Region"}, "\",\r\n",
                                            "        \"LogGroup\": \"", {"Ref": "DeploymentLogs"}, "\",\r\n",
                                            "        \"LogStream\": \"{instance_id}/cfn-init.log\"\r\n",
                                            "      }\r\n",
                                            "    },\r\n",
                                            "    {\r\n",
                                            "      \"Id\": \"ChefRunLogStream\",\r\n",
                                            "      \"FullName\": \"AWS.EC2.Windows.CloudWatch.CloudWatchLogsOutput,AWS.EC2.Windows.CloudWatch\",\r\n",
                                            "      \"Parameters\": {\r\n",
                                            "        \"Region\": \"", {"Ref": "AWS::Region"}, "\",\r\n",
                                            "        \"LogGroup\": \"", {"Ref": "DeploymentLogs"}, "\",\r\n",
                                            "        \"LogStream\": \"{instance_id}/chef-run.log\"\r\n",
                                            "      }\r\n",
                                            "    },\r\n",
                                            "    {\r\n",
                                            "      \"Id\": \"CfnInitLogs\",\r\n",
                                            "      \"FullName\": \"AWS.EC2.Windows.CloudWatch.CustomLog.CustomLogInputComponent,AWS.EC2.Windows.CloudWatch\",\r\n",
                                            "      \"Parameters\": {\r\n",
                                            "        \"LogDirectoryPath\": \"C:\\\\cfn\\\\log\",\r\n",
                                            "        \"TimestampFormat\": \"yyyy-MM-dd HH:mm:ss,fff\",\r\n",
                                            "        \"Encoding\": \"UTF-8\",\r\n",
                                            "        \"Filter\": \"cfn-init.log\",\r\n",
                                            "        \"CultureName\": \"en-US\",\r\n",
                                            "        \"TimeZoneKind\": \"Local\",\r\n",
                                            "        \"LineCount\": \"1\"\r\n",
                                            "      }\r\n",
                                            "    },\r\n",
                                            "    {\r\n",
                                            "      \"Id\": \"ChefRunLogs\",\r\n",
                                            "      \"FullName\": \"AWS.EC2.Windows.CloudWatch.CustomLog.CustomLogInputComponent,AWS.EC2.Windows.CloudWatch\",\r\n",
                                            "      \"Parameters\": {\r\n",
                                            "        \"LogDirectoryPath\": \"C:\\\\chef\",\r\n",
                                            "        \"TimestampFormat\": \"[yyyy-MM-ddTHH:mm:sszzz]\",\r\n",
                                            "        \"Encoding\": \"UTF-8\",\r\n",
                                            "        \"Filter\": \"chef-run.log\",\r\n",
                                            "        \"CultureName\": \"en-US\",\r\n",
                                            "        \"TimeZoneKind\": \"Local\",\r\n",
                                            "        \"LineCount\": \"1\"\r\n",
                                            "      }\r\n",
                                            "    }],\r\n",
                                            "    \"Flows\": {\r\n",
                                            "      \"Flows\":[\"CfnInitLogs,CfnInitLogStream\",\"ChefRunLogs,ChefRunLogStream\"]\r\n",
                                            "    }\r\n",
                                            "  }\r\n",
                                            "}\r\n"
                                        ]
                                    ]
                                }
                            }
                        }
                    }
                }
            }
        }
    },
    "Outputs": {
        "AdminURL": {
            "Value": {"Fn::Join": [ "", [ "https://", {"Ref": "SiteDomain"}, "/server/manager" ] ]},
            "Description": "ArcGIS Server Administrator Directory URL"
        },
        "RestURL": {
            "Value": {"Fn::Join": [ "", [ "https://", {"Ref": "SiteDomain"}, "/server/rest" ] ]},
            "Description": "ArcGIS REST Services Directory URL"
        },
        "PortalURL": {
            "Value": {"Fn::Join": [ "", [ "https://", {"Ref": "SiteDomain"}, "/portal/home" ] ]},
            "Description": "Portal for ArcGIS Home URL"
        },
        "LogsURL": {
            "Value": {"Fn::Join": ["", [ "https://console.aws.amazon.com/cloudwatch/home?region=", {"Ref": "AWS::Region"}, "#logStream:group=", {"Ref": "DeploymentLogs"} ] ]},
            "Description": "Deployment Logs"
        },
        "VPCId" : {
            "Description" : "VPC ID",
            "Value" :  {"Ref" : "VPC"}
        },
        "SecurityGroup" : {
            "Description" : "Security group ID",
            "Value" :  {"Fn::GetAtt" : ["EC2SecurityGroup", "GroupId"]}
        },
        "RouteTable" : {
            "Description" : "Route table",
            "Value" :  {"Ref" : "RouteTable"}
        }
    }
}
