From aad141c10a9b21c400769c1e56d882ac34fbb723 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kacper=20J=C3=B3zef=20Drupisz?= <kdrupisz@meta.com> Date: Sun, 28 Apr 2024 17:41:43 +0100 Subject: [PATCH] Admin/superuser table to manage users/ app is not crushing when non user tries to access dashboard --- .gitignore | 4 +- myproject/debug.log | 1172 +++++++++++++++++ .../__pycache__/__init__.cpython-311.pyc | Bin 204 -> 208 bytes .../myapp/__pycache__/apps.cpython-311.pyc | Bin 573 -> 712 bytes myproject/myapp/payments.py | 14 +- myproject/myapp/templates/user_page.html | 71 +- myproject/myapp/urls.py | 7 +- myproject/myapp/views.py | 78 +- .../__pycache__/__init__.cpython-311.pyc | Bin 208 -> 165 bytes .../__pycache__/settings.cpython-311.pyc | Bin 2981 -> 4038 bytes myproject/myproject/settings.py | 3 +- 11 files changed, 1309 insertions(+), 40 deletions(-) diff --git a/.gitignore b/.gitignore index bb48dca..6809f86 100644 --- a/.gitignore +++ b/.gitignore @@ -7,4 +7,6 @@ myproject/myproject/__pycache__/__init__.cpython-312.pyc myproject/myproject/__pycache__/settings.cpython-312.pyc myproject/myproject/__pycache__/urls.cpython-312.pyc .venv/ -myproject/debug.log \ No newline at end of file +myproject/debug.log +./myproject/debug.log +debug.log diff --git a/myproject/debug.log b/myproject/debug.log index 3e46aa6..c96e5d9 100644 --- a/myproject/debug.log +++ b/myproject/debug.log @@ -1161,3 +1161,1175 @@ django.template.exceptions.TemplateSyntaxError: Invalid block tag on line 262: ' Watching for file changes with StatReloader Not Found: /favicon.ico Watching for file changes with StatReloader +Watching for file changes with StatReloader +Watching for file changes with StatReloader +Watching for file changes with StatReloader +Request[POST]: https://api.sandbox.paypal.com/v1/oauth2/token +Request[POST]: https://api.sandbox.paypal.com/v1/oauth2/token +Request[POST]: https://api.sandbox.paypal.com/v1/oauth2/token +Response[200]: OK, Duration: 0.542388s. +Response[200]: OK, Duration: 0.711223s. +PayPal-Request-Id: 724dc458-b6b6-4cba-b3ed-ce0dd4c54e28 +PayPal-Request-Id: ae4a938c-163b-44c6-b324-94e33f921d3b +Request[POST]: https://api.sandbox.paypal.com/v1/payments/payment +Request[POST]: https://api.sandbox.paypal.com/v1/payments/payment +Response[200]: OK, Duration: 0.632735s. +PayPal-Request-Id: 9f74d433-a82f-433a-b23c-b66a12c71d03 +Request[POST]: https://api.sandbox.paypal.com/v1/payments/payment +Response[201]: Created, Duration: 0.601147s. +Response[201]: Created, Duration: 0.617433s. +Response[201]: Created, Duration: 0.618051s. +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 62, in render_to_string + return template.render(context, request) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 61, in render + return self.template.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 171, in render + return self._render(context) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 163, in _render + return self.nodelist.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in render + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in <listcomp> + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 159, in render + return compiled_parent._render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 163, in _render + return self.nodelist.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in render + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in <listcomp> + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 65, in render + result = block.nodelist.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in render + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in <listcomp> + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 325, in render + return nodelist.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in render + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in <listcomp> + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 325, in render + return nodelist.render(context) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in render + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 1000, in <listcomp> + return SafeString("".join([node.render_annotated(context) for node in self])) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 241, in render + nodelist.append(node.render_annotated(context)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 961, in render_annotated + return self.render(context) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 478, in render + url = reverse(view_name, args=args, kwargs=kwargs, current_app=current_app) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/urls/base.py", line 88, in reverse + return resolver._reverse_with_prefix(view, prefix, *args, **kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/urls/resolvers.py", line 848, in _reverse_with_prefix + raise NoReverseMatch(msg) +django.urls.exceptions.NoReverseMatch: Reverse for 'change_user_type' not found. 'change_user_type' is not a valid view function or pattern name. +/usr/src/app/myapp/urls.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/urls.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '%' from 'user.is_superuser%' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '%' from 'user.is_superuser%' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '%' from 'user.is_superuser%' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 502, in parse + compile_func = self.tags[command] + ~~~~~~~~~^^^^^^^^^ +KeyError: 'elif' + +During handling of the above exception, another exception occurred: + +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 860, in do_for + nodelist_loop = parser.parse( + ^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 504, in parse + self.invalid_block_tag(token, command, parse_until) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 555, in invalid_block_tag + raise self.error( +django.template.exceptions.TemplateSyntaxError: Invalid block tag on line 283: 'elif', expected 'empty' or 'endfor'. Did you forget to register or load this tag? +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '(user_profile)' from 'dir(user_profile)' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '(user)' from 'dir(user)' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 190, in users + return render(request, 'user_page.html', context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 15, in get_template + return engine.get_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/backends/django.py", line 33, in get_template + return Template(self.engine.get_template(template_name), self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 175, in get_template + template, origin = self.find_template(template_name) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/engine.py", line 157, in find_template + template = loader.get_template(name, skip=skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/cached.py", line 57, in get_template + template = super().get_template(template_name, skip) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loaders/base.py", line 28, in get_template + return Template( + ^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 154, in __init__ + self.nodelist = self.compile_nodelist() + ^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 196, in compile_nodelist + return parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 295, in do_extends + nodelist = parser.parse() + ^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py", line 234, in do_block + nodelist = parser.parse(("endblock",)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 510, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 508, in parse + compiled_result = compile_func(self, token) + ^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py", line 960, in do_if + nodelist = parser.parse(("elif", "else", "endif")) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 481, in parse + raise self.error(token, e) + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 479, in parse + filter_expression = self.compile_filter(token.contents) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 597, in compile_filter + return FilterExpression(token, self) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/base.py", line 698, in __init__ + raise TemplateSyntaxError( +django.template.exceptions.TemplateSyntaxError: Could not parse the remainder: '(user)' from 'dir(user)' +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 171, in users + print(request.user.is_superuser()) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^ +TypeError: 'bool' object is not callable +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /change_user_type/7/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 323, in change_user_type + user_profile = get_object_or_404(Profile, user__id=user_id) + ^^^^^^^^^^^^^^^^^ +NameError: name 'get_object_or_404' is not defined +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /change_user_type/7/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 323, in change_user_type + user_profile.user_type = user_type + ^^^^^^^^^^^^ +NameError: name 'user_profile' is not defined +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +psycopg.errors.UndefinedColumn: column "root" does not exist +LINE 1: ...ELECT date, user, log FROM myapp_log where user = root ORDER... + ^ + +The above exception was the direct cause of the following exception: + +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 176, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 107, in user_table + cursor.execute(query) + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 122, in execute + return super().execute(sql, params) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 79, in execute + return self._execute_with_wrappers( + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 92, in _execute_with_wrappers + return executor(sql, params, many, context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 100, in _execute + with self.db.wrap_database_errors: + File "/usr/local/lib/python3.11/site-packages/django/db/utils.py", line 91, in __exit__ + raise dj_exc_value.with_traceback(traceback) from exc_value + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +django.db.utils.ProgrammingError: column "root" does not exist +LINE 1: ...ELECT date, user, log FROM myapp_log where user = root ORDER... + ^ +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 176, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 176, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 176, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user_id) + ^^^^^^^^^^^^^^^ +AttributeError: 'WSGIRequest' object has no attribute 'user_id' +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 101, in user_table + print(request.user.user_id) + ^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/utils/functional.py", line 253, in inner + return func(_wrapped, *args) + ^^^^^^^^^^^^^^^^^^^^^ +AttributeError: 'User' object has no attribute 'user_id' +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +psycopg.errors.SyntaxError: syntax error at or near "ORDER" +LINE 1: SELECT date, user, log FROM myapp_log where ORDER BY date DE... + ^ + +The above exception was the direct cause of the following exception: + +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 107, in user_table + cursor.execute(query) + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 122, in execute + return super().execute(sql, params) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 79, in execute + return self._execute_with_wrappers( + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 92, in _execute_with_wrappers + return executor(sql, params, many, context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 100, in _execute + with self.db.wrap_database_errors: + File "/usr/local/lib/python3.11/site-packages/django/db/utils.py", line 91, in __exit__ + raise dj_exc_value.with_traceback(traceback) from exc_value + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +django.db.utils.ProgrammingError: syntax error at or near "ORDER" +LINE 1: SELECT date, user, log FROM myapp_log where ORDER BY date DE... + ^ +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +psycopg.errors.SyntaxError: syntax error at or near "ORDER" +LINE 1: SELECT date, user, log FROM myapp_log where ORDER BY date DE... + ^ + +The above exception was the direct cause of the following exception: + +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 174, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 107, in user_table + cursor.execute(query) + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 122, in execute + return super().execute(sql, params) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 79, in execute + return self._execute_with_wrappers( + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 92, in _execute_with_wrappers + return executor(sql, params, many, context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 100, in _execute + with self.db.wrap_database_errors: + File "/usr/local/lib/python3.11/site-packages/django/db/utils.py", line 91, in __exit__ + raise dj_exc_value.with_traceback(traceback) from exc_value + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +django.db.utils.ProgrammingError: syntax error at or near "ORDER" +LINE 1: SELECT date, user, log FROM myapp_log where ORDER BY date DE... + ^ +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/payments.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/payments.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/payments.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +psycopg.errors.UndefinedColumn: column "none" does not exist +LINE 1: ...CT date, user, log FROM myapp_log WHERE user_id = None ORDER... + ^ + +The above exception was the direct cause of the following exception: + +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 172, in users + data_user = user_table(request) + ^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 105, in user_table + cursor.execute(query) + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 122, in execute + return super().execute(sql, params) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 79, in execute + return self._execute_with_wrappers( + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 92, in _execute_with_wrappers + return executor(sql, params, many, context) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 100, in _execute + with self.db.wrap_database_errors: + File "/usr/local/lib/python3.11/site-packages/django/db/utils.py", line 91, in __exit__ + raise dj_exc_value.with_traceback(traceback) from exc_value + File "/usr/local/lib/python3.11/site-packages/django/db/backends/utils.py", line 103, in _execute + return self.cursor.execute(sql) + ^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/psycopg/cursor.py", line 732, in execute + raise ex.with_traceback(None) +django.db.utils.ProgrammingError: column "none" does not exist +LINE 1: ...CT date, user, log FROM myapp_log WHERE user_id = None ORDER... + ^ +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 204, in _get_response + self.check_response(response, callback) + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 332, in check_response + raise ValueError( +ValueError: The view myapp.views.users didn't return an HttpResponse object. It returned None instead. +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 191, in users + return render(request, 'login.html') + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 19, in get_template + raise TemplateDoesNotExist(template_name, chain=chain) +django.template.exceptions.TemplateDoesNotExist: login.html +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Internal Server Error: /user/ +Traceback (most recent call last): + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner + response = get_response(request) + ^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response + response = wrapped_callback(request, *callback_args, **callback_kwargs) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/src/app/myapp/views.py", line 191, in users + return render(request, 'login.html' + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/shortcuts.py", line 24, in render + content = loader.render_to_string(template_name, context, request, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 61, in render_to_string + template = get_template(template_name, using=using) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + File "/usr/local/lib/python3.11/site-packages/django/template/loader.py", line 19, in get_template + raise TemplateDoesNotExist(template_name, chain=chain) +django.template.exceptions.TemplateDoesNotExist: login.html +/usr/src/app/myapp/views.py changed, reloading. +Watching for file changes with StatReloader +Not Found: /uiser +/usr/src/app/myproject/settings.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myproject/settings.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myproject/settings.py changed, reloading. +Watching for file changes with StatReloader +/usr/src/app/myproject/settings.py changed, reloading. +Watching for file changes with StatReloader diff --git a/myproject/myapp/__pycache__/__init__.cpython-311.pyc b/myproject/myapp/__pycache__/__init__.cpython-311.pyc index e807264b8895b1f0dcae0e7a5d7b6eb62b750728..771bcd6d508dbc4a5c6c889a6c3b01ea434e6473 100644 GIT binary patch delta 156 zcmX@Zc!803IWI340|NuYt2n(h-HE)C@gUxGh7^V<h7`tN22G|avE0hUf&#t7f`Vc_ zUl7wdKQApa-A|M8mQYG+T4HHVNqk~KL3}b;cqPMUka53E^h1kNi;DHLQ;JFpGK;J9 uL-R8AQ&Nj3Hft!eF)%PNGB7X{3o<Y;d|+l|WV|7&dx1d+f{Iue7#INOFf2>} delta 152 zcmcb>c!rU8IWI340|NuY6N@XU3=?@JW7!xO7^X9%Fa$GbGWxA#C}Lt@VE7DD@he_G zv^ce>SU)2%H#4QQs3<WbH!)A&CAB!aB)>pEG~CrWKer$_Ia5C}HL=K8-zCvC*hN1j wD={xUU$-PNGp9T=Z(^&4A}a#}10w?iLoq)C1H%VqMn=XD3^1aInSp@;0H{$YUjP6A diff --git a/myproject/myapp/__pycache__/apps.cpython-311.pyc b/myproject/myapp/__pycache__/apps.cpython-311.pyc index 0e8827ab12cc647ec42899dd1a9080d08893551d..7ef25830ab88583a4e8ea309e400a79db6f37851 100644 GIT binary patch delta 434 zcmdnXa)On2IWI340|NuYt2n*1gA;j6m1Gzg7^X9%GDI<^Fhnt>Fh((_Fh#MXFt;#7 zv8J#DGib6-oM&90%m~s1#Y_wg49pA+44?VHdQ%uv7;+eD8B-X788n&via^qujJJ4m zD-#O}^oldn^AdB4HJNU)6sP8-6|pfeFcgE7C@B0g&<`z6Eh^T}PAMua$SkhX56#Qe zPf0CK(a)_cD9X=DO)k*~n=(0%k;DELYf)-qN@bOxFUVl${JgZxbUm;T2gpnj1_p)( zh8r9*7f{h>kgNSP*(P4G3n}7eU|?9uP{hN)z)%DVhay%G3q-Jh%+Ldy(ZB$KHzX}C zu!!B@7HV+$z{1EX`+)(IDB_vCgi%>a2xJW0)L$Gnx%nxjIjMF<B9k97s+zMh%6?$L SBqnHn1c`nD5oq#YCjtQa{b!i~ delta 291 zcmX@Xx|fA_IWI340|NuY6N@XUeG_?0WyBa57^X9%GDI<^Fhnt>Fh((_Fh#MXFb6Ye zvP@iJ%<QMhI(aUmUHwXi&meujqV+?IQ;UlAGZJ$%Q%Z}95;JlW^YmR(i?d7e3-m+7 zU7hoD3xbm~^&?Xgi;VSM5?zB`^i#4D^V0KmOA<44$}{s)^m8i<it@8klS}k-D-#O} z^b-pTiuDRAi&z;L7{CMz0|P^`Bm)CO0~AhXXX0gRaA|NU;+?F|q%6e)QppP<_!t-% qesS33=BJeAq}mk;OwM6aHD_WJ{=k4qOwjxY68!=q(Bz9ih5-Q57EDzD diff --git a/myproject/myapp/payments.py b/myproject/myapp/payments.py index 6ce5f3c..495d77f 100644 --- a/myproject/myapp/payments.py +++ b/myproject/myapp/payments.py @@ -6,7 +6,7 @@ from django.urls import reverse from django.shortcuts import redirect, render from django.urls import reverse from .models import UserTokenCount - +from .views import get_log_data, create_log # Create a payment that can be made via the PayPal API # Create a payment that can be made via the PayPal API def create_payment(request): @@ -14,7 +14,7 @@ def create_payment(request): paypalrestsdk.configure({ "mode": settings.PAYPAL_MODE, "client_id": settings.PAYPAL_CLIENT_ID, - "client_secret": settings.PAYPAL_CLIENT_SECRET + "client_secret": settings.PAYPAL_CLIENT_SECRET }) # Create payment object @@ -45,7 +45,7 @@ def create_payment(request): }] }) - # Successfully communicated with API + # Successfully communicated with API if payment.create(): print("Payment created successfully!") # get url for payment approval @@ -70,7 +70,7 @@ def execute_payment(request): print("no payment") #TODO: Change this to a more appropriate path, maybe a generic error page that takes a string:Error to display in a template return redirect('handler404') - + # configure API paypalrestsdk.configure({ "mode": settings.PAYPAL_MODE, @@ -88,11 +88,11 @@ def execute_payment(request): # Allocate some tokens user = request.user tokens_purchased = 1 - + # increment user_tokens # commit changes # TODO: Change something here such that the token amount added depends on a detail of the transaction, - # i.e. £9.99 payment for one token or £24.99 for + # i.e. £9.99 payment for one token or £24.99 for # if request.user.is_authenticated: add_tokens(user, tokens_purchased) @@ -114,4 +114,6 @@ def payment_cancelled(request): return render(request, 'payment_cancelled.html') def payment_success(request): + log_data = get_log_data(Action.PAYMENT_SUCCESSFUL, 'success', user=request.user.username) + create_log(log_data) return render(request,'payment_success.html') diff --git a/myproject/myapp/templates/user_page.html b/myproject/myapp/templates/user_page.html index 5a36c2d..71b16d6 100644 --- a/myproject/myapp/templates/user_page.html +++ b/myproject/myapp/templates/user_page.html @@ -7,7 +7,9 @@ User settings </h1> <h3 class="mb-4 text-xl font-semibold dark:text-white"> - {% if user_profile.user_type == 0 %} + {% if user_profile.is_superuser %} + User type: Superuser + {% elif user_profile.user_type == 0 %} User type: User {% elif user_profile.user_type == 1 %} User type: Admin @@ -21,7 +23,7 @@ </h3> </div> <!-- Right Content --> - + <div class="col-span-full xl:col-auto"> <div class="p-4 mb-4 bg-white border boder-gray-200 rounded-lg shadow-sm 2xl:col-span-2 dark:border-gray-700 sm:p-6 dark:bg-gray-800"> <h3 class="mb-4 text-xl font-semibold dark:text-white">Tokens:</h3> @@ -31,13 +33,13 @@ <h3 class="mb-4 text-xl font-semibold dark:text-white">Change your password</h3> <a href="{% url 'password_change' %}" class="text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800">Change Password</a> </div> - - - {% if user_profile.user_type == 3 %} + + + {% if user_profile.user_type == 3 or user.is_superuser or user_profile.user_type == 1%} <div class="p-4 mb-4 bg-white border border-gray-200 rounded-lg shadow-sm 2xl:col-span-2 dark:border-gray-700 sm:p-6 dark:bg-gray-800" > - + <h3 class="mb-4 text-xl font-semibold dark:text-white"> Generate Financial Statement </h3> @@ -86,7 +88,7 @@ {% comment %} REPLACE WITH LOGIC TO CHECK PROPER USER {% endcomment %} </div> {% endif %} - {% if 1 %} + {% if user_profile.user_type == 2 or user.is_superuser or user_profile.user_type == 1%} <div class="p-4 mb-4 bg-white border border-gray-200 rounded-lg shadow-sm 2xl:col-span-2 dark:border-gray-700 sm:p-6 dark:bg-gray-800" @@ -152,7 +154,7 @@ {% else %} <span>No email address on record.</span> {% endif %} - + </div> <div class="col-span-6 sm:col-span-3"> <label @@ -252,7 +254,7 @@ function closeModal() { {% if 1 %} {% comment %} REPLACE WITH LOGIC TO CHECK PROPER USER {%endcomment %} - {% if user_profile.user_type == 2 %} + {% if user_profile.user_type == 2 or user.is_superuser%} <div class="p-4 mb-4 bg-white border border-gray-200 rounded-lg shadow-sm 2xl:col-span-2 dark:border-gray-700 sm:p-6 dark:bg-gray-800" > @@ -298,6 +300,57 @@ function closeModal() { </table> </div> {% endif %} + {% if user.is_superuser or user_profile.user_type == 1 %} + <div class="p-4 mb-4 bg-white border border-gray-200 rounded-lg shadow-sm 2xl:col-span-2 dark:border-gray-700 sm:p-6 dark:bg-gray-800"> + <h3 class="mb-4 text-xl font-semibold dark:text-white"> + User Management + </h3> + <table class="w-full text-sm text-left rtl:text-right text-gray-500 dark:text-gray-400"> + <thead class="text-xs text-gray-700 uppercase bg-gray-50 dark:bg-gray-700 dark:text-gray-400"> + <tr> + <th scope="col" class="px-6 py-3">Username</th> + <th scope="col" class="px-6 py-3">User Type</th> + <th scope="col" class="px-6 py-3">Actions</th> + </tr> + </thead> + <tbody> + {% for user_profile in all_user_profiles %} + <tr class="odd:bg-white odd:dark:bg-gray-900 even:bg-gray-50 even:dark:bg-gray-800 border-b dark:border-gray-700"> + <td class="px-6 py-4">{{ user_profile.user.username }}</td> + <td class="px-6 py-4"> + {% if user_profile.is_superuser %} + Superuser + {% elif user_profile.user_type == 1 %} + Admin + {% elif user_profile.user_type == 2 %} + ML Engineer + {% elif user_profile.user_type == 3 %} + Accountant + {% else %} + User + {% endif %} + </td> + <td class="px-6 py-4"> + <form action="{% url 'change_user_type' user_profile.user.id %}" method="post"> + {% csrf_token %} + <select name="user_type"> + <option value="0">User</option> + <option value="1">Admin</option> + <option value="2">ML Engineer</option> + <option value="3">Accountant</option> + </select> + <button type="submit" class="p-2 bg-blue-500 text-white rounded-md hover:bg-blue-600"> + Change User Type + </button> + </form> + </td> + </tr> + {% endfor %} + </tbody> + </table> + </div> + +{% endif %} {% endif %} {% comment %} Admin page functionality end {% endcomment %} </div> </div> diff --git a/myproject/myapp/urls.py b/myproject/myapp/urls.py index 49240b9..f646034 100644 --- a/myproject/myapp/urls.py +++ b/myproject/myapp/urls.py @@ -1,5 +1,5 @@ from django.urls import path -from .views import InstrumentDetectionView, index, log_fileupload, users, maintenance, handler404, handler500, terms_conditions, privacy_policy, handling_music_file, pricing, generate_pdf, admin_table +from .views import InstrumentDetectionView, index, log_fileupload, users, maintenance, handler404, handler500, terms_conditions, privacy_policy, handling_music_file, pricing, generate_pdf, admin_table, change_user_type from .payments import create_payment, execute_payment, payment_cancelled, payment_success from django.contrib.auth import views as auth_views @@ -22,13 +22,15 @@ urlpatterns = [ path('generate_pdf/', generate_pdf, name='generate_pdf'), path('pricing/', pricing, name='pricing'), path('generate_pdf/', generate_pdf, name='generate_pdf'), - path('admin_table/', admin_table, name='admin_table'), path('instrument_detection/', InstrumentDetectionView.as_view(), name='instrument_detection'), path('password_change/', auth_views.PasswordChangeView.as_view(template_name='password_change_form.html'), name='password_change'), path('password_change/done/', auth_views.PasswordChangeDoneView.as_view(template_name='password_change_done.html'), name='password_change_done'), # Logging path('log_fileupload', log_fileupload, name='log_fileupload'), + # Admin + path('change_user_type/<int:user_id>/', change_user_type, name='change_user_type'), + path('admin_table/', admin_table, name='admin_table'), # Authentication @@ -41,4 +43,5 @@ urlpatterns = [ path('payment/execute/', execute_payment, name='execute_payment'), path('payment/cancel/', payment_cancelled, name='payment_cancelled'), path('payment_success/', payment_success, name='success') + ] diff --git a/myproject/myapp/views.py b/myproject/myapp/views.py index ed4c7d9..4baabe6 100644 --- a/myproject/myapp/views.py +++ b/myproject/myapp/views.py @@ -4,7 +4,7 @@ from django.contrib.auth.models import User from django.contrib import messages from django.http import HttpResponse from django.utils import timezone -from django.shortcuts import render, redirect +from django.shortcuts import render, redirect, get_object_or_404 from django.template import RequestContext import logging from reportlab.pdfgen import canvas @@ -12,7 +12,7 @@ import json from datetime import datetime from .forms import InstrumentDetectionForm -from .models import Log, Action, User, UserTokenCount +from .models import Log, Action, User, UserTokenCount, Profile from django.http import JsonResponse from django.db import connection @@ -97,10 +97,9 @@ def admin_table(request): def user_table(request): - # Execute the query and fetch all rows - query = """SELECT date, user, log FROM myapp_log ORDER BY date DESC""" + user_id= request.user.id # Only display user logs code below - # query = """SELECT date, user, log FROM myapp_log WHERE user = '{}' ORDER BY date DESC""".format(request.user) + query = """SELECT date, user, log FROM myapp_log WHERE user_id = {} ORDER BY date DESC""".format(user_id) with connection.cursor() as cursor: cursor.execute(query) rows = cursor.fetchall() @@ -120,11 +119,11 @@ def user_table(request): def index(request): # Initialize default context - context = {'form': InstrumentDetectionForm(), + context = {'form': InstrumentDetectionForm(), 'predictions': [], 'file_name': None } - + # Handle authenticated users if request.user.is_authenticated: token_count = UserTokenCount.objects.get(user=request.user).token_count @@ -147,7 +146,7 @@ def index(request): else: context['form'] = form # For GET requests or if form is not valid, render the page with the default or updated context - return render(request, 'index1.html', context) + return render(request, 'index1.html', context) # Handle unauthenticated users else: @@ -162,10 +161,11 @@ def index(request): return render(request, 'index2.html') - + def users(request): +<<<<<<< HEAD # Make a request to the admin_table view to get the data context = {} data_admin = admin_table(request) @@ -183,8 +183,32 @@ def users(request): context['user_profile'] = user_profile context['user'] = user print(context['user_data']) +======= + if request.user.is_authenticated: + # Make a request to the admin_table view to get the data + context = {} + data_admin = admin_table(request) + data_user = user_table(request) + admin_dict = json.loads(data_admin.content) + user_dict = json.loads(data_user.content) + token_count = UserTokenCount.objects.get(user=request.user).token_count + user_profile = request.user.profile + user = request.user + all_user_profiles = Profile.objects.all() # Retrieve all Profile objects +>>>>>>> 74b89e6 (Admin/superuser table to manage users/ app is not crushing when non user tries to access dashboard) + + # Pass the data as a context variable to the template + # !!! ADMIN DATA ONLY DISPLAYED AND GET IF USER IS ADMIN !!! + context['admin_data'] = admin_dict['data'] + context['user_data'] = user_dict['data'] + context['token_count'] = token_count + context['user_profile'] = user_profile + context['user'] = user + context['all_user_profiles'] = all_user_profiles # Add all_user_profiles to the context - return render(request, 'user_page.html', context) + return render(request, 'user_page.html', context) + return redirect( 'login' +) def handler404(request, *args, **kwargs): response = render(request, '404.html', {}) @@ -222,7 +246,7 @@ class RegisterView(generic.CreateView): login(self.request, user) return response - + class CustomLoginView(LoginView): authentication_form = LoginAuthenticationForm @@ -272,22 +296,30 @@ class InstrumentDetectionView(APIView): # Decrease the user's token count by one user_token_count.token_count -= 1 user_token_count.save() - + serializer = InstrumentDetectionSerializer(data=request.data) if serializer.is_valid(): audio_file = serializer.validated_data['audio_file'] +<<<<<<< HEAD +======= + + # Save the uploaded file temporarily + # with open('temp_audio.wav', 'wb') as f: + # f.write(audio_file.read()) + +>>>>>>> 74b89e6 (Admin/superuser table to manage users/ app is not crushing when non user tries to access dashboard) # Preprocess the audio file preprocessed_data = preprocess_audio_for_inference(audio_file) - + # Prepare data for TensorFlow Serving data = json.dumps({"signature_name": "serving_default", "instances": [window.tolist() for window in preprocessed_data]}) - + # Send request to TensorFlow Serving url = 'http://tensorflow_serving:8501/v1/models/instrument_model/versions/2:predict' headers = {"Content-Type": "application/json"} response = requests.post(url, data=data, headers=headers) - + # Process the response if response.status_code == 200: raw_predictions = response.json()['predictions'] @@ -296,10 +328,10 @@ class InstrumentDetectionView(APIView): return Response({"predictions": formatted_predictions}, status=status.HTTP_200_OK) else: return Response({"error": "Failed to get predictions"}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) - + return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) - - + + def format_predictions(self, predictions): instruments = ['Guitar', 'Drum', 'Violin', 'Piano'] formatted_predictions = [] @@ -308,11 +340,17 @@ class InstrumentDetectionView(APIView): formatted_scores = "<br>".join([f"{instruments[i]} - {score:.2f}" for i, score in enumerate(prediction)]) formatted_predictions.append(f"{formatted_window}{formatted_scores}") return formatted_predictions - +def change_user_type(request, user_id): + if request.method == 'POST': + user_type = request.POST.get('user_type') + user_profile = get_object_or_404(Profile, user__id=user_id) # Get the user profile + user_profile.user_type = user_type + user_profile.save() + return redirect('users') # Redirect to the users page def user_has_credits(): has_credits = False - return has_credits \ No newline at end of file + return has_credits diff --git a/myproject/myproject/__pycache__/__init__.cpython-311.pyc b/myproject/myproject/__pycache__/__init__.cpython-311.pyc index 95e9dd7c81ec1f76c54d413dacf931df6de0629f..232e911995b5972b98643e97e8931fb6bd8ae6a7 100644 GIT binary patch delta 48 zcmcb>xRjA+IWI340|NuYt2n*1i999}7W$#ZsYS*5*(pV(1)0TF`k{H5`YEZ!6PtYj DP9_gu delta 91 zcmZ3=c!7~;IWI340|NuYNsB9~6M0OWll4Q3Q;UlAGZJ$%Q%Z}95;JlW^YmR(i?d7e v3-m+7U7hoD3xbm~^&?Xgi;VSM5?zB`^i#4D^V0KmOA<44$}{sOM)(2%SGXTY diff --git a/myproject/myproject/__pycache__/settings.cpython-311.pyc b/myproject/myproject/__pycache__/settings.cpython-311.pyc index 43e185ac37432969c976b6535ce0ec93d8654c01..1ef36cbff201991f79cacad2e94af779b146e8a9 100644 GIT binary patch delta 1738 zcmZ1~eoS6tIWI340|NuYt2n*1L&6LUk3k$52FoxoFnpfJG*P37D}^ncF^VglA%%V7 zBF%b^WlRhVtC?VG(;1`q(iu`X7coZhr*K6Hq;RM3r0}NjrSPW+qzKMo&SXsCO=nEu zOA(sGlp;KbB}y<wB$Yiyw2GU7A)PUWHAO6)Aw_%<V<uyY#2l7%#wei_$td9zsTAo{ z<}4AIEek|pta=y&M5oB4$f7z2yC#rY7*3H(ktbP?LW&|(56pfdEK*8QhH8S^O@tnm z6jf9`DQa`rG8v=9Qq)s4G8t3URZ=uTREidu)Xro~XNeL|(TS2s(T$Q!VU3bXVU3cW zxJ=bt57nF~nH2pf*%X5)xfH`F`4polg%qPG#T4Txr4*AW<rLE>l@#V+22Hcgd5mq0 zthX4oG&v`KV_GS9i?1lPxFkNUC^0v+JijQriYK=+v7kV|xFoS8GkNnJ<`TyGmy8Sy z3~skr(lT>WZ?Sm#x%pQK=j5lSXXd5rxn<_0dL-th<fIl=ai*jum8R?E<fm&g-(t;4 zElbV0#hRRxSX_LI1Ee=EF*j9{=@v%@M164)Hv<EMCd)1MvecsD%>2At5-FL*iAg!B z@u?M=#U+_}>G2?I_)?3Ci})BA7;do?<>!}d4qy#otd~v6O3X{o*Goy#OG-@6PR&ax z)+@*_E=ey+EiTNt#T(!s9O5428XWKE=<9lmKP5FSu{5V7J|!t0<O(GD&|ue~TRbrN z(&E&jTY_-S0gl1J;r>A`w*+7c3KENp%kzuEQjm=B@DC2T#gvkSBoyEu6q0En%D|w> zc8kr`&)w6{^%e`*DJ)<MIp8L<fOWHgG!!XszRM=V$Z?Ae68e*WvTM{=2|+me#YM^b znYoGSsm1!g81-+l7boVWB;{9B1vo|)cvR%)6}kBqrRNpqW@ToYm<6Z$6$fUf<QWBI zd6l^4d!~nZ8~7EaBpPN0x`if17+F+Rmim^3W_o3tndiqRdw6;pCtH*``-VsAR^AG5 z4Ty;FHjXl{a4B*(aj%TeE-~@X4)96x3W`XvED10(Dl~K{NXpGJ4a_W0bjvU=DNha# zP0aCd335tu3o5TjiHI-C^~jEQGm8u^iAc0G)l{9V%rSBDD-J1Rb{~ItcTYd}Tbv=T zz5zatA+Eu<1j2*eJ>wk%0(?B39YZ|*{cf?R=9Og@<>%dEPEReFtiTz>!yO#r7~<(1 zALQ>JGP#gbq5c-9r>~>CYkX*s&n+Pze|Jy6_#jso&mdRl5U`lAkH5QrXb7qxcYtGL zfTK^mufL1yEdeOU*~in>FC^a6<(3GlNU*DOkZZ_FhR>i3{>wr?v^ce>SU)?ZsI(xH ztGG%(G%r&>CAE0+9ZntY5C#SYP(CU4W|}O_6)!0$GJ&;$_X8J~5Yq<+7}3D@L27a* zmkguW<b7P?E^G_}f;SXYA8_#95S6|ms&zv``2#zPAlC;55W&nQ$o4^iK}=?X#|=U8 z53J0*Y#$gvgeV_3(+37VZl(tI4=R(daXHtkF|hL85Hh?WAT)(*I^QI|8TA(o94`tu zT@i3X65GIcQNaF+fc*^-u_<2D{U-TcP&T_@;dN2O`-+G+vO1QF0;X34OtA=k;AIzJ z`@jGqm^pcw8aO|wFmUouw&V5-;$q+z>`Cv>>B^a5u^{3ipWYQdy$0?ZykZSpAGjFA zOfN79J>XGj;Cvt|ae+bThM4392H_7J4Ez!e+&6?%FE9w)5YN28AOb-}K@1EG0RN-m AZvX%Q delta 723 zcmX>mzf@dfIWI340|Ns?vFDZ4>%0sMk3k$5W`i<5J26hwDB?+Hh~i3TNMT#V7{xs~ zk4d$jeHjx2!)hj|Du#5%D85wo6pkux28Jm96xJw#6wWBYbcPhJMT}8GDcn)QDLkp{ zDZC*0bjB3c6uxwZ6#hkwnT#m{b6C<DqeM~!qeN4LQiN04Q$#?jQbgx4Wim#IrHG}7 zXELUUrAUBDNiZp;lF69P5+$A@9VL+>6D66#8YPv&8YP_~8zqw>7bTm*9L%68zxfnX z8zYk@$K+6!m9|wpxs{0p1^UG$i6xoIx7Z-GCS#Rya(-?>QEG8<evw{UW?o8aQL&yg zT*wV9vRQ_;gmJShdkCYYR7zH2UV6S>N|IhuVsdtBUP`fEabZqoNvd%bS4t9$t;uwY z&DGD{)6ex5i=U&fYZ3ouH%=MG$yr<)Oqz0&Be*B}^E&(c1_ZeV2ge8b`-j{TfOB2_ z9G!ezU2X{nhd73KI=gxLxCY0&dHT7y1_j^Z^7V9a@o^1z406521JW2D8sy{b@8>p| zn@4W4IZxo^sXX%DD;Yk6qUKk!erR!OQL%nTVs2(iX;D#PMs8xBzDsIxc1eDLerUKW z$fv={nfj5biABcxE{U$eF8UB3>XsyC=9FjVO}6FL;WlJoU|<BLm2Sq#CA{(C0zwVE zAGkP$m_9JThz7n75|iKX${2Dn2ujYdxG139!23X0`~ri(12MY`48k8+IQW=8Fu;fg zt`8y%0tyX0A2=qb@Hs2-F|hL85YoFLATh({qJa7bR%QXV4-6oJnU$BRf%AjZWM%$9 aNgf71@dmCBTnu8S7Z`*fs7RlIfdK#?55&I! diff --git a/myproject/myproject/settings.py b/myproject/myproject/settings.py index d1a9799..56e2fdb 100644 --- a/myproject/myproject/settings.py +++ b/myproject/myproject/settings.py @@ -26,7 +26,7 @@ SECRET_KEY = 'django-insecure-t%k1f1!c4_9f#x@r_z_k69oz21@0eadh2qb_k3pm3=gknej9f@ # SECURITY WARNING: don't run with debug turned on in production! DEBUG = True -ALLOWED_HOSTS = ["*"] +ALLOWED_HOSTS = ['*'] # Application definition @@ -180,4 +180,3 @@ LOGOUT_REDIRECT_URL = '/' PAYPAL_MODE = 'sandbox' PAYPAL_CLIENT_ID = 'AYpHxonrFMrgnqmjii46SeNsQidn2PjJtEoIgVK0Nrda1iQFUbX28zyuMvUiJk67o_cHII3c8vCMWY-y' PAYPAL_CLIENT_SECRET = 'EPXXK3Z7xDr4Gy_kt4OkPLbJRXd9tP62q1Dpbmj5QiwaFh7twcSUalHDRBbFRwxdX_rmHk_F6YStXa95' - -- GitLab