diff --git a/app/__init__.py b/app/__init__.py
index e7a21381d94d8a46fd7e00fef8c93a3ab1d56236..9a1f7df8023fa7abf8cb8516ce54faa1937c2d5d 100644
--- a/app/__init__.py
+++ b/app/__init__.py
@@ -34,14 +34,14 @@ def create_app(config_name):
     with app.app_context():
         from .events import socketio as socketio_events
         from .events import sqlalchemy as sqlalchemy_events
-        from .admin import admin as admin_blueprint
-        from .auth import auth as auth_blueprint
-        from .corpora import corpora as corpora_blueprint
-        from .errors import errors as errors_blueprint
-        from .jobs import jobs as jobs_blueprint
-        from .main import main as main_blueprint
-        from .services import services as services_blueprint
-        from .settings import settings as settings_blueprint
+        from .admin import bp as admin_blueprint
+        from .auth import bp as auth_blueprint
+        from .corpora import bp as corpora_blueprint
+        from .errors import bp as errors_blueprint
+        from .jobs import bp as jobs_blueprint
+        from .main import bp as main_blueprint
+        from .services import bp as services_blueprint
+        from .settings import bp as settings_blueprint
 
     app.register_blueprint(admin_blueprint, url_prefix='/admin')
     app.register_blueprint(auth_blueprint, url_prefix='/auth')
diff --git a/app/admin/__init__.py b/app/admin/__init__.py
index 9bb011f8906e2477d31e9604d6966a3aeb054e6e..b5936b4c5db70ed09e2a9ca6731149b0afcaec25 100644
--- a/app/admin/__init__.py
+++ b/app/admin/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-admin = Blueprint('admin', __name__)
-from . import views
+bp = Blueprint('admin', __name__)
+from . import routes
diff --git a/app/admin/views.py b/app/admin/routes.py
similarity index 89%
rename from app/admin/views.py
rename to app/admin/routes.py
index 7f62d4a9ad6c853f6a6c716744a2fa134f8bcef8..c9a04053364c5c2a561b36e59462bae80a8d182b 100644
--- a/app/admin/views.py
+++ b/app/admin/routes.py
@@ -1,6 +1,6 @@
 from flask import flash, redirect, render_template, url_for
 from flask_login import login_required
-from . import admin
+from . import bp
 from .forms import EditGeneralSettingsAdminForm
 from .. import db
 from ..decorators import admin_required
@@ -8,14 +8,14 @@ from ..models import Role, User
 from ..settings import tasks as settings_tasks
 
 
-@admin.route('/')
+@bp.route('/')
 @login_required
 @admin_required
 def index():
     return redirect(url_for('.users'))
 
 
-@admin.route('/users')
+@bp.route('/users')
 @login_required
 @admin_required
 def users():
@@ -24,7 +24,7 @@ def users():
     return render_template('admin/users.html.j2', title='Users', users=users)
 
 
-@admin.route('/users/<int:user_id>')
+@bp.route('/users/<int:user_id>')
 @login_required
 @admin_required
 def user(user_id):
@@ -32,7 +32,7 @@ def user(user_id):
     return render_template('admin/user.html.j2', title='User', user=user)
 
 
-@admin.route('/users/<int:user_id>/delete')
+@bp.route('/users/<int:user_id>/delete')
 @login_required
 @admin_required
 def delete_user(user_id):
@@ -41,7 +41,7 @@ def delete_user(user_id):
     return redirect(url_for('.users'))
 
 
-@admin.route('/users/<int:user_id>/edit', methods=['GET', 'POST'])  # noqa
+@bp.route('/users/<int:user_id>/edit', methods=['GET', 'POST'])  # noqa
 @login_required
 @admin_required
 def edit_user(user_id):
diff --git a/app/auth/__init__.py b/app/auth/__init__.py
index a45dc3f349c631dc7f7a93c23ab499c6f091f176..6f6ba82da7ab031509e4865c49b9f0c13c0f8f5a 100644
--- a/app/auth/__init__.py
+++ b/app/auth/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-auth = Blueprint('auth', __name__)
-from . import views
+bp = Blueprint('auth', __name__)
+from . import routes
diff --git a/app/auth/views.py b/app/auth/routes.py
similarity index 93%
rename from app/auth/views.py
rename to app/auth/routes.py
index b63556424f47fc48a52ee2aef6169533227b72d9..d45c06445c03eb378f36440f8055a708e4493bac 100644
--- a/app/auth/views.py
+++ b/app/auth/routes.py
@@ -1,7 +1,7 @@
 from datetime import datetime
 from flask import abort, flash, redirect, render_template, request, url_for
 from flask_login import current_user, login_user, login_required, logout_user
