You've already forked helm-gitea
							
							Compare commits
	
		
			67 Commits
		
	
	
		
			v12.0.0
			...
			1d49cf3f58
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 1d49cf3f58 | |||
|   | 0a463f7252 | ||
|   | 14ac6abf78 | ||
| 89017545d3 | |||
|   | 40d8e5b6e3 | ||
|   | 1cdb7b7342 | ||
|   | 5c88f5fe9b | ||
|   | d7437cef0b | ||
|   | 1d7037e55e | ||
|   | 9cf42f55b0 | ||
|   | 8ed2db6aa5 | ||
|   | 667834962e | ||
|   | 78aba58284 | ||
|   | 7c0a924ca3 | ||
|   | 677b1af2ed | ||
|   | c9af860e60 | ||
|   | 3721929be2 | ||
|   | 44e9970b0b | ||
|   | 4fc53cd978 | ||
|   | 122bccd932 | ||
|   | 3233e33e27 | ||
|   | 6b99230843 | ||
| d9e181df93 | |||
|   | 603f8e68a7 | ||
| 10ad0f7743 | |||
| e31bd265b1 | |||
|   | 4cfcbd729f | ||
|   | f786359136 | ||
|   | 6d5fbcbaee | ||
|   | 14a4e47b73 | ||
|   | 3a7859f6cc | ||
|   | 364dfa2076 | ||
| 468c12643f | |||
|   | 46aa0534bb | ||
|   | 455cc67d41 | ||
|   | ec898f1330 | ||
| 82190f3d30 | |||
|   | e059beb82b | ||
|   | 9206b34af3 | ||
|   | 203a282e93 | ||
|   | 81c12fa3e5 | ||
|   | c7e294cf8c | ||
|   | ce60c7bb0f | ||
|   | 2875e08daf | ||
| 09767c4494 | |||
|   | a45253abf9 | ||
|   | f9efe98fe7 | ||
|   | 92c187f264 | ||
|   | 4fbdf634a9 | ||
|   | f0dcbe88dd | ||
|   | aa7ccb47ba | ||
|   | 0f1f329de4 | ||
|   | cb28148dc8 | ||
|   | ee84a1750b | ||
|   | 6e1d516bb2 | ||
|   | 08143654a5 | ||
|   | e134835662 | ||
|   | e7db8cddd9 | ||
| ec7a659535 | |||
|   | db177a356f | ||
|   | d29a7e84a4 | ||
|   | 31fa278145 | ||
|   | 52c249eb08 | ||
|   | 0d532363eb | ||
|   | 8f0f44a864 | ||
|   | cf86118976 | ||
|   | 7f96084a30 | 
							
								
								
									
										114
									
								
								.gitea/scripts/add-annotations.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										114
									
								
								.gitea/scripts/add-annotations.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,114 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| set -e | ||||
