blob: 77cde19907e5e009887775179d6314755e14238d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
#! /usr/bin/env bash
#
# This script install all dependencies and configure Newspipe.
# Usage:
# ./install.sh (sqlite|postgres)
#
sudo apt-get install npm
poetry install
npm install
cp newspipe/conf/conf.cfg-sample newspipe/conf/conf.cfg
# Delete default database configuration
sed -i '/database/d' newspipe/conf/conf.cfg
sed -i '/database_url/d' newspipe/conf/conf.cfg
# Configuration of the database
if [ "$1" == postgres ]; then
echo "Installing requirements for PostgreSQL..."
sudo apt-get install -y postgresql > /dev/null
echo "Configuring the database..."
echo "127.0.0.1:5433:aggregator:pgsqluser:pgsqlpwd" > ~/.pgpass
chmod 0600 ~/.pgpass
sudo -u postgres createuser pgsqluser --no-superuser --createdb --no-createrole
sudo -u postgres createdb aggregator --no-password
echo "ALTER USER pgsqluser WITH ENCRYPTED PASSWORD 'pgsqlpwd';" | sudo -u postgres psql
echo "GRANT ALL PRIVILEGES ON DATABASE aggregator TO pgsqluser;" | sudo -u postgres psql
# Add configuration lines for PostgreSQL
echo '[database]' >> newspipe/conf/conf.cfg
echo 'database_url = postgres://pgsqluser:pgsqlpwd@127.0.0.1:5433/aggregator' >> newspipe/conf/conf.cfg
elif [ "$1" == sqlite ]; then
# Add configuration lines for SQLite
echo "Configuring the SQLite database..."
echo '[database]' >> newspipe/conf/conf.cfg
echo 'database_url = sqlite:///newspipe.db' >> newspipe/conf/conf.cfg
fi
poetry shell
echo "Initialization of the database..."
python newspipe/manager.py db_empty
python newspipe/manager.py db_create
echo "Launching Newspipe..."
python newspipe/runserver.py
|