forked from littlebizzy/slickstack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ss-install-ubuntu-users.txt
145 lines (107 loc) · 7.32 KB
/
ss-install-ubuntu-users.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#!/bin/bash
####################################################################################################
#### author: SlickStack ############################################################################
#### link: https://slickstack.io ###################################################################
#### mirror: https://mirrors.slickstack.io/bash/ss-install-ubuntu-users.txt ########################
#### path: /var/www/ss-install-ubuntu-users ########################################################
#### destination: n/a (not a boilerplate) ##########################################################
#### purpose: Reinstalls the Ubuntu (OS) users (sudo/sftp) based on ss-config (idempotent) #########
#### module version: Ubuntu 20.04 LTS ##############################################################
#### sourced by: ss-install ########################################################################
#### bash aliases: ss install ubuntu users #########################################################
####################################################################################################
## SS-CONFIG MUST BE PROPERLY CONFIGURED AND ON CURRENT BUILD BEFORE RUNNING SS-INSTALL ##
## ENSURE YOUR SS-CONFIG BUILD REMAINS CURRENT BY RUNNING SS-UPDATE OCCASIONALLY ##
## source ss-config ##
source /var/www/ss-config
## source ss-functions ##
source /var/www/ss-functions
## BELOW THIS RELIES ON SS-CONFIG AND SS-FUNCTIONS
####################################################################################################
#### SS-Install-Ubuntu-Users: Message (Begin Script) ###############################################
####################################################################################################
## this is a simple message that announces to the shell the purpose of this bash script ##
## it will only be noticed by sudo users who manually call ss core bash scripts ##
## echo message ##
echo -e "${PURPLE}Running ss-install-ubuntu-users: Reinstalls the Ubuntu (OS) users (sudo/sftp) based on ss-config (idempotent)... ${NOCOLOR}"
sleep "$SLEEP_MESSAGE_BEGIN"
####################################################################################################
#### SS-Install-Ubuntu-Users: Cleanup Temporary Files ##############################################
####################################################################################################
## delete tmp files ##
# n/a
####################################################################################################
#### SS-Install-Ubuntu-Users: Configure Root Password + Setup Ubuntu Users #########################
####################################################################################################
## set root password ##
echo "root:$ROOT_PASSWORD" | sudo /usr/sbin/chpasswd
## ensure root password never expires ##
# passwd -x -1 <username>
chage -E -1 -m 0 -M -1 -I -1 -W 99999 root
# chage -E -1 -m 0 -M -1 -I -1 -W 99999 $SUDO_USER
# chage -E -1 -m 0 -M -1 -I -1 -W 99999 $SFTP_USER
## create sudo user ##
adduser --disabled-password --quiet --shell /bin/bash --gecos "" $SUDO_USER
# echo "$SUDO_USER:$SUDO_PASSWORD" | sudo /usr/sbin/chpasswd
sudo echo "$SUDO_USER:$SUDO_PASSWORD" | sudo /usr/sbin/chpasswd
## ensure home directory exists ##
mkhomedir_helper $SUDO_USER
## create sftp user ##
adduser --disabled-password --quiet --shell /bin/bash --gecos "" $SFTP_USER
# echo "$SFTP_USER:$SFTP_PASSWORD" | sudo /usr/sbin/chpasswd
sudo echo "$SFTP_USER:$SFTP_PASSWORD" | sudo /usr/sbin/chpasswd
###### useradd -p "$SFTP_PASSWORD" -s /bin/bash "$SFTP_USER"
## ensure home directory exists ##
mkhomedir_helper $SFTP_USER
## ensure wordpress group exists ##
groupadd -f wordpress
## add SFTP_USER and www-data to wordpress group + add SFTP_USER to www-data group ##
usermod -a -G wordpress "$SFTP_USER"
usermod -a -G wordpress www-data
usermod -a -G www-data "$SFTP_USER"
####################################################################################################
#### SS-Install-Ubuntu-Users: Configure Sudo Permissions (Sudoers File) ############################
####################################################################################################
## download latest versions ##
wget -O /tmp/sudoers "$MIRROR_SUDOERS"
## replace variables ##
sed -i "s/@SUDO_USER/${SUDO_USER}/g" /tmp/sudoers
## copy files to their destinations ##
cp /tmp/sudoers /etc/sudoers
####################################################################################################
#### SS-Install-Ubuntu-Users: Reset Permissions (Ubuntu Users) #####################################
####################################################################################################
## run ss-perms-ubuntu-users ##
source "$PATH_SS_PERMS_UBUNTU_USERS"
####################################################################################################
#### SS-Install-Ubuntu-Users: Cleanup Temporary Files ##############################################
####################################################################################################
## delete tmp files ##
# n/a
####################################################################################################
#### SS-Install-Ubuntu-Users: Install (Optimize) Ubuntu Bash #######################################
####################################################################################################
## here we reinstall bash run commands which requires the users to be installed already ##
## there is no drawback to running this repeatedly so we include it here casually ##
## run ss-install-ubuntu-bash ##
source "$PATH_SS_INSTALL_UBUNTU_BASH"
####################################################################################################
#### SS-Install-Ubuntu-Users: Touch Timestamp File (End Script) ####################################
####################################################################################################
## this is a dummy timestamp file that will remember the last time this script was run ##
## it can be useful for developer reference and is sometimes used by SlickStack ##
## script timestamp ##
touch "$TIMESTAMP_SS_INSTALL_UBUNTU_USERS"
####################################################################################################
#### SlickStack: External References Used To Improve This Script (Thanks, Interwebz) ###############
####################################################################################################
## Ref: https://askubuntu.com/questions/94060/run-adduser-non-interactively
## Ref: http://manpages.ubuntu.com/manpages/trusty/man8/adduser.8.html
## Ref: https://www.computerhope.com/unix/adduser.htm
## Ref: https://explainshell.com/explain?cmd=adduser+--disabled-password+--quiet+--system+--home+%2Fvar%2Frun%2Frails-new+--no-create-home+--gecos+%22Rails+New+daemon%22+--group+rails-new
## Ref: https://stackoverflow.com/questions/2150882/how-to-automatically-add-user-account-and-password-with-a-bash-script
## Ref: https://github.com/jupyterhub/jupyterhub/issues/2145
## Ref: https://serverfault.com/questions/167416/how-can-i-automatically-change-directory-on-ssh-login
## Ref: https://unix.stackexchange.com/questions/140602/how-do-i-start-all-shell-sessions-in-a-directory-other-than-home
## Ref: https://askubuntu.com/questions/335961/create-default-home-directory-for-existing-user-in-terminal
## SS_EOF