|  | ||||
| CHART_FILE="Chart.yaml" | ||||
| if [ ! -f "${CHART_FILE}" ]; then | ||||
|   echo "ERROR: ${CHART_FILE} not found!" 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| DEFAULT_NEW_TAG="$(git tag --sort=-version:refname | head -n 1)" | ||||
| DEFAULT_OLD_TAG="$(git tag --sort=-version:refname | head -n 2 | tail -n 1)" | ||||
|  | ||||
| if [ -z "${1}" ]; then | ||||
|   read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG | ||||
|   if [ -z "${OLD_TAG}" ]; then | ||||
|     OLD_TAG="${DEFAULT_OLD_TAG}" | ||||
|   fi | ||||
|  | ||||
|   while [ -z "$(git tag --list "${OLD_TAG}")" ]; do | ||||
|     echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2 | ||||
|     read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG | ||||
|     if [ -z "${OLD_TAG}" ]; then | ||||
|       OLD_TAG="${DEFAULT_OLD_TAG}" | ||||
|     fi | ||||
|   done | ||||
| else | ||||
|   OLD_TAG=${1} | ||||
|   if [ -z "$(git tag --list "${OLD_TAG}")" ]; then | ||||
|     echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| if [ -z "${2}" ]; then | ||||
|   read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG | ||||
|   if [ -z "${NEW_TAG}" ]; then | ||||
|     NEW_TAG="${DEFAULT_NEW_TAG}" | ||||
|   fi | ||||
|  | ||||
|   while [ -z "$(git tag --list "${NEW_TAG}")" ]; do | ||||
|     echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2 | ||||
|     read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG | ||||
|     if [ -z "${NEW_TAG}" ]; then | ||||
|       NEW_TAG="${DEFAULT_NEW_TAG}" | ||||
|     fi | ||||
|   done | ||||
| else | ||||
|   NEW_TAG=${2} | ||||
|  | ||||
|   if [ -z "$(git tag --list "${NEW_TAG}")" ]; then | ||||
|     echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| CHANGE_LOG_YAML=$(mktemp) | ||||
| echo "[]" > "${CHANGE_LOG_YAML}" | ||||
|  | ||||
| function map_type_to_kind() { | ||||
|   case "${1}" in | ||||
|     feat) | ||||
|       echo "added" | ||||
|     ;; | ||||
|     fix) | ||||
|       echo "fixed" | ||||
|     ;; | ||||
|     chore|style|test|ci|docs|refac) | ||||
|       echo "changed" | ||||
|     ;; | ||||
|     revert) | ||||
|       echo "removed" | ||||
|     ;; | ||||
|     sec) | ||||
|       echo "security" | ||||
|     ;; | ||||
|     *) | ||||
|       echo "skip" | ||||
|     ;; | ||||
|   esac | ||||
| } | ||||
|  | ||||
| COMMIT_TITLES="$(git log --pretty=format:"%s" "${OLD_TAG}..${NEW_TAG}")" | ||||
|  | ||||
| echo "INFO: Generate change log entries from ${OLD_TAG} until ${NEW_TAG}" | ||||
|  | ||||
| while IFS= read -r line; do | ||||
|   if [[ "${line}" =~ ^([a-zA-Z]+)(\([^\)]+\))?\:\ (.+)$ ]]; then | ||||
|     TYPE="${BASH_REMATCH[1]}" | ||||
|     KIND=$(map_type_to_kind "${TYPE}") | ||||
|  | ||||
|     if [ "${KIND}" == "skip" ]; then | ||||
|       continue | ||||
|     fi | ||||
|  | ||||
|     DESC="${BASH_REMATCH[3]}" | ||||
|  | ||||
|     echo "- ${KIND}: ${DESC}" | ||||
|  | ||||
|     jq --arg kind "${KIND}" --arg description "${DESC}" '. += [ $ARGS.named ]' < "${CHANGE_LOG_YAML}" > "${CHANGE_LOG_YAML}.new" | ||||
|     mv "${CHANGE_LOG_YAML}.new" "${CHANGE_LOG_YAML}" | ||||
|  | ||||
|   fi | ||||
| done <<< "${COMMIT_TITLES}" | ||||
|  | ||||
| if [ -s "${CHANGE_LOG_YAML}" ]; then | ||||
|   yq --inplace --input-format json --output-format yml "${CHANGE_LOG_YAML}" | ||||
|   yq --no-colors --inplace ".annotations.\"artifacthub.io/changes\" |= loadstr(\"${CHANGE_LOG_YAML}\") | sort_keys(.)" "${CHART_FILE}" | ||||
| else | ||||
|   echo "ERROR: Changelog file is empty: ${CHANGE_LOG_YAML}" 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| rm "${CHANGE_LOG_YAML}" | ||||
| @@ -8,12 +8,12 @@ on: | ||||
| jobs: | ||||
|   changelog: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.1 | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.5 | ||||
|     steps: | ||||
|       - name: install tools | ||||
|         run: | | ||||
|           apk add -q --update --no-cache nodejs curl jq sed | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@v5 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - name: Generate upcoming changelog | ||||
|   | ||||
| @@ -11,9 +11,9 @@ on: | ||||
| jobs: | ||||
|   check-and-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: commitlint/commitlint:19.8.1 | ||||
|     container: commitlint/commitlint:20.1.0 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@v5 | ||||
|       - name: check PR title | ||||
|         run: | | ||||
|           echo "${{ gitea.event.pull_request.title }}" | commitlint --config .commitlintrc.json | ||||
|   | ||||
| @@ -5,79 +5,106 @@ on: | ||||
|     tags: | ||||
|       - "*" | ||||
|  | ||||
| env: | ||||
|   # renovate: datasource=docker depName=alpine/helm | ||||
|   HELM_VERSION: "3.17.3" | ||||
|  | ||||
| jobs: | ||||
|   # generate-chart-publish: | ||||
|   #   runs-on: ubuntu-latest | ||||
|   #   steps: | ||||
|   #     - uses: actions/checkout@v4 | ||||
|   #     - name: install tools | ||||
|   #       run: | | ||||
|   #         apt update -y | ||||
|   #         apt install -y curl ca-certificates curl gnupg | ||||
|   #         # helm | ||||
|   #         curl -O https://get.helm.sh/helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|   #         tar -xzf helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|   #         mv linux-amd64/helm /usr/local/bin/ | ||||
|   #         rm -rf linux-amd64 helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|   #         helm version | ||||
|   #         # docker | ||||
|   #         install -m 0755 -d /etc/apt/keyrings | ||||
|   #         curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg | ||||
|   #         chmod a+r /etc/apt/keyrings/docker.gpg | ||||
|   #         echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null | ||||
|   #         apt update -y | ||||
|   #         apt install -y python3 python3-pip apt-transport-https docker-ce-cli | ||||
|   #         pip install awscli --break-system-packages | ||||
|   generate-chart-publish: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v5 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|   #     - name: Import GPG key | ||||
|   #       id: import_gpg | ||||
|   #       uses: https://github.com/crazy-max/ghaction-import-gpg@v6 | ||||
|   #       with: | ||||
|   #         gpg_private_key: ${{ secrets.GPGSIGN_KEY }} | ||||
|   #         passphrase: ${{ secrets.GPGSIGN_PASSPHRASE }} | ||||
|   #         fingerprint: CC64B1DB67ABBEECAB24B6455FC346329753F4B0 | ||||
|       - name: Install packages via apt | ||||
|         run: | | ||||
|           apt update --yes | ||||
|           apt install --yes curl ca-certificates curl gnupg jq | ||||
|  | ||||
|   #     # Using helm gpg plugin as 'helm package --sign' has issues with gpg2: https://github.com/helm/helm/issues/2843 | ||||
|   #     - name: package chart | ||||
|   #       run: | | ||||
|   #         echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | docker login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} --password-stdin | ||||
|   #         # FIXME: use upstream after https://github.com/technosophos/helm-gpg/issues/1 is solved | ||||
|   #         helm plugin install https://github.com/pat-s/helm-gpg | ||||
|   #         helm dependency build | ||||
|   #         helm package --version "${GITHUB_REF#refs/tags/v}" ./ | ||||
|   #         mkdir gitea | ||||
|   #         mv gitea*.tgz gitea/ | ||||
|   #         curl -s -L -o gitea/index.yaml https://dl.gitea.com/charts/index.yaml | ||||
|   #         helm repo index gitea/ --url https://dl.gitea.com/charts --merge gitea/index.yaml | ||||
|   #         # push to dockerhub | ||||
|   #         echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | helm registry login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} registry-1.docker.io --password-stdin | ||||
|   #         helm push gitea/gitea-${GITHUB_REF#refs/tags/v}.tgz oci://registry-1.docker.io/giteacharts | ||||
|   #         helm registry logout registry-1.docker.io | ||||
|       - name: Install helm | ||||
|         env: | ||||
|           # renovate: datasource=docker depName=alpine/helm | ||||
|           HELM_VERSION: "3.19.0" | ||||
|         run: | | ||||
|           curl --fail --location --output /dev/stdout --silent --show-error https://get.helm.sh/helm-v${HELM_VERSION}-linux-$(dpkg --print-architecture).tar.gz | tar --extract --gzip --file /dev/stdin | ||||
|           mv linux-$(dpkg --print-architecture)/helm /usr/local/bin/ | ||||
|           rm --force --recursive linux-$(dpkg --print-architecture) helm-v${HELM_VERSION}-linux-$(dpkg --print-architecture).tar.gz | ||||
|           helm version | ||||
|  | ||||
|   #     - name: aws credential configure | ||||
|   #       uses: https://github.com/aws-actions/configure-aws-credentials@v4 | ||||
|   #       with: | ||||
|   #         aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | ||||
|   #         aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||
|   #         aws-region: ${{ secrets.AWS_REGION }} | ||||
|       - name: Install yq | ||||
|         env: | ||||
|           YQ_VERSION: v4.45.4 # renovate: datasource=github-releases depName=mikefarah/yq | ||||
|         run: | | ||||
|           curl --fail --location --output /dev/stdout --silent --show-error https://github.com/mikefarah/yq/releases/download/${YQ_VERSION}/yq_linux_$(dpkg --print-architecture).tar.gz | tar --extract --gzip --file /dev/stdin | ||||
|           mv yq_linux_$(dpkg --print-architecture) /usr/local/bin | ||||
|           rm --force --recursive yq_linux_$(dpkg --print-architecture) yq_linux_$(dpkg --print-architecture).tar.gz | ||||
|           yq --version | ||||
|  | ||||
|   #     - name: Copy files to S3 and clear cache | ||||
|   #       run: | | ||||
|   #         aws s3 sync gitea/ s3://${{ secrets.AWS_S3_BUCKET}}/charts/ | ||||
|       - name: Install docker-ce via apt | ||||
|         run: | | ||||
|           install -m 0755 -d /etc/apt/keyrings | ||||
|           curl --fail --location --silent --show-error https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg | ||||
|           chmod a+r /etc/apt/keyrings/docker.gpg | ||||
|           echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null | ||||
|           apt update --yes | ||||
|           apt install --yes python3 python3-pip apt-transport-https docker-ce-cli | ||||
|  | ||||
|       - name: Install awscli | ||||
|         run: | | ||||
|           pip install awscli --break-system-packages | ||||
|           aws --version | ||||
|  | ||||
|       - name: Import GPG key | ||||
|         id: import_gpg | ||||
|         uses: https://github.com/crazy-max/ghaction-import-gpg@v6 | ||||
|         with: | ||||
|           gpg_private_key: ${{ secrets.GPGSIGN_KEY }} | ||||
|           passphrase: ${{ secrets.GPGSIGN_PASSPHRASE }} | ||||
|           fingerprint: CC64B1DB67ABBEECAB24B6455FC346329753F4B0 | ||||
|  | ||||
|       - name: Add Artifacthub.io annotations | ||||
|         run: | | ||||
|           NEW_TAG="$(git tag --sort=-version:refname | head --lines 1)" | ||||
|           OLD_TAG="$(git tag --sort=-version:refname | head --lines 2 | tail --lines 1)" | ||||
|           .gitea/scripts/add-annotations.sh "${OLD_TAG}" "${NEW_TAG}" | ||||
|  | ||||
|       - name: Print Chart.yaml | ||||
|         run: cat Chart.yaml | ||||
|  | ||||
|       # Using helm gpg plugin as 'helm package --sign' has issues with gpg2: https://github.com/helm/helm/issues/2843 | ||||
|       - name: package chart | ||||
|         run: | | ||||
|           echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | docker login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} --password-stdin | ||||
|           # FIXME: use upstream after https://github.com/technosophos/helm-gpg/issues/1 is solved | ||||
|           helm plugin install https://github.com/pat-s/helm-gpg | ||||
|           helm dependency build | ||||
|           helm package --version "${GITHUB_REF#refs/tags/v}" ./ | ||||
|           mkdir gitea | ||||
|           mv gitea*.tgz gitea/ | ||||
|           curl --fail --location --output gitea/index.yaml --silent --show-error https://dl.gitea.com/charts/index.yaml | ||||
|           helm repo index gitea/ --url https://dl.gitea.com/charts --merge gitea/index.yaml | ||||
|           # push to dockerhub | ||||
|           echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | helm registry login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} registry-1.docker.io --password-stdin | ||||
|           helm push gitea/gitea-${GITHUB_REF#refs/tags/v}.tgz oci://registry-1.docker.io/giteacharts | ||||
|           helm registry logout registry-1.docker.io | ||||
|  | ||||
|       - name: aws credential configure | ||||
|         uses: https://github.com/aws-actions/configure-aws-credentials@v5 | ||||
|         with: | ||||
|           aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | ||||
|           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||
|           aws-region: ${{ secrets.AWS_REGION }} | ||||
|  | ||||
|       - name: Copy files to S3 and clear cache | ||||
|         run: | | ||||
|           aws s3 sync gitea/ s3://${{ secrets.AWS_S3_BUCKET}}/charts/ | ||||
|  | ||||
|   release-gitea: | ||||
|     # needs: generate-chart-publish | ||||
|     needs: generate-chart-publish | ||||
|     runs-on: ubuntu-latest | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.1 | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.5 | ||||
|     steps: | ||||
|       - name: install tools | ||||
|         run: | | ||||
|           apk add -q --update --no-cache nodejs | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@v5 | ||||
|         with: | ||||
|           fetch-tags: true | ||||
|           fetch-depth: 0 | ||||
|   | ||||
| @@ -10,18 +10,18 @@ on: | ||||
|  | ||||
| env: | ||||
|   # renovate: datasource=github-releases depName=helm-unittest/helm-unittest | ||||
|   HELM_UNITTEST_VERSION: "v0.8.2" | ||||
|   HELM_UNITTEST_VERSION: "v1.0.3" | ||||
|  | ||||
| jobs: | ||||
|   check-and-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: alpine/helm:3.17.3 | ||||
|     container: alpine/helm:3.19.0 | ||||
|     steps: | ||||
|       - name: install tools | ||||
|         run: | | ||||
|           apk update | ||||
|           apk add --update bash make nodejs npm yamllint ncurses | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@v5 | ||||
|       - name: install chart dependencies | ||||
|         run: helm dependency build | ||||
|       - name: lint | ||||
|   | ||||
							
								
								
									
										2
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "yaml.schemas": { | ||||
|         "https://raw.githubusercontent.com/helm-unittest/helm-unittest/v0.8.2/schema/helm-testsuite.json": [ | ||||
|         "https://raw.githubusercontent.com/helm-unittest/helm-unittest/v1.0.3/schema/helm-testsuite.json": [ | ||||
|             "/unittests/**/*.yaml" | ||||
|         ] | ||||
|     }, | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| charts/* @justusbunsi @pat-s | ||||
| * @rossigee @volker.raschek @ChristopherHX | ||||
|   | ||||
							
								
								
									
										12
									
								
								Chart.lock
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								Chart.lock
									
									
									
									
									
								
							| @@ -1,15 +1,15 @@ | ||||
| dependencies: | ||||
| - name: postgresql | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 16.7.2 | ||||
|   version: 16.7.27 | ||||
| - name: postgresql-ha | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 16.0.3 | ||||
|   version: 16.3.2 | ||||
| - name: valkey-cluster | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 3.0.5 | ||||
|   version: 3.0.24 | ||||
| - name: valkey | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 3.0.4 | ||||
| digest: sha256:9f184e842e4e04f7a1a3791ed92ab2ce085c4cf8f9dc9ce9a70b45b8af4c3c3c | ||||
| generated: "2025-05-10T03:23:40.55670864Z" | ||||
|   version: 3.0.31 | ||||
| digest: sha256:ceb6a1890cfdc2627abb85d3e2a4baa64d30afd21dcfabce978a824a67f0a2bb | ||||
| generated: "2025-08-30T00:03:04.59764502Z" | ||||
|   | ||||
							
								
								
									
										41
									
								
								Chart.yaml
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								Chart.yaml
									
									
									
									
									
								
							| @@ -4,9 +4,14 @@ description: Gitea Helm chart for Kubernetes | ||||
| type: application | ||||
| version: 0.0.0 | ||||
| # renovate datasource=github-releases depName=go-gitea/gitea extractVersion=^v(?<version>.*)$ | ||||
| appVersion: 1.23.8 | ||||
| appVersion: 1.24.6 | ||||
| icon: https://gitea.com/assets/img/logo.svg | ||||
|  | ||||
| annotations: | ||||
|   artifacthub.io/links: | | ||||
|     - name: support | ||||
|       url: https://gitea.com/gitea/helm-gitea/issues | ||||
|  | ||||
| keywords: | ||||
|   - git | ||||
|   - issue tracker | ||||
| @@ -14,42 +19,44 @@ keywords: | ||||
|   - wiki | ||||
|   - gitea | ||||
|   - gogs | ||||
|  | ||||
| sources: | ||||
|   - https://gitea.com/gitea/helm-gitea | ||||
|   - https://github.com/go-gitea/gitea | ||||
|   - https://docker.gitea.com/gitea | ||||
|  | ||||
| maintainers: | ||||
|   - name: Charlie Drage | ||||
|     email: charlie@charliedrage.com | ||||
|   - name: Gitea Authors | ||||
|     email: maintainers@gitea.io | ||||
|   - name: Konrad Lother | ||||
|     email: konrad.lother@novum-rgi.de | ||||
|   - name: Lucas Hahn | ||||
|     email: lucas.hahn@novum-rgi.de | ||||
|   - name: Steven Kriegler | ||||
|     email: sk.bunsenbrenner@gmail.com | ||||
|   - name: Patrick Schratz | ||||
|     email: patrick.schratz@gmail.com | ||||
|   # https://gitea.com/rossigee | ||||
|   - name: Ross Golder | ||||
|     email: ross@golder.org | ||||
|   # https://gitea.com/volker.raschek | ||||
|   - name: Markus Pesch | ||||
|     email: markus.pesch+apps@cryptic.systems | ||||
|   # https://gitea.com/DaanSelen | ||||
|   - name: Daan Selen | ||||
|     email: dselen@nerthus.nl | ||||
|   # https://gitea.com/ChristopherHX | ||||
|   - name: Christopher Homberger | ||||
|     email: christopher.homberger@web.de | ||||
|  | ||||
| dependencies: | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/postgresql | ||||
|   - name: postgresql | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 16.7.2 | ||||
|     version: 16.7.27 | ||||
|     condition: postgresql.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/postgresql-ha/Chart.yaml | ||||
|   - name: postgresql-ha | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 16.0.3 | ||||
|     version: 16.3.2 | ||||
|     condition: postgresql-ha.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/valkey-cluster/Chart.yaml | ||||
|   - name: valkey-cluster | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 3.0.5 | ||||
|     version: 3.0.24 | ||||
|     condition: valkey-cluster.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/valkey/Chart.yaml | ||||
|   - name: valkey | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 3.0.4 | ||||
|     version: 3.0.31 | ||||
|     condition: valkey.enabled | ||||
|   | ||||
							
								
								
									
										127
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										127
									
								
								README.md
									
									
									
									
									
								
							| @@ -33,6 +33,7 @@ | ||||
| - [Metrics and profiling](#metrics-and-profiling) | ||||
|   - [Secure Metrics Endpoint](#secure-metrics-endpoint) | ||||
| - [Pod annotations](#pod-annotations) | ||||
| - [TLS certificate rotation](#tls-certificate-rotation) | ||||
| - [Themes](#themes) | ||||
| - [Renovate](#renovate) | ||||
| - [Parameters](#parameters) | ||||
| @@ -101,8 +102,8 @@ These dependencies are enabled by default: | ||||
|  | ||||
| Alternatively, the following non-HA replacements are available: | ||||
|  | ||||
| - PostgreSQL ([Bitnami PostgreSQL](<Postgresql](https://github.com/bitnami/charts/blob/main/bitnami/postgresql/Chart.yaml)>)) | ||||
| - Valkey ([Bitnami Valkey](<Valkey](https://github.com/bitnami/charts/blob/main/bitnami/valkey/Chart.yaml)>)) | ||||
| - PostgreSQL ([Bitnami PostgreSQL](https://github.com/bitnami/charts/blob/main/bitnami/postgresql/Chart.yaml)) | ||||
| - Valkey ([Bitnami Valkey](https://github.com/bitnami/charts/blob/main/bitnami/valkey/Chart.yaml)) | ||||
|  | ||||
| ### Dependency Versioning | ||||
|  | ||||
| @@ -166,7 +167,7 @@ available. As this is a Golang application, this can be implemented using `GOMAX | ||||
| of defining `GOMAXPROCS` automatically based on the defined CPU limit like `1000m`. Please keep in mind, that the CFS | ||||
| rate of `100ms` - default on each kubernetes node, is also very important to avoid CPU throttling. | ||||
|  | ||||
| Further information about this topic can be found [here](https://kanishk.io/posts/cpu-throttling-in-containerized-go-apps/). | ||||
| Further information about this topic can be found [under this link](https://kanishk.io/posts/cpu-throttling-in-containerized-go-apps/). | ||||
|  | ||||
| > [!NOTE] | ||||
| > The environment variable `GOMAXPROCS` is set automatically, when a CPU limit is defined. An explicit configuration is | ||||
| @@ -533,7 +534,7 @@ and the repository exists. | ||||
| ``` | ||||
|  | ||||
| To solve this problem add the capability `SYS_CHROOT` to the `securityContext`. | ||||
| More about this issue [here](https://gitea.com/gitea/helm-gitea/issues/161). | ||||
| More about this issue [under this link](https://gitea.com/gitea/helm-gitea/issues/161). | ||||
|  | ||||
| ### Cache | ||||
|  | ||||
| @@ -693,7 +694,7 @@ Affected options: | ||||
|  | ||||
| Like the admin user, OAuth2 settings can be updated and disabled but not deleted. | ||||
| Deleting OAuth2 settings has to be done in the ui. | ||||
| All OAuth2 values, which are documented [here](https://docs.gitea.com/administration/command-line#admin), are | ||||
| All OAuth2 values, which are documented [under this link](https://docs.gitea.com/administration/command-line#admin), are | ||||
| available. | ||||
|  | ||||
| Multiple OAuth2 sources can be configured with additional OAuth list items. | ||||
| @@ -816,6 +817,31 @@ gitea: | ||||
|   podAnnotations: {} | ||||
| ``` | ||||
|  | ||||
| ## TLS certificate rotation | ||||
|  | ||||
| If Gitea uses TLS certificates that are mounted as a secret in the container file system, Gitea will not automatically apply them when the TLS certificates are rotated. | ||||
| Such a rotation can be for example triggered, when the cert-manager issues new TLS certificates before expiring. Further information is described as GitHub | ||||
| [issue](https://github.com/go-gitea/gitea/issues/27962). | ||||
|  | ||||
| Until the issue is present, a workaround can be applied. | ||||
| For example stakater's [reloader](https://github.com/stakater/Reloader) controller can be used to trigger a rolling update. | ||||
| The following annotation must be added to instruct the reloader controller to trigger a rolling update, when the mounted `configMaps` and `secrets` have been changed. | ||||
|  | ||||
| ```yaml | ||||
| deployment: | ||||
|   annotations: | ||||
|     reloader.stakater.com/auto: "true" | ||||
| ``` | ||||
|  | ||||
| Instead of triggering a rolling update for configMap and secret resources, this action can also be defined for individual items. | ||||
| For example, when the secret named `gitea-tls` is mounted and the reloader controller should only listen for changes of this secret: | ||||
|  | ||||
| ```yaml | ||||
| deployment: | ||||
|   annotations: | ||||
|     secret.reloader.stakater.com/reload: "gitea-tls" | ||||
| ``` | ||||
|  | ||||
| ## Themes | ||||
|  | ||||
| Custom themes can be added via k8s secrets and referencing them in `values.yaml`. | ||||
| @@ -1044,6 +1070,8 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
| | `persistence.subPath`                             | Subdirectory of the volume to mount at                                                                | `nil`                  | | ||||
| | `persistence.volumeName`                          | Name of persistent volume in PVC                                                                      | `""`                   | | ||||
| | `extraContainers`                                 | Additional sidecar containers to run in the pod                                                       | `[]`                   | | ||||
| | `preExtraInitContainers`                          | Additional init containers to run in the pod before Gitea runs it owns init containers.               | `[]`                   | | ||||
| | `postExtraInitContainers`                         | Additional init containers to run in the pod after Gitea runs it owns init containers.                | `[]`                   | | ||||
| | `extraVolumes`                                    | Additional volumes to mount to the Gitea deployment                                                   | `[]`                   | | ||||
| | `extraContainerVolumeMounts`                      | Mounts that are only mapped into the Gitea runtime/main container, to e.g. override custom templates. | `[]`                   | | ||||
| | `extraInitVolumeMounts`                           | Mounts that are only mapped into the init-containers. Can be used for additional preconfiguration.    | `[]`                   | | ||||
| @@ -1134,52 +1162,69 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
|  | ||||
| Valkey cluster and [Valkey](#valkey) cannot be enabled at the same time. | ||||
|  | ||||
| | Name                                  | Description                                                          | Value   | | ||||
| | ------------------------------------- | -------------------------------------------------------------------- | ------- | | ||||
| | `valkey-cluster.enabled`              | Enable valkey cluster                                                | `true`  | | ||||
| | `valkey-cluster.usePassword`          | Whether to use password authentication                               | `false` | | ||||
| | `valkey-cluster.usePasswordFiles`     | Whether to mount passwords as files instead of environment variables | `false` | | ||||
| | `valkey-cluster.cluster.nodes`        | Number of valkey cluster master nodes                                | `3`     | | ||||
| | `valkey-cluster.cluster.replicas`     | Number of valkey cluster master node replicas                        | `0`     | | ||||
| | `valkey-cluster.service.ports.valkey` | Port of Valkey service                                               | `6379`  | | ||||
| | Name                                                | Description                                                           | Value                          | | ||||
| | --------------------------------------------------- | --------------------------------------------------------------------- | ------------------------------ | | ||||
| | `valkey-cluster.enabled`                            | Enable valkey cluster                                                 | `true`                         | | ||||
| | `valkey-cluster.usePassword`                        | Whether to use password authentication.                               | `false`                        | | ||||
| | `valkey-cluster.usePasswordFiles`                   | Whether to mount passwords as files instead of environment variables. | `false`                        | | ||||
| | `valkey-cluster.image.repository`                   | Image repository, eg. `bitnamilegacy/valkey-cluster`.                 | `bitnamilegacy/valkey-cluster` | | ||||
| | `valkey-cluster.cluster.nodes`                      | Number of valkey cluster master nodes                                 | `3`                            | | ||||
| | `valkey-cluster.cluster.replicas`                   | Number of valkey cluster master node replicas                         | `0`                            | | ||||
| | `valkey-cluster.metrics.image.repository`           | Image repository, eg. `bitnamilegacy/redis-exporter`.                 | `bitnamilegacy/redis-exporter` | | ||||
| | `valkey-cluster.service.ports.valkey`               | Port of Valkey service                                                | `6379`                         | | ||||
| | `valkey-cluster.sysctlImage.repository`             | Image repository, eg. `bitnamilegacy/os-shell`.                       | `bitnamilegacy/os-shell`       | | ||||
| | `valkey-cluster.volumePermissions.image.repository` | Image repository, eg. `bitnamilegacy/os-shell`.                       | `bitnamilegacy/os-shell`       | | ||||
|  | ||||
| ### valkey | ||||
|  | ||||
| Valkey and [Valkey cluster](#valkey-cluster) cannot be enabled at the same time. | ||||
|  | ||||
| | Name                                 | Description                                 | Value        | | ||||
| | ------------------------------------ | ------------------------------------------- | ------------ | | ||||
| | `valkey.enabled`                     | Enable valkey standalone or replicated      | `false`      | | ||||
| | `valkey.architecture`                | Whether to use standalone or replication    | `standalone` | | ||||
| | `valkey.global.valkey.password`      | Required password                           | `changeme`   | | ||||
| | `valkey.master.count`                | Number of Valkey master instances to deploy | `1`          | | ||||
| | `valkey.master.service.ports.valkey` | Port of Valkey service                      | `6379`       | | ||||
| | Name                                        | Description                                           | Value                           | | ||||
| | ------------------------------------------- | ----------------------------------------------------- | ------------------------------- | | ||||
| | `valkey.enabled`                            | Enable valkey standalone or replicated                | `false`                         | | ||||
| | `valkey.architecture`                       | Whether to use standalone or replication              | `standalone`                    | | ||||
| | `valkey.kubectl.image.repository`           | Image repository, eg. `bitnamilegacy/kubectl`.        | `bitnamilegacy/kubectl`         | | ||||
| | `valkey.image.repository`                   | Image repository, eg. `bitnamilegacy/valkey`.         | `bitnamilegacy/valkey`          | | ||||
| | `valkey.global.valkey.password`             | Required password                                     | `changeme`                      | | ||||
| | `valkey.master.count`                       | Number of Valkey master instances to deploy           | `1`                             | | ||||
| | `valkey.master.service.ports.valkey`        | Port of Valkey service                                | `6379`                          | | ||||
| | `valkey.metrics.image.repository`           | Image repository, eg. `bitnamilegacy/redis-exporter`. | `bitnamilegacy/redis-exporter`  | | ||||
| | `valkey.sentinel.image.repository`          | Image repository, eg. `bitnamilegacy/sentinel`.       | `bitnamilegacy/valkey-sentinel` | | ||||
| | `valkey.volumePermissions.image.repository` | Image repository, eg. `bitnamilegacy/os-shell`.       | `bitnamilegacy/os-shell`        | | ||||
|  | ||||
| ### PostgreSQL HA | ||||
|  | ||||
| | Name                                        | Description                                                      | Value       | | ||||
| | ------------------------------------------- | ---------------------------------------------------------------- | ----------- | | ||||
| | `postgresql-ha.enabled`                     | Enable PostgreSQL HA                                             | `true`      | | ||||
| | `postgresql-ha.postgresql.password`         | Password for the `gitea` user (overrides `auth.password`)        | `changeme4` | | ||||
| | `postgresql-ha.global.postgresql.database`  | Name for a custom database to create (overrides `auth.database`) | `gitea`     | | ||||
| | `postgresql-ha.global.postgresql.username`  | Name for a custom user to create (overrides `auth.username`)     | `gitea`     | | ||||
| | `postgresql-ha.global.postgresql.password`  | Name for a custom password to create (overrides `auth.password`) | `gitea`     | | ||||
| | `postgresql-ha.postgresql.repmgrPassword`   | Repmgr Password                                                  | `changeme2` | | ||||
| | `postgresql-ha.postgresql.postgresPassword` | postgres Password                                                | `changeme1` | | ||||
| | `postgresql-ha.pgpool.adminPassword`        | pgpool adminPassword                                             | `changeme3` | | ||||
| | `postgresql-ha.service.ports.postgresql`    | PostgreSQL service port (overrides `service.ports.postgresql`)   | `5432`      | | ||||
| | `postgresql-ha.persistence.size`            | PVC Storage Request for PostgreSQL HA volume                     | `10Gi`      | | ||||
| | Name                                               | Description                                                      | Value                             | | ||||
| | -------------------------------------------------- | ---------------------------------------------------------------- | --------------------------------- | | ||||
| | `postgresql-ha.enabled`                            | Enable PostgreSQL HA                                             | `true`                            | | ||||
| | `postgresql-ha.global.postgresql.database`         | Name for a custom database to create (overrides `auth.database`) | `gitea`                           | | ||||
| | `postgresql-ha.global.postgresql.username`         | Name for a custom user to create (overrides `auth.username`)     | `gitea`                           | | ||||
| | `postgresql-ha.global.postgresql.password`         | Name for a custom password to create (overrides `auth.password`) | `gitea`                           | | ||||
| | `postgresql-ha.metrics.image.repository`           | Image repository, eg. `bitnamilegacy/postgres-exporter`.         | `bitnamilegacy/postgres-exporter` | | ||||
| | `postgresql-ha.postgresql.image.repository`        | Image repository, eg. `bitnamilegacy/postgresql-repmgr`.         | `bitnamilegacy/postgresql-repmgr` | | ||||
| | `postgresql-ha.postgresql.repmgrPassword`          | Repmgr Password                                                  | `changeme2`                       | | ||||
| | `postgresql-ha.postgresql.postgresPassword`        | postgres Password                                                | `changeme1`                       | | ||||
| | `postgresql-ha.postgresql.password`                | Password for the `gitea` user (overrides `auth.password`)        | `changeme4`                       | | ||||
| | `postgresql-ha.pgpool.adminPassword`               | pgpool adminPassword                                             | `changeme3`                       | | ||||
| | `postgresql-ha.pgpool.image.repository`            | Image repository, eg. `bitnamilegacy/pgpool`.                    | `bitnamilegacy/pgpool`            | | ||||
| | `postgresql-ha.pgpool.srCheckPassword`             | pgpool srCheckPassword                                           | `changeme4`                       | | ||||
| | `postgresql-ha.service.ports.postgresql`           | PostgreSQL service port (overrides `service.ports.postgresql`)   | `5432`                            | | ||||
| | `postgresql-ha.persistence.size`                   | PVC Storage Request for PostgreSQL HA volume                     | `10Gi`                            | | ||||
| | `postgresql-ha.volumePermissions.image.repository` | Image repository, eg. `bitnamilegacy/os-shell`.                  | `bitnamilegacy/os-shell`          | | ||||
|  | ||||
| ### PostgreSQL | ||||
|  | ||||
| | Name                                                    | Description                                                      | Value   | | ||||
| | ------------------------------------------------------- | ---------------------------------------------------------------- | ------- | | ||||
| | `postgresql.enabled`                                    | Enable PostgreSQL                                                | `false` | | ||||
| | `postgresql.global.postgresql.auth.password`            | Password for the `gitea` user (overrides `auth.password`)        | `gitea` | | ||||
| | `postgresql.global.postgresql.auth.database`            | Name for a custom database to create (overrides `auth.database`) | `gitea` | | ||||
| | `postgresql.global.postgresql.auth.username`            | Name for a custom user to create (overrides `auth.username`)     | `gitea` | | ||||
| | `postgresql.global.postgresql.service.ports.postgresql` | PostgreSQL service port (overrides `service.ports.postgresql`)   | `5432`  | | ||||
| | `postgresql.primary.persistence.size`                   | PVC Storage Request for PostgreSQL volume                        | `10Gi`  | | ||||
| | Name                                                    | Description                                                      | Value                             | | ||||
| | ------------------------------------------------------- | ---------------------------------------------------------------- | --------------------------------- | | ||||
| | `postgresql.enabled`                                    | Enable PostgreSQL                                                | `false`                           | | ||||
| | `postgresql.global.postgresql.auth.password`            | Password for the `gitea` user (overrides `auth.password`)        | `gitea`                           | | ||||
| | `postgresql.global.postgresql.auth.database`            | Name for a custom database to create (overrides `auth.database`) | `gitea`                           | | ||||
| | `postgresql.global.postgresql.auth.username`            | Name for a custom user to create (overrides `auth.username`)     | `gitea`                           | | ||||
| | `postgresql.global.postgresql.service.ports.postgresql` | PostgreSQL service port (overrides `service.ports.postgresql`)   | `5432`                            | | ||||
| | `postgresql.image.repository`                           | Image repository, eg. `bitnamilegacy/postgresql`.                | `bitnamilegacy/postgresql`        | | ||||
| | `postgresql.primary.persistence.size`                   | PVC Storage Request for PostgreSQL volume                        | `10Gi`                            | | ||||
| | `postgresql.metrics.image.repository`                   | Image repository, eg. `bitnamilegacy/postgres-exporter`.         | `bitnamilegacy/postgres-exporter` | | ||||
| | `postgresql.volumePermissions.image.repository`         | Image repository, eg. `bitnamilegacy/os-shell`.                  | `bitnamilegacy/os-shell`          | | ||||
|  | ||||
| ### Advanced | ||||
|  | ||||
| @@ -1216,7 +1261,7 @@ If you miss this, blindly upgrading may delete your Postgres instance and you ma | ||||
|   To deploy and use "Actions", please see the new dedicated chart at <https://gitea.com/gitea/helm-actions>. | ||||
|   It is maintained by a seperate maintainer group and hasn't seen a release yet (at the time of the 12.0 release). | ||||
|   Feel encouraged to contribute if "Actions" is important to you! | ||||
|    | ||||
|  | ||||
|   This change was made to avoid overloading the existing helm chart, which is already quite large in size and configuration options. | ||||
|   In addition, the existing maintainers team was not actively using "Actions" which slowed down development and community contributions. | ||||
|   While the new chart is still young (and waiting for contributions! and maintainers), we believe that it is the best way moving forward for both parts. | ||||
|   | ||||
							
								
								
									
										413
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										413
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -8,7 +8,7 @@ | ||||
|       "license": "MIT", | ||||
|       "devDependencies": { | ||||
|         "@bitnami/readme-generator-for-helm": "^2.5.0", | ||||
|         "markdownlint-cli": "^0.44.0" | ||||
|         "markdownlint-cli": "^0.45.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=16.0.0", | ||||
| @@ -16,9 +16,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@bitnami/readme-generator-for-helm": { | ||||
|       "version": "2.7.0", | ||||
|       "resolved": "https://registry.npmjs.org/@bitnami/readme-generator-for-helm/-/readme-generator-for-helm-2.7.0.tgz", | ||||
|       "integrity": "sha512-fVxExmcuJ9NZb9ZE9OW3+lG8pUlXJAJdaO8UukV3A7WzYu4qOTr03MXPH9Gt5e/6mo3x4WYI/cXBksKfS0qn3w==", | ||||
|       "version": "2.7.2", | ||||
|       "resolved": "https://registry.npmjs.org/@bitnami/readme-generator-for-helm/-/readme-generator-for-helm-2.7.2.tgz", | ||||
|       "integrity": "sha512-7eXyJzxQTQj2ajpHlIhadciCCYWOqN8ieaweU25bStHOZowQ2c2CQyjO/bX4gxIf73LoRKxHhEYgLTllJY9SIw==", | ||||
|       "dev": true, | ||||
|       "license": "Apache-2.0", | ||||
|       "dependencies": { | ||||
| @@ -32,11 +32,35 @@ | ||||
|         "readme-generator": "bin/index.js" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@isaacs/balanced-match": { | ||||
|       "version": "4.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/@isaacs/balanced-match/-/balanced-match-4.0.1.tgz", | ||||
|       "integrity": "sha512-yzMTt9lEb8Gv7zRioUilSglI0c0smZ9k5D65677DLWLtWJaXIS3CqcGyUFByYKlnUj6TkjLVs54fBl6+TiGQDQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@isaacs/brace-expansion": { | ||||
|       "version": "5.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/@isaacs/brace-expansion/-/brace-expansion-5.0.0.tgz", | ||||
|       "integrity": "sha512-ZT55BDLV0yv0RBm2czMiZ+SqCGO7AvmOM3G/w2xhVPH+te0aKgFjmBvGlL1dH+ql2tgGO3MVrbb3jCKyvpgnxA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "@isaacs/balanced-match": "^4.0.1" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@isaacs/cliui": { | ||||
|       "version": "8.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", | ||||
|       "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "string-width": "^5.1.2", | ||||
|         "string-width-cjs": "npm:string-width@^4.2.0", | ||||
| @@ -49,17 +73,6 @@ | ||||
|         "node": ">=12" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@pkgjs/parseargs": { | ||||
|       "version": "0.11.0", | ||||
|       "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", | ||||
|       "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "optional": true, | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/@types/debug": { | ||||
|       "version": "4.1.12", | ||||
|       "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.12.tgz", | ||||
| @@ -92,10 +105,11 @@ | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/ansi-regex": { | ||||
|       "version": "6.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", | ||||
|       "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", | ||||
|       "version": "6.2.2", | ||||
|       "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", | ||||
|       "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       }, | ||||
| @@ -104,10 +118,11 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/ansi-styles": { | ||||
|       "version": "6.2.1", | ||||
|       "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", | ||||
|       "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", | ||||
|       "version": "6.2.3", | ||||
|       "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", | ||||
|       "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=12" | ||||
|       }, | ||||
| @@ -119,19 +134,22 @@ | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", | ||||
|       "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "Python-2.0" | ||||
|     }, | ||||
|     "node_modules/balanced-match": { | ||||
|       "version": "1.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", | ||||
|       "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/brace-expansion": { | ||||
|       "version": "1.1.11", | ||||
|       "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", | ||||
|       "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", | ||||
|       "version": "1.1.12", | ||||
|       "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz", | ||||
|       "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "balanced-match": "^1.0.0", | ||||
|         "concat-map": "0.0.1" | ||||
| @@ -175,6 +193,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", | ||||
|       "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "color-name": "~1.1.4" | ||||
|       }, | ||||
| @@ -186,7 +205,8 @@ | ||||
|       "version": "1.1.4", | ||||
|       "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", | ||||
|       "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/commander": { | ||||
|       "version": "13.1.0", | ||||
| @@ -202,13 +222,15 @@ | ||||
|       "version": "0.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", | ||||
|       "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/cross-spawn": { | ||||
|       "version": "7.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", | ||||
|       "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", | ||||
|       "version": "7.0.6", | ||||
|       "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", | ||||
|       "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "path-key": "^3.1.0", | ||||
|         "shebang-command": "^2.0.0", | ||||
| @@ -219,9 +241,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/debug": { | ||||
|       "version": "4.4.0", | ||||
|       "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", | ||||
|       "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", | ||||
|       "version": "4.4.3", | ||||
|       "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", | ||||
|       "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
| @@ -237,9 +259,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/decode-named-character-reference": { | ||||
|       "version": "1.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/decode-named-character-reference/-/decode-named-character-reference-1.0.2.tgz", | ||||
|       "integrity": "sha512-O8x12RzrUF8xyVcY0KJowWsmaJxQbmy0/EtnNtHRpsOcT7dFk5W598coHqBVpmWo1oQQfsCqfCmkZN5DJrZVdg==", | ||||
|       "version": "1.2.0", | ||||
|       "resolved": "https://registry.npmjs.org/decode-named-character-reference/-/decode-named-character-reference-1.2.0.tgz", | ||||
|       "integrity": "sha512-c6fcElNV6ShtZXmsgNgFFV5tVX2PaV4g+MOAkb8eXHvn6sryJBrZa9r0zV6+dtTyoCKxtDy5tyQ5ZwQuidtd+Q==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
| @@ -255,6 +277,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", | ||||
|       "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=4.0.0" | ||||
|       } | ||||
| @@ -311,19 +334,22 @@ | ||||
|       "version": "0.2.0", | ||||
|       "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", | ||||
|       "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/emoji-regex": { | ||||
|       "version": "9.2.2", | ||||
|       "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", | ||||
|       "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/entities": { | ||||
|       "version": "4.5.0", | ||||
|       "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", | ||||
|       "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", | ||||
|       "dev": true, | ||||
|       "license": "BSD-2-Clause", | ||||
|       "engines": { | ||||
|         "node": ">=0.12" | ||||
|       }, | ||||
| @@ -332,12 +358,13 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/foreground-child": { | ||||
|       "version": "3.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz", | ||||
|       "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==", | ||||
|       "version": "3.3.1", | ||||
|       "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.1.tgz", | ||||
|       "integrity": "sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "cross-spawn": "^7.0.0", | ||||
|         "cross-spawn": "^7.0.6", | ||||
|         "signal-exit": "^4.0.1" | ||||
|       }, | ||||
|       "engines": { | ||||
| @@ -351,13 +378,16 @@ | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", | ||||
|       "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "ISC" | ||||
|     }, | ||||
|     "node_modules/glob": { | ||||
|       "version": "7.2.3", | ||||
|       "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", | ||||
|       "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", | ||||
|       "deprecated": "Glob versions prior to v9 are no longer supported", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "fs.realpath": "^1.0.0", | ||||
|         "inflight": "^1.0.4", | ||||
| @@ -374,9 +404,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/ignore": { | ||||
|       "version": "7.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/ignore/-/ignore-7.0.3.tgz", | ||||
|       "integrity": "sha512-bAH5jbK/F3T3Jls4I0SO1hmPR0dKU0a7+SY6n1yzRtG54FLO8d6w/nxLFX2Nb7dBu6cCWXPaAME6cYqFUMmuCA==", | ||||
|       "version": "7.0.5", | ||||
|       "resolved": "https://registry.npmjs.org/ignore/-/ignore-7.0.5.tgz", | ||||
|       "integrity": "sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
| @@ -387,7 +417,9 @@ | ||||
|       "version": "1.0.6", | ||||
|       "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", | ||||
|       "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", | ||||
|       "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "once": "^1.3.0", | ||||
|         "wrappy": "1" | ||||
| @@ -397,13 +429,15 @@ | ||||
|       "version": "2.0.4", | ||||
|       "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", | ||||
|       "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "ISC" | ||||
|     }, | ||||
|     "node_modules/ini": { | ||||
|       "version": "4.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/ini/-/ini-4.1.1.tgz", | ||||
|       "integrity": "sha512-QQnnxNyfvmHFIsj7gkPcYymR8Jdw/o7mp5ZFihxn6h8Ci6fh3Dx4E1gPjpQEpIuPo9XVNY/ZUwh4BPMjGyL01g==", | ||||
|       "version": "4.1.3", | ||||
|       "resolved": "https://registry.npmjs.org/ini/-/ini-4.1.3.tgz", | ||||
|       "integrity": "sha512-X7rqawQBvfdjS10YU1y1YVreA3SsLrW9dX2CewP2EbBJM4ypVNLDkO5y04gejPwKIY9lR+7r9gn3rFPt/kmWFg==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "engines": { | ||||
|         "node": "^14.17.0 || ^16.13.0 || >=18.0.0" | ||||
|       } | ||||
| @@ -450,6 +484,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", | ||||
|       "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
| @@ -469,13 +504,31 @@ | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", | ||||
|       "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "ISC" | ||||
|     }, | ||||
|     "node_modules/jackspeak": { | ||||
|       "version": "4.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-4.1.1.tgz", | ||||
|       "integrity": "sha512-zptv57P3GpL+O0I7VdMJNBZCu+BPHVQUk55Ft8/QCJjTVxrnJHuVuX/0Bl2A6/+2oyR/ZMEuFKwmzqqZ/U5nPQ==", | ||||
|       "dev": true, | ||||
|       "license": "BlueOak-1.0.0", | ||||
|       "dependencies": { | ||||
|         "@isaacs/cliui": "^8.0.2" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/js-yaml": { | ||||
|       "version": "4.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", | ||||
|       "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "argparse": "^2.0.1" | ||||
|       }, | ||||
| @@ -495,14 +548,15 @@ | ||||
|       "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-5.0.1.tgz", | ||||
|       "integrity": "sha512-p/nXbhSEcu3pZRdkW1OfJhpsVtW1gd4Wa1fnQc9YLiTfAjn0312eMKimbdIQzuZl9aa9xUGaRlP9T/CJE/ditQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=0.10.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/katex": { | ||||
|       "version": "0.16.21", | ||||
|       "resolved": "https://registry.npmjs.org/katex/-/katex-0.16.21.tgz", | ||||
|       "integrity": "sha512-XvqR7FgOHtWupfMiigNzmh+MgUVmDGU2kXZm899ZkPfcuoPuFxyHmXsgATDpFZDAXCI8tvinaVcDo8PIIJSo4A==", | ||||
|       "version": "0.16.23", | ||||
|       "resolved": "https://registry.npmjs.org/katex/-/katex-0.16.23.tgz", | ||||
|       "integrity": "sha512-7VlC1hsEEolL9xNO05v9VjrvWZePkCVBJqj8ruICxYjZfHaHbaU53AlP+PODyFIXEnaEIEWi3wJy7FPZ95JAVg==", | ||||
|       "dev": true, | ||||
|       "funding": [ | ||||
|         "https://opencollective.com/katex", | ||||
| @@ -531,6 +585,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-5.0.0.tgz", | ||||
|       "integrity": "sha512-5aHCbzQRADcdP+ATqnDuhhJ/MRIqDkZX5pyjFHRRysS8vZ5AbqGEoFIb6pYHPZ+L/OC2Lc+xT8uHVVR5CAK/wQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "uc.micro": "^2.0.0" | ||||
|       } | ||||
| @@ -539,13 +594,25 @@ | ||||
|       "version": "4.17.21", | ||||
|       "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", | ||||
|       "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/lru-cache": { | ||||
|       "version": "11.2.2", | ||||
|       "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-11.2.2.tgz", | ||||
|       "integrity": "sha512-F9ODfyqML2coTIsQpSkRHnLSZMtkU8Q+mSfcaIyKwy58u+8k5nvAYeiNhsyMARvzNcXJ9QfWVrcPsC9e9rAxtg==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdown-it": { | ||||
|       "version": "14.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-14.1.0.tgz", | ||||
|       "integrity": "sha512-a54IwgWPaeBCAAsv13YgmALOF1elABB08FxO9i+r4VFk5Vl4pKokRPeX8u5TCgSsPi6ec1otfLjdOpVcgbpshg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "argparse": "^2.0.1", | ||||
|         "entities": "^4.4.0", | ||||
| @@ -563,6 +630,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-2.0.0.tgz", | ||||
|       "integrity": "sha512-Ezda85ToJUBhM6WGaG6veasyym+Tbs3cMAw/ZhOPqXiYsr0jgocBV3j3nx+4lk47plLlIqjwuTm/ywVI+zjJ/A==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "repeat-string": "^1.0.0" | ||||
|       }, | ||||
| @@ -572,136 +640,89 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint": { | ||||
|       "version": "0.37.4", | ||||
|       "resolved": "https://registry.npmjs.org/markdownlint/-/markdownlint-0.37.4.tgz", | ||||
|       "integrity": "sha512-u00joA/syf3VhWh6/ybVFkib5Zpj2e5KB/cfCei8fkSRuums6nyisTWGqjTWIOFoFwuXoTBQQiqlB4qFKp8ncQ==", | ||||
|       "version": "0.38.0", | ||||
|       "resolved": "https://registry.npmjs.org/markdownlint/-/markdownlint-0.38.0.tgz", | ||||
|       "integrity": "sha512-xaSxkaU7wY/0852zGApM8LdlIfGCW8ETZ0Rr62IQtAnUMlMuifsg09vWJcNYeL4f0anvr8Vo4ZQar8jGpV0btQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "markdown-it": "14.1.0", | ||||
|         "micromark": "4.0.1", | ||||
|         "micromark-core-commonmark": "2.0.2", | ||||
|         "micromark-extension-directive": "3.0.2", | ||||
|         "micromark": "4.0.2", | ||||
|         "micromark-core-commonmark": "2.0.3", | ||||
|         "micromark-extension-directive": "4.0.0", | ||||
|         "micromark-extension-gfm-autolink-literal": "2.1.0", | ||||
|         "micromark-extension-gfm-footnote": "2.1.0", | ||||
|         "micromark-extension-gfm-table": "2.1.0", | ||||
|         "micromark-extension-gfm-table": "2.1.1", | ||||
|         "micromark-extension-math": "3.1.0", | ||||
|         "micromark-util-types": "2.0.1" | ||||
|         "micromark-util-types": "2.0.2" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=18" | ||||
|         "node": ">=20" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/DavidAnson" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli": { | ||||
|       "version": "0.44.0", | ||||
|       "resolved": "https://registry.npmjs.org/markdownlint-cli/-/markdownlint-cli-0.44.0.tgz", | ||||
|       "integrity": "sha512-ZJTAONlvF9NkrIBltCdW15DxN9UTbPiKMEqAh2EU2gwIFlrCMavyCEPPO121cqfYOrLUJWW8/XKWongstmmTeQ==", | ||||
|       "version": "0.45.0", | ||||
|       "resolved": "https://registry.npmjs.org/markdownlint-cli/-/markdownlint-cli-0.45.0.tgz", | ||||
|       "integrity": "sha512-GiWr7GfJLVfcopL3t3pLumXCYs8sgWppjIA1F/Cc3zIMgD3tmkpyZ1xkm1Tej8mw53B93JsDjgA3KOftuYcfOw==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "commander": "~13.1.0", | ||||
|         "glob": "~10.4.5", | ||||
|         "ignore": "~7.0.3", | ||||
|         "glob": "~11.0.2", | ||||
|         "ignore": "~7.0.4", | ||||
|         "js-yaml": "~4.1.0", | ||||
|         "jsonc-parser": "~3.3.1", | ||||
|         "jsonpointer": "~5.0.1", | ||||
|         "markdownlint": "~0.37.4", | ||||
|         "minimatch": "~9.0.5", | ||||
|         "markdown-it": "~14.1.0", | ||||
|         "markdownlint": "~0.38.0", | ||||
|         "minimatch": "~10.0.1", | ||||
|         "run-con": "~1.3.2", | ||||
|         "smol-toml": "~1.3.1" | ||||
|         "smol-toml": "~1.3.4" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "markdownlint": "markdownlint.js" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=18" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/brace-expansion": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", | ||||
|       "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "balanced-match": "^1.0.0" | ||||
|         "node": ">=20" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/glob": { | ||||
|       "version": "10.4.5", | ||||
|       "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", | ||||
|       "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", | ||||
|       "version": "11.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.3.tgz", | ||||
|       "integrity": "sha512-2Nim7dha1KVkaiF4q6Dj+ngPPMdfvLJEOpZk/jKiUAkqKebpGAWQXAq9z1xu9HKu5lWfqw/FASuccEjyznjPaA==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "foreground-child": "^3.1.0", | ||||
|         "jackspeak": "^3.1.2", | ||||
|         "minimatch": "^9.0.4", | ||||
|         "foreground-child": "^3.3.1", | ||||
|         "jackspeak": "^4.1.1", | ||||
|         "minimatch": "^10.0.3", | ||||
|         "minipass": "^7.1.2", | ||||
|         "package-json-from-dist": "^1.0.0", | ||||
|         "path-scurry": "^1.11.1" | ||||
|         "path-scurry": "^2.0.0" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "glob": "dist/esm/bin.mjs" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/jackspeak": { | ||||
|       "version": "3.4.3", | ||||
|       "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", | ||||
|       "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", | ||||
|       "dev": true, | ||||
|       "license": "BlueOak-1.0.0", | ||||
|       "dependencies": { | ||||
|         "@isaacs/cliui": "^8.0.2" | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       }, | ||||
|       "optionalDependencies": { | ||||
|         "@pkgjs/parseargs": "^0.11.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/lru-cache": { | ||||
|       "version": "10.4.3", | ||||
|       "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", | ||||
|       "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", | ||||
|       "dev": true, | ||||
|       "license": "ISC" | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/minimatch": { | ||||
|       "version": "9.0.5", | ||||
|       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", | ||||
|       "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", | ||||
|       "version": "10.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.3.tgz", | ||||
|       "integrity": "sha512-IPZ167aShDZZUMdRk66cyQAW3qr0WzbHkPdMYa8bzZhlHhO3jALbKdxcaak7W9FfT2rZNpQuUu4Od7ILEpXSaw==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "brace-expansion": "^2.0.1" | ||||
|         "@isaacs/brace-expansion": "^5.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=16 || 14 >=14.17" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/markdownlint-cli/node_modules/path-scurry": { | ||||
|       "version": "1.11.1", | ||||
|       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", | ||||
|       "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", | ||||
|       "dev": true, | ||||
|       "license": "BlueOak-1.0.0", | ||||
|       "dependencies": { | ||||
|         "lru-cache": "^10.2.0", | ||||
|         "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=16 || 14 >=14.18" | ||||
|         "node": "20 || >=22" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
| @@ -711,12 +732,13 @@ | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-2.0.0.tgz", | ||||
|       "integrity": "sha512-Lf+9+2r+Tdp5wXDXC4PcIBjTDtq4UKjCPMQhKIuzpJNW0b96kVqSwW0bT7FhRSfmAiFYgP+SCRvdrDozfh0U5w==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/micromark": { | ||||
|       "version": "4.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/micromark/-/micromark-4.0.1.tgz", | ||||
|       "integrity": "sha512-eBPdkcoCNvYcxQOAKAlceo5SNdzZWfF+FcSupREAzdAh9rRmE239CEQAiTwIgblwnoM8zzj35sZ5ZwvSEOF6Kw==", | ||||
|       "version": "4.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/micromark/-/micromark-4.0.2.tgz", | ||||
|       "integrity": "sha512-zpe98Q6kvavpCr1NPVSCMebCKfD7CA2NqZ+rykeNhONIJBpc1tFKt9hucLGwha3jNTNI8lHpctWJWoimVF4PfA==", | ||||
|       "dev": true, | ||||
|       "funding": [ | ||||
|         { | ||||
| @@ -750,9 +772,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/micromark-core-commonmark": { | ||||
|       "version": "2.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-2.0.2.tgz", | ||||
|       "integrity": "sha512-FKjQKbxd1cibWMM1P9N+H8TwlgGgSkWZMmfuVucLCHaYqeSvJ0hFeHsIa65pA2nYbes0f8LDHPMrd9X7Ujxg9w==", | ||||
|       "version": "2.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-2.0.3.tgz", | ||||
|       "integrity": "sha512-RDBrHEMSxVFLg6xvnXmb1Ayr2WzLAWjeSATAoxwKYJV94TeNavgoIdA0a9ytzDSVzBy2YKFK+emCPOEibLeCrg==", | ||||
|       "dev": true, | ||||
|       "funding": [ | ||||
|         { | ||||
| @@ -785,9 +807,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/micromark-extension-directive": { | ||||
|       "version": "3.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-extension-directive/-/micromark-extension-directive-3.0.2.tgz", | ||||
|       "integrity": "sha512-wjcXHgk+PPdmvR58Le9d7zQYWy+vKEU9Se44p2CrCDPiLr2FMyiT4Fyb5UFKFC66wGB3kPlgD7q3TnoqPS7SZA==", | ||||
|       "version": "4.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-extension-directive/-/micromark-extension-directive-4.0.0.tgz", | ||||
|       "integrity": "sha512-/C2nqVmXXmiseSSuCdItCMho7ybwwop6RrrRPk0KbOHW21JKoCldC+8rFOaundDoRBUWBnJJcxeA/Kvi34WQXg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
| @@ -843,9 +865,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/micromark-extension-gfm-table": { | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.1.0.tgz", | ||||
|       "integrity": "sha512-Ub2ncQv+fwD70/l4ou27b4YzfNaCJOvyX4HxXU15m7mpYY+rjuWzsLIPZHJL253Z643RpbcP1oeIJlQ/SKW67g==", | ||||
|       "version": "2.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.1.1.tgz", | ||||
|       "integrity": "sha512-t2OU/dXXioARrC6yWfJ4hqB7rct14e8f7m0cbI5hUmDyyIlwv5vEtooptH8INkbLzOatzKuVbQmAYcbWoyz6Dg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
| @@ -1193,9 +1215,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/micromark-util-subtokenize": { | ||||
|       "version": "2.0.4", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-2.0.4.tgz", | ||||
|       "integrity": "sha512-N6hXjrin2GTJDe3MVjf5FuXpm12PGm80BrUAeub9XFXca8JZbP+oIwY4LJSVwFUCL1IPm/WwSVUN7goFHmSGGQ==", | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-2.1.0.tgz", | ||||
|       "integrity": "sha512-XQLu552iSctvnEcgXw6+Sx75GflAPNED1qx7eBJ+wydBb2KCbRZe+NwvIEEMM83uml1+2WSXpBAcp9IUCgCYWA==", | ||||
|       "dev": true, | ||||
|       "funding": [ | ||||
|         { | ||||
| @@ -1233,9 +1255,9 @@ | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/micromark-util-types": { | ||||
|       "version": "2.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-2.0.1.tgz", | ||||
|       "integrity": "sha512-534m2WhVTddrcKVepwmVEVnUAmtrx9bfIjNoQHRqfnvdaHQiFytEhJoTgpWJvDEXCO5gLTQh3wYC1PgOJA4NSQ==", | ||||
|       "version": "2.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-2.0.2.tgz", | ||||
|       "integrity": "sha512-Yw0ECSpJoViF1qTU4DC6NwtC4aWGt1EkzaQB8KPPyCRR8z9TWeV0HbEFGTO+ZY1wB22zmxnJqhPyTpOVCpeHTA==", | ||||
|       "dev": true, | ||||
|       "funding": [ | ||||
|         { | ||||
| @@ -1254,6 +1276,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", | ||||
|       "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "brace-expansion": "^1.1.7" | ||||
|       }, | ||||
| @@ -1266,6 +1289,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", | ||||
|       "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/ljharb" | ||||
|       } | ||||
| @@ -1292,6 +1316,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", | ||||
|       "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "wrappy": "1" | ||||
|       } | ||||
| @@ -1328,6 +1353,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", | ||||
|       "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=0.10.0" | ||||
|       } | ||||
| @@ -1337,15 +1363,34 @@ | ||||
|       "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", | ||||
|       "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/path-scurry": { | ||||
|       "version": "2.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-2.0.0.tgz", | ||||
|       "integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==", | ||||
|       "dev": true, | ||||
|       "license": "BlueOak-1.0.0", | ||||
|       "dependencies": { | ||||
|         "lru-cache": "^11.0.0", | ||||
|         "minipass": "^7.1.2" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": "20 || >=22" | ||||
|       }, | ||||
|       "funding": { | ||||
|         "url": "https://github.com/sponsors/isaacs" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/punycode.js": { | ||||
|       "version": "2.3.1", | ||||
|       "resolved": "https://registry.npmjs.org/punycode.js/-/punycode.js-2.3.1.tgz", | ||||
|       "integrity": "sha512-uxFIHU0YlHYhDQtV4R9J6a52SLx28BCjT+4ieh7IGbgwVJWO+km431c4yRlREUAsAmt/uMjQUyQHNEPf0M39CA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=6" | ||||
|       } | ||||
| @@ -1355,6 +1400,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", | ||||
|       "integrity": "sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=0.10" | ||||
|       } | ||||
| @@ -1364,6 +1410,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/run-con/-/run-con-1.3.2.tgz", | ||||
|       "integrity": "sha512-CcfE+mYiTcKEzg0IqS08+efdnH0oJ3zV0wSUFBNrMHMuxCtXvBCLzCJHatwuXDcu/RlhjTziTo/a1ruQik6/Yg==", | ||||
|       "dev": true, | ||||
|       "license": "(BSD-2-Clause OR MIT OR Apache-2.0)", | ||||
|       "dependencies": { | ||||
|         "deep-extend": "^0.6.0", | ||||
|         "ini": "~4.1.0", | ||||
| @@ -1379,6 +1426,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", | ||||
|       "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "shebang-regex": "^3.0.0" | ||||
|       }, | ||||
| @@ -1391,15 +1439,17 @@ | ||||
|       "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", | ||||
|       "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/signal-exit": { | ||||
|       "version": "4.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.0.1.tgz", | ||||
|       "integrity": "sha512-uUWsN4aOxJAS8KOuf3QMyFtgm1pkb6I+KRZbRF/ghdf5T7sM+B1lLLzPDxswUjkmHyxQAVzEgG35E3NzDM9GVw==", | ||||
|       "version": "4.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", | ||||
|       "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "engines": { | ||||
|         "node": ">=14" | ||||
|       }, | ||||
| @@ -1408,9 +1458,9 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/smol-toml": { | ||||
|       "version": "1.3.1", | ||||
|       "resolved": "https://registry.npmjs.org/smol-toml/-/smol-toml-1.3.1.tgz", | ||||
|       "integrity": "sha512-tEYNll18pPKHroYSmLLrksq233j021G0giwW7P3D24jC54pQ5W5BXMsQ/Mvw1OJCmEYDgY+lrzT+3nNUtoNfXQ==", | ||||
|       "version": "1.3.4", | ||||
|       "resolved": "https://registry.npmjs.org/smol-toml/-/smol-toml-1.3.4.tgz", | ||||
|       "integrity": "sha512-UOPtVuYkzYGee0Bd2Szz8d2G3RfMfJ2t3qVdZUAozZyAk+a0Sxa+QKix0YCwjL/A1RR0ar44nCxaoN9FxdJGwA==", | ||||
|       "dev": true, | ||||
|       "license": "BSD-3-Clause", | ||||
|       "engines": { | ||||
| @@ -1425,6 +1475,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", | ||||
|       "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "eastasianwidth": "^0.2.0", | ||||
|         "emoji-regex": "^9.2.2", | ||||
| @@ -1443,6 +1494,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", | ||||
|       "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "emoji-regex": "^8.0.0", | ||||
|         "is-fullwidth-code-point": "^3.0.0", | ||||
| @@ -1457,6 +1509,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", | ||||
|       "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
| @@ -1465,13 +1518,15 @@ | ||||
|       "version": "8.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", | ||||
|       "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/string-width-cjs/node_modules/strip-ansi": { | ||||
|       "version": "6.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", | ||||
|       "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-regex": "^5.0.1" | ||||
|       }, | ||||
| @@ -1480,10 +1535,11 @@ | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/strip-ansi": { | ||||
|       "version": "7.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", | ||||
|       "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", | ||||
|       "version": "7.1.2", | ||||
|       "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", | ||||
|       "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-regex": "^6.0.1" | ||||
|       }, | ||||
| @@ -1500,6 +1556,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", | ||||
|       "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-regex": "^5.0.1" | ||||
|       }, | ||||
| @@ -1512,6 +1569,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", | ||||
|       "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
| @@ -1521,6 +1579,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", | ||||
|       "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       }, | ||||
| @@ -1532,13 +1591,15 @@ | ||||
|       "version": "2.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-2.1.0.tgz", | ||||
|       "integrity": "sha512-ARDJmphmdvUk6Glw7y9DQ2bFkKBHwQHLi2lsaH6PPmz/Ka9sFOBsBluozhDltWmnv9u/cF6Rt87znRTPV+yp/A==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/which": { | ||||
|       "version": "2.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", | ||||
|       "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "isexe": "^2.0.0" | ||||
|       }, | ||||
| @@ -1554,6 +1615,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", | ||||
|       "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-styles": "^6.1.0", | ||||
|         "string-width": "^5.0.1", | ||||
| @@ -1572,6 +1634,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", | ||||
|       "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-styles": "^4.0.0", | ||||
|         "string-width": "^4.1.0", | ||||
| @@ -1589,6 +1652,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", | ||||
|       "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "engines": { | ||||
|         "node": ">=8" | ||||
|       } | ||||
| @@ -1598,6 +1662,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", | ||||
|       "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "color-convert": "^2.0.1" | ||||
|       }, | ||||
| @@ -1612,13 +1677,15 @@ | ||||
|       "version": "8.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", | ||||
|       "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "MIT" | ||||
|     }, | ||||
|     "node_modules/wrap-ansi-cjs/node_modules/string-width": { | ||||
|       "version": "4.2.3", | ||||
|       "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", | ||||
|       "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "emoji-regex": "^8.0.0", | ||||
|         "is-fullwidth-code-point": "^3.0.0", | ||||
| @@ -1633,6 +1700,7 @@ | ||||
|       "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", | ||||
|       "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", | ||||
|       "dev": true, | ||||
|       "license": "MIT", | ||||
|       "dependencies": { | ||||
|         "ansi-regex": "^5.0.1" | ||||
|       }, | ||||
| @@ -1644,19 +1712,20 @@ | ||||
|       "version": "1.0.2", | ||||
|       "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", | ||||
|       "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", | ||||
|       "dev": true | ||||
|       "dev": true, | ||||
|       "license": "ISC" | ||||
|     }, | ||||
|     "node_modules/yaml": { | ||||
|       "version": "2.7.0", | ||||
|       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.7.0.tgz", | ||||
|       "integrity": "sha512-+hSoy/QHluxmC9kCIJyL/uyFmLmc+e5CFR5Wa+bpIhIj85LVb9ZH2nVnqrHoSvKogwODv0ClqZkmiSSaIH5LTA==", | ||||
|       "version": "2.8.1", | ||||
|       "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.8.1.tgz", | ||||
|       "integrity": "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw==", | ||||
|       "dev": true, | ||||
|       "license": "ISC", | ||||
|       "bin": { | ||||
|         "yaml": "bin.mjs" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">= 14" | ||||
|         "node": ">= 14.6" | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -14,6 +14,6 @@ | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@bitnami/readme-generator-for-helm": "^2.5.0", | ||||
|     "markdownlint-cli": "^0.44.0" | ||||
|     "markdownlint-cli": "^0.45.0" | ||||
|   } | ||||
| } | ||||
| @@ -49,6 +49,14 @@ | ||||
|       ], | ||||
|     }, | ||||
|   ], | ||||
|   lockFileMaintenance: { | ||||
|     "enabled": true, | ||||
|     "commitMessageAction": "update", | ||||
|     "commitMessageTopic": "lockfiles", | ||||
|     schedule: [ | ||||
|       'at any time', | ||||
|     ] | ||||
|   }, | ||||
|   packageRules: [ | ||||
|     { | ||||
|       groupName: 'subcharts (minor & patch)', | ||||
|   | ||||
| @@ -361,16 +361,18 @@ https | ||||
|   {{- if not .Values.gitea.config.server.SSH_PORT -}} | ||||
|     {{- $_ := set .Values.gitea.config.server "SSH_PORT" .Values.service.ssh.port -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "SSH_LISTEN_PORT") -}} | ||||
|     {{- if not .Values.image.rootless -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_PORT -}} | ||||
|     {{- else -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" "2222" -}} | ||||
|     {{- end -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "START_SSH_SERVER") -}} | ||||
|     {{- if .Values.image.rootless -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "START_SSH_SERVER" "true" -}} | ||||
|       {{- if not (hasKey .Values.gitea.config.server "SSH_LISTEN_PORT") -}} | ||||
|         {{- if not .Values.gitea.config.server.SSH_LISTEN_PORT -}} | ||||
|           {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_PORT -}} | ||||
|         {{- else -}} | ||||
|           {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_LISTEN_PORT -}} | ||||
|         {{- end -}} | ||||
|       {{- end -}} | ||||
|     {{- else -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "START_SSH_SERVER" "false" -}} | ||||
|     {{- end -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "APP_DATA_PATH") -}} | ||||
|   | ||||
| @@ -27,7 +27,7 @@ stringData: | ||||
|     {{- end }} | ||||
|      | ||||
|     {{- /* multiple replicas assertions */ -}} | ||||
|     {{- if gt .Values.replicaCount 1.0 -}} | ||||
|     {{- if gt (.Values.replicaCount | int) 1 -}} | ||||
|       {{- if .Values.gitea.config.cron -}} | ||||
|         {{- if .Values.gitea.config.cron.GIT_GC_REPOS -}} | ||||
|           {{- if eq .Values.gitea.config.cron.GIT_GC_REPOS.ENABLED true -}} | ||||
|   | ||||
| @@ -59,6 +59,9 @@ spec: | ||||
|       securityContext: | ||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} | ||||
|       initContainers: | ||||
|         {{- if .Values.preExtraInitContainers }} | ||||
|         {{- toYaml .Values.preExtraInitContainers | nindent 8 }} | ||||
|         {{- end }} | ||||
|         - name: init-directories | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
| @@ -98,7 +101,7 @@ spec: | ||||
|         - name: init-app-ini | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           command:  | ||||
|           command: | ||||
|           - "{{ .Values.initContainersScriptsVolumeMountPath }}/config_environment.sh" | ||||
|           env: | ||||
|             - name: GITEA_APP_INI | ||||
| @@ -143,7 +146,7 @@ spec: | ||||
|         {{- if .Values.signing.enabled }} | ||||
|         - name: configure-gpg | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           command:  | ||||
|           command: | ||||
|           - "{{ .Values.initContainersScriptsVolumeMountPath }}/configure_gpg_environment.sh" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           securityContext: | ||||
| @@ -272,6 +275,9 @@ spec: | ||||
|             {{- include "gitea.init-additional-mounts" . | nindent 12 }} | ||||
|           resources: | ||||
|             {{- toYaml .Values.initContainers.resources | nindent 12 }} | ||||
|         {{- if .Values.postExtraInitContainers }} | ||||
|         {{- toYaml .Values.postExtraInitContainers | nindent 8 }} | ||||
|         {{- end }} | ||||
|       terminationGracePeriodSeconds: {{ .Values.deployment.terminationGracePeriodSeconds }} | ||||
|       containers: | ||||
|         - name: {{ .Chart.Name }} | ||||
|   | ||||
| @@ -10,7 +10,7 @@ metadata: | ||||
| {{ .Values.persistence.labels | toYaml | indent 4}} | ||||
| spec: | ||||
|   accessModes: | ||||
|   {{- if gt .Values.replicaCount 1.0 }} | ||||
|   {{- if gt (.Values.replicaCount | int) 1 }} | ||||
|       - ReadWriteMany | ||||
|   {{- else }} | ||||
|     {{- .Values.persistence.accessModes | toYaml | nindent 4 }} | ||||
|   | ||||
 Submodule unittests/bash/bats updated: fed179f296...855844b834
									
								
							 Submodule unittests/bash/test_helper/bats-assert updated: b93143a1bf...3be0fb7856
									
								
							 Submodule unittests/bash/test_helper/bats-mock updated: 93e0128b87...9d8aa349f1
									
								
							 Submodule unittests/bash/test_helper/bats-support updated: d007fc1f45...0954abb992
									
								
							| @@ -18,6 +18,7 @@ set: | ||||
