cloudflare-soos

Crates.iocloudflare-soos
lib.rscloudflare-soos
version2.3.1
sourcesrc
created_at2020-03-20 18:19:25.439124
updated_at2023-11-14 16:44:57.796761
descriptionHelper tool for Cloudflare's enhanced HTTP/2 and HTTP/3 prioritization, which makes progressive images load faster. Supports JPEG, GIF, and PNG.
homepagehttps://blog.cloudflare.com/parallel-streaming-of-progressive-images/
repository
max_upload_size
id220756
size89,850
Ivan Nikulin (inikulin)

documentation

README

Scan Offsets of Scans

Progressive image parser for HTTP/2 parallel progressive streaming feature and HTTP/3 prioritization.

Computes optimal offsets for the cf-priority-change and Priority headers to render images progressively with a "preview" and "good enough" stages. In JPEG it tries to render DC channels only (libjpeg-turbo has a special support for nicely blurring the DC-only stage) and then prioritize sending enough data for the image look fully loaded.

In case of GIF animations it prioritizes sending the first frame only. In interlaced PNG it roughly guesses progressive scans. For non-progressive images it tries to send image dimensions before any other data to aid page layout and (improves Cumulative Layout Shift (CLS) metric).

Building and usage

Install Rust 1.60 or later, and run:

cargo install cloudflare-soos
soos-cf-priority image.jpg [--rfc9218]

This will print to stdout Cloudflare's cf-priority (first line) and cf-priority-change (second line) headers with breakpoints for the image.jpg file, an error to stderr. When an --rfc9218 argument provider, it will print out HTTP3 priority header instead, e.g. u=1;i=?0,change=(1000;u=3;i=?0 10000;u=5;i 100000;u=6;i). The image is read from stdin if not path is specified. This tool requires progressive JPEG files, and doesn't do anything for baseline JPEG or other formats.

The same can be done programmatically by using this crate as a library and calling soos::Scans::from_file(jpeg_bytes)?.cf_priority_change_headers()? or soos::Scans::from_file(jpeg_bytes)?.rfc9218_priority_change_headers()? for rfc9218 (h3) priority header.

You can also build for WASM with rustup target add wasm32-unknown-unknown; cargo build --release --target=wasm32-unknown-unknown or use wasm-pack.

Example tools

cargo run --example cf-priority -- image.jpg
cargo run --example rfc9218-priority -- image.jpg
cargo run --example scan -- image.jpg

These tools show debug information used to generate the HTTP priority headers.

Credits

JPEG parsing is based on jpeg-decoder by Ulf Nilsson. GIF parsing is from Piston GIF crate.

Commit count: 0

cargo fmt