Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stevelacey/cloudflare-screenshot
🌇 Screenshot webpages using Puppeteer on Cloudflare
https://github.com/stevelacey/cloudflare-screenshot
puppeteer puppeteer-screenshot screenshot-generator screenshot-utility social-media
Last synced: 2 months ago
JSON representation
🌇 Screenshot webpages using Puppeteer on Cloudflare
- Host: GitHub
- URL: https://github.com/stevelacey/cloudflare-screenshot
- Owner: stevelacey
- Created: 2024-04-24T04:36:06.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-06-07T17:54:28.000Z (7 months ago)
- Last Synced: 2024-06-07T19:13:08.863Z (7 months ago)
- Topics: puppeteer, puppeteer-screenshot, screenshot-generator, screenshot-utility, social-media
- Language: JavaScript
- Homepage:
- Size: 21.5 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Cloudflare Screenshot
=====================Screenshot webpages to render social media cards on-the-fly using Puppeteer; largely based on [how Pieter generates shareable pictures](https://levels.io/phantomjs-social-media-share-pictures) for [Nomad List](https://nomadlist.com), and how I did them for [Coworkations](https://coworkations.com) with [cardserver](https://github.com/stevelacey/cardserver).
| [![Coworkations](https://coworkations.com/cards/coworkations.png)](https://coworkations.com/cards/coworkations.png) [📄 HTML](https://coworkations.com/cards/coworkations) [🖼️ PNG](https://coworkations.com/cards/coworkations.png) | [![Hacker Paradise: Cape Town South Africa](https://coworkations.com/cards/hacker-paradise/cape-town-south-africa.png)](https://coworkations.com/cards/hacker-paradise/cape-town-south-africa.png) [📄 HTML](https://coworkations.com/cards/hacker-paradise/cape-town-south-africa) [🖼️ PNG](https://coworkations.com/cards/hacker-paradise/cape-town-south-africa.png) |
| --: | --: |
| **[![Nomad Cruise VI: Spain To Greece](https://coworkations.com/cards/nomad-cruise/nomad-cruise-13-canada-to-japan-sep-2024.png)](https://coworkations.com/cards/nomad-cruise/nomad-cruise-13-canada-to-japan-sep-2024.png) [📄 HTML](https://coworkations.com/cards/nomad-cruise/nomad-cruise-13-canada-to-japan-sep-2024) [🖼️ PNG](https://coworkations.com/cards/nomad-cruise/nomad-cruise-13-canada-to-japan-sep-2024.png)** | **[![PACK: Ubud Bali](https://coworkations.com/cards/pack/ubud-bali-2.png)](https://coworkations.com/cards/pack/ubud-bali-2.png) [📄 HTML](https://coworkations.com/cards/pack/ubud-bali-2) [🖼️ PNG](https://coworkations.com/cards/pack/ubud-bali-2.png)** |Setup
-----After deploying to Cloudflare the site should be good to go, try visiting `https://{site-name}/screenshot` for a capture of your homepage.
Any additional path that comes after `/screenshot` is used in the request to your webserver:
```
https://{site-name}/screenshot/**/* -> {BASE_URL}/**/*
```If you want to change the `BASE_URL` edit the site's environment variables from `Site Settings > Build & deploy > Environment`, the value should be the root domain of your website e.g. `https://example.com`.
Usage
-----Cloudflare Screenshot performs HTML requests based on PNG requests like so:
| 🖼 PNG (Cloudflare request) | 📄 HTML (webserver request) |
| :------------------------------------------------------------- | :---------------------------------------------- |
| https://steve.ly/screenshot/cards/steve.png | https://steve.ly/cards/steve |
| https://coworkations.com/screenshot/cards/coworkations.png | https://coworkations.com/cards/coworkations |
| https://coworkations.com/screenshot/cards/hacker-paradise.png | https://coworkations.com/cards/hacker-paradise |
| https://coworkations.com/screenshot/cards/pack/ubud-bali-2.png | https://coworkations.com/cards/pack/ubud-bali-2 |If you want to serve your cards on the same domain as your app, you can route PNG traffic to Cloudflare via NGINX:
```
location ~ ^/(cards/.*\.png)$ {
proxy_pass http://{site-name}/screenshot/$1;
}
```Then your URLs can look something like this:
| 🖼 PNG (Cloudflare request) | 📄 HTML (webserver request) |
| :-------------------------------------------------- | :---------------------------------------------- |
| https://steve.ly/cards/steve.png | https://steve.ly/cards/steve |
| https://coworkations.com/cards/coworkations.png | https://coworkations.com/cards/coworkations |
| https://coworkations.com/cards/hacker-paradise.png | https://coworkations.com/cards/hacker-paradise |
| https://coworkations.com/cards/pack/ubud-bali-2.png | https://coworkations.com/cards/pack/ubud-bali-2 |Alternatively, you can route all `/screenshots/` traffic to Cloudflare, then prefix any path on your site with `/screenshots/` to capture a screenshot.
```
location /screenshots/ {
proxy_pass http://{site-name}/screenshot/;
}
```Note that query params are passed through to your backend, which can be useful if you want to toggle features like Cookiebot or Intercom on/off.
Caching
-------Cloudflare Screenshot serves sensible cache headers, and allows you to suffix requests with `.png` which helps reverse proxies like Cloudflare recognize the content as cacheable.
In addition to that, you might want to cache results locally so they don't hit Cloudflare every time.
To do that, add something like this to your `nginx.conf`:
```
proxy_cache_path /tmp/nginx levels=1:2 keys_zone=static:10m max_size=10g inactive=7d use_temp_path=off;
proxy_cache_valid 7d;
```And update your location block like so:
```
location /screenshots/ {
proxy_cache static;
proxy_pass http://{site-name}/screenshot/;
}
```Markup
------You’ll want meta tags something like these:
```html
```
Debugging
---------- [Facebook Sharing Debugger](https://developers.facebook.com/tools/debug)
- [Twitter Card Validator](https://cards-dev.twitter.com/validator)