Mail those more than six months inactive users of your Mastodon server and delete them from your database if they don't reply after 30 days of receiving this warning email.
Anar al arxiu
2019-11-30 14:36:53 +01:00
db-setup.py first commit 2019-11-30 14:07:16 +01:00
mailing.py first commit 2019-11-30 14:07:16 +01:00
README.md Updated README.md 2019-11-30 14:36:53 +01:00
setup.py first commit 2019-11-30 14:07:16 +01:00

mailing

Mail your Mastodon server inactive users and track their feedback.

This code written in Python get all more than a year inactive users from Mastodon's database and email them with the subject and message of your choice. Emailed inactive users data are stored into new Postgresql database to track feedback and status. Run mailing.py periodically to catch 'new' inactive users and uptade the elapsed days of the already emailed ones.

Dependencies

  • Python 3
  • Postgresql server
  • Everything else at the top of mailing.py!

Usage:

Within Python Virtual Environment:

  1. Run 'db-setup.py' to set database parameters and create needed database and table. All collected data of inactive users (see point 3) will be written there.

  2. Run 'setup.py' to set your SMTP parameters and desired email subject. They will be saved to 'secrets/secrets.txt' for further use.

  3. Run 'mailing.py' to start emailing your inactive users (last sign in at older that a year). Their username, account_id, email, delivery status (True if successful) and delivery date will be written to Postgresql database. There is another column, 'deleted', False by default. Will be useful to track deleted/not deleted inactive users if you choose to do so.

  4. Use your favourite scheduling method to set mailing.py to run regularly. Column 'elapsed_days' of mailing's database will be updated so you can decide actions after some time.

Note: install all needed packages with 'pip install package'