usermod -v
( --add-sub-uids
) とusermod -w
( --add-sub-gids
) は、ユーザー アカウントの subuid と subgid の範囲を操作するために使用できますが、それらを単に一覧表示できるツールはないようです。そのようなツールはありますか?
少なくとも私の Ubuntu 14.04 ボックスでは、およびgetent
からの情報を処理する準備ができていないようです。/etc/subuid
/etc/subgid
awk
現在、私はその目的のために小さなシェル スクリプトを使用しています。
以下は抜粋ですusermod(8)
:
-v, --add-sub-uids FIRST-LAST
Add a range of subordinate uids to the users account.
[...]
-V, --del-sub-uids FIRST-LAST
Remove a range of subordinate uids from the users account.
[...]
-w, --add-sub-gids FIRST-LAST
Add a range of subordinate gids to the users account.
[...]
-W, --del-sub-gids FIRST-LAST
Remove a range of subordinate gids from the users account.
[...]
答え1
とりあえず、私が使用しているシェル スクリプトを以下に示します。
#!/bin/bash
SUBUID=/etc/subuid
SUBGID=/etc/subgid
for i in $SUBUID $SUBGID; do [[ -f "$i" ]] || { echo "ERROR: $i does not exist, but is required."; exit 1; }; done
[[ -n "$1" ]] && USERS=$1 || USERS=$(awk -F : '{x=x " " $1} END{print x}' $SUBUID)
for i in $USERS; do
awk -F : "\$1 ~ /$i/ {printf(\"%-16s sub-UIDs: %6d..%6d (%6d)\", \$1 \",\", \$2, \$2+\$3, \$3)}" $SUBUID
awk -F : "\$1 ~ /$i/ {printf(\", sub-GIDs: %6d..%6d (%6d)\", \$2, \$2+\$3, \$3)}" $SUBGID
echo ""
done
構文:
showsubids [username]
ユーザー名が指定されていない場合は、すべてがリストされます。ユーザー名が指定されている場合は、そのユーザー名のエントリのみが表示されます。
エラー処理は最適ではありませんが、誰かの役に立つなら...