freedombone-utils-gnusocialtools 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # functions common to GNU Social server varieties
  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. QVITTER_THEME_REPO="https://git.gnu.io/h2p/Qvitter.git"
  31. QVITTER_THEME_COMMIT='a7f82628402db3a7579bb9b2877da3c5737da77b'
  32. PLEROMA_REPO="https://gitgud.io/lambadalambda/pleroma-fe"
  33. PLEROMA_COMMIT='1f8d30386388f8b91aa84fdbd7861e588aa0d935'
  34. function pleroma_set_background_image_from_url {
  35. domain_name="$1"
  36. url="$2"
  37. title="$3"
  38. if [ ${#domain_name} -eq 0 ]; then
  39. echo "1"
  40. return
  41. fi
  42. ext=
  43. if [ ${#url} -gt 0 ]; then
  44. if [[ "$url" == *".jpeg" || "$url" == *".jpg" ]]; then
  45. ext="jpg"
  46. fi
  47. if [[ "$url" == *".png" ]]; then
  48. ext="png"
  49. fi
  50. if [[ "$url" == *".gif" ]]; then
  51. ext="gif"
  52. fi
  53. fi
  54. if [ ${#ext} -gt 0 ]; then
  55. if [ -d /var/www/${domain_name}/htdocs/static ]; then
  56. cd /var/www/${domain_name}/htdocs/static
  57. # remove any existing image
  58. if [ -f bg_custom.${ext} ]; then
  59. rm bg_custom.${ext}
  60. fi
  61. # get the new image
  62. wget "$url" -O bg_custom.${ext}
  63. if [ ! -f bg_custom.${ext} ]; then
  64. echo "$url"
  65. echo $'Custom background image for pleroma could not be downloaded'
  66. echo "1"
  67. return
  68. fi
  69. sed -i "s|\"background\":.*|\"background\": \"/static/bg_custom.${ext}\",|g" config.json
  70. # update the qvitter background
  71. if [ -d /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img ]; then
  72. cp bg_custom.${ext} /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img
  73. if ! grep -q "bg_custom.${ext}" /var/www/${domain_name}/htdocs/config.php; then
  74. if grep -q 'sitebackground' /var/www/${domain_name}/htdocs/config.php; then
  75. sed -i '/sitebackground/d' /var/www/${domain_name}/htdocs/config.php
  76. fi
  77. echo "\$config['site']['qvitter']['sitebackground'] = 'img/bg_custom.${ext}';" >> /var/www/${domain_name}/htdocs/config.php
  78. fi
  79. fi
  80. else
  81. # qvitter background
  82. if [ -d /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img ]; then
  83. cd /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img
  84. # remove any existing image
  85. if [ -f bg_custom.${ext} ]; then
  86. rm bg_custom.${ext}
  87. fi
  88. # get the new image
  89. wget "$url" -O bg_custom.${ext}
  90. if [ ! -f bg_custom.${ext} ]; then
  91. echo "$url"
  92. echo $'Custom background image for Qvitter could not be downloaded'
  93. echo "3"
  94. return
  95. fi
  96. if ! grep -q "bg_custom.${ext}" /var/www/${domain_name}/htdocs/config.php; then
  97. if grep -q 'sitebackground' /var/www/${domain_name}/htdocs/config.php; then
  98. sed -i '/sitebackground/d' /var/www/${domain_name}/htdocs/config.php
  99. fi
  100. echo "\$config['site']['qvitter']['sitebackground'] = 'img/bg_custom.${ext}';" >> /var/www/${domain_name}/htdocs/config.php
  101. fi
  102. fi
  103. fi
  104. else
  105. echo "2"
  106. return
  107. fi
  108. # customise the logo
  109. if [ -f /var/www/${domain_name}/htdocs/static/logo.png ]; then
  110. if [ -f ~/freedombone/img/logo_fbone3.png ]; then
  111. cp ~/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/static/logo.png
  112. else
  113. if [ -f /home/$MY_USERNAME/freedombone/img/logo_fbone3.png ]; then
  114. cp /home/$MY_USERNAME/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/static/logo.png
  115. fi
  116. fi
  117. fi
  118. # customise the title
  119. if [ -f /var/www/${domain_name}/htdocs/static/config.json ]; then
  120. sed -i "s|\"name\":.*|\"name\": \"${title}\",|g" /var/www/${domain_name}/htdocs/static/config.json
  121. fi
  122. echo "0"
  123. }
  124. function install_qvitter {
  125. domain_name=$1
  126. app_name=$2
  127. # update to the next commit
  128. function_check set_repo_commit
  129. set_repo_commit /var/www/${domain_name}/htdocs/local/plugins/Qvitter "${app_name} theme commit" "$QVITTER_THEME_COMMIT" $QVITTER_THEME_REPO
  130. # customise with project logo
  131. if [ -f /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img/sprite.png ]; then
  132. if [ -f ~/freedombone/img/logo_fbone3.png ]; then
  133. cp ~/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img/sprite.png
  134. else
  135. if [ -f /home/$MY_USERNAME/freedombone/img/logo_fbone3.png ]; then
  136. cp /home/$MY_USERNAME/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img/sprite.png
  137. fi
  138. fi
  139. fi
  140. if [[ $(app_is_installed "${app_name}_theme") == "1" ]]; then
  141. return
  142. fi
  143. apt-get -yq install wget
  144. if [ ! -d /var/www/${domain_name}/htdocs/local/plugins ]; then
  145. mkdir -p /var/www/${domain_name}/htdocs/local/plugins
  146. fi
  147. cd /var/www/${domain_name}/htdocs/local/plugins
  148. function_check git_clone
  149. git_clone $QVITTER_THEME_REPO Qvitter
  150. cd /var/www/${domain_name}/htdocs/local/plugins/Qvitter
  151. git checkout $QVITTER_THEME_COMMIT -b $QVITTER_THEME_COMMIT
  152. config_file=/var/www/${domain_name}/htdocs/config.php
  153. if ! grep -q "addPlugin('Qvitter')" $config_file; then
  154. echo "" >> $config_file
  155. echo "// Qvitter settings" >> $config_file
  156. echo "addPlugin('Qvitter');" >> $config_file
  157. echo "\$config['site']['qvitter']['enabledbydefault'] = true;" >> $config_file
  158. echo "\$config['site']['qvitter']['defaultbackgroundcolor'] = '#f4f4f4';" >> $config_file
  159. echo "\$config['site']['qvitter']['defaultlinkcolor'] = '#0084B4';" >> $config_file
  160. echo "\$config['site']['qvitter']['timebetweenpolling'] = 30000; // 30 secs" >> $config_file
  161. if [[ $ONION_ONLY == 'no' ]]; then
  162. echo "\$config['site']['qvitter']['urlshortenerapiurl'] = 'http://qttr.at/shortener.php';" >> $config_file
  163. echo "\$config['site']['qvitter']['urlshortenersignature'] = 'b6afeec983';" >> $config_file
  164. fi
  165. echo "\$config['site']['qvitter']['favicon'] = 'img/favicon.ico?v=4';" >> $config_file
  166. echo "\$config['site']['qvitter']['sprite'] = Plugin::staticPath('Qvitter', '').'img/sprite.png?v=40';" >> $config_file
  167. echo "\$config['site']['qvitter']['enablewelcometext'] = false;" >> $config_file
  168. echo "\$config['site']['qvitter']['blocked_ips'] = array();" >> $config_file
  169. fi
  170. # customise with project logo
  171. if [ -f /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img/sprite.png ]; then
  172. if [ -f ~/freedombone/img/gnusocial_sprite.png ]; then
  173. cp ~/freedombone/img/gnusocial_sprite.png /var/www/${domain_name}/htdocs/local/plugins/Qvitter/img/sprite.png
  174. fi
  175. fi
  176. chown -R www-data:www-data /var/www/${domain_name}/htdocs
  177. cd /var/www/${domain_name}/htdocs
  178. php scripts/upgrade.php
  179. php scripts/checkschema.php
  180. chown -R www-data:www-data /var/www/${domain_name}/htdocs
  181. set_completion_param "${app_name} theme commit" "$QVITTER_THEME_COMMIT"
  182. install_completed ${app_name}_theme
  183. }
  184. function install_gnusocial_default_background {
  185. gnusocial_type=$1
  186. domain_name=$2
  187. # customise the logo
  188. if [ -f /var/www/${domain_name}/htdocs/static/logo.png ]; then
  189. if [ -f ~/freedombone/img/logo_fbone3.png ]; then
  190. cp ~/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/static/logo.png
  191. else
  192. if [ -f /home/$MY_USERNAME/freedombone/img/logo_fbone3.png ]; then
  193. cp /home/$MY_USERNAME/freedombone/img/logo_fbone3.png /var/www/${domain_name}/htdocs/static/logo.png
  194. fi
  195. fi
  196. fi
  197. if [ ! -f /var/www/${domain_name}/htdocs/static/bg.jpg ]; then
  198. return
  199. fi
  200. if [ -f ~/freedombone/img/backgrounds/${gnusocial_type}.jpg ]; then
  201. cp ~/freedombone/img/backgrounds/${gnusocial_type}.jpg /var/www/${domain_name}/htdocs/static/bg.jpg
  202. else
  203. if [ -f /home/$MY_USERNAME/freedombone/img/backgrounds/${gnusocial_type}.jpg ]; then
  204. cp /home/$MY_USERNAME/freedombone/img/backgrounds/${gnusocial_type}.jpg /var/www/${domain_name}/htdocs/static/bg.jpg
  205. fi
  206. fi
  207. }
  208. function install_pleroma_front_end {
  209. app_name="$1"
  210. pleroma_domain="$2"
  211. background_url="$3"
  212. title="$4"
  213. if [ ! -d $INSTALL_DIR/pleroma ]; then
  214. function_check git_clone
  215. git_clone $PLEROMA_REPO $INSTALL_DIR/pleroma
  216. if [ ! -d $INSTALL_DIR/pleroma ]; then
  217. echo $'Unable to clone pleroma repo'
  218. exit 682252
  219. fi
  220. fi
  221. cd $INSTALL_DIR/pleroma
  222. git checkout $PLEROMA_COMMIT -b $PLEROMA_COMMIT
  223. set_completion_param "${app_name} pleroma commit" "$PLEROMA_COMMIT"
  224. if [ -d $INSTALL_DIR/pleroma/node_modules ]; then
  225. rm -rf $INSTALL_DIR/pleroma/node_modules
  226. fi
  227. npm install -g yarn
  228. npm install -g eslint@3.19.0
  229. npm install -g eslint-plugin-promise@3.5.0
  230. npm install -g moment@2.18.1
  231. npm install -g node-sass@4.5.2
  232. yarn
  233. if [ -f $INSTALL_DIR/pleroma/dist/index.html ]; then
  234. rm -rf $INSTALL_DIR/pleroma/dist/*
  235. fi
  236. npm run build
  237. if [ ! -d $INSTALL_DIR/pleroma/dist ]; then
  238. echo 'Unable to build pleroma'
  239. exit 7629352
  240. fi
  241. if [ ! -f $INSTALL_DIR/pleroma/dist/index.html ]; then
  242. echo $'Unable to build pleroma index.html'
  243. exit 5282682
  244. fi
  245. cp -r $INSTALL_DIR/pleroma/dist/* /var/www/${pleroma_domain}/htdocs/
  246. pleroma_set_background_image_from_url "$pleroma_domain" "$background_url" "$title"
  247. nginx_site=/etc/nginx/sites-available/${pleroma_domain}
  248. sed -i 's|index index.php;|index index.html;|g' $nginx_site
  249. if [ -f /var/www/${pleroma_domain}/htdocs/index.php ]; then
  250. mv /var/www/${pleroma_domain}/htdocs/index.php /var/www/${pleroma_domain}/htdocs/index_qvitter.php
  251. fi
  252. sed -i 's|index.php|index_qvitter.php|g' $nginx_site
  253. # remove any cached yarn files
  254. if [ -d /root/.cache/yarn ]; then
  255. rm -rf /root/.cache/yarn
  256. fi
  257. chown -R www-data:www-data /var/www/${pleroma_domain}/htdocs
  258. }
  259. function upgrade_pleroma {
  260. domain_name="$1"
  261. app_name="$2"
  262. background_url="$3"
  263. title="$4"
  264. if [ -d $INSTALL_DIR/pleroma ]; then
  265. set_repo_commit $INSTALL_DIR/pleroma "${app_name} pleroma commit" "$PLEROMA_COMMIT" $PLEROMA_REPO
  266. cd $INSTALL_DIR/pleroma
  267. npm run build
  268. if [ ! -d $INSTALL_DIR/pleroma/dist ]; then
  269. echo 'Unable to build pleroma'
  270. exit 268362
  271. fi
  272. if [ -f /var/www/${domain_name}/htdocs/static/logo.png ]; then
  273. cp /var/www/${domain_name}/htdocs/static/logo.png /var/www/${domain_name}/htdocs/static/logo.png.old
  274. fi
  275. if [ -f /var/www/${domain_name}/htdocs/static/bg.jpg ]; then
  276. cp /var/www/${domain_name}/htdocs/static/bg.jpg /var/www/${domain_name}/htdocs/static/bg.jpg.old
  277. fi
  278. if [ -f /var/www/${domain_name}/htdocs/static/config.json ]; then
  279. cp /var/www/${domain_name}/htdocs/static/config.json /var/www/${domain_name}/htdocs/static/config.json.old
  280. fi
  281. cp -r $INSTALL_DIR/pleroma/dist/* /var/www/${domain_name}/htdocs/
  282. if [ -f /var/www/${domain_name}/htdocs/static/config.json.old ]; then
  283. mv /var/www/${domain_name}/htdocs/static/config.json.old /var/www/${domain_name}/htdocs/static/config.json
  284. fi
  285. sed -i "s|\"name\":.*|\"name\": \"${title}\",|g" /var/www/${domain_name}/htdocs/static/config.json
  286. if [ -f /var/www/${domain_name}/htdocs/static/logo.png.old ]; then
  287. cp /var/www/${domain_name}/htdocs/static/logo.png.old /var/www/${domain_name}/htdocs/static/logo.png
  288. fi
  289. if [ -f /var/www/${domain_name}/htdocs/static/bg.jpg.old ]; then
  290. cp /var/www/${domain_name}/htdocs/static/bg.jpg.old /var/www/${domain_name}/htdocs/static/bg.jpg
  291. fi
  292. if [ -f /var/www/${domain_name}/htdocs/index.php ]; then
  293. mv /var/www/${domain_name}/htdocs/index.php /var/www/${domain_name}/htdocs/index_qvitter.php
  294. fi
  295. chown -R www-data:www-data /var/www/${domain_name}/htdocs
  296. else
  297. install_pleroma_front_end "${app_name}" "${domain_name}" "${background_url}" "${title}"
  298. fi
  299. }
  300. function gnusocial_hourly_script {
  301. gnusocial_type=$1
  302. domain_name=$2
  303. # check that the daemon is running
  304. echo '#!/bin/bash' > /etc/cron.hourly/${gnusocial_type}-daemons
  305. echo -n 'daemon_lines=$(ps aux | grep "' >> /etc/cron.hourly/${gnusocial_type}-daemons
  306. echo -n "${domain_name}" >> /etc/cron.hourly/${gnusocial_type}-daemons
  307. echo '/htdocs/scripts/queuedaemon.php" | grep "/var/www")' >> /etc/cron.hourly/${gnusocial_type}-daemons
  308. echo "cd /var/www/${domain_name}/htdocs" >> /etc/cron.hourly/${gnusocial_type}-daemons
  309. echo 'if [[ $daemon_lines != *"/var/www/"* ]]; then' >> /etc/cron.hourly/${gnusocial_type}-daemons
  310. echo " ADMIN_USER=\$(cat $COMPLETION_FILE | grep 'Admin user' | awk -F ':' '{print \$2}')" >> /etc/cron.hourly/${gnusocial_type}-daemons
  311. echo ' MY_EMAIL_ADDRESS=$ADMIN_USER@$HOSTNAME' >> /etc/cron.hourly/${gnusocial_type}-daemons
  312. echo -n " echo \"Restarting ${gnusocial_type} daemons\" | mail -s \"${gnusocial_type} " >> /etc/cron.hourly/${gnusocial_type}-daemons
  313. echo 'daemons not found" $MY_EMAIL_ADDRESS' >> /etc/cron.hourly/${gnusocial_type}-daemons
  314. echo ' scripts/startdaemons.sh' >> /etc/cron.hourly/${gnusocial_type}-daemons
  315. echo 'fi' >> /etc/cron.hourly/${gnusocial_type}-daemons
  316. echo 'php scripts/delete_orphan_files.php > /dev/null' >> /etc/cron.hourly/${gnusocial_type}-daemons
  317. echo 'php scripts/clean_thumbnails.php -y > /dev/null' >> /etc/cron.hourly/${gnusocial_type}-daemons
  318. echo 'php scripts/clean_file_table.php -y > /dev/null' >> /etc/cron.hourly/${gnusocial_type}-daemons
  319. echo 'php scripts/upgrade.php > /dev/null' >> /etc/cron.hourly/${gnusocial_type}-daemons
  320. chmod +x /etc/cron.hourly/${gnusocial_type}-daemons
  321. }
  322. function gnusocial_block_user_script {
  323. echo '#!/bin/bash' > /usr/bin/gnusocial-delete-user
  324. echo '' >> /usr/bin/gnusocial-delete-user
  325. echo 'database_name=$1' >> /usr/bin/gnusocial-delete-user
  326. echo 'remove_user=$2' >> /usr/bin/gnusocial-delete-user
  327. echo 'domain_name=$3' >> /usr/bin/gnusocial-delete-user
  328. echo 'MARIADB_PASSWORD=$(freedombone-pass -u root -a mariadb)' >> /usr/bin/gnusocial-delete-user
  329. echo '' >> /usr/bin/gnusocial-delete-user
  330. echo 'if [ ${#remove_user} -lt 2 ]; then' >> /usr/bin/gnusocial-delete-user
  331. echo ' echo $"No user was specified"' >> /usr/bin/gnusocial-delete-user
  332. echo ' exit 1' >> /usr/bin/gnusocial-delete-user
  333. echo 'fi' >> /usr/bin/gnusocial-delete-user
  334. echo '' >> /usr/bin/gnusocial-delete-user
  335. echo 'if [[ "$remove_user" != *"."* || "$remove_user" != *"@"* ]]; then' >> /usr/bin/gnusocial-delete-user
  336. echo ' echo $"This doesnt look like a user"' >> /usr/bin/gnusocial-delete-user
  337. echo ' exit 2' >> /usr/bin/gnusocial-delete-user
  338. echo 'fi' >> /usr/bin/gnusocial-delete-user
  339. echo '' >> /usr/bin/gnusocial-delete-user
  340. echo 'if [ ${#database_name} -lt 2 ]; then' >> /usr/bin/gnusocial-delete-user
  341. echo ' echo $"No database was specified"' >> /usr/bin/gnusocial-delete-user
  342. echo ' exit 3' >> /usr/bin/gnusocial-delete-user
  343. echo 'fi' >> /usr/bin/gnusocial-delete-user
  344. echo '' >> /usr/bin/gnusocial-delete-user
  345. echo "nickname=\$(echo \"\$remove_user\" | awk -F '@' '{print \$1}')" >> /usr/bin/gnusocial-delete-user
  346. echo "remove_domain=\$(echo \"\$remove_user\" | awk -F '@' '{print \$2}')" >> /usr/bin/gnusocial-delete-user
  347. echo '' >> /usr/bin/gnusocial-delete-user
  348. echo 'database_query="select profile.id from profile where nickname = '"'"'${nickname}'"'"' and profileurl like '"'"'%${remove_domain}%'"'"';"' >> /usr/bin/gnusocial-delete-user
  349. echo 'declare -a ids=$(mysql -u root --password="$MARIADB_PASSWORD" << EOF' >> /usr/bin/gnusocial-delete-user
  350. echo 'use $database_name;' >> /usr/bin/gnusocial-delete-user
  351. echo '$database_query' >> /usr/bin/gnusocial-delete-user
  352. echo 'EOF' >> /usr/bin/gnusocial-delete-user
  353. echo ')' >> /usr/bin/gnusocial-delete-user
  354. echo '' >> /usr/bin/gnusocial-delete-user
  355. echo 'ctr=0' >> /usr/bin/gnusocial-delete-user
  356. echo 'for id in $ids' >> /usr/bin/gnusocial-delete-user
  357. echo 'do' >> /usr/bin/gnusocial-delete-user
  358. echo ' if [ $ctr -gt 0 ]; then' >> /usr/bin/gnusocial-delete-user
  359. echo ' #echo "Removing user ID $id on $remove_domain"' >> /usr/bin/gnusocial-delete-user
  360. echo '' >> /usr/bin/gnusocial-delete-user
  361. echo ' database_query="delete from reply where profile_id=${id};"' >> /usr/bin/gnusocial-delete-user
  362. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-user
  363. echo '' >> /usr/bin/gnusocial-delete-user
  364. echo ' database_query="delete from reply where replied_id=${id};"' >> /usr/bin/gnusocial-delete-user
  365. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-user
  366. echo '' >> /usr/bin/gnusocial-delete-user
  367. echo ' if [ $domain_name ]; then' >> /usr/bin/gnusocial-delete-user
  368. echo ' database_query="select rendered from notice where profile_id=${id} and rendered like '"'"'%/file/%'"'"';"' >> /usr/bin/gnusocial-delete-user
  369. echo ' declare -a stored_files=$(mysql -u root --password="$MARIADB_PASSWORD" << EOF' >> /usr/bin/gnusocial-delete-user
  370. echo 'use $database_name;' >> /usr/bin/gnusocial-delete-user
  371. echo '$database_query' >> /usr/bin/gnusocial-delete-user
  372. echo 'EOF' >> /usr/bin/gnusocial-delete-user
  373. echo ')' >> /usr/bin/gnusocial-delete-user
  374. echo -n " files_to_delete=\$(echo \"\$stored_files\" | " >> /usr/bin/gnusocial-delete-user
  375. echo 'sed -n '"'"'s/.*href="\([^"]*\).*/\1/p'"'"' | awk -F '"'"'file/'"'"' '"'"'{print $2}'"'"')' >> /usr/bin/gnusocial-delete-user
  376. echo ' filectr=0' >> /usr/bin/gnusocial-delete-user
  377. echo ' for f in $files_to_delete' >> /usr/bin/gnusocial-delete-user
  378. echo ' do' >> /usr/bin/gnusocial-delete-user
  379. echo ' if [ $filectr -gt 0 ]; then' >> /usr/bin/gnusocial-delete-user
  380. echo ' if $(ls /var/www/${domain_name}/htdocs/file/*${f}* 1> /dev/null 2>&1); then' >> /usr/bin/gnusocial-delete-user
  381. echo ' rm /var/www/${domain_name}/htdocs/file/*${f}*' >> /usr/bin/gnusocial-delete-user
  382. echo ' fi' >> /usr/bin/gnusocial-delete-user
  383. echo ' fi' >> /usr/bin/gnusocial-delete-user
  384. echo ' filectr=$((filectr + 1))' >> /usr/bin/gnusocial-delete-user
  385. echo ' done' >> /usr/bin/gnusocial-delete-user
  386. echo ' fi' >> /usr/bin/gnusocial-delete-user
  387. echo '' >> /usr/bin/gnusocial-delete-user
  388. echo ' database_query="delete from notice where profile_id=${id};"' >> /usr/bin/gnusocial-delete-user
  389. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-user
  390. echo '' >> /usr/bin/gnusocial-delete-user
  391. echo ' database_query="delete from profile where id=${id};"' >> /usr/bin/gnusocial-delete-user
  392. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-user
  393. echo '' >> /usr/bin/gnusocial-delete-user
  394. echo ' database_query="delete from qvitternotification where to_profile_id=${id} or from_profile_id=${id};"' >> /usr/bin/gnusocial-delete-user
  395. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-user
  396. echo ' fi' >> /usr/bin/gnusocial-delete-user
  397. echo ' ctr=$((ctr + 1))' >> /usr/bin/gnusocial-delete-user
  398. echo 'done' >> /usr/bin/gnusocial-delete-user
  399. chmod +x /usr/bin/gnusocial-delete-user
  400. }
  401. function gnusocial_block_domain_script {
  402. database_name=$1
  403. gnusoc_domain=$2
  404. echo '#!/bin/bash' > /usr/bin/gnusocial-delete-domain
  405. echo '' >> /usr/bin/gnusocial-delete-domain
  406. echo 'database_name=$1' >> /usr/bin/gnusocial-delete-domain
  407. echo 'remove_domain=$2' >> /usr/bin/gnusocial-delete-domain
  408. echo 'domain_name=$3' >> /usr/bin/gnusocial-delete-domain
  409. echo "MARIADB_PASSWORD=\$(${PROJECT_NAME}-pass -u root -a mariadb)" >> /usr/bin/gnusocial-delete-domain
  410. echo '' >> /usr/bin/gnusocial-delete-domain
  411. echo 'if [ ${#remove_domain} -lt 2 ]; then' >> /usr/bin/gnusocial-delete-domain
  412. echo ' echo $"No domain was specified"' >> /usr/bin/gnusocial-delete-domain
  413. echo ' exit 1' >> /usr/bin/gnusocial-delete-domain
  414. echo 'fi' >> /usr/bin/gnusocial-delete-domain
  415. echo '' >> /usr/bin/gnusocial-delete-domain
  416. echo 'if [[ "$remove_domain" != *"."* ]]; then' >> /usr/bin/gnusocial-delete-domain
  417. echo ' echo $"This doesnt look like a domain"' >> /usr/bin/gnusocial-delete-domain
  418. echo ' exit 2' >> /usr/bin/gnusocial-delete-domain
  419. echo 'fi' >> /usr/bin/gnusocial-delete-domain
  420. echo '' >> /usr/bin/gnusocial-delete-domain
  421. echo 'if [ ${#database_name} -lt 2 ]; then' >> /usr/bin/gnusocial-delete-domain
  422. echo ' echo $"No database was specified"' >> /usr/bin/gnusocial-delete-domain
  423. echo ' exit 3' >> /usr/bin/gnusocial-delete-domain
  424. echo 'fi' >> /usr/bin/gnusocial-delete-domain
  425. echo '' >> /usr/bin/gnusocial-delete-domain
  426. echo "database_query=\"select profile.id from profile where profileurl like '%\${remove_domain}%';\"" >> /usr/bin/gnusocial-delete-domain
  427. echo 'declare -a ids=$(mysql -u root --password="$MARIADB_PASSWORD" << EOF' >> /usr/bin/gnusocial-delete-domain
  428. echo 'use $database_name;' >> /usr/bin/gnusocial-delete-domain
  429. echo '$database_query' >> /usr/bin/gnusocial-delete-domain
  430. echo 'EOF' >> /usr/bin/gnusocial-delete-domain
  431. echo ')' >> /usr/bin/gnusocial-delete-domain
  432. echo '' >> /usr/bin/gnusocial-delete-domain
  433. echo 'ctr=0' >> /usr/bin/gnusocial-delete-domain
  434. echo 'for id in $ids' >> /usr/bin/gnusocial-delete-domain
  435. echo 'do' >> /usr/bin/gnusocial-delete-domain
  436. echo ' if [ $ctr -gt 0 ]; then' >> /usr/bin/gnusocial-delete-domain
  437. echo ' #echo "Removing user ID $id on $remove_domain"' >> /usr/bin/gnusocial-delete-domain
  438. echo '' >> /usr/bin/gnusocial-delete-domain
  439. echo " database_query=\"delete from conversation where uri like '%\${remove_domain}%';\"" >> /usr/bin/gnusocial-delete-domain
  440. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  441. echo '' >> /usr/bin/gnusocial-delete-domain
  442. echo ' database_query="delete from reply where profile_id=${id};"' >> /usr/bin/gnusocial-delete-domain
  443. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  444. echo '' >> /usr/bin/gnusocial-delete-domain
  445. echo ' database_query="delete from reply where replied_id=${id};"' >> /usr/bin/gnusocial-delete-domain
  446. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  447. echo '' >> /usr/bin/gnusocial-delete-domain
  448. echo ' if [ $domain_name ]; then' >> /usr/bin/gnusocial-delete-domain
  449. echo ' database_query="select rendered from notice where profile_id=${id} and rendered like '"'"'%/file/%'"'"';"' >> /usr/bin/gnusocial-delete-domain
  450. echo ' declare -a stored_files=$(mysql -u root --password="$MARIADB_PASSWORD" << EOF' >> /usr/bin/gnusocial-delete-domain
  451. echo 'use $database_name;' >> /usr/bin/gnusocial-delete-domain
  452. echo '$database_query' >> /usr/bin/gnusocial-delete-domain
  453. echo 'EOF' >> /usr/bin/gnusocial-delete-domain
  454. echo ')' >> /usr/bin/gnusocial-delete-domain
  455. echo -n " files_to_delete=\$(echo \"\$stored_files\" | " >> /usr/bin/gnusocial-delete-domain
  456. echo 'sed -n '"'"'s/.*href="\([^"]*\).*/\1/p'"'"' | awk -F '"'"'file/'"'"' '"'"'{print $2}'"'"')' >> /usr/bin/gnusocial-delete-domain
  457. echo ' filectr=0' >> /usr/bin/gnusocial-delete-domain
  458. echo ' for f in $files_to_delete' >> /usr/bin/gnusocial-delete-domain
  459. echo ' do' >> /usr/bin/gnusocial-delete-domain
  460. echo ' if [ $filectr -gt 0 ]; then' >> /usr/bin/gnusocial-delete-domain
  461. echo ' if $(ls /var/www/${domain_name}/htdocs/file/*${f}* 1> /dev/null 2>&1); then' >> /usr/bin/gnusocial-delete-domain
  462. echo ' rm /var/www/${domain_name}/htdocs/file/*${f}*' >> /usr/bin/gnusocial-delete-domain
  463. echo ' fi' >> /usr/bin/gnusocial-delete-domain
  464. echo ' fi' >> /usr/bin/gnusocial-delete-domain
  465. echo ' filectr=$((filectr + 1))' >> /usr/bin/gnusocial-delete-domain
  466. echo ' done' >> /usr/bin/gnusocial-delete-domain
  467. echo ' fi' >> /usr/bin/gnusocial-delete-domain
  468. echo '' >> /usr/bin/gnusocial-delete-domain
  469. echo ' database_query="delete from notice where profile_id=${id};"' >> /usr/bin/gnusocial-delete-domain
  470. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  471. echo '' >> /usr/bin/gnusocial-delete-domain
  472. echo ' database_query="delete from profile where id=${id};"' >> /usr/bin/gnusocial-delete-domain
  473. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  474. echo '' >> /usr/bin/gnusocial-delete-domain
  475. echo ' database_query="delete from qvitternotification where to_profile_id=${id} or from_profile_id=${id};"' >> /usr/bin/gnusocial-delete-domain
  476. echo ' mysql -u root --password="$MARIADB_PASSWORD" -e "$database_query" $database_name' >> /usr/bin/gnusocial-delete-domain
  477. echo ' fi' >> /usr/bin/gnusocial-delete-domain
  478. echo ' ctr=$((ctr + 1))' >> /usr/bin/gnusocial-delete-domain
  479. echo 'done' >> /usr/bin/gnusocial-delete-domain
  480. chmod +x /usr/bin/gnusocial-delete-domain
  481. echo '#!/bin/bash' > /usr/bin/${database_name}-firewall
  482. echo '' >> /usr/bin/${database_name}-firewall
  483. echo "PROJECT_NAME=$PROJECT_NAME" >> /usr/bin/${database_name}-firewall
  484. echo "GNUSOCIAL_DOMAIN_NAME=$gnusoc_domain" >> /usr/bin/${database_name}-firewall
  485. echo "database_name=$database_name" >> /usr/bin/${database_name}-firewall
  486. echo 'FIREWALL_DOMAINS=$HOME/${PROJECT_NAME}-firewall-domains.cfg' >> /usr/bin/${database_name}-firewall
  487. echo '' >> /usr/bin/${database_name}-firewall
  488. echo 'while read block; do' >> /usr/bin/${database_name}-firewall
  489. echo ' if [[ "$block" != *"@"* ]]; then' >> /usr/bin/${database_name}-firewall
  490. echo ' /usr/bin/gnusocial-delete-domain "$database_name" "$block" "$GNUSOCIAL_DOMAIN_NAME"' >> /usr/bin/${database_name}-firewall
  491. echo ' else' >> /usr/bin/${database_name}-firewall
  492. echo ' /usr/bin/gnusocial-delete-user "$database_name" "$block" "$GNUSOCIAL_DOMAIN_NAME"' >> /usr/bin/${database_name}-firewall
  493. echo ' fi' >> /usr/bin/${database_name}-firewall
  494. echo 'done <$FIREWALL_DOMAINS' >> /usr/bin/${database_name}-firewall
  495. echo '' >> /usr/bin/${database_name}-firewall
  496. echo '# remove any metadata from images uploaded in the last 2 minutes' >> /usr/bin/${database_name}-firewall
  497. echo 'if [ -d /var/www/$GNUSOCIAL_DOMAIN_NAME/htdocs ]; then' >> /usr/bin/${database_name}-firewall
  498. echo ' cd /var/www/$GNUSOCIAL_DOMAIN_NAME/htdocs' >> /usr/bin/${database_name}-firewall
  499. echo ' declare -a recent_image=$(find file ! -name thumb-* -mmin -2 -type f -exec ls -l {} + | awk -F '"'"'file/'"'"' '"'"'{print $2}'"'"')' >> /usr/bin/${database_name}-firewall
  500. echo ' for f in ${recent_image[@]}' >> /usr/bin/${database_name}-firewall
  501. echo ' do' >> /usr/bin/${database_name}-firewall
  502. echo ' if [ ${#f} -gt 1 ]; then' >> /usr/bin/${database_name}-firewall
  503. echo ' exiftool -q -all= "file/${f}"' >> /usr/bin/${database_name}-firewall
  504. echo ' fi' >> /usr/bin/${database_name}-firewall
  505. echo ' done' >> /usr/bin/${database_name}-firewall
  506. echo 'fi' >> /usr/bin/${database_name}-firewall
  507. chmod +x /usr/bin/${database_name}-firewall
  508. if ! grep -q "${database_name}-firewall" /etc/crontab; then
  509. echo "*/1 * * * * root /usr/bin/${database_name}-firewall" >> /etc/crontab
  510. fi
  511. }
  512. function expire_gnusocial_posts {
  513. domain_name=$1
  514. gnusocial_type=$2
  515. expire_months=$3
  516. if [ ! $expire_months ]; then
  517. expire_months=3
  518. fi
  519. expire_days=$((expire_months * 30))
  520. # To prevent the database size from growing endlessly this script expires posts
  521. # after a number of months
  522. if [ ! -d /var/www/${domain_name}/htdocs ]; then
  523. return
  524. fi
  525. gnusocial_expire_posts_script=/usr/bin/${gnusocial_type}-expire-posts
  526. echo '<?php' > $gnusocial_expire_posts_script
  527. echo '' >> $gnusocial_expire_posts_script
  528. echo "// ${gnusocial_type} post expiry script, based on StatExpire by Tony Baldwin" >> $gnusocial_expire_posts_script
  529. echo '// https://github.com/tonybaldwin/statexpire' >> $gnusocial_expire_posts_script
  530. echo '' >> $gnusocial_expire_posts_script
  531. echo "\$oldate=date((\"Y-m-d\"), strtotime(\"-${expire_months} months\"));" >> $gnusocial_expire_posts_script
  532. echo '$username="root";' >> $gnusocial_expire_posts_script
  533. echo "\$password=shell_exec('${PROJECT_NAME}-pass -u root -a mariadb');" >> $gnusocial_expire_posts_script
  534. echo "\$database=\"${gnusocial_type}\";" >> $gnusocial_expire_posts_script
  535. echo '' >> $gnusocial_expire_posts_script
  536. echo 'if (!$link = mysql_connect("localhost", $username, $password)) {' >> $gnusocial_expire_posts_script
  537. echo ' echo "Could not connect to mariadb";' >> $gnusocial_expire_posts_script
  538. echo ' exit;' >> $gnusocial_expire_posts_script
  539. echo '}' >> $gnusocial_expire_posts_script
  540. echo '' >> $gnusocial_expire_posts_script
  541. echo 'if (!mysql_select_db($database, $link)) {' >> $gnusocial_expire_posts_script
  542. echo " echo \"Could not select ${gnusocial_type} database\";" >> $gnusocial_expire_posts_script
  543. echo ' exit;' >> $gnusocial_expire_posts_script
  544. echo '}' >> $gnusocial_expire_posts_script
  545. echo '' >> $gnusocial_expire_posts_script
  546. echo "\$notice_query=\"DELETE FROM notice WHERE created <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_posts_script
  547. echo "\$conversation_query=\"DELETE FROM conversation WHERE created <= '$oldate 01:01:01'\";" >> $gnusocial_expire_posts_script
  548. echo "\$reply_query=\"DELETE FROM reply WHERE modified <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_posts_script
  549. echo "\$notification_query=\"DELETE FROM qvitternotification WHERE created <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_posts_script
  550. echo '' >> $gnusocial_expire_posts_script
  551. echo 'mysql_query($notice_query);' >> $gnusocial_expire_posts_script
  552. echo '$rowaff1=mysql_affected_rows();' >> $gnusocial_expire_posts_script
  553. echo 'mysql_query($conversation_query);' >> $gnusocial_expire_posts_script
  554. echo '$rowaff2=mysql_affected_rows();' >> $gnusocial_expire_posts_script
  555. echo 'mysql_query($reply_query);' >> $gnusocial_expire_posts_script
  556. echo '$rowaff3=mysql_affected_rows();' >> $gnusocial_expire_posts_script
  557. echo 'mysql_query($notification_query);' >> $gnusocial_expire_posts_script
  558. echo '$rowaff4=mysql_affected_rows();' >> $gnusocial_expire_posts_script
  559. echo 'mysql_close();' >> $gnusocial_expire_posts_script
  560. echo '' >> $gnusocial_expire_posts_script
  561. echo -n "echo \"Expire ${gnusocial_type} posts: " >> $gnusocial_expire_posts_script
  562. echo '$rowaff1 notices, $rowaff2 conversations, $rowaff3 replies, and $rowaff4 qvitter notifications deleted from database.\n";' >> $gnusocial_expire_posts_script
  563. chmod +x $gnusocial_expire_posts_script
  564. gnusocial_expire_script=/usr/bin/${gnusocial_type}-expire
  565. echo '#!/bin/bash' > $gnusocial_expire_script
  566. echo "/usr/bin/php $gnusocial_expire_posts_script" >> $gnusocial_expire_script
  567. echo "find /var/www/${domain_name}/htdocs/file/* -mtime +${expire_days} -exec rm {} +" >> $gnusocial_expire_script
  568. chmod +x $gnusocial_expire_script
  569. # Add a cron job
  570. if ! grep -q "${gnusocial_expire_script}" /etc/crontab; then
  571. echo "10 3 5 * * root /usr/bin/timeout 500 ${gnusocial_expire_script}" >> /etc/crontab
  572. fi
  573. # remove old expire script
  574. if [ -f /etc/cron.weekly/clear-${gnusocial_type}-database ]; then
  575. rm /etc/cron.weekly/clear-${gnusocial_type}-database
  576. fi
  577. }
  578. function gnusocial_use_classic {
  579. database_name=$1
  580. domain_name=$(get_completion_param "$database_name domain")
  581. if [ -f /var/www/$domain_name/htdocs/index_qvitter.php ]; then
  582. mv /var/www/$domain_name/htdocs/index_qvitter.php /var/www/$domain_name/htdocs/index.php
  583. fi
  584. if [ -f /etc/nginx/sites-available/$domain_name ]; then
  585. sed -i 's|index_qvitter.php|index.php|g' /etc/nginx/sites-available/$domain_name
  586. sed -i 's|index.html|index.php|g' /etc/nginx/sites-available/$domain_name
  587. fi
  588. if ! grep -q "//addPlugin('Qvitter')" /var/www/$domain_name/htdocs/config.php; then
  589. sed -i "s|// addPlugin('Qvitter')|addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  590. sed -i "s|addPlugin('Qvitter')|//addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  591. fi
  592. systemctl restart nginx
  593. }
  594. function gnusocial_use_qvitter {
  595. database_name=$1
  596. domain_name=$(get_completion_param "$database_name domain")
  597. if [ -f /var/www/$domain_name/htdocs/index_qvitter.php ]; then
  598. mv /var/www/$domain_name/htdocs/index_qvitter.php /var/www/$domain_name/htdocs/index.php
  599. fi
  600. if [ -f /etc/nginx/sites-available/$domain_name ]; then
  601. sed -i 's|index_qvitter.php|index.php|g' /etc/nginx/sites-available/$domain_name
  602. sed -i 's|index.html|index.php|g' /etc/nginx/sites-available/$domain_name
  603. fi
  604. if grep -q "//addPlugin('Qvitter')" /var/www/$domain_name/htdocs/config.php; then
  605. sed -i "s|//addPlugin('Qvitter')|addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  606. fi
  607. if grep -q "// addPlugin('Qvitter')" /var/www/$domain_name/htdocs/config.php; then
  608. sed -i "s|// addPlugin('Qvitter')|addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  609. fi
  610. systemctl restart nginx
  611. }
  612. function gnusocial_use_pleroma {
  613. database_name=$1
  614. domain_name=$(get_completion_param "$database_name domain")
  615. if [ ! -d /var/www/$domain_name/htdocs/static ]; then
  616. return
  617. fi
  618. if [ -f /var/www/$domain_name/htdocs/index.php ]; then
  619. mv /var/www/$domain_name/htdocs/index.php /var/www/$domain_name/htdocs/index_qvitter.php
  620. fi
  621. if [ -f /etc/nginx/sites-available/$domain_name ]; then
  622. sed -i 's|index.php|index_qvitter.php|g' /etc/nginx/sites-available/$domain_name
  623. sed -i 's|index index_qvitter.php|index index.html|g' /etc/nginx/sites-available/$domain_name
  624. fi
  625. if grep -q "//addPlugin('Qvitter')" /var/www/$domain_name/htdocs/config.php; then
  626. sed -i "s|//addPlugin('Qvitter')|addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  627. fi
  628. if grep -q "// addPlugin('Qvitter')" /var/www/$domain_name/htdocs/config.php; then
  629. sed -i "s|// addPlugin('Qvitter')|addPlugin('Qvitter')|g" /var/www/$domain_name/htdocs/config.php
  630. fi
  631. systemctl restart nginx
  632. }
  633. # NOTE: deliberately there is no "exit 0"