Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BIO-6387] enabled dbca extension, configured config and add cronjob #4

Merged
merged 9 commits into from
Dec 20, 2023
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .ahoy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -74,12 +74,12 @@ commands:
logs:
usage: Show Docker logs.
cmd: |
TAIL=100
if [[ $# -eq 2 ]]; then
SERVICE=$1
TAIL=$2
else
SERVICE=$1
TAIL=100
fi;
docker compose -f $DOCKER_COMPOSE logs -f --tail=$TAIL $SERVICE

Expand Down Expand Up @@ -124,7 +124,7 @@ commands:
usage: Pipe in a postgres dump file. `ahoy db-import local.dump`
cmd: |
if [ -e "$@" ] ; then
docker compose -f $DOCKER_COMPOSE exec -T $POSTGRESQL_CONTAINER_NAME sh -c 'pg_restore -U $CKAN_DB_USER -d $CKAN_DB --clean --if-exists -v' < "$@"
docker compose -f $DOCKER_COMPOSE exec -T $POSTGRESQL_CONTAINER_NAME sh -c 'pg_restore -U $CKAN_DB_USER -d $CKAN_DB --clean --if-exists -v --no-owner --no-privileges' < "$@"
else echo "Provided sql file" "$@" "does not exist"
fi

Expand Down
9 changes: 1 addition & 8 deletions .env.dbca
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ NGINX_CONTAINER_NAME=nginx
REDIS_CONTAINER_NAME=redis
POSTGRESQL_CONTAINER_NAME=db
SOLR_CONTAINER_NAME=solr
DATAPUSHER_CONTAINER_NAME=datapusher
CKAN_CONTAINER_NAME=ckan
WORKER_CONTAINER_NAME=ckan-worker

Expand Down Expand Up @@ -54,7 +53,7 @@ CKAN_SMTP_STARTTLS=True
CKAN_SMTP_USER=user
CKAN_SMTP_PASSWORD=pass
CKAN_SMTP_MAIL_FROM=ckan@localhost
TZ=UTC
TZ=Australia/Perth

# Solr
SOLR_IMAGE_VERSION=2.10-solr9
Expand All @@ -74,12 +73,6 @@ NGINX_PORT=80
NGINX_SSLPORT=443

# Extensions
CKAN__PLUGINS="image_view text_view datatables_view pdf_view datastore xloader pages showcase hierarchy_display hierarchy_form hierarchy_group_form dcat envvars"
CKAN__VIEWS__DEFAULT_VIEWS="text_view datatables_view pdf_view"
CKAN__HARVEST__MQ__TYPE=redis
CKAN__HARVEST__MQ__HOSTNAME=redis
CKAN__HARVEST__MQ__PORT=6379
CKAN__HARVEST__MQ__REDIS_DB=1

## WA DBCA Config ##
# Docker compose project name
Expand Down
19 changes: 17 additions & 2 deletions .vscode/launch.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
"-c continue",
"/usr/bin/ckan",
"--config",
"/srv/app/ckan.ini",
"/srv/app/config/dbca.ini",
"run",
"--host",
"0.0.0.0",
Expand All @@ -30,9 +30,24 @@
"-c continue",
"/usr/bin/ckan",
"--config",
"/srv/app/ckan.ini",
"/srv/app/config/dbca.ini",
"jobs",
"worker",
"priority"
],
"justMyCode": true
},
{
"name": "Python: CKAN CLI Command Run & Debug",
"type": "python",
"request": "launch",
"module": "pdb",
"args": [
"-c continue",
"/srv/app/config/dbca.ini",
"--config",
"/srv/app/dbca.ini",
"<CLI_COMMAND>"
],
"justMyCode": true
}
Expand Down
14 changes: 13 additions & 1 deletion ckan/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM ckan/ckan-base:2.10.1
FROM ckan/ckan-base:2.10.3

