Skip to content

Store and Deliver images with R2 backend Cloudflare Workers.

Notifications You must be signed in to change notification settings

yusukebe/r2-image-worker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

r2-image-worker

Store and deliver images with Cloudflare R2 backend Cloudflare Workers.

Synopsis

  1. Deploy r2-image-worker to Cloudflare Workers.
  2. PUT your image file to r2-image-worker.
  3. The image file will be stored in Cloudflare R2 storage.
  4. r2-image-worker will respond the key of the stored image. abcdef.png
  5. r2-image-worker serve the images on https://r2-image-worker.username.workers.dev/abcdef.png
  6. Images will be cached on Cloudflare CDN.
User => Image => r2-image-worker => R2
User <= Image <= r2-image-worker <= CDN Cache <= R2

Prerequisites

  • Cloudflare Account
  • Wrangler CLI
  • (Custom domain - Cache API is not available in .workers.dev domain)

Set up

First, git clone

git clone https://github.com/yusukebe/r2-image-worker.git
cd r2-image-worker

Create R2 bucket:

wrangler r2 bucket create images

Copy wrangler.example.toml to wrangler.toml:

cp wrangler.example.toml wrangler.toml

Edit wrangler.toml.

Variables

Secret variables

Secret variables are:

  • USER - User name of basic auth
  • PASS - User password of basic auth

To set these, use wrangler secret put command:

wrangler secret put USER

Publish

To publish to your Cloudflare Workers:

npm run deploy

Endpoints

/upload

Header:

To pass the Basic Auth, add the Base64 string of "user:pass" to Authorization header.

Authorization: Basic ...

Body:

Value of body should be a Form contains an image binary and a width and a height.

  • image: File
  • width: string (optional)
  • height: string (optional)

Test

  1. Download a simple image
wget https://hono.dev/images/hono-kawaii.png -O /tmp/1.jpg
  1. Upload to u endpoint.
curl -X PUT \
  -F "image=@/tmp/1.jpg" \
  https://change_user_here:change_pass_here@change_url_here/upload \
  -vvv
  1. Visit the image
https://change_user_here:change_pass_here@change_url_here/image_returned_in_step2

Tips

Using Cloudflare Images

You can deliver your images via Cloudflare Images if you are using a custom domain.

https://<ZONE>/cdn-cgi/image/format=auto,width=800,quality=75/<SOURCE-IMAGE>

Using with Shortcuts

Awesome!!!

Screen cast

Setting shortcuts like this:

Screenshot

Author

Yusuke Wada https://github.com/yusukebe

License

MIT