paste.auth.cas – CAS authentication

CAS 1.0 Authentication

The Central Authentication System is a straight-forward single sign-on mechanism developed by Yale University’s ITS department. It has since enjoyed widespread success and is deployed at many major universities and some corporations.

This implementation has the goal of maintaining current path arguments passed to the system so that it can be used as middleware at any stage of processing. It has the secondary goal of allowing for other authentication methods to be used concurrently.

Module Contents

class paste.auth.cas.AuthCASHandler(application, authority)

middleware to implement CAS 1.0 authentication

There are several possible outcomes:

  1. If the REMOTE_USER environment variable is already populated; then this middleware is a no-op, and the request is passed along to the application.

  2. If a query argument ‘ticket’ is found, then an attempt to validate said ticket /w the authentication service done. If the ticket is not validated; an 403 ‘Forbidden’ exception is raised. Otherwise, the REMOTE_USER variable is set with the NetID that was validated and AUTH_TYPE is set to “cas”.

  3. Otherwise, a 303 ‘See Other’ is returned to the client directing them to login using the CAS service. After logon, the service will send them back to this same URL, only with a ‘ticket’ query argument.

Parameters:

authority

This is a fully-qualified URL to a CAS 1.0 service. The URL should end with a ‘/’ and have the ‘login’ and ‘validate’ sub-paths as described in the CAS 1.0 documentation.