# Install any extensions needed by your CKAN instance
# See Dockerfile.dev for more details and examples
Expand All @@ -21,3 +21,15 @@ RUN for d in $APP_DIR/patches/*; do \
done ; \
fi ; \
done

## DBCA specific configuration ##

# Override the default start_ckan.sh script
COPY setup/dbca_start_ckan.sh.override ${APP_DIR}/start_ckan.sh
RUN chmod +x ${APP_DIR}/start_ckan.sh

# Copy config files
COPY config/*.ini ${APP_DIR}/config/

# Override default CKAN config file to use dbca.ini
ENV CKAN_INI=${APP_DIR}/config/dbca.ini
17 changes: 13 additions & 4 deletions ckan/Dockerfile.dev
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM ckan/ckan-dev:2.10.1
FROM ckan/ckan-dev:2.10.3

# Install any extensions needed by your CKAN instance
# - Make sure to add the plugins to CKAN__PLUGINS in the .env file
Expand Down Expand Up @@ -38,9 +38,6 @@ RUN pip3 install pip --upgrade && \
chmod +x ${APP_DIR}/dbca_requirements.sh && \
${APP_DIR}/dbca_requirements.sh

COPY setup/dbca_start_ckan_development.sh.override ${APP_DIR}/start_ckan_development.sh
RUN chmod +x ${APP_DIR}/start_ckan_development.sh

# Clone the extension(s) your are writing for your own project in the `src` folder
# to get them mounted in this image at runtime

Expand All @@ -58,3 +55,15 @@ RUN for d in $APP_DIR/patches/*; do \
done ; \
fi ; \
done

## DBCA specific configuration ##

# Override the default dbca_start_ckan_development.sh script
COPY setup/dbca_start_ckan_development.sh.override ${APP_DIR}/start_ckan_development.sh
RUN chmod +x ${APP_DIR}/start_ckan_development.sh

# Copy config files
COPY config/*.ini ${APP_DIR}/config/

# Override default CKAN config file to use dbca.ini
ENV CKAN_INI=${APP_DIR}/config/dbca.ini
68 changes: 68 additions & 0 deletions ckan/config/dbca.ini
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
#
# DBCA configuration
#

[app:main]

## General settings ############################################################
# This will include the config file settings from the default ckan config file
use = config:/srv/app/ckan.ini
ckan.devserver.watch_patterns = /srv/app/ckan.ini

## Plugins Settings ############################################################
ckan.plugins = image_view text_view datatables_view pdf_view datastore xloader pages showcase hierarchy_display hierarchy_form hierarchy_group_form dcat dbca scheming_datasets envvars

## Resource Views Settings #####################################################
ckan.views.default_views = text_view datatables_view pdf_view

## Internationalisation Settings ###############################################
ckan.locale_default = en_AU
ckan.display_timezone = Australia/Perth
ckan.resource_formats = /srv/app/src_extensions/ckanext-dbca/ckanext/dbca/config/resource_formats.json

## CKAN Extensions configuration ###############################################

# ckanext-scheming
scheming.dataset_schemas = ckanext.dbca:dbca_dataset.yaml
scheming.presets = ckanext.scheming:presets.json ckanext.dbca:dbca_presets.json
MarkCalvert marked this conversation as resolved.
Show resolved Hide resolved

## Logging configuration
[loggers]
keys = root, ckan, ckanext, werkzeug

[handlers]
keys = console

[formatters]
keys = generic

[logger_root]
level = WARNING
handlers = console

[logger_werkzeug]
level = WARNING
handlers = console
qualname = werkzeug
propagate = 0

[logger_ckan]
level = INFO
handlers = console
qualname = ckan
propagate = 0

[logger_ckanext]
level = DEBUG
handlers = console
qualname = ckanext
propagate = 0

[handler_console]
class = StreamHandler
args = (sys.stderr,)
level = NOTSET
formatter = generic

[formatter_generic]
format = %(asctime)s %(levelname)-5.5s [%(name)s] %(message)s
16 changes: 16 additions & 0 deletions ckan/config/uwsgi.ini
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
[uwsgi]

plugins= http,python
socket=/tmp/uwsgi.sock
wsgi-file=/srv/app/wsgi.py
module=wsgi:application
uid=92
gid=92
http=0.0.0.0:5000
master=enable-threads
lazy-apps=true
processes=5
disable-logging=true
buffer-size=32768
vacuum=true
harakiri=50
3 changes: 2 additions & 1 deletion ckan/setup/dbca_ckan_cron_jobs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# Crontab for CKAN cron jobs
# Example cron job runs the harvester run command every 15 mins
#*/15 * * * * /usr/bin/ckan -c /srv/app/ckan.ini harvester run >> $APP_DIR/logs/ckan-cron-jobs.log 2>&1
#*/15 * * * * /usr/bin/ckan -c /srv/app/config/dbca/ckan.ini harvester run >> $APP_DIR/logs/ckan-cron-jobs.log 2>&1
0 0 * * * /usr/bin/ckan -c /srv/app/config/dbca/ckan.ini dbca scheduled_datasets >> $APP_DIR/logs/ckan-cron-jobs.log 2>&1
46 changes: 46 additions & 0 deletions ckan/setup/dbca_start_ckan.sh.override
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
#!/bin/bash

# Update the default ckan config file
export CKAN_INI=$APP_DIR/ckan.ini

# Set up the Secret key used by Beaker and Flask
# This can be overriden using a CKAN___BEAKER__SESSION__SECRET env var
if grep -qE "beaker.session.secret ?= ?$" ckan.ini
then
echo "Setting beaker.session.secret in ini file"
ckan config-tool $CKAN_INI "beaker.session.secret=$(python3 -c 'import secrets; print(secrets.token_urlsafe())')"
ckan config-tool $CKAN_INI "WTF_CSRF_SECRET_KEY=$(python3 -c 'import secrets; print(secrets.token_urlsafe())')"
JWT_SECRET=$(python3 -c 'import secrets; print("string:" + secrets.token_urlsafe())')
ckan config-tool $CKAN_INI "api_token.jwt.encode.secret=${JWT_SECRET}"
ckan config-tool $CKAN_INI "api_token.jwt.decode.secret=${JWT_SECRET}"
fi

