The Universal Musical Instrument Lexicon (UMIL) is a crowd-sourcing website dedicated to collecting names and images of musical instruments from various historical periods and cultures. Inspired by projects like MIMO (Musical Instruments Museum Online), UMIL aims to create a platform where users can contribute instrument names in their native languages while exploring a rich display of instrument pictures.
The ambitious initiative will greatly assist in mapping instrument names and facilitating cross-referencing of instruments across diverse sources. To achieve a multilingual search experience, UMIL employs a thesaurus-like concept, assigning each instrument a unique URI that links all its names together. Furthermore, this system ensures that search results are presented in the user's preferred language when utilizing SESEMMI (Search Engine System for Enhancing Music Metadata Interoperability).
- Installation for Local Development
- Installation for Deployment
- Managing Database Migrations
- Loading Data
NOTE: These instructions are for local development only. Refer to the "Installation for Deployment" section for installation on a remote server.
- UMIL requires Docker Engine with Compose V2. Verify your version with
docker compose --version
and look for an output such asDocker Compose version v2.19.1
. If you do not have the correct version, refer to the Docker Compose Migration Documentation.
After cloning this repository, you will need a local .env
file at the root of the directory. Copy the contents or rename the .env.sample
file to .env
and update it to include uncommented environment variables for the database credentials POSTGRES_USER
and POSTGRES_PASSWORD
, as well as the DJANGO_SECRET_KEY
. The database credentials can be set to anything while the DJANGO_SECRET_KEY
will need to be obtained from one of the developers working on the UMIL project. Next you will need to verify the values of the DEVELOPMENT
and HOST_NAME
variables. For local development ONLY, these should be set to "true" and "localhost", respectively.
In one terminal run the following commands to build the docker images and run the specified services.
docker compose build
docker compose up
If you are not running docker containers in detatched mode (e.g docker compose up -d
) open a second terminal and go into the running container shell. Run migrations commands to create/populate tables. The following commands should be executed to complete the aforementioned steps.
docker compose exec -it app bash
python manage.py makemigrations
python manage.py migrate
python manage.py import_languages
python manage.py import_instruments
The Django development server should now be available at localhost:8000
. Ensure that the database schema is properly set up and the application can display data as expected by navigating to localhost:8000/instruments/
.
NOTE: that it is recommended to bring the containers down with docker compose down
after you are done developing, testing, and committing your changes. After executing the previous command, the application will no longer be available localhost:8000
. To once again view the running application, run docker compose up -d
and ensure all migrations made by you or other developers are up-to-date with docker compose exec -it app bash
and python manage.py migrate
. For further clarifications on managing migrations refer to this section.
When installed with DEVELOPMENT=true
in the .env
file, some additional modules are included in the application container that provide debugging tools: django-extensions
and django-debug-toolbar
. The debugging toolbar provided by django-debug-toolbar
is shown when viewing the development server in the browser. The development installation runs the runserver_plus
(provided by django-extensions
) command automatically, which provides an in-browser debug console when errors are raised in the application. django-extensions
also provides additional tools potentitally useful for development. Further information can be found at module documentation.
UMIL requires Docker Engine with Compose V2. Ensure that the remote server has these installed.
SSH into the server. After cloning the repository, set up a local .env
file. Copy or rename the .env.sample
file to .env
and update it to include uncommented environment variables for database credentials POSTGRES_USER
and POSTGRES_PASSWORD
. Ensure that POSTGRES_PASSWORD
is secure. Additionally, set DJANGO_SECRET_KEY
with a secure secret key for Django.
Ensure that the DEVELOPMENT
variable is set to "false", and that HOST_NAME
is set to the host name where the UMIL instance will be served (for example, "vim.linkedmusic.ca" or "vim.staging.linkedmusic.ca").
Run the following commands:
docker compose build
docker compose up -d
Django automates changes to the database schema with migrations.
If your development changes any application models, be sure to make and commit migrations along with those changes. To create and apply migrations open a separate terminal and run the following commands:
docker compose exec -it app bash
python manage.py makemigrations
python manage.py migrate
Commit the resulting migrations files with the model changes.
If changes you make require migrations, or you merge migrations made by others into you development branch, you will need to apply those migrations to your local copy of the database:
docker compose exec -it app bash
python manage.py migrate
At present, UMIL supports an initial list of 262 instruments curated from Wikidata, and their names in English and French. These instruments can be found in web-app/django/startup_data/vim_instruments_with_images-15Sept.csv
.
Two django management commands are provided to load these initial instruments. These should be run from within the app Docker container by going into its shell.
docker compose exec -it app bash
python manage.py import_languages
python manage.py import_instruments
UMIL uses poetry
to manage python dependencies and a poetry.lock
file to ensure reproducible builds in development and production. Dependencies can be found in the pyproject.toml
file and are divided into three groups:
main
- the core dependencies required by the application.debug
- dependencies that provide tools for debugging and are installed in the application Docker container only during local development.dev
- optional dependencies (eg. for code formatting, linting, type checking) that can be useful in the development environment, but are never used in the application container.
NOTE: it is not generally necessary to use poetry
for development, except when adding additional dependencies.