Просмотр исходного кода

create task process 20.01.25:2.09

root месяцев назад: 2
Родитель
Сommit
984a49767c
2 измененных файлов с 51 добавлено и 31 удалено
  1. 2 3
      avto4certbot.dev/avto4certbot.conf
  2. 49 28
      avto4certbot.dev/avto4certbot.sh

+ 2 - 3
avto4certbot.dev/avto4certbot.conf

@@ -1,13 +1,12 @@
1 1
 ## config file
2 2
 ## domains - follow the format! domains email port...
3 3
 domains=( 
4
- "mydomen.ru admin@mydomen.ru 80"
5
- "mydomen2.ru admin@mydomen.ru 80"
4
+ "mydomains.ru admin@mydomains.ru 8080"
6 5
  );
7 6
 
8 7
 ## if update - restart this services
9 8
 services=(
10
-    "apache2"
9
+    "nginx"
11 10
  );
12 11
 
13 12
 ## - nginx sites

+ 49 - 28
avto4certbot.dev/avto4certbot.sh

@@ -1,4 +1,4 @@
1
-#!/bin/bash
1
+#!/bin/bash -x
2 2
 #
3 3
 # author: Koshuba V.O.
4 4
 # license: GPL 2.0
@@ -23,6 +23,9 @@ event_key="1";
23 23
 # message from errors
24 24
 reports=();
25 25
 
26
+# work_sites
27
+active_sites=();
28
+
26 29
 ##--@S static values
27 30
 # depends
28 31
 pkgdep=("curl" "certbot" "letsencrypt") # packages
@@ -122,36 +125,42 @@ function checkDep() {
122 125
 }
123 126
 
124 127
 function swSites(){
125
-## clear job link
128
+## clear active sites
126 129
 if [ "$event_key" = "1" ]; then
127
-  for ((xd=0; xd != ${#domains[@]}; xd++)); do
128
-    local site_data=( $(echo -e ${domains[$xd]}|sed 's/ /\n /g') );
129
-    site_name="${site_data[0]}";
130
-    if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]]; then
131
-      if [ -f $sites_apache/$site_name.conf ]; then
132
-        rm $sites_apache/$site_name.conf
130
+active_sites=( $(cat $tmp_dir/active_sites.inf) );
131
+  for ((xd=0; xd != ${#active_sites[@]}; xd++)); do
132
+    if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]] && [[ "$opt" != "" ]]; then
133
+      if [ -f $sites_apache/${active_sites[$xd]} ]; then
134
+        rm $sites_apache/${active_sites[$xd]}
133 135
       fi
134 136
     fi
135
-    if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]]; then
136
-      if [ -f $sites_nginx/$site_name.conf ]; then
137
-        rm $sites_nginx/$site_name.conf
137
+    if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]] && [[ "$opt" != "" ]]; then
138
+      if [ -f $sites_nginx/${active_sites[$xd]} ]; then
139
+        rm $sites_nginx/${active_sites[$xd]}
138 140
       fi
139 141
     fi
140 142
   done
141 143
 fi
142
-## restore job link
144
+## restore active sites
143 145
 if [ "$event_key" = "0" ]; then
