Update file run_onchange_before_20-ensure-user-group.sh.tmpl
This commit is contained in:
parent
87414c9d63
commit
62ed0d317c
1 changed files with 34 additions and 29 deletions
|
@ -8,37 +8,42 @@
|
||||||
{{ includeTemplate "universal/profile-before" }}
|
{{ includeTemplate "universal/profile-before" }}
|
||||||
{{ includeTemplate "universal/logg-before" }}
|
{{ includeTemplate "universal/logg-before" }}
|
||||||
|
|
||||||
### Ensure user has group of same name (required for Macports)
|
if [ -n "$USER" ]; then
|
||||||
logg info "Ensuring user ($USER) has a group with the same name ($USER) and that it is a member. Sudo privileges may be required"
|
logg info "Adding the $USER user to the $USER group"
|
||||||
|
### Ensure user has group of same name (required for Macports)
|
||||||
|
logg info "Ensuring user ($USER) has a group with the same name ($USER) and that it is a member. Sudo privileges may be required"
|
||||||
|
|
||||||
GROUP="$USER"
|
GROUP="$USER"
|
||||||
USERNAME="$USER"
|
USERNAME="$USER"
|
||||||
|
|
||||||
### Add group
|
### Add group
|
||||||
sudo dscl . create /Groups/$GROUP
|
sudo dscl . create /Groups/$GROUP
|
||||||
|
|
||||||
### Add GroupID to group
|
### Add GroupID to group
|
||||||
if [[ "$(sudo dscl . read /Groups/$GROUP gid 2>&1)" == *'No such key'* ]]; then
|
if [[ "$(sudo dscl . read /Groups/$GROUP gid 2>&1)" == *'No such key'* ]]; then
|
||||||
MAX_ID_GROUP="$(dscl . -list /Groups gid | awk '{print $2}' | sort -ug | tail -1)"
|
MAX_ID_GROUP="$(dscl . -list /Groups gid | awk '{print $2}' | sort -ug | tail -1)"
|
||||||
GROUP_ID="$((MAX_ID_GROUP+1))"
|
GROUP_ID="$((MAX_ID_GROUP+1))"
|
||||||
sudo dscl . create /Groups/$GROUP gid "$GROUP_ID"
|
sudo dscl . create /Groups/$GROUP gid "$GROUP_ID"
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Add user
|
||||||
|
sudo dscl . create /Users/$USERNAME
|
||||||
|
|
||||||
|
### Add PrimaryGroupID to user
|
||||||
|
if [[ "$(sudo dscl . read /Users/$USERNAME PrimaryGroupID 2>&1)" == *'No such key'* ]]; then
|
||||||
|
sudo dscl . create /Users/$USERNAME PrimaryGroupID 20
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Add UniqueID to user
|
||||||
|
if [[ "$(sudo dscl . read /Users/$USERNAME UniqueID 2>&1)" == *'No such key'* ]]; then
|
||||||
|
MAX_ID_USER="$(dscl . -list /Users UniqueID | awk '{print $2}' | sort -ug | tail -1)"
|
||||||
|
USER_ID="$((MAX_ID_USER+1))"
|
||||||
|
sudo dscl . create /Users/$USERNAME UniqueID "$USERID"
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Add user to group
|
||||||
|
sudo dseditgroup -o edit -t user -a $USERNAME $GROUP
|
||||||
|
else
|
||||||
|
logg warn 'The USER environment variable is unavailable'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
### Add user
|
|
||||||
sudo dscl . create /Users/$USERNAME
|
|
||||||
|
|
||||||
### Add PrimaryGroupID to user
|
|
||||||
if [[ "$(sudo dscl . read /Users/$USERNAME PrimaryGroupID 2>&1)" == *'No such key'* ]]; then
|
|
||||||
sudo dscl . create /Users/$USERNAME PrimaryGroupID 20
|
|
||||||
fi
|
|
||||||
|
|
||||||
### Add UniqueID to user
|
|
||||||
if [[ "$(sudo dscl . read /Users/$USERNAME UniqueID 2>&1)" == *'No such key'* ]]; then
|
|
||||||
MAX_ID_USER="$(dscl . -list /Users UniqueID | awk '{print $2}' | sort -ug | tail -1)"
|
|
||||||
USER_ID="$((MAX_ID_USER+1))"
|
|
||||||
sudo dscl . create /Users/$USERNAME UniqueID "$USERID"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### Add user to group
|
|
||||||
sudo dseditgroup -o edit -t user -a $USERNAME $GROUP
|
|
||||||
{{ end -}}
|
{{ end -}}
|
||||||
|
|
Loading…
Reference in a new issue