Friendica Communications Platform (please note that this is a clone of the repository at github, issues are handled there) https://friendi.ca
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

109 lines
4.1KB

  1. #!/bin/bash
  2. #Script to setup the vagrant instance for running friendica
  3. #
  4. #DO NOT RUN on your physical machine as this won't be of any use
  5. #and f.e. deletes your /var/www/ folder!
  6. echo "Friendica configuration settings"
  7. sudo apt-get update
  8. # Install virtualbox guest additions
  9. sudo apt-get install virtualbox-guest-x11
  10. #Selfsigned cert
  11. echo ">>> Installing *.xip.io self-signed SSL"
  12. SSL_DIR="/etc/ssl/xip.io"
  13. DOMAIN="*.xip.io"
  14. EXTRADOMAIN="friendica.local"
  15. PASSPHRASE="vaprobash"
  16. SUBJ="
  17. C=US
  18. ST=Connecticut
  19. O=Vaprobash
  20. localityName=New Haven
  21. commonName=$DOMAIN
  22. subjectAltName=DNS:$EXTRADOMAIN
  23. organizationalUnitName=
  24. emailAddress=
  25. "
  26. sudo mkdir -p "$SSL_DIR"
  27. sudo openssl genrsa -out "$SSL_DIR/xip.io.key" 4096
  28. sudo openssl req -new -subj "$(echo -n "$SUBJ" | tr "\n" "/")" -key "$SSL_DIR/xip.io.key" -out "$SSL_DIR/xip.io.csr" -passin pass:$PASSPHRASE
  29. sudo openssl x509 -req -days 365 -in "$SSL_DIR/xip.io.csr" -signkey "$SSL_DIR/xip.io.key" -out "$SSL_DIR/xip.io.crt"
  30. #Install apache2
  31. echo ">>> Installing Apache2 webserver"
  32. sudo apt-get install -y apache2
  33. sudo a2enmod rewrite actions ssl
  34. sudo cp /vagrant/bin/dev/vagrant_vhost.sh /usr/local/bin/vhost
  35. sudo chmod guo+x /usr/local/bin/vhost
  36. sudo vhost -s 192.168.22.10.xip.io -d /var/www -p /etc/ssl/xip.io -c xip.io -a friendica.local
  37. sudo a2dissite 000-default
  38. sudo service apache2 restart
  39. #Install php
  40. echo ">>> Installing PHP7"
  41. sudo apt-get install -y php libapache2-mod-php php-cli php-mysql php-curl php-gd php-mbstring php-xml imagemagick php-imagick php-zip
  42. sudo systemctl restart apache2
  43. #Install mysql
  44. echo ">>> Installing Mysql"
  45. sudo debconf-set-selections <<< "mariadb-server mariadb-server/root_password password root"
  46. sudo debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password root"
  47. sudo apt-get install -qq mariadb-server
  48. # enable remote access
  49. # setting the mysql bind-address to allow connections from everywhere
  50. sed -i "s/bind-address.*/bind-address = 0.0.0.0/" /etc/mysql/my.cnf
  51. # adding grant privileges to mysql root user from everywhere
  52. # thx to http://stackoverflow.com/questions/7528967/how-to-grant-mysql-privileges-in-a-bash-script for this
  53. MYSQL=`which mysql`
  54. Q1="GRANT ALL ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;"
  55. Q2="FLUSH PRIVILEGES;"
  56. SQL="${Q1}${Q2}"
  57. $MYSQL -uroot -proot -e "$SQL"
  58. # add a separate database user for friendica
  59. $MYSQL -uroot -proot -e "CREATE USER 'friendica'@'localhost' identified by 'friendica';"
  60. $MYSQL -uroot -proot -e "GRANT ALL PRIVILEGES ON friendica.* TO 'friendica'@'localhost';"
  61. $MYSQL -uroot -proot -e "FLUSH PRIVILEGES"
  62. systemctl restart mysql
  63. #configure rudimentary mail server (local delivery only)
  64. #add Friendica accounts for local user accounts, use email address like vagrant@friendica.local, read the email with 'mail'.
  65. debconf-set-selections <<< "postfix postfix/mailname string friendica.local"
  66. debconf-set-selections <<< "postfix postfix/main_mailer_type string 'Local Only'"
  67. sudo apt-get install -y postfix mailutils libmailutils-dev
  68. sudo echo -e "friendica1: vagrant\nfriendica2: vagrant\nfriendica3: vagrant\nfriendica4: vagrant\nfriendica5: vagrant" >> /etc/aliases && sudo newaliases
  69. # Friendica needs git for fetching some dependencies
  70. sudo apt-get install -y git
  71. #make the vagrant directory the docroot
  72. sudo rm -rf /var/www/
  73. sudo ln -fs /vagrant /var/www
  74. # install deps with composer
  75. sudo apt install unzip
  76. cd /var/www
  77. sudo -u www-data php bin/composer.phar install
  78. # initial config file for friendica in vagrant
  79. cp /vagrant/mods/local.config.vagrant.php /vagrant/config/local.config.php
  80. # copy the .htaccess-dist file to .htaccess so that rewrite rules work
  81. cp /vagrant/.htaccess-dist /vagrant/.htaccess
  82. # create the friendica database
  83. echo "create database friendica DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci" | $MYSQL -u root -proot
  84. # import test database
  85. $MYSQL -uroot -proot friendica < /vagrant/friendica_test_data.sql
  86. # create cronjob - activate if you have enough memory in you dev VM
  87. echo "*/10 * * * * cd /vagrant; /usr/bin/php bin/worker.php" >> friendicacron
  88. sudo crontab friendicacron
  89. sudo rm friendicacron
  90. # friendica needs write access to /tmp
  91. sudo chmod 777 /tmp