Skip to content

Latest commit

 

History

History
132 lines (89 loc) · 6.27 KB

README.md

File metadata and controls

132 lines (89 loc) · 6.27 KB

AWS Foundry VTT CloudFormation Deployment with TLS Encryption

This is a fork of the Foundry CF deploy script by Lupert and Cat.

New Things

  • Supports Foundry 11
  • Amazon Linux 2023 on EC2
  • Node 20.x
  • Newer more cost efficient / performant instance type support, including ARM64
  • Experimental IPv6 support

Note this is just something being done in my spare time and for fun/interest. Please keep that in mind.

Installation

You'll need some technical expertise and basic familiarity with AWS to get this running. It's not quite click-ops, but it's close. Some parts do require some click-ops once.

You can also refer to the original repo's wiki, but the gist is:

Requirements

  • AWS CLI
  • direnv+
  • Python > 3.12
  • Docker (if running sam local)
  • GNUMake

Foundry VTT Download

Download the NodeJS installer for Foundry VTT from the Foundry VTT website. Then either:

  • Upload it to a manually created S3 bucket (see AWS Pre-setup below)
  • Upload it to Google Drive, make the link publicly shared (anyone with the link can view) (I had issues with this working)
  • Have a Foundry VTT Patreon download link handy, or
  • Upload it somewhere else it can be fetched publicly

It's not recommended to use the time-limited links that you can get from the Foundry VTT site, but if that works for you, it's also an option.

Note: Foundry 11.313 at a minimum is recommended due to Electron fixing a second major security flaw in the WebP decoder.

AWS Pre-setup

This only needs to be done once, no matter how many times you redeploy.

  • Register a domain and have the route53 hostedzone created in the AWS Console

  • Create an SSH key in EC2, under EC2 / Network & Security / Key Pairs

    • You only need to do this once, the first time. If you tear down and redeploy the stack you can reuse the same SSH key
    • That said, consider rotating keys regularly as a good security practise
    • Keep the downloaded private keypair (PEM or PPK) file safe, you'll need it for SSH / SCP access to the EC2 server instance
  • Create an IAM User with access key (terrible I know) for CLI access

    • consider rotating keys regularly as a good security practise
  • Create a staging bucket for your foundry artifact

AWS Setup

Note: This repo currently relies on your default VPC, which should be set up automatically when you first create your acccount. If you have a custom VPC, it's not (yet) supported.

  • Copy .envrc.example to .envrc

    • amend as required with your variables, credentials, staging bucket etc
  • execute make deploy-server to deploy the foundry server

    • It should be pretty automated from there. Again, just be careful of the LetsEncrypt TLS issuance limits.
    • If need be, set the LetsEncrypt TLS testing option to False in the CloudFormation setup if you are debugging a failed stack deploy. Should you run out of LetsEncrypt TLS requests, you'll need to wait one week before trying again.
  • execute make cert - This creates a certificate for your API, only required the first time

  • execute make deploy-api - This creates the Python lambda and API at api.foundry.${domain}

API

The api can control a few things

  • GET /ip/add - Add your current IP address (as determined by X-Forwarded-For) to the S3 bucket policy
  • GET /ip/reset - Purge all current IP's barring the defaults
  • GET /start - start the EC2 Foundry server
  • GET /stop - stop the EC2 Foundry Server

Security and Updates

As of the v1.1.0 release, Linux auto-patching is enabled by default. A utility script utils/kernel_updates.sh also exists to help you manage this if you want to disable or re-enable or run it.

It's also recommended to SSH into the instance and run sudo dnf upgrade every so often to make sure your packages are up to date with the latest fixes and security releases.

Upgrading From a Previous Installation

see Upgrading

IPv6 Support

see IPv6

Debugging Failed CloudFormation

As long as you can get as far as the EC2 being spun up, then:

  • If you encounter a creation error, try setting CloudFormation to preserve resources instead of rollback so you can check the troublesome resources
  • Disable LetsEncrypt certificate requests (UseLetsEncryptTLS set to False), until you're happy that it's working to avoid running into the certificate issuance limit
  • Add your IP to the Inbound rules of the created Security Group (if you didn't already during the CloudFormation config)
  • Grab the EC2's IP from the EC2 web console details
  • Open up PuTTy or similar, connect to the IP using the SSH keypair (I'd recommend to only accept the key once, rather than accept always, as you may end up destroying this instance)
  • Check the setup logs
    • sudo tail -f /tmp/foundry-setup.log if setup scripts are still running, or
    • sudo cat /tmp/foundry-setup.log | less if setup scripts have finished running

Hopefully that gives you some insight in what's going on...

Future Considerations

  • Improve CloudWatch logs (?)
  • Add script to facilitate transfer between two EC2s?
  • Store LetsEncrypt PEM keys in AWS Secrets Manager and retrieve them instead of requesting new ones to work around the issuance limit (is that even possible / supported?)
  • Better ownership/permissions defaults?
  • Automatically select the x86_64 or arm64 image based on instance choice (even possible?)
  • Consider using SSH forwarding via SSM or EC2 Instance Connect instead of key pair stuff, would need to look into this
  • IPv6 support (AWS will soon start charging for IPv4 address assignments), in progress
  • Consider better packaging to remove public github repo cloning but instead use a packaged copy of the repo

Notes

  • The s3 bucket policy contains 3 private range subnets (usually the default vpc subnets)

    • This is intentional despite the lack of use
    • Having more than 1 item ensures the lambda code assumption (that its a list) can be true
      • By all means PR a better code if you would like
    • Having them there does not harm anything
  • This install clones the public repository to access scripts

    • Ensure you update the repo to your own if making changes