Skip to content

GenomicDataInfrastructure/gdi-userportal-ckan-docker

 
 

Repository files navigation

REUSE status example workflow example workflow example workflow Quality Gate Status GitHub contributors Contributor Covenant

CKAN for GDI - User Portal

1. Overview

This project has two purposes:

  1. Prepare a docker image for CKAN, with all extensions and configurations needed to deploy the catalogue for the User Portal.
  2. Setup a development environment for testing, fixing and enhancing our customised CKAN and its extensions.

The CKAN images used are from the official CKAN ckan-docker repo.

The non-CKAN images are as follows:

  • PostgreSQL: Official PostgreSQL image. Database files are stored in a named volume.
  • Solr: CKAN's pre-configured Solr image. Index data is stored in a named volume.
  • Redis: standard Redis image
  • NGINX: latest stable nginx image that includes SSL and Non-SSL endpoints
  • National Catalogue Mock: Python script to expose a synthetic RDF file, to test the Harvester.

CKAN and all the components are configured using environment variables that you can set in the .env file.

2. Before running locally

  • Install docker with support to docker compose v2.
    • Ensure you have enough computer resources, if you are using colima: colima start --arch aarch64 --vm-type=vz --mount-type=virtiofs --vz-rosetta --cpu 4 --memory 10
  • Copy .env.example to .env.
  • Ensure git submodules are pulled correctly after clone CKAN-DOCKER git submodule update --init

3. Useful commands

3.1. Build and start dev environment

docker compose up -d --build

3.2. Remove images and volumes

docker compose down -v

3.3. Logs

docker compose logs -f

3.4. Re-index SOLR

ckan -c ckan.ini search-index rebuild

4. Accessing the running instance

The ckan instance runs on port defined in CKAN_PORT_HOST (5500). Access it at http://localhost:5500.
A sysadmin account is created by default with the following credentials (defined in .env):

  • CKAN_SYSADMIN_NAME=ckan_admin
  • CKAN_SYSADMIN_PASSWORD=test1234

5. installing new extensions

The current agreement is:

  • Fork all the branches from the extension's repo into GitHub GDI.
  • Create and push a new branch following this standard: user-portal-{original branch name/tag name} Reminder, prefer always to use a release/tag branch, over main/master branches, to avoid not tested changes.
  • Add a git submodule: git submodule add {git_ssh_url} src/ckanext-{extension}.
  • Add branch reference into .gitmodules, if not added.
  • Configure the extension via environment variables or via a setup script. Setup scripts must be added into ckan/docker-entrypoint.d/.
  • Ensure the extension is working as expected.
  • Update ckan/Dockerfile to install the new extension via pip.

All Docker Compose commands in this README will use the V2 version of Compose ie: docker compose. The older version (V1) used the docker-compose command. Please see Docker Compose for more information.

Copying and License

This work is licensed under multiple licenses. Here is a brief summary as of January 2024:

  • All original source code is licensed under AGPL-3.0-only, copyright (c) 2006-2024 Open Knowledge Foundation and contributors.
  • All documentation is licensed under CC-BY-4.0.
  • github actions workflows are licensed under Apache-2.0.
  • For more accurate information, check the individual files.

About

Scripts and images to run CKAN using Docker Compose

Resources

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 51.5%
  • Python 35.7%
  • Dockerfile 12.8%