diff --git a/app/templates/user/edit_settings.html b/app/templates/user/edit_settings.html index c09748fa..233a1eea 100644 --- a/app/templates/user/edit_settings.html +++ b/app/templates/user/edit_settings.html @@ -37,6 +37,11 @@
Import
{{ render_field(form.import_file) }} {{ render_field(form.submit) }} +
+
Export
+

Export community subscriptions and user settings

+ {{ render_field(form.export_settings) }} +

{{ _('Delete account') }} diff --git a/app/user/forms.py b/app/user/forms.py index 6dd64f7a..4ee33815 100644 --- a/app/user/forms.py +++ b/app/user/forms.py @@ -46,6 +46,7 @@ class SettingsForm(FlaskForm): manually_approves_followers = BooleanField(_l('Manually approve followers')) vote_privately = BooleanField(_l('Vote privately')) import_file = FileField(_l('Import community subscriptions and user blocks from Lemmy')) + export_settings = SubmitField(_l('Export')) sorts = [('hot', _l('Hot')), ('top', _l('Top')), ('new', _l('New')), diff --git a/app/user/routes.py b/app/user/routes.py index 2762ec58..6d70f2de 100644 --- a/app/user/routes.py +++ b/app/user/routes.py @@ -1,8 +1,9 @@ from datetime import datetime, timedelta from time import sleep from random import randint +from io import BytesIO -from flask import redirect, url_for, flash, request, make_response, session, Markup, current_app, abort, json, g +from flask import redirect, url_for, flash, request, make_response, session, Markup, current_app, abort, json, g, send_file from flask_login import login_user, logout_user, current_user, login_required from flask_babel import _, lazy_gettext as _l @@ -28,6 +29,7 @@ from app.utils import get_setting, render_template, markdown_to_html, user_acces blocked_communities from sqlalchemy import desc, or_, text import os +import json as python_json @bp.route('/people', methods=['GET', 'POST']) @@ -227,7 +229,65 @@ def change_settings(): ('de', _l('German')), ('ja', _l('Japanese')), ] - if form.validate_on_submit(): + # seperate if to handle just the 'Export' button being clicked + if form.export_settings.data and form.validate(): + # make the empty dict + user_dict = {} + + # take the current_user already found + # add user's settings to the dict for output + user_dict['user_name'] = user.user_name + user_dict['alt_user_name'] = user.alt_user_name + user_dict['title'] = user.title + user_dict['email'] = user.email + user_dict['about'] = user.about + # user_dict['about_html'] = user.about_html + user_dict['keywords'] = user.keywords + user_dict['matrix_user_id'] = user.matrix_user_id + user_dict['hide_nsfw'] = user.hide_nsfw + user_dict['hide_nsfl'] = user.hide_nsfl + # user_dict['public_key'] = user.public_key + # user_dict['private_key'] = user.private_key + user_dict['receive_message_mode'] = user.receive_message_mode + user_dict['bot'] = user.bot + user_dict['ignore_bots'] = user.ignore_bots + user_dict['default_sort'] = user.default_sort + user_dict['default_filter'] = user.default_filter + user_dict['theme'] = user.theme + user_dict['markdown_editor'] = user.markdown_editor + user_dict['interface_language'] = user.interface_language + user_dict['reply_collapse_threshold'] = user.reply_collapse_threshold + # user_dict['roles'] = user.roles + # user_dict['vote_privately'] = user.vote_privately + + # get the user subscribed communities' ap_profile_id + user_subscribed_communities = [] + for c in user.communities(): + if c.ap_profile_id is None: + continue + else: + user_subscribed_communities.append(c.ap_profile_id) + user_dict['followed_communities'] = user_subscribed_communities + + # setup the BytesIO buffer + buffer = BytesIO() + buffer.write(str(python_json.dumps(user_dict)).encode('utf-8')) + buffer.seek(0) + + # confirmation displated to user when the page loads up again + flash(_l('Export Complete.')) + + # send the file to the user as a download + # the as_attachment=True results in flask + # redirecting to the current page, so no + # url_for needed here + return send_file( + buffer, + download_name=f'{user.user_name}_piefed_settings.json', + as_attachment=True, + mimetype='application/json' + ) + elif form.validate_on_submit(): propagate_indexable = form.indexable.data != current_user.indexable current_user.newsletter = form.newsletter.data current_user.searchable = form.searchable.data