# Run the prerun script to init CKAN and create the default admin user
python3 prerun.py

# Run any startup scripts provided by images extending this one
if [[ -d "/docker-entrypoint.d" ]]
then
for f in /docker-entrypoint.d/*; do
case "$f" in
*.sh) echo "$0: Running init file $f"; bash "$f" ;;
*.py) echo "$0: Running init file $f"; python3 "$f"; echo ;;
*) echo "$0: Ignoring $f (not an sh or py file)" ;;
esac
done
fi

# Revert back touse DBCA config file
export CKAN_INI=$APP_DIR/config/dbca.ini
# Unset CKAN__PLUGINS to stop the extension envvars overriding the plugins value set in the dbca config file
unset CKAN__PLUGINS

if [ $? -eq 0 ]
then
# Start supervisord
supervisord --configuration /etc/supervisord.conf &
# Start uwsgi
uwsgi -i $APP_DIR/config/uwsgi.ini
else
echo "[prerun] failed...not starting CKAN."
fi
7 changes: 6 additions & 1 deletion ckan/setup/dbca_start_ckan_development.sh.override
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,8 @@ if [ ! -f /tmp/container_ready ]; then
fi
fi
done

# Update the default ckan config file
export CKAN_INI=$APP_DIR/ckan.ini
# Set debug to true
echo "Enabling debug mode"
ckan config-tool $CKAN_INI -s DEFAULT "debug = true"
Expand Down Expand Up @@ -88,6 +89,10 @@ if [ ! -f /tmp/container_ready ]; then
done
fi

# Revert back touse DBCA config file
export CKAN_INI=$APP_DIR/config/dbca.ini
# Unset CKAN__PLUGINS to stop the extension envvars overriding the plugins value set in the dbca config file
unset CKAN__PLUGINS
# Set the container as ready so the startup scripts are not run again
touch /tmp/container_ready
fi
Expand Down
2 changes: 1 addition & 1 deletion ckan/supervisor/ckan_worker_default.conf
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
[program:ckan-worker-default]

; Use the full paths to the virtualenv and your configuration file here.
command=/usr/bin/ckan -c /srv/app/ckan.ini jobs worker
command=/usr/bin/ckan -c /srv/app/config/dbca.ini jobs worker


; User the worker runs as.
Expand Down
1 change: 1 addition & 0 deletions docker-compose.dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ services:
volumes:
- ckan_storage:/var/lib/ckan
- ./src:/srv/app/src_extensions
- ./ckan/config:/srv/app/config
restart: unless-stopped
healthcheck:
test: ["CMD", "wget", "-qO", "/dev/null", "http://localhost:5000"]
Expand Down
2 changes: 2 additions & 0 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ services:
networks:
- webnet
- ckannet
env_file:
- .env
depends_on:
ckan:
condition: service_healthy
Expand Down
1 change: 1 addition & 0 deletions nginx/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ RUN apk update --no-cache && \
COPY setup/nginx.conf ${NGINX_DIR}/nginx.conf
COPY setup/index.html /usr/share/nginx/html/index.html
COPY setup/default.conf ${NGINX_DIR}/conf.d/
COPY setup/default.conf.template ${NGINX_DIR}/templates/

RUN mkdir -p ${NGINX_DIR}/certs

Expand Down
46 changes: 46 additions & 0 deletions nginx/setup/default.conf.template
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
server {
#listen 80;
#listen [::]:80;
listen 443 ssl;
listen [::]:443 ssl;
server_name localhost;
ssl_certificate /etc/nginx/certs/ckan-local.crt;
ssl_certificate_key /etc/nginx/certs/ckan-local.key;

# TLS 1.2 & 1.3 only
ssl_protocols TLSv1.2 TLSv1.3;

# Disable weak ciphers
ssl_prefer_server_ciphers on;
ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256';

# SSL sessions
ssl_session_timeout 1d;
# ssl_session_cache dfine in stream and http
ssl_session_tickets off;

#access_log /var/log/nginx/host.access.log main;

location / {
proxy_pass http://${CKAN_CONTAINER_NAME:-ckan}:${CKAN_PORT:-5000}/;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header Host $host;
#proxy_cache cache;
proxy_cache_bypass $cookie_auth_tkt;
proxy_no_cache $cookie_auth_tkt;
proxy_cache_valid 30m;
proxy_cache_key $host$scheme$proxy_host$request_uri;
}

error_page 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 421 422 423 424 425 426 428 429 431 451 500 501 502 503 504 505 506 507 508 510 511 /error.html;

# redirect server error pages to the static page /error.html
#
location = /error.html {
ssi on;
internal;
auth_basic off;
root /usr/share/nginx/html;
}

}
2 changes: 2 additions & 0 deletions src/dbca_install_extensions.sh
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
cd src/

## Must Have ##
git clone https://github.com/dbca-wa/ckanext-dbca.git

# QA
# git clone https://github.com/dbca-wa/ckanext-qa.git
# These extensions will be installed by default, but we don't want them
Expand Down