Skip to main content

Name Authority App for Django.

Project description

Django Name Build Status Docs Status PyPI Version

Python Implementation of NACO Normalization Rules

The Name App is a tool originally developed for documenting names used by the UNT Libraries in its various digital library systems and collections. The app provides a consistent way of communicating the authorized version of a name and information about the name that is useful for reuse. The Name App generates a unique URL for each name that can be used to unambiguously refer to a person, organization, event, building or piece of software. In addition to an HTML page for each name there are a number of other formats available for each record including a MADS XML version and a simple JSON representation. A key feature of the UNT Name App is the ability to link to other vocabularies such as the Virtual International Authority File (VIAF), the Library of Congress Name Authority File, or Wikipedia.


Installation

For installation instructions, see the Installation page in the docs.

License

See LICENSE.

Acknowledgements

django-name was developed at the UNT Libraries.

Contributors:

Requirements

  • Python 3.9 or later

Development

There are three ways to set up this environment locally.

Docker

Install Docker. Instructions differ based on installation method.

Clone the repository.

$ git clone https://github.com/unt-libraries/django-name.git
$ cd django-name

Warm up the Mariadb database. This only needs to be done when the database container doesn't exist yet. This will take about a minute once the image has been pulled.

$ docker compose up -d mariadb

Start the app and run the migrations.

# start the app
$ docker compose up -d

# run the migrations
$ docker compose run --rm web ./manage.py migrate

# optional: add a superuser in order to login to the admin interface
$ docker compose run --rm web ./manage.py createsuperuser

At this point you should be able to access your local instance of the site by visiting <dockerhost>:8000/name/

The code is in a volume that is shared between your workstation and the web container, which means any edits you make on your workstation will also be reflected in the Docker container. No need to rebuild the container to pick up changes in the code.

However, if the requirements files change, it is important that you rebuild the web container for those packages to be installed. This is something that could happen when switching between feature branches, or when pulling updates from the remote.

# stop the app
$ docker compose stop

# remove the web container
$ docker compose rm web

# rebuild the web container
$ docker compose build web

# start the app
$ docker compose up -d

Developing with Podman and Podman-Compose

Install or Enable Podman.

Install Podman Compose.

$ sudo dnf install podman-compose

You will follow the same steps as above, starting with Clone the repository. For all of the docker steps, you will have to replace the word docker with podman.

If you have SELinux, you may need to temporarily add :Z to the web volumes in the docker-compose.yml. It will look like .:/app/:Z. You may also need to use sudo for your podman-compose commands.

Traditional Setup

Clone the repository.

$ git clone https://github.com/unt-libraries/django-name.git
$ cd django-name

Install the mysql development package. The command depends on your system:

# Red Hat
sudo dnf install mysql-devel

# Ubuntu / Windows (WSL)
sudo apt install libmysqlclient-dev

# macOS via Homebrew
brew install mysql-client

Create a virtual environment and activate it

$ python -m venv env
$ source env/bin/activate

Install the dev dependencies

$ pip install .'[dev,test,codestyle]'

Replace the DATABASES Django setting in ./tests/settings/dev.py with

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': './db.sqlite3', 
    }
}

Add table data

$ python manage.py migrate

Start dev instance

$ python manage.py runserver

The app should be available at http://localhost:8000/name/

Running the Tests

NOTE: tests will not pass without the mariadb and postgres databases available.

To run the tests via Tox, use this command. If you are using podman-compose, swap the word docker with podman for the commands below.

$ docker compose run --rm web tox

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_name-5.0.0.tar.gz (55.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_name-5.0.0-py3-none-any.whl (58.0 kB view details)

Uploaded Python 3

File details

Details for the file django_name-5.0.0.tar.gz.

File metadata

  • Download URL: django_name-5.0.0.tar.gz
  • Upload date:
  • Size: 55.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for django_name-5.0.0.tar.gz
Algorithm Hash digest
SHA256 d74f47d4f7a720b3652ecbe63d7a458351f9dd5791be3a9b98afa564b127e770
MD5 c68d87e4b19c77bbf976cf93d0a560dc
BLAKE2b-256 d3fa9d0f5ac66fb13469070973c520783140a1e3e79423891af56b8774440441

See more details on using hashes here.

File details

Details for the file django_name-5.0.0-py3-none-any.whl.

File metadata

  • Download URL: django_name-5.0.0-py3-none-any.whl
  • Upload date:
  • Size: 58.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for django_name-5.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e5346fe95fa78d214c80cfed33862eefa40938b2eba9044ab6b57da8e27498d4
MD5 2679c71fcdc1510c6da7201eeb0678c2
BLAKE2b-256 78d37b3277471815d75477c1ca2f657ec58decebc3e7b7035ec3eb003a89b0de

See more details on using hashes here.

Supported by

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