Skip to main content

Django app for IIIF Presentation book content

Project description

Django application to index and display IIIF Manifests for books

Build Status Code Coverage Code Health Requirements Status https://img.shields.io/badge/Say%20Thanks-!-1EAEDB.svg

djiffy is intended to be a reusable Django application for working with digitized book content provided via IIIF Presentation manifests. This is an alpha version and it does not yet support the full IIIF Presentation specification.

Installation

Use pip to install:

pip install djiffy

You can also install from GitHub. Use a branch or tag name, e.g. @develop or @1.0, to install a specific tagged release or branch:

pip install git+https://github.com/Princeton-CDH/djiffy.git@develop#egg=djiffy

Configuration

Add djiffy to installed applications and make sure that django.contrib.humanize is also enabled:

INSTALLED_APPS = (
    ...
    'django.contrib.humanize',
    'dal',
    'dal_select2',
    'djiffy',
    ...
)

Include the default djiffy urls at the desired base url with the namespace djiffy:

urlpatterns = [
    ...
    url(r'^iiif-books/', include('djiffy.urls', namespace='djiffy')),
    ...
]

Run migrations to create database tables:

python manage.py migrate

If you are need to use djiffy to access manifests that require an authorization token, use DJIFFY_AUTH_TOKENS in your project settings to configure each domain that requires an auth token. The configuration should be formatted like this:

DJIFFY_AUTH_TOKENS = {
    'example.com': 'myauthtoken',
}

Usage

Import IIIF content using the import_manifest manage command. This command can take an IIIF Collection or single Manifest, via local file or URL. Imported content can be viewed in Django admin.:

python manage.py import_manifest http://url.for/iiif/manifest
python manage.py import_manifest /path/to/local/collection

Development instructions

This git repository uses git flow branching conventions.

Initial setup and installation:

  • recommended: create and activate a python 3.5 virtualenv:

    virtualenv djiffy -p python3.5
    source djiffy/bin/activate
  • pip install the package with its python dependencies:

    pip install -e .

Unit Testing

Unit tests are written with py.test but use some Django test classes for convenience and compatibility with django test suites. Running the tests requires a minimal settings file for Django required configurations.

  • Copy sample test settings and add a SECRET_KEY:

    cp ci/testsettings.py testsettings.py
  • To run the tests, either use the configured setup.py test command:

    python setup.py test
  • Or install test requirements and use py.test directly:

    pip install -e '.[test]'
    py.test

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

djiffy-0.5.0.tar.gz (322.8 kB view details)

Uploaded Source

Built Distribution

djiffy-0.5.0-py3-none-any.whl (379.9 kB view details)

Uploaded Python 3

File details

Details for the file djiffy-0.5.0.tar.gz.

File metadata

  • Download URL: djiffy-0.5.0.tar.gz
  • Upload date:
  • Size: 322.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for djiffy-0.5.0.tar.gz
Algorithm Hash digest
SHA256 4c8d8d22da8183da9a5d5716a0a317ededfe4d3b0966afcd8da06ce2498b1453
MD5 eea5ae1308320a933198b403091c1944
BLAKE2b-256 f9a0861585dde57dd4359ddbbb9c0b6cc4880d70a843f4b1d9daeda04359a7bf

See more details on using hashes here.

File details

Details for the file djiffy-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for djiffy-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ef528d40db44b053e4ab6c4b4a3466d8168946bf2a8735734737dcc13cf54f1c
MD5 1763b4bb22f49ffc58b391778330b340
BLAKE2b-256 bf98e0ec40ab200391d2d5a1eba66926849a3a6d9965a1b9b7e6c926f6e69503

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