mirror of
				https://github.com/community-scripts/ProxmoxVE.git
				synced 2025-11-04 10:22:50 +00:00 
			
		
		
		
	Compare commits
	
		
			91 Commits
		
	
	
		
			2025-01-01
			...
			2025-01-08
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					f428146c47 | ||
| 
						 | 
					0059adecf1 | ||
| 
						 | 
					e1daaa6409 | ||
| 
						 | 
					ff712bc36e | ||
| 
						 | 
					9330e9a640 | ||
| 
						 | 
					5fc783da67 | ||
| 
						 | 
					670d64ec43 | ||
| 
						 | 
					4da57bd76c | ||
| 
						 | 
					29b98b450b | ||
| 
						 | 
					c88d3a3883 | ||
| 
						 | 
					f5a54bc3ad | ||
| 
						 | 
					2078deca57 | ||
| 
						 | 
					bc702e2a6d | ||
| 
						 | 
					ab10013fbe | ||
| 
						 | 
					9abd8bf9aa | ||
| 
						 | 
					6a78564cc3 | ||
| 
						 | 
					0ec532a4e7 | ||
| 
						 | 
					d712be955c | ||
| 
						 | 
					701f7e9cba | ||
| 
						 | 
					5196539d1b | ||
| 
						 | 
					774cdcaf8d | ||
| 
						 | 
					784e109012 | ||
| 
						 | 
					5184f47eb6 | ||
| 
						 | 
					f7d37a8f3c | ||
| 
						 | 
					4888c33e4b | ||
| 
						 | 
					f98d81f5bf | ||
| 
						 | 
					d7518d8644 | ||
| 
						 | 
					599c462035 | ||
| 
						 | 
					0909132d5c | ||
| 
						 | 
					5123532729 | ||
| 
						 | 
					d814907f99 | ||
| 
						 | 
					32a99a44d4 | ||
| 
						 | 
					e94280f1a1 | ||
| 
						 | 
					b9ca4b7634 | ||
| 
						 | 
					8431931cc4 | ||
| 
						 | 
					8bf7f7a460 | ||
| 
						 | 
					6adf8e38b0 | ||
| 
						 | 
					817455360e | ||
| 
						 | 
					84d36eba84 | ||
| 
						 | 
					a0baf1cecc | ||
| 
						 | 
					144182d22c | ||
| 
						 | 
					81ffa34497 | ||
| 
						 | 
					abfd5e086d | ||
| 
						 | 
					0e84eba9d2 | ||
| 
						 | 
					d827d42968 | ||
| 
						 | 
					d3d6ec8b20 | ||
| 
						 | 
					314f932764 | ||
| 
						 | 
					e191b94151 | ||
| 
						 | 
					9cc4bda762 | ||
| 
						 | 
					32572c6072 | ||
| 
						 | 
					a1fe451fe2 | ||
| 
						 | 
					ba97af3b9f | ||
| 
						 | 
					859f3dffc3 | ||
| 
						 | 
					84b15641fb | ||
| 
						 | 
					a99bdb9e97 | ||
| 
						 | 
					6035469047 | ||
| 
						 | 
					982a19cf28 | ||
| 
						 | 
					e3299a67ec | ||
| 
						 | 
					6f557aa394 | ||
| 
						 | 
					38f4a98e4f | ||
| 
						 | 
					5967a7f496 | ||
| 
						 | 
					67cdc35d02 | ||
| 
						 | 
					71c04d9e12 | ||
| 
						 | 
					eee58b43db | ||
| 
						 | 
					8a35df4f59 | ||
| 
						 | 
					9fd4a13a8a | ||
| 
						 | 
					9f2ae06726 | ||
| 
						 | 
					a5adf44f39 | ||
| 
						 | 
					536de5d083 | ||
| 
						 | 
					dfa14693ee | ||
| 
						 | 
					b03e223e91 | ||
| 
						 | 
					036728df0d | ||
| 
						 | 
					682087c6ec | ||
| 
						 | 
					5338a6762a | ||
| 
						 | 
					3a52f8dbfb | ||
| 
						 | 
					8fd34ea277 | ||
| 
						 | 
					593669b960 | ||
| 
						 | 
					e165153dcb | ||
| 
						 | 
					ff8b060cad | ||
| 
						 | 
					6f51b0f5a2 | ||
| 
						 | 
					487f36fec6 | ||
| 
						 | 
					385b36d29e | ||
| 
						 | 
					3b8ff01385 | ||
| 
						 | 
					11de586c93 | ||
| 
						 | 
					eacaca938d | ||
| 
						 | 
					dc0cf2cb3b | ||
| 
						 | 
					585f9a2404 | ||
| 
						 | 
					c72eb13e74 | ||
| 
						 | 
					e356259785 | ||
| 
						 | 
					618445ec08 | ||
| 
						 | 
					3e5274a951 | 
							
								
								
									
										54
									
								
								.github/check-script.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										54
									
								
								.github/check-script.yml
									
									
									
									
										vendored
									
									
								
							@@ -1,54 +0,0 @@
 | 
			
		||||
name: Check Shell Scripts
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  pull_request:
 | 
			
		||||
    paths:
 | 
			
		||||
      - '**/*.sh'  # Führt den Check nur für Shell-Skripte aus
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  check-scripts:
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
    - name: Checkout Code
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
 | 
			
		||||
    - name: Check `source` Line in Scripts
 | 
			
		||||
      shell: bash
 | 
			
		||||
      run: |
 | 
			
		||||
        set -e
 | 
			
		||||
        ERROR_COUNT=0
 | 
			
		||||
        FILES=$(find . -name "*.sh")
 | 
			
		||||
 | 
			
		||||
        for FILE in $FILES; do
 | 
			
		||||
          # Check for exact match of the source line in line 2
 | 
			
		||||
          if [[ $(sed -n '2p' "$FILE") =~ ^source[[:space:]]+<(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) ]]; then
 | 
			
		||||
            echo "Check passed for: $FILE"
 | 
			
		||||
          else
 | 
			
		||||
            echo "Error in $FILE: Line 2 must be exactly 'source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)' if a source line is used."
 | 
			
		||||
            ERROR_COUNT=$((ERROR_COUNT + 1))
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
          # Check for shebang line at the top
 | 
			
		||||
          if [[ $(head -n 1 "$FILE") != "#!/usr/bin/env bash" ]]; then
 | 
			
		||||
            echo "Error in $FILE: The first line must be '#!/usr/bin/env bash'."
 | 
			
		||||
            ERROR_COUNT=$((ERROR_COUNT + 1))
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
          # Check for executable permissions
 | 
			
		||||
          if [[ ! -x "$FILE" ]]; then
 | 
			
		||||
            echo "Warning in $FILE: This script is not executable. Consider running 'chmod +x $FILE'."
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
          # Check for empty lines at the beginning of the script
 | 
			
		||||
          if [[ $(head -n 10 "$FILE" | grep -c '^$') -gt 0 ]]; then
 | 
			
		||||
            echo "Warning in $FILE: There are empty lines at the beginning of the script. Consider removing them."
 | 
			
		||||
          fi
 | 
			
		||||
        done
 | 
			
		||||
 | 
			
		||||
        if [[ "$ERROR_COUNT" -gt 0 ]]; then
 | 
			
		||||
          echo "$ERROR_COUNT script(s) failed validation."
 | 
			
		||||
          exit 1
 | 
			
		||||
        else
 | 
			
		||||
          echo "All scripts passed."
 | 
			
		||||
        fi
 | 
			
		||||
							
								
								
									
										10
									
								
								.github/workflows/changelog-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/changelog-pr.yml
									
									
									
									
										vendored
									
									
								
							@@ -157,3 +157,13 @@ jobs:
 | 
			
		||||
          if [ -n "$PR_NUMBER" ]; then
 | 
			
		||||
            gh pr review $PR_NUMBER --approve
 | 
			
		||||
          fi
 | 
			
		||||
          
 | 
			
		||||
      - name: Re-approve pull request after update
 | 
			
		||||
        if: steps.verify-diff.outputs.changed == 'true'
 | 
			
		||||
        env:
 | 
			
		||||
          GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
			
		||||
        run: |
 | 
			
		||||
          PR_NUMBER=$(gh pr list --head "${BRANCH_NAME}" --json number --jq '.[].number')
 | 
			
		||||
          if [ -n "$PR_NUMBER" ]; then
 | 
			
		||||
            gh pr review $PR_NUMBER --approve
 | 
			
		||||
          fi
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										157
									
								
								.github/workflows/validate-filenames.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								.github/workflows/validate-filenames.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,157 @@
 | 
			
		||||
name: Validate filenames
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  pull_request_target:
 | 
			
		||||
    paths:
 | 
			
		||||
      - "ct/*.sh"
 | 
			
		||||
      - "install/*.sh"
 | 
			
		||||
      - "json/*.json"
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  check-files:
 | 
			
		||||
    name: Check changed files
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    permissions:
 | 
			
		||||
      pull-requests: write
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Get pull request information
 | 
			
		||||
        if: github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        id: pr
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const { data: pullRequest } = await github.rest.pulls.get({
 | 
			
		||||
              ...context.repo,
 | 
			
		||||
              pull_number: context.payload.pull_request.number,
 | 
			
		||||
            });
 | 
			
		||||
            return pullRequest;
 | 
			
		||||
 | 
			
		||||
      - name: Checkout code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
        with:
 | 
			
		||||
          fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
 | 
			
		||||
          ref: ${{ github.event_name == 'pull_request_target' && fromJSON(steps.pr.outputs.result).merge_commit_sha || '' }}
 | 
			
		||||
 | 
			
		||||
      - name: Get changed files
 | 
			
		||||
        id: changed-files
 | 
			
		||||
        run: |
 | 
			
		||||
          if ${{ github.event_name == 'pull_request_target' }}; then
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ steps.pr.outputs.result && fromJSON(steps.pr.outputs.result).merge_commit_sha }} | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          else
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: "Validate filenames in ct and install directory"
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-scripts
 | 
			
		||||
        run: |
 | 
			
		||||
          CHANGED_FILES=$(printf "%s\n" ${{ steps.changed-files.outputs.files }} | { grep -E '^(ct|install)/.*\.sh$' || true; })
 | 
			
		||||
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in $CHANGED_FILES; do
 | 
			
		||||
            BASENAME=$(echo "$(basename "${FILE%.*}")")
 | 
			
		||||
            if [[ ! "$BASENAME" =~ ^[a-z0-9-]+$ ]]; then
 | 
			
		||||
                    NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Non-compliant filenames found, change to lowercase:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: "Validate filenames in json directory."
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-json
 | 
			
		||||
        run: |
 | 
			
		||||
          CHANGED_FILES=$(printf "%s\n" ${{ steps.changed-files.outputs.files }} | { grep -E '^json/.*\.json$' || true; })
 | 
			
		||||
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in $CHANGED_FILES; do
 | 
			
		||||
            BASENAME=$(echo "$(basename "${FILE%.*}")")
 | 
			
		||||
            if [[ ! "$BASENAME" =~ ^[a-z0-9-]+$ ]]; then
 | 
			
		||||
                    NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Non-compliant filenames found, change to lowercase:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Post results and comment
 | 
			
		||||
        if: always() && steps.check-scripts.outputs.files != '' && steps.check-json.outputs.files != '' && github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const result = "${{ job.status }}" === "success" ? "success" : "failure";
 | 
			
		||||
            const nonCompliantFiles = {
 | 
			
		||||
              script: "${{ steps.check-scripts.outputs.files }}",
 | 
			
		||||
              JSON: "${{ steps.check-json.outputs.files }}",
 | 
			
		||||
            };
 | 
			
		||||
 | 
			
		||||
            const issueNumber = context.payload.pull_request
 | 
			
		||||
              ? context.payload.pull_request.number
 | 
			
		||||
              : null;
 | 
			
		||||
            const commentIdentifier = "validate-filenames";
 | 
			
		||||
            let newCommentBody = `<!-- ${commentIdentifier}-start -->\n### Filename validation\n\n`;
 | 
			
		||||
 | 
			
		||||
            if (result === "failure") {
 | 
			
		||||
              newCommentBody += ":x: We found issues in the following changed files:\n\n";
 | 
			
		||||
              for (const [check, files] of Object.entries(nonCompliantFiles)) {
 | 
			
		||||
                if (files) {
 | 
			
		||||
                  newCommentBody += `**${check.charAt(0).toUpperCase() + check.slice(1)} filename invalid:**\n${files
 | 
			
		||||
                    .trim()
 | 
			
		||||
                    .split(" ")
 | 
			
		||||
                    .map((file) => `- ${file}`)
 | 
			
		||||
                    .join("\n")}\n\n`;
 | 
			
		||||
                }
 | 
			
		||||
              }
 | 
			
		||||
              newCommentBody +=
 | 
			
		||||
                "Please change the filenames to lowercase and use only alphanumeric characters and dashes.\n";
 | 
			
		||||
            } else {
 | 
			
		||||
              newCommentBody += `:rocket: All files passed filename validation!\n`;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            newCommentBody += `\n\n<!-- ${commentIdentifier}-end -->`;
 | 
			
		||||
 | 
			
		||||
            if (issueNumber) {
 | 
			
		||||
              const { data: comments } = await github.rest.issues.listComments({
 | 
			
		||||
                ...context.repo,
 | 
			
		||||
                issue_number: issueNumber,
 | 
			
		||||
              });
 | 
			
		||||
 | 
			
		||||
              const existingComment = comments.find(
 | 
			
		||||
                (comment) => comment.user.login === "github-actions[bot]",
 | 
			
		||||
              );
 | 
			
		||||
 | 
			
		||||
              if (existingComment) {
 | 
			
		||||
                if (existingComment.body.includes(commentIdentifier)) {
 | 
			
		||||
                  const re = new RegExp(String.raw`<!-- ${commentIdentifier}-start -->[\s\S]*?<!-- ${commentIdentifier}-end -->`, "");
 | 
			
		||||
                  newCommentBody = existingComment.body.replace(re, newCommentBody);
 | 
			
		||||
                } else {
 | 
			
		||||
                  newCommentBody = existingComment.body + '\n\n---\n\n' + newCommentBody;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await github.rest.issues.updateComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  comment_id: existingComment.id,
 | 
			
		||||
                  body: newCommentBody,
 | 
			
		||||
                });
 | 
			
		||||
              } else {
 | 
			
		||||
                await github.rest.issues.createComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  issue_number: issueNumber,
 | 
			
		||||
                  body: newCommentBody,
 | 
			
		||||
                });
 | 
			
		||||
              }
 | 
			
		||||
            }
 | 
			
		||||
							
								
								
									
										130
									
								
								.github/workflows/validate-formatting.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								.github/workflows/validate-formatting.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,130 @@
 | 
			
		||||
