Full documentation


Settings for django-session-security.

Time (in seconds) before the user should be warned that is session will expire because of inactivity. Default 540. Overridable in settings.SESSION_SECURITY_WARN_AFTER.
Time (in seconds) before the user should be logged out if inactive. Default is 600. Overridable in settings.SESSION_SECURITY_EXPIRE_AFTER.
List of urls that should be ignored by the middleware. For example the ping ajax request of session_security is made without user intervention, as such it should not be used to update the user’s last activity datetime. Overridable in settings.SESSION_SECURITY_PASSIVE_URLS.
Same as PASSIVE_URLS, but takes Django URL names instead of a path. This is useful in case path names change, or contain parameterized values, and thus cannot be described statically. NOTE: currently namespaces are not handled. Overridable in settings.SESSION_SECURITY_PASSIVE_URL_NAMES.
Set this to True in your settings if you want the project to run without having to set SESSION_EXPIRE_AT_BROWSER_CLOSE=True, which you should because it makes no sense to use this app with SESSION_EXPIRE_AT_BROWSER_CLOSE to False.


SessionSecurityMiddleware is the heart of the security that this application attemps to provide.

To install this middleware, add to your settings.MIDDLEWARE_CLASSES:


Make sure that it is placed after authentication middlewares.

class session_security.middleware.SessionSecurityMiddleware(get_response=None)[source]

In charge of maintaining the real ‘last activity’ time, and log out the user if appropriate.


Return time (in seconds) before the user should be logged out.


Should we skip activity update on this URL/View.


Update last activity time or logout.

update_last_activity(request, now)[source]

If request.GET['idleFor'] is set, check if it refers to a more recent activity than request.session['_session_security'] and update it in this case.


Helpers to support json encoding of session data


Get the last activity datetime string from the session and return the python datetime object.

session_security.utils.set_last_activity(session, dt)[source]

Set the last activity datetime as a string in the session.


One url meant to be used by JavaScript.

Connects the PingView.

To install this url, include it in urlpatterns definition in urls.py, ie:

urlpatterns = patterns('',
    # ....
    url(r'session_security/', include('session_security.urls')),
    # ....


One view method for AJAX requests by SessionSecurity objects.

class session_security.views.PingView(**kwargs)[source]

This view is just in charge of returning the number of seconds since the ‘real last activity’ that is maintained in the session by the middleware.

Constructor. Called in the URLconf; can contain helpful extra keyword arguments, and other things.



{% load i18n %}

<div id="session_security_warning" class="session_security" style="display:none" aria-hidden="true" role="dialog">
    <div class="session_security_overlay"></div>
    <div class="session_security_modal" role="document" tabindex="-1">
        <h3>{% trans 'Your session is about to expire' %}</h3>
        <p>{% trans 'Click or type to extend your session.' %}</p>


{% comment %}
This demonstrates how to setup session security client side stuff on your own.
It provides sensible defaults so you could start with just::

    {% include 'session_security/all.html' %}

{% endcomment %}

{% load session_security_tags %}
{% load i18n l10n %}
{% load static from staticfiles %}

{# If the user is not authenticated then there is no session to secure ! #}
{% if request.user.is_authenticated %}

    {# The modal dialog stylesheet, it's pretty light so it should be easy to hack #}
    <link rel="stylesheet" type="text/css" href="{% static 'session_security/style.css' %}">

    {# Include the template that actually contains the modal dialog #}
    {% include 'session_security/dialog.html' %}

    {# Load SessionSecurity javascript 'class', jquery should be loaded - by you - at this point #}
    <script type="text/javascript" src="{% static 'session_security/script.js' %}"></script>

    {# Bootstrap a SessionSecurity instance as the sessionSecurity global variable #}
    {% localize off %}
        <script type="text/javascript">
            var sessionSecurity = new yourlabs.SessionSecurity({
                pingUrl: '{% url 'session_security_ping' %}',
                warnAfter: {{ request|warn_after|unlocalize }},
                expireAfter: {{ request|expire_after|unlocalize }},
                confirmFormDiscard: "{% trans 'You have unsaved changes in a form of this page.' %}"
    {% endlocalize %}    
{% endif %}

Static files


Read the script documentation


/* credit: http://www.csslab.cl/2008/01/30/ventana-modal-solo-con-css/ */
.session_security_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    -moz-opacity: 0.75;
    filter: alpha(opacity=75);

.session_security_modal {
    position: fixed;
    top: 25%;
    left: 25%;
    width: 50%;
    padding: 16px;
    background: #fff;
    color: #333;
    overflow: auto;
    text-align: center;