-from . import auth
+from . import bp
 from .forms import (LoginForm, ResetPasswordForm, ResetPasswordRequestForm,
                     RegistrationForm)
 from .. import db
@@ -11,7 +11,7 @@ import logging
 import os
 
 
-@auth.before_app_request
+@bp.before_app_request
 def before_request():
     """
     Checks if a user is unconfirmed when visiting specific sites. Redirects to
@@ -27,7 +27,7 @@ def before_request():
             return redirect(url_for('auth.unconfirmed'))
 
 
-@auth.route('/login', methods=['GET', 'POST'])
+@bp.route('/login', methods=['GET', 'POST'])
 def login():
     if current_user.is_authenticated:
         return redirect(url_for('main.dashboard'))
@@ -46,7 +46,7 @@ def login():
     return render_template('auth/login.html.j2', form=form, title='Log in')
 
 
-@auth.route('/logout')
+@bp.route('/logout')
 @login_required
 def logout():
     logout_user()
@@ -54,7 +54,7 @@ def logout():
     return redirect(url_for('main.index'))
 
 
-@auth.route('/register', methods=['GET', 'POST'])
+@bp.route('/register', methods=['GET', 'POST'])
 def register():
     if current_user.is_authenticated:
         return redirect(url_for('main.dashboard'))
@@ -83,7 +83,7 @@ def register():
                            title='Register')
 
 
-@auth.route('/confirm/<token>')
+@bp.route('/confirm/<token>')
 @login_required
 def confirm(token):
     if current_user.confirmed:
@@ -97,7 +97,7 @@ def confirm(token):
         return redirect(url_for('.unconfirmed'))
 
 
-@auth.route('/unconfirmed')
+@bp.route('/unconfirmed')
 def unconfirmed():
     if current_user.is_anonymous:
         return redirect(url_for('main.index'))
@@ -106,7 +106,7 @@ def unconfirmed():
     return render_template('auth/unconfirmed.html.j2', title='Unconfirmed')
 
 
-@auth.route('/confirm')
+@bp.route('/confirm')
 @login_required
 def resend_confirmation():
     token = current_user.generate_confirmation_token()
@@ -117,7 +117,7 @@ def resend_confirmation():
     return redirect(url_for('auth.unconfirmed'))
 
 
-@auth.route('/reset', methods=['GET', 'POST'])
+@bp.route('/reset', methods=['GET', 'POST'])
 def reset_password_request():
     if current_user.is_authenticated:
         return redirect(url_for('main.dashboard'))
@@ -136,7 +136,7 @@ def reset_password_request():
                            title='Password Reset')
 
 
-@auth.route('/reset/<token>', methods=['GET', 'POST'])
+@bp.route('/reset/<token>', methods=['GET', 'POST'])
 def reset_password(token):
     if current_user.is_authenticated:
         return redirect(url_for('main.dashboard'))
diff --git a/app/corpora/__init__.py b/app/corpora/__init__.py
index 18392bab234f9f44cf009732211812d1fb54102a..af44719d041b28fbe92ed002a3fb7d46cb083743 100644
--- a/app/corpora/__init__.py
+++ b/app/corpora/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-corpora = Blueprint('corpora', __name__)
-from . import events, views  # noqa
\ No newline at end of file
+bp = Blueprint('corpora', __name__)
+from . import events, routes  # noqa
diff --git a/app/corpora/views.py b/app/corpora/routes.py
similarity index 94%
rename from app/corpora/views.py
rename to app/corpora/routes.py
index 0c5b9cfe5fb0ab99d6e72af918dddf9a48e7231c..40ada4bdaf825e63ac6743729c418f10427db3cb 100644
--- a/app/corpora/views.py
+++ b/app/corpora/routes.py
@@ -1,7 +1,7 @@
 from flask import (abort, flash, make_response, redirect, request,
                    render_template, url_for, send_from_directory)
 from flask_login import current_user, login_required
-from . import corpora
+from . import bp
 from . import tasks
 from .forms import (AddCorpusFileForm, AddCorpusForm, AddQueryResultForm,
                     EditCorpusFileForm, QueryDownloadForm, QueryForm,
@@ -20,7 +20,7 @@ from zipfile import ZipFile
 from .import_corpus import check_zip_contents
 
 
-@corpora.route('/add', methods=['GET', 'POST'])
+@bp.route('/add', methods=['GET', 'POST'])
 @login_required
 def add_corpus():
     form = AddCorpusForm()
@@ -45,7 +45,7 @@ def add_corpus():
                            title='Add corpus')
 
 
-@corpora.route('/import', methods=['GET', 'POST'])
+@bp.route('/import', methods=['GET', 'POST'])
 @login_required
 def import_corpus():
     form = ImportCorpusForm()
@@ -114,7 +114,7 @@ def import_corpus():
                            title='Import Corpus')
 
 
-@corpora.route('/<int:corpus_id>')
+@bp.route('/<int:corpus_id>')
 @login_required
 def corpus(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -125,7 +125,7 @@ def corpus(corpus_id):
                            corpus_files=corpus_files, title='Corpus')
 
 
-@corpora.route('/<int:corpus_id>/download')
+@bp.route('/<int:corpus_id>/download')
 @login_required
 def download_corpus(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -139,7 +139,7 @@ def download_corpus(corpus_id):
     )
 
 
-@corpora.route('/<int:corpus_id>/analyse')
+@bp.route('/<int:corpus_id>/analyse')
 @login_required
 def analyse_corpus(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -164,7 +164,7 @@ def analyse_corpus(corpus_id):
     )
 
 
-@corpora.route('/<int:corpus_id>/delete')
+@bp.route('/<int:corpus_id>/delete')
 @login_required
 def delete_corpus(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -175,7 +175,7 @@ def delete_corpus(corpus_id):
     return redirect(url_for('main.dashboard'))
 
 
-@corpora.route('/<int:corpus_id>/files/add', methods=['GET', 'POST'])
+@bp.route('/<int:corpus_id>/files/add', methods=['GET', 'POST'])
 @login_required
 def add_corpus_file(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -210,7 +210,7 @@ def add_corpus_file(corpus_id):
                            form=form, title='Add corpus file')
 
 
-@corpora.route('/<int:corpus_id>/files/<int:corpus_file_id>/delete')
+@bp.route('/<int:corpus_id>/files/<int:corpus_file_id>/delete')
 @login_required
 def delete_corpus_file(corpus_id, corpus_file_id):
     corpus_file = CorpusFile.query.get_or_404(corpus_file_id)
@@ -224,7 +224,7 @@ def delete_corpus_file(corpus_id, corpus_file_id):
     return redirect(url_for('.corpus', corpus_id=corpus_id))
 
 
-@corpora.route('/<int:corpus_id>/files/<int:corpus_file_id>/download')
+@bp.route('/<int:corpus_id>/files/<int:corpus_file_id>/download')
 @login_required
 def download_corpus_file(corpus_id, corpus_file_id):
     corpus_file = CorpusFile.query.get_or_404(corpus_file_id)
@@ -238,8 +238,7 @@ def download_corpus_file(corpus_id, corpus_file_id):
                                filename=corpus_file.filename)
 
 
-@corpora.route('/<int:corpus_id>/files/<int:corpus_file_id>',
-               methods=['GET', 'POST'])
+@bp.route('/<int:corpus_id>/files/<int:corpus_file_id>', methods=['GET', 'POST'])
 @login_required
 def corpus_file(corpus_id, corpus_file_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -284,7 +283,7 @@ def corpus_file(corpus_id, corpus_file_id):
                            title='Edit corpus file')
 
 
-@corpora.route('/<int:corpus_id>/prepare')
+@bp.route('/<int:corpus_id>/prepare')
 @login_required
 def prepare_corpus(corpus_id):
     corpus = Corpus.query.get_or_404(corpus_id)
@@ -299,7 +298,7 @@ def prepare_corpus(corpus_id):
 
 
 # Following are view functions to add, view etc. exported results.
-@corpora.route('/result/add', methods=['GET', 'POST'])
+@bp.route('/result/add', methods=['GET', 'POST'])
 @login_required
 def add_query_result():
     '''
@@ -350,7 +349,7 @@ def add_query_result():
                            form=form, title='Add query result')
 
 
-@corpora.route('/result/<int:query_result_id>')
+@bp.route('/result/<int:query_result_id>')
 @login_required
 def query_result(query_result_id):
     query_result = QueryResult.query.get_or_404(query_result_id)
@@ -361,7 +360,7 @@ def query_result(query_result_id):
                            query_result=query_result, title='Query result')
 
 
-@corpora.route('/result/<int:query_result_id>/inspect')
+@bp.route('/result/<int:query_result_id>/inspect')
 @login_required
 def inspect_query_result(query_result_id):
     '''
@@ -391,7 +390,7 @@ def inspect_query_result(query_result_id):
                            title='Inspect query result')
 
 
-@corpora.route('/result/<int:query_result_id>/delete')
+@bp.route('/result/<int:query_result_id>/delete')
 @login_required
 def delete_query_result(query_result_id):
     query_result = QueryResult.query.get_or_404(query_result_id)
@@ -403,7 +402,7 @@ def delete_query_result(query_result_id):
     return redirect(url_for('services.service', service="corpus_analysis"))
 
 
-@corpora.route('/result/<int:query_result_id>/download')
+@bp.route('/result/<int:query_result_id>/download')
 @login_required
 def download_query_result(query_result_id):
     query_result = QueryResult.query.get_or_404(query_result_id)
diff --git a/app/errors/__init__.py b/app/errors/__init__.py
index 3087208b60d8b0057a473632378ccc511533c9ad..0d79af4857891d0c86c260b95416c3ddac5f80b3 100644
--- a/app/errors/__init__.py
+++ b/app/errors/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-errors = Blueprint('errors', __name__)
-from app.errors import handlers
+bp = Blueprint('errors', __name__)
+from . import handlers
diff --git a/app/errors/handlers.py b/app/errors/handlers.py
index c568fd8c6d0fdb29c4f05bc97b46a7f772e70386..afbc543ae6294fa136b94205574e6a591b81e32d 100644
--- a/app/errors/handlers.py
+++ b/app/errors/handlers.py
@@ -1,8 +1,8 @@
 from flask import render_template, request, jsonify
-from . import errors
+from . import bp
 
 
-@errors.app_errorhandler(403)
+@bp.app_errorhandler(403)
 def forbidden(e):
     if (request.accept_mimetypes.accept_json
             and not request.accept_mimetypes.accept_html):
@@ -12,7 +12,7 @@ def forbidden(e):
     return render_template('errors/403.html.j2', title='Forbidden'), 403
 
 
-@errors.app_errorhandler(404)
+@bp.app_errorhandler(404)
 def not_found(e):
     if (request.accept_mimetypes.accept_json
             and not request.accept_mimetypes.accept_html):
@@ -22,7 +22,7 @@ def not_found(e):
     return render_template('errors/404.html.j2', title='Not Found'), 404
 
 
-@errors.app_errorhandler(413)
+@bp.app_errorhandler(413)
 def payload_too_large(e):
     if (request.accept_mimetypes.accept_json
             and not request.accept_mimetypes.accept_html):
@@ -32,7 +32,7 @@ def payload_too_large(e):
     return render_template('errors/413.html.j2', title='Payload Too Large'), 413
 
 
-@errors.app_errorhandler(500)
+@bp.app_errorhandler(500)
 def internal_server_error(e):
     if (request.accept_mimetypes.accept_json
             and not request.accept_mimetypes.accept_html):
diff --git a/app/jobs/__init__.py b/app/jobs/__init__.py
index 07e0e1bb1e3adf5017c263094af528ea88bf92a3..722440696ab9da37a9c9ff5a2c05fd771e71085b 100644
--- a/app/jobs/__init__.py
+++ b/app/jobs/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-jobs = Blueprint('jobs', __name__)
-from . import views
+bp = Blueprint('jobs', __name__)
+from . import routes
diff --git a/app/jobs/views.py b/app/jobs/routes.py
similarity index 90%
rename from app/jobs/views.py
rename to app/jobs/routes.py
index 4101c7ae9b6d47544df0c2d1d7c4dae9e6c12a3b..5db5692f7c4b3f30877bbcfbedabea99140a5997 100644
--- a/app/jobs/views.py
+++ b/app/jobs/routes.py
@@ -1,14 +1,14 @@
 from flask import (abort, flash, redirect, render_template,
                    send_from_directory, url_for)
 from flask_login import current_user, login_required
-from . import jobs
+from . import bp
 from . import tasks
 from ..decorators import admin_required
 from ..models import Job, JobInput, JobResult
 import os
 
 
-@jobs.route('/<int:job_id>')
+@bp.route('/<int:job_id>')
 @login_required
 def job(job_id):
     job = Job.query.get_or_404(job_id)
@@ -19,7 +19,7 @@ def job(job_id):
                            title='Job')
 
 
-@jobs.route('/<int:job_id>/delete')
+@bp.route('/<int:job_id>/delete')
 @login_required
 def delete_job(job_id):
     job = Job.query.get_or_404(job_id)
@@ -30,7 +30,7 @@ def delete_job(job_id):
     return redirect(url_for('main.dashboard'))
 
 
-@jobs.route('/<int:job_id>/inputs/<int:job_input_id>/download')
+@bp.route('/<int:job_id>/inputs/<int:job_input_id>/download')
 @login_required
 def download_job_input(job_id, job_input_id):
     job_input = JobInput.query.filter(JobInput.job_id == job_id, JobInput.id == job_input_id).first_or_404()  # noqa
@@ -42,7 +42,7 @@ def download_job_input(job_id, job_input_id):
                                filename=job_input.filename)
 
 
-@jobs.route('/<int:job_id>/restart')
+@bp.route('/<int:job_id>/restart')
 @login_required
 @admin_required
 def restart(job_id):
@@ -55,7 +55,7 @@ def restart(job_id):
     return redirect(url_for('.job', job_id=job_id))
 
 
-@jobs.route('/<int:job_id>/results/<int:job_result_id>/download')
+@bp.route('/<int:job_id>/results/<int:job_result_id>/download')
 @login_required
 def download_job_result(job_id, job_result_id):
     job_result = JobResult.query.filter(JobResult.job_id == job_id, JobResult.id == job_result_id).first_or_404()  # noqa
diff --git a/app/main/__init__.py b/app/main/__init__.py
index d658fca77e05e829cf37e537c697b8e1c548101a..6563022425984947949a2d8c5debf6124bf31de9 100644
--- a/app/main/__init__.py
+++ b/app/main/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-main = Blueprint('main', __name__)
-from . import views
+bp = Blueprint('main', __name__)
+from . import routes
diff --git a/app/main/views.py b/app/main/routes.py
similarity index 86%
rename from app/main/views.py
rename to app/main/routes.py
index 6f3816decc9550eec2736614e9de54dae9f6ba39..9edf5b99f1975271736fbfa942cf19477722ef23 100644
--- a/app/main/views.py
+++ b/app/main/routes.py
@@ -1,11 +1,11 @@
 from flask import flash, redirect, render_template, url_for
 from flask_login import login_required, login_user
-from . import main
+from . import bp
 from ..auth.forms import LoginForm
 from ..models import User
 
 
-@main.route('/', methods=['GET', 'POST'])
+@bp.route('/', methods=['GET', 'POST'])
 def index():
     form = LoginForm(prefix='login-form')
     if form.validate_on_submit():
@@ -19,28 +19,28 @@ def index():
     return render_template('main/index.html.j2', form=form, title='nopaque')
 
 
-@main.route('/about_and_faq')
+@bp.route('/about_and_faq')
 def about_and_faq():
     return render_template('main/about_and_faq.html.j2', title='About and faq')
 
 
-@main.route('/dashboard')
+@bp.route('/dashboard')
 @login_required
 def dashboard():
     return render_template('main/dashboard.html.j2', title='Dashboard')
 
 
-@main.route('/news')
+@bp.route('/news')
 def news():
     return render_template('main/news.html.j2', title='News')
 
 
-@main.route('/privacy_policy')
+@bp.route('/privacy_policy')
 def privacy_policy():
     return render_template('main/privacy_policy.html.j2',
                            title='Privacy statement (GDPR)')
 
 
-@main.route('/terms_of_use')
+@bp.route('/terms_of_use')
 def terms_of_use():
     return render_template('main/terms_of_use.html.j2', title='Terms of Use')
diff --git a/app/services/__init__.py b/app/services/__init__.py
index 832a715f76ae98cf0cc281ffa9efc2ace880f20b..5c553e896df9daa489a822542a18195d2d55a761 100644
--- a/app/services/__init__.py
+++ b/app/services/__init__.py
@@ -73,5 +73,5 @@ SERVICES = {
 }
 
 
-services = Blueprint('services', __name__)
-from . import views
+bp = Blueprint('services', __name__)
+from . import routes
diff --git a/app/services/views.py b/app/services/routes.py
similarity index 96%
rename from app/services/views.py
rename to app/services/routes.py
index 90d24bdd408727de8c8b24a4b45f846f25bc13a3..b69c4e100ff91bfb9629c674e45155719bd17127 100644
--- a/app/services/views.py
+++ b/app/services/routes.py
@@ -2,7 +2,7 @@ from flask import (abort, flash, make_response, render_template, request,
                    url_for)
 from flask_login import current_user, login_required
 from werkzeug.utils import secure_filename
-from . import services
+from . import bp
 from . import SERVICES
 from .. import db
 from .forms import AddJobForms
@@ -12,14 +12,14 @@ import logging
 import os
 
 
-@services.route('/corpus-analysis')
+@bp.route('/corpus-analysis')
 @login_required
 def corpus_analysis():
     return render_template('services/corpus_analysis.html.j2',
                            title='Corpus analysis')
 
 
-@services.route('/<service>', methods=['GET', 'POST'])
+@bp.route('/<service>', methods=['GET', 'POST'])
 @login_required
 def service(service):
     # Check if the requested service exist
diff --git a/app/settings/__init__.py b/app/settings/__init__.py
index 2329d880513181a2642551fd3fd1076d8a727217..1dab51423eaa11e91dbda4361896e3b707633351 100644
--- a/app/settings/__init__.py
+++ b/app/settings/__init__.py
@@ -1,5 +1,5 @@
 from flask import Blueprint
 
 
-settings = Blueprint('settings', __name__)
-from . import views  # noqa
+bp = Blueprint('settings', __name__)
+from . import routes  # noqa
diff --git a/app/settings/views.py b/app/settings/routes.py
similarity index 90%
rename from app/settings/views.py
rename to app/settings/routes.py
index a7fc0b38c17ac157f17393822b3b863f128c9418..ebc3a385a8c5f1a6a486552272c3883f049abc55 100644
--- a/app/settings/views.py
+++ b/app/settings/routes.py
@@ -1,18 +1,18 @@
 from flask import flash, redirect, render_template, url_for
 from flask_login import current_user, login_required, logout_user
-from . import settings, tasks
+from . import bp, tasks
 from .forms import (ChangePasswordForm, EditGeneralSettingsForm,
                     EditNotificationSettingsForm)
 from .. import db
 
 
-@settings.route('/')
+@bp.route('/')
 @login_required
 def index():
     return redirect(url_for('.edit_general_settings'))
 
 
-@settings.route('/change_password', methods=['GET', 'POST'])
+@bp.route('/change_password', methods=['GET', 'POST'])
 @login_required
 def change_password():
     form = ChangePasswordForm()
@@ -25,7 +25,7 @@ def change_password():
                            form=form, title='Change password')
 
 
-@settings.route('/edit_general_settings', methods=['GET', 'POST'])
+@bp.route('/edit_general_settings', methods=['GET', 'POST'])
 @login_required
 def edit_general_settings():
     form = EditGeneralSettingsForm()
@@ -43,7 +43,7 @@ def edit_general_settings():
                            form=form, title='General settings')
 
 
-@settings.route('/edit_notification_settings', methods=['GET', 'POST'])
+@bp.route('/edit_notification_settings', methods=['GET', 'POST'])
 @login_required
 def edit_notification_settings():
     form = EditNotificationSettingsForm()
@@ -63,7 +63,7 @@ def edit_notification_settings():
                            form=form, title='Notification settings')
 
 
-@settings.route('/delete')
+@bp.route('/delete')
 @login_required
 def delete():
     """
diff --git a/requirements.txt b/requirements.txt
index 5faa3cee8249c20ce4cdc0dfdf35dda476e2ee2b..95816e15be45e8f8fe661df1ab85be00d0a29c7d 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -7,6 +7,7 @@ Flask-Login
 Flask-Mail
 Flask-Migrate
 Flask-Paranoid
+Flask-RestPlus
 Flask-SocketIO~=5.0.0
 Flask-SQLAlchemy
 Flask-WTF