name: Validate script formatting
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  push:
 | 
			
		||||
    branches:
 | 
			
		||||
      - main
 | 
			
		||||
  pull_request_target:
 | 
			
		||||
    paths:
 | 
			
		||||
      - "**/*.sh"
 | 
			
		||||
      - "**/*.func"
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  shfmt:
 | 
			
		||||
    name: Check changed files
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    permissions:
 | 
			
		||||
      pull-requests: write
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Get pull request information
 | 
			
		||||
        if: github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        id: pr
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const { data: pullRequest } = await github.rest.pulls.get({
 | 
			
		||||
              ...context.repo,
 | 
			
		||||
              pull_number: context.payload.pull_request.number,
 | 
			
		||||
            });
 | 
			
		||||
            return pullRequest;
 | 
			
		||||
 | 
			
		||||
      - name: Checkout code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
        with:
 | 
			
		||||
          fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
 | 
			
		||||
          ref: ${{ github.event_name == 'pull_request_target' && fromJSON(steps.pr.outputs.result).merge_commit_sha || '' }}
 | 
			
		||||
 | 
			
		||||
      - name: Get changed files
 | 
			
		||||
        id: changed-files
 | 
			
		||||
        run: |
 | 
			
		||||
          if ${{ github.event_name == 'pull_request_target' }}; then
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ steps.pr.outputs.result && fromJSON(steps.pr.outputs.result).merge_commit_sha }} | grep -E '\.(sh|func)$' | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          else
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | grep -E '\.(sh|func)$' | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Set up Go
 | 
			
		||||
        if: steps.changed-files.outputs.files != ''
 | 
			
		||||
        uses: actions/setup-go@v5
 | 
			
		||||
 | 
			
		||||
      - name: Install shfmt
 | 
			
		||||
        if: steps.changed-files.outputs.files != ''
 | 
			
		||||
        run: |
 | 
			
		||||
          go install mvdan.cc/sh/v3/cmd/shfmt@latest
 | 
			
		||||
          echo "$GOPATH/bin" >> $GITHUB_PATH
 | 
			
		||||
 | 
			
		||||
      - name: Run shfmt
 | 
			
		||||
        if: steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: shfmt
 | 
			
		||||
        run: |
 | 
			
		||||
          set +e
 | 
			
		||||
 | 
			
		||||
          shfmt_output=$(shfmt -d ${{ steps.changed-files.outputs.files }})
 | 
			
		||||
          if [[ $? -eq 0 ]]; then
 | 
			
		||||
            exit 0
 | 
			
		||||
          else
 | 
			
		||||
            echo "diff=\"$(echo -n "$shfmt_output" | base64 -w 0)\"" >> $GITHUB_OUTPUT
 | 
			
		||||
            printf "%s" "$shfmt_output"
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Post comment with results
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != '' && github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const result = "${{ job.status }}" === "success" ? "success" : "failure";
 | 
			
		||||
            const diff = Buffer.from(
 | 
			
		||||
              ${{ steps.shfmt.outputs.diff }},
 | 
			
		||||
              "base64",
 | 
			
		||||
            ).toString();
 | 
			
		||||
            const issueNumber = context.payload.pull_request
 | 
			
		||||
              ? context.payload.pull_request.number
 | 
			
		||||
              : null;
 | 
			
		||||
            const commentIdentifier = "validate-formatting";
 | 
			
		||||
            let newCommentBody = `<!-- ${commentIdentifier}-start -->\n### Script formatting\n\n`;
 | 
			
		||||
 | 
			
		||||
            if (result === "failure") {
 | 
			
		||||
              newCommentBody +=
 | 
			
		||||
                `:x: We found issues in the formatting of the following changed files:\n\n\`\`\`diff\n${diff}\n\`\`\`\n`;
 | 
			
		||||
            } else {
 | 
			
		||||
              newCommentBody += `:rocket: All changed shell scripts are formatted correctly!\n`;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            newCommentBody += `\n\n<!-- ${commentIdentifier}-end -->`;
 | 
			
		||||
 | 
			
		||||
            if (issueNumber) {
 | 
			
		||||
              const { data: comments } = await github.rest.issues.listComments({
 | 
			
		||||
                ...context.repo,
 | 
			
		||||
                issue_number: issueNumber,
 | 
			
		||||
              });
 | 
			
		||||
 | 
			
		||||
              const existingComment = comments.find(
 | 
			
		||||
                (comment) => comment.user.login === "github-actions[bot]",
 | 
			
		||||
              );
 | 
			
		||||
 | 
			
		||||
              if (existingComment) {
 | 
			
		||||
                if (existingComment.body.includes(commentIdentifier)) {
 | 
			
		||||
                  const re = new RegExp(
 | 
			
		||||
                    String.raw`<!-- ${commentIdentifier}-start -->[\s\S]*?<!-- ${commentIdentifier}-end -->`,
 | 
			
		||||
                    "",
 | 
			
		||||
                  );
 | 
			
		||||
                  newCommentBody = existingComment.body.replace(re, newCommentBody);
 | 
			
		||||
                } else {
 | 
			
		||||
                  newCommentBody = existingComment.body + "\n\n---\n\n" + newCommentBody;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await github.rest.issues.updateComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  comment_id: existingComment.id,
 | 
			
		||||
                  body: newCommentBody,
 | 
			
		||||
                });
 | 
			
		||||
              } else {
 | 
			
		||||
                await github.rest.issues.createComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  issue_number: issueNumber,
 | 
			
		||||
                  body: newCommentBody,
 | 
			
		||||
                });
 | 
			
		||||
              }
 | 
			
		||||
            }
 | 
			
		||||
							
								
								
									
										226
									
								
								.github/workflows/validate-scripts.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										226
									
								
								.github/workflows/validate-scripts.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,226 @@
 | 
			
		||||
name: Validate scripts
 | 
			
		||||
