2022-12-22 20:29:31 +08:00
#!/bin/bash
DOCKER_TAG = " $1 "
2023-03-30 16:16:24 +08:00
# The logic needs the files in ./helm-chart
mv ./nextcloud-aio-helm-chart ./helm-chart
2022-12-22 20:29:31 +08:00
# Clean
rm -f ./helm-chart/values.yaml
rm -rf ./helm-chart/templates
# Install kompose
2023-09-26 21:03:09 +08:00
curl -L https://github.com/kubernetes/kompose/releases/latest/download/kompose-linux-amd64 -o kompose
2022-12-22 20:29:31 +08:00
chmod +x kompose
sudo mv ./kompose /usr/local/bin/kompose
2023-07-18 22:50:18 +08:00
# Install yq
snap install yq
2022-12-22 20:29:31 +08:00
set -ex
# Conversion of docker-compose
cd manual-install
cp latest.yml latest.yml.backup
cp sample.conf /tmp/
sed -i 's|^|export |' /tmp/sample.conf
# shellcheck disable=SC1091
source /tmp/sample.conf
rm /tmp/sample.conf
2024-02-01 20:25:22 +08:00
sed -i '/OVERWRITEHOST/d' latest.yml
2024-07-17 23:21:54 +08:00
sed -i " s|:latest $|: $DOCKER_TAG | " latest.yml
2023-02-03 22:50:15 +08:00
sed -i "s|\${APACHE_IP_BINDING}:||" latest.yml
2023-10-27 16:39:01 +08:00
sed -i '/APACHE_IP_BINDING/d' latest.yml
2022-12-22 20:29:31 +08:00
sed -i " s|\${APACHE_PORT}:\${APACHE_PORT}/| $APACHE_PORT : $APACHE_PORT /| " latest.yml
sed -i " s|\${TALK_PORT}:\${TALK_PORT}/| $TALK_PORT : $TALK_PORT /|g " latest.yml
2023-02-02 22:22:36 +08:00
sed -i " s|- \${APACHE_PORT}|- $APACHE_PORT | " latest.yml
sed -i " s|- \${TALK_PORT}|- $TALK_PORT | " latest.yml
2022-12-22 20:29:31 +08:00
sed -i " s|\${NEXTCLOUD_DATADIR}| $NEXTCLOUD_DATADIR | " latest.yml
2023-05-11 16:57:19 +08:00
sed -i " /name: nextcloud-aio/, $ d " latest.yml
2022-12-22 20:29:31 +08:00
sed -i "/NEXTCLOUD_DATADIR/d" latest.yml
2023-01-29 07:02:18 +08:00
sed -i "/\${NEXTCLOUD_MOUNT}/d" latest.yml
2023-01-28 23:23:46 +08:00
sed -i "/^volumes:/a\ \ nextcloud_aio_nextcloud_trusted_cacerts:\n \ \ \ \ name: nextcloud_aio_nextcloud_trusted_cacerts" latest.yml
2022-12-22 20:29:31 +08:00
sed -i "s|\${NEXTCLOUD_TRUSTED_CACERTS_DIR}:|nextcloud_aio_nextcloud_trusted_cacerts:|g#" latest.yml
sed -i 's|\${|{{ .Values.|g' latest.yml
sed -i 's|}| }}|g' latest.yml
2023-07-18 22:50:18 +08:00
yq -i 'del(.services.[].profiles)' latest.yml
2023-09-28 16:52:59 +08:00
# Delete read_only and tmpfs setting while https://github.com/kubernetes/kubernetes/issues/48912 is not fixed
yq -i 'del(.services.[].read_only)' latest.yml
yq -i 'del(.services.[].tmpfs)' latest.yml
2022-12-22 20:29:31 +08:00
cat latest.yml
2023-07-18 22:50:18 +08:00
kompose convert -c -f latest.yml --namespace nextcloud-aio-namespace
2022-12-22 20:29:31 +08:00
cd latest
2023-07-18 22:50:18 +08:00
if [ -f ./templates/manual-install-nextcloud-aio-networkpolicy.yaml ] ; then
mv ./templates/manual-install-nextcloud-aio-networkpolicy.yaml ./templates/nextcloud-aio-networkpolicy.yaml
fi
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-01-28 23:23:46 +08:00
find ./ -name '*networkpolicy.yaml' -exec sed -i "s|manual-install-nextcloud-aio|nextcloud-aio|" \{ } \;
2023-02-01 23:00:52 +08:00
cat << EOL > /tmp/initcontainers
initContainers:
- name: init-volumes
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-02-01 23:00:52 +08:00
command:
- chmod
2023-02-02 01:51:40 +08:00
- "777"
2023-02-01 23:00:52 +08:00
volumeMountsInitContainer:
EOL
2023-02-02 20:06:26 +08:00
cat << EOL > /tmp/initcontainers.database
2023-02-03 00:37:19 +08:00
initContainers:
2023-05-11 17:47:36 +08:00
- name: init-subpath
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-02-02 20:06:26 +08:00
command:
2023-05-03 18:21:46 +08:00
- mkdir
- "-p"
2023-05-03 23:22:55 +08:00
- /nextcloud-aio-database/data
volumeMountsInitContainer:
- name: init-volumes
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-05-03 23:22:55 +08:00
command:
2023-02-02 20:06:26 +08:00
- chown
- 999:999
2023-05-03 02:12:57 +08:00
- "-R"
2023-02-02 20:06:26 +08:00
volumeMountsInitContainer:
EOL
2023-11-21 19:00:51 +08:00
cat << EOL > /tmp/initcontainers.clamav
initContainers:
- name: init-subpath
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-11-21 19:00:51 +08:00
command:
- mkdir
- "-p"
- /nextcloud-aio-clamav/data
volumeMountsInitContainer:
- name: init-volumes
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-11-21 19:00:51 +08:00
command:
- chown
- 100:100
- "-R"
volumeMountsInitContainer:
EOL
2023-11-21 23:49:51 +08:00
cat << EOL > /tmp/initcontainers.nextcloud
initContainers:
2023-12-07 16:17:45 +08:00
- name: "delete-lost-found"
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2024-03-12 06:33:56 +08:00
{ { - end } }
2023-11-21 23:49:51 +08:00
command:
- rm
- "-rf"
2023-12-07 16:17:45 +08:00
- "/nextcloud-aio-nextcloud/lost+found"
2023-11-21 23:49:51 +08:00
volumeMountsInitRmLostFound:
- name: init-volumes
2024-08-16 17:46:21 +08:00
image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.ALPINE_IMAGE_ORG }}alpine"
2023-11-21 23:49:51 +08:00
command:
- chmod
- "777"
volumeMountsInitContainer:
EOL
2023-02-01 23:00:52 +08:00
# shellcheck disable=SC1083
DEPLOYMENTS = " $( find ./ -name '*deployment.yaml' ) "
mapfile -t DEPLOYMENTS <<< " $DEPLOYMENTS "
for variable in " ${ DEPLOYMENTS [@] } " ; do
if grep -q volumeMounts " $variable " ; then
2023-11-21 19:00:51 +08:00
if echo " $variable " | grep -q database; then
2023-02-02 20:06:26 +08:00
sed -i "/^ spec:/r /tmp/initcontainers.database" " $variable "
2023-11-21 19:00:51 +08:00
elif echo " $variable " | grep -q clamav; then
sed -i "/^ spec:/r /tmp/initcontainers.clamav" " $variable "
2023-11-21 23:49:51 +08:00
elif echo " $variable " | grep -q "nextcloud-deployment.yaml" ; then
sed -i "/^ spec:/r /tmp/initcontainers.nextcloud" " $variable "
2023-11-21 19:00:51 +08:00
else
sed -i "/^ spec:/r /tmp/initcontainers" " $variable "
2023-02-02 20:06:26 +08:00
fi
2023-02-01 23:00:52 +08:00
volumeNames = " $( grep -A1 mountPath " $variable " | grep -v mountPath | sed 's|.*name: ||' | sed '/^--$/d' ) "
mapfile -t volumeNames <<< " $volumeNames "
for volumeName in " ${ volumeNames [@] } " ; do
2023-02-05 00:03:42 +08:00
# The Nextcloud container runs as root user and sets the correct permissions automatically for the data-dir if the www-data user cannot write to it
if [ " $volumeName " != "nextcloud-aio-nextcloud-data" ] ; then
sed -i " /^.*volumeMountsInitContainer:/i\ \ \ \ \ \ \ \ \ \ \ \ - / $volumeName " " $variable "
sed -i " /volumeMountsInitContainer:/a\ \ \ \ \ \ \ \ \ \ \ \ - name: $volumeName \n\ \ \ \ \ \ \ \ \ \ \ \ \ \ mountPath: / $volumeName " " $variable "
2023-11-21 23:49:51 +08:00
sed -i " /volumeMountsInitRmLostFound:/a\ \ \ \ \ \ \ \ \ \ \ \ - name: $volumeName \n\ \ \ \ \ \ \ \ \ \ \ \ \ \ mountPath: / $volumeName " " $variable "
2023-05-03 02:12:57 +08:00
# Workaround for the database volume
if [ " $volumeName " = nextcloud-aio-database ] ; then
sed -i "/mountPath: \/var\/lib\/postgresql\/data/a\ \ \ \ \ \ \ \ \ \ \ \ \ \ subPath: data" " $variable "
2023-11-21 19:00:51 +08:00
elif [ " $volumeName " = nextcloud-aio-clamav ] ; then
sed -i "/mountPath: \/var\/lib\/clamav/a\ \ \ \ \ \ \ \ \ \ \ \ \ \ subPath: data" " $variable "
2023-05-03 02:12:57 +08:00
fi
2023-02-05 00:03:42 +08:00
fi
2023-02-01 23:00:52 +08:00
done
2023-11-21 23:49:51 +08:00
sed -i "s|volumeMountsInitContainer:|volumeMounts:|" " $variable "
sed -i "s|volumeMountsInitRmLostFound:|volumeMounts:|" " $variable "
2023-02-02 19:49:26 +08:00
if grep -q claimName " $variable " ; then
claimNames = " $( grep claimName " $variable " ) "
mapfile -t claimNames <<< " $claimNames "
for claimName in " ${ claimNames [@] } " ; do
if grep -A1 " ^ $claimName $" " $variable " | grep -q "readOnly: true" ; then
sed -i " /^ $claimName $/{n;d} " " $variable "
fi
done
fi
2023-02-01 23:00:52 +08:00
fi
done
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2024-02-28 19:01:30 +08:00
find ./ -name '*.yaml' -exec sed -i 's|nextcloud-aio-namespace|"\{\{ .Values.NAMESPACE \}\}"|' \{ } \;
2023-07-18 22:50:18 +08:00
# shellcheck disable=SC1083
2023-01-28 23:23:46 +08:00
find ./ -name '*service.yaml' -exec sed -i " /^status:/, $ d " \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-01-28 23:23:46 +08:00
find ./ -name '*deployment.yaml' -exec sed -i "s|manual-install-nextcloud-aio|nextcloud-aio|" \{ } \;
# shellcheck disable=SC1083
2023-06-18 08:46:42 +08:00
find ./ -name '*deployment.yaml' -exec sed -i "/medium: Memory/d" \{ } \;
# shellcheck disable=SC1083
2023-06-19 23:49:08 +08:00
find ./ -name '*deployment.yaml' -exec sed -i "s|emptyDir:|emptyDir: \{\}|" \{ } \;
2023-06-18 08:46:42 +08:00
# shellcheck disable=SC1083
2023-09-29 17:30:33 +08:00
find ./ -name '*deployment.yaml' -exec sed -i "/hostPort:/d" \{ } \;
# shellcheck disable=SC1083
2023-01-28 23:23:46 +08:00
find ./ -name '*persistentvolumeclaim.yaml' -exec sed -i "s|ReadOnlyMany|ReadWriteOnce|" \{ } \;
2023-11-07 04:47:31 +08:00
# shellcheck disable=SC1083
find ./ -name 'nextcloud-aio-nextcloud-persistentvolumeclaim.yaml' -exec sed -i "s|ReadWriteOnce|ReadWriteMany|" \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
find ./ -name '*persistentvolumeclaim.yaml' -exec sed -i "/accessModes:/i\ \ {{- if .Values.STORAGE_CLASS }}" \{ } \;
# shellcheck disable=SC1083
find ./ -name '*persistentvolumeclaim.yaml' -exec sed -i "/accessModes:/i\ \ storageClassName: {{ .Values.STORAGE_CLASS }}" \{ } \;
# shellcheck disable=SC1083
find ./ -name '*persistentvolumeclaim.yaml' -exec sed -i "/accessModes:/i\ \ {{- end }}" \{ } \;
# shellcheck disable=SC1083
2023-02-03 22:50:15 +08:00
find ./ -name '*deployment.yaml' -exec sed -i "/restartPolicy:/d" \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-02-03 22:50:15 +08:00
find ./ -name '*apache*' -exec sed -i " s| $APACHE_PORT |{{ .Values.APACHE_PORT }}| " \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-02-03 22:50:15 +08:00
find ./ -name '*talk*' -exec sed -i " s| $TALK_PORT |{{ .Values.TALK_PORT }}| " \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-02-03 22:50:15 +08:00
find ./ -name '*apache-service.yaml' -exec sed -i "/^spec:/a\ \ type: LoadBalancer" \{ } \;
# shellcheck disable=SC1083
find ./ -name '*talk-service.yaml' -exec sed -i "/^spec:/a\ \ type: LoadBalancer" \{ } \;
2023-02-04 22:23:44 +08:00
echo '---' > /tmp/talk-service.copy
# shellcheck disable=SC1083
find ./ -name '*talk-service.yaml' -exec cat \{ } \; >> /tmp/talk-service.copy
sed -i 's|name: nextcloud-aio-talk|name: nextcloud-aio-talk-public|' /tmp/talk-service.copy
# shellcheck disable=SC1083
INTERNAL_TALK_PORTS = " $( find ./ -name '*talk-deployment.yaml' -exec grep -oP 'containerPort: [0-9]+' \{ } \; ) "
mapfile -t INTERNAL_TALK_PORTS <<< " $INTERNAL_TALK_PORTS "
for port in " ${ INTERNAL_TALK_PORTS [@] } " ; do
port = " $( echo " $port " | grep -oP '[0-9]+' ) "
sed -i " / $port /d " /tmp/talk-service.copy
done
echo '---' >> /tmp/talk-service.copy
# shellcheck disable=SC1083
2023-08-17 15:14:39 +08:00
find ./ -name '*talk-service.yaml' -exec grep -v '{{ .Values.TALK.*}}\|protocol: UDP\|type: LoadBalancer' \{ } \; >> /tmp/talk-service.copy
2023-02-04 22:23:44 +08:00
# shellcheck disable=SC1083
find ./ -name '*talk-service.yaml' -exec mv /tmp/talk-service.copy \{ } \;
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
2023-11-13 21:09:36 +08:00
find ./ -name '*service.yaml' -exec sed -i "/type: LoadBalancer/a\ \ externalTrafficPolicy: Local" \{ } \;
# shellcheck disable=SC1083
2023-11-13 21:24:13 +08:00
find ./ -name '*service.yaml' -exec sed -i "/^spec:/a\ \ ipFamilyPolicy: PreferDualStack" \{ } \;
# shellcheck disable=SC1083
2022-12-22 20:29:31 +08:00
find ./ -name '*.yaml' -exec sed -i "s|'{{|\"{{|g;s|}}'|}}\"|g" \{ } \;
# shellcheck disable=SC1083
find ./ \( -not -name '*service.yaml' -name '*.yaml' \) -exec sed -i "/^status:/d" \{ } \;
# shellcheck disable=SC1083
find ./ \( -not -name '*persistentvolumeclaim.yaml' -name '*.yaml' \) -exec sed -i "/resources:/d" \{ } \;
# shellcheck disable=SC1083
2024-07-15 19:45:53 +08:00
find ./ -name "*namespace.yaml" -exec sed -i "1i\\{{- if and \(ne .Values.NAMESPACE \"default\"\) \(ne .Values.NAMESPACE_DISABLED \"yes\"\) }}" \{ } \;
2024-03-04 17:24:22 +08:00
# shellcheck disable=SC1083
find ./ -name "*namespace.yaml" -exec sed -i " $ a {{- end }} " \{ } \;
# shellcheck disable=SC1083
2022-12-22 20:29:31 +08:00
find ./ -name '*.yaml' -exec sed -i "/creationTimestamp: null/d" \{ } \;
2023-02-23 22:36:05 +08:00
VOLUMES = " $( find ./ -name '*persistentvolumeclaim.yaml' | sed 's|-persistentvolumeclaim.yaml||g;s|.*nextcloud-aio-||g' | sort) "
2023-02-01 19:35:40 +08:00
mapfile -t VOLUMES <<< " $VOLUMES "
for variable in " ${ VOLUMES [@] } " ; do
name = " $( echo " $variable " | sed 's|-|_|g' | tr '[:lower:]' '[:upper:]' ) _STORAGE_SIZE "
VOLUME_VARIABLE += ( " $name " )
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $variable -persistentvolumeclaim.yaml " -exec sed -i " s|storage: 100Mi|storage: {{ .Values. $name }}| " \{ } \;
done
2022-12-22 20:29:31 +08:00
2023-11-16 20:58:06 +08:00
# Additional config
cat << EOL > /tmp/additional.config
- name: SMTP_HOST
value: "{{ .Values.SMTP_HOST }}"
- name: SMTP_SECURE
value: "{{ .Values.SMTP_SECURE }}"
- name: SMTP_PORT
value: "{{ .Values.SMTP_PORT }}"
- name: SMTP_AUTHTYPE
value: "{{ .Values.SMTP_AUTHTYPE }}"
- name: SMTP_NAME
value: "{{ .Values.SMTP_NAME }}"
- name: SMTP_PASSWORD
value: "{{ .Values.SMTP_PASSWORD }}"
- name: MAIL_FROM_ADDRESS
value: "{{ .Values.MAIL_FROM_ADDRESS }}"
- name: MAIL_DOMAIN
value: "{{ .Values.MAIL_DOMAIN }}"
- name: SUBSCRIPTION_KEY
value: "{{ .Values.SUBSCRIPTION_KEY }}"
- name: APPS_ALLOWLIST
value: "{{ .Values.APPS_ALLOWLIST }}"
2023-11-22 00:34:37 +08:00
- name: ADDITIONAL_TRUSTED_PROXY
value: "{{ .Values.ADDITIONAL_TRUSTED_PROXY }}"
2024-02-01 20:25:22 +08:00
- name: ADDITIONAL_TRUSTED_DOMAIN
value: "{{ .Values.ADDITIONAL_TRUSTED_DOMAIN }}"
2023-12-07 19:32:08 +08:00
- name: SERVERINFO_TOKEN
value: "{{ .Values.SERVERINFO_TOKEN }}"
2024-05-28 17:15:13 +08:00
- name: NEXTCLOUD_DEFAULT_QUOTA
value: "{{ .Values.NEXTCLOUD_DEFAULT_QUOTA }}"
2024-07-26 18:57:40 +08:00
- name: NEXTCLOUD_MAINTENANCE_WINDOW
value: "{{ .Values.NEXTCLOUD_MAINTENANCE_WINDOW }}"
2023-11-16 20:58:06 +08:00
EOL
# shellcheck disable=SC1083
find ./ -name '*nextcloud-deployment.yaml' -exec sed -i "/^.*\- env:/r /tmp/additional.config" \{ } \;
2024-02-01 20:25:22 +08:00
# Additional config
cat << EOL > /tmp/additional-apache.config
- name: ADDITIONAL_TRUSTED_DOMAIN
value: "{{ .Values.ADDITIONAL_TRUSTED_DOMAIN }}"
EOL
# shellcheck disable=SC1083
find ./ -name '*apache-deployment.yaml' -exec sed -i "/^.*\- env:/r /tmp/additional-apache.config" \{ } \;
2024-04-04 17:03:02 +08:00
# Additional config
cat << EOL > /tmp/additional-talk.config
- name: TALK_MAX_STREAM_BITRATE
value: "{{ .Values.TALK_MAX_STREAM_BITRATE }}"
2024-04-11 20:06:58 +08:00
- name: TALK_MAX_SCREEN_BITRATE
value: "{{ .Values.TALK_MAX_SCREEN_BITRATE }}"
2024-04-04 17:03:02 +08:00
EOL
# shellcheck disable=SC1083
find ./ -name '*talk-deployment.yaml' -exec sed -i "/^.*\- env:/r /tmp/additional-talk.config" \{ } \;
2024-03-14 19:40:17 +08:00
# shellcheck disable=SC1083
2024-03-26 20:54:02 +08:00
find ./ -name '*deployment.yaml' -exec sed -i '/image: nextcloud/s/$/"/;s|image: nextcloud/|image: "{{ .Values.IMAGE_MIRROR_PREFIX }}{{ .Values.NEXTCLOUD_IMAGE_ORG }}/|;' \{ } \;
2024-02-01 20:25:22 +08:00
2024-07-22 21:43:04 +08:00
cat << EOL > templates/nextcloud-aio-networkpolicy.yaml
{ { - if eq .Values.NETWORK_POLICY_ENABLED "yes" } }
# https://github.com/ahmetb/kubernetes-network-policy-recipes/blob/master/04-deny-traffic-from-other-namespaces.md
kind: NetworkPolicy
apiVersion: networking.k8s.io/v1
metadata:
namespace: "{{ .Values.NAMESPACE }}"
name: nextcloud-aio-deny-from-other-namespaces
spec:
podSelector:
matchLabels:
2024-07-25 21:27:50 +08:00
policyTypes:
- Ingress
- Egress
2024-07-22 21:43:04 +08:00
ingress:
- from:
- podSelector: { }
2024-07-25 21:27:50 +08:00
egress:
- to:
- podSelector: { }
2024-07-22 21:43:04 +08:00
{ { - end } }
EOL
2022-12-22 20:29:31 +08:00
cd ../
mkdir -p ../helm-chart/
rm latest/Chart.yaml
rm latest/README.md
mv latest/* ../helm-chart/
rm -r latest
rm latest.yml
mv latest.yml.backup latest.yml
# Get version of AIO
AIO_VERSION = " $( grep 'Nextcloud AIO ' ../php/templates/containers.twig | grep -oP '[0-9]+.[0-9]+.[0-9]+' ) "
sed -i " s|^version:.*|version: $AIO_VERSION | " ../helm-chart/Chart.yaml
# Conversion of sample.conf
cp sample.conf /tmp/
sed -i 's|"||g' /tmp/sample.conf
sed -i 's|=|: |' /tmp/sample.conf
sed -i 's|= |: |' /tmp/sample.conf
sed -i '/^NEXTCLOUD_DATADIR/d' /tmp/sample.conf
2023-02-03 22:50:15 +08:00
sed -i '/^APACHE_IP_BINDING/d' /tmp/sample.conf
2023-01-29 07:02:18 +08:00
sed -i '/^NEXTCLOUD_MOUNT/d' /tmp/sample.conf
2023-02-02 19:05:09 +08:00
sed -i '/_ENABLED.*/s/ yes / "yes" /' /tmp/sample.conf
2023-02-10 20:58:23 +08:00
sed -i '/_ENABLED.*/s/ no / "no" /' /tmp/sample.conf
2022-12-22 20:29:31 +08:00
sed -i 's|^NEXTCLOUD_TRUSTED_CACERTS_DIR: .*|NEXTCLOUD_TRUSTED_CACERTS_DIR: # Setting this to any value allows to automatically import root certificates into the Nextcloud container|' /tmp/sample.conf
2023-04-19 05:44:07 +08:00
sed -i 's|10737418240|"10737418240"|' /tmp/sample.conf
2023-07-18 22:50:18 +08:00
# shellcheck disable=SC2129
2023-06-17 05:55:43 +08:00
echo "" >> /tmp/sample.conf
2023-01-29 07:02:18 +08:00
# shellcheck disable=SC2129
2022-12-22 20:29:31 +08:00
echo 'STORAGE_CLASS: # By setting this, you can adjust the storage class for your volumes' >> /tmp/sample.conf
2023-02-01 19:35:40 +08:00
for variable in " ${ VOLUME_VARIABLE [@] } " ; do
echo " $variable : 1Gi # You can change the size of the $( echo " $variable " | sed 's|_STORAGE_SIZE||;s|_|-|g' | tr '[:upper:]' '[:lower:]' ) volume that default to 1Gi with this value " >> /tmp/sample.conf
done
2023-11-06 23:00:49 +08:00
sed -i "s|NEXTCLOUD_STORAGE_SIZE: 1Gi|NEXTCLOUD_STORAGE_SIZE: 5Gi|" /tmp/sample.conf
sed -i "s|NEXTCLOUD_DATA_STORAGE_SIZE: 1Gi|NEXTCLOUD_DATA_STORAGE_SIZE: 5Gi|" /tmp/sample.conf
2023-11-16 20:58:06 +08:00
# Additional config
cat << ADDITIONA L_CONFIG >> /tmp/sample.conf
2023-11-22 02:10:06 +08:00
NAMESPACE: default # By changing this, you can adjust the namespace of the installation which allows to install multiple instances on one kubernetes cluster
2024-07-15 19:45:53 +08:00
NAMESPACE_DISABLED: "no" # By setting this to "yes", you can disabled the creation of the namespace so that you can use a pre-created one
2024-07-22 21:43:04 +08:00
NETWORK_POLICY_ENABLED: "no" # By setting this to "yes", you can enable a network policy that limits network access to the same namespace. ⚠️ Attention: this breaks if you use an ingress!!! So it should be disabled if you do so!
2023-11-16 20:58:06 +08:00
SUBSCRIPTION_KEY: # This allows to set the Nextcloud Enterprise key via ENV
2023-12-07 19:32:08 +08:00
SERVERINFO_TOKEN: # This allows to set the serverinfo app token for monitoring your Nextcloud via the serverinfo app
2023-11-16 20:58:06 +08:00
APPS_ALLOWLIST: # This allows to configure allowed apps that will be shown in Nextcloud's Appstore. You need to enter the app-IDs of the apps here and separate them with spaces. E.g. 'files richdocuments'
2023-11-22 00:34:37 +08:00
ADDITIONAL_TRUSTED_PROXY: # Allows to add one additional ip-address to Nextcloud's trusted proxies and to the Office WOPI-allowlist automatically. Set it e.g. like this: 'your.public.ip-address'. You can also use an ip-range here.
2024-02-01 20:25:22 +08:00
ADDITIONAL_TRUSTED_DOMAIN: # Allows to add one domain to Nextcloud's trusted domains and also generates a certificate automatically for it
2024-05-28 17:15:13 +08:00
NEXTCLOUD_DEFAULT_QUOTA: "10 GB" # Allows to adjust the default quota that will be taken into account in Nextcloud for new users. Setting it to "unlimited" will set it to unlimited
2024-07-26 18:57:40 +08:00
NEXTCLOUD_MAINTENANCE_WINDOW: # Allows to define the maintenance window for Nextcloud. See https://docs.nextcloud.com/server/stable/admin_manual/configuration_server/background_jobs_configuration.html#parameters for possible values
2023-11-16 20:58:06 +08:00
SMTP_HOST: # (empty by default): The hostname of the SMTP server.
SMTP_SECURE: # (empty by default): Set to 'ssl' to use SSL, or 'tls' to use STARTTLS.
SMTP_PORT: # (default: '465' for SSL and '25' for non-secure connections): Optional port for the SMTP connection. Use '587' for an alternative port for STARTTLS.
SMTP_AUTHTYPE: # (default: 'LOGIN'): The method used for authentication. Use 'PLAIN' if no authentication or STARTLS is required.
SMTP_NAME: # (empty by default): The username for the authentication.
SMTP_PASSWORD: # (empty by default): The password for the authentication.
MAIL_FROM_ADDRESS: # (not set by default): Set the local-part for the 'from' field in the emails sent by Nextcloud.
MAIL_DOMAIN: # (not set by default): Set a different domain for the emails than the domain where Nextcloud is installed.
2024-04-04 17:03:02 +08:00
TALK_MAX_STREAM_BITRATE: "1048576" # This allows to adjust the max stream bitrate of the talk hpb
2024-04-11 20:06:58 +08:00
TALK_MAX_SCREEN_BITRATE: "2097152" # This allows to adjust the max stream bitrate of the talk hpb
2024-03-14 19:40:17 +08:00
2024-08-16 16:00:47 +08:00
IMAGE_MIRROR_PREFIX: # Setting this allows you to pull Nextcloud images through a mirror registry. It needs a trailing slash!
2024-03-14 19:40:17 +08:00
NEXTCLOUD_IMAGE_ORG: nextcloud # Setting this allows you to change the image's org name in case a different image needs to be used e.g. for compliance reasons.
2024-08-16 17:46:21 +08:00
ALPINE_IMAGE_ORG: # Setting this allows you to change the image's org name in case a different image needs to be used e.g. for compliance reasons. It needs a trailing slash!
2023-11-16 20:58:06 +08:00
ADDITIONAL_CONFIG
2022-12-22 20:29:31 +08:00
mv /tmp/sample.conf ../helm-chart/values.yaml
2023-06-13 16:16:09 +08:00
ENABLED_VARIABLES = " $( grep -oP '^[A-Z_]+_ENABLED' ../helm-chart/values.yaml) "
2022-12-22 20:29:31 +08:00
mapfile -t ENABLED_VARIABLES <<< " $ENABLED_VARIABLES "
cd ../helm-chart/
for variable in " ${ ENABLED_VARIABLES [@] } " ; do
2023-06-13 16:16:09 +08:00
name = " $( echo " $variable " | sed 's|_ENABLED||g;s|_|-|g' | tr '[:upper:]' '[:lower:]' ) "
2022-12-22 20:29:31 +08:00
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -deployment.yaml " -exec sed -i " 1i\\{{- if eq .Values. $variable \"yes\" }} " \{ } \;
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -deployment.yaml " -exec sed -i " $ a {{- end }} " \{ } \;
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -service.yaml " -exec sed -i " 1i\\{{- if eq .Values. $variable \"yes\" }} " \{ } \;
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -service.yaml " -exec sed -i " $ a {{- end }} " \{ } \;
2023-11-23 18:34:57 +08:00
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -persistentvolumeclaim.yaml " -exec sed -i " 1i\\{{- if eq .Values. $variable \"yes\" }} " \{ } \;
# shellcheck disable=SC1083
find ./ -name " *nextcloud-aio- $name -persistentvolumeclaim.yaml " -exec sed -i " $ a {{- end }} " \{ } \;
2022-12-22 20:29:31 +08:00
done
2024-02-23 23:19:27 +08:00
# Additional case for FTS volume
# shellcheck disable=SC1083
find ./ -name "*nextcloud-aio-elasticsearch-persistentvolumeclaim.yaml" -exec sed -i "1i\\{{- if eq .Values.FULLTEXTSEARCH_ENABLED \"yes\" }}" \{ } \;
# shellcheck disable=SC1083
find ./ -name "*nextcloud-aio-elasticsearch-persistentvolumeclaim.yaml" -exec sed -i " $ a {{- end }} " \{ } \;
2022-12-22 20:29:31 +08:00
chmod 777 -R ./
2023-03-30 16:16:24 +08:00
# Seems like the dir needs to match the name of the chart
cd ../
rm -rf ./nextcloud-aio-helm-chart
mv ./helm-chart ./nextcloud-aio-helm-chart
2022-12-22 20:29:31 +08:00
set +ex