Database backend for Annotator (http://annotatorjs.org)
Project description
Annotator Store
This is a backend store for Annotator.
The functionality can roughly be separated in two parts:
An abstraction layer wrapping Elasticsearch, to easily manage annotation storage. It features authorization to filter search results according to their permission settings.
A Flask blueprint for a web server that exposes an HTTP API to the annotation storage. To use this functionality, build this package with the [flask] option.
Getting going
You’ll need a recent version of Python (Python 2 >=2.6 or Python 3 >=3.3) and ElasticSearch (>=1.0.0) installed.
The quickest way to get going requires the pip and virtualenv tools (easy_install virtualenv will get them both). Run the following in the repository root:
virtualenv pyenv source pyenv/bin/activate pip install -e .[flask] cp annotator.cfg.example annotator.cfg python run.py
You should see something like:
* Running on http://127.0.0.1:5000/ * Restarting with reloader...
If you wish to customize the configuration of the Annotator Store, make your changes to annotator.cfg or dive into run.py.
Additionally, the HOST and PORT environment variables override the default socket binding of address 127.0.0.1 and port 5000.
Store API
The Store API is designed to be compatible with the Annotator. The annotation store, a JSON-speaking REST API, will be mounted at /api by default. See the Annotator documentation for details.
Running tests
We use nosetests to run tests. You can just pip install -e .[testing], ensure ElasticSearch is running, and then:
$ nosetests ...................................................................................... ---------------------------------------------------------------------- Ran 86 tests in 19.171s OK
Alternatively (and preferably), you should install Tox, and then run tox. This will run the tests against multiple versions of Python (if you have them installed).
Please open an issue if you find that the tests don’t all pass on your machine, making sure to include the output of pip freeze.
Changelog
0.13.1
Reindexer can run even when target exists.
0.13
Slight changes to reindex.py to ease subclassing it.
0.12
A tool for migrating/reindexing elasticsearch (reindex.py) was added (#103).
The store returns more appropriate HTTP response codes (#96).
Dropped support for ElasticSearch versions before 1.0.0 (#92).
The default search query has been changed from a term-filtered “match all” to a set of “match queries”, resulting in more liberal interpretations of queries (#89).
The default elasticsearch analyzer for annotation fields has been changed to “keyword” in order to provide more consistent case-sensitivity behaviours (#73, #88).
Made Flask an optional dependency: it is now possible to use the persistence components of the project without needing Flask (#76).
Python 3 compatibility (#72).
0.11.2
SECURITY: Fixed bug that allowed authenticated users to overwrite annotations on which they did not have permissions (#82).
0.11.1
Fixed support for using ElasticSearch instances behind HTTP Basic auth
0.11.0
Add support for ElasticSearch 1.0
Create changelog
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file annotator-0.13.1.tar.gz
.
File metadata
- Download URL: annotator-0.13.1.tar.gz
- Upload date:
- Size: 55.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8060c799a62085e322a2a73d12a54a58a468e9afd0aacfac124eb94edbcbb59a |
|
MD5 | ae48af388632ad01053dbdf64d727729 |
|
BLAKE2b-256 | 9615bb007e77c7ee17023b408edc8b17810c765b2601e14f785322fa2dd3e83b |
File details
Details for the file annotator-0.13.1-py2.py3-none-any.whl
.
File metadata
- Download URL: annotator-0.13.1-py2.py3-none-any.whl
- Upload date:
- Size: 45.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4baea75edb9855e8d4bf41e679c9f669b026e715eb9bb51c87726837a70eaa76 |
|
MD5 | 5710d52c4411968086b3adfbbb4db233 |
|
BLAKE2b-256 | 8ec0b37225ffb28b64479d1bb735c3f7801aa8bd2932470c8c1354940a60da52 |