144
-  for ((xd=0; xd != ${#domains[@]}; xd++)); do
145
-    local site_data=( $(echo -e ${domains[$xd]}|sed 's/ /\n /g') );
146
-    site_name="${site_data[0]}";
147
-    if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]]; then
148
-      if [ ! -f $sites_apache/$site_name.conf ]; then
149
-        ln -s $available_apache/$site_name.conf $sites_apache/$site_name.conf
146
+  # clear tmp configs
147
+  if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]] && [[ "$opt" != "" ]]; then
148
+    rm $available_apache/*.conf
149
+  fi
150
+  if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]] && [[ "$opt" != "" ]]; then
151
+    rm $available_nginx/*.conf
152
+  fi
153
+  # restore active links
154
+  active_sites=( $(cat $tmp_dir/active_sites.inf) );
155
+  for ((xd=0; xd != ${#active_sites[@]}; xd++)); do
156
+    if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]] && [[ "$opt" != "" ]]; then
157
+      if [ ! -f $sites_apache/${active_sites[$xd]} ]; then
158
+        ln -s $available_apache/${active_sites[$xd]} $sites_apache/${active_sites[$xd]}
150 159
       fi
151 160
     fi
152
-    if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]]; then
153
-      if [ ! -f $sites_nginx/$site_name.conf ]; then
154
-        ln -s $available_nginx/$site_name.conf $sites_apache/$site_name.conf
161
+    if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]] && [[ "$opt" != "" ]]; then
162
+      if [ ! -f $sites_nginx/${active_sites[$xd]} ]; then
163
+        ln -s $available_nginx/${active_sites[$xd]} $sites_apache/${active_sites[$xd]}
155 164
       fi
156 165
     fi
157 166
   done
@@ -228,7 +237,7 @@ for ((xd=0; xd != ${#domains[@]}; xd++)); do
228 237
   site_owner="${site_data[1]}";
229 238
   site_port="${site_data[2]}";
230 239
   ## apache2 config
231
-  if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]]; then
240
+  if [[ $opt != "nginx" ]] || [[ "$opt" == "apache" ]] && [[ "$opt" != "" ]] ; then
232 241
     echo >$conf_dir/$site_name.conf;
233 242
     echo -e '<VirtualHost *:'"$site_port"'>' >>$conf_dir/$site_name.conf;
234 243
     echo -e '  ServerName '"$site_name"'' >>$conf_dir/$site_name.conf;
@@ -251,7 +260,7 @@ for ((xd=0; xd != ${#domains[@]}; xd++)); do
251 260
   fi
252 261
 
253 262
   ## nginx config
254
-  if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]]; then
263
+  if [[ $opt != "apache" ]] || [[ "$opt" == "nginx" ]] && [[ "$opt" != "" ]]; then
255 264
     echo >$conf_dir/$site_name.conf;
256 265
     echo -e 'server { listen 0.0.0.0:'"$site_port"';' >>$conf_dir/$site_name.conf;
257 266
     echo -e '  server_name '"$site_name"';' >>$conf_dir/$site_name.conf;
@@ -293,6 +302,7 @@ echo "  avtocertbot.sh --update nginx"
293 302
 case "$cmd" in
294 303
   ## create cert
295 304
   "--create" | "--create" )
305
+if [ "$opt" != "" ]; then
296 306
     getInfo;
297 307
     checkDep;
298 308
     event_key="1";
@@ -300,16 +310,20 @@ case "$cmd" in
300 310
     swSites;
301 311
     createConf;
302 312
     systemctl start $service;
303
-    createCert;
304
-    scanSSL;
313
+    #createCert;
314
+    #scanSSL;
305 315
     event_key="0";
306 316
     systemctl stop $service;
307 317
     swSites;
308 318
     systemctl start $service;
319
+else
320
+    pHelp;
321
+fi
309 322
   ;;
310 323
 
311
-  ## create cert
324
+  ## update cert
312 325
   "--update" | "--update" )
326
+if [ "$opt" != "" ]; then
313 327
    getInfo;
314 328
    checkDep;
315 329
    event_key="1";
@@ -317,19 +331,26 @@ case "$cmd" in
317 331
    swSites;
318 332
    createConf;
319 333
    systemctl start $service;
320
-   certbot -n renew;
321
-   scanSSL;
334
+   #certbot -n renew;
335
+   #scanSSL;
322 336
    event_key="0";
323 337
    systemctl stop $service;
324 338
    swSites;
325 339
    systemctl start $service;
340
+else
341
+    pHelp;
342
+fi
326 343
   ;;
327 344
 
328 345
   ## create cert
329 346
   "--flist" | "--flist" )
347
+if [ "$opt" != "" ]; then
330 348
     getInfo;
331 349
     checkDep;
332 350
     scanSSL;
351
+else
352
+    pHelp;
353
+fi
333 354
   ;;
334 355
 
335 356
   ## start defaults