Metadata-Version: 2.1
Name: django-zookeeper-locks
Version: 1.0.0
Summary: Utils for using Zookeeper locks through zookeeper in Django commands and views.
Author: WeDeploy
Author-email: github@wedeploy.com
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Description-Content-Type: text/markdown
License-File: LICENSE

Django Zookeeper Locks
==================

![example workflow](https://github.com/wedeploy/django-zookeeper-locks/actions/workflows/test-package.yml/badge.svg?branch=main)
[![Coverage Status](https://coveralls.io/repos/github/wedeploy/django-zookeeper-locks/badge.svg)](https://coveralls.io/github/wedeploy/django-zookeeper-locks)

About
-----

[Django Zookeeper
Locks](https://github.com/wedeploy/django-zookeeper-locks) provides a
utils for using Zookeeper locks through zookeeper in
[Django](https://www.djangoproject.com) applications.

Install
-------

```bash
pip install django-zookeeper-locks
```

Usage
-----

Register app in `INSTALLED_APPS` and define following settings:

```python
ZOOKEEPER_APP_NAMESPACE = 'some-unique-app-name'
ZOOKEEPER_HOSTS = ['10.32.96.201:2181']
```

Usage example:

```python
lock = Lock('my-lock-{object_id}')
with lock(object_id=123):
    print('so alone')

try:
    with lock(object_id=123, timeout=9):
        print('so alone')
except LockTimeout:
    print('unable to lock after waiting for 9s')

try:
    with lock(object_id=123, blocking=False):
        print('so alone')
except Locked:
    print('unable to lock immediately')
```

Extras
------

Migrations
----------

This package defines its version of the data migration command -
`migrate_with_zookeeper`. Thanks to this command it is possible to quickly
and correctly perform data migration process in applications running
simultaneously on many different hosts and using the same database. The
command can be used independently or as a base class for the migrate
command in your own application. The `__init__` method of the defined
class accepts the optional `lock` argument, which allows you to define
your own `zookeeper_locks.locks.Lock` object to protect the critical section
of the migration.

License
-------

The Django Zookeeper Locks package is licensed under the [FreeBSD
License](https://opensource.org/licenses/BSD-2-Clause).
