diff --git a/agrold-javaweb/charts/virtuoso/templates/initdb.yaml b/agrold-javaweb/charts/virtuoso/templates/initdb.yaml index 5bd986d..e022622 100644 --- a/agrold-javaweb/charts/virtuoso/templates/initdb.yaml +++ b/agrold-javaweb/charts/virtuoso/templates/initdb.yaml @@ -1,4 +1,4 @@ -{{- if .Values.initdb.enabled }} +{{- if or .Values.initdb.enabled .Values.facetedSearch.enabled (not .Values.serveConductor) }} apiVersion: v1 kind: {{ .Values.initdb.kind }} metadata: @@ -7,4 +7,18 @@ data: {{- range $key, $val := .Values.initdb.data }} {{ $key | quote }}: {{ $val | quote }} {{- end }} + + + {{- if not .Values.serveConductor }} + "99999999999999999_disable_conductor.sql": |- + vad_uninstall('conductor/1.00.8852'); + {{- end }} + + {{- if .Values.facetedSearch.enabled }} + "99999999999999999_enable_faceted.sql": |- + vad_install('/opt/virtuoso-opensource/vad/fct_dav.vad', 0); + {{- if .Values.facetedSearch.enableLabels }} + registry_set('fct_desc_value_labels', '1'); + {{- end }} + {{- end }} {{- end }} \ No newline at end of file diff --git a/agrold-javaweb/charts/virtuoso/templates/scripts.yaml b/agrold-javaweb/charts/virtuoso/templates/scripts.yaml deleted file mode 100644 index 99ff31b..0000000 --- a/agrold-javaweb/charts/virtuoso/templates/scripts.yaml +++ /dev/null @@ -1,224 +0,0 @@ -{{- if or (not .Values.serveConductor) .Values.facetedSearch.enabled }} -apiVersion: v1 -kind: {{ .Values.initdb.kind }} -metadata: - name: {{ include "sparql.scripts.configMapName" . }} -data: - "run_scripts.sh": | - #!/bin/bash - - set -e - - {{- if not .Values.serveConductor }} - ./disable_conductor.sh - {{- end }} - {{- if .Values.facetedSearch.enabled }} - ./enable_fct.sh - {{- end }} - - "disable_conductor.sh": | - #!/bin/bash - - set -e - - version="$(isql -U dba -P ${DBA_PASSWORD} 'EXEC=vad_list_packages();' | grep conductor | grep -oh -E '[0-9]{1,}\.[0-9]{1,}\.[0-9]{1,}')" - isql -U dba -P ${DBA_PASSWORD} "EXEC=vad_uninstall('conductor/$version');" - - echo -e "\e[32mSucessfully disabled conductor!\e[0m" - - "enable_fct.sh": | - #!/bin/bash - - isql -U dba -P ${DBA_PASSWORD} "EXEC=vad_install('/opt/virtuoso-opensource/vad/fct_dav.vad', 0);" - - {{- if .Values.facetedSearch.enableLabels }} - isql -U dba -P ${DBA_PASSWORD} "EXEC=registry_set('fct_desc_value_labels', '1');" - {{- end }} - - echo -e "\e[32mSucessfully installed faceted search!\e[0m" - - "wait-for-it.sh": | - #!/usr/bin/env bash - # Use this script to test if a given TCP host/port are available - #https://github.com/vishnubob/wait-for-it/blob/master/wait-for-it.sh - - WAITFORIT_cmdname=${0##*/} - - echoerr() { if [[ $WAITFORIT_QUIET -ne 1 ]]; then echo "$@" 1>&2; fi } - - usage() - { - cat << USAGE >&2 - Usage: - $WAITFORIT_cmdname host:port [-s] [-t timeout] [-- command args] - -h HOST | --host=HOST Host or IP under test - -p PORT | --port=PORT TCP port under test - Alternatively, you specify the host and port as host:port - -s | --strict Only execute subcommand if the test succeeds - -q | --quiet Don't output any status messages - -t TIMEOUT | --timeout=TIMEOUT - Timeout in seconds, zero for no timeout - -- COMMAND ARGS Execute command with args after the test finishes - USAGE - exit 1 - } - - wait_for() - { - if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then - echoerr "$WAITFORIT_cmdname: waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" - else - echoerr "$WAITFORIT_cmdname: waiting for $WAITFORIT_HOST:$WAITFORIT_PORT without a timeout" - fi - WAITFORIT_start_ts=$(date +%s) - while : - do - if [[ $WAITFORIT_ISBUSY -eq 1 ]]; then - nc -z $WAITFORIT_HOST $WAITFORIT_PORT - WAITFORIT_result=$? - else - (echo -n > /dev/tcp/$WAITFORIT_HOST/$WAITFORIT_PORT) >/dev/null 2>&1 - WAITFORIT_result=$? - fi - if [[ $WAITFORIT_result -eq 0 ]]; then - WAITFORIT_end_ts=$(date +%s) - echoerr "$WAITFORIT_cmdname: $WAITFORIT_HOST:$WAITFORIT_PORT is available after $((WAITFORIT_end_ts - WAITFORIT_start_ts)) seconds" - break - fi - sleep 1 - done - return $WAITFORIT_result - } - - wait_for_wrapper() - { - # In order to support SIGINT during timeout: http://unix.stackexchange.com/a/57692 - if [[ $WAITFORIT_QUIET -eq 1 ]]; then - timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --quiet --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & - else - timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & - fi - WAITFORIT_PID=$! - trap "kill -INT -$WAITFORIT_PID" INT - wait $WAITFORIT_PID - WAITFORIT_RESULT=$? - if [[ $WAITFORIT_RESULT -ne 0 ]]; then - echoerr "$WAITFORIT_cmdname: timeout occurred after waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" - fi - return $WAITFORIT_RESULT - } - - # process arguments - while [[ $# -gt 0 ]] - do - case "$1" in - *:* ) - WAITFORIT_hostport=(${1//:/ }) - WAITFORIT_HOST=${WAITFORIT_hostport[0]} - WAITFORIT_PORT=${WAITFORIT_hostport[1]} - shift 1 - ;; - --child) - WAITFORIT_CHILD=1 - shift 1 - ;; - -q | --quiet) - WAITFORIT_QUIET=1 - shift 1 - ;; - -s | --strict) - WAITFORIT_STRICT=1 - shift 1 - ;; - -h) - WAITFORIT_HOST="$2" - if [[ $WAITFORIT_HOST == "" ]]; then break; fi - shift 2 - ;; - --host=*) - WAITFORIT_HOST="${1#*=}" - shift 1 - ;; - -p) - WAITFORIT_PORT="$2" - if [[ $WAITFORIT_PORT == "" ]]; then break; fi - shift 2 - ;; - --port=*) - WAITFORIT_PORT="${1#*=}" - shift 1 - ;; - -t) - WAITFORIT_TIMEOUT="$2" - if [[ $WAITFORIT_TIMEOUT == "" ]]; then break; fi - shift 2 - ;; - --timeout=*) - WAITFORIT_TIMEOUT="${1#*=}" - shift 1 - ;; - --) - shift - WAITFORIT_CLI=("$@") - break - ;; - --help) - usage - ;; - *) - echoerr "Unknown argument: $1" - usage - ;; - esac - done - - if [[ "$WAITFORIT_HOST" == "" || "$WAITFORIT_PORT" == "" ]]; then - echoerr "Error: you need to provide a host and port to test." - usage - fi - - WAITFORIT_TIMEOUT=${WAITFORIT_TIMEOUT:-15} - WAITFORIT_STRICT=${WAITFORIT_STRICT:-0} - WAITFORIT_CHILD=${WAITFORIT_CHILD:-0} - WAITFORIT_QUIET=${WAITFORIT_QUIET:-0} - - # Check to see if timeout is from busybox? - WAITFORIT_TIMEOUT_PATH=$(type -p timeout) - WAITFORIT_TIMEOUT_PATH=$(realpath $WAITFORIT_TIMEOUT_PATH 2>/dev/null || readlink -f $WAITFORIT_TIMEOUT_PATH) - - WAITFORIT_BUSYTIMEFLAG="" - if [[ $WAITFORIT_TIMEOUT_PATH =~ "busybox" ]]; then - WAITFORIT_ISBUSY=1 - # Check if busybox timeout uses -t flag - # (recent Alpine versions don't support -t anymore) - if timeout &>/dev/stdout | grep -q -e '-t '; then - WAITFORIT_BUSYTIMEFLAG="-t" - fi - else - WAITFORIT_ISBUSY=0 - fi - - if [[ $WAITFORIT_CHILD -gt 0 ]]; then - wait_for - WAITFORIT_RESULT=$? - exit $WAITFORIT_RESULT - else - if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then - wait_for_wrapper - WAITFORIT_RESULT=$? - else - wait_for - WAITFORIT_RESULT=$? - fi - fi - - if [[ $WAITFORIT_CLI != "" ]]; then - if [[ $WAITFORIT_RESULT -ne 0 && $WAITFORIT_STRICT -eq 1 ]]; then - echoerr "$WAITFORIT_cmdname: strict mode, refusing to execute subprocess" - exit $WAITFORIT_RESULT - fi - exec "${WAITFORIT_CLI[@]}" - else - exit $WAITFORIT_RESULT - fi -{{- end }} \ No newline at end of file diff --git a/agrold-javaweb/charts/virtuoso/templates/statefulset.yaml b/agrold-javaweb/charts/virtuoso/templates/statefulset.yaml index e663fdb..afa2cf4 100644 --- a/agrold-javaweb/charts/virtuoso/templates/statefulset.yaml +++ b/agrold-javaweb/charts/virtuoso/templates/statefulset.yaml @@ -32,42 +32,14 @@ spec: securityContext: {{- toYaml .Values.podSecurityContext | nindent 8 }} volumes: - {{- if .Values.initdb.enabled }} + {{- $mount_initdb := or .Values.initdb.enabled .Values.facetedSearch.enabled (not .Values.serveConductor) -}} + {{- if $mount_initdb }} - name: {{ include "sparql.initdb.configMapName" . }} configMap: defaultMode: 0551 name: {{ include "sparql.initdb.configMapName" . }} {{- end }} - {{- if not .Values.serveConductor }} - - name: disableconductor - configMap: - defaultMode: 0551 - name: {{ include "sparql.scripts.configMapName" . }} - {{- end }} containers: - {{- if or (not .Values.serveConductor) .Values.facetedSearch.enabled }} - # Turns out we cannot do this in the /initdb.d because - # it blocks connections to the 1111 port - - name: disable-conductor - image: openlink/virtuoso-opensource-7 - tag: 7.2.11 - volumeMounts: - - name: disableconductor - mountPath: /mnt - restartPolicy: OnFailure - command: - - /bin/sh - - "-c" - - /mnt/..data/wait-for-it.sh localhost:1111 -t 0 -- /mnt/..data/run_scripts.sh - env: - - name: "DBA_PASSWORD" - valueFrom: - secretKeyRef: - name: {{ include "sparql.secretName" . }} - key: DBAPassword - - {{- end }} - - name: {{ .Chart.Name }} securityContext: {{- toYaml .Values.securityContext | nindent 12 }} @@ -87,7 +59,7 @@ spec: path: '/sparql?query=select+("pong"+as+%3Fpong)+{}' port: http volumeMounts: - {{- if .Values.initdb.enabled }} + {{- if $mount_initdb }} - name: {{ include "sparql.initdb.configMapName" . }} mountPath: /initdb.d {{- end }}