2014-06-20 14:05:44 +00:00
|
|
|
#!/bin/bash
|
2024-08-25 06:45:08 +00:00
|
|
|
# SPDX-FileCopyrightText: 2010-2024 the Friendica project
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
#
|
2021-05-24 15:06:52 +00:00
|
|
|
# Script to setup the vagrant instance for running friendica
|
2014-06-20 14:05:44 +00:00
|
|
|
#
|
2021-05-24 15:06:52 +00:00
|
|
|
# DO NOT RUN on your physical machine as this won't be of any use
|
|
|
|
# and f.e. deletes your /var/www/ folder!
|
|
|
|
#
|
|
|
|
# Run as root by vagrant
|
|
|
|
#
|
|
|
|
##
|
|
|
|
|
|
|
|
ADMIN_NICK="admin"
|
|
|
|
ADMIN_PASSW="admin"
|
2014-09-15 17:48:47 +00:00
|
|
|
|
2021-05-24 15:06:52 +00:00
|
|
|
USER_NICK="user"
|
|
|
|
USER_PASSW="user"
|
|
|
|
|
|
|
|
##
|
|
|
|
|
|
|
|
echo "Friendica configuration settings"
|
|
|
|
apt-get update
|
2017-09-06 08:00:06 +00:00
|
|
|
|
2014-09-15 17:48:47 +00:00
|
|
|
#Selfsigned cert
|
|
|
|
echo ">>> Installing *.xip.io self-signed SSL"
|
|
|
|
SSL_DIR="/etc/ssl/xip.io"
|
|
|
|
DOMAIN="*.xip.io"
|
2018-03-23 15:12:11 +00:00
|
|
|
EXTRADOMAIN="friendica.local"
|
2014-09-15 17:48:47 +00:00
|
|
|
PASSPHRASE="vaprobash"
|
|
|
|
SUBJ="
|
2019-11-14 21:36:29 +00:00
|
|
|
C=US/
|
|
|
|
ST=Connecticut/
|
|
|
|
O=Vaprobash/
|
|
|
|
localityName=New Haven/
|
|
|
|
commonName=$DOMAIN/
|
2018-03-23 15:12:11 +00:00
|
|
|
subjectAltName=DNS:$EXTRADOMAIN
|
2014-09-15 17:48:47 +00:00
|
|
|
"
|
2021-05-24 15:06:52 +00:00
|
|
|
mkdir -p "$SSL_DIR"
|
|
|
|
openssl genrsa -out "$SSL_DIR/xip.io.key" 4096
|
|
|
|
openssl req -new -subj "$(echo -n "$SUBJ" | tr "\n" "/")" -key "$SSL_DIR/xip.io.key" -out "$SSL_DIR/xip.io.csr" -passin pass:$PASSPHRASE
|
|
|
|
openssl x509 -req -days 365 -in "$SSL_DIR/xip.io.csr" -signkey "$SSL_DIR/xip.io.key" -out "$SSL_DIR/xip.io.crt"
|
2014-09-15 17:48:47 +00:00
|
|
|
|
2024-12-30 14:40:33 +00:00
|
|
|
#Install php
|
|
|
|
echo ">>> Add PHP repository"
|
|
|
|
apt-get install -qq -y lsb-release ca-certificates apt-transport-https software-properties-common gnupg
|
|
|
|
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/sury-php.list
|
|
|
|
wget -qO - https://packages.sury.org/php/apt.gpg | sudo gpg --dearmor --yes -o /etc/apt/trusted.gpg.d/spotify.gpg
|
|
|
|
apt update
|
|
|
|
|
|
|
|
echo ">>> Installing PHP8"
|
|
|
|
apt-get install -qq php libapache2-mod-php php8.3-cli php8.3-mysql php8.3-curl php8.3-gd php8.3-mbstring php8.3-xml imagemagick php8.3-imagick php8.3-zip php8.3-gmp php8.3-intl
|
|
|
|
|
|
|
|
echo ">>> Installing PHP7"
|
|
|
|
apt-get install -qq php7.4 php7.4-cli php7.4-mysql php7.4-curl php7.4-gd php7.4-mbstring php7.4-xml php7.4-imagick php7.4-zip php7.4-gmp php7.4-intl
|
2014-09-15 17:48:47 +00:00
|
|
|
|
|
|
|
#Install apache2
|
|
|
|
echo ">>> Installing Apache2 webserver"
|
2021-05-24 15:06:52 +00:00
|
|
|
apt-get install -qq apache2
|
|
|
|
a2enmod rewrite actions ssl
|
|
|
|
cp /vagrant/bin/dev/vagrant_vhost.sh /usr/local/bin/vhost
|
|
|
|
chmod guo+x /usr/local/bin/vhost
|
2022-10-15 15:31:57 +00:00
|
|
|
vhost -s 192.168.56.10.xip.io -d /var/www -p /etc/ssl/xip.io -c xip.io -a friendica.local
|
2021-05-24 15:06:52 +00:00
|
|
|
a2dissite 000-default
|
|
|
|
service apache2 restart
|
2014-09-15 17:48:47 +00:00
|
|
|
|
|
|
|
#Install mysql
|
|
|
|
echo ">>> Installing Mysql"
|
2021-05-24 15:06:52 +00:00
|
|
|
debconf-set-selections <<< "mariadb-server mariadb-server/root_password password root"
|
|
|
|
debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password root"
|
|
|
|
apt-get install -qq mariadb-server
|
2014-09-15 17:48:47 +00:00
|
|
|
# enable remote access
|
|
|
|
# setting the mysql bind-address to allow connections from everywhere
|
|
|
|
sed -i "s/bind-address.*/bind-address = 0.0.0.0/" /etc/mysql/my.cnf
|
|
|
|
# adding grant privileges to mysql root user from everywhere
|
|
|
|
# thx to http://stackoverflow.com/questions/7528967/how-to-grant-mysql-privileges-in-a-bash-script for this
|
|
|
|
MYSQL=`which mysql`
|
|
|
|
Q1="GRANT ALL ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;"
|
|
|
|
Q2="FLUSH PRIVILEGES;"
|
|
|
|
SQL="${Q1}${Q2}"
|
|
|
|
$MYSQL -uroot -proot -e "$SQL"
|
2017-10-04 18:25:15 +00:00
|
|
|
# add a separate database user for friendica
|
|
|
|
$MYSQL -uroot -proot -e "CREATE USER 'friendica'@'localhost' identified by 'friendica';"
|
|
|
|
$MYSQL -uroot -proot -e "GRANT ALL PRIVILEGES ON friendica.* TO 'friendica'@'localhost';"
|
|
|
|
$MYSQL -uroot -proot -e "FLUSH PRIVILEGES"
|
2017-09-06 08:00:06 +00:00
|
|
|
systemctl restart mysql
|
2016-11-19 15:08:08 +00:00
|
|
|
|
2014-06-20 14:05:44 +00:00
|
|
|
|
2015-01-30 16:03:42 +00:00
|
|
|
#configure rudimentary mail server (local delivery only)
|
2018-03-23 15:12:11 +00:00
|
|
|
#add Friendica accounts for local user accounts, use email address like vagrant@friendica.local, read the email with 'mail'.
|
2021-05-24 15:06:52 +00:00
|
|
|
echo ">>> Installing 'Local Only' postfix"
|
2018-03-23 15:12:11 +00:00
|
|
|
debconf-set-selections <<< "postfix postfix/mailname string friendica.local"
|
2015-01-30 16:03:42 +00:00
|
|
|
debconf-set-selections <<< "postfix postfix/main_mailer_type string 'Local Only'"
|
2021-05-24 15:06:52 +00:00
|
|
|
apt-get install -qq postfix mailutils libmailutils-dev
|
2021-10-01 08:18:43 +00:00
|
|
|
echo -e "$ADMIN_NICK: vagrant\n$USER_NICK: vagrant" >> /etc/aliases && newaliases
|
2015-01-30 16:03:42 +00:00
|
|
|
|
2019-10-04 09:40:39 +00:00
|
|
|
# Friendica needs git for fetching some dependencies
|
2021-05-24 15:06:52 +00:00
|
|
|
echo ">>> Installing git"
|
|
|
|
apt-get install -qq git
|
2019-10-04 09:40:39 +00:00
|
|
|
|
2014-06-20 14:05:44 +00:00
|
|
|
#make the vagrant directory the docroot
|
2021-05-24 15:06:52 +00:00
|
|
|
echo ">>> Symlink /var/www to /vagrant"
|
|
|
|
rm -rf /var/www/
|
|
|
|
ln -fs /vagrant /var/www
|
2014-06-20 14:05:44 +00:00
|
|
|
|
2021-10-01 08:00:01 +00:00
|
|
|
# Setup Friendica
|
2018-03-23 15:12:11 +00:00
|
|
|
cd /var/www
|
2021-05-24 15:06:52 +00:00
|
|
|
echo ">>> Setup Friendica"
|
2014-06-20 16:32:40 +00:00
|
|
|
|
2018-11-16 22:09:54 +00:00
|
|
|
# copy the .htaccess-dist file to .htaccess so that rewrite rules work
|
|
|
|
cp /vagrant/.htaccess-dist /vagrant/.htaccess
|
|
|
|
|
2015-07-23 20:06:18 +00:00
|
|
|
# create the friendica database
|
2018-03-23 16:16:22 +00:00
|
|
|
echo "create database friendica DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci" | $MYSQL -u root -proot
|
2021-05-24 15:06:52 +00:00
|
|
|
|
|
|
|
# install friendica
|
|
|
|
bin/console autoinstall -f /vagrant/mods/local.config.vagrant.php
|
|
|
|
|
|
|
|
# add users
|
|
|
|
# (disable a bunch of validation because this is a dev install, deh, it needs invalid emails and stupid passwords)
|
|
|
|
bin/console config system disable_email_validation 1
|
|
|
|
bin/console config system disable_password_exposed 1
|
|
|
|
bin/console user add "$ADMIN_NICK" "$ADMIN_NICK" "$ADMIN_NICK@friendica.local" en
|
|
|
|
bin/console user password "$ADMIN_NICK" "$ADMIN_PASSW"
|
|
|
|
bin/console user add "$USER_NICK" "$USER_NICK" "$USER_NICK@friendica.local" en
|
|
|
|
bin/console user password "$USER_NICK" "$USER_PASSW"
|
|
|
|
|
2017-09-06 08:00:06 +00:00
|
|
|
# create cronjob - activate if you have enough memory in you dev VM
|
2021-05-24 15:06:52 +00:00
|
|
|
# cronjob runs as www-data user
|
|
|
|
echo ">>> Installing cronjob"
|
|
|
|
echo "*/10 * * * * www-data cd /vagrant; /usr/bin/php bin/worker.php" >> /etc/cron.d/friendica
|
2014-06-20 14:05:44 +00:00
|
|
|
|
2018-02-23 15:02:37 +00:00
|
|
|
# friendica needs write access to /tmp
|
2021-05-24 15:06:52 +00:00
|
|
|
chmod 777 /tmp
|