Autopurge
It sounds nasty but with my aggressive caching I need a way to purge the cache when I publish a new blog post. An automated way would be best. Thus; auto-purge.
Enter Zapier. The IFTTT for webhooks.
data:image/s3,"s3://crabby-images/613f0/613f03e10cd19dabd19002bbfea016652e83a617" alt=""
The process works like this:
- I publish a new post
- Ghost fires off a webhook to Zapier
- Zapier receives this webhook, and sends a request to Cloudflare via API
- Cloudflare purges
In order to set this up like I have, you'll need a few things;
- A Zapier account
- A Cloudflare account
- The email address for your Cloudflare account
- Your site’s Zone ID
- Your Cloudflare API key
Once you've got everything prepared, head on over to Zapier and create a new Zap.
Trigger
You'll want to find Ghost as the trigger app.
data:image/s3,"s3://crabby-images/12132/121325f047d3240baa94f8e6e9be2c3df94ddf84" alt=""
And set the trigger to a new story. Defining the published status comes a bit later in the setup.
data:image/s3,"s3://crabby-images/c8de6/c8de6f4db533e38ec2336032520ebced232f9904" alt=""
Connect to your Ghost instance. You'll need to define a full URL, https://
and all.
data:image/s3,"s3://crabby-images/4e7b2/4e7b2af71f67330d4d8fb211157d39d73ee00ab6" alt=""
And here is where we set the trigger status to be published. There are others available but published is the status we care about for this Zap.
data:image/s3,"s3://crabby-images/a952c/a952c00771de272a2961f3491673801b3857f66b" alt=""
Action
Cloudflare doesn't have an app in Zapier, so we'll have to make do with a webhook...
data:image/s3,"s3://crabby-images/35561/35561a32b63b51f5419c6126a47f10099e489d26" alt=""
... a custom webhook!
data:image/s3,"s3://crabby-images/19f7d/19f7df7e246a0c121ae3bd066389f02ef8b948a9" alt=""
When setting up the webhook it needs to be a POST request to URL:https://api.cloudflare.com/client/v4/zones/<Zone ID>/purge_cache
Ignore data pass-through.
Set the data to the following JSON;
{
"purge_everything":true
}
And add in two headers, their keys are X-Auth-Email
and X-Auth-Key
.
data:image/s3,"s3://crabby-images/6e9a1/6e9a171ab1712aeacf80f96bee5ce8c740d1e9cf" alt=""
Once that's done hit continue and test the webhook.
data:image/s3,"s3://crabby-images/78b4e/78b4e93482a7dc35ac5e8853cfd7ea029c6b4c08" alt=""
Done!
With all of that hard work out of the way your super cache purging adventure can begin.
Happy blogging!
data:image/s3,"s3://crabby-images/d5c2d/d5c2dc69a58dac6971aff0845371a9506c98df4f" alt=""