This is a lambda function template you can use to run on site publishing events in Drzzle. What this does is loop through all site files, downloads each one to lambda's tmp/
folder for uploading elsewhere. You control where your files go!
The callback to keep in mind here is the onFileCreated function. In this callback, you have a file buffer ready to go along with the path needed to be uploaded on your server. Here you can do the work needed for the upload.
All of this can be automated better in the future but for now, make sure you have created an empty lambda function in your AWS account using the latest node version. To make this easiest, title it site-publish-hook
. If using a different name, be sure to update it in the aws.yml file and in API Gateway.
To invoke this function, you will need to set up a REST API using API Gateway
. Follow the steps below to do so manually:
- In your AWS dashboard, find API Gateway and click "Create API".
- Find "REST API" and hit build.
- Leave the defaults (New API) selected, give it a name then hit "Create API".
- Click "Actions" -> "Create Method" and select "Post" from the dropdown.
- In the method settings, make sure the following are selected:
- Integration Type: Lambda Function
- Use Lambda Proxy Integration: ✅
- Lambda Region: (same region as lambda function)
- Lambda Function:
site-publish-hook
(or whatever you named the function) - Use Default Timeout: ✅
- Click "Actions" -> "Deploy API". For Deployment stage select [New Stage]. Then give it a name and hit "Deploy".
After the API is deployed, head over to Drzzle and add a new webhook in your site's admin panel, paste in the Invoke URL and hit save.
We included a simple node script (deploy.js
) to zip this function up and auto upload it to your AWS account. You will need to have the AWS CLI installed first to use it. See instructions for installing the CLI.
npm run deploy
Lambda has some limits on it's tmp/
folder size. If you have media files over 512mb
the function may error. Do also keep in mind to set your lambda timeout long enough to handle the size of your website. It usually runs really quick.
If you have lots of large media files and fear that this function will timeout or error, then lambda may not be the way to go. You'd likely be better off setting up a small cloud server to handle this work. The good news is, you can still use the code in this function!