Hansel generates empty linux packages. These packages can be installed to track dependencies manually added to a container image.
You can use hansel in a multistep build:
FROM ghcr.io/Shopify/hansel:latest AS crumbs
RUN hansel --name rando-thing --version v1.2.3 --debian
FROM debian:bullseye
RUN curl -o /usr/bin/rando-thing https://rando.thing/v1.2.3/unsigned-blob-yolo
COPY --from=crumbs /rando-thing*.deb /tmp/rando-thing.deb
RUN dpkg -i /tmp/rando-thing.deb && \
rm /tmp/rando-thing.deb
The name is inspired by:
Hansel and Gretel, as the packages are breadcrumbs left for container scanners to identify.