Skip to main content

Page Lock application prevents users being able to edit same page defined by its unique URL at the same time. The application is tailored to django admin implementation.

Project description

## Django Admin Page Lock

Page Lock for Django Admin allows developers to implement customizable locking pages.
With Admin Page Locking, only the designated (typically first) user receives full rights.
Subsequent users get only rights assigned by the administrator. You can store page log data in
your application’s defined database.

#### Use Case:
1. User-1 lands on page. User1 has full rights (editing).
2. Users-N can land and view page, but cannot use full rights (no editing).
3. User-1 leaves.
4. Whoever next enters, or refreshes, becomes User-1.

### Features
* two models are available that define storing/loading data from storage (`redis` or `database`);
* developer can disable whole locking functionality;
* page url being lock can be composed with or without url parameters;
* very customizable.

### Requirements
* Django 1.8;
* Python 2.7.

### Instalation
* run `pip install django-admin-page-lock`;
* add `admin_page_lock` to `setings.py`;
* run `./manage.py migrate` or `./manage.py syncdb`.

### Configuration
* update template by adding:
```
<div id="page_lock_bar">
<div id="page_lock_message_display"></div>
<div id="page_lock_counter_display"></div>
<button type="button" id="page_lock_refresh_button">{% trans "REFRESH" %}</button>
<button type="button" id="page_lock_reload_button">{% trans "RELOAD" %}</button>
<input type="hidden" id="page_lock_template_data" value="{{ page_lock_template_data }}">
<input type="hidden" id="page_lock_api_interval" value="{{ page_lock_api_interval }}">
</div>
```
Note:
* to hide locking buttons for pages where locking logic is not needed, update template by adding js block:
```
<script type="text/javascript">
$(document).ready(function() {
var api_interval = parseInt($('#page_lock_api_interval').val());
if (!api_interval) {
$('.page_lock_bar').hide();
}
});
</script>
```;
* mark `html` items by `class=page_lock_block` to hide/show them;
* update `css` file in order to enhance included `html` code;
* views where you want to apply locking logic must be inherited from either `PageLockAdminMixin` or `PageLockViewMixin` for `django admin views` or `django views`, respectively;
* re-define parameters in your settings if you don't want to use default ones:

| Name | Type | Description |
| ---------------------- | ---------- | -------------------------------------------------- |
| API_INTERVAL | integer | interval between API calls from `js` |
| CAN_OPEN_MORE_TABS | boolean | whether use can open one page in more tabs |
| DISABLE_CRSF_TOKEN | boolean | whether app uses `CSRF` protection |
| DISABLE | boolean | switching off/on locking logic |
| HANDLER_CLASS | string | in case you want to define your handler |
| HOMEPAGE | string | page to redirect user if something goes wrong |
| MESSAGES | dictionary | for customizing messages (not implemented yet) |
| TIMEOUT | integer | interval user stays on the page without refreshing |
| MODEL | string | where data are stored (`redis` or `database`) |
| REDIS_SETTINGS | dictionary | settings of app `redis` |
| URL_IGNORE_PARAMETERS | boolean | whether url parameters are taken into account |

### APIs

#### 1. ClosePageConnection
There are several `APIs` listed bellow. There are implemented in the way that they can be used by both frontend (`js`)
and backend (`python`). The logic is implemented in `handlers.py` and depends on chosen model as well.

On the first glance, you can think that `GetPageInfo` and `OpenPageConnection` are same `APIs` but
the functionality of first one doesn't change anything but second one.

| Method |Name | Type | Description |
|---------- |------------------- | --------- | ------------------------------------------------- |
| POST | url | string | url of the page |
| POST | user_reference | string | reference of user (`id` or `current section` ) |
| POST | csrf_token | string | generated `csfr` protection token |
| GET | is_locked | boolean | whether the page is locked |

#### 2. GetPageInfo

| Method |Name | Type | Description |
|---------- |------------------- | --------- | ------------------------------------------------- |
| POST | url | string | url of the page |
| POST | user_reference | string | reference of user (`id` or `current section` ) |
| POST | csrf_token | string | generated `csfr` protection token |
| GET | is_locked | boolean | whether the page is locked |
| GET | locked_by | string | user_reference of user locking current page |
| GET | page_lock_settings | dictionary| various parameters of settings |
| GET | reconnected | boolean | whether user is reconnected (not implemented yet) |

#### 3. OpenPageConnection

| Method |Name | Type | Description |
|---------- |------------------- | --------- | ------------------------------------------------- |
| POST | url | string | url of the page |
| POST | user_reference | string | reference of user (`id` or `current section` ) |
| POST | csrf_token | string | generated `csfr` protection token |
| GET | is_locked | boolean | whether the page is locked |
| GET | locked_by | string | user_reference of user locking current page |
| GET | page_lock_settings | dictionary| various parameters of settings |
| GET | reconnected | boolean | whether user is reconnected (not implemented yet) |


### TODO
There are still several functionalities missing. I would appreciate any contribution.
* writing unit tests;
* finish using `CAN_OPEN_MORE_TABS` settings parameter;
* migrating logic related to reopening from `OpenPageConnection` to new API `ReopenPageConnection`;

### To be implemented soon:
1. User lands on page. Page is locked for only this user.
2. Other user attempts to open page.
3. Other users get redirected to landing page (homepage, create new, and so on).

### Users
* Showmax uses this package as part of Content Management System.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-admin-page-lock-1.2.1.tar.gz (28.1 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page