Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

pypm install django-cas-provider

How to install django-cas-provider

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install django-cas-provider
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
0.3.1 Available View build log
0.3.0 Available View build log
Windows (64-bit)
0.3.1 Available View build log
0.3.0 Available View build log
Mac OS X (10.5+)
0.3.1 Available View build log
0.3.0 Available View build log
Linux (32-bit)
0.3.1 Available View build log
0.3.0 Available View build log
Linux (64-bit)
0.3.1 Available View build log
0.3.0 Available View build log
Lastest release
version 0.3.1 on Oct 18th, 2011


django-cas-provider is a provider for the Central Authentication Service. It supports CAS version 1.0 and parts of CAS version 2.0 protocol. It allows remote services to authenticate users for the purposes of Single Sign-On (SSO). For example, a user logs into a CAS server (provided by django-cas-provider) and can then access other services (such as email, calendar, etc) without re-entering her password for each service. For more details, see the CAS wiki and Single Sign-On on Wikipedia.


To install, run the following command from this directory:

python setup.py install

Or, put cas_provider somewhere on your Python path.

If you want use CAS v.2 protocol or above, you must install lxml package to correct work.


I introduced south for DB schema migration. The schema from any previous version without south is 0001_initial. You will get an error:

Running migrations for cas_provider:

- Migrating forwards to 0001_initial.

> cas_provider:0001_initial

Traceback (most recent call last):


django.db.utils.DatabaseError: relation "cas_provider_serviceticket" already exists

to circumvent that problem you will need to fake the initial migration:

python manage.py migrate cas_provider 0001_initial --fake


  1. Add 'cas_provider' to your INSTALLED_APPS tuple in settings.py.
  2. In settings.py, set LOGIN_URL to '/cas/login/' and LOGOUT_URL to '/cas/logout/'
  3. In urls.py, put the following line: (r'^cas/', include('cas_provider.urls')),
  4. Create login/logout templates (or modify the samples)
  5. Use 'cleanuptickets' management command to clean up expired tickets


CAS_TICKET_EXPIRATION - minutes to tickets expiration. Default is 5 minutes.

CAS_CUSTOM_ATTRIBUTES_CALLBACK - name of callback to provide dictionary with extended user attributes (may be used in CAS v.2 or above). Default is None.

CAS_CUSTOM_ATTRIBUTES_FORMAT - name of custom attribute formatter callback will be used to format custom user attributes. This package provide module attribute_formatters with formatters for common used formats. Available formats styles are RubyCAS, Jasig and `Name-Value. Default is Jasig style. See module source code for more details.

System Message: WARNING/2 (<string>, line 62); backlink

Inline interpreted text or phrase reference start-string without end-string.

CAS_AUTO_REDIRECT_AFTER_LOGOUT - If False (default behavior, specified in CAS protocol) after successful logout notification page will be shown. If it's True, after successful logout will be auto redirect back to service without any notification.


System Message: WARNING/2 (<string>, line 73)

Title underline too short.

  • CAS Protocol <http://www.jasig.org/cas/protocol>
  • CAS 1 Architecture <http://www.jasig.org/cas/cas1-architecture>
  • CAS 2 Architecture <http://www.jasig.org/cas/cas2-architecture>
  • Proxy Authentication <http://www.jasig.org/cas/proxy-authentication>
  • CAS – Central Authentication Service <http://www.jusfortechies.com/cas/overview.html>
  • Proxy CAS Walkthrough <https://wiki.jasig.org/display/CAS/Proxy+CAS+Walkthrough>


System Message: WARNING/2 (<string>, line 83)

Title underline too short.


It has not required arguments.

Optional arguments:

  • template_name - login form template name (default is 'cas/login.html')

  • success_redirect - redirect after successful login if service GET argument is not provided

    (default is settings.LOGIN_REDIRECT_URL)

  • warn_template_name - warning page template name to allow login user to service if he already authenticated in SSO (default is 'cas/warn.html')

If request.GET has 'warn' argument and user has already authenticated in SSO it shows warning message instead of generate Service Ticket and redirect.


This destroys a client's single sign-on CAS session. The ticket-granting cookie is destroyed, and subsequent requests to login view will not obtain service tickets until the user again presents primary credentials (and thereby establishes a new single sign-on session).

It has not required arguments.

Optional arguments:

  • template_name - template name for page with successful logout message (default is 'cas/logout.html')

It checks the validity of a service ticket. It is part of the CAS 1.0 protocol and thus does not handle proxy authentication.

It has not arguments.


It checks the validity of a service ticket and returns an XML-fragment response via CAS 2.0 protocol. Work with proxy is not supported yet.

It has not arguments.


System Message: WARNING/2 (<string>, line 132)

Title underline too short.


Custom attribute format style may be changed in project settings with CAS_CUSTOM_ATTRIBUTES_FORMAT constant. You can provide your own formatter callback or specify existing in this package in attribute_formatters module.

Attribute formatter callback takes two arguments:

  • auth_success - cas:authenticationSuccess node. It is `lxml.etree.SubElement`instance;

    System Message: WARNING/2 (<string>, line 140); backlink

    Inline interpreted text or phrase reference start-string without end-string.

  • attrs - dictionary with user attributes received from callback specified in

    CAS_CUSTOM_ATTRIBUTES_CALLBACK in project settings.

Example of generated XML below:

<cas:serviceResponse xmlns:cas='http://www.yale.edu/tp/cas'>

        <!-- extended user attributes wiil be here -->

  • Name-Value style (provided in cas_provider.attribute_formatters.name_value):

    <cas:attribute name='attraStyle' value='Name-Value' />
    <cas:attribute name='surname' value='Smith' />
    <cas:attribute name='givenName' value='John' />
    <cas:attribute name='memberOf' value='CN=Staff,OU=Groups,DC=example,DC=edu' />
    <cas:attribute name='memberOf' value='CN=Spanish Department,OU=Departments,OU=Groups,DC=example,DC=edu' />
  • Jasig Style attributes (provided in cas_provider.attribute_formatters.jasig):

        <cas:memberOf>CN=Spanish Department,OU=Departments,OU=Groups,DC=example,DC=edu</cas:memberOf>
  • RubyCAS style (provided in cas_provider.attribute_formatters.ruby_cas):

    <cas:memberOf>CN=Spanish Department,OU=Departments,OU=Groups,DC=example,DC=edu</cas:memberOf>

Subscribe to package updates

Last updated Oct 18th, 2011

Download Stats

Last month:2

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.