freedombone-app-smilodon 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # Smilodon ActivityPub app
  12. #
  13. # License
  14. # =======
  15. #
  16. # Copyright (C) 2017 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. VARIANTS='full full-vim social'
  31. IN_DEFAULT_INSTALL=0
  32. SHOW_ON_ABOUT=1
  33. SHOW_ICANN_ADDRESS_ON_ABOUT=0
  34. SMILODON_REPO="https://github.com/bashrc/smilodon"
  35. SMILODON_COMMIT='e17dad10f9d4c00516b9c93a587e4298b3639af3'
  36. SMILODON_ADMIN_PASSWORD=
  37. SMILODON_ONION_PORT=8054
  38. SMILODON_PATH=/etc/smilodon
  39. SMILODON_SECRET_KEY=
  40. smilodon_variables=(SMILODON_REPO
  41. SMILODON_ADMIN_PASSWORD
  42. USB_MOUNT
  43. SMILODON_SECRET_KEY
  44. MY_EMAIL_ADDRESS
  45. MY_USERNAME)
  46. function logging_on_smilodon {
  47. echo -n ''
  48. }
  49. function logging_off_smilodon {
  50. echo -n ''
  51. }
  52. function remove_user_smilodon {
  53. remove_username="$1"
  54. }
  55. function add_user_smilodon {
  56. new_username="$1"
  57. new_user_password="$2"
  58. echo '0'
  59. }
  60. function install_interactive_smilodon {
  61. echo -n ''
  62. APP_INSTALLED=1
  63. }
  64. function change_password_smilodon {
  65. curr_username="$1"
  66. new_user_password="$2"
  67. #${PROJECT_NAME}-pass -u "$curr_username" -a smilodon -p "$new_user_password"
  68. }
  69. function smilodon_create_database {
  70. if [ ! $SMILODON_ADMIN_PASSWORD ]; then
  71. return
  72. fi
  73. function_check create_database_mongodb
  74. create_database_mongodb smilodon "$SMILODON_ADMIN_PASSWORD" smilodon
  75. }
  76. function reconfigure_smilodon {
  77. echo -n ''
  78. }
  79. function upgrade_smilodon {
  80. CURR_SMILODON_COMMIT=$(get_completion_param "smilodon commit")
  81. if [[ "$CURR_SMILODON_COMMIT" == "$SMILODON_COMMIT" ]]; then
  82. return
  83. fi
  84. if [[ $(app_is_installed smilodon) == "1" ]]; then
  85. systemctl stop smilodon
  86. function_check set_repo_commit
  87. set_repo_commit $SMILODON_PATH "smilodon commit" "$SMILODON_COMMIT" $SMILODON_REPO
  88. chown -R smilodon:smilodon $SMILODON_PATH
  89. systemctl start smilodon
  90. fi
  91. }
  92. function backup_local_smilodon {
  93. if [ -d $SMILODON_PATH ]; then
  94. systemctl stop smilodon
  95. USE_MONGODB=1
  96. function_check backup_database_to_usb
  97. backup_database_to_usb smilodon
  98. backup_directory_to_usb $SMILODON_PATH smilodon
  99. systemctl start smilodon
  100. fi
  101. }
  102. function restore_local_smilodon {
  103. temp_restore_dir=/root/tempsmilodon
  104. systemctl stop smilodon
  105. function_check smilodon_create_database
  106. smilodon_create_database
  107. USE_MONGODB=1
  108. restore_database smilodon
  109. if [ -d ${SMILODON_PATH} ]; then
  110. if [ -d $temp_restore_dir${SMILODON_PATH} ]; then
  111. if [ -d $temp_restore_dir${SMILODON_PATH} ]; then
  112. rm -rf ${SMILODON_PATH}
  113. mv $temp_restore_dir$SMILODON_PATH ${SMILODON_PATH}/
  114. else
  115. cp -r $temp_restore_dir/* ${SMILODON_PATH}/
  116. fi
  117. if [ ! "$?" = "0" ]; then
  118. function_check backup_unmount_drive
  119. backup_unmount_drive
  120. systemctl start smilodon
  121. exit 528823
  122. fi
  123. chown -R smilodon:smilodon ${SMILODON_PATH}
  124. fi
  125. fi
  126. if [ -d $USB_MOUNT/backup/smilodon ]; then
  127. chown -R smilodon:smilodon ${SMILODON_PATH}
  128. if [ -d $temp_restore_dir ]; then
  129. rm -rf $temp_restore_dir
  130. fi
  131. fi
  132. systemctl start smilodon
  133. }
  134. function backup_remote_smilodon {
  135. if [ -d $SMILODON_PATH ]; then
  136. function_check suspend_site
  137. suspend_site smilodon
  138. systemctl stop smilodon
  139. USE_MONGODB=1
  140. function_check backup_database_to_friend
  141. backup_database_to_friend smilodon
  142. function_check backup_directory_to_friend
  143. backup_directory_to_friend $SMILODON_PATH smilodon
  144. systemctl start smilodon
  145. function_check restart_site
  146. restart_site
  147. else
  148. echo $"Smilodon domain specified but not found in $SMILODON_PATH"
  149. fi
  150. }
  151. function restore_remote_smilodon {
  152. temp_restore_dir=/root/tempsmilodon
  153. if grep -q "smilodon domain" $COMPLETION_FILE; then
  154. echo $"Restoring smilodon"
  155. systemctl stop smilodon
  156. function_check restore_database_from_friend
  157. function_check smilodon_create_database
  158. smilodon_create_database
  159. USE_MONGODB=1
  160. restore_database_from_friend smilodon
  161. if [ -d $SMILODON_PATH ]; then
  162. if [ -d $temp_restore_dir$SMILODON_PATH ]; then
  163. rm -rf $SMILODON_PATH
  164. mv $temp_restore_dir$SMILODON_PATH ${SMILODON_PATH}/
  165. else
  166. cp -r $temp_restore_dir/* ${SMILODON_PATH}/
  167. fi
  168. if [ ! "$?" = "0" ]; then
  169. systemctl start smilodon
  170. exit 6391643
  171. fi
  172. fi
  173. if [ -d $SERVER_DIRECTORY/backup/smilodon ]; then
  174. chown -R smilodon:smilodon ${SMILODON_PATH}
  175. fi
  176. if [ -d /root/tempsmilodon ]; then
  177. rm -rf /root/tempsmilodon
  178. fi
  179. systemctl start smilodon
  180. echo $"Restore of smilodon complete"
  181. fi
  182. }
  183. function remove_smilodon {
  184. nginx_dissite smilodon
  185. systemctl stop smilodon
  186. systemctl disable smilodon
  187. rm /etc/systemd/system/smilodon.service
  188. function_check remove_onion_service
  189. remove_onion_service smilodon ${SMILODON_ONION_PORT}
  190. if [ -f /etc/nginx/sites-available/smilodon ]; then
  191. rm /etc/nginx/sites-available/smilodon
  192. fi
  193. groupdel -f smilodon
  194. userdel -r smilodon
  195. if [ -d $SMILODON_PATH ]; then
  196. rm -rf $SMILODON_PATH
  197. fi
  198. function_check remove_mongodb_user
  199. remove_mongodb_user smilodon
  200. function_check drop_database_mongodb
  201. drop_database_mongodb smilodon
  202. function_check remove_mongodb
  203. remove_mongodb smilodon
  204. remove_completion_param install_smilodon
  205. sed -i '/smilodon/d' $COMPLETION_FILE
  206. }
  207. function install_smilodon {
  208. apt-get -yq install python3-pip
  209. if [ -d $SMILODON_PATH ]; then
  210. rm -rf $SMILODON_PATH
  211. fi
  212. if [ -d /repos/smilodon ]; then
  213. mkdir $SMILODON_PATH
  214. cp -r -p /repos/smilodon/. $SMILODON_PATH
  215. cd $SMILODON_PATH
  216. git pull
  217. else
  218. function_check git_clone
  219. git_clone $SMILODON_REPO $SMILODON_PATH
  220. fi
  221. if [ ! -d $SMILODON_PATH ]; then
  222. echo $'Could not clone smilodon repo'
  223. exit 6784783
  224. fi
  225. cd $SMILODON_PATH
  226. git checkout $SMILODON_COMMIT -b $SMILODON_COMMIT
  227. set_completion_param "smilodon commit" "$SMILODON_COMMIT"
  228. groupadd smilodon
  229. useradd -c "Smilodon system account" -d $SMILODON_PATH -m -r -g smilodon smilodon
  230. SMILODON_ONION_HOSTNAME=$(add_onion_service smilodon 80 ${SMILODON_ONION_PORT})
  231. if [ ! $SMILODON_SECRET_KEY ]; then
  232. SMILODON_SECRET_KEY="$(create_password 30)$(create_password 30)$(create_password 30)$(create_password 30)"
  233. fi
  234. if [ -f $IMAGE_PASSWORD_FILE ]; then
  235. SMILODON_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  236. else
  237. if [ ! $SMILODON_ADMIN_PASSWORD ]; then
  238. SMILODON_ADMIN_PASSWORD="$(create_password ${MINIMUM_PASSWORD_LENGTH})"
  239. fi
  240. fi
  241. export smilodon_domain_name=$SMILODON_ONION_HOSTNAME
  242. export secret_key="$SMILODON_SECRET_KEY"
  243. export mongodb_username='smilodon'
  244. export mongodb_password="$SMILODON_ADMIN_PASSWORD"
  245. export smilodon_admin_address=$MY_EMAIL_ADDRESS
  246. export MAIL_SERVER='localhost'
  247. export MAIL_PORT=25
  248. function_check install_mongodb
  249. install_mongodb smilodon
  250. smilodon_create_database
  251. pip3 install -r requirements.txt
  252. if [ ! "$?" = "0" ]; then
  253. echo $'Unable to install smilodon dependencies'
  254. exit 87352835
  255. fi
  256. echo 'server {' > /etc/nginx/sites-available/smilodon
  257. echo " listen 127.0.0.1:${SMILODON_ONION_PORT} default_server;" >> /etc/nginx/sites-available/smilodon
  258. echo " server_name $SMILODON_ONION_HOSTNAME;" >> /etc/nginx/sites-available/smilodon
  259. echo '' >> /etc/nginx/sites-available/smilodon
  260. echo ' access_log /dev/null;' >> /etc/nginx/sites-available/smilodon
  261. echo ' error_log /dev/null;' >> /etc/nginx/sites-available/smilodon
  262. echo '' >> /etc/nginx/sites-available/smilodon
  263. echo ' location / {' >> /etc/nginx/sites-available/smilodon
  264. echo ' proxy_pass http://localhost:5000;' >> /etc/nginx/sites-available/smilodon
  265. echo ' }' >> /etc/nginx/sites-available/smilodon
  266. echo '}' >> /etc/nginx/sites-available/smilodon
  267. nginx_ensite smilodon
  268. systemctl enable mongodb
  269. systemctl restart mongodb
  270. chown -R smilodon:smilodon ${SMILODON_PATH}
  271. echo '#!/bin/bash' > ${SMILODON_PATH}/run_smilodon.sh
  272. echo "cd ${SMILODON_PATH}" >> ${SMILODON_PATH}/run_smilodon.sh
  273. echo "export smilodon_domain_name=$SMILODON_ONION_HOSTNAME" >> ${SMILODON_PATH}/run_smilodon.sh
  274. echo "export secret_key='$SMILODON_SECRET_KEY'" >> ${SMILODON_PATH}/run_smilodon.sh
  275. echo "export mongodb_username='smilodon'" >> ${SMILODON_PATH}/run_smilodon.sh
  276. echo "export mongodb_password='$SMILODON_ADMIN_PASSWORD'" >> ${SMILODON_PATH}/run_smilodon.sh
  277. echo "export smilodon_admin_address=$MY_EMAIL_ADDRESS" >> ${SMILODON_PATH}/run_smilodon.sh
  278. echo "export MAIL_SERVER='localhost'" >> ${SMILODON_PATH}/run_smilodon.sh
  279. echo "export MAIL_PORT=25" >> ${SMILODON_PATH}/run_smilodon.sh
  280. echo "python3 run.py" >> ${SMILODON_PATH}/run_smilodon.sh
  281. chmod +x ${SMILODON_PATH}/run_smilodon.sh
  282. chown smilodon:smilodon ${SMILODON_PATH}/run_smilodon.sh
  283. echo '[Unit]' > /etc/systemd/system/smilodon.service
  284. echo 'Description=Smilodon ActivityPub messenger' >> /etc/systemd/system/smilodon.service
  285. echo 'After=network.target mongodb.service' >> /etc/systemd/system/smilodon.service
  286. echo 'After=tor.service' >> /etc/systemd/system/smilodon.service
  287. echo '' >> /etc/systemd/system/smilodon.service
  288. echo '[Service]' >> /etc/systemd/system/smilodon.service
  289. echo 'User=smilodon' >> /etc/systemd/system/smilodon.service
  290. echo 'Group=smilodon' >> /etc/systemd/system/smilodon.service
  291. echo "WorkingDirectory=${SMILODON_PATH}/" >> /etc/systemd/system/smilodon.service
  292. echo "ExecStart=${SMILODON_PATH}/run_smilodon.sh" >> /etc/systemd/system/smilodon.service
  293. echo 'Restart=on-failure' >> /etc/systemd/system/smilodon.service
  294. echo 'RestartSec=10' >> /etc/systemd/system/smilodon.service
  295. echo '' >> /etc/systemd/system/smilodon.service
  296. echo '[Install]' >> /etc/systemd/system/smilodon.service
  297. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/smilodon.service
  298. systemctl enable smilodon
  299. systemctl daemon-reload
  300. systemctl start smilodon
  301. systemctl restart nginx
  302. ${PROJECT_NAME}-pass -u $MY_USERNAME -a smilodon -p "$SMILODON_ADMIN_PASSWORD"
  303. APP_INSTALLED=1
  304. }
  305. # NOTE: deliberately no exit 0