Forked from tony-gutierrez/AWS_Single_LetsEncrypt.yaml
          
        
    
          Created
          June 29, 2017 21:38 
        
      - 
      
- 
        Save billsinc/c06e767135423d80dbd65cf0136effb3 to your computer and use it in GitHub Desktop. 
    AWS Elastic Beanstalk .ebextensions config for single instance free SSL using letsencrypt certbot and nginx. http://bluefletch.com/blog/domain-agnostic-letsencrypt-ssl-config-for-elastic-beanstalk-single-instances/
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | # Dont forget to set the env variable "certdomain", and either fill in your email below or use an env variable for that too. | |
| # Also note that this config is using the LetsEncrypt staging server, remove the flag when ready! | |
| Resources: | |
| sslSecurityGroupIngress: | |
| Type: AWS::EC2::SecurityGroupIngress | |
| Properties: | |
| GroupId: {"Fn::GetAtt" : ["AWSEBSecurityGroup", "GroupId"]} | |
| IpProtocol: tcp | |
| ToPort: 443 | |
| FromPort: 443 | |
| CidrIp: 0.0.0.0/0 | |
| files: | |
| # The Nginx config forces https, and is meant as an example only. | |
| /etc/nginx/conf.d/000_http_redirect_custom.conf: | |
| mode: "000644" | |
| owner: root | |
| group: root | |
| content: | | |
| server { | |
| listen 8080; | |
| return 301 https://$host$request_uri; | |
| } | |
| # The Nginx config forces https, and is meant as an example only. | |
| /etc/nginx/conf.d/https_custom.pre: | |
| mode: "000644" | |
| owner: root | |
| group: root | |
| content: | | |
| # HTTPS server | |
| server { | |
| listen 443 default ssl; | |
| server_name localhost; | |
| error_page 497 https://$host$request_uri; | |
| ssl_certificate /etc/letsencrypt/live/ebcert/fullchain.pem; | |
| ssl_certificate_key /etc/letsencrypt/live/ebcert/privkey.pem; | |
| ssl_session_timeout 5m; | |
| ssl_protocols TLSv1.1 TLSv1.2; | |
| ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH"; | |
| ssl_prefer_server_ciphers on; | |
| if ($ssl_protocol = "") { | |
| rewrite ^ https://$host$request_uri? permanent; | |
| } | |
| location ~ ^/(lib/|img/) { | |
| root /var/app/current/public; | |
| access_log off; | |
| } | |
| location / { | |
| proxy_pass http://nodejs; | |
| proxy_set_header Connection ""; | |
| proxy_http_version 1.1; | |
| proxy_set_header Host $host; | |
| proxy_set_header X-Real-IP $remote_addr; | |
| proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |
| proxy_set_header Upgrade $http_upgrade; | |
| proxy_set_header Connection "upgrade"; | |
| } | |
| } | |
| packages: | |
| yum: | |
| epel-release: [] | |
| container_commands: | |
| 10_installcertbot: | |
| command: "wget https://dl.eff.org/certbot-auto;chmod a+x certbot-auto" | |
| 20_getcert: | |
| command: "sudo ./certbot-auto certonly --debug --non-interactive --email [email protected] --agree-tos --standalone --domains ${certdomain} --keep-until-expiring --pre-hook \"service nginx stop\" --staging" | |
| 30_link: | |
| command: "ln -sf /etc/letsencrypt/live/${certdomain} /etc/letsencrypt/live/ebcert" | |
| 40_config: | |
| command: "mv /etc/nginx/conf.d/https_custom.pre /etc/nginx/conf.d/https_custom.conf" | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment