From 9ac7eeb633f81a5bafe20fca61e17de9cb5070b9 Mon Sep 17 00:00:00 2001 From: Carter McKinnon Date: Mon, 14 Aug 2023 18:21:00 -0700 Subject: [PATCH] Cache IMDS tokens per-user --- files/bin/imds | 7 +++---- test/cases/imds-token-refresh.sh | 2 +- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/files/bin/imds b/files/bin/imds index 2d23801ba..061c8b070 100755 --- a/files/bin/imds +++ b/files/bin/imds @@ -49,8 +49,8 @@ function imdscurl() { } function get-token() { - local TOKEN_DIR=/tmp/imds-tokens - mkdir -p -m a+wrx $TOKEN_DIR + local TOKEN_DIR="/tmp/imds-tokens/$(whoami)" + mkdir -p -m 0600 $TOKEN_DIR # cleanup expired tokens local DELETED_TOKENS=0 @@ -71,8 +71,7 @@ function get-token() { -X PUT \ "http://$IMDS_ENDPOINT/latest/api/token") echo "$TOKEN" > "$TOKEN_DIR/$TOKEN_FILE" - # make sure any user can utilize (and clean up) these tokens - chmod a+rwx $TOKEN_DIR/$TOKEN_FILE + chmod 0600 "$TOKEN_DIR/$TOKEN_FILE" log "🔑 Retrieved a fresh IMDS token that will expire in $IMDS_TOKEN_TTL_SECONDS seconds." else log "ℹī¸ Using cached IMDS token that expires in $(($TOKEN_FILE - $CURRENT_TIME)) seconds." diff --git a/test/cases/imds-token-refresh.sh b/test/cases/imds-token-refresh.sh index 1f4ca7039..76af2c460 100755 --- a/test/cases/imds-token-refresh.sh +++ b/test/cases/imds-token-refresh.sh @@ -6,7 +6,7 @@ set -o pipefail echo "--> Should refresh IMDS token on configured interval" exit_code=0 -TOKEN_DIR=/tmp/imds-tokens +TOKEN_DIR=/tmp/imds-tokens/$(whoami) TTL=5 export IMDS_TOKEN_TTL_SECONDS=$TTL export IMDS_DEBUG=true