|       password: custom-password-overwritten-by-global-postgresql-password | ||||
|     pgpool: | ||||
|       adminPassword: custom-password-pgpool | ||||
|       srCheckPassword: custom-password-sr-check | ||||
|     service: | ||||
|       ports: | ||||
|         postgresql: 1234 | ||||
| @@ -75,6 +76,13 @@ tests: | ||||
|         equal: | ||||
|           path: data["admin-password"] | ||||
|           value: "Y3VzdG9tLXBhc3N3b3JkLXBncG9vbA==" | ||||
|   - it: "[postgresql-ha] pgpool.srCheckPassword is applied as expected" | ||||
|     template: charts/postgresql-ha/templates/pgpool/secrets.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: data["sr-check-password"] | ||||
|           value: "Y3VzdG9tLXBhc3N3b3JkLXNyLWNoZWNr" | ||||
|   - it: "[postgresql-ha] persistence.size is applied as expected" | ||||
|     template: charts/postgresql-ha/templates/postgresql/statefulset.yaml | ||||
|     asserts: | ||||
|   | ||||
| @@ -15,7 +15,7 @@ tests: | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/postgresql-repmgr:17.+$ | ||||
|           pattern: bitnamilegacy/postgresql-repmgr:17.+$ | ||||
|   - it: "[postgresql] ensures we detect major image version upgrades" | ||||
|     template: charts/postgresql/templates/primary/statefulset.yaml | ||||
|     set: | ||||
| @@ -28,7 +28,7 @@ tests: | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/postgresql:17.+$ | ||||
|           pattern: bitnamilegacy/postgresql:17.+$ | ||||
|   - it: "[valkey-cluster] ensures we detect major image version upgrades" | ||||
|     template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|     set: | ||||
| @@ -41,7 +41,7 @@ tests: | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/valkey-cluster:8.+$ | ||||
|           pattern: bitnamilegacy/valkey-cluster:8.+$ | ||||
|   - it: "[valkey] ensures we detect major image version upgrades" | ||||
|     template: charts/valkey/templates/primary/application.yaml | ||||
|     set: | ||||
| @@ -54,4 +54,4 @@ tests: | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/valkey:8.+$ | ||||
|           pattern: bitnamilegacy/valkey:8.+$ | ||||
|   | ||||
							
								
								
									
										59
									
								
								unittests/helm/deployment/extraInitContainers.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								unittests/helm/deployment/extraInitContainers.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| suite: deployment template | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
