from django.http import JsonResponse from django.contrib import auth from django.contrib.auth.models import Group, User, Permission from django.core import mail from django.db.models import Q from django.shortcuts import render, redirect from django.template.loader import render_to_string from OACPL.utils import url_fix_render_to_string from charter_members.models import Attorney from newsletters.models import Subscriber from OACPL import settings def index(request): attorneys = Attorney.objects.filter(front_page=True).order_by('order') return render(request, 'index.html', {'attorneys': attorneys, 'contact': settings.EMAIL_CONTACT}) def contact(request): name = request.POST.get('name') email = request.POST.get('email') subject = request.POST.get('subject') body = request.POST.get('body') result = False if name is not None and email is not None and subject is not None and body is not None: result = mail.send_mail('OACPL CONTACT: %(subject)s' % locals(), body, settings.EMAIL_HOST_USER, [settings.EMAIL_CONTACT], html_message=url_fix_render_to_string('email.html', {'content': 'Someone has messaged you via the website contact form!

Subject:
%(subject)s
From: %(name)s <%(email)s>

%(body)s' % locals(), 'signature': ' '})) return JsonResponse({'success': True if result else False}) def login(request): if request.method == 'POST': if request.POST.get('request') == 'login': user = auth.authenticate(request, username=request.POST.get('username'), password=request.POST.get('password')) if user: auth.login(request, user) return redirect('/') else: return render(request, 'login.html', {'navbar': False, 'footer': False, 'failed': True}) elif request.POST.get('request') == 'register': user = User.objects.create_user(request.POST.get('username'), email=request.POST.get('email'), password=request.POST.get('password')) user.save() default_group = Group.objects.filter(name='default') if default_group: default_group[0].user_set.add(user) if settings.EMAIL_HOST: mail.send_mail('OACPL Registration', 'You have successfully registered to the Ontario Association of Child Protection Lawyers!', settings.EMAIL_HOST_USER, [request.POST.get('email')], html_message=render_to_string('email.html', {'content': 'You have successfully registered to the Ontario Association of Child Protection Lawyers!', 'name': user.username, 'base_url': settings.BASE_URL})) if request.POST.get('newsletter'): Subscriber.objects.create(email=request.POST.get('email')) if request.POST.get('caselaw'): perm = Permission.objects.get(codename='change_user') admins = User.objects.filter(Q(groups__permissions=perm) | Q(user_permissions=perm) | Q(is_superuser=True)).distinct().values_list('email', flat=True) mail.send_mail('OACPL Case Law Request', '{} {} ({}) has requested access to case law'.format(user.first_name, user.last_name, user.email), settings.EMAIL_HOST_USER, admins, html_message=render_to_string('email.html', {'content': '%(email)s has requested case law access.', 'base_url': settings.BASE_URL})) auth.login(request, user) return redirect('/') else: return render(request, 'login.html', {'navbar': False, 'footer': False}) def logout(request): auth.logout(request) return redirect('/')