Я работаю над сценарием, и он содержит функцию для создания нового пользователя, и эту функцию необходимо запустить как root, чтобы работать, но когда я запускаю свой сценарий как:
sudo ./sample.sh
Это выдает следующую ошибку:
. / sample: 3: синтаксическая ошибка: "(" непредвиденная
Но когда я запускаю ее без sudo, я получаю такой вывод:
-
-
useradd: Permission denied.
useradd: cannot lock /etc/passwd; try again later.
chage: user 'yt' does not exist in /etc/passwd
chage: user 'yt' does not exist in /etc/passwd
-
-
sed: can't read /etc/sudoers: Permission denied
sed: can't read /etc/sudoers: Permission denied
-
-
Таким образом, скрипт работает с моим стандартным пользователем (это просто проблема с привилегиями). Я не понимаю, почему он не работает с sudo. Я нахожу в inte rnet, что мне нужно экспортировать функция, но все та же проблема, вот сценарий:
############create user Function#
#!/bin/bash
function user_create ()
{
useradd -m -p '#SOME_PASSWD' -s /bin/bash $userName
sudo chage -m 5 -M 90 -I 30 -W 14 $userName
sudo chage --lastday 0 $userName
echo ''
echo '--------------------------------------------------------------------------------------------'
echo -e '\e[32mPasswd set for \e[1m'$userName' for 90 days MAX | 5 days MIN\e[0m'
echo -e '\e[32mPasswd is set to change the current passwd in next login for \e[1m' $userName
echo -e '\e[0m--------------------------------------------------------------------------------------------'
#User based policy#
sed -i "#SOME_SED_COMMAND" /etc/sudoers
sed -i "/#SOME_STRING/#NEW_STRING" /etc/sudoers
echo -e '\e[33m'
sudo cat /etc/sudoers | grep -i "$userName"
echo -e '\e[0m'
echo ''
echo '------------------------------------------------------------------'
echo -e '\e[1m\e[32mUser Privilege Set\e[0m'
echo '------------------------------------------------------------------'
return 0
}
export -f user_create
if [ -z $1 ]
then
echo -e 'e\1[m e\[100m e\[33m Do you want to CREATE A NEW USER?e\[0m (y/n)'
read createUser
if [ $createUser = 'y' -o $createUser = 'Y' ]
then
echo 'Enter USER.NAME:::: First_Name.Last_Name'
read userName
user_create
else
echo ''
echo '------------------------------------------------------------------'
echo -e '\e[31mNO NEW USER added.\e[0m'
echo '------------------------------------------------------------------'
fi
else
userName=$1
User_Create
fi