| tests: | ||||
|   - it: Render the deployment (default) | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 3 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|  | ||||
|   - it: Render the deployment (signing) | ||||
|     set: | ||||
|       signing.enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 4 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|  | ||||
|   - it: Render the deployment (extraInitContainers) | ||||
|     set: | ||||
|       postExtraInitContainers: | ||||
|         - name: foo | ||||
|           image: docker.io/library/busybox:latest | ||||
|       preExtraInitContainers: | ||||
|         - name: bar | ||||
|           image: docker.io/library/busybox:latest | ||||
|       signing.enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 6 | ||||
|         template: templates/gitea/deployment.yaml | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers | ||||
|           content: | ||||
|             name: foo | ||||
|             image: docker.io/library/busybox:latest | ||||
|         template: templates/gitea/deployment.yaml | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers | ||||
|           content: | ||||
|             name: bar | ||||
|             image: docker.io/library/busybox:latest | ||||
|         template: templates/gitea/deployment.yaml | ||||
							
								
								
									
										167
									
								
								values.yaml
									
									
									
									
									
								
							
							
						
						
									
										167
									
								
								values.yaml
									
									
									
									
									
								
							| @@ -279,7 +279,19 @@ persistence: | ||||
| extraContainers: [] | ||||
| #  - name: sidecar-bob | ||||
| #    image: busybox | ||||
| #    command: [/bin/sh, -c, 'echo "Hello world"; sleep 86400'] | ||||
| #    command: [/bin/sh, -c, 'echo "Hello world"'] | ||||
|  | ||||
| ## @param preExtraInitContainers Additional init containers to run in the pod before gitea runs it owns init containers. | ||||
| preExtraInitContainers: [] | ||||
| # - name: pre-init-container | ||||
| #   image: docker.io/library/busybox | ||||
| #   command: [ /bin/sh, -c, 'echo "Hello world! I am a pre init container."' ] | ||||
|  | ||||
| ## @param postExtraInitContainers Additional init containers to run in the pod after gitea runs it owns init containers. | ||||
| postExtraInitContainers: [] | ||||
| # - name: post-init-container | ||||
| #   image: docker.io/library/busybox | ||||
| #   command: [ /bin/sh, -c, 'echo "Hello world! I am a post init container."' ] | ||||
|  | ||||
| ## @param extraVolumes Additional volumes to mount to the Gitea deployment | ||||
| extraVolumes: [] | ||||
| @@ -502,92 +514,161 @@ gitea: | ||||
|     failureThreshold: 10 | ||||
|  | ||||
| ## @section valkey-cluster | ||||
| ## @param valkey-cluster.enabled Enable valkey cluster | ||||
| # ⚠️ The valkey charts do not work well with special characters in the password (<https://gitea.com/gitea/helm-chart/issues/690>). | ||||
| # Consider omitting such or open an issue in the Bitnami repo and let us know once this got fixed. | ||||
| ## @param valkey-cluster.usePassword Whether to use password authentication | ||||
| ## @param valkey-cluster.usePasswordFiles Whether to mount passwords as files instead of environment variables | ||||
| ## @param valkey-cluster.cluster.nodes Number of valkey cluster master nodes | ||||
| ## @param valkey-cluster.cluster.replicas Number of valkey cluster master node replicas | ||||
| ## @param valkey-cluster.service.ports.valkey Port of Valkey service | ||||
| ## @descriptionStart | ||||
| ## Valkey cluster and [Valkey](#valkey) cannot be enabled at the same time. | ||||
| ## @descriptionEnd | ||||
| valkey-cluster: | ||||
|   ## @param valkey-cluster.enabled Enable valkey cluster | ||||
|   # ⚠️ The valkey charts do not work well with special characters in the password (<https://gitea.com/gitea/helm-chart/issues/690>). | ||||
|   # Consider omitting such or open an issue in the Bitnami repo and let us know once this got fixed. | ||||
|   ## @param valkey-cluster.usePassword Whether to use password authentication. | ||||
|   ## @param valkey-cluster.usePasswordFiles Whether to mount passwords as files instead of environment variables. | ||||
|   enabled: true | ||||
|   usePassword: false | ||||
|   usePasswordFiles: false | ||||
|  | ||||
|   ## @param valkey-cluster.image.repository Image repository, eg. `bitnamilegacy/valkey-cluster`. | ||||
|   image: | ||||
|     repository: bitnamilegacy/valkey-cluster | ||||
|  | ||||
|   ## @param valkey-cluster.cluster.nodes Number of valkey cluster master nodes | ||||
|   ## @param valkey-cluster.cluster.replicas Number of valkey cluster master node replicas | ||||
|   cluster: | ||||
|     nodes: 3 # default: 6 | ||||
|     replicas: 0 # default: 1 | ||||
|  | ||||
|   ## @param valkey-cluster.metrics.image.repository Image repository, eg. `bitnamilegacy/redis-exporter`. | ||||
|   metrics: | ||||
|     image: | ||||
|       repository: bitnamilegacy/redis-exporter | ||||
|  | ||||
|   ## @param valkey-cluster.service.ports.valkey Port of Valkey service | ||||
|   service: | ||||
|     ports: | ||||
|       valkey: 6379 | ||||
|  | ||||
|   ## @param valkey-cluster.sysctlImage.repository Image repository, eg. `bitnamilegacy/os-shell`. | ||||
|   sysctlImage: | ||||
|     repository: bitnamilegacy/os-shell | ||||
|  | ||||
|   ## @param valkey-cluster.volumePermissions.image.repository Image repository, eg. `bitnamilegacy/os-shell`. | ||||
|   volumePermissions: | ||||
|     image: | ||||
|       repository: bitnamilegacy/os-shell | ||||
|  | ||||
|  | ||||
| ## @section valkey | ||||
| ## @param valkey.enabled Enable valkey standalone or replicated | ||||
| ## @param valkey.architecture Whether to use standalone or replication | ||||
| # ⚠️ The valkey charts do not work well with special characters in the password (<https://gitea.com/gitea/helm-chart/issues/690>). | ||||
| # Consider omitting such or open an issue in the Bitnami repo and let us know once this got fixed. | ||||
| ## @param valkey.global.valkey.password Required password | ||||
| ## @param valkey.master.count Number of Valkey master instances to deploy | ||||
| ## @param valkey.master.service.ports.valkey Port of Valkey service | ||||
|  | ||||
| ## @descriptionStart | ||||
| ## Valkey and [Valkey cluster](#valkey-cluster) cannot be enabled at the same time. | ||||
| ## @descriptionEnd | ||||
| valkey: | ||||
|   ## @param valkey.enabled Enable valkey standalone or replicated | ||||
|   ## @param valkey.architecture Whether to use standalone or replication | ||||
|   enabled: false | ||||
|   architecture: standalone | ||||
|  | ||||
|   ## @param valkey.kubectl.image.repository Image repository, eg. `bitnamilegacy/kubectl`. | ||||
|   kubectl: | ||||
|     image: | ||||
|       repository: bitnamilegacy/kubectl | ||||
|  | ||||
|   ## @param valkey.image.repository Image repository, eg. `bitnamilegacy/valkey`. | ||||
|   image: | ||||
|     repository: bitnamilegacy/valkey | ||||
|  | ||||
|   # ⚠️ The valkey charts do not work well with special characters in the password (<https://gitea.com/gitea/helm-chart/issues/690>). | ||||
|   # Consider omitting such or open an issue in the Bitnami repo and let us know once this got fixed. | ||||
|   ## @param valkey.global.valkey.password Required password | ||||
|   global: | ||||
|     valkey: | ||||
|       password: changeme | ||||
|  | ||||
|   ## @param valkey.master.count Number of Valkey master instances to deploy | ||||
|   ## @param valkey.master.service.ports.valkey Port of Valkey service | ||||
|   master: | ||||
|     count: 1 | ||||
|     service: | ||||
|       ports: | ||||
|         valkey: 6379 | ||||
|  | ||||
|   ## @param valkey.metrics.image.repository Image repository, eg. `bitnamilegacy/redis-exporter`. | ||||
|   metrics: | ||||
|     image: | ||||
|       repository: bitnamilegacy/redis-exporter | ||||
|  | ||||
|   ## @param valkey.sentinel.image.repository Image repository, eg. `bitnamilegacy/sentinel`. | ||||
|   sentinel: | ||||
|     image: | ||||
|       repository: bitnamilegacy/valkey-sentinel | ||||
|  | ||||
|   ## @param valkey.volumePermissions.image.repository Image repository, eg. `bitnamilegacy/os-shell`. | ||||
|   volumePermissions: | ||||
|     image: | ||||
|       repository: bitnamilegacy/os-shell | ||||
|  | ||||
| ## @section PostgreSQL HA | ||||
| # | ||||
| ## @param postgresql-ha.enabled Enable PostgreSQL HA | ||||
| ## @param postgresql-ha.postgresql.password Password for the `gitea` user (overrides `auth.password`) | ||||
| ## @param postgresql-ha.global.postgresql.database Name for a custom database to create (overrides `auth.database`) | ||||
| ## @param postgresql-ha.global.postgresql.username Name for a custom user to create (overrides `auth.username`) | ||||
| ## @param postgresql-ha.global.postgresql.password Name for a custom password to create (overrides `auth.password`) | ||||
| ## @param postgresql-ha.postgresql.repmgrPassword Repmgr Password | ||||
| ## @param postgresql-ha.postgresql.postgresPassword postgres Password | ||||
| ## @param postgresql-ha.pgpool.adminPassword pgpool adminPassword | ||||
| ## @param postgresql-ha.service.ports.postgresql PostgreSQL service port (overrides `service.ports.postgresql`) | ||||
| ## @param postgresql-ha.persistence.size PVC Storage Request for PostgreSQL HA volume | ||||
| postgresql-ha: | ||||
|   ## @param postgresql-ha.enabled Enable PostgreSQL HA | ||||
|   enabled: true | ||||
|  | ||||
|   ## @param postgresql-ha.global.postgresql.database Name for a custom database to create (overrides `auth.database`) | ||||
|   ## @param postgresql-ha.global.postgresql.username Name for a custom user to create (overrides `auth.username`) | ||||
|   ## @param postgresql-ha.global.postgresql.password Name for a custom password to create (overrides `auth.password`) | ||||
|   global: | ||||
|     postgresql: | ||||
|       database: gitea | ||||
|       password: gitea | ||||
|       username: gitea | ||||
|   enabled: true | ||||
|  | ||||
|   ## @param postgresql-ha.metrics.image.repository Image repository, eg. `bitnamilegacy/postgres-exporter`. | ||||
|   metrics: | ||||
|     image: | ||||
|       repository: bitnamilegacy/postgres-exporter | ||||
|  | ||||
|   ## @param postgresql-ha.postgresql.image.repository Image repository, eg. `bitnamilegacy/postgresql-repmgr`. | ||||
|   ## @param postgresql-ha.postgresql.repmgrPassword Repmgr Password | ||||
|   ## @param postgresql-ha.postgresql.postgresPassword postgres Password | ||||
|   ## @param postgresql-ha.postgresql.password Password for the `gitea` user (overrides `auth.password`) | ||||
|   postgresql: | ||||
|     image: | ||||
|       repository: bitnamilegacy/postgresql-repmgr | ||||
|     repmgrPassword: changeme2 | ||||
|     postgresPassword: changeme1 | ||||
|     password: changeme4 | ||||
|  | ||||
|   ## @param postgresql-ha.pgpool.adminPassword pgpool adminPassword | ||||
|   ## @param postgresql-ha.pgpool.image.repository Image repository, eg. `bitnamilegacy/pgpool`. | ||||
|   ## @param postgresql-ha.pgpool.srCheckPassword pgpool srCheckPassword | ||||
|   pgpool: | ||||
|     adminPassword: changeme3 | ||||
|     image: | ||||
|       repository: bitnamilegacy/pgpool | ||||
|     srCheckPassword: changeme4 | ||||
|  | ||||
|   ## @param postgresql-ha.service.ports.postgresql PostgreSQL service port (overrides `service.ports.postgresql`) | ||||
|   service: | ||||
|     ports: | ||||
|       postgresql: 5432 | ||||
|  | ||||
|   ## @param postgresql-ha.persistence.size PVC Storage Request for PostgreSQL HA volume | ||||
|   persistence: | ||||
|     size: 10Gi | ||||
|  | ||||
|   ## @param postgresql-ha.volumePermissions.image.repository Image repository, eg. `bitnamilegacy/os-shell`. | ||||
|   volumePermissions: | ||||
|     image: | ||||
|       repository: bitnamilegacy/os-shell | ||||
|  | ||||
| ## @section PostgreSQL | ||||
| # | ||||
| ## @param postgresql.enabled Enable PostgreSQL | ||||
| ## @param postgresql.global.postgresql.auth.password Password for the `gitea` user (overrides `auth.password`) | ||||
| ## @param postgresql.global.postgresql.auth.database Name for a custom database to create (overrides `auth.database`) | ||||
| ## @param postgresql.global.postgresql.auth.username Name for a custom user to create (overrides `auth.username`) | ||||
| ## @param postgresql.global.postgresql.service.ports.postgresql PostgreSQL service port (overrides `service.ports.postgresql`) | ||||
| ## @param postgresql.primary.persistence.size PVC Storage Request for PostgreSQL volume | ||||
| postgresql: | ||||
|   ## @param postgresql.enabled Enable PostgreSQL | ||||
|   enabled: false | ||||
|  | ||||
|   ## @param postgresql.global.postgresql.auth.password Password for the `gitea` user (overrides `auth.password`) | ||||
|   ## @param postgresql.global.postgresql.auth.database Name for a custom database to create (overrides `auth.database`) | ||||
|   ## @param postgresql.global.postgresql.auth.username Name for a custom user to create (overrides `auth.username`) | ||||
|   ## @param postgresql.global.postgresql.service.ports.postgresql PostgreSQL service port (overrides `service.ports.postgresql`) | ||||
|   global: | ||||
|     postgresql: | ||||
|       auth: | ||||
| @@ -597,10 +678,26 @@ postgresql: | ||||
|       service: | ||||
|         ports: | ||||
|           postgresql: 5432 | ||||
|  | ||||
|   ## @param postgresql.image.repository Image repository, eg. `bitnamilegacy/postgresql`. | ||||
|   image: | ||||
|     repository: bitnamilegacy/postgresql | ||||
|  | ||||
|   ## @param postgresql.primary.persistence.size PVC Storage Request for PostgreSQL volume | ||||
|   primary: | ||||
|     persistence: | ||||
|       size: 10Gi | ||||
|  | ||||
|   ## @param postgresql.metrics.image.repository Image repository, eg. `bitnamilegacy/postgres-exporter`. | ||||
|   metrics: | ||||
|     image: | ||||
|       repository: bitnamilegacy/postgres-exporter | ||||
|  | ||||
|   ## @param postgresql.volumePermissions.image.repository Image repository, eg. `bitnamilegacy/os-shell`. | ||||
|   volumePermissions: | ||||
|     image: | ||||
|       repository: bitnamilegacy/os-shell | ||||
|  | ||||
| # By default, removed or moved settings that still remain in a user defined values.yaml will cause Helm to fail running the install/update. | ||||
| # Set it to false to skip this basic validation check. | ||||
| ## @section Advanced | ||||
|   | ||||
		Reference in New Issue
	
	Block a user