From f2521c85368dbbebb29a6e917e8c27c29e46e41c Mon Sep 17 00:00:00 2001 From: Grant Limberg Date: Wed, 26 Mar 2025 11:23:46 -0700 Subject: [PATCH] Allow setting local.conf content from Docker environment variable --- README.docker.md | 1 + entrypoint.sh.release | 10 ++++++++-- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/README.docker.md b/README.docker.md index 0410f892e..5b046e320 100644 --- a/README.docker.md +++ b/README.docker.md @@ -64,6 +64,7 @@ You can control a few settings including the identity used and the authtoken use - `ZEROTIER_API_SECRET`: replaces the `authtoken.secret` before booting and allows you to manage the control socket's authentication key. - `ZEROTIER_IDENTITY_PUBLIC`: the `identity.public` file for zerotier-one. Use `zerotier-idtool` to generate one of these for you. - `ZEROTIER_IDENTITY_SECRET`: the `identity.secret` file for zerotier-one. Use `zerotier-idtool` to generate one of these for you. +- `ZEROTIER_LOCAL_CONF`: Sets the the `local.conf` file content for zerotier-one ### Tips diff --git a/entrypoint.sh.release b/entrypoint.sh.release index 284a3d419..da9b8f8c8 100644 --- a/entrypoint.sh.release +++ b/entrypoint.sh.release @@ -9,15 +9,16 @@ mkztfile() { file=$1 mode=$2 content=$3 - + echo "creating $file" mkdir -p /var/lib/zerotier-one - echo "$content" > "/var/lib/zerotier-one/$file" + echo -n "$content" > "/var/lib/zerotier-one/$file" chmod "$mode" "/var/lib/zerotier-one/$file" } if [ "x$ZEROTIER_API_SECRET" != "x" ] then mkztfile authtoken.secret 0600 "$ZEROTIER_API_SECRET" + mkztfile metricstoken.secret 0600 "$ZEROTIER_API_SECRET" fi if [ "x$ZEROTIER_IDENTITY_PUBLIC" != "x" ] @@ -30,6 +31,11 @@ then mkztfile identity.secret 0600 "$ZEROTIER_IDENTITY_SECRET" fi +if [ "x$ZEROTIER_LOCAL_CONF" != "x" ] +then + mkztfile local.conf 0644 "$ZEROTIER_LOCAL_CONF" +fi + mkztfile zerotier-one.port 0600 "9993" killzerotier() {