Skip to main content

ACID transaction with common files

Project description

acidfile
========

`acidfile` module provides the ACIDFile object. This object can be used as a
regular file object but instead of write one copy of the data, it will write
several copies to disk in an ACID manner.

This algorithm was explained by `Elvis Pfützenreuter`_ in his blog post
`Achieving ACID transactions with common files`_.

Latest stable version can be found on `PyPI`_.

.. image:: https://travis-ci.org/nilp0inter/acidfile.png?branch=develop
:target: https://travis-ci.org/nilp0inter/acidfile

.. image:: https://pypip.in/v/acidfile/badge.png
:target: https://pypi.python.org/pypi/acidfile
:alt: Latest PyPI version

.. image:: https://pypip.in/d/acidfile/badge.png
:target: https://pypi.python.org/pypi/acidfile
:alt: Number of PyPI downloads

`acidfile` is compatible with python 2.6, 2.7, 3.2, 3.3, 3.4 and pypy

Contribute:

.. image:: http://api.flattr.com/button/flattr-badge-large.png
:target: https://flattr.com/submit/auto?user_id=nilp0inter&url=https://github.com/nilp0inter/acidfile&title=acidfile&language=&tags=github&category=software
:alt: Flattr this git repo

Installation
------------

Latest version can be installed via `pip`

.. code-block:: bash

$ pip install --upgrade acidfile


Running the tests
-----------------

Clone this repository and install the develop requirements.

.. code-block:: bash

$ git clone https://github.com/nilp0inter/acidfile.git
$ cd acidfile
$ pip install -r requirements/develop.txt
$ python setup.py develop
$ tox


Usage examples
--------------


Basic usage
+++++++++++

.. code-block:: python

>>> from acidfile import ACIDFile

>>> myfile = ACIDFile('/tmp/myfile.txt', 'w')
>>> myfile.write(b'Some important data.')
>>> myfile.close()

At the close invocation two copies will be written to disk: *myfile.txt.0* and
below *myfile.txt.1*. Each one will have an creation timestamp and a HMAC
signature.

.. code-block:: python

>>> myfile = ACIDFile('/tmp/myfile.txt', 'r')
>>> print myfile.read()
'Some important data.'
>>> myfile.close()

If any of the files is damaged due to turning off without proper shutdown or
disk failure, manipulation, etc. It will be detected by the internal HMAC and
the other's file data would be used instead.

.. note:: If you want to read an `acidfile`, never pass the full path of the
real file, instead use the file name that you use in the creation step.

| ✗ ACIDFile('/tmp/myfile.txt.0', 'r')
| ✗ ACIDFile('/tmp/myfile.txt.1', 'r')
| ✓ ACIDFile('/tmp/myfile.txt', 'r')


Context manager
+++++++++++++++

ACIDFile can (and should) be used as a regular context manager:

.. code-block:: python

>>> with ACIDFile('/tmp/myfile.txt', 'w') as myfile:
... myfile.write(b'Some important data.')


Number of copies
++++++++++++++++

The number of inner copies of the data can be configured through the **copies**
parameter.


Checksum Key
++++++++++++

The key used for compute and check the internal HMAC signature can be setted
by the **key** parameter.

It's recommended to change that key in order to protect against fraud, making
more difficult for a tamperer to put a fake file in place of the legitimate
one.

.. _PyPI: https://pypi.python.org/pypi/acidfile
.. _Elvis Pfützenreuter: epx@epx.com.br
.. _Achieving ACID transactions with common files: http://epx.com.br/artigos/arqtrans_en.php


.. This is your project NEWS file which will contain the release notes.
.. Example: http://www.python.org/download/releases/2.6/NEWS.txt
.. The content of this file, along with README.rst, will appear in your
.. project's PyPI page.

News
====


1.2.1
-----

* Using io.open in setup.py to read README and NEWS. This fix some
problems installing the package.
+ Python 3.4 support.


1.2.0
-----

+ Python 2.6 support.
+ Added Python 3.2 and pypy to tox tests.
+ Added flattr button :D
* Fixed flake8 and pylint warnings.


1.1.0
-----

+ Python 3 support.
+ Changed testing framework to `behave` because python 3 support.
+ Using `tox` for multiple python version testing.


1.0.0
-----

* First stable release.
+ Documentation.


0.0.1
-----

* Initial development.

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

acidfile-1.2.1.tar.gz (6.1 kB view details)

Uploaded Source

File details

Details for the file acidfile-1.2.1.tar.gz.

File metadata

  • Download URL: acidfile-1.2.1.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for acidfile-1.2.1.tar.gz
Algorithm Hash digest
SHA256 c77bbcc7454235029cab6a116d824cf896b0a0b133470a137bac3f792f6c7dbc
MD5 b9cc1f6c8fc78135b286967fb0d5f3d7
BLAKE2b-256 1f4f51ba5631b70efedd1ba0267ea0845bd7bb968c7cfef7b80a93ae6c9b15b4

See more details on using hashes here.

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