-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathraspbian_server.sh
executable file
·198 lines (160 loc) · 5.57 KB
/
raspbian_server.sh
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
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
#!/bin/bash
: '
@Author Marco A Gallegos
@Date 2020-12-18
@Descripcion
proveer instalaciones basicas para raspbian 10 como servidor
'
#funciones globales
aviso(){
echo $1
}
read -sp 'enter the sudo password:' sudo_pass
echo ""
if [[ ! $sudo_pass ]]; then
aviso "necesito el pasword de sudo"
exit
fi
# revisiones preliminares
val_stow=$(stow --version)
#instalaciones necesarias
if [[ ! $val_stow ]]; then
echo $sudo_pass | sudo apt install stow -y
aviso "se instalo stow" true
fi
#primer paso validar que sea fedora en version 32 o superior
distro_text=$(grep "^NAME" /etc/os-release)
version_text=$(grep "^VERSION_ID" /etc/os-release)
IFS='=' # space is set as delimiter
read -ra distro_arr <<< "$distro_text" # distro_text is read into an array as tokens separated by IFS
read -ra version_arr <<< "$version_text"
distro_name=${distro_arr[1]}
distro_version=${version_arr[1]}
#fedora_version_rpm=$(rpm -E %fedora)
desktop_envirenment=$DESKTOP_SESSION # variable de entorno
#if [[ $distro_name != "Fedora" && $distro_name != "fedora" ]] || [[ $distro_version < 32 ]]#; then
# echo "no es una distro fedora soportada"
# exit
#else
# echo "distro soportada"
#fi
user=$(whoami)
declare -A config # especificamos que config es un array
config=(
[ohmybashurl]='https://raw.github.com/ohmybash/oh-my-bash/master/tools/install.sh'
[flutterurl]='https://storage.googleapis.com/flutter_infra/releases/stable/linux/flutter_linux_v1.12.13+hotfix.5-stable.tar.xz'
[rpmqafile]='rpmqa.txt'
[composerbinpath]="export PATH=\$PATH:/home/$user/.config/composer/vendor/bin"
)
# solo ejecutamos rpm -qa 1 vez por que es lento lo mandamos a un archivo y luego solo hacemos grep a este
#if [ -f "${config[rpmqafile]}" ];then
# echo $sudo_pass | sudo -S rm "${config[rpmqafile]}"
#fi
#rpm -qa > "${config[rpmqafile]}"
# el swapiness activo en el sistema
val_swappines=$(cat /proc/sys/vm/swappiness)
# este archivo almacena el valor swapiness editado por el usuario
val_swap=$(grep "vm.swappines" /etc/sysctl.d/99-sysctl.conf )
host_name=$(uname -n)
val_graciasudo="basura :v"
# librerias que se deben instalar
#val_pythondevel=$(grep "python3-dev" ${config[rpmqafile]})
# aplicaciones/etc que se deben instalar
# TODO testear
val_oh_my_bash=$(ls ~/.oh-my-bash/)
val_python=$(python3 --version)
val_pip=$(pip3 -V)
val_git=$(git --version)
val_php=$(php --version)
val_composer=$(composer --version)
val_node=$(node --version)
val_npm=$(npm --version)
val_nala=$(nala --version)
val_snap=$(snap --version)
# aplicaciones/librerias de python
val_pip_tools=$(pip3 show pip-tools)
#val_spyder=$(pip3 show spyder) # necesitas instalar libqtxdg
# probando
val_docker=$(docker --version)
# pendiente
#sdks
# pendiente
val_flutter=$(flutter --version)
# auxiliar para mostrar tanto notificaciones push como logs
aviso() {
echo "$1"
}
# instalamos todo aquello necesario
if [[ ! $val_git ]]; then
echo $sudo_pass | sudo -S apt install git gitflow -y
aviso "Git se ha instalado" true
fi
if [[ ! $val_oh_my_bash ]]; then
echo $sudo_pass | sh -c "$(curl -fsSL ${config[ohmybashurl]})"
aviso "oh my bash is installed" true
fi
if [[ ! $val_pip || ! $val_python ]]; then
echo $sudo_pass | sudo -S apt install python3-pip -y
aviso "Python y/o PIP esta instalado" true
fi
if [[ ! $val_php ]]; then
# https://rpmfusion.org/Configuration
echo $sudo_pass | sudo apt -y install php-cli php-fpm php-mysql php-zip php-dev php-gd php-mbstring php-curl php-xml php-pear php-bcmath php-json
aviso "PHP is installed" true
fi
if [[ ! $val_composer ]]; then
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
echo $sudo_pass | sudo php composer-setup.php --install-dir=/bin --filename=composer
php -r "unlink('composer-setup.php');"
existe_path=$(grep "${config[composerbinpath]}" /etc/profile)
if [[ ! $existe_path ]]; then
echo $sudo_pass | sudo -S sed -i "\$a ${config[composerbinpath]}" /etc/profile
fi
source /etc/profile
aviso "Composer se ha instalado cierra y abre tu terminal para ver los cambios reflejados"
fi
if [[ ! $val_node || ! $val_npm ]]; then
# eacho $sudo_pass | sudo apt -y install nodejs npm
# use nvm intead
aviso "NodeJs/npm se ha instalado" true
fi
if [[ ! $val_docker ]];then
echo $sudo_pass | sudo apt-get install -y apt-transport-https ca-certificates curl gnupg-agent software-properties-common
echo $sudo_pass | sudo curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -
echo $sudo_pass | sudo add-apt-repository "deb [arch=arm64] https://download.docker.com/linux/debian $(lsb_release -cs) stable"
echo $sudo_pass | sudo apt update -y
echo $sudo_pass | sudo apt install -y docker-ce docker-ce-cli containerd.io docker-compose
echo $sudo_pass | sudo groupadd docker
echo $sudo_pass | sudo usermod -aG docker $user
fi
if [[ ! $val_flutter && $val_snap ]];then
# https://flutter.dev/docs/get-started/install/linux
# se debe instalar en /opt/flutter por convencion
# echo $sudo_pass | sudo -S
sudo snap install flutter --classic
aviso "Flutter se ha instalado para usarlo reinicia el equipo" true
fi
if [[ ! $val_snap ]];then
echo $sudo_pass | sudo apt install snap snapd
aviso "Flutter se ha instalado para usarlo reinicia el equipo" true
fi
# script main functions
update(){
if [[ ! $val_nala ]]; then
echo $sudo_pass | sudo apt update -y
echo $sudo_pass | sudo apt upgrade -y
echo $sudo_pass | sudo pip3 install --upgrade pip
else
echo $sudo_pass | sudo nala update
echo $sudo_pass | sudo nala upgrade -y
fi
}
if [[ $1 ]]; then
case $1 in
"update" )
update
;;
*)
echo "opcion invalida: $1"
esac
fi