Compare commits
No commits in common. "2b4010418060b124af8e50bc75df9969a1ea8911" and "32be1999e94d41995f2815650a40b595510b2953" have entirely different histories.
2b40104180
...
32be1999e9
|
@ -1,4 +1,3 @@
|
||||||
from smtplib import SMTPException
|
|
||||||
from django.urls import reverse_lazy
|
from django.urls import reverse_lazy
|
||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
from django.utils.translation import gettext_lazy as _
|
from django.utils.translation import gettext_lazy as _
|
||||||
|
@ -10,7 +9,6 @@ from django.views.generic.edit import (
|
||||||
)
|
)
|
||||||
from dashboard.mixins import DashboardView, Http403
|
from dashboard.mixins import DashboardView, Http403
|
||||||
from user.models import User, Institution
|
from user.models import User, Institution
|
||||||
from admin.email import NotifyActivateUserByEmail
|
|
||||||
|
|
||||||
|
|
||||||
class AdminView(DashboardView):
|
class AdminView(DashboardView):
|
||||||
|
@ -44,7 +42,7 @@ class UsersView(AdminView, TemplateView):
|
||||||
return context
|
return context
|
||||||
|
|
||||||
|
|
||||||
class CreateUserView(AdminView, NotifyActivateUserByEmail, CreateView):
|
class CreateUserView(AdminView, CreateView):
|
||||||
template_name = "user.html"
|
template_name = "user.html"
|
||||||
title = _("User")
|
title = _("User")
|
||||||
breadcrumb = _("admin / User") + " /"
|
breadcrumb = _("admin / User") + " /"
|
||||||
|
@ -60,12 +58,6 @@ class CreateUserView(AdminView, NotifyActivateUserByEmail, CreateView):
|
||||||
form.instance.institution = self.request.user.institution
|
form.instance.institution = self.request.user.institution
|
||||||
form.instance.set_password(form.instance.password)
|
form.instance.set_password(form.instance.password)
|
||||||
response = super().form_valid(form)
|
response = super().form_valid(form)
|
||||||
|
|
||||||
try:
|
|
||||||
self.send_email(form.instance)
|
|
||||||
except SMTPException as e:
|
|
||||||
messages.error(self.request, e)
|
|
||||||
|
|
||||||
return response
|
return response
|
||||||
|
|
||||||
|
|
||||||
|
|
23
api/views.py
23
api/views.py
|
@ -1,6 +1,5 @@
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from django.conf import settings
|
|
||||||
from django.urls import reverse_lazy
|
from django.urls import reverse_lazy
|
||||||
from django.shortcuts import get_object_or_404, redirect
|
from django.shortcuts import get_object_or_404, redirect
|
||||||
from django.utils.translation import gettext_lazy as _
|
from django.utils.translation import gettext_lazy as _
|
||||||
|
@ -70,29 +69,9 @@ def NewSnapshot(request):
|
||||||
except Exception:
|
except Exception:
|
||||||
return JsonResponse({'status': 'fail'}, status=200)
|
return JsonResponse({'status': 'fail'}, status=200)
|
||||||
|
|
||||||
annotation = Annotation.objects.filter(
|
return JsonResponse({'status': 'success'}, status=200)
|
||||||
uuid=data['uuid'],
|
|
||||||
type=Annotation.Type.SYSTEM,
|
|
||||||
key="hidalgo1",
|
|
||||||
owner=tk.owner.institution
|
|
||||||
).first()
|
|
||||||
|
|
||||||
|
|
||||||
if not annotation:
|
|
||||||
return JsonResponse({'status': 'fail'}, status=200)
|
|
||||||
|
|
||||||
url = "{}://{}{}".format(
|
|
||||||
request.scheme,
|
|
||||||
settings.DOMAIN,
|
|
||||||
reverse_lazy("device:details", args=(annotation.value,))
|
|
||||||
)
|
|
||||||
response = {
|
|
||||||
"status": "success",
|
|
||||||
"dhid": annotation.value[:5].upper(),
|
|
||||||
"url": url,
|
|
||||||
"public_url": url
|
|
||||||
}
|
|
||||||
return JsonResponse(response, status=200)
|
|
||||||
|
|
||||||
|
|
||||||
class TokenView(DashboardView, SingleTableView):
|
class TokenView(DashboardView, SingleTableView):
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
{% trans 'Documents' %}
|
{% trans 'Documents' %}
|
||||||
</a>
|
</a>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<a href="{# url 'dashboard:exports' object.id #}" type="button" class="btn btn-green-admin">
|
<a href="{# url 'idhub:admin_people_activate' object.id #}" type="button" class="btn btn-green-admin">
|
||||||
<i class="bi bi-reply"></i>
|
<i class="bi bi-reply"></i>
|
||||||
{% trans 'Exports' %}
|
{% trans 'Exports' %}
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -27,7 +27,7 @@ class Device:
|
||||||
# the id is the chid of the device
|
# the id is the chid of the device
|
||||||
self.id = kwargs["id"]
|
self.id = kwargs["id"]
|
||||||
self.pk = self.id
|
self.pk = self.id
|
||||||
self.shortid = self.pk[:6].upper()
|
self.shortid = self.pk[:6]
|
||||||
self.algorithm = None
|
self.algorithm = None
|
||||||
self.owner = None
|
self.owner = None
|
||||||
self.annotations = []
|
self.annotations = []
|
||||||
|
|
|
@ -39,30 +39,6 @@ assert DOMAIN in ALLOWED_HOSTS, "DOMAIN is not ALLOWED_HOST"
|
||||||
|
|
||||||
CSRF_TRUSTED_ORIGINS = config('CSRF_TRUSTED_ORIGINS', default=f'https://{DOMAIN}', cast=Csv())
|
CSRF_TRUSTED_ORIGINS = config('CSRF_TRUSTED_ORIGINS', default=f'https://{DOMAIN}', cast=Csv())
|
||||||
|
|
||||||
|
|
||||||
INITIAL_ADMIN_EMAIL = config("INITIAL_ADMIN_EMAIL", default='admin@example.org')
|
|
||||||
INITIAL_ADMIN_PASSWORD = config("INITIAL_ADMIN_PASSWORD", default='1234')
|
|
||||||
|
|
||||||
DEFAULT_FROM_EMAIL = config(
|
|
||||||
'DEFAULT_FROM_EMAIL', default='webmaster@localhost')
|
|
||||||
|
|
||||||
EMAIL_HOST = config('EMAIL_HOST', default='localhost')
|
|
||||||
|
|
||||||
EMAIL_HOST_USER = config('EMAIL_HOST_USER', default='')
|
|
||||||
|
|
||||||
EMAIL_HOST_PASSWORD = config('EMAIL_HOST_PASSWORD', default='')
|
|
||||||
|
|
||||||
EMAIL_PORT = config('EMAIL_PORT', default=25, cast=int)
|
|
||||||
|
|
||||||
EMAIL_USE_TLS = config('EMAIL_USE_TLS', default=False, cast=bool)
|
|
||||||
|
|
||||||
EMAIL_BACKEND = config('EMAIL_BACKEND', default='django.core.mail.backends.smtp.EmailBackend')
|
|
||||||
|
|
||||||
EMAIL_FILE_PATH = config('EMAIL_FILE_PATH', default='/tmp/app-messages')
|
|
||||||
|
|
||||||
ENABLE_EMAIL = config("ENABLE_EMAIL", default=True, cast=bool)
|
|
||||||
|
|
||||||
|
|
||||||
# Application definition
|
# Application definition
|
||||||
|
|
||||||
INSTALLED_APPS = [
|
INSTALLED_APPS = [
|
||||||
|
|
|
@ -1,31 +0,0 @@
|
||||||
{% load i18n %}{% autoescape off %}
|
|
||||||
{% trans "DeviceHub" as site %}
|
|
||||||
<p>
|
|
||||||
{% blocktrans %}You're receiving this email because your user account at {{site}} has been activated.{% endblocktrans %}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
{% trans "Your username is:" %} {{ user.username }}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
{% trans "Please go to the following page and choose a password:" %}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
{% block reset_link %}
|
|
||||||
<a href="{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}">
|
|
||||||
{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}
|
|
||||||
</a>
|
|
||||||
{% endblock %}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
{% trans "Thanks for using our site!" %}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
{% blocktrans %}The {{site}} team{% endblocktrans %}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
{% endautoescape %}
|
|
|
@ -1,19 +0,0 @@
|
||||||
{% load i18n %}{% autoescape off %}
|
|
||||||
|
|
||||||
{% trans "DeviceHub" as site %}
|
|
||||||
|
|
||||||
{% blocktrans %}You're receiving this email because your user account at {{site}} has been activated.{% endblocktrans %}
|
|
||||||
|
|
||||||
{% trans "Your username is:" %} {{ user.username }}
|
|
||||||
|
|
||||||
{% trans "Please go to the following page and choose a password:" %}
|
|
||||||
{% block reset_link %}
|
|
||||||
{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}
|
|
||||||
{% endblock %}
|
|
||||||
|
|
||||||
|
|
||||||
{% trans "Thanks for using our site!" %}
|
|
||||||
|
|
||||||
{% blocktrans %}The {{site}} team{% endblocktrans %}
|
|
||||||
|
|
||||||
{% endautoescape %}
|
|
|
@ -1,4 +0,0 @@
|
||||||
{% load i18n %}{% autoescape off %}
|
|
||||||
{% trans "IdHub" as site %}
|
|
||||||
{% blocktrans %}User activation on {{site}}{% endblocktrans %}
|
|
||||||
{% endautoescape %}
|
|
|
@ -9,8 +9,8 @@
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
{% block reset_link %}
|
{% block reset_link %}
|
||||||
<a href="{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}">
|
<a href="{{ protocol }}://{{ domain }}{% url 'idhub:password_reset_confirm' uidb64=uid token=token %}">
|
||||||
{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}
|
{{ protocol }}://{{ domain }}{% url 'idhub:password_reset_confirm' uidb64=uid token=token %}
|
||||||
</a>
|
</a>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
{% trans "Please go to the following page and choose a new password:" %}
|
{% trans "Please go to the following page and choose a new password:" %}
|
||||||
{% block reset_link %}
|
{% block reset_link %}
|
||||||
{{ protocol }}://{{ domain }}{% url 'login:password_reset_confirm' uidb64=uid token=token %}
|
{{ protocol }}://{{ domain }}{% url 'idhub:password_reset_confirm' uidb64=uid token=token %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
{% trans "Your username, in case you've forgotten:" %} {{ user.username }}
|
{% trans "Your username, in case you've forgotten:" %} {{ user.username }}
|
||||||
|
|
||||||
|
|
|
@ -65,10 +65,8 @@ class PasswordResetView(auth_views.PasswordResetView):
|
||||||
success_url = reverse_lazy('login:password_reset_done')
|
success_url = reverse_lazy('login:password_reset_done')
|
||||||
|
|
||||||
def form_valid(self, form):
|
def form_valid(self, form):
|
||||||
import pdb; pdb.set_trace()
|
|
||||||
try:
|
try:
|
||||||
response = super().form_valid(form)
|
return super().form_valid(form)
|
||||||
return response
|
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
logger.error(err)
|
logger.error(err)
|
||||||
return HttpResponseRedirect(self.success_url)
|
return HttpResponseRedirect(self.success_url)
|
||||||
|
|
Loading…
Reference in a new issue