+
+@never_cache
+def logout(request, template_name='cas/logout.html',
+ auto_redirect=settings.CAS_AUTO_REDIRECT_AFTER_LOGOUT):
+ url = request.GET.get('url', None)
+ if request.user.is_authenticated:
+ for ticket in ServiceTicket.objects.filter(user=request.user):
+ ticket.delete()
+ auth_logout(request)
+ if url and auto_redirect:
+ return HttpResponseRedirect(url)
+ return render(request, template_name, {'url': url})
+
+
+@never_cache
+def proxy(request):
+ targetService = request.GET['targetService']
+ pgt_id = request.GET['pgt']
+
+ try:
+ proxyGrantingTicket = ProxyGrantingTicket.objects.get(ticket=pgt_id)
+ except ProxyGrantingTicket.DoesNotExist:
+ return _cas2_error_response(INVALID_TICKET)
+
+ pt = ProxyTicket.objects.create(proxyGrantingTicket=proxyGrantingTicket,
+ user=proxyGrantingTicket.user,
+ service=targetService)
+ return _cas2_proxy_success(pt.ticket)
+
+
+def ticket_validate(service, ticket_string, pgtUrl):
+ if service is None or ticket_string is None:
+ return _cas2_error_response(INVALID_REQUEST)
+
+ try:
+ if ticket_string.startswith('ST'):
+ ticket = ServiceTicket.objects.get(ticket=ticket_string)
+ elif ticket_string.startswith('PT'):
+ ticket = ProxyTicket.objects.get(ticket=ticket_string)
+ else:
+ return _cas2_error_response(INVALID_TICKET,
+ '%(ticket)s is neither Service (ST-...) nor Proxy Ticket (PT-...)' % {
+ 'ticket': ticket_string})
+ except ServiceTicket.DoesNotExist:
+ return _cas2_error_response(INVALID_TICKET)
+
+ ticketUrl = urlparse(ticket.service)
+ serviceUrl = urlparse(service)
+
+ if not(ticketUrl.hostname == serviceUrl.hostname and ticketUrl.path == serviceUrl.path and ticketUrl.port == serviceUrl.port):
+ return _cas2_error_response(INVALID_SERVICE)
+
+ pgtIouId = None
+ proxies = ()
+ if pgtUrl is not None:
+ pgt = generate_proxy_granting_ticket(pgtUrl, ticket)
+ if pgt:
+ pgtIouId = pgt.pgtiou
+
+ try:
+ proxyTicket = ticket.proxyticket
+ except ProxyTicket.DoesNotExist:
+ pass
+ else:
+ pgt = proxyTicket.proxyGrantingTicket
+ # I am issued by this proxy granting ticket
+ while pgt.pgt is not None:
+ proxies += (pgt.service,)
+ pgt = pgt.pgt
+
+ user = ticket.user
+ ticket.delete()
+ return _cas2_sucess_response(user, pgtIouId, proxies)
+
+
+@never_cache