freedombone-template 30KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # Command to create app templates
  12. #
  13. # License
  14. # =======
  15. #
  16. # Copyright (C) 2018 Bob Mottram <bob@freedombone.net>
  17. #
  18. # This program is free software: you can redistribute it and/or modify
  19. # it under the terms of the GNU Affero General Public License as published by
  20. # the Free Software Foundation, either version 3 of the License, or
  21. # (at your option) any later version.
  22. #
  23. # This program is distributed in the hope that it will be useful,
  24. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  25. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  26. # GNU Affero General Public License for more details.
  27. #
  28. # You should have received a copy of the GNU Affero General Public License
  29. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  30. PROJECT_NAME='freedombone'
  31. app_name='noapp'
  32. app_name_lower=$(echo ${app_name} | tr '[:upper:]' '[:lower:]')
  33. app_name=$app_name_lower
  34. app_name_upper=$(echo ${app_name} | tr '[:lower:]' '[:upper:]')
  35. echo "test: $app_name_upper"
  36. app_repo="TODO"
  37. app_repo_commit='TODO'
  38. app_php=
  39. app_node=
  40. app_onion_only=
  41. app_port=
  42. app_port_internal=
  43. app_daemon=
  44. app_dir=
  45. your_name=''
  46. your_email=''
  47. SHOW_ON_ABOUT=1
  48. database_type=''
  49. function show_help {
  50. echo ''
  51. echo $"${PROJECT_NAME}-template --app [myappname] --php yes -n \"My Name\" -e \"myname@mydomain\" > src/${PROJECT_NAME}-app-myappname"
  52. echo ''
  53. echo $'Creates a new app script which can then be filled in'
  54. echo ''
  55. echo ''
  56. echo $' -h --help Show help'
  57. echo $' -a --app [name] Name of the application'
  58. echo $' -n --name [name] Your name'
  59. echo $' -e --email [address] Your email address'
  60. echo $' -r --repo [url] Git repo url for the app'
  61. echo $' -c --commit [hash] Git commit'
  62. echo $' --port [number] Port number for the app'
  63. echo $' --portinternal [number] Internal port between a daemon and the web server'
  64. echo $' --node [yes|no] Is this a nodejs app?'
  65. echo $' -o --onion [yes|no] Is this app only available on an onion address?'
  66. echo $' -p --php [yes|no] Is this a PHP app?'
  67. echo $' -s --daemon [yes|no] Add a daemon'
  68. echo $' -d --database [mariadb|postgresql] Type of database'
  69. echo $' --dir [directory] Where to install to'
  70. echo ''
  71. exit 0
  72. }
  73. while [ $# -gt 1 ]
  74. do
  75. key="$1"
  76. case $key in
  77. -h|--help)
  78. show_help
  79. ;;
  80. -a|--app|--appname)
  81. shift
  82. app_name="$1"
  83. app_name_lower=$(echo ${app_name} | tr '[:upper:]' '[:lower:]')
  84. app_name=$app_name_lower
  85. app_name_upper=$(echo ${app_name} | tr '[:lower:]' '[:upper:]')
  86. ;;
  87. -r|--repo)
  88. shift
  89. app_repo="$1"
  90. ;;
  91. -c|--commit)
  92. shift
  93. app_repo_commit="$1"
  94. ;;
  95. -n|--name)
  96. shift
  97. your_name="$1"
  98. ;;
  99. -e|--email)
  100. shift
  101. your_email="$1"
  102. ;;
  103. -d|--database)
  104. shift
  105. database_type="$1"
  106. ;;
  107. -p|--php)
  108. shift
  109. app_php="$1"
  110. ;;
  111. --node|--nodejs)
  112. shift
  113. app_node="$1"
  114. ;;
  115. -s|--daemon|--systemd)
  116. shift
  117. if [[ "$1" == 'yes' ]]; then
  118. app_daemon=1
  119. fi
  120. ;;
  121. -o|--onion)
  122. shift
  123. if [[ "$1" == 'yes' ]]; then
  124. app_onion_only=1
  125. fi
  126. ;;
  127. --port)
  128. shift
  129. app_port="$1"
  130. ;;
  131. --portinternal|--portint)
  132. shift
  133. app_port_internal="$1"
  134. ;;
  135. --dir)
  136. shift
  137. app_dir="$1"
  138. ;;
  139. *)
  140. # unknown option
  141. ;;
  142. esac
  143. shift
  144. done
  145. if [[ "$app_name" == 'noapp' ]]; then
  146. show_help
  147. exit 1
  148. fi
  149. if [[ "$app_name" == *' '* ]]; then
  150. echo $'app name should not contain any spaces'
  151. exit 2
  152. fi
  153. if [[ "$app_name" == *'_'* ]]; then
  154. echo $'app name should not contain any underscore characters'
  155. exit 3
  156. fi
  157. if [[ "$app_name" == *'-'* ]]; then
  158. echo $'app name should not contain any hyphen characters'
  159. exit 4
  160. fi
  161. if [ ${#app_name} -lt 3 ]; then
  162. echo $'app name should be at least three characters'
  163. exit 5
  164. fi
  165. if [ ${#your_name} -lt 2 ]; then
  166. echo $'Specify your name with --name'
  167. exit 6
  168. fi
  169. if [ ${#your_email} -lt 3 ]; then
  170. echo $'Specify your email address with --email'
  171. exit 7
  172. fi
  173. if [[ "$your_email" != *'@'* ]]; then
  174. echo $"That doesn't look like an email address"
  175. exit 8
  176. fi
  177. echo '#!/bin/bash'
  178. echo '#'
  179. echo '# .---. . .'
  180. echo '# | | |'
  181. echo '# |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.'
  182. echo "# | | (.-' (.-' ( | ( )| | | | )( )| | (.-'"
  183. echo "# ' ' --' --' -' - -' ' ' -' -' -' ' - --'"
  184. echo '#'
  185. echo '# Freedom in the Cloud'
  186. echo '#'
  187. echo '# License'
  188. echo '# ======='
  189. echo '#'
  190. echo "# Copyright (C) $(date +%Y) ${your_name} <${your_email}>"
  191. echo '#'
  192. echo '# This program is free software: you can redistribute it and/or modify'
  193. echo '# it under the terms of the GNU Affero General Public License as published by'
  194. echo '# the Free Software Foundation, either version 3 of the License, or'
  195. echo '# (at your option) any later version.'
  196. echo '#'
  197. echo '# This program is distributed in the hope that it will be useful,'
  198. echo '# but WITHOUT ANY WARRANTY; without even the implied warranty of'
  199. echo '# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the'
  200. echo '# GNU Affero General Public License for more details.'
  201. echo '#'
  202. echo '# You should have received a copy of the GNU Affero General Public License'
  203. echo '# along with this program. If not, see <http://www.gnu.org/licenses/>.'
  204. echo ''
  205. echo "VARIANTS='full full-vim'"
  206. echo ''
  207. echo 'IN_DEFAULT_INSTALL=0'
  208. echo "SHOW_ON_ABOUT=${SHOW_ON_ABOUT}"
  209. if [ $app_onion_only ]; then
  210. echo 'SHOW_ICANN_ADDRESS_ON_ABOUT=0'
  211. fi
  212. echo ''
  213. echo "${app_name_upper}_DOMAIN_NAME="
  214. echo "${app_name_upper}_CODE="
  215. if [ $app_port ]; then
  216. echo "${app_name_upper}_PORT=$app_port"
  217. fi
  218. echo "${app_name_upper}_ONION_PORT=$(( ( RANDOM % 1000 ) + 9010 ))"
  219. echo "${app_name_upper}_REPO=\"${app_repo}\""
  220. echo "${app_name_upper}_COMMIT='${app_repo_commit}'"
  221. if [ $app_daemon ]; then
  222. if [ ! $app_port_internal ]; then
  223. echo "${app_name_upper}_PORT_INTERNAL=TODO"
  224. else
  225. echo "${app_name_upper}_PORT_INTERNAL=$app_port_internal"
  226. fi
  227. fi
  228. echo ''
  229. echo "${app_name}=(ONION_ONLY"
  230. echo " ${app_name_upper}_DOMAIN_NAME"
  231. echo " ${app_name_upper}_CODE"
  232. echo ' DDNS_PROVIDER'
  233. echo " MY_USERNAME)"
  234. echo ''
  235. echo "function logging_on_${app_name} {"
  236. echo " echo -n ''"
  237. echo "}"
  238. echo ''
  239. echo "function logging_off_${app_name} {"
  240. echo " echo -n ''"
  241. echo '}'
  242. echo ''
  243. echo "function remove_user_${app_name} {"
  244. echo ' remove_username="$1"'
  245. echo ''
  246. echo " \${PROJECT_NAME}-pass -u \$remove_username --rmapp ${app_name}"
  247. echo '}'
  248. echo ''
  249. echo "function add_user_${app_name} {"
  250. echo ' new_username="$1"'
  251. echo ' new_user_password="$2"'
  252. echo ''
  253. echo " \${PROJECT_NAME}-pass -u \$new_username -a ${app_name} -p \"\$new_user_password\""
  254. echo " echo '0'"
  255. echo '}'
  256. echo ''
  257. echo "function install_interactive_${app_name} {"
  258. if [ ! $app_onion_only ]; then
  259. echo ' if [ ! $ONION_ONLY ]; then'
  260. echo " ONION_ONLY='no'"
  261. echo ' fi'
  262. echo ''
  263. echo ' if [[ $ONION_ONLY != "no" ]]; then'
  264. echo " ${app_name_upper}_DOMAIN_NAME='${app_name}.local'"
  265. echo " write_config_param \"${app_name_upper}_DOMAIN_NAME\" \"\$${app_name_upper}_DOMAIN_NAME\""
  266. echo ' else'
  267. echo " interactive_site_details \"${app_name}\" \"${app_name_upper}_DOMAIN_NAME\" \"${app_name}_CODE\""
  268. echo ' fi'
  269. else
  270. echo " echo -n ''"
  271. fi
  272. echo ' APP_INSTALLED=1'
  273. echo '}'
  274. echo ''
  275. echo "function change_password_${app_name} {"
  276. echo ' curr_username="$1"'
  277. echo ' new_user_password="$2"'
  278. echo ''
  279. echo " read_config_param '${app_name_upper}_DOMAIN_NAME'"
  280. echo ''
  281. echo " \${PROJECT_NAME}-pass -u \"\$curr_username\" -a ${app_name} -p \"\$new_user_password\""
  282. echo '}'
  283. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" || "$database_type" == "postgres"* ]]; then
  284. echo ''
  285. echo "function ${app_name}_create_database {"
  286. echo ' if [ -f $IMAGE_PASSWORD_FILE ]; then'
  287. echo " ${app_name_upper}_ADMIN_PASSWORD=\"\$(printf `cat $IMAGE_PASSWORD_FILE`)\""
  288. echo ' else'
  289. echo " if [ ! \$${app_name_upper}_ADMIN_PASSWORD ]; then"
  290. echo " ${app_name_upper}_ADMIN_PASSWORD=\"\$(create_password \${MINIMUM_PASSWORD_LENGTH})\""
  291. echo ' fi'
  292. echo ' fi'
  293. echo " if [ ! \$${app_name_upper}_ADMIN_PASSWORD ]; then"
  294. echo ' return'
  295. echo ' fi'
  296. echo ''
  297. if [[ "$database_type" != "postgres"* ]]; then
  298. echo " create_database ${app_name} \"\$${app_name_upper}_ADMIN_PASSWORD\" \$MY_USERNAME"
  299. else
  300. echo ' systemctl restart postgresql'
  301. echo " run_system_query_postgresql \"CREATE USER peertube WITH PASSWORD '\$${app_name_upper}_ADMIN_PASSWORD';\""
  302. echo " run_system_query_postgresql \"CREATE DATABASE ${app_name} OWNER ${app_name};\""
  303. echo " run_system_query_postgresql \"GRANT ALL PRIVILEGES ON DATABASE ${app_name} to ${app_name};\""
  304. echo " run_system_query_postgresql \"set statement_timeout to 40000;\""
  305. fi
  306. echo '}'
  307. fi
  308. echo ''
  309. echo "function reconfigure_${app_name} {"
  310. echo ' # This is used if you need to switch identity. Dump old keys and generate new ones'
  311. echo " echo -n ''"
  312. echo '}'
  313. echo ''
  314. echo "function configure_interactive_${app_name} {"
  315. echo ' while true'
  316. echo ' do'
  317. echo ' data=$(tempfile 2>/dev/null)'
  318. echo ' trap "rm -f $data" 0 1 2 5 15'
  319. echo " dialog --backtitle \$\"Freedombone Control Panel\" \\"
  320. echo " --title \$\"${app_name}\" \\"
  321. echo " --radiolist \$\"Choose an operation:\" 16 70 3 \\"
  322. echo ' 1 $"Option 1" off \'
  323. echo ' 2 $"Option 2" off \'
  324. echo ' 3 $"Exit" on 2> $data'
  325. echo ' sel=$?'
  326. echo ' case $sel in'
  327. echo ' 1) return;;'
  328. echo ' 255) return;;'
  329. echo ' esac'
  330. echo ' case $(cat $data) in'
  331. echo ' 1) # call some function for option 1'
  332. echo ' ;;'
  333. echo ' 2) # call some function for option 2'
  334. echo ' ;;'
  335. echo ' 3) break;;'
  336. echo ' esac'
  337. echo ' done'
  338. echo '}'
  339. echo ''
  340. echo "function upgrade_${app_name} {"
  341. echo " CURR_${app_name_upper}_COMMIT=\$(get_completion_param \"${app_name} commit\")"
  342. echo " if [[ \"\$CURR_${app_name_upper}_COMMIT\" == \"\$${app_name_upper}_COMMIT\" ]]; then"
  343. echo ' return'
  344. echo ' fi'
  345. echo ''
  346. echo " if grep -q \"${app_name} domain\" \$COMPLETION_FILE; then"
  347. echo " ${app_name_upper}_DOMAIN_NAME=\$(get_completion_param \"${app_name} domain\")"
  348. echo ' fi'
  349. echo ''
  350. echo ' # update to the next commit'
  351. if [ ! $app_dir ]; then
  352. echo " set_repo_commit /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs \"${app_name} commit\" \"\$${app_name_upper}_COMMIT\" \$${app_name_upper}_REPO"
  353. echo " chown -R www-data:www-data /var/www/\${${app_name_upper}_DOMAIN_NAME}/htdocs"
  354. else
  355. echo " set_repo_commit ${app_dir} \"${app_name} commit\" \"\$${app_name_upper}_COMMIT\" \$${app_name_upper}_REPO"
  356. echo " chown -R ${app_name}:${app_name} ${app_dir}"
  357. fi
  358. echo '}'
  359. echo ''
  360. echo "function backup_local_${app_name} {"
  361. echo " ${app_name_upper}_DOMAIN_NAME='${app_name}'"
  362. echo " if grep -q \"${app_name} domain\" \$COMPLETION_FILE; then"
  363. echo " ${app_name_upper}_DOMAIN_NAME=\$(get_completion_param \"${app_name} domain\")"
  364. echo ' fi'
  365. echo ''
  366. if [ ! $app_dir ]; then
  367. echo " source_directory=/var/www/\${${app_name_upper}_DOMAIN_NAME}/htdocs"
  368. else
  369. echo " source_directory=${app_dir}"
  370. fi
  371. echo ''
  372. echo " suspend_site \${${app_name_upper}_DOMAIN_NAME}"
  373. echo ''
  374. echo " dest_directory=${app_name}"
  375. echo ' backup_directory_to_usb $source_directory $dest_directory'
  376. echo ''
  377. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  378. echo " backup_database_to_usb ${app_name}"
  379. echo ''
  380. fi
  381. if [[ "$database_type" == "postgres"* ]]; then
  382. echo ' USE_POSTGRESQL=1'
  383. echo " backup_database_to_usb ${app_name}"
  384. echo ''
  385. fi
  386. echo ' restart_site'
  387. echo '}'
  388. echo ''
  389. echo "function restore_local_${app_name} {"
  390. echo " if ! grep -q \"${app_name} domain\" \$COMPLETION_FILE; then"
  391. echo ' return'
  392. echo ' fi'
  393. echo " ${app_name_upper}_DOMAIN_NAME=\$(get_completion_param \"${app_name} domain\")"
  394. echo " if [ \$${app_name_upper}_DOMAIN_NAME ]; then"
  395. echo " temp_restore_dir=/root/temp${app_name}"
  396. if [ ! $app_dir ]; then
  397. echo " ${app_name}_dir=/var/www/\${${app_name_upper}_DOMAIN_NAME}/htdocs"
  398. else
  399. echo " ${app_name}_dir=${app_dir}"
  400. fi
  401. echo ''
  402. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  403. echo " ${app_name}_create_database"
  404. echo ''
  405. echo " restore_database ${app_name}"
  406. echo ' if [ -d $temp_restore_dir ]; then'
  407. echo ' rm -rf $temp_restore_dir'
  408. echo ' fi'
  409. echo ''
  410. fi
  411. if [[ "$database_type" == "postgres"* ]]; then
  412. echo " ${app_name}_create_database"
  413. echo ''
  414. echo ' USE_POSTGRESQL=1'
  415. echo " restore_database ${app_name}"
  416. echo ' if [ -d $temp_restore_dir ]; then'
  417. echo ' rm -rf $temp_restore_dir'
  418. echo ' fi'
  419. echo ''
  420. fi
  421. echo " restore_directory_from_usb \$temp_restore_dir ${app_name}"
  422. echo ' if [ -d $temp_restore_dir ]; then'
  423. echo " if [ -d cp \$temp_restore_dir\$${app_name}_dir ]; then"
  424. echo " cp -rp \$temp_restore_dir\$${app_name}_dir/* \$${app_name}_dir/"
  425. echo ' else'
  426. echo " if [ ! -d \$${app_name}_dir ]; then"
  427. echo " mkdir \$${app_name}_dir"
  428. echo ' fi'
  429. echo " cp -rp \$temp_restore_dir/* \$${app_name}_dir/"
  430. echo ' fi'
  431. echo " chown -R www-data:www-data \$${app_name}_dir"
  432. echo ' rm -rf $temp_restore_dir'
  433. echo ' fi'
  434. echo ''
  435. echo ' fi'
  436. echo '}'
  437. echo ''
  438. echo "function backup_remote_${app_name} {"
  439. echo " ${app_name_upper}_DOMAIN_NAME='${app_name}'"
  440. echo " if grep -q \"${app_name} domain\" \$COMPLETION_FILE; then"
  441. echo " ${app_name_upper}_DOMAIN_NAME=\$(get_completion_param \"${app_name} domain\")"
  442. echo ' fi'
  443. echo ''
  444. if [ ! $app_dir ]; then
  445. echo " source_directory=/var/www/\${${app_name_upper}_DOMAIN_NAME}/htdocs"
  446. else
  447. echo " source_directory=${app_dir}"
  448. fi
  449. echo ''
  450. echo " suspend_site \${${app_name_upper}_DOMAIN_NAME}"
  451. echo ''
  452. echo " dest_directory=${app_name}"
  453. echo ' backup_directory_to_friend $source_directory $dest_directory'
  454. echo ''
  455. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  456. echo " backup_database_to_friend ${app_name}"
  457. fi
  458. if [[ "$database_type" == "postgres"* ]]; then
  459. echo ' USE_POSTGRESQL=1'
  460. echo " backup_database_to_friend ${app_name}"
  461. echo ''
  462. fi
  463. echo ''
  464. echo ' restart_site'
  465. echo '}'
  466. echo ''
  467. echo "function restore_remote_${app_name} {"
  468. echo " if ! grep -q \"${app_name} domain\" \$COMPLETION_FILE; then"
  469. echo ' return'
  470. echo ' fi'
  471. echo " ${app_name_upper}_DOMAIN_NAME=\$(get_completion_param \"${app_name} domain\")"
  472. echo " if [ \$${app_name_upper}_DOMAIN_NAME ]; then"
  473. echo " temp_restore_dir=/root/temp${app_name}"
  474. if [ ! $app_dir ]; then
  475. echo " ${app_name}_dir=/var/www/\${${app_name_upper}_DOMAIN_NAME}/htdocs"
  476. else
  477. echo " ${app_name}_dir=${app_dir}"
  478. fi
  479. echo ''
  480. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  481. echo " ${app_name}_create_database"
  482. echo ''
  483. echo " restore_database_from_friend ${app_name}"
  484. echo ' if [ -d $temp_restore_dir ]; then'
  485. echo ' rm -rf $temp_restore_dir'
  486. echo ' fi'
  487. echo ''
  488. fi
  489. if [[ "$database_type" == "postgres"* ]]; then
  490. echo " ${app_name}_create_database"
  491. echo ''
  492. echo ' USE_POSTGRESQL=1'
  493. echo " restore_database_from_friend ${app_name}"
  494. echo ' if [ -d $temp_restore_dir ]; then'
  495. echo ' rm -rf $temp_restore_dir'
  496. echo ' fi'
  497. echo ''
  498. fi
  499. echo " restore_directory_from_friend \$temp_restore_dir ${app_name}"
  500. echo ' if [ -d $temp_restore_dir ]; then'
  501. echo " if [ -d cp \$temp_restore_dir\$${app_name}_dir ]; then"
  502. echo " cp -rp \$temp_restore_dir\$${app_name}_dir/* \$${app_name}_dir/"
  503. echo ' else'
  504. echo " if [ ! -d \$${app_name}_dir ]; then"
  505. echo " mkdir \$${app_name}_dir"
  506. echo ' fi'
  507. echo " cp -rp \$temp_restore_dir/* \$${app_name}_dir/"
  508. echo ' fi'
  509. echo " chown -R www-data:www-data \$${app_name}_dir"
  510. echo ' rm -rf $temp_restore_dir'
  511. echo ' fi'
  512. echo ''
  513. echo ' fi'
  514. echo '}'
  515. echo ''
  516. echo "function remove_${app_name} {"
  517. if [[ "$app_node" == 'yes' ]]; then
  518. echo " remove_nodejs ${app_name}"
  519. echo ''
  520. fi
  521. echo " nginx_dissite \$${app_name_upper}_DOMAIN_NAME"
  522. echo " remove_certs \$${app_name_upper}_DOMAIN_NAME"
  523. echo ''
  524. if [ $app_daemon ]; then
  525. echo " if [ -f /etc/systemd/system/${app_name}.service ]; then"
  526. echo " systemctl stop ${app_name}"
  527. echo " systemctl disable ${app_name}"
  528. echo " rm /etc/systemd/system/${app_name}.service"
  529. echo ' fi'
  530. echo " userdel -r ${app_name}"
  531. fi
  532. echo ''
  533. echo " if [ -d /var/www/\$${app_name_upper}_DOMAIN_NAME ]; then"
  534. echo " rm -rf /var/www/\$${app_name_upper}_DOMAIN_NAME"
  535. echo ' fi'
  536. echo " if [ -f /etc/nginx/sites-available/\$${app_name_upper}_DOMAIN_NAME ]; then"
  537. echo " rm /etc/nginx/sites-available/\$${app_name_upper}_DOMAIN_NAME"
  538. echo ' fi'
  539. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  540. echo " drop_database ${app_name}"
  541. fi
  542. if [[ "$database_type" == "postgres"* ]]; then
  543. echo " drop_database_postgresql ${app_name}"
  544. fi
  545. echo " remove_onion_service ${app_name} \${${app_name_upper}_ONION_PORT}"
  546. echo " if grep -q \"${app_name}\" /etc/crontab; then"
  547. echo " sed -i \"/${app_name}/d\" /etc/crontab"
  548. echo ' fi'
  549. echo " remove_app ${app_name}"
  550. echo " remove_completion_param install_${app_name}"
  551. echo " sed -i '/${app_name}/d' \$COMPLETION_FILE"
  552. if [ $app_port ]; then
  553. echo ''
  554. echo " firewall_remove ${app_port} tcp"
  555. fi
  556. echo ''
  557. echo " remove_ddns_domain \$${app_name_upper}_DOMAIN_NAME"
  558. echo '}'
  559. echo ''
  560. echo "function install_${app_name} {"
  561. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  562. echo ' install_mariadb'
  563. echo ''
  564. echo ' get_mariadb_password'
  565. echo ''
  566. fi
  567. if [[ "$database_type" == "postgres"* ]]; then
  568. echo ' install_postgresql'
  569. echo ''
  570. fi
  571. if [[ "$app_node" == 'yes' ]]; then
  572. echo "install_nodejs ${app_name}"
  573. fi
  574. if [[ "$app_php" == 'yes' ]]; then
  575. echo ' apt-get -yq install php-gettext php-curl php-gd php-mysql git curl'
  576. echo ' apt-get -yq install memcached php-memcached php-intl exiftool libfcgi0ldbl'
  577. echo ''
  578. fi
  579. echo " if [ ! -d /var/www/\$${app_name_upper}_DOMAIN_NAME ]; then"
  580. echo " mkdir /var/www/\$${app_name_upper}_DOMAIN_NAME"
  581. echo ' fi'
  582. echo " if [ ! -d /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs ]; then"
  583. echo " if [ -d /repos/${app_name} ]; then"
  584. echo " mkdir /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  585. if [ ! $app_dir ]; then
  586. echo " cp -r -p /repos/${app_name}/. /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  587. echo " cd /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  588. else
  589. echo " cp -r -p /repos/${app_name}/. ${app_dir}"
  590. echo " cd ${app_dir}"
  591. fi
  592. echo ' git pull'
  593. echo ' else'
  594. if [ ! $app_dir ]; then
  595. echo " git_clone \$${app_name_upper}_REPO /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  596. else
  597. echo " git_clone \$${app_name_upper}_REPO ${app_dir}"
  598. fi
  599. echo ' fi'
  600. echo ''
  601. if [ ! $app_dir ]; then
  602. echo " if [ ! -d /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs ]; then"
  603. else
  604. echo " if [ ! -d ${app_dir} ]; then"
  605. fi
  606. echo " echo \$'Unable to clone ${app_name} repo'"
  607. echo ' exit 87525'
  608. echo ' fi'
  609. echo ' fi'
  610. echo ''
  611. if [ ! $app_dir ]; then
  612. echo " cd /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  613. else
  614. echo " cd ${app_dir}"
  615. fi
  616. echo " git checkout \$${app_name_upper}_COMMIT -b \$${app_name_upper}_COMMIT"
  617. echo " set_completion_param \"${app_name} commit\" \"\$${app_name_upper}_COMMIT\""
  618. echo ''
  619. echo " chmod g+w /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  620. echo " chown -R www-data:www-data /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs"
  621. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" || "$database_type" == "postgres"* ]]; then
  622. echo ''
  623. echo " ${app_name}_create_database"
  624. fi
  625. echo ''
  626. echo " add_ddns_domain \$${app_name_upper}_DOMAIN_NAME"
  627. echo ''
  628. echo " ${app_name_upper}_ONION_HOSTNAME=\$(add_onion_service ${app_name} 80 \${${app_name_upper}_ONION_PORT})"
  629. echo ''
  630. echo " ${app_name}_nginx_site=/etc/nginx/sites-available/\$${app_name_upper}_DOMAIN_NAME"
  631. if [ $app_onion_only ]; then
  632. echo ' if [[ $ONION_ONLY == "no" ]]; then'
  633. if [[ "$app_php" == 'yes' ]]; then
  634. echo " nginx_http_redirect \$${app_name_upper}_DOMAIN_NAME \"index index.php\""
  635. else
  636. echo " nginx_http_redirect \$${app_name_upper}_DOMAIN_NAME \"index index.html\""
  637. fi
  638. echo " echo 'server {' >> \$${app_name}_nginx_site"
  639. echo " echo ' listen 443 ssl;' >> \$${app_name}_nginx_site"
  640. echo " echo ' #listen [::]:443 ssl;' >> \$${app_name}_nginx_site"
  641. echo " echo \" server_name \$${app_name_upper}_DOMAIN_NAME;\" >> \$${app_name}_nginx_site"
  642. echo " echo '' >> \$${app_name}_nginx_site"
  643. echo " nginx_compress \$${app_name_upper}_DOMAIN_NAME"
  644. echo " echo '' >> \$${app_name}_nginx_site"
  645. echo " echo ' # Security' >> \$${app_name}_nginx_site"
  646. echo " nginx_ssl \$${app_name_upper}_DOMAIN_NAME"
  647. echo ''
  648. echo " nginx_disable_sniffing \$${app_name_upper}_DOMAIN_NAME"
  649. echo ''
  650. echo " echo ' add_header Strict-Transport-Security max-age=15768000;' >> \$${app_name}_nginx_site"
  651. echo " echo '' >> \$${app_name}_nginx_site"
  652. echo " echo ' # Logs' >> \$${app_name}_nginx_site"
  653. echo " echo ' access_log /dev/null;' >> \$${app_name}_nginx_site"
  654. echo " echo ' error_log /dev/null;' >> \$${app_name}_nginx_site"
  655. echo " echo '' >> \$${app_name}_nginx_site"
  656. echo " echo ' # Root' >> \$${app_name}_nginx_site"
  657. echo " echo \" root /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs;\" >> \$${app_name}_nginx_site"
  658. echo " echo '' >> \$${app_name}_nginx_site"
  659. if [[ "$app_php" == 'yes' ]]; then
  660. echo " echo ' index index.php;' >> \$${app_name}_nginx_site"
  661. echo " echo ' location ~ \.php {' >> \$${app_name}_nginx_site"
  662. echo " echo ' include snippets/fastcgi-php.conf;' >> \$${app_name}_nginx_site"
  663. echo " echo ' fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;' >> \$${app_name}_nginx_site"
  664. echo " echo ' fastcgi_read_timeout 30;' >> \$${app_name}_nginx_site"
  665. echo " echo ' }' >> \$${app_name}_nginx_site"
  666. echo " echo '' >> \$${app_name}_nginx_site"
  667. else
  668. echo " echo ' index index.html;' >> \$${app_name}_nginx_site"
  669. fi
  670. echo " echo ' # Location' >> \$${app_name}_nginx_site"
  671. echo " echo ' location / {' >> \$${app_name}_nginx_site"
  672. echo " nginx_limits \$${app_name_upper}_DOMAIN_NAME '15m'"
  673. if [ ! $app_daemon ]; then
  674. echo " echo ' try_files \$uri \$uri/ /index.html;' >> \$${app_name}_nginx_site"
  675. else
  676. echo " echo \" proxy_pass http://localhost:\$${app_name_upper}_PORT_INTERNAL;\" >> \$${app_name}_nginx_site"
  677. fi
  678. echo " echo ' }' >> \$${app_name}_nginx_site"
  679. echo " echo '}' >> \$${app_name}_nginx_site"
  680. echo ' else'
  681. echo " echo -n '' > \$${app_name}_nginx_site"
  682. echo ' fi'
  683. else
  684. echo " echo -n '' > \$${app_name}_nginx_site"
  685. fi
  686. echo " echo 'server {' >> \$${app_name}_nginx_site"
  687. echo " echo \" listen 127.0.0.1:\$${app_name_upper}_ONION_PORT default_server;\" >> \$${app_name}_nginx_site"
  688. echo " echo \" server_name \$${app_name_upper}_ONION_HOSTNAME;\" >> \$${app_name}_nginx_site"
  689. echo " echo '' >> \$${app_name}_nginx_site"
  690. echo " nginx_compress \$${app_name_upper}_DOMAIN_NAME"
  691. echo " echo '' >> \$${app_name}_nginx_site"
  692. echo " nginx_disable_sniffing \$${app_name_upper}_DOMAIN_NAME"
  693. echo " echo '' >> \$${app_name}_nginx_site"
  694. echo " echo ' # Logs' >> \$${app_name}_nginx_site"
  695. echo " echo ' access_log /dev/null;' >> \$${app_name}_nginx_site"
  696. echo " echo ' error_log /dev/null;' >> \$${app_name}_nginx_site"
  697. echo " echo '' >> \$${app_name}_nginx_site"
  698. echo " echo ' # Root' >> \$${app_name}_nginx_site"
  699. echo " echo \" root /var/www/\$${app_name_upper}_DOMAIN_NAME/htdocs;\" >> \$${app_name}_nginx_site"
  700. echo " echo '' >> \$${app_name}_nginx_site"
  701. if [[ "$app_php" == 'yes' ]]; then
  702. echo " echo ' index index.php;' >> \$${app_name}_nginx_site"
  703. echo " echo ' location ~ \.php {' >> \$${app_name}_nginx_site"
  704. echo " echo ' include snippets/fastcgi-php.conf;' >> \$${app_name}_nginx_site"
  705. echo " echo ' fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;' >> \$${app_name}_nginx_site"
  706. echo " echo ' fastcgi_read_timeout 30;' >> \$${app_name}_nginx_site"
  707. echo " echo ' }' >> \$${app_name}_nginx_site"
  708. echo " echo '' >> \$${app_name}_nginx_site"
  709. else
  710. echo " echo ' index index.html;' >> \$${app_name}_nginx_site"
  711. fi
  712. echo " echo ' # Location' >> \$${app_name}_nginx_site"
  713. echo " echo ' location / {' >> \$${app_name}_nginx_site"
  714. echo " nginx_limits \$${app_name_upper}_DOMAIN_NAME '15m'"
  715. if [ ! $app_daemon ]; then
  716. echo " echo ' try_files \$uri \$uri/ index.html;' >> \$${app_name}_nginx_site"
  717. else
  718. echo " echo \" proxy_pass http://localhost:\$${app_name_upper}_PORT_INTERNAL;\" >> \$${app_name}_nginx_site"
  719. fi
  720. echo " echo ' }' >> \$${app_name}_nginx_site"
  721. echo " echo '}' >> \$${app_name}_nginx_site"
  722. if [[ "$app_php" == 'yes' ]]; then
  723. echo ''
  724. echo ' configure_php'
  725. fi
  726. if [ $app_daemon ]; then
  727. echo ''
  728. echo " useradd -d TODO_PATH_TO_INSTALL -s /bin/false ${app_name}"
  729. echo ''
  730. echo " echo '[Unit]' > /etc/systemd/system/${app_name}.service"
  731. echo " echo 'Description=${app_name}' >> /etc/systemd/system/${app_name}.service"
  732. echo " echo 'After=syslog.target' >> /etc/systemd/system/${app_name}.service"
  733. echo " echo 'After=network.target' >> /etc/systemd/system/${app_name}.service"
  734. echo " echo '' >> /etc/systemd/system/${app_name}.service"
  735. echo " echo '[Service]' >> /etc/systemd/system/${app_name}.service"
  736. echo " echo 'Type=simple' >> /etc/systemd/system/${app_name}.service"
  737. echo " echo 'User=${app_name}' >> /etc/systemd/system/${app_name}.service"
  738. echo " echo 'Group=${app_name}' >> /etc/systemd/system/${app_name}.service"
  739. if [ ! $app_dir ]; then
  740. echo " echo 'WorkingDirectory=TODO' >> /etc/systemd/system/${app_name}.service"
  741. else
  742. echo " echo 'WorkingDirectory=${app_dir}' >> /etc/systemd/system/${app_name}.service"
  743. fi
  744. echo " echo 'ExecStart=TODO' >> /etc/systemd/system/${app_name}.service"
  745. echo " echo 'Restart=always' >> /etc/systemd/system/${app_name}.service"
  746. echo " echo 'Environment=\"USER=${app_name}\"' >> /etc/systemd/system/${app_name}.service"
  747. echo " echo '' >> /etc/systemd/system/${app_name}.service"
  748. echo " echo '[Install]' >> /etc/systemd/system/${app_name}.service"
  749. echo " echo 'WantedBy=multi-user.target' >> /etc/systemd/system/${app_name}.service"
  750. echo " systemctl enable ${app_name}"
  751. if [ $app_dir ]; then
  752. echo " chown -R ${app_name}:${app_name} ${app_dir}"
  753. fi
  754. echo " systemctl start ${app_name}"
  755. fi
  756. echo ''
  757. echo " create_site_certificate \$${app_name_upper}_DOMAIN_NAME 'yes'"
  758. echo ''
  759. echo " nginx_ensite \$${app_name_upper}_DOMAIN_NAME"
  760. echo ''
  761. if [[ "$database_type" == "mariadb" || "$database_type" == "mysql" ]]; then
  762. echo ' systemctl restart mariadb'
  763. fi
  764. if [[ "$app_php" == 'yes' ]]; then
  765. echo ' systemctl restart php7.0-fpm'
  766. fi
  767. echo ' systemctl restart nginx'
  768. echo ''
  769. echo " \${PROJECT_NAME}-pass -u \$MY_USERNAME -a ${app_name} -p \"\$${app_name_upper}_ADMIN_PASSWORD\""
  770. echo " set_completion_param \"${app_name} domain\" \"\$${app_name_upper}_DOMAIN_NAME\""
  771. if [ $app_port ]; then
  772. echo ''
  773. echo " firewall_add ${app_name} ${app_port} tcp"
  774. fi
  775. echo ''
  776. echo ' APP_INSTALLED=1'
  777. echo '}'
  778. echo ''
  779. echo '# NOTE: deliberately there is no "exit 0"'