build+ci: add Dockerfile and workflow

Refs: #5303
Change-Id: I757249bfc247a581c8dc9c782fef767561fd6896
diff --git a/.dockerignore b/.dockerignore
new file mode 100644
index 0000000..3c7f02d
--- /dev/null
+++ b/.dockerignore
@@ -0,0 +1,27 @@
+# Waf build system
+build/
+.waf-*-*/
+.waf3-*-*/
+.lock-waf*
+
+# Compiled python code
+**/__pycache__/
+**/*.py[cod]
+
+# Qt Creator
+*.creator
+*.creator.user
+.qtc_clangd/
+
+# Visual Studio Code
+.vscode/
+
+# macOS
+**/.DS_Store
+**/.AppleDouble
+**/.LSOverride
+**/._*
+
+# Other
+Dockerfile
+VERSION.info
diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml
new file mode 100644
index 0000000..9827007
--- /dev/null
+++ b/.github/workflows/docker.yml
@@ -0,0 +1,19 @@
+name: Docker
+on:
+  push:
+    tags:
+      - 'ndn-tools-*'
+  schedule:
+    # twice a month
+    - cron: '20 10 5,20 * *'
+  workflow_dispatch:
+
+permissions:
+  packages: write
+  id-token: write
+
+jobs:
+  ndn-tools:
+    uses: named-data/actions/.github/workflows/docker-image.yml@v1
+    with:
+      name: ndn-tools
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000..bf5965c
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,50 @@
+# syntax=docker/dockerfile:1
+
+ARG NDN_CXX_VERSION=latest
+FROM ghcr.io/named-data/ndn-cxx-build:${NDN_CXX_VERSION} AS build
+
+RUN apt-get install -Uy --no-install-recommends \
+        libpcap-dev \
+    && apt-get distclean
+
+ARG JOBS
+ARG SOURCE_DATE_EPOCH
+RUN --mount=rw,target=/src <<EOF
+    set -eux
+    cd /src
+    ./waf configure \
+        --prefix=/usr \
+        --libdir=/usr/lib \
+        --sysconfdir=/etc \
+        --localstatedir=/var \
+        --sharedstatedir=/var
+    ./waf build
+    ./waf install
+    mkdir -p /deps/debian
+    touch /deps/debian/control
+    cd /deps
+    for binary in ndnpeek ndnpoke ndncatchunks ndnputchunks ndnping ndnpingserver ndndump ndn-dissect; do
+        dpkg-shlibdeps --ignore-missing-info "/usr/bin/${binary}" -O \
+            | sed -n 's|^shlibs:Depends=||p' | sed 's| ([^)]*),\?||g' > "${binary}"
+    done
+EOF
+
+
+FROM ghcr.io/named-data/ndn-cxx-runtime:${NDN_CXX_VERSION} AS ndn-tools
+
+COPY --link --from=build /usr/bin/ndnpeek /usr/bin/
+COPY --link --from=build /usr/bin/ndnpoke /usr/bin/
+COPY --link --from=build /usr/bin/ndncatchunks /usr/bin/
+COPY --link --from=build /usr/bin/ndnputchunks /usr/bin/
+COPY --link --from=build /usr/bin/ndnping /usr/bin/
+COPY --link --from=build /usr/bin/ndnpingserver /usr/bin/
+COPY --link --from=build /usr/bin/ndndump /usr/bin/
+COPY --link --from=build /usr/bin/ndn-dissect /usr/bin/
+
+RUN --mount=from=build,source=/deps,target=/deps \
+    apt-get install -Uy --no-install-recommends $(cat /deps/ndn*) \
+    && apt-get distclean
+
+ENV HOME=/config
+VOLUME /config
+VOLUME /run/nfd