on:
 | 
			
		||||
  push:
 | 
			
		||||
    branches:
 | 
			
		||||
      - main
 | 
			
		||||
  pull_request_target:
 | 
			
		||||
    paths:
 | 
			
		||||
      - "ct/*.sh"
 | 
			
		||||
      - "install/*.sh"
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  check-scripts:
 | 
			
		||||
    name: Check changed files
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    permissions:
 | 
			
		||||
      pull-requests: write
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Get pull request information
 | 
			
		||||
        if: github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        id: pr
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const { data: pullRequest } = await github.rest.pulls.get({
 | 
			
		||||
              ...context.repo,
 | 
			
		||||
              pull_number: context.payload.pull_request.number,
 | 
			
		||||
            });
 | 
			
		||||
            return pullRequest;
 | 
			
		||||
 | 
			
		||||
      - name: Checkout code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
        with:
 | 
			
		||||
          fetch-depth: 0 # Ensure the full history is fetched for accurate diffing
 | 
			
		||||
          ref: ${{ github.event_name == 'pull_request_target' && fromJSON(steps.pr.outputs.result).merge_commit_sha || '' }}
 | 
			
		||||
 | 
			
		||||
      - name: Get changed files
 | 
			
		||||
        id: changed-files
 | 
			
		||||
        run: |
 | 
			
		||||
          if ${{ github.event_name == 'pull_request_target' }}; then
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ steps.pr.outputs.result && fromJSON(steps.pr.outputs.result).merge_commit_sha }} | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          else
 | 
			
		||||
              echo "files=$(git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | grep -E '\.(sh|func)$' | xargs)" >> $GITHUB_OUTPUT
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check build.func line
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: build-func
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if [[ "$FILE" == ct/* ]] && [[ $(sed -n '2p' "$FILE") != "source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)" ]]; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Build.func line missing or incorrect in files:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check executable permissions
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-executable
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if [[ ! -x "$FILE" ]]; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Files not executable:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check copyright
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-copyright
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if ! sed -n '3p' "$FILE" | grep -qE "^# Copyright \(c\) [0-9]{4}(-[0-9]{4})? (tteck \| community-scripts ORG|community-scripts ORG|tteck)$"; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Copyright header missing or not on line 3 in files:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check author
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-author
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if ! sed -n '4p' "$FILE" | grep -qE "^# Author: .+"; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Author header missing or invalid on line 4 in files:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check license
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-license
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if [[ "$(sed -n '5p' "$FILE")" != "# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE" ]]; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "License header missing or not on line 5 in files:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Check source
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != ''
 | 
			
		||||
        id: check-source
 | 
			
		||||
        run: |
 | 
			
		||||
          NON_COMPLIANT_FILES=""
 | 
			
		||||
          for FILE in ${{ steps.changed-files.outputs.files }}; do
 | 
			
		||||
            if ! sed -n '6p' "$FILE" | grep -qE "^# Source: .+"; then
 | 
			
		||||
              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
			
		||||
            fi
 | 
			
		||||
          done
 | 
			
		||||
 | 
			
		||||
          if [ -n "$NON_COMPLIANT_FILES" ]; then
 | 
			
		||||
            echo "files=$NON_COMPLIANT_FILES" >> $GITHUB_OUTPUT
 | 
			
		||||
            echo "Source header missing or not on line 6 in files:"
 | 
			
		||||
            for FILE in $NON_COMPLIANT_FILES; do
 | 
			
		||||
              echo "$FILE"
 | 
			
		||||
            done
 | 
			
		||||
            exit 1
 | 
			
		||||
          fi
 | 
			
		||||
 | 
			
		||||
      - name: Post results and comment
 | 
			
		||||
        if: always() && steps.changed-files.outputs.files != '' && github.event_name == 'pull_request_target'
 | 
			
		||||
        uses: actions/github-script@v7
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            const result = '${{ job.status }}' === 'success' ? 'success' : 'failure';
 | 
			
		||||
            const nonCompliantFiles = {
 | 
			
		||||
              'Invalid build.func source': "${{ steps.build-func.outputs.files }}",
 | 
			
		||||
              'Not executable': "${{ steps.check-executable.outputs.files }}",
 | 
			
		||||
              'Copyright header line missing or invalid': "${{ steps.check-copyright.outputs.files }}",
 | 
			
		||||
              'Author header line missing or invalid': "${{ steps.check-author.outputs.files }}",
 | 
			
		||||
              'License header line missing or invalid': "${{ steps.check-license.outputs.files }}",
 | 
			
		||||
              'Source header line missing or invalid': "${{ steps.check-source.outputs.files }}"
 | 
			
		||||
            };
 | 
			
		||||
 | 
			
		||||
            const issueNumber = context.payload.pull_request ? context.payload.pull_request.number : null;
 | 
			
		||||
            const commentIdentifier = 'validate-scripts';
 | 
			
		||||
            let newCommentBody = `<!-- ${commentIdentifier}-start -->\n### Script validation\n\n`;
 | 
			
		||||
 | 
			
		||||
            if (result === 'failure') {
 | 
			
		||||
              newCommentBody += ':x: We found issues in the following changed files:\n\n';
 | 
			
		||||
              for (const [check, files] of Object.entries(nonCompliantFiles)) {
 | 
			
		||||
                if (files) {
 | 
			
		||||
                  newCommentBody += `**${check}:**\n${files.trim().split(' ').map(file => `- ${file}`).join('\n')}\n\n`;
 | 
			
		||||
                }
 | 
			
		||||
              }
 | 
			
		||||
            } else {
 | 
			
		||||
              newCommentBody += `:rocket: All changed shell scripts passed validation!\n`;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            newCommentBody += `\n\n<!-- ${commentIdentifier}-end -->`;
 | 
			
		||||
 | 
			
		||||
            if (issueNumber) {
 | 
			
		||||
              const { data: comments } = await github.rest.issues.listComments({
 | 
			
		||||
                ...context.repo,
 | 
			
		||||
                issue_number: issueNumber
 | 
			
		||||
              });
 | 
			
		||||
 | 
			
		||||
              const existingComment = comments.find(comment => comment.user.login === 'github-actions[bot]');
 | 
			
		||||
 | 
			
		||||
              if (existingComment) {
 | 
			
		||||
                if (existingComment.body.includes(commentIdentifier)) {
 | 
			
		||||
                  const re = new RegExp(String.raw`<!-- ${commentIdentifier}-start -->[\s\S]*?<!-- ${commentIdentifier}-end -->`, "");
 | 
			
		||||
                  newCommentBody = existingComment.body.replace(re, newCommentBody);
 | 
			
		||||
                } else {
 | 
			
		||||
                  newCommentBody = existingComment.body + '\n\n---\n\n' + newCommentBody;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await github.rest.issues.updateComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  comment_id: existingComment.id,
 | 
			
		||||
                  body: newCommentBody
 | 
			
		||||
                });
 | 
			
		||||
              } else {
 | 
			
		||||
                await github.rest.issues.createComment({
 | 
			
		||||
                  ...context.repo,
 | 
			
		||||
                  issue_number: issueNumber,
 | 
			
		||||
                  body: newCommentBody
 | 
			
		||||
                });
 | 
			
		||||
              }
 | 
			
		||||
            }
 | 
			
		||||
							
								
								
									
										116
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -16,6 +16,122 @@ All LXC instances created using this repository come pre-installed with Midnight
 | 
			
		||||
> [!IMPORTANT]
 | 
			
		||||
Do not break established syntax in this file, as it is automatically updated by a Github Workflow
 | 
			
		||||
 | 
			
		||||
## 2025-01-08
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### 🌐 Website
 | 
			
		||||
 | 
			
		||||
- update postgresql json to add post install password setup [@rdiazlugo](https://github.com/rdiazlugo) ([#1318](https://github.com/community-scripts/ProxmoxVE/pull/1318))
 | 
			
		||||
 | 
			
		||||
### 🧰 Maintenance
 | 
			
		||||
 | 
			
		||||
- fix(ci): formatting event & chmod +x [@se-bastiaan](https://github.com/se-bastiaan) ([#1335](https://github.com/community-scripts/ProxmoxVE/pull/1335))
 | 
			
		||||
- fix: correctly handle pull_request_target event [@se-bastiaan](https://github.com/se-bastiaan) ([#1327](https://github.com/community-scripts/ProxmoxVE/pull/1327))
 | 
			
		||||
 | 
			
		||||
## 2025-01-07
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### 🚀 Updated Scripts
 | 
			
		||||
 | 
			
		||||
- Fix: Folder-Check for Updatescript Zammad [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1309](https://github.com/community-scripts/ProxmoxVE/pull/1309))
 | 
			
		||||
 | 
			
		||||
### 🧰 Maintenance
 | 
			
		||||
 | 
			
		||||
- fix: permissions of validate pipelines [@se-bastiaan](https://github.com/se-bastiaan) ([#1316](https://github.com/community-scripts/ProxmoxVE/pull/1316))
 | 
			
		||||
- Set Execution Rights for GH-Action: Validate Scripts [@MickLesk](https://github.com/MickLesk) ([#1312](https://github.com/community-scripts/ProxmoxVE/pull/1312))
 | 
			
		||||
 | 
			
		||||
## 2025-01-06
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### ✨ New Scripts
 | 
			
		||||
 | 
			
		||||
- New Script: Typesense [@tlissak](https://github.com/tlissak) ([#1291](https://github.com/community-scripts/ProxmoxVE/pull/1291))
 | 
			
		||||
- New script: GLPI [@opastorello](https://github.com/opastorello) ([#1201](https://github.com/community-scripts/ProxmoxVE/pull/1201))
 | 
			
		||||
 | 
			
		||||
### 🚀 Updated Scripts
 | 
			
		||||
 | 
			
		||||
- Fix Tag in HyperHDR Script [@MickLesk](https://github.com/MickLesk) ([#1299](https://github.com/community-scripts/ProxmoxVE/pull/1299))
 | 
			
		||||
- [Fix]: Fixed rm Bug in pf2etools [@MickLesk](https://github.com/MickLesk) ([#1292](https://github.com/community-scripts/ProxmoxVE/pull/1292))
 | 
			
		||||
- Fix: Homebox Update Script  [@MickLesk](https://github.com/MickLesk) ([#1284](https://github.com/community-scripts/ProxmoxVE/pull/1284))
 | 
			
		||||
- Add ca-certificates for Install (Frigate) [@MickLesk](https://github.com/MickLesk) ([#1282](https://github.com/community-scripts/ProxmoxVE/pull/1282))
 | 
			
		||||
- fix: buffer from base64 in formatting pipeline [@se-bastiaan](https://github.com/se-bastiaan) ([#1285](https://github.com/community-scripts/ProxmoxVE/pull/1285))
 | 
			
		||||
 | 
			
		||||
### 🧰 Maintenance
 | 
			
		||||
 | 
			
		||||
- Add reapproval of Changelog-PR [@MickLesk](https://github.com/MickLesk) ([#1279](https://github.com/community-scripts/ProxmoxVE/pull/1279))
 | 
			
		||||
- ci: combine header checks into workflow with PR comment [@se-bastiaan](https://github.com/se-bastiaan) ([#1257](https://github.com/community-scripts/ProxmoxVE/pull/1257))
 | 
			
		||||
- ci: change filename checks into steps with PR comment [@se-bastiaan](https://github.com/se-bastiaan) ([#1255](https://github.com/community-scripts/ProxmoxVE/pull/1255))
 | 
			
		||||
- ci: add pipeline for code formatting checks [@se-bastiaan](https://github.com/se-bastiaan) ([#1239](https://github.com/community-scripts/ProxmoxVE/pull/1239))
 | 
			
		||||
 | 
			
		||||
## 2025-01-05
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### 💥 Breaking Changes
 | 
			
		||||
 | 
			
		||||
- [Breaking] Update Zigbee2mqtt to v.2.0.0 (Read PR Description) [@MickLesk](https://github.com/MickLesk) ([#1221](https://github.com/community-scripts/ProxmoxVE/pull/1221))
 | 
			
		||||
 | 
			
		||||
### ❔ Unlabelled
 | 
			
		||||
 | 
			
		||||
- Add RAM and Disk units [@oOStroudyOo](https://github.com/oOStroudyOo) ([#1261](https://github.com/community-scripts/ProxmoxVE/pull/1261))
 | 
			
		||||
 | 
			
		||||
## 2025-01-04
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### 🚀 Updated Scripts
 | 
			
		||||
 | 
			
		||||
- Fix gpg key pf2tools & 5etools [@MickLesk](https://github.com/MickLesk) ([#1242](https://github.com/community-scripts/ProxmoxVE/pull/1242))
 | 
			
		||||
- Homarr: Fix missing curl dependency [@MickLesk](https://github.com/MickLesk) ([#1238](https://github.com/community-scripts/ProxmoxVE/pull/1238))
 | 
			
		||||
- Homeassistan Core: Fix Python3 and add missing dependencies [@MickLesk](https://github.com/MickLesk) ([#1236](https://github.com/community-scripts/ProxmoxVE/pull/1236))
 | 
			
		||||
- Fix: Update Python for HomeAssistant [@MickLesk](https://github.com/MickLesk) ([#1227](https://github.com/community-scripts/ProxmoxVE/pull/1227))
 | 
			
		||||
- OneDev: Add git-lfs [@MickLesk](https://github.com/MickLesk) ([#1225](https://github.com/community-scripts/ProxmoxVE/pull/1225))
 | 
			
		||||
- Pf2eTools & 5eTools: Fixing npm build [@TheRealVira](https://github.com/TheRealVira) ([#1213](https://github.com/community-scripts/ProxmoxVE/pull/1213))
 | 
			
		||||
 | 
			
		||||
### 🌐 Website
 | 
			
		||||
 | 
			
		||||
- Bump next from 15.0.2 to 15.1.3 in /frontend [@dependabot[bot]](https://github.com/dependabot[bot]) ([#1212](https://github.com/community-scripts/ProxmoxVE/pull/1212))
 | 
			
		||||
 | 
			
		||||
### 🧰 Maintenance
 | 
			
		||||
 | 
			
		||||
- [GitHub Action] Add filename case check [@quantumryuu](https://github.com/quantumryuu) ([#1228](https://github.com/community-scripts/ProxmoxVE/pull/1228))
 | 
			
		||||
 | 
			
		||||
## 2025-01-03
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### 🚀 Updated Scripts
 | 
			
		||||
 | 
			
		||||
- Improve Homarr Installation [@MickLesk](https://github.com/MickLesk) ([#1208](https://github.com/community-scripts/ProxmoxVE/pull/1208))
 | 
			
		||||
- Fix: Zabbix-Update Script [@MickLesk](https://github.com/MickLesk) ([#1205](https://github.com/community-scripts/ProxmoxVE/pull/1205))
 | 
			
		||||
- Update Script: Lazylibrarian [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1190](https://github.com/community-scripts/ProxmoxVE/pull/1190))
 | 
			
		||||
- Fix: Memos update function [@MickLesk](https://github.com/MickLesk) ([#1207](https://github.com/community-scripts/ProxmoxVE/pull/1207))
 | 
			
		||||
- Keep Lubelogger data after update to a new version [@JcMinarro](https://github.com/JcMinarro) ([#1200](https://github.com/community-scripts/ProxmoxVE/pull/1200))
 | 
			
		||||
 | 
			
		||||
### 🌐 Website
 | 
			
		||||
 | 
			
		||||
- Update Nextcloud-LXC JSON [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1191](https://github.com/community-scripts/ProxmoxVE/pull/1191))
 | 
			
		||||
 | 
			
		||||
### 🧰 Maintenance
 | 
			
		||||
 | 
			
		||||
- Github action to check metadata lines in scripts. [@quantumryuu](https://github.com/quantumryuu) ([#1110](https://github.com/community-scripts/ProxmoxVE/pull/1110))
 | 
			
		||||
 | 
			
		||||
## 2025-01-02
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 | 
			
		||||
### ✨ New Scripts
 | 
			
		||||
 | 
			
		||||
- New Script: Pf2eTools [@TheRealVira](https://github.com/TheRealVira) ([#1162](https://github.com/community-scripts/ProxmoxVE/pull/1162))
 | 
			
		||||
- New Script: 5etools [@TheRealVira](https://github.com/TheRealVira) ([#1157](https://github.com/community-scripts/ProxmoxVE/pull/1157))
 | 
			
		||||
 | 
			
		||||
### 🚀 Updated Scripts
 | 
			
		||||
 | 
			
		||||
- Update config template in blocky-install.sh [@xFichtl1](https://github.com/xFichtl1) ([#1059](https://github.com/community-scripts/ProxmoxVE/pull/1059))
 | 
			
		||||
 | 
			
		||||
## 2025-01-01
 | 
			
		||||
 | 
			
		||||
### Changed
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										113
									
								
								ct/5etools.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								ct/5etools.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,113 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: TheRealVira
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
# Source: https://5e.tools/
 | 
			
		||||
 | 
			
		||||
# App Default Values
 | 
			
		||||
APP="5etools"
 | 
			
		||||
var_tags="wiki"
 | 
			
		||||
var_cpu="1"
 | 
			
		||||
var_ram="512"
 | 
			
		||||
var_disk="13"
 | 
			
		||||
var_os="debian"
 | 
			
		||||
var_version="12"
 | 
			
		||||
var_unprivileged="1"
 | 
			
		||||
 | 
			
		||||
# App Output & Base Settings
 | 
			
		||||
header_info "$APP"
 | 
			
		||||
base_settings
 | 
			
		||||
 | 
			
		||||
# Core
 | 
			
		||||
variables
 | 
			
		||||
color
 | 
			
		||||
catch_errors
 | 
			
		||||
 | 
			
		||||
function update_script() {
 | 
			
		||||
    header_info
 | 
			
		||||
    check_container_storage
 | 
			
		||||
    check_container_resources
 | 
			
		||||
 | 
			
		||||
    # Check if installation is present | -f for file, -d for folder
 | 
			
		||||
    if [[ ! -d "/opt/${APP}" ]]; then
 | 
			
		||||
        msg_error "No ${APP} Installation Found!"
 | 
			
		||||
        exit
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    RELEASE=$(curl -s https://api.github.com/repos/5etools-mirror-3/5etools-src/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f "/opt/${APP}_version.txt" ]]; then
 | 
			
		||||
        # Crawling the new version and checking whether an update is required
 | 
			
		||||
        msg_info "Updating System"
 | 
			
		||||
        apt-get update &>/dev/null
 | 
			
		||||
        apt-get -y upgrade &>/dev/null
 | 
			
		||||
        msg_ok "Updated System"
 | 
			
		||||
 | 
			
		||||
        # Execute Update
 | 
			
		||||
        msg_info "Updating base 5etools"
 | 
			
		||||
        cd /opt
 | 
			
		||||
        wget -q "https://github.com/5etools-mirror-3/5etools-src/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
        unzip -q "${RELEASE}.zip"
 | 
			
		||||
        mv "/opt/${APP}/img" "/opt/img-backup"
 | 
			
		||||
        rm -rf "/opt/${APP}"
 | 
			
		||||
        mv "${APP}-src-${RELEASE:1}" "/opt/${APP}"
 | 
			
		||||
        mv "/opt/img-backup" "/opt/${APP}/img"
 | 
			
		||||
        cd /opt/5etools
 | 
			
		||||
        $STD npm install
 | 
			
		||||
        $STD npm run build
 | 
			
		||||
        cd ~
 | 
			
		||||
        echo "${RELEASE}" >"/opt/${APP}_version.txt"
 | 
			
		||||
        chown -R www-data: "/opt/${APP}"
 | 
			
		||||
        chmod -R 755 "/opt/${APP}"
 | 
			
		||||
        msg_ok "Updated base 5etools"
 | 
			
		||||
        # Cleaning up
 | 
			
		||||
        msg_info "Cleaning Up"
 | 
			
		||||
        rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
        $STD apt-get -y autoremove
 | 
			
		||||
        $STD apt-get -y autoclean
 | 
			
		||||
        msg_ok "Cleanup Completed"
 | 
			
		||||
    else
 | 
			
		||||
        msg_ok "No update required. Base ${APP} is already at ${RELEASE}"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    IMG_RELEASE=$(curl -s https://api.github.com/repos/5etools-mirror-2/5etools-img/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
    if [[ "${IMG_RELEASE}" != "$(cat /opt/${APP}_IMG_version.txt)" ]] || [[ ! -f "/opt/${APP}_IMG_version.txt" ]]; then
 | 
			
		||||
        # Crawling the new version and checking whether an update is required
 | 
			
		||||
        msg_info "Updating System"
 | 
			
		||||
        apt-get update &>/dev/null
 | 
			
		||||
        apt-get -y upgrade &>/dev/null
 | 
			
		||||
        msg_ok "Updated System"
 | 
			
		||||
 | 
			
		||||
        # Execute Update
 | 
			
		||||
        msg_info "Updating 5etools images"
 | 
			
		||||
        curl -sSL "https://github.com/5etools-mirror-2/5etools-img/archive/refs/tags/${IMG_RELEASE}.zip" > "${IMG_RELEASE}.zip"
 | 
			
		||||
        unzip -q "${IMG_RELEASE}.zip"
 | 
			
		||||
        rm -rf "/opt/${APP}/img"
 | 
			
		||||
        mv "${APP}-img-${IMG_RELEASE:1}" "/opt/${APP}/img"
 | 
			
		||||
        echo "${IMG_RELEASE}" >"/opt/${APP}_IMG_version.txt"
 | 
			
		||||
        chown -R www-data: "/opt/${APP}"
 | 
			
		||||
        chmod -R 755 "/opt/${APP}"
 | 
			
		||||
 | 
			
		||||
        msg_ok "Updating 5etools images"
 | 
			
		||||
 | 
			
		||||
        # Cleaning up
 | 
			
		||||
        msg_info "Cleaning Up"
 | 
			
		||||
        rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
        rm -rf ${IMG_RELEASE}.zip
 | 
			
		||||
        $STD apt-get -y autoremove
 | 
			
		||||
        $STD apt-get -y autoclean
 | 
			
		||||
        msg_ok "Cleanup Completed"
 | 
			
		||||
    else
 | 
			
		||||
        msg_ok "No update required. ${APP} images are already at ${IMG_RELEASE}"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
start
 | 
			
		||||
build_container
 | 
			
		||||
description
 | 
			
		||||
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}${CL}"
 | 
			
		||||
							
								
								
									
										52
									
								
								ct/glpi.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								ct/glpi.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,52 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
			
		||||
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: Nícolas Pastorello (opastorello)
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
 | 
			
		||||
# App Default Values
 | 
			
		||||
APP="GLPI"
 | 
			
		||||
var_tags="asset-management;foss"
 | 
			
		||||
var_cpu="2"
 | 
			
		||||
var_ram="2048"
 | 
			
		||||
var_disk="10"
 | 
			
		||||
var_os="debian"
 | 
			
		||||
var_version="12"
 | 
			
		||||
var_unprivileged="1"
 | 
			
		||||
 | 
			
		||||
# App Output & Base Settings
 | 
			
		||||
header_info "$APP"
 | 
			
		||||
base_settings
 | 
			
		||||
 | 
			
		||||
# Core
 | 
			
		||||
variables
 | 
			
		||||
color
 | 
			
		||||
catch_errors
 | 
			
		||||
 | 
			
		||||
function update_script() {
 | 
			
		||||
  header_info
 | 
			
		||||
  check_container_storage
 | 
			
		||||
  check_container_resources
 | 
			
		||||
 | 
			
		||||
  if [[ ! -d /opt/glpi ]]; then
 | 
			
		||||
    msg_error "No ${APP} Installation Found!"
 | 
			
		||||
    exit
 | 
			
		||||
  fi
 | 
			
		||||
  RELEASE=$(curl -s https://api.github.com/repos/glpi-project/glpi/releases/latest | grep '"tag_name"' | sed -E 's/.*"tag_name": "([^"]+)".*/\1/')
 | 
			
		||||
  if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then
 | 
			
		||||
    msg_error "Ther is currently no automatic update function for ${APP}."
 | 
			
		||||
  else
 | 
			
		||||
    msg_ok "No update required. ${APP} is already at v${RELEASE}."
 | 
			
		||||
  fi
 | 
			
		||||
  exit
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
start
 | 
			
		||||
build_container
 | 
			
		||||
description
 | 
			
		||||
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:80${CL}"
 | 
			
		||||
@@ -51,7 +51,9 @@ function update_script() {
 | 
			
		||||
      echo -e "${GN}Updating to Stable Version${CL}"
 | 
			
		||||
      BR=""
 | 
			
		||||
    fi
 | 
			
		||||
    if [[ "$PY" == "python3.11" ]]; then echo -e "⚠️  Home Assistant will soon require Python 3.12."; fi
 | 
			
		||||
    if [[ "$PY" =~ ^python3\.(11|12)\.[0-9]+$ ]]; then
 | 
			
		||||
    echo -e "⚠️  Home Assistant will soon require Python 3.13.x";
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    msg_info "Stopping Home Assistant"
 | 
			
		||||
    systemctl stop homeassistant
 | 
			
		||||
 
 | 
			
		||||
@@ -40,8 +40,10 @@ function update_script() {
 | 
			
		||||
    msg_info "Updating ${APP} to ${RELEASE}"
 | 
			
		||||
    cd /opt
 | 
			
		||||
    rm -rf homebox_bak
 | 
			
		||||
    rm -rf /tmp/homebox.tar.gz
 | 
			
		||||
    mv homebox homebox_bak
 | 
			
		||||
    wget -qO- https://github.com/sysadminsmedia/homebox/releases/download/${RELEASE}/homebox_Linux_x86_64.tar.gz | tar -xzf - -C /opt
 | 
			
		||||
    wget -qO /tmp/homebox.tar.gz https://github.com/sysadminsmedia/homebox/releases/download/${RELEASE}/homebox_Linux_x86_64.tar.gz
 | 
			
		||||
    tar -xzf /tmp/homebox.tar.gz -C /opt
 | 
			
		||||
    chmod +x /opt/homebox
 | 
			
		||||
    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
			
		||||
    msg_ok "Updated Homebox"
 | 
			
		||||
 
 | 
			
		||||
@@ -7,7 +7,7 @@ source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/m
 | 
			
		||||
 | 
			
		||||
# App Default Values
 | 
			
		||||
APP="HyperHDR"
 | 
			
		||||
var_tags="ambient lightning"
 | 
			
		||||
var_tags="ambient-lightning"
 | 
			
		||||
var_cpu="2"
 | 
			
		||||
var_ram="2048"
 | 
			
		||||
var_disk="4"
 | 
			
		||||
 
 | 
			
		||||
@@ -42,11 +42,19 @@ function update_script() {
 | 
			
		||||
    msg_info "Updating ${APP} to v${RELEASE}"
 | 
			
		||||
    cd /opt
 | 
			
		||||
    wget -q https://github.com/hargata/lubelog/releases/download/v${RELEASE}/LubeLogger_v${RELEASE_TRIMMED}_linux_x64.zip
 | 
			
		||||
    cp /opt/lubelogger/appsettings.json /opt/appsettings.json
 | 
			
		||||
    mkdir -p /tmp/lubeloggerData/wwwroot
 | 
			
		||||
    cp /opt/lubelogger/appsettings.json /tmp/lubeloggerData/appsettings.json
 | 
			
		||||
    cp -r /opt/lubelogger/config /tmp/lubeloggerData/
 | 
			
		||||
    cp -r /opt/lubelogger/data /tmp/lubeloggerData/
 | 
			
		||||
    [[ -e /opt/lubelogger/wwwroot/translations ]] && cp -r /opt/lubelogger/wwwroot/translations /tmp/lubeloggerData/wwwroot/
 | 
			
		||||
    [[ -e /opt/lubelogger/wwwroot/documents ]] && cp -r /opt/lubelogger/wwwroot/documents /tmp/lubeloggerData/wwwroot/
 | 
			
		||||
    [[ -e /opt/lubelogger/wwwroot/images ]] && cp -r /opt/lubelogger/wwwroot/images /tmp/lubeloggerData/wwwroot/
 | 
			
		||||
    [[ -e /opt/lubelogger/wwwroot/temp ]] && cp -r /opt/lubelogger/wwwroot/temp /tmp/lubeloggerData/wwwroot/
 | 
			
		||||
    [[ -e /opt/lubelogger/log ]] && cp -r /opt/lubelogger/log /tmp/lubeloggerData/
 | 
			
		||||
    rm -rf /opt/lubelogger
 | 
			
		||||
    unzip -qq LubeLogger_v${RELEASE_TRIMMED}_linux_x64.zip -d lubelogger
 | 
			
		||||
    chmod 700 /opt/lubelogger/CarCareTracker
 | 
			
		||||
    mv -f /opt/appsettings.json /opt/lubelogger/appsettings.json
 | 
			
		||||
    cp -rf /tmp/lubeloggerData/* /opt/lubelogger/
 | 
			
		||||
    echo "${RELEASE}" >"/opt/${APP}_version.txt"
 | 
			
		||||
    msg_ok "Updated ${APP} to v${RELEASE}"
 | 
			
		||||
 | 
			
		||||
@@ -56,6 +64,7 @@ function update_script() {
 | 
			
		||||
 | 
			
		||||
    msg_info "Cleaning up"
 | 
			
		||||
    rm -rf /opt/LubeLogger_v${RELEASE_TRIMMED}_linux_x64.zip
 | 
			
		||||
    rm -rf /tmp/lubeloggerData
 | 
			
		||||
    msg_ok "Cleaned"
 | 
			
		||||
    msg_ok "Updated Successfully"
 | 
			
		||||
  else
 | 
			
		||||
@@ -71,4 +80,4 @@ description
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:5000${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:5000${CL}"
 | 
			
		||||
 
 | 
			
		||||
@@ -34,6 +34,7 @@ function update_script() {
 | 
			
		||||
  fi
 | 
			
		||||
  msg_info "Updating $APP (Patience)"
 | 
			
		||||
  cd /opt/memos
 | 
			
		||||
  git reset --hard HEAD
 | 
			
		||||
  output=$(git pull --no-rebase)
 | 
			
		||||
  if echo "$output" | grep -q "Already up to date."; then
 | 
			
		||||
    msg_ok "$APP is already up to date."
 | 
			
		||||
@@ -60,4 +61,4 @@ description
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:9030${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:9030${CL}"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										81
									
								
								ct/pf2etools.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								ct/pf2etools.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,81 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: TheRealVira
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
# Source: https://pf2etools.com/
 | 
			
		||||
 | 
			
		||||
# App Default Values
 | 
			
		||||
APP="Pf2eTools"
 | 
			
		||||
var_tags="wiki"
 | 
			
		||||
var_cpu="1"
 | 
			
		||||
var_ram="512"
 | 
			
		||||
var_disk="6"
 | 
			
		||||
var_os="debian"
 | 
			
		||||
var_version="12"
 | 
			
		||||
var_unprivileged="1"
 | 
			
		||||
 | 
			
		||||
# App Output & Base Settings
 | 
			
		||||
header_info "$APP"
 | 
			
		||||
base_settings
 | 
			
		||||
 | 
			
		||||
# Core
 | 
			
		||||
variables
 | 
			
		||||
color
 | 
			
		||||
catch_errors
 | 
			
		||||
 | 
			
		||||
function update_script() {
 | 
			
		||||
    header_info
 | 
			
		||||
    check_container_storage
 | 
			
		||||
    check_container_resources
 | 
			
		||||
 | 
			
		||||
    # Check if installation is present | -f for file, -d for folder
 | 
			
		||||
    if [[ ! -d "/opt/${APP}" ]]; then
 | 
			
		||||
        msg_error "No ${APP} Installation Found!"
 | 
			
		||||
        exit
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    RELEASE=$(curl -s https://api.github.com/repos/Pf2eToolsOrg/Pf2eTools/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f "/opt/${APP}_version.txt" ]]; then
 | 
			
		||||
        # Crawling the new version and checking whether an update is required
 | 
			
		||||
        msg_info "Updating System"
 | 
			
		||||
        apt-get update &>/dev/null
 | 
			
		||||
        apt-get -y upgrade &>/dev/null
 | 
			
		||||
        msg_ok "Updated System"
 | 
			
		||||
 | 
			
		||||
        # Execute Update
 | 
			
		||||
        msg_info "Updating ${APP}"
 | 
			
		||||
        cd /opt
 | 
			
		||||
        wget -q "https://github.com/Pf2eToolsOrg/Pf2eTools/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
        unzip -q ${RELEASE}.zip
 | 
			
		||||
        rm -rf "/opt/${APP}"
 | 
			
		||||
        mv ${APP}-${RELEASE:1} /opt/${APP}
 | 
			
		||||
        cd /opt/Pf2eTools
 | 
			
		||||
        $STD npm install
 | 
			
		||||
        $STD npm run build
 | 
			
		||||
        echo "${RELEASE}" >"/opt/${APP}_version.txt"
 | 
			
		||||
        msg_ok "Updated ${APP}"
 | 
			
		||||
 | 
			
		||||
        chown -R www-data: "/opt/${APP}"
 | 
			
		||||
        chmod -R 755 "/opt/${APP}"
 | 
			
		||||
 | 
			
		||||
        # Cleaning up
 | 
			
		||||
        msg_info "Cleaning Up"
 | 
			
		||||
        rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
        $STD apt-get -y autoremove
 | 
			
		||||
        $STD apt-get -y autoclean
 | 
			
		||||
        msg_ok "Cleanup Completed"
 | 
			
		||||
    else
 | 
			
		||||
        msg_ok "No update required. ${APP} is already at ${RELEASE}"
 | 
			
		||||
    fi
 | 
			
		||||
    exit
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
start
 | 
			
		||||
build_container
 | 
			
		||||
description
 | 
			
		||||
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}${CL}"
 | 
			
		||||
							
								
								
									
										54
									
								
								ct/typesense.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								ct/typesense.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,54 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: tlissak | Co-Author MickLesk
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
# Source: https://typesense.org/
 | 
			
		||||
 | 
			
		||||
# App Default Values
 | 
			
		||||
APP="TypeSense"
 | 
			
		||||
var_tags="database"
 | 
			
		||||
var_cpu="1"
 | 
			
		||||
var_ram="1024"
 | 
			
		||||
var_disk="4"
 | 
			
		||||
var_os="debian"
 | 
			
		||||
var_version="12"
 | 
			
		||||
var_unprivileged="1"
 | 
			
		||||
 | 
			
		||||
# App Output & Base Settings
 | 
			
		||||
header_info "$APP"
 | 
			
		||||
base_settings
 | 
			
		||||
 | 
			
		||||
# Core
 | 
			
		||||
variables
 | 
			
		||||
color
 | 
			
		||||
catch_errors
 | 
			
		||||
 | 
			
		||||
function update_script() {
 | 
			
		||||
    header_info
 | 
			
		||||
    check_container_storage
 | 
			
		||||
    check_container_resources
 | 
			
		||||
    if [[ ! -f /etc/typesense/typesense-server.ini ]]; then
 | 
			
		||||
        msg_error "No ${APP} Installation Found!"
 | 
			
		||||
        exit
 | 
			
		||||
    fi
 | 
			
		||||
    RELEASE=$(curl -s https://api.github.com/repos/typesense/typesense/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
			
		||||
    if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then
 | 
			
		||||
        msg_info "Updating ${APP} LXC"
 | 
			
		||||
        apt-get update &>/dev/null
 | 
			
		||||
        apt-get -y upgrade &>/dev/null
 | 
			
		||||
        msg_ok "Updated Successfully"
 | 
			
		||||
    else
 | 
			
		||||
        msg_ok "No update required. ${APP} is already at ${RELEASE}"
 | 
			
		||||
    fi
 | 
			
		||||
    exit
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
start
 | 
			
		||||
build_container
 | 
			
		||||
description
 | 
			
		||||
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following IP:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}${IP}:8108${CL}"
 | 
			
		||||
@@ -41,7 +41,7 @@ function update_script() {
 | 
			
		||||
    cp /etc/zabbix/zabbix_server.conf /opt/zabbix-backup/
 | 
			
		||||
    cp /etc/apache2/conf-enabled/zabbix.conf /opt/zabbix-backup/
 | 
			
		||||
    cp -R /usr/share/zabbix/ /opt/zabbix-backup/
 | 
			
		||||
    cp -R /usr/share/zabbix-* /opt/zabbix-backup/
 | 
			
		||||
    #cp -R /usr/share/zabbix-* /opt/zabbix-backup/ Remove temporary
 | 
			
		||||
    rm -Rf /etc/apt/sources.list.d/zabbix.list
 | 
			
		||||
    cd /tmp
 | 
			
		||||
    wget -q https://repo.zabbix.com/zabbix/7.2/release/debian/pool/main/z/zabbix-release/zabbix-release_latest+debian12_all.deb
 | 
			
		||||
 
 | 
			
		||||
@@ -28,7 +28,7 @@ function update_script() {
 | 
			
		||||
    header_info
 | 
			
		||||
    check_container_storage
 | 
			
		||||
    check_container_resources
 | 
			
		||||
    if [[ ! -d /opt/zamad ]]; then
 | 
			
		||||
    if [[ ! -d /opt/zammad ]]; then
 | 
			
		||||
        msg_error "No ${APP} Installation Found!"
 | 
			
		||||
        exit
 | 
			
		||||
    fi
 | 
			
		||||
 
 | 
			
		||||
@@ -32,91 +32,35 @@ function update_script() {
 | 
			
		||||
    msg_error "No ${APP} Installation Found!"
 | 
			
		||||
    exit
 | 
			
		||||
  fi
 | 
			
		||||
  if [[ "$(node -v | cut -d 'v' -f 2)" == "18."* ]]; then
 | 
			
		||||
    if ! command -v npm >/dev/null 2>&1; then
 | 
			
		||||
      echo "Installing NPM..."
 | 
			
		||||
      apt-get install -y npm >/dev/null 2>&1
 | 
			
		||||
      echo "Installed NPM..."
 | 
			
		||||
    fi
 | 
			
		||||
  RELEASE=$(curl -s https://api.github.com/repos/Koenkk/zigbee2mqtt/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
  if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then
 | 
			
		||||
    msg_info "Stopping Service"
 | 
			
		||||
    systemctl stop zigbee2mqtt
 | 
			
		||||
    msg_ok "Stopped Service"
 | 
			
		||||
 | 
			
		||||
    msg_info "Creating Backup"
 | 
			
		||||
    mkdir -p /opt/z2m_backup
 | 
			
		||||
    tar -czf /opt/z2m_backup/${APP}_backup_$(date +%Y%m%d%H%M%S).tar.gz -C /opt zigbee2mqtt &>/dev/null
 | 
			
		||||
    mv /opt/zigbee2mqtt/data /opt/z2m_backup
 | 
			
		||||
    msg_ok "Backup Created"
 | 
			
		||||
 | 
			
		||||
    msg_info "Updating ${APP} to v${RELEASE}"
 | 
			
		||||
    cd /opt
 | 
			
		||||
    wget -q "https://github.com/Koenkk/zigbee2mqtt/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
    unzip -q ${RELEASE}.zip
 | 
			
		||||
    mv zigbee2mqtt-${RELEASE} /opt/zigbee2mqtt
 | 
			
		||||
    rm -rf /opt/zigbee2mqtt/data
 | 
			
		||||
    mv /opt/z2m_backup/data /opt/zigbee2mqtt
 | 
			
		||||
    cd /opt/zigbee2mqtt 
 | 
			
		||||
    pnpm install --frozen-lockfile &>/dev/null
 | 
			
		||||
    pnpm build &>/dev/null
 | 
			
		||||
    msg_info "Starting Service"
 | 
			
		||||
    systemctl start zigbee2mqtt
 | 
			
		||||
    msg_ok "Started Service"
 | 
			
		||||
    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
			
		||||
  else
 | 
			
		||||
    msg_ok "No update required. ${APP} is already at v${RELEASE}."
 | 
			
		||||
  fi
 | 
			
		||||
  cd /opt/zigbee2mqtt
 | 
			
		||||
 | 
			
		||||
  stop_zigbee2mqtt() {
 | 
			
		||||
    if which systemctl 2>/dev/null >/dev/null; then
 | 
			
		||||
      echo "Shutting down Zigbee2MQTT..."
 | 
			
		||||
      sudo systemctl stop zigbee2mqtt
 | 
			
		||||
    else
 | 
			
		||||
      echo "Skipped stopping Zigbee2MQTT, no systemctl found"
 | 
			
		||||
    fi
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  start_zigbee2mqtt() {
 | 
			
		||||
    if which systemctl 2>/dev/null >/dev/null; then
 | 
			
		||||
      echo "Starting Zigbee2MQTT..."
 | 
			
		||||
      sudo systemctl start zigbee2mqtt
 | 
			
		||||
    else
 | 
			
		||||
      echo "Skipped starting Zigbee2MQTT, no systemctl found"
 | 
			
		||||
    fi
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  set -e
 | 
			
		||||
 | 
			
		||||
  if [ -d data-backup ]; then
 | 
			
		||||
    echo "ERROR: Backup directory exists. May be previous restoring was failed?"
 | 
			
		||||
    echo "1. Save 'data-backup' and 'data' dirs to safe location to make possibility to restore config later."
 | 
			
		||||
    echo "2. Manually delete 'data-backup' dir and try again."
 | 
			
		||||
    exit 1
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  stop_zigbee2mqtt
 | 
			
		||||
 | 
			
		||||
  echo "Generating a backup of the configuration..."
 | 
			
		||||
  cp -R data data-backup || {
 | 
			
		||||
    echo "Failed to create backup."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  echo "Checking if any changes were made to package-lock.json..."
 | 
			
		||||
  git checkout package-lock.json || {
 | 
			
		||||
    echo "Failed to check package-lock.json."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  echo "Initiating update..."
 | 
			
		||||
  if ! git pull; then
 | 
			
		||||
    echo "Update failed, temporarily storing changes and trying again."
 | 
			
		||||
    git stash && git pull || (
 | 
			
		||||
      echo "Update failed even after storing changes. Aborting."
 | 
			
		||||
      exit 1
 | 
			
		||||
    )
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  echo "Acquiring necessary components..."
 | 
			
		||||
  npm ci || {
 | 
			
		||||
    echo "Failed to install necessary components."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  echo "Building..."
 | 
			
		||||
  npm run build || {
 | 
			
		||||
    echo "Failed to build new version."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  echo "Restoring configuration..."
 | 
			
		||||
  cp -R data-backup/* data || {
 | 
			
		||||
    echo "Failed to restore configuration."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  rm -rf data-backup || {
 | 
			
		||||
    echo "Failed to remove backup directory."
 | 
			
		||||
    exit 1
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  start_zigbee2mqtt
 | 
			
		||||
 | 
			
		||||
  echo "Done!"
 | 
			
		||||
  exit
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -127,4 +71,4 @@ description
 | 
			
		||||
msg_ok "Completed Successfully!\n"
 | 
			
		||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
			
		||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:9442${CL}"
 | 
			
		||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:9442${CL}"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										107
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										107
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -31,7 +31,7 @@
 | 
			
		||||
        "fuse.js": "^7.0.0",
 | 
			
		||||
        "lucide-react": "^0.453.0",
 | 
			
		||||
        "mini-svg-data-uri": "^1.4.4",
 | 
			
		||||
        "next": "15.0.2",
 | 
			
		||||
        "next": "15.1.3",
 | 
			
		||||
        "next-themes": "^0.3.0",
 | 
			
		||||
        "nuqs": "^2.1.1",
 | 
			
		||||
        "pocketbase": "^0.21.4",
 | 
			
		||||
@@ -1556,10 +1556,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/env": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/env/-/env-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-c0Zr0ModK5OX7D4ZV8Jt/wqoXtitLNPwUfG9zElCZztdaZyNVnN40rDXVZ/+FGuR4CcNV5AEfM6N8f+Ener7Dg==",
 | 
			
		||||
      "license": "MIT"
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/env/-/env-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-Q1tXwQCGWyA3ehMph3VO+E6xFPHDKdHFYosadt0F78EObYxPio0S09H9UGYznDe6Wc8eLKLG89GqcFJJDiK5xw=="
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/eslint-plugin-next": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
@@ -1602,13 +1601,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-darwin-arm64": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-GK+8w88z+AFlmt+ondytZo2xpwlfAR8U6CRwXancHImh6EdGfHMIrTSCcx5sOSBei00GyLVL0ioo1JLKTfprgg==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-aZtmIh8jU89DZahXQt1La0f2EMPt/i7W+rG1sLtYJERsP7GRnNFghsciFpQcKHcGh4dUiyTB5C1X3Dde/Gw8gg==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "arm64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "darwin"
 | 
			
		||||
@@ -1618,13 +1616,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-darwin-x64": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-KUpBVxIbjzFiUZhiLIpJiBoelqzQtVZbdNNsehhUn36e2YzKHphnK8eTUW1s/4aPy5kH/UTid8IuVbaOpedhpw==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-aw8901rjkVBK5mbq5oV32IqkJg+CQa6aULNlN8zyCWSsePzEG3kpDkAFkkTOh3eJ0p95KbkLyWBzslQKamXsLA==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "x64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "darwin"
 | 
			
		||||
@@ -1634,13 +1631,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-linux-arm64-gnu": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-9J7TPEcHNAZvwxXRzOtiUvwtTD+fmuY0l7RErf8Yyc7kMpE47MIQakl+3jecmkhOoIyi/Rp+ddq7j4wG6JDskQ==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-YbdaYjyHa4fPK4GR4k2XgXV0p8vbU1SZh7vv6El4bl9N+ZSiMfbmqCuCuNU1Z4ebJMumafaz6UCC2zaJCsdzjw==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "arm64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "linux"
 | 
			
		||||
@@ -1650,13 +1646,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-linux-arm64-musl": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-BjH4ZSzJIoTTZRh6rG+a/Ry4SW0HlizcPorqNBixBWc3wtQtj4Sn9FnRZe22QqrPnzoaW0ctvSz4FaH4eGKMww==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-qgH/aRj2xcr4BouwKG3XdqNu33SDadqbkqB6KaZZkozar857upxKakbRllpqZgWl/NDeSCBYPmUAZPBHZpbA0w==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "arm64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "linux"
 | 
			
		||||
@@ -1666,13 +1661,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-linux-x64-gnu": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-i3U2TcHgo26sIhcwX/Rshz6avM6nizrZPvrDVDY1bXcLH1ndjbO8zuC7RoHp0NSK7wjJMPYzm7NYL1ksSKFreA==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-uzafnTFwZCPN499fNVnS2xFME8WLC9y7PLRs/yqz5lz1X/ySoxfaK2Hbz74zYUdEg+iDZPd8KlsWaw9HKkLEVw==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "x64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "linux"
 | 
			
		||||
@@ -1682,13 +1676,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-linux-x64-musl": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-AMfZfSVOIR8fa+TXlAooByEF4OB00wqnms1sJ1v+iu8ivwvtPvnkwdzzFMpsK5jA2S9oNeeQ04egIWVb4QWmtQ==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-el6GUFi4SiDYnMTTlJJFMU+GHvw0UIFnffP1qhurrN1qJV3BqaSRUjkDUgVV44T6zpw1Lc6u+yn0puDKHs+Sbw==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "x64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "linux"
 | 
			
		||||
@@ -1698,13 +1691,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-win32-arm64-msvc": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-JkXysDT0/hEY47O+Hvs8PbZAeiCQVxKfGtr4GUpNAhlG2E0Mkjibuo8ryGD29Qb5a3IOnKYNoZlh/MyKd2Nbww==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-6RxKjvnvVMM89giYGI1qye9ODsBQpHSHVo8vqA8xGhmRPZHDQUE4jcDbhBwK0GnFMqBnu+XMg3nYukNkmLOLWw==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "arm64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "win32"
 | 
			
		||||
@@ -1714,13 +1706,12 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@next/swc-win32-x64-msvc": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-foaUL0NqJY/dX0Pi/UcZm5zsmSk5MtP/gxx3xOPyREkMFN+CTjctPfu3QaqrQHinaKdPnMWPJDKt4VjDfTBe/Q==",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-VId/f5blObG7IodwC5Grf+aYP0O8Saz1/aeU3YcWqNdIUAmFQY3VEPKPaIzfv32F/clvanOb2K2BR5DtDs6XyQ==",
 | 
			
		||||
      "cpu": [
 | 
			
		||||
        "x64"
 | 
			
		||||
      ],
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "optional": true,
 | 
			
		||||
      "os": [
 | 
			
		||||
        "win32"
 | 
			
		||||
@@ -3024,12 +3015,11 @@
 | 
			
		||||
      "license": "Apache-2.0"
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@swc/helpers": {
 | 
			
		||||
      "version": "0.5.13",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.13.tgz",
 | 
			
		||||
      "integrity": "sha512-UoKGxQ3r5kYI9dALKJapMmuK+1zWM/H17Z1+iwnNmzcJRnfFuevZs375TA5rW31pu4BS4NoSy1fRsexDXfWn5w==",
 | 
			
		||||
      "license": "Apache-2.0",
 | 
			
		||||
      "version": "0.5.15",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.15.tgz",
 | 
			
		||||
      "integrity": "sha512-JQ5TuMi45Owi4/BIMAJBoSQoOJu12oOk/gADqlcUL9JEdHB8vyjUSsxqeNXnmXHjYKMi2WcYtezGEEhqUI/E2g==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "tslib": "^2.4.0"
 | 
			
		||||
        "tslib": "^2.8.0"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@testing-library/dom": {
 | 
			
		||||
@@ -7104,14 +7094,13 @@
 | 
			
		||||
      "license": "MIT"
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/next": {
 | 
			
		||||
      "version": "15.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/next/-/next-15.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-rxIWHcAu4gGSDmwsELXacqAPUk+j8dV/A9cDF5fsiCMpkBDYkO2AEaL1dfD+nNmDiU6QMCFN8Q30VEKapT9UHQ==",
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "version": "15.1.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/next/-/next-15.1.3.tgz",
 | 
			
		||||
      "integrity": "sha512-5igmb8N8AEhWDYzogcJvtcRDU6n4cMGtBklxKD4biYv4LXN8+awc/bbQ2IM2NQHdVPgJ6XumYXfo3hBtErg1DA==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@next/env": "15.0.2",
 | 
			
		||||
        "@next/env": "15.1.3",
 | 
			
		||||
        "@swc/counter": "0.1.3",
 | 
			
		||||
        "@swc/helpers": "0.5.13",
 | 
			
		||||
        "@swc/helpers": "0.5.15",
 | 
			
		||||
        "busboy": "1.6.0",
 | 
			
		||||
        "caniuse-lite": "^1.0.30001579",
 | 
			
		||||
        "postcss": "8.4.31",
 | 
			
		||||
@@ -7121,25 +7110,25 @@
 | 
			
		||||
        "next": "dist/bin/next"
 | 
			
		||||
      },
 | 
			
		||||
      "engines": {
 | 
			
		||||
        "node": ">=18.18.0"
 | 
			
		||||
        "node": "^18.18.0 || ^19.8.0 || >= 20.0.0"
 | 
			
		||||
      },
 | 
			
		||||
      "optionalDependencies": {
 | 
			
		||||
        "@next/swc-darwin-arm64": "15.0.2",
 | 
			
		||||
        "@next/swc-darwin-x64": "15.0.2",
 | 
			
		||||
        "@next/swc-linux-arm64-gnu": "15.0.2",
 | 
			
		||||
        "@next/swc-linux-arm64-musl": "15.0.2",
 | 
			
		||||
        "@next/swc-linux-x64-gnu": "15.0.2",
 | 
			
		||||
        "@next/swc-linux-x64-musl": "15.0.2",
 | 
			
		||||
        "@next/swc-win32-arm64-msvc": "15.0.2",
 | 
			
		||||
        "@next/swc-win32-x64-msvc": "15.0.2",
 | 
			
		||||
        "@next/swc-darwin-arm64": "15.1.3",
 | 
			
		||||
        "@next/swc-darwin-x64": "15.1.3",
 | 
			
		||||
        "@next/swc-linux-arm64-gnu": "15.1.3",
 | 
			
		||||
        "@next/swc-linux-arm64-musl": "15.1.3",
 | 
			
		||||
        "@next/swc-linux-x64-gnu": "15.1.3",
 | 
			
		||||
        "@next/swc-linux-x64-musl": "15.1.3",
 | 
			
		||||
        "@next/swc-win32-arm64-msvc": "15.1.3",
 | 
			
		||||
        "@next/swc-win32-x64-msvc": "15.1.3",
 | 
			
		||||
        "sharp": "^0.33.5"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependencies": {
 | 
			
		||||
        "@opentelemetry/api": "^1.1.0",
 | 
			
		||||
        "@playwright/test": "^1.41.2",
 | 
			
		||||
        "babel-plugin-react-compiler": "*",
 | 
			
		||||
        "react": "^18.2.0 || 19.0.0-rc-02c0e824-20241028",
 | 
			
		||||
        "react-dom": "^18.2.0 || 19.0.0-rc-02c0e824-20241028",
 | 
			
		||||
        "react": "^18.2.0 || 19.0.0-rc-de68d2f4-20241204 || ^19.0.0",
 | 
			
		||||
        "react-dom": "^18.2.0 || 19.0.0-rc-de68d2f4-20241204 || ^19.0.0",
 | 
			
		||||
        "sass": "^1.3.0"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependenciesMeta": {
 | 
			
		||||
 
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
    "fuse.js": "^7.0.0",
 | 
			
		||||
    "lucide-react": "^0.453.0",
 | 
			
		||||
    "mini-svg-data-uri": "^1.4.4",
 | 
			
		||||
    "next": "15.0.2",
 | 
			
		||||
    "next": "15.1.3",
 | 
			
		||||
    "next-themes": "^0.3.0",
 | 
			
		||||
    "nuqs": "^2.1.1",
 | 
			
		||||
    "pocketbase": "^0.21.4",
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										83
									
								
								install/5etools-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								install/5etools-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,83 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: TheRealVira
 | 
			
		||||
# License: MIT
 | 
			
		||||
# Source: https://5e.tools/
 | 
			
		||||
 | 
			
		||||
# Import Functions und Setup
 | 
			
		||||
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | 
			
		||||
color
 | 
			
		||||
verb_ip6
 | 
			
		||||
catch_errors
 | 
			
		||||
setting_up_container
 | 
			
		||||
network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  curl \
 | 
			
		||||
  mc \
 | 
			
		||||
  sudo \
 | 
			
		||||
  git \
 | 
			
		||||
  gpg \
 | 
			
		||||
  ca-certificates \
 | 
			
		||||
  apache2
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Node.js Repository"
 | 
			
		||||
mkdir -p /etc/apt/keyrings
 | 
			
		||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
			
		||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_20.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
 | 
			
		||||
msg_ok "Set up Node.js Repository"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Node.js"
 | 
			
		||||
$STD apt-get update
 | 
			
		||||
$STD apt-get install -y nodejs
 | 
			
		||||
msg_ok "Installed Node.js"
 | 
			
		||||
 | 
			
		||||
# Setup App
 | 
			
		||||
msg_info "Set up 5etools Base"
 | 
			
		||||
cd /opt
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/5etools-mirror-3/5etools-src/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
wget -q "https://github.com/5etools-mirror-3/5etools-src/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
unzip -q "${RELEASE}.zip"
 | 
			
		||||
mv "5etools-src-${RELEASE:1}" /opt/5etools
 | 
			
		||||
cd /opt/5etools
 | 
			
		||||
$STD npm install
 | 
			
		||||
$STD npm run build
 | 
			
		||||
echo "${RELEASE}" >"/opt/5etools_version.txt"
 | 
			
		||||
msg_ok "Set up 5etools Base"
 | 
			
		||||
 | 
			
		||||
msg_info "Set up 5etools Image"
 | 
			
		||||
cd /opt
 | 
			
		||||
IMG_RELEASE=$(curl -s https://api.github.com/repos/5etools-mirror-2/5etools-img/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
curl -sSL "https://github.com/5etools-mirror-2/5etools-img/archive/refs/tags/${IMG_RELEASE}.zip" > "${IMG_RELEASE}.zip"
 | 
			
		||||
unzip -q "${IMG_RELEASE}.zip"
 | 
			
		||||
mv "5etools-img-${IMG_RELEASE:1}" /opt/5etools/img
 | 
			
		||||
echo "${IMG_RELEASE}" >"/opt/5etools_IMG_version.txt"
 | 
			
		||||
msg_ok "Set up 5etools Image"
 | 
			
		||||
 | 
			
		||||
msg_info "Creating Service"
 | 
			
		||||
cat <<EOF >> /etc/apache2/apache2.conf
 | 
			
		||||
<Location /server-status>
 | 
			
		||||
    SetHandler server-status
 | 
			
		||||
    Order deny,allow
 | 
			
		||||
    Allow from all
 | 
			
		||||
</Location>
 | 
			
		||||
EOF
 | 
			
		||||
rm -rf /var/www/html
 | 
			
		||||
ln -s "/opt/5etools" /var/www/html
 | 
			
		||||
chown -R www-data: "/opt/5etools"
 | 
			
		||||
chmod -R 755 "/opt/5etools"
 | 
			
		||||
msg_ok "Created Service"
 | 
			
		||||
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/${IMG_RELEASE}.zip
 | 
			
		||||
rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
 | 
			
		||||
motd_ssh
 | 
			
		||||
customize
 | 
			
		||||
@@ -28,241 +28,46 @@ RELEASE=$(curl -s https://api.github.com/repos/0xERR0R/blocky/releases/latest |
 | 
			
		||||
wget -qO- https://github.com/0xERR0R/blocky/releases/download/v${RELEASE}/blocky_v${RELEASE}_Linux_x86_64.tar.gz | tar -xzf - -C /opt/blocky/
 | 
			
		||||
 | 
			
		||||
cat <<EOF >/opt/blocky/config.yml
 | 
			
		||||
upstream:
 | 
			
		||||
  # these external DNS resolvers will be used. Blocky picks 2 random resolvers from the list for each query
 | 
			
		||||
  # format for resolver: [net:]host:[port][/path]. net could be empty (default, shortcut for tcp+udp), tcp+udp, tcp, udp, tcp-tls or https (DoH). If port is empty, default port will be used (53 for udp and tcp, 853 for tcp-tls, 443 for https (Doh))
 | 
			
		||||
  # this configuration is mandatory, please define at least one external DNS resolver
 | 
			
		||||
  default:
 | 
			
		||||
    # example for tcp+udp IPv4 server (https://digitalcourage.de/)
 | 
			
		||||
    #- 5.9.164.112
 | 
			
		||||
    # Cloudflare
 | 
			
		||||
    - 1.1.1.1
 | 
			
		||||
    # example for DNS-over-TLS server (DoT)
 | 
			
		||||
    #- tcp-tls:fdns1.dismail.de:853
 | 
			
		||||
    # example for DNS-over-HTTPS (DoH)
 | 
			
		||||
    #- https://dns.digitale-gesellschaft.ch/dns-query
 | 
			
		||||
  # optional: use client name (with wildcard support: * - sequence of any characters, [0-9] - range)
 | 
			
		||||
  # or single ip address / client subnet as CIDR notation
 | 
			
		||||
  #laptop*:
 | 
			
		||||
    #- 123.123.123.123
 | 
			
		||||
# configuration documentation: https://0xerr0r.github.io/blocky/latest/configuration/
 | 
			
		||||
 | 
			
		||||
# optional: timeout to query the upstream resolver. Default: 2s
 | 
			
		||||
#upstreamTimeout: 2s
 | 
			
		||||
upstreams:
 | 
			
		||||
  groups:
 | 
			
		||||
    # these external DNS resolvers will be used. Blocky picks 2 random resolvers from the list for each query
 | 
			
		||||
    # format for resolver: [net:]host:[port][/path]. net could be empty (default, shortcut for tcp+udp), tcp+udp, tcp, udp, tcp-tls or https (DoH). If port is empty, default port will be used (53 for udp and tcp, 853 for tcp-tls, 443 for https (Doh))
 | 
			
		||||
    # this configuration is mandatory, please define at least one external DNS resolver
 | 
			
		||||
    default:
 | 
			
		||||
      # Cloudflare
 | 
			
		||||
      - 1.1.1.1
 | 
			
		||||
      # Quad9 DNS-over-TLS server (DoT)
 | 
			
		||||
      - tcp-tls:dns.quad9.net
 | 
			
		||||
 | 
			
		||||
# optional: If true, blocky will fail to start unless at least one upstream server per group is reachable. Default: false
 | 
			
		||||
#startVerifyUpstream: true
 | 
			
		||||
 | 
			
		||||
# optional: Determines how blocky will create outgoing connections. This impacts both upstreams, and lists.
 | 
			
		||||
# accepted: dual, v4, v6
 | 
			
		||||
# default: dual
 | 
			
		||||
#connectIPVersion: dual
 | 
			
		||||
 | 
			
		||||
# optional: custom IP address(es) for domain name (with all sub-domains). Multiple addresses must be separated by a comma
 | 
			
		||||
# example: query "printer.lan" or "my.printer.lan" will return 192.168.178.3
 | 
			
		||||
#customDNS:
 | 
			
		||||
  #customTTL: 1h
 | 
			
		||||
  # optional: if true (default), return empty result for unmapped query types (for example TXT, MX or AAAA if only IPv4 address is defined).
 | 
			
		||||
  # if false, queries with unmapped types will be forwarded to the upstream resolver
 | 
			
		||||
  #filterUnmappedTypes: true
 | 
			
		||||
  # optional: replace domain in the query with other domain before resolver lookup in the mapping
 | 
			
		||||
  #rewrite:
 | 
			
		||||
    #example.com: printer.lan
 | 
			
		||||
  #mapping:
 | 
			
		||||
    #printer.lan: 192.168.178.3,2001:0db8:85a3:08d3:1319:8a2e:0370:7344
 | 
			
		||||
 | 
			
		||||
# optional: definition, which DNS resolver(s) should be used for queries to the domain (with all sub-domains). Multiple resolvers must be separated by a comma
 | 
			
		||||
# Example: Query client.fritz.box will ask DNS server 192.168.178.1. This is necessary for local network, to resolve clients by host name
 | 
			
		||||
#conditional:
 | 
			
		||||
  # optional: if false (default), return empty result if after rewrite, the mapped resolver returned an empty answer. If true, the original query will be sent to the upstream resolver
 | 
			
		||||
  # Example: The query "blog.example.com" will be rewritten to "blog.fritz.box" and also redirected to the resolver at 192.168.178.1. If not found and if  was set to , the original query "blog.example.com" will be sent upstream.
 | 
			
		||||
  # Usage: One usecase when having split DNS for internal and external (internet facing) users, but not all subdomains are listed in the internal domain.
 | 
			
		||||
  #fallbackUpstream: false
 | 
			
		||||
  # optional: replace domain in the query with other domain before resolver lookup in the mapping
 | 
			
		||||
  #rewrite:
 | 
			
		||||
    #example.com: fritz.box
 | 
			
		||||
  #mapping:
 | 
			
		||||
    #fritz.box: 192.168.178.1
 | 
			
		||||
    #lan.net: 192.168.178.1,192.168.178.2
 | 
			
		||||
 | 
			
		||||
# optional: use black and white lists to block queries (for example ads, trackers, adult pages etc.)
 | 
			
		||||
# optional: use allow/denylists to block queries (for example ads, trackers, adult pages etc.)
 | 
			
		||||
blocking:
 | 
			
		||||
  # definition of blacklist groups. Can be external link (http/https) or local file
 | 
			
		||||
  blackLists:
 | 
			
		||||
  # definition of denylist groups. Can be external link (http/https) or local file
 | 
			
		||||
  denylists:
 | 
			
		||||
    ads:
 | 
			
		||||
      - https://s3.amazonaws.com/lists.disconnect.me/simple_ad.txt
 | 
			
		||||
      - https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts
 | 
			
		||||
      - http://sysctl.org/cameleon/hosts
 | 
			
		||||
      - https://s3.amazonaws.com/lists.disconnect.me/simple_tracking.txt
 | 
			
		||||
      - |
 | 
			
		||||
        # inline definition with YAML literal block scalar style
 | 
			
		||||
        # hosts format
 | 
			
		||||
        someadsdomain.com
 | 
			
		||||
    special:
 | 
			
		||||
      - https://raw.githubusercontent.com/StevenBlack/hosts/master/alternates/fakenews/hosts
 | 
			
		||||
  # definition of whitelist groups. Attention: if the same group has black and whitelists, whitelists will be used to disable particular blacklist entries. If a group has only whitelist entries -> this means only domains from this list are allowed, all other domains will be blocked
 | 
			
		||||
  whiteLists:
 | 
			
		||||
    ads:
 | 
			
		||||
      - whitelist.txt
 | 
			
		||||
      - |
 | 
			
		||||
        # inline definition with YAML literal block scalar style
 | 
			
		||||
        # hosts format
 | 
			
		||||
        whitelistdomain.com
 | 
			
		||||
        # this is a regex
 | 
			
		||||
        /^banners?[_.-]/
 | 
			
		||||
  # definition: which groups should be applied for which client
 | 
			
		||||
  clientGroupsBlock:
 | 
			
		||||
    # default will be used, if no special definition for a client name exists
 | 
			
		||||
    default:
 | 
			
		||||
      - ads
 | 
			
		||||
      - special
 | 
			
		||||
    # use client name (with wildcard support: * - sequence of any characters, [0-9] - range)
 | 
			
		||||
    # or single ip address / client subnet as CIDR notation
 | 
			
		||||
    #laptop*:
 | 
			
		||||
      #- ads
 | 
			
		||||
    #192.168.178.1/24:
 | 
			
		||||
      #- special
 | 
			
		||||
  # which response will be sent, if query is blocked:
 | 
			
		||||
  # zeroIp: 0.0.0.0 will be returned (default)
 | 
			
		||||
  # nxDomain: return NXDOMAIN as return code
 | 
			
		||||
  # comma separated list of destination IP addresses (for example: 192.100.100.15, 2001:0db8:85a3:08d3:1319:8a2e:0370:7344). Should contain ipv4 and ipv6 to cover all query types. Useful with running web server on this address to display the "blocked" page.
 | 
			
		||||
  blockType: zeroIp
 | 
			
		||||
  # optional: TTL for answers to blocked domains
 | 
			
		||||
  # default: 6h
 | 
			
		||||
  blockTTL: 1m
 | 
			
		||||
  # optional: automatically list refresh period (in duration format). Default: 4h.
 | 
			
		||||
  # Negative value -> deactivate automatically refresh.
 | 
			
		||||
  # 0 value -> use default
 | 
			
		||||
  refreshPeriod: 4h
 | 
			
		||||
  # optional: timeout for list download (each url). Default: 60s. Use large values for big lists or slow internet connections
 | 
			
		||||
  downloadTimeout: 4m
 | 
			
		||||
  # optional: Download attempt timeout. Default: 60s
 | 
			
		||||
  downloadAttempts: 5
 | 
			
		||||
  # optional: Time between the download attempts. Default: 1s
 | 
			
		||||
  downloadCooldown: 10s
 | 
			
		||||
  # optional: if failOnError, application startup will fail if at least one list can't be downloaded / opened. Default: blocking
 | 
			
		||||
  #startStrategy: failOnError
 | 
			
		||||
 | 
			
		||||
# optional: configuration for caching of DNS responses
 | 
			
		||||
caching:
 | 
			
		||||
  # duration how long a response must be cached (min value).
 | 
			
		||||
  # If <=0, use response's TTL, if >0 use this value, if TTL is smaller
 | 
			
		||||
  # Default: 0
 | 
			
		||||
  minTime: 5m
 | 
			
		||||
  # duration how long a response must be cached (max value).
 | 
			
		||||
  # If <0, do not cache responses
 | 
			
		||||
  # If 0, use TTL
 | 
			
		||||
  # If > 0, use this value, if TTL is greater
 | 
			
		||||
  # Default: 0
 | 
			
		||||
  maxTime: 30m
 | 
			
		||||
  # Max number of cache entries (responses) to be kept in cache (soft limit). Useful on systems with limited amount of RAM.
 | 
			
		||||
  # Default (0): unlimited
 | 
			
		||||
  maxItemsCount: 0
 | 
			
		||||
  # if true, will preload DNS results for often used queries (default: names queried more than 5 times in a 2-hour time window)
 | 
			
		||||
  # this improves the response time for often used queries, but significantly increases external traffic
 | 
			
		||||
  # default: false
 | 
			
		||||
  prefetching: true
 | 
			
		||||
  # prefetch track time window (in duration format)
 | 
			
		||||
  # default: 120
 | 
			
		||||
  prefetchExpires: 2h
 | 
			
		||||
  # name queries threshold for prefetch
 | 
			
		||||
  # default: 5
 | 
			
		||||
  prefetchThreshold: 5
 | 
			
		||||
  # Max number of domains to be kept in cache for prefetching (soft limit). Useful on systems with limited amount of RAM.
 | 
			
		||||
  # Default (0): unlimited
 | 
			
		||||
  #prefetchMaxItemsCount: 0
 | 
			
		||||
 | 
			
		||||
# optional: configuration of client name resolution
 | 
			
		||||
clientLookup:
 | 
			
		||||
  # optional: this DNS resolver will be used to perform reverse DNS lookup (typically local router)
 | 
			
		||||
  #upstream: 192.168.178.1
 | 
			
		||||
  # optional: some routers return multiple names for client (host name and user defined name). Define which single name should be used.
 | 
			
		||||
  # Example: take second name if present, if not take first name
 | 
			
		||||
  #singleNameOrder:
 | 
			
		||||
    #- 2
 | 
			
		||||
    #- 1
 | 
			
		||||
  # optional: custom mapping of client name to IP addresses. Useful if reverse DNS does not work properly or just to have custom client names.
 | 
			
		||||
  #clients:
 | 
			
		||||
    #laptop:
 | 
			
		||||
      #- 192.168.178.29
 | 
			
		||||
# optional: configuration for prometheus metrics endpoint
 | 
			
		||||
prometheus:
 | 
			
		||||
  # enabled if true
 | 
			
		||||
  #enable: true
 | 
			
		||||
  # url path, optional (default '/metrics')
 | 
			
		||||
  #path: /metrics
 | 
			
		||||
 | 
			
		||||
# optional: write query information (question, answer, client, duration etc.) to daily csv file
 | 
			
		||||
queryLog:
 | 
			
		||||
  # optional one of: mysql, postgresql, csv, csv-client. If empty, log to console
 | 
			
		||||
  #type: mysql
 | 
			
		||||
  # directory (should be mounted as volume in docker) for csv, db connection string for mysql/postgresql
 | 
			
		||||
  #target: db_user:db_password@tcp(db_host_or_ip:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local
 | 
			
		||||
  #postgresql target: postgres://user:password@db_host_or_ip:5432/db_name
 | 
			
		||||
  # if > 0, deletes log files which are older than ... days
 | 
			
		||||
  #logRetentionDays: 7
 | 
			
		||||
  # optional: Max attempts to create specific query log writer, default: 3
 | 
			
		||||
  #creationAttempts: 1
 | 
			
		||||
  # optional: Time between the creation attempts, default: 2s
 | 
			
		||||
  #creationCooldown: 2s
 | 
			
		||||
  type:
 | 
			
		||||
 | 
			
		||||
# optional: Blocky can synchronize its cache and blocking state between multiple instances through redis.
 | 
			
		||||
redis:
 | 
			
		||||
  # Server address and port
 | 
			
		||||
  #address: redis:6379
 | 
			
		||||
  # Password if necessary
 | 
			
		||||
  #password: passwd
 | 
			
		||||
  # Database, default: 0
 | 
			
		||||
  #database: 2
 | 
			
		||||
  # Connection is required for blocky to start. Default: false
 | 
			
		||||
  #required: true
 | 
			
		||||
  # Max connection attempts, default: 3
 | 
			
		||||
  #connectionAttempts: 10
 | 
			
		||||
  # Time between the connection attempts, default: 1s
 | 
			
		||||
  #connectionCooldown: 3s
 | 
			
		||||
# optional: use these DNS servers to resolve denylist urls and upstream DNS servers. It is useful if no system DNS resolver is configured, and/or to encrypt the bootstrap queries.
 | 
			
		||||
bootstrapDns:
 | 
			
		||||
  - upstream: tcp-tls:one.one.one.one
 | 
			
		||||
    ips:
 | 
			
		||||
      - 1.1.1.1
 | 
			
		||||
 | 
			
		||||
# optional: DNS listener port(s) and bind ip address(es), default 53 (UDP and TCP). Example: 53, :53, "127.0.0.1:5353,[::1]:5353"
 | 
			
		||||
port: 553
 | 
			
		||||
# optional: Port(s) and bind ip address(es) for DoT (DNS-over-TLS) listener. Example: 853, 127.0.0.1:853
 | 
			
		||||
#tlsPort: 853
 | 
			
		||||
# optional: HTTPS listener port(s) and bind ip address(es), default empty = no http listener. If > 0, will be used for prometheus metrics, pprof, REST API, DoH... Example: 443, :443, 127.0.0.1:443
 | 
			
		||||
#httpPort: 4000
 | 
			
		||||
#httpsPort: 443
 | 
			
		||||
# optional: Mininal TLS version that the DoH and DoT server will use
 | 
			
		||||
#minTlsServeVersion: 1.3
 | 
			
		||||
# if https port > 0: path to cert and key file for SSL encryption. if not set, self-signed certificate will be generated
 | 
			
		||||
#certFile: server.crt
 | 
			
		||||
#keyFile: server.key
 | 
			
		||||
# optional: use this DNS server to resolve blacklist urls and upstream DNS servers. Useful if no DNS resolver is configured and blocky needs to resolve a host name. Format net:IP:port, net must be udp or tcp
 | 
			
		||||
#bootstrapDns: tcp+udp:1.1.1.1
 | 
			
		||||
 | 
			
		||||
filtering:
 | 
			
		||||
# optional: drop all queries with following query types. Default: empty
 | 
			
		||||
  #queryTypes:
 | 
			
		||||
    #- AAAA
 | 
			
		||||
 | 
			
		||||
# optional: if path defined, use this file for query resolution (A, AAAA and rDNS). Default: empty
 | 
			
		||||
hostsFile:
 | 
			
		||||
  # optional: Path to hosts file (e.g. /etc/hosts on Linux)
 | 
			
		||||
  #filePath: /etc/hosts
 | 
			
		||||
  # optional: TTL, default: 1h
 | 
			
		||||
  #hostsTTL: 60m
 | 
			
		||||
  # optional: Time between hosts file refresh, default: 1h
 | 
			
		||||
  #refreshPeriod: 30m
 | 
			
		||||
  # optional: Whether loopback hosts addresses (127.0.0.0/8 and ::1) should be filtered or not, default: false
 | 
			
		||||
  #filterLoopback: true
 | 
			
		||||
# optional: Log level (one from debug, info, warn, error). Default: info
 | 
			
		||||
#logLevel: info
 | 
			
		||||
# optional: Log format (text or json). Default: text
 | 
			
		||||
#logFormat: text
 | 
			
		||||
# optional: log timestamps. Default: true
 | 
			
		||||
#logTimestamp: true
 | 
			
		||||
# optional: obfuscate log output (replace all alphanumeric characters with *) for user sensitive data like request domains or responses to increase privacy. Default: false
 | 
			
		||||
#logPrivacy: false
 | 
			
		||||
 | 
			
		||||
# optional: add EDE error codes to dns response
 | 
			
		||||
#ede: 
 | 
			
		||||
  # enabled if true, Default: false
 | 
			
		||||
  #enable: true
 | 
			
		||||
# optional: logging configuration
 | 
			
		||||
log:
 | 
			
		||||
  # optional: Log level (one from trace, debug, info, warn, error). Default: info
 | 
			
		||||
  level: info
 | 
			
		||||
EOF
 | 
			
		||||
msg_ok "Installed Blocky"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -15,7 +15,7 @@ network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies (Patience)"
 | 
			
		||||
$STD apt-get install -y {curl,sudo,mc,git,gpg,automake,build-essential,xz-utils,libtool,ccache,pkg-config,libgtk-3-dev,libavcodec-dev,libavformat-dev,libswscale-dev,libv4l-dev,libxvidcore-dev,libx264-dev,libjpeg-dev,libpng-dev,libtiff-dev,gfortran,openexr,libatlas-base-dev,libssl-dev,libtbb2,libtbb-dev,libdc1394-22-dev,libopenexr-dev,libgstreamer-plugins-base1.0-dev,libgstreamer1.0-dev,gcc,gfortran,libopenblas-dev,liblapack-dev,libusb-1.0-0-dev,jq,moreutils}
 | 
			
		||||
$STD apt-get install -y {curl,sudo,mc,git,gpg,ca-certificates,automake,build-essential,xz-utils,libtool,ccache,pkg-config,libgtk-3-dev,libavcodec-dev,libavformat-dev,libswscale-dev,libv4l-dev,libxvidcore-dev,libx264-dev,libjpeg-dev,libpng-dev,libtiff-dev,gfortran,openexr,libatlas-base-dev,libssl-dev,libtbb2,libtbb-dev,libdc1394-22-dev,libopenexr-dev,libgstreamer-plugins-base1.0-dev,libgstreamer1.0-dev,gcc,gfortran,libopenblas-dev,liblapack-dev,libusb-1.0-0-dev,jq,moreutils}
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Python3 Dependencies"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										151
									
								
								install/glpi-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										151
									
								
								install/glpi-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,151 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: Nícolas Pastorello (opastorello)
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
 | 
			
		||||
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | 
			
		||||
color
 | 
			
		||||
verb_ip6
 | 
			
		||||
catch_errors
 | 
			
		||||
setting_up_container
 | 
			
		||||
network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  curl \
 | 
			
		||||
  git \
 | 
			
		||||
  sudo \
 | 
			
		||||
  mc \
 | 
			
		||||
  apache2 \
 | 
			
		||||
  php8.2-{apcu,cli,common,curl,gd,imap,ldap,mysql,xmlrpc,xml,mbstring,bcmath,intl,zip,redis,bz2,soap} \
 | 
			
		||||
  php-cas \
 | 
			
		||||
  libapache2-mod-php \
 | 
			
		||||
  mariadb-server
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up database"
 | 
			
		||||
DB_NAME=glpi_db
 | 
			
		||||
DB_USER=glpi
 | 
			
		||||
DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)
 | 
			
		||||
mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql mysql
 | 
			
		||||
mysql -u root -e "CREATE DATABASE $DB_NAME;"
 | 
			
		||||
mysql -u root -e "CREATE USER '$DB_USER'@'localhost' IDENTIFIED BY '$DB_PASS';"
 | 
			
		||||
mysql -u root -e "GRANT ALL PRIVILEGES ON $DB_NAME.* TO '$DB_USER'@'localhost';"
 | 
			
		||||
mysql -u root -e "GRANT SELECT ON \`mysql\`.\`time_zone_name\` TO '$DB_USER'@'localhost'; FLUSH PRIVILEGES;"
 | 
			
		||||
{
 | 
			
		||||
    echo "GLPI Database Credentials"
 | 
			
		||||
    echo "Database: $DB_NAME"
 | 
			
		||||
    echo "Username: $DB_USER"
 | 
			
		||||
    echo "Password: $DB_PASS"
 | 
			
		||||
} >> ~/glpi_db.creds
 | 
			
		||||
msg_ok "Set up database"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing GLPi"
 | 
			
		||||
cd /opt
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/glpi-project/glpi/releases/latest | grep '"tag_name"' | sed -E 's/.*"tag_name": "([^"]+)".*/\1/')
 | 
			
		||||
wget -q "https://github.com/glpi-project/glpi/releases/download/${RELEASE}/glpi-${RELEASE}.tgz"
 | 
			
		||||
$STD tar -xzvf glpi-${RELEASE}.tgz
 | 
			
		||||
cd /opt/glpi
 | 
			
		||||
$STD php bin/console db:install --db-name=$DB_NAME --db-user=$DB_USER --db-password=$DB_PASS --no-interaction
 | 
			
		||||
echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
 | 
			
		||||
msg_ok "Installed GLPi"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting Downstream file"
 | 
			
		||||
cat <<EOF > /opt/glpi/inc/downstream.php
 | 
			
		||||
<?php
 | 
			
		||||
define('GLPI_CONFIG_DIR', '/etc/glpi/');
 | 
			
		||||
if (file_exists(GLPI_CONFIG_DIR . '/local_define.php')) {
 | 
			
		||||
    require_once GLPI_CONFIG_DIR . '/local_define.php';
 | 
			
		||||
}
 | 
			
		||||
EOF
 | 
			
		||||
 | 
			
		||||
mv /opt/glpi/config /etc/glpi
 | 
			
		||||
mv /opt/glpi/files /var/lib/glpi
 | 
			
		||||
mv /var/lib/glpi/_log /var/log/glpi
 | 
			
		||||
 | 
			
		||||
cat <<EOF > /etc/glpi/local_define.php
 | 
			
		||||
<?php
 | 
			
		||||
define('GLPI_VAR_DIR', '/var/lib/glpi');
 | 
			
		||||
define('GLPI_DOC_DIR', GLPI_VAR_DIR);
 | 
			
		||||
define('GLPI_CRON_DIR', GLPI_VAR_DIR . '/_cron');
 | 
			
		||||
define('GLPI_DUMP_DIR', GLPI_VAR_DIR . '/_dumps');
 | 
			
		||||
define('GLPI_GRAPH_DIR', GLPI_VAR_DIR . '/_graphs');
 | 
			
		||||
define('GLPI_LOCK_DIR', GLPI_VAR_DIR . '/_lock');
 | 
			
		||||
define('GLPI_PICTURE_DIR', GLPI_VAR_DIR . '/_pictures');
 | 
			
		||||
define('GLPI_PLUGIN_DOC_DIR', GLPI_VAR_DIR . '/_plugins');
 | 
			
		||||
define('GLPI_RSS_DIR', GLPI_VAR_DIR . '/_rss');
 | 
			
		||||
define('GLPI_SESSION_DIR', GLPI_VAR_DIR . '/_sessions');
 | 
			
		||||
define('GLPI_TMP_DIR', GLPI_VAR_DIR . '/_tmp');
 | 
			
		||||
define('GLPI_UPLOAD_DIR', GLPI_VAR_DIR . '/_uploads');
 | 
			
		||||
define('GLPI_CACHE_DIR', GLPI_VAR_DIR . '/_cache');
 | 
			
		||||
define('GLPI_LOG_DIR', '/var/log/glpi');
 | 
			
		||||
EOF
 | 
			
		||||
msg_ok "Configured Downstream file"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting Folder and File Permissions"
 | 
			
		||||
chown root:root /opt/glpi/ -R
 | 
			
		||||
chown www-data:www-data /etc/glpi -R
 | 
			
		||||
chown www-data:www-data /var/lib/glpi -R
 | 
			
		||||
chown www-data:www-data /var/log/glpi -R
 | 
			
		||||
chown www-data:www-data /opt/glpi/marketplace -Rf
 | 
			
		||||
find /opt/glpi/ -type f -exec chmod 0644 {} \;
 | 
			
		||||
find /opt/glpi/ -type d -exec chmod 0755 {} \;
 | 
			
		||||
find /etc/glpi -type f -exec chmod 0644 {} \;
 | 
			
		||||
find /etc/glpi -type d -exec chmod 0755 {} \;
 | 
			
		||||
find /var/lib/glpi -type f -exec chmod 0644 {} \;
 | 
			
		||||
find /var/lib/glpi -type d -exec chmod 0755 {} \;
 | 
			
		||||
find /var/log/glpi -type f -exec chmod 0644 {} \;
 | 
			
		||||
find /var/log/glpi -type d -exec chmod 0755 {} \;
 | 
			
		||||
msg_ok "Configured Folder and File Permissions"
 | 
			
		||||
 | 
			
		||||
msg_info "Setup Service"
 | 
			
		||||
cat <<EOF >/etc/apache2/sites-available/glpi.conf
 | 
			
		||||
<VirtualHost *:80>
 | 
			
		||||
    ServerName localhost
 | 
			
		||||
    DocumentRoot /opt/glpi/public
 | 
			
		||||
 | 
			
		||||
    <Directory /opt/glpi/public>
 | 
			
		||||
        Require all granted
 | 
			
		||||
        RewriteEngine On
 | 
			
		||||
        RewriteCond %{HTTP:Authorization} ^(.+)$
 | 
			
		||||
        RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
 | 
			
		||||
        RewriteCond %{REQUEST_FILENAME} !-f
 | 
			
		||||
        RewriteRule ^(.*)$ index.php [QSA,L]
 | 
			
		||||
    </Directory>
 | 
			
		||||
 | 
			
		||||
    ErrorLog \${APACHE_LOG_DIR}/glpi_error.log
 | 
			
		||||
    CustomLog \${APACHE_LOG_DIR}/glpi_access.log combined
 | 
			
		||||
</VirtualHost>
 | 
			
		||||
EOF
 | 
			
		||||
$STD a2dissite 000-default.conf
 | 
			
		||||
$STD a2enmod rewrite
 | 
			
		||||
$STD a2ensite glpi.conf
 | 
			
		||||
msg_ok "Setup Service"
 | 
			
		||||
 | 
			
		||||
msg_info "Setup Cronjob"
 | 
			
		||||
echo "* * * * * php /opt/glpi/front/cron.php" | crontab -
 | 
			
		||||
msg_ok "Setup Cronjob"
 | 
			
		||||
 | 
			
		||||
msg_info "Update PHP Params"
 | 
			
		||||
PHP_VERSION=$(ls /etc/php/ | grep -E '^[0-9]+\.[0-9]+$' | head -n 1)
 | 
			
		||||
PHP_INI="/etc/php/$PHP_VERSION/apache2/php.ini"
 | 
			
		||||
sed -i 's/^upload_max_filesize = .*/upload_max_filesize = 20M/' $PHP_INI
 | 
			
		||||
sed -i 's/^post_max_size = .*/post_max_size = 20M/' $PHP_INI
 | 
			
		||||
sed -i 's/^max_execution_time = .*/max_execution_time = 60/' $PHP_INI
 | 
			
		||||
sed -i 's/^max_input_vars = .*/max_input_vars = 5000/' $PHP_INI
 | 
			
		||||
sed -i 's/^memory_limit = .*/memory_limit = 256M/' $PHP_INI
 | 
			
		||||
sed -i 's/^;\?\s*session.cookie_httponly\s*=.*/session.cookie_httponly = On/' $PHP_INI
 | 
			
		||||
systemctl restart apache2
 | 
			
		||||
msg_ok "Update PHP Params"
 | 
			
		||||
 | 
			
		||||
motd_ssh
 | 
			
		||||
customize
 | 
			
		||||
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/glpi/install
 | 
			
		||||
rm -rf /opt/glpi-${RELEASE}.tgz
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
@@ -16,11 +16,15 @@ network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y curl
 | 
			
		||||
$STD apt-get install -y sudo
 | 
			
		||||
$STD apt-get install -y mc
 | 
			
		||||
$STD apt-get install -y ca-certificates
 | 
			
		||||
$STD apt-get install -y gnupg
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  sudo \
 | 
			
		||||
  mc \
 | 
			
		||||
  curl \
 | 
			
		||||
  ca-certificates \
 | 
			
		||||
  gnupg \
 | 
			
		||||
  make \
 | 
			
		||||
  g++ \
 | 
			
		||||
  build-essential
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Node.js Repository"
 | 
			
		||||
 
 | 
			
		||||
@@ -14,9 +14,49 @@ network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies (Patience)"
 | 
			
		||||
$STD apt-get install -y git curl sudo mc bluez libffi-dev libssl-dev libjpeg-dev zlib1g-dev autoconf build-essential libopenjp2-7 libturbojpeg0-dev ffmpeg liblapack3 liblapack-dev dbus-broker libpcap-dev libavdevice-dev libavformat-dev libavcodec-dev libavutil-dev libavfilter-dev libmariadb-dev-compat libatlas-base-dev pip python3.12-dev
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  curl \
 | 
			
		||||
  git \
 | 
			
		||||
  sudo \
 | 
			
		||||
  mc \
 | 
			
		||||
  gnupg \
 | 
			
		||||
  ca-certificates \
 | 
			
		||||
  bluez \
 | 
			
		||||
  libtiff6 \
 | 
			
		||||
  tzdata \
 | 
			
		||||
  libffi-dev \
 | 
			
		||||
  libssl-dev \
 | 
			
		||||
  libjpeg-dev \
 | 
			
		||||
  zlib1g-dev \
 | 
			
		||||
  autoconf \
 | 
			
		||||
  build-essential \
 | 
			
		||||
  libopenjp2-7 \
 | 
			
		||||
  libturbojpeg0-dev \
 | 
			
		||||
  ffmpeg \
 | 
			
		||||
  liblapack3 \
 | 
			
		||||
  liblapack-dev \
 | 
			
		||||
  dbus-broker \
 | 
			
		||||
  libpcap-dev \
 | 
			
		||||
  libavdevice-dev \
 | 
			
		||||
  libavformat-dev \
 | 
			
		||||
  libavcodec-dev \
 | 
			
		||||
  libavutil-dev \
 | 
			
		||||
  libavfilter-dev \
 | 
			
		||||
  libmariadb-dev-compat \
 | 
			
		||||
  libatlas-base-dev \
 | 
			
		||||
  software-properties-common
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setup Python3"
 | 
			
		||||
$STD add-apt-repository -y ppa:deadsnakes/ppa
 | 
			
		||||
$STD apt-get update
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  python3.13-* \
 | 
			
		||||
  python3-pip \
 | 
			
		||||
  python3.13-dev \
 | 
			
		||||
  python3.13-venv
 | 
			
		||||
msg_ok "Setup Python3"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing UV"
 | 
			
		||||
$STD pip install uv
 | 
			
		||||
msg_ok "Installed UV"
 | 
			
		||||
 
 | 
			
		||||
@@ -56,11 +56,11 @@ $STD composer install --no-dev --optimize-autoloader --no-interaction
 | 
			
		||||
cp .env.dist .env
 | 
			
		||||
sed -i "/^DATABASE_URL=/c\DATABASE_URL=mysql://$DB_USER:$DB_PASS@127.0.0.1:3306/$DB_NAME?charset=utf8mb4&serverVersion=$MYSQL_VERSION" /opt/kimai/.env
 | 
			
		||||
$STD bin/console kimai:install -n
 | 
			
		||||
chown -R :www-data /opt/kimai
 | 
			
		||||
chmod -R g+r /opt/kimai
 | 
			
		||||
chmod -R g+rw /opt/kimai
 | 
			
		||||
sudo chown -R www-data:www-data /opt/kimai
 | 
			
		||||
sudo chmod -R 755 /opt/kimai
 | 
			
		||||
chown -R :www-data /opt/*
 | 
			
		||||
chmod -R g+r /opt/*
 | 
			
		||||
chmod -R g+rw /opt/*
 | 
			
		||||
sudo chown -R www-data:www-data /opt/*
 | 
			
		||||
sudo chmod -R 755 /opt/*
 | 
			
		||||
$STD expect <<EOF
 | 
			
		||||
set timeout -1
 | 
			
		||||
log_user 0
 | 
			
		||||
 
 | 
			
		||||
@@ -15,15 +15,21 @@ network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y curl
 | 
			
		||||
$STD apt-get install -y sudo
 | 
			
		||||
$STD apt-get install -y mc
 | 
			
		||||
$STD apt-get install -y git
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
    curl \
 | 
			
		||||
    sudo \
 | 
			
		||||
    mc \
 | 
			
		||||
    git \
 | 
			
		||||
    libpng-dev \
 | 
			
		||||
    libjpeg-dev \
 | 
			
		||||
    libtiff-dev \
 | 
			
		||||
    imagemagick
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Python3 Dependencies"
 | 
			
		||||
$STD apt-get install -y pip
 | 
			
		||||
$STD apt-get install -y python3-irc
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
    pip \
 | 
			
		||||
    python3-irc
 | 
			
		||||
$STD pip install jaraco.stream
 | 
			
		||||
$STD pip install python-Levenshtein
 | 
			
		||||
$STD pip install soupsieve
 | 
			
		||||
@@ -31,6 +37,8 @@ msg_ok "Installed Python3 Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing LazyLibrarian"
 | 
			
		||||
$STD git clone https://gitlab.com/LazyLibrarian/LazyLibrarian /opt/LazyLibrarian
 | 
			
		||||
cd /opt/LazyLibrarian
 | 
			
		||||
$STD pip install .
 | 
			
		||||
msg_ok "Installed LazyLibrarian"
 | 
			
		||||
 | 
			
		||||
msg_info "Creating Service"
 | 
			
		||||
 
 | 
			
		||||
@@ -19,7 +19,8 @@ $STD apt-get install -y \
 | 
			
		||||
    mc \
 | 
			
		||||
    sudo \
 | 
			
		||||
    default-jdk \
 | 
			
		||||
    git
 | 
			
		||||
    git \
 | 
			
		||||
    git-lfs
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -41,4 +42,4 @@ msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/onedev-latest.tar.gz
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										75
									
								
								install/pf2etools-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								install/pf2etools-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,75 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: TheRealVira
 | 
			
		||||
# License: MIT
 | 
			
		||||
# Source: https://pf2etools.com/
 | 
			
		||||
 | 
			
		||||
# Import Functions und Setup
 | 
			
		||||
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | 
			
		||||
color
 | 
			
		||||
verb_ip6
 | 
			
		||||
catch_errors
 | 
			
		||||
setting_up_container
 | 
			
		||||
network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  curl \
 | 
			
		||||
  mc \
 | 
			
		||||
  sudo \
 | 
			
		||||
  apache2 \
 | 
			
		||||
  gpg \
 | 
			
		||||
  ca-certificates \
 | 
			
		||||
  git
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Node.js Repository"
 | 
			
		||||
mkdir -p /etc/apt/keyrings
 | 
			
		||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
			
		||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_20.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
 | 
			
		||||
msg_ok "Set up Node.js Repository"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Node.js"
 | 
			
		||||
$STD apt-get update
 | 
			
		||||
$STD apt-get install -y nodejs
 | 
			
		||||
msg_ok "Installed Node.js"
 | 
			
		||||
 | 
			
		||||
# Setup App
 | 
			
		||||
msg_info "Setup Pf2eTools"
 | 
			
		||||
cd /opt
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/Pf2eToolsOrg/Pf2eTools/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
wget -q "https://github.com/Pf2eToolsOrg/Pf2eTools/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
unzip -q "${RELEASE}.zip"
 | 
			
		||||
mv "Pf2eTools-${RELEASE:1}" /opt/Pf2eTools
 | 
			
		||||
cd /opt/Pf2eTools
 | 
			
		||||
$STD npm install
 | 
			
		||||
$STD npm run build
 | 
			
		||||
cd ~
 | 
			
		||||
echo "${RELEASE}" >/opt/Pf2eTools_version.txt
 | 
			
		||||
msg_ok "Set up Pf2eTools"
 | 
			
		||||
 | 
			
		||||
msg_info "Creating Service"
 | 
			
		||||
cat <<EOF >> /etc/apache2/apache2.conf
 | 
			
		||||
<Location /server-status>
 | 
			
		||||
    SetHandler server-status
 | 
			
		||||
    Order deny,allow
 | 
			
		||||
    Allow from all
 | 
			
		||||
</Location>
 | 
			
		||||
EOF
 | 
			
		||||
rm -rf /var/www/html
 | 
			
		||||
ln -s "/opt/Pf2eTools" /var/www/html
 | 
			
		||||
chown -R www-data: "/opt/Pf2eTools"
 | 
			
		||||
chmod -R 755 "/opt/Pf2eTools"
 | 
			
		||||
msg_ok "Created Service"
 | 
			
		||||
 | 
			
		||||
# Cleanup
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
 | 
			
		||||
motd_ssh
 | 
			
		||||
customize
 | 
			
		||||
							
								
								
									
										39
									
								
								install/typesense-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								install/typesense-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
 | 
			
		||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
			
		||||
# Author: tlissak
 | 
			
		||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
			
		||||
# Source: https://typesense.org/
 | 
			
		||||
 | 
			
		||||
source /dev/stdin <<< "$FUNCTIONS_FILE_PATH"
 | 
			
		||||
color
 | 
			
		||||
verb_ip6
 | 
			
		||||
catch_errors
 | 
			
		||||
setting_up_container
 | 
			
		||||
network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
    curl \
 | 
			
		||||
    mc \
 | 
			
		||||
    sudo 
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing TypeSense"
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/typesense/typesense/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
			
		||||
cd /opt
 | 
			
		||||
wget -q https://dl.typesense.org/releases/${RELEASE}/typesense-server-${RELEASE}-amd64.deb
 | 
			
		||||
$STD apt install -y /opt/typesense-server-${RELEASE}-amd64.deb
 | 
			
		||||
echo 'enable-cors = true' >> /etc/typesense/typesense-server.ini
 | 
			
		||||
echo "${RELEASE}" >"/opt/${APPLICATION}_version.txt"
 | 
			
		||||
msg_ok "Installed TypeSense"
 | 
			
		||||
 | 
			
		||||
motd_ssh
 | 
			
		||||
customize
 | 
			
		||||
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/typesense-server-${RELEASE}-amd64.deb
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
@@ -14,21 +14,22 @@ network_check
 | 
			
		||||
update_os
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Dependencies"
 | 
			
		||||
$STD apt-get install -y curl
 | 
			
		||||
$STD apt-get install -y sudo
 | 
			
		||||
$STD apt-get install -y mc
 | 
			
		||||
$STD apt-get install -y git
 | 
			
		||||
$STD apt-get install -y make
 | 
			
		||||
$STD apt-get install -y g++
 | 
			
		||||
$STD apt-get install -y gcc
 | 
			
		||||
$STD apt-get install -y ca-certificates
 | 
			
		||||
$STD apt-get install -y gnupg
 | 
			
		||||
$STD apt-get install -y \
 | 
			
		||||
  curl \
 | 
			
		||||
  sudo \
 | 
			
		||||
  mc \
 | 
			
		||||
  git \
 | 
			
		||||
  make \
 | 
			
		||||
  g++ \
 | 
			
		||||
  gcc \
 | 
			
		||||
  ca-certificates \
 | 
			
		||||
  gnupg
 | 
			
		||||
msg_ok "Installed Dependencies"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Node.js Repository"
 | 
			
		||||
mkdir -p /etc/apt/keyrings
 | 
			
		||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
			
		||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_20.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
 | 
			
		||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_22.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
 | 
			
		||||
msg_ok "Set up Node.js Repository"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Node.js"
 | 
			
		||||
@@ -36,37 +37,47 @@ $STD apt-get update
 | 
			
		||||
$STD apt-get install -y nodejs
 | 
			
		||||
msg_ok "Installed Node.js"
 | 
			
		||||
 | 
			
		||||
msg_info "Setting up Zigbee2MQTT Repository"
 | 
			
		||||
$STD git clone --depth 1 https://github.com/Koenkk/zigbee2mqtt.git /opt/zigbee2mqtt
 | 
			
		||||
msg_ok "Set up Zigbee2MQTT Repository"
 | 
			
		||||
msg_info "Installing pnpm"
 | 
			
		||||
$STD npm install -g pnpm
 | 
			
		||||
msg_ok "Installed pnpm"
 | 
			
		||||
 | 
			
		||||
msg_info "Installing Zigbee2MQTT"
 | 
			
		||||
msg_info "Setting up Zigbee2MQTT"
 | 
			
		||||
cd /opt
 | 
			
		||||
RELEASE=$(curl -s https://api.github.com/repos/Koenkk/zigbee2mqtt/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
			
		||||
wget -q "https://github.com/Koenkk/zigbee2mqtt/archive/refs/tags/${RELEASE}.zip"
 | 
			
		||||
unzip -q ${RELEASE}.zip
 | 
			
		||||
mv zigbee2mqtt-${RELEASE} /opt/zigbee2mqtt
 | 
			
		||||
cd /opt/zigbee2mqtt/data
 | 
			
		||||
mv configuration.example.yaml configuration.yaml
 | 
			
		||||
cd /opt/zigbee2mqtt
 | 
			
		||||
$STD npm ci
 | 
			
		||||
$STD pnpm install --frozen-lockfile
 | 
			
		||||
$STD pnpm build
 | 
			
		||||
msg_ok "Installed Zigbee2MQTT"
 | 
			
		||||
 | 
			
		||||
msg_info "Creating Service"
 | 
			
		||||
service_path="/etc/systemd/system/zigbee2mqtt.service"
 | 
			
		||||
echo "[Unit]
 | 
			
		||||
cat <<EOF >/etc/systemd/system/zigbee2mqtt.service
 | 
			
		||||
[Unit]
 | 
			
		||||
Description=zigbee2mqtt
 | 
			
		||||
After=network.target
 | 
			
		||||
[Service]
 | 
			
		||||
Environment=NODE_ENV=production
 | 
			
		||||
ExecStart=/usr/bin/npm start
 | 
			
		||||
ExecStart=/usr/bin/pnpm start
 | 
			
		||||
WorkingDirectory=/opt/zigbee2mqtt
 | 
			
		||||
StandardOutput=inherit
 | 
			
		||||
StandardError=inherit
 | 
			
		||||
Restart=always
 | 
			
		||||
User=root
 | 
			
		||||
[Install]
 | 
			
		||||
WantedBy=multi-user.target" >$service_path
 | 
			
		||||
$STD systemctl enable zigbee2mqtt.service
 | 
			
		||||
WantedBy=multi-user.target
 | 
			
		||||
EOF
 | 
			
		||||
systemctl enable -q --now zigbee2mqtt.service
 | 
			
		||||
msg_ok "Created Service"
 | 
			
		||||
 | 
			
		||||
motd_ssh
 | 
			
		||||
customize
 | 
			
		||||
 | 
			
		||||
msg_info "Cleaning up"
 | 
			
		||||
rm -rf /opt/${RELEASE}.zip
 | 
			
		||||
$STD apt-get -y autoremove
 | 
			
		||||
$STD apt-get -y autoclean
 | 
			
		||||
msg_ok "Cleaned"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										34
									
								
								json/5etools.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								json/5etools.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "5etools",
 | 
			
		||||
    "slug": "5etools",
 | 
			
		||||
    "categories": [
 | 
			
		||||
        0
 | 
			
		||||
    ],
 | 
			
		||||
    "date_created": "2025-01-02",
 | 
			
		||||
    "type": "ct",
 | 
			
		||||
    "updateable": true,
 | 
			
		||||
    "privileged": false,
 | 
			
		||||
    "interface_port": 80,
 | 
			
		||||
    "documentation": "https://wiki.tercept.net/en/5eTools",
 | 
			
		||||
    "website": "https://5e.tools/",
 | 
			
		||||
    "logo": "https://wiki.tercept.net/core-wiki-assets/5etoolslogocircle.png",
 | 
			
		||||
    "description": "5eTools is a website providing a suite of tools for 5th Edition Dungeons & Dragons players and Dungeon Masters.",
 | 
			
		||||
    "install_methods": [
 | 
			
		||||
        {
 | 
			
		||||
            "type": "default",
 | 
			
		||||
            "script": "ct/5etools.sh",
 | 
			
		||||
            "resources": {
 | 
			
		||||
                "cpu": 1,
 | 
			
		||||
                "ram": 512,
 | 
			
		||||
                "hdd": 13,
 | 
			
		||||
                "os": "debian",
 | 
			
		||||
                "version": "12"
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "default_credentials": {
 | 
			
		||||
        "username": null,
 | 
			
		||||
        "password": null
 | 
			
		||||
    },
 | 
			
		||||
    "notes": []
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										34
									
								
								json/glpi.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								json/glpi.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
{
 | 
			
		||||
  "name": "GLPI",
 | 
			
		||||
  "slug": "glpi",
 | 
			
		||||
  "categories": [
 | 
			
		||||
    0
 | 
			
		||||
  ],
 | 
			
		||||
  "date_created": "2025-01-06",
 | 
			
		||||
  "type": "ct",
 | 
			
		||||
  "updateable": false,
 | 
			
		||||
  "privileged": false,
 | 
			
		||||
  "interface_port": 80,
 | 
			
		||||
  "documentation": "https://glpi-project.org/documentation/",
 | 
			
		||||
  "website": "https://glpi-project.org/",
 | 
			
		||||
  "logo": "https://raw.githubusercontent.com/glpi-project/glpi/refs/heads/main/public/pics/login_logo_glpi.png",
 | 
			
		||||
  "description": "GLPI is a Free Asset and IT Management Software package, Data center management, ITIL Service Desk, licenses tracking and software auditing.",
 | 
			
		||||
  "install_methods": [
 | 
			
		||||
    {
 | 
			
		||||
      "type": "default",
 | 
			
		||||
      "script": "ct/glpi.sh",
 | 
			
		||||
      "resources": {
 | 
			
		||||
        "cpu": 2,
 | 
			
		||||
        "ram": 2048,
 | 
			
		||||
        "hdd": 10,
 | 
			
		||||
        "os": "Debian",
 | 
			
		||||
        "version": "12"
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  ],
 | 
			
		||||
  "default_credentials": {
 | 
			
		||||
    "username": "glpi",
 | 
			
		||||
    "password": "glpi"
 | 
			
		||||
  },
 | 
			
		||||
  "notes": []
 | 
			
		||||
}
 | 
			
		||||
@@ -41,5 +41,10 @@
 | 
			
		||||
        "username": null,
 | 
			
		||||
        "password": null
 | 
			
		||||
    },
 | 
			
		||||
    "notes": []
 | 
			
		||||
    "notes": [
 | 
			
		||||
        {
 | 
			
		||||
            "text": "Only Alpine: To get the username and password, run the script again inside the LXC shell.",
 | 
			
		||||
            "type": "warning"
 | 
			
		||||
        }
 | 
			
		||||
    ]
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										34
									
								
								json/pf2etools.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								json/pf2etools.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "Pf2eTools",
 | 
			
		||||
    "slug": "Pf2eTools",
 | 
			
		||||
    "categories": [
 | 
			
		||||
        0
 | 
			
		||||
    ],
 | 
			
		||||
    "date_created": "2025-01-02",
 | 
			
		||||
    "type": "ct",
 | 
			
		||||
    "updateable": true,
 | 
			
		||||
    "privileged": false,
 | 
			
		||||
    "interface_port": 80,
 | 
			
		||||
    "documentation": "https://github.com/Pf2eToolsOrg/Pf2eTools/wiki",
 | 
			
		||||
    "website": "https://pf2etools.com/",
 | 
			
		||||
    "logo": "https://raw.githubusercontent.com/Pf2eToolsOrg/Pf2eTools/refs/heads/dev/android-chrome-192x192.png",
 | 
			
		||||
    "description": "Pf2eTools is an open-source website aiming to provide tools and information for Pathfinder 2nd Edition players and gamemasters. It's built using basic web technologies to ensure wide compatibility, and utilises client-side caching for speed, efficiency, and offline access.",
 | 
			
		||||
    "install_methods": [
 | 
			
		||||
        {
 | 
			
		||||
            "type": "default",
 | 
			
		||||
            "script": "ct/pf2etools.sh",
 | 
			
		||||
            "resources": {
 | 
			
		||||
                "cpu": 1,
 | 
			
		||||
                "ram": 512,
 | 
			
		||||
                "hdd": 6,
 | 
			
		||||
                "os": "debian",
 | 
			
		||||
                "version": "12"
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "default_credentials": {
 | 
			
		||||
        "username": null,
 | 
			
		||||
        "password": null
 | 
			
		||||
    },
 | 
			
		||||
    "notes": []
 | 
			
		||||
}
 | 
			
		||||
@@ -30,5 +30,10 @@
 | 
			
		||||
        "username": null,
 | 
			
		||||
        "password": null
 | 
			
		||||
    },
 | 
			
		||||
    "notes": []
 | 
			
		||||
    "notes": [
 | 
			
		||||
        {
 | 
			
		||||
            "text": "Set a password after installation for postgres user by running `echo \"ALTER USER postgres with encrypted password 'your_password';\" | sudo -u postgres psql`",
 | 
			
		||||
            "type": "info"
 | 
			
		||||
        }
 | 
			
		||||
    ]
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										39
									
								
								json/typesense.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								json/typesense.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "TypeSense",
 | 
			
		||||
    "slug": "typesense",
 | 
			
		||||
    "categories": [
 | 
			
		||||
        5
 | 
			
		||||
    ],
 | 
			
		||||
    "date_created": "2025-01-06",
 | 
			
		||||
    "type": "ct",
 | 
			
		||||
    "updateable": true,
 | 
			
		||||
    "privileged": false,
 | 
			
		||||
    "interface_port": null,
 | 
			
		||||
    "documentation": "https://typesense.org/docs/",
 | 
			
		||||
    "website": "https://typesense.org/",
 | 
			
		||||
    "logo": "https://typesense.org/_nuxt/img/typesense_logo_white.0f9fb0a.svg",
 | 
			
		||||
    "description": "Typesense is an open-source, fast, and lightweight search engine optimized for delivering instant, relevant, and typo-tolerant search results. Designed for ease of use and high performance, it offers features like real-time indexing, fuzzy matching, customizable relevance ranking, and a simple API for integration. Typesense is particularly well-suited for applications requiring instant search capabilities, such as e-commerce, documentation, or any content-rich websites. It is often compared to tools like Elasticsearch but is more developer-friendly and less resource-intensive.",
 | 
			
		||||
    "install_methods": [
 | 
			
		||||
        {
 | 
			
		||||
            "type": "default",
 | 
			
		||||
            "script": "ct/typesense.sh",
 | 
			
		||||
            "resources": {
 | 
			
		||||
                "cpu": 1,
 | 
			
		||||
                "ram": 1024,
 | 
			
		||||
                "hdd": 4,
 | 
			
		||||
                "os": "debian",
 | 
			
		||||
                "version": "12"
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "default_credentials": {
 | 
			
		||||
        "username": null,
 | 
			
		||||
        "password": null
 | 
			
		||||
    },
 | 
			
		||||
    "notes": [
 | 
			
		||||
        {
 | 
			
		||||
            "text": "This script requires some extra steps after the installation, Please checkout the 'documentation' Button",
 | 
			
		||||
            "type": "info"
 | 
			
		||||
        }
 | 
			
		||||
    ]
 | 
			
		||||
}
 | 
			
		||||
@@ -316,7 +316,7 @@ echo_default() {
 | 
			
		||||
  echo -e "${CONTAINERTYPE}${BOLD}${DGN}Container Type: ${BGN}$CT_TYPE_DESC${CL}"
 | 
			
		||||
  echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}${DISK_SIZE}GB${CL}"
 | 
			
		||||
  echo -e "${CPUCORE}${BOLD}${DGN}CPU Cores: ${BGN}${CORE_COUNT}${CL}"
 | 
			
		||||
  echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}${RAM_SIZE}MB${CL}"
 | 
			
		||||
  echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}${RAM_SIZE}MiB${CL}"
 | 
			
		||||
  echo -e "${CONTAINERID}${BOLD}${DGN}Container ID: ${BGN}${CT_ID}${CL}"
 | 
			
		||||
  if [ "$VERB" == "yes" ]; then
 | 
			
		||||
    echo -e "${SEARCH}${BOLD}${DGN}Verbose Mode: ${BGN}Enabled${CL}"
 | 
			
		||||
@@ -463,13 +463,13 @@ advanced_settings() {
 | 
			
		||||
  if DISK_SIZE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Disk Size in GB" 8 58 $var_disk --title "DISK SIZE" 3>&1 1>&2 2>&3); then
 | 
			
		||||
    if [ -z "$DISK_SIZE" ]; then
 | 
			
		||||
      DISK_SIZE="$var_disk"
 | 
			
		||||
      echo -e "${DISKSIZE}${DGN}Disk Size: ${BGN}$DISK_SIZE${CL}"
 | 
			
		||||
      echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}${DISK_SIZE}GB${CL}"
 | 
			
		||||
    else
 | 
			
		||||
      if ! [[ $DISK_SIZE =~ $INTEGER ]]; then
 | 
			
		||||
        echo -e "{INFO}${HOLD}${RD} DISK SIZE MUST BE AN INTEGER NUMBER!${CL}"
 | 
			
		||||
        advanced_settings
 | 
			
		||||
      fi
 | 
			
		||||
      echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}$DISK_SIZE${CL}"
 | 
			
		||||
      echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}${DISK_SIZE}GB${CL}"
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    exit_script
 | 
			
		||||
@@ -489,9 +489,9 @@ advanced_settings() {
 | 
			
		||||
  if RAM_SIZE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Allocate RAM in MiB" 8 58 $var_ram --title "RAM" 3>&1 1>&2 2>&3); then
 | 
			
		||||
    if [ -z "$RAM_SIZE" ]; then
 | 
			
		||||
      RAM_SIZE="$var_ram"
 | 
			
		||||
      echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}$RAM_SIZE${CL}"
 | 
			
		||||
      echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}${RAM_SIZE}MiB${CL}"
 | 
			
		||||
    else
 | 
			
		||||
      echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}$RAM_SIZE${CL}"
 | 
			
		||||
      echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}${RAM_SIZE}MiB${CL}"
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    exit_script
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user