2024-03-05 19:54:17 +00:00
# Contents
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
* [Setup Database ](#setup-database )
* [Install Python Libraries ](#install-python-libraries )
2024-03-07 10:51:50 +00:00
* [Install additional requirements ](#install-additional-requirements )
2024-03-05 19:54:17 +00:00
* [Setup pyfedi ](#setup-pyfedi )
* [Setup .env file ](#setup-env-file )
* [Initialise Database and Setup Admin account ](#initialise-database-and-setup-admin-account )
* [Run the app ](#run-the-app )
* [Database Management ](#database-management )
* [Keeping your local instance up to date ](#keeping-your-local-instance-up-to=date )
* [Running PieFed in production ](#running-piefed-in-production )
* [Pre-requisites for Mac OS ](#pre-requisites-for-mac-os )
* [Notes for Windows (WSL2) ](#notes-for-windows-wsl2 )
* [Notes for Pip Package Management ](#notes-for-pip-package-management )
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
< div id = "setup-database" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Setup Database
2023-08-29 22:01:06 +12:00
2024-03-23 21:23:38 +13:00
#### Install postgresql
PieFed should work on version 13.x or newer. If you have errors running `flask init-db` , check your postrgesql version.
##### Install postgresql 16:
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
For installation environments that use `apt` as a package manager:
```bash
sudo apt install ca-certificates pkg-config
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main" >> /etc/apt/sources.list.d/pgdg.list'
sudo apt update
sudo apt install libpq-dev postgresql
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
#### Create new DB user
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
Choose a username and password. To use 'pyfedi' for both:
2024-03-31 12:39:52 +01:00
```bash
sudo -iu postgres psql -c "CREATE USER pyfedi WITH PASSWORD 'pyfedi';"
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
#### Create new database
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
Choose a database name, owned by your new user. For a database called and owned by 'pyfedi':
2024-03-31 12:39:52 +01:00
```bash
sudo -iu postgres psql -c "CREATE DATABASE pyfedi WITH OWNER pyfedi;"
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
< div id = "install-python-libraries" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Install Python Libraries
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
[Pre-requisites for Mac OS ](#pre-requisites-for-mac-os )
[Notes for Windows (WSL2) ](#notes-for-windows-wsl2 )
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
For installation environments that use `apt` as a package manager:
```bash
sudo apt install python3-pip python3-venv python3-dev python3-psycopg2
```
2023-08-29 22:01:06 +12:00
2024-03-07 10:51:50 +00:00
< div id = "install-additional-requirements" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-07 10:51:50 +00:00
## Install additional requirements
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
For installation environments that use 'apt' as a package manager:
```bash
sudo apt install redis-server
sudo apt install git
sudo apt install tesseract-ocr
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
< div id = "setup-pyfedi" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Setup PyFedi
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
* Clone PyFedi
2024-04-15 22:08:38 +01:00
```bash
2024-03-31 12:39:52 +01:00
git clone https://codeberg.org/rimu/pyfedi.git
```
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
* cd into pyfedi, set up and enter virtual environment
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
```bash
cd pyfedi
python3 -m venv ./venv
source venv/bin/activate
```
* Use pip to install requirements
```bash
pip install wheel
pip install -r requirements.txt
```
2024-03-05 19:54:17 +00:00
(see [Notes for Windows (WSL2) ](#windows-wsl2 ) if appropriate)
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
< div id = "setup-env-file" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Setup .env file
2024-03-31 12:39:52 +01:00
* Copy `env.sample` to `.env`
* Edit `.env` to suit your server.
* Using the same username, password, and database name as used when setting up database, set the connection up, something like this:
```
2024-02-08 08:13:49 +13:00
DATABASE_URL=postgresql+psycopg2://username:password@localhost/database_name
2024-03-31 12:39:52 +01:00
```
* Also change `SECRET_KEY` to some random sequence of numbers and letters.
2024-04-01 20:29:15 +01:00
2024-02-08 08:13:49 +13:00
2024-03-31 12:39:52 +01:00
### Extra info
2024-08-09 18:30:02 -04:00
2024-03-31 12:39:52 +01:00
* `SERVER_NAME` should be the domain of the site/instance. Use `127.0.0.1:5000` during development unless using ngrok.
2024-04-01 20:29:15 +01:00
* `RECAPTCHA_PUBLIC_KEY` and `RECAPTCHA_PRIVATE_KEY` can be generated at https://www.google.com/recaptcha/admin/create (this is optional - omit to allow registration without RECAPCHA).
2024-03-31 12:39:52 +01:00
* `CACHE_TYPE` can be `FileSystemCache` or `RedisCache` . `FileSystemCache` is fine during development (set `CACHE_DIR` to `/tmp/piefed` or `/dev/shm/piefed` )
2024-04-04 21:36:03 +13:00
while `RedisCache` **should** be used in production. If using `RedisCache` , set `CACHE_REDIS_URL` to `redis://localhost:6379/1` . Visit https://yourdomain/testredis to check if your redis url is working.
2024-02-08 08:13:49 +13:00
2024-03-31 12:39:52 +01:00
* `CELERY_BROKER_URL` is similar to `CACHE_REDIS_URL` but with a different number on the end: `redis://localhost:6379/0`
2024-02-08 08:13:49 +13:00
2024-03-31 12:39:52 +01:00
* `MAIL_*` is for sending email using a SMTP server. Leave `MAIL_SERVER` empty to send email using AWS SES instead.
2024-02-08 08:13:49 +13:00
2024-03-31 12:39:52 +01:00
* `AWS_REGION` is the name of the AWS region where you chose to set up SES, if using SES. [SES credentials are stored in `~/.aws/credentials` ](https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html ). That file has a format like
2024-02-08 08:13:49 +13:00
2024-03-31 12:39:52 +01:00
```
[default]
aws_access_key_id = JKJHER*#KJFFF
aws_secret_access_key = /jkhejhkrejhkre
region=ap-southeast-2
```
You can also [use environment variables ](https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html#environment-variables ) if you prefer.
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
* Test email sending by going to https://yourdomain/test_email. It will try to send an email to the current user's email address.
2024-03-01 17:05:43 +13:00
If it does not work check the log file at logs/pyfedi.log for clues.
2024-06-26 20:47:24 +08:00
* BOUNCE_ADDRESS is where email bounces will go to. If BOUNCE_* is configured then all emails in that inbox
will be treated as bounces and deleted after extracting the email addresses in them. Use a dedicated inbox
for bounces, not a inbox you also use for other purposes.
2024-08-09 18:30:02 -04:00
### Development mode
2024-08-12 20:29:15 +12:00
Setting `FLASK_DEBUG=1` in the `.env` file will enable the `<your-site>/dev/tools` page.
2024-08-09 18:30:02 -04:00
That page can be accessed from the `Admin` navigation drop down, or nav bar as `Dev Tools` . That page has buttons that can create/delete communities and topics. The communities and topics will all begin with "dev_".
2024-03-05 19:54:17 +00:00
< div id = "initialise-database-and-setup-admin-account" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Initialise database, and set up admin account
2024-03-24 19:47:51 +13:00
2024-03-31 12:39:52 +01:00
```bash
export FLASK_APP=pyfedi.py
flask db upgrade
flask init-db
```
2024-03-24 19:47:51 +13:00
2024-03-05 19:54:17 +00:00
(choose a new username, email address, and password for your PyFedi admin account)
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
If you see an error message `ModuleNotFoundError: No module named 'flask_babel'` then use `venv/bin/flask` instead of `flask`
2024-03-24 19:47:51 +13:00
for all flask commands.
2024-03-05 19:54:17 +00:00
< div id = "run-the-app" > < / div >
2024-03-01 16:58:04 +13:00
2024-03-31 12:39:52 +01:00
## Run the app
```bash
flask run
```
2024-03-05 19:54:17 +00:00
(open web browser at http://127.0.0.1:5000)
(log in with username and password from admin account)
2024-03-01 16:58:04 +13:00
2024-03-05 19:54:17 +00:00
< div id = "database-management" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Database Management
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
In future if you use git pull and notice some new files in `migrations/versions/*` , you need to do:
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
```bash
source venv/bin/activate #if not already in virtual environment
flask db upgrade
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
#### For Database changes:
2023-08-29 22:01:06 +12:00
2024-03-31 12:39:52 +01:00
create a migration based on recent changes to `app/models.py` :
```bash
flask db migrate -m "users table"
```
2024-03-05 19:54:17 +00:00
run migrations:
2024-03-31 12:39:52 +01:00
```bash
flask db upgrade
```
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
< div id = "keeping-your-local-instance-up-to=date" > < / div >
2023-08-29 22:01:06 +12:00
2024-03-05 19:54:17 +00:00
## Keeping your local instance up to date
2023-08-29 22:01:06 +12:00
2024-02-08 08:39:08 +13:00
In a development environment, all you need to do is
2024-03-31 12:39:52 +01:00
```bash
git pull
flask db upgrade
```
2024-02-08 08:39:08 +13:00
In production, celery and flask run as background services so they need to be restarted manually. Run the `./deploy.sh` script
to easily restart services at the same time as pulling down changes from git, etc.
2024-03-05 19:54:17 +00:00
< div id = "federation-during-development" > < / div >
## Federation during development
2024-02-07 15:00:20 +13:00
Federation doesn't work without SSL, without a domain name or without your server being accessible from outside your network. So, when running on http://127.0.0.1:5000 you have none of those.
The site will still run without federation. You can create local communities and post in them...
2024-03-05 19:54:17 +00:00
My way around this is to use ngrok.com, which is a quick and simple way to create a temporary VPN with a domain and SSL. The free plan comes with ephermeral domain names that change every few days, which will break federation, or one randomly-named static domain that will need re-launching every few days. $10 per month will get you https://yourwhatever.ngrok.app which won't change.
2024-02-07 15:02:09 +13:00
2024-08-16 11:48:56 +12:00
Once you have ngrok working, edit the `.env` file and change the `SERVER_NAME` variable to your new domain name (all lower case).
2024-02-07 15:02:09 +13:00
2024-03-05 19:54:17 +00:00
< div id = "running-piefed-in-production" > < / div >
## Running PieFed in production
2024-04-16 14:34:22 +02:00
Running PieFed in production relies on several additional packages that need to be installed.
```bash
source venv/bin/activate #if not already in virtual environment
pip3 install gunicorn celery
```
2024-03-31 12:39:52 +01:00
Copy `celery_worker.default.py` to `celery_worker.py` . Edit `DATABASE_URL` and `SERVER_NAME` to have the same values as in `.env` .
2024-02-08 08:39:08 +13:00
2024-03-31 12:39:52 +01:00
Edit `gunicorn.conf.py` and change `worker_tmp_dir` if needed.
2024-02-08 08:39:08 +13:00
2024-02-08 12:46:48 +13:00
You will want to [tune PostgreSQL ](https://pgtune.leopard.in.ua/ ). [More on this ](https://www.enterprisedb.com/postgres-tutorials/how-tune-postgresql-memory ).
If you have more than 4 GB of RAM, consider [turning on 'huge pages' ](https://www.percona.com/blog/why-linux-hugepages-are-super-important-for-database-servers-a-case-with-postgresql/ )
also [see this ](https://pganalyze.com/blog/5mins-postgres-tuning-huge-pages ).
2024-02-08 08:39:08 +13:00
2024-03-31 12:39:52 +01:00
[PgBouncer ](https://www.pgbouncer.org ) can be helpful in a high traffic situation.
2024-02-08 08:39:08 +13:00
2024-08-01 16:24:36 +08:00
To assess whether to accept a registration application it can be helpful to know the country of the applicant. This can be
automatically discovered by using [the ipinfo service ](https://ipinfo.io/ ) - register with them to get an API token and put it into your .env file.
2024-03-05 19:54:17 +00:00
< div id = "background-services" > < / div >
2024-03-01 22:11:06 +13:00
2024-03-05 19:54:17 +00:00
### Background services
2024-03-01 22:11:06 +13:00
2024-02-08 08:39:08 +13:00
Gunicorn and Celery need to run as background services:
2024-03-05 19:54:17 +00:00
#### Gunicorn
2024-02-08 08:39:08 +13:00
Create a new file:
2024-03-31 12:39:52 +01:00
```bash
sudo nano /etc/systemd/system/pyfedi.service
```
2024-02-08 08:39:08 +13:00
Add the following to the new file, altering paths as appropriate for your install location
2024-03-31 12:39:52 +01:00
```
[Unit]
Description=Gunicorn instance to serve PieFed application
After=network.target
[Service]
User=rimu
Group=rimu
WorkingDirectory=/home/rimu/pyfedi/
Environment="PATH=/home/rimu/pyfedi/venv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin"
ExecStart=/home/rimu/pyfedi/venv/bin/gunicorn --config gunicorn.conf.py --preload pyfedi:app
ExecReload=/bin/kill -HUP $MAINPID
Restart=always
[Install]
WantedBy=multi-user.target
```
2024-02-08 08:39:08 +13:00
2024-03-05 19:54:17 +00:00
#### Celery
2024-02-08 08:39:08 +13:00
Create another file:
2024-03-31 12:39:52 +01:00
```bash
sudo nano /etc/systemd/system/celery.service
```
2024-02-08 08:39:08 +13:00
Add the following, altering as appropriate
2024-03-31 12:39:52 +01:00
```
[Unit]
Description=Celery Service
After=network.target
[Service]
Type=forking
User=rimu
Group=rimu
EnvironmentFile=/etc/default/celeryd
WorkingDirectory=/home/rimu/pyfedi
ExecStart=/bin/sh -c '${CELERY_BIN} multi start -A ${CELERY_APP} ${CELERYD_NODES} --pidfile=${CELERYD_PID_FILE} \
--logfile=${CELERYD_LOG_FILE} ${CELERYD_OPTS}'
ExecStop=/bin/sh -c '${CELERY_BIN} multi stopwait ${CELERYD_NODES} --pidfile=${CELERYD_PID_FILE}'
ExecReload=/bin/sh -c '${CELERY_BIN} multi restart -A ${CELERY_APP} ${CELERYD_NODES} --pidfile=${CELERYD_PID_FILE} \
--logfile=${CELERYD_LOG_FILE} ${CELERYD_OPTS}'
[Install]
WantedBy=multi-user.target
```
2024-02-08 08:39:08 +13:00
Create another file:
2024-03-31 12:39:52 +01:00
```
sudo nano /etc/default/celeryd
```
2024-02-08 08:39:08 +13:00
Contents (change paths to suit):
2024-03-31 12:39:52 +01:00
```
# The names of the workers. This example creates one workers
CELERYD_NODES="worker1"
# The name of the Celery App, should be the same as the python file
# where the Celery tasks are defined
CELERY_APP="celery_worker.celery"
# Log and PID directories
CELERYD_LOG_FILE="/var/log/celery/%n%I.log"
CELERYD_PID_FILE="/dev/shm/celery/%n.pid"
# Log level
CELERYD_LOG_LEVEL=INFO
# Path to celery binary, that is in your virtual environment
CELERY_BIN=/home/rimu/pyfedi/venv/bin/celery
2024-06-14 21:33:20 +08:00
CELERYD_OPTS="--autoscale=5,1 --max-tasks-per-child=1000"
2024-03-31 12:39:52 +01:00
```
2024-02-08 08:39:08 +13:00
2024-03-05 19:54:17 +00:00
#### Enable and start background services
2024-02-08 08:39:08 +13:00
2024-03-31 12:39:52 +01:00
```bash
sudo systemctl enable pyfedi.service
sudo systemctl enable celery.service
2024-02-08 08:39:08 +13:00
2024-03-31 12:39:52 +01:00
sudo systemctl start pyfedi.service
sudo systemctl start celery.service
```
2024-02-08 08:39:08 +13:00
Check status of services:
2024-03-31 12:39:52 +01:00
```bash
sudo systemctl status pyfedi.service
sudo systemctl status celery.service
```
2024-02-08 08:39:08 +13:00
Inspect log files at:
2024-02-07 15:00:20 +13:00
2024-03-31 12:39:52 +01:00
* `/var/log/celery/*`
* `/var/log/nginx/*`
* `/your_piefed_installation/logs/pyfedi.log`
2024-02-27 07:06:04 +13:00
2024-03-05 19:54:17 +00:00
### Nginx
2024-02-27 07:06:04 +13:00
You need a reverse proxy that sends all traffic to port 5000. Something like:
2024-03-31 12:39:52 +01:00
```
upstream app_server {
# fail_timeout=0 means we always retry an upstream even if it failed
# to return a good HTTP response
# for UNIX domain socket setups
# server unix:/tmp/gunicorn.sock fail_timeout=0;
# for a TCP configuration
server 127.0.0.1:5000 fail_timeout=0;
keepalive 4;
}
server {
server_name piefed.social
root /whatever
2024-07-15 16:27:35 +08:00
keepalive_timeout 30;
2024-03-31 12:39:52 +01:00
ssi off;
location / {
# Proxy all requests to Gunicorn
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_pass http://app_server;
2024-02-27 07:06:04 +13:00
ssi off;
}
2024-07-15 16:27:35 +08:00
# Serve static files directly with nginx
location /static/ {
alias /whatever/app/static/;
expires max;
access_log off;
}
2024-03-31 12:39:52 +01:00
}
```
2024-02-27 07:06:04 +13:00
2024-04-02 12:38:59 +13:00
**_The above is not a complete configuration_** - you will want to add more settings for SSL, etc. See also
https://codeberg.org/rimu/pyfedi/issues/136#issuecomment -1726739
2024-02-27 07:06:04 +13:00
2024-03-05 19:54:17 +00:00
### Cron tasks
2024-03-01 22:11:06 +13:00
2024-03-31 12:39:52 +01:00
To send email reminders about unread notifications, put this in a new file under `/etc/cron.d`
2024-03-01 22:11:06 +13:00
```
1 */6 * * * rimu cd /home/rimu/pyfedi && /home/rimu/pyfedi/email_notifs.sh
```
2024-03-31 12:39:52 +01:00
Change `/home/rimu/pyfedi` to the location of your installation and change `rimu` to the user that piefed runs as.
2024-03-01 22:11:06 +13:00
2024-03-31 12:39:52 +01:00
Once a week or so it's good to run `remove_orphan_files.sh` to save disk space:
2024-03-01 22:11:06 +13:00
```
5 4 * * 1 rimu cd /home/rimu/pyfedi && /home/rimu/pyfedi/remove_orphan_files.sh
```
2024-08-18 12:15:49 +12:00
One per day there are some maintenance tasks that PieFed needs to do:
```
5 2 * * * rimu cd /home/rimu/pyfedi && /home/rimu/pyfedi/daily.sh
```
If celery is hanging occasionally, put this script in /etc/cron.hourly:
2024-07-24 07:40:23 +08:00
```
#!/bin/bash
# Define the service to restart
SERVICE="celery.service"
# Get the load average for the last 1 minute
LOAD=$(awk '{print $1}' /proc/loadavg)
# Check if the load average is less than 0.1
if (( $(echo "$LOAD < 0.1 " | bc -l ) ) ) ; then
# Restart the service
systemctl restart $SERVICE
# Log the action
echo "$(date): Load average is $LOAD. Restarted $SERVICE." >> /var/log/restart_service.log
else
# Log that no action was taken
echo "$(date): Load average is $LOAD. No action taken." >> /var/log/restart_service.log
fi
```
Adjust the echo "$LOAD < 0.1 " to suit your system .
2024-03-05 19:54:17 +00:00
### Email
2024-03-04 09:53:02 +13:00
Email can be sent either through SMTP or Amazon web services (SES). SES is faster but PieFed does not send much
email so it probably doesn't matter which method you choose.
2024-03-05 19:54:17 +00:00
#### AWS SES
2024-03-04 09:53:02 +13:00
2024-03-31 12:39:52 +01:00
PieFed uses Amazon's `boto3` module to connect to SES. Boto3 needs to log into AWS and that can be set up using a file
at `~/.aws/credentials` or environment variables. Details at https://boto3.amazonaws.com/v1/documentation/api/latest/guide/credentials.html.
2024-03-04 09:53:02 +13:00
2024-03-31 12:39:52 +01:00
In your `.env` you need to set the AWS region you're using for SES. Something like `AWS_REGION = 'ap-southeast-2'` .
2024-03-04 09:53:02 +13:00
2024-03-23 15:24:34 +13:00
#### CDN
A CDN like Cloudflare is recommended for instances with more than a handful of users. [Recommended caching settings ](https://join.piefed.social/2024/02/20/how-much-difference-does-a-cdn-make-to-a-fediverse-instance/ ).
PieFed has the capability to automatically remove file copies from the Cloudflare cache whenever
2024-03-31 12:39:52 +01:00
those files are deleted from the server. To enable this, set these variables in your `.env` file:
2024-03-23 15:24:34 +13:00
2024-03-31 12:39:52 +01:00
- `CLOUDFLARE_API_TOKEN` - go to https://dash.cloudflare.com/profile/api-tokens and create a "Zone.Cache Purge" token.
- `CLOUDFLARE_ZONE_ID` - this can be found in the right hand column of your Cloudflare dashboard in the API section.
2024-03-23 15:24:34 +13:00
2024-03-05 19:54:17 +00:00
#### SMTP
2024-03-04 09:53:02 +13:00
2024-03-31 12:39:52 +01:00
To use SMTP you need to set all the `MAIL_*` environment variables in you `.env` file. See `env.sample` for a list of them.
2024-03-04 09:53:02 +13:00
2024-03-05 19:54:17 +00:00
#### Testing email
2024-03-04 09:53:02 +13:00
2024-03-31 12:39:52 +01:00
You need to set `MAIL_FROM` in `.env` to some email address.
2024-03-04 09:53:02 +13:00
Log into Piefed then go to https://yourdomain/test_email to trigger a test email. It will use SES or SMTP depending on
2024-03-31 12:39:52 +01:00
which environment variables you defined in .env. If `MAIL_SERVER` is empty it will try SES. Then if `AWS_REGION` is empty it'll
2024-03-04 09:53:02 +13:00
silently do nothing.
2024-03-05 19:54:17 +00:00
---
< div id = "pre-requisites-for-mac-os" > < / div >
## Pre-requisites for Mac OS
#### Install Python Version Manager (pyenv)
see this site: https://opensource.com/article/19/5/python-3-default-mac
2024-03-31 12:39:52 +01:00
```bash
brew install pyenv
```
2024-03-05 19:54:17 +00:00
#### Install Python3 version and set as default (with pyenv)
2024-03-31 12:39:52 +01:00
```bash
pyenv install 3.8.6
pyenv global 3.7.3
```
2024-03-05 19:54:17 +00:00
Note..
You may see this error when running `pip install -r requirements.txt` in regards to psycopg2:
ld: library not found for -lssl
clang: error: linker command failed with exit code 1 (use -v to see invocation)
error: command 'clang' failed with exit status 1
If this happens try installing openssl...
Install openssl with brew install openssl if you don't have it already.
`brew install openssl`
Add openssl path to LIBRARY_PATH :
export LIBRARY_PATH=$LIBRARY_PATH:/usr/local/opt/openssl/lib/
---
< div id = "notes-for-windows-wsl2" > < / div >
## Notes for Windows (WSL 2 - Ubuntu 22.04 LTS - Python 3.9.16)
**Important:**
Python 3.10+ or 3.11+ may cause some package or compatibility errors. If you are having issues installing packages from
2024-03-31 12:39:52 +01:00
`requirements.txt` , try using Python 3.8 or 3.9 instead with `pyenv` (https://github.com/pyenv/pyenv).
2024-03-05 19:54:17 +00:00
Follow all the setup instructions in the pyenv documentation and setup any version of either Python 3.8 or 3.9.
If you are getting installation errors or missing packages with pyenv, run
2024-03-31 12:39:52 +01:00
```bash
sudo apt-update
sudo apt install build-essential libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev curl libncursesw5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev libffi-dev liblzma-dev llvm
```
---
2024-03-05 19:54:17 +00:00
#### Install Python 3, pip, and venv
2024-03-31 12:39:52 +01:00
```bash
sudo apt-get update
sudo apt-get upgrade
sudo apt-get install python3 python3-pip ipython3 libpq-dev python3-psycopg2 python3-dev build-essential redis-server
sudo apt-get install python3-venv
```
2024-03-05 19:54:17 +00:00
#### Setup venv first before installing other packages
**Note: **
(Replace < 3.9 > with your version number if you are using another version of Python,
e.g. 'sudo apt-get install python3.10-venv' for Python 3.10. Repeat for the rest of the instructions below.)
2024-03-31 12:39:52 +01:00
```bash
python3.9 -m venv ./venv
source venv/bin/activate
```
2024-03-05 19:54:17 +00:00
Make sure that your venv is also running the correct version of pyenv. You may need to re-setup venv if you setup venv before pyenv.
Follow the package installation instructions above to get the packages
2024-03-31 12:39:52 +01:00
```bash
python3.9 -m pip install --upgrade pip setuptools wheel
pip install -r requirements.txt
```
2024-03-05 19:54:17 +00:00
< div id = "notes-for-pip-package-management" > < / div >
---
## Notes for Pip Package Management:
2024-03-31 12:39:52 +01:00
make sure you have `wheel` installed:
```bash
pip install wheel
```
2024-03-05 19:54:17 +00:00
install packages from a file:
2024-03-31 12:39:52 +01:00
```bash
pip install -r requirements.txt
```
2024-03-05 19:54:17 +00:00
dump currently installed packages to file:
2024-03-31 12:39:52 +01:00
```bash
pip freeze > requirements.txt
```
2024-03-05 19:54:17 +00:00
upgrade a package:
2024-03-31 12:39:52 +01:00
```bash
pip install --upgrade < package_name >
```
2024-03-05 19:54:17 +00:00