Link preview data is not always available—sadly.
Maybe you need to get the header image from a WordPress post, or you’re building a Notion database with links, and would like to enrich it? If so, then this guide is for you. Here’s a few easy steps on how to set that up, with the help of a free API.
This is the data that we’ll retrieve:
data:image/s3,"s3://crabby-images/828df/828df9af17618eba9bb486e7a901503016b94d5f" alt=""
Let’s go!
1) Creating an API key
Scouring the internet, I found a couple of APIs that return link preview data. The one I landed on is called URL Meta
data:image/s3,"s3://crabby-images/d57d0/d57d0d28b0892293b78b0601cea244e08ee65857" alt=""
Create an API key on https://urlmeta.org/.
Once an account has been created, you’ll be able to copy your API key:
data:image/s3,"s3://crabby-images/b12a0/b12a0b1679119f19c17a9647ee33386115d7f9ea" alt=""
2) Base 64 encode your credentials
As per the API docs, we’ll need to base encode the:
email:apiKeyHere
data:image/s3,"s3://crabby-images/f4300/f4300dbe8d377ef11f19351ab434a3f035f6ee0d" alt=""
And use the Authorization Basic header (more on that later). We’ll head to this link first:
Then fill out the following details—and take these steps:
data:image/s3,"s3://crabby-images/6d342/6d3420c2011519f23e5a47ef2a8fbb6dbe1b8422" alt=""
- Add your email address, followed by a colon, then the API key
- Click on the ENCODE button
- Copy everything that appears in the box
3) Setting up a custom request in Webhooks by Zapier
Now comes the easiest part! Here’s how it’s going to look:
data:image/s3,"s3://crabby-images/3b914/3b914ad142e299b2dd5e89316d1cda75d8889cb5" alt=""
- We’ll select the Custom Request in Webhooks by Zapier action
- Select GET
- Add the URL https://api.urlmeta.org/?url=XXX (and replace XXX with a mapped object from a previous step/or hard code it by manually typing something out)
- Add the `Authorization` header, then use `Basic baseEncodedValueHere`)
- Ready for testing!
The output:
data:image/s3,"s3://crabby-images/6e871/6e87152fb955f57ca982c2b59cd464bd10188f44" alt=""
And there you have it! We have a solution to dynamically retrieve link preview data.
data:image/s3,"s3://crabby-images/4f4f4/4f4f4d2ebc8f63a5c942800c511be2cc5cc987f0" alt=""
Hope that helps!