mirror of
				https://github.com/community-scripts/ProxmoxVE.git
				synced 2025-11-04 10:22:50 +00:00 
			
		
		
		
	Compare commits
	
		
			157 Commits
		
	
	
		
			2025-01-29
			...
			2025-02-06
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					f1eca8a4bf | ||
| 
						 | 
					199d304841 | ||
| 
						 | 
					4163526379 | ||
| 
						 | 
					9272a1181c | ||
| 
						 | 
					2e51c289ca | ||
| 
						 | 
					03828943b0 | ||
| 
						 | 
					d71ef779ec | ||
| 
						 | 
					9736d5c785 | ||
| 
						 | 
					ef33864adf | ||
| 
						 | 
					d7b6a97415 | ||
| 
						 | 
					5b4c417729 | ||
| 
						 | 
					9c4e9ed4be | ||
| 
						 | 
					5a25348e04 | ||
| 
						 | 
					f5a73a5449 | ||
| 
						 | 
					82fecd7bbd | ||
| 
						 | 
					9badef6f03 | ||
| 
						 | 
					0e2f711cac | ||
| 
						 | 
					fbec881f70 | ||
| 
						 | 
					a3f1ff30e0 | ||
| 
						 | 
					4eb93ea49b | ||
| 
						 | 
					7d8ecead7d | ||
| 
						 | 
					5cf1f880c6 | ||
| 
						 | 
					873ae3e8af | ||
| 
						 | 
					4a273c7134 | ||
| 
						 | 
					439a7ed9e8 | ||
| 
						 | 
					d941af4cf2 | ||
| 
						 | 
					cb79d7baab | ||
| 
						 | 
					fbe2fb10af | ||
| 
						 | 
					1a00ba109b | ||
| 
						 | 
					88ee57cf15 | ||
| 
						 | 
					857964653c | ||
| 
						 | 
					682674727c | ||
| 
						 | 
					5451e61484 | ||
| 
						 | 
					778b6be4e0 | ||
| 
						 | 
					c52c6ec3a3 | ||
| 
						 | 
					34837c7777 | ||
| 
						 | 
					f98124a57f | ||
| 
						 | 
					7838dd6277 | ||
| 
						 | 
					a6f656eacf | ||
| 
						 | 
					43646a8e19 | ||
| 
						 | 
					8b52639d23 | ||
| 
						 | 
					8afb439ed7 | ||
| 
						 | 
					42b175144a | ||
| 
						 | 
					cb6e2c4455 | ||
| 
						 | 
					8662be2e4e | ||
| 
						 | 
					f66f43d91a | ||
| 
						 | 
					c112edd8ac | ||
| 
						 | 
					398bae1f64 | ||
| 
						 | 
					7c2a6822b5 | ||
| 
						 | 
					3a33e006d4 | ||
| 
						 | 
					3aedafbfc6 | ||
| 
						 | 
					4587352377 | ||
| 
						 | 
					62dac32400 | ||
| 
						 | 
					401a9e1a45 | ||
| 
						 | 
					569d0ac374 | ||
| 
						 | 
					e75312007d | ||
| 
						 | 
					103a5371e6 | ||
| 
						 | 
					abfe17ce74 | ||
| 
						 | 
					86295fcf67 | ||
| 
						 | 
					c9012c54df | ||
| 
						 | 
					fd051552f3 | ||
| 
						 | 
					169076e68e | ||
| 
						 | 
					971aa5ba16 | ||
| 
						 | 
					6be54478f4 | ||
| 
						 | 
					6b225058de | ||
| 
						 | 
					78d96fdaa2 | ||
| 
						 | 
					8129e3cf39 | ||
| 
						 | 
					0e5f663df5 | ||
| 
						 | 
					de45527d45 | ||
| 
						 | 
					d7b3f33030 | ||
| 
						 | 
					88daaed113 | ||
| 
						 | 
					41744c0ab6 | ||
| 
						 | 
					c3cd5314fe | ||
| 
						 | 
					6f29ab8942 | ||
| 
						 | 
					bd5db081c1 | ||
| 
						 | 
					c5a69d6e8b | ||
| 
						 | 
					a75c0e1562 | ||
| 
						 | 
					a97d76f428 | ||
| 
						 | 
					0e0539af3f | ||
| 
						 | 
					8d46f7266e | ||
| 
						 | 
					7f5ee39b25 | ||
| 
						 | 
					85333212b0 | ||
| 
						 | 
					577a415f10 | ||
| 
						 | 
					db24bf4d02 | ||
| 
						 | 
					21e0e0df98 | ||
| 
						 | 
					83015c8cff | ||
| 
						 | 
					7ca1ed019c | ||
| 
						 | 
					fb8f911c49 | ||
| 
						 | 
					b4a0b74bfd | ||
| 
						 | 
					99556bdbd2 | ||
| 
						 | 
					ec3b70e8fd | ||
| 
						 | 
					50ffcd4734 | ||
| 
						 | 
					55c1f2f3dc | ||
| 
						 | 
					99e04e1ded | ||
| 
						 | 
					884428e113 | ||
| 
						 | 
					00f58d71d6 | ||
| 
						 | 
					fa4ab5c8a3 | ||
| 
						 | 
					1528c46f0b | ||
| 
						 | 
					c5b9e4db64 | ||
| 
						 | 
					36f2fb3e52 | ||
| 
						 | 
					e379db8baf | ||
| 
						 | 
					91ba5cd412 | ||
| 
						 | 
					745d1f9444 | ||
| 
						 | 
					76f12fc596 | ||
| 
						 | 
					995906f299 | ||
| 
						 | 
					05ec444e2d | ||
| 
						 | 
					19911f5b81 | ||
| 
						 | 
					57b37b1e16 | ||
| 
						 | 
					91a3fd10e0 | ||
| 
						 | 
					6f0ebac209 | ||
| 
						 | 
					f40e6e5453 | ||
| 
						 | 
					8a07124457 | ||
| 
						 | 
					41c32af0d6 | ||
| 
						 | 
					3cb4196fee | ||
| 
						 | 
					a33108cd4f | ||
| 
						 | 
					a0d7c5db0e | ||
| 
						 | 
					baef2a0cb9 | ||
| 
						 | 
					f9b84bf5ee | ||
| 
						 | 
					ccab9d1be5 | ||
| 
						 | 
					58a2ece7b7 | ||
| 
						 | 
					aa16f936c8 | ||
| 
						 | 
					c8829beddd | ||
| 
						 | 
					3adc22d837 | ||
| 
						 | 
					71b1288220 | ||
| 
						 | 
					3c58303a9f | ||
| 
						 | 
					b8edf0dd68 | ||
| 
						 | 
					2fa3116c9c | ||
| 
						 | 
					d416ff9cfa | ||
| 
						 | 
					2e2db6603e | ||
| 
						 | 
					72335f2c4e | ||
| 
						 | 
					a359ffc211 | ||
| 
						 | 
					cd4bcefa58 | ||
| 
						 | 
					a0eb173824 | ||
| 
						 | 
					3d42ecb152 | ||
| 
						 | 
					0642c7e2c8 | ||
| 
						 | 
					af04e933e3 | ||
| 
						 | 
					0dfc513a27 | ||
| 
						 | 
					26433efcd8 | ||
| 
						 | 
					343de50ef8 | ||
| 
						 | 
					a38e9070ef | ||
| 
						 | 
					e2b548a7c3 | ||
| 
						 | 
					737b18dea5 | ||
| 
						 | 
					6b777a03c0 | ||
| 
						 | 
					d9b4778360 | ||
| 
						 | 
					7299b77359 | ||
| 
						 | 
					d3882b6818 | ||
| 
						 | 
					2ef0cd0f89 | ||
| 
						 | 
					f2eb24d527 | ||
| 
						 | 
					f520607d85 | ||
| 
						 | 
					1270d87bf8 | ||
| 
						 | 
					7f2481ea12 | ||
| 
						 | 
					05f114ed64 | ||
| 
						 | 
					6924a6fea4 | ||
| 
						 | 
					bb553ae48c | ||
| 
						 | 
					cbb18668dd | ||
| 
						 | 
					c7418171b4 | ||
| 
						 | 
					ed2ead9ef2 | 
							
								
								
									
										2
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							@@ -80,7 +80,7 @@ git switch -c your-feature-branch
 | 
				
			|||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### 4. Change paths in build.func install.func and AppName.sh
 | 
					### 4. Change paths in build.func install.func and AppName.sh
 | 
				
			||||||
To be able to develop from your own branch you need to change `https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main` to `https://raw.githubusercontent.com/[USER]/[REPOSITORY]/refs/head/[BRANCH]`. You need to make this change atleast in misc/build.func misc/install.func and in your ct/AppName.sh. This change is only for testing. Before opening a Pull Request you should change this line change all this back to point to `https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main`.
 | 
					To be able to develop from your own branch you need to change `https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main` to `https://raw.githubusercontent.com/[USER]/[REPOSITORY]/refs/heads/[BRANCH]`. You need to make this change atleast in misc/build.func misc/install.func and in your ct/AppName.sh. This change is only for testing. Before opening a Pull Request you should change this line change all this back to point to `https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main`.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### 4. Commit changes (without build.func and install.func!)
 | 
					### 4. Commit changes (without build.func and install.func!)
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										3
									
								
								.github/CONTRIBUTOR_GUIDE/ct/AppName.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/CONTRIBUTOR_GUIDE/ct/AppName.sh
									
									
									
									
										vendored
									
									
								
							@@ -1,6 +1,6 @@
 | 
				
			|||||||
#!/usr/bin/env bash
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
					source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
				
			||||||
# Copyright (c) 2021-2024 community-scripts ORG
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
# Author: [YourUserName]
 | 
					# Author: [YourUserName]
 | 
				
			||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
# Source: [SOURCE_URL]
 | 
					# Source: [SOURCE_URL]
 | 
				
			||||||
@@ -66,7 +66,6 @@ function update_script() {
 | 
				
			|||||||
        # Starting Services
 | 
					        # Starting Services
 | 
				
			||||||
        msg_info "Starting $APP"
 | 
					        msg_info "Starting $APP"
 | 
				
			||||||
        systemctl start [SERVICE_NAME]
 | 
					        systemctl start [SERVICE_NAME]
 | 
				
			||||||
        sleep 2
 | 
					 | 
				
			||||||
        msg_ok "Started $APP"
 | 
					        msg_ok "Started $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # Cleaning up
 | 
					        # Cleaning up
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
#!/usr/bin/env bash
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Copyright (c) 2021-2024 community-scripts ORG
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
# Author: [YourUserName]
 | 
					# Author: [YourUserName]
 | 
				
			||||||
# License: MIT
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
# Source: [SOURCE_URL]
 | 
					# Source: [SOURCE_URL]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Import Functions und Setup
 | 
					# Import Functions und Setup
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								.github/workflows/auto-update-app-headers.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/auto-update-app-headers.yml
									
									
									
									
										vendored
									
									
								
							@@ -72,6 +72,26 @@ jobs:
 | 
				
			|||||||
                       --label "automated pr"
 | 
					                       --label "automated pr"
 | 
				
			||||||
        env:
 | 
					        env:
 | 
				
			||||||
          GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
					          GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
				
			||||||
 | 
					      
 | 
				
			||||||
 | 
					      - name: Approve pull request
 | 
				
			||||||
 | 
					        if: env.changed == 'true'
 | 
				
			||||||
 | 
					        env:
 | 
				
			||||||
 | 
					          GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
				
			||||||
 | 
					        run: |
 | 
				
			||||||
 | 
					          PR_NUMBER=$(gh pr list --head "pr-update-app-files" --json number --jq '.[].number')
 | 
				
			||||||
 | 
					          if [ -n "$PR_NUMBER" ]; then
 | 
				
			||||||
 | 
					            gh pr review $PR_NUMBER --approve
 | 
				
			||||||
 | 
					          fi
 | 
				
			||||||
 | 
					          
 | 
				
			||||||
 | 
					      - name: Re-approve pull request after update
 | 
				
			||||||
 | 
					        if: env.changed == 'true'
 | 
				
			||||||
 | 
					        env:
 | 
				
			||||||
 | 
					          GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
				
			||||||
 | 
					        run: |
 | 
				
			||||||
 | 
					          PR_NUMBER=$(gh pr list --head "pr-update-app-files" --json number --jq '.[].number')
 | 
				
			||||||
 | 
					          if [ -n "$PR_NUMBER" ]; then
 | 
				
			||||||
 | 
					            gh pr review $PR_NUMBER --approve
 | 
				
			||||||
 | 
					          fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Step 8: Output success message when no changes
 | 
					      # Step 8: Output success message when no changes
 | 
				
			||||||
      - name: No changes detected
 | 
					      - name: No changes detected
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,7 +17,7 @@ find ./ct -type f -name "*.sh" | sort | while read -r script; do
 | 
				
			|||||||
    output_file="${headers_dir}/$(basename "${script%.*}")"
 | 
					    output_file="${headers_dir}/$(basename "${script%.*}")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Generate figlet output
 | 
					    # Generate figlet output
 | 
				
			||||||
    figlet_output=$(figlet -f slant "$app_name")
 | 
					    figlet_output=$(figlet -w 500 -f slant "$app_name")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Check if figlet output is not empty
 | 
					    # Check if figlet output is not empty
 | 
				
			||||||
    if [[ -n "$figlet_output" ]]; then
 | 
					    if [[ -n "$figlet_output" ]]; then
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								.github/workflows/validate-filenames.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/validate-filenames.yml
									
									
									
									
										vendored
									
									
								
							@@ -50,9 +50,13 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
          NON_COMPLIANT_FILES=""
 | 
					          NON_COMPLIANT_FILES=""
 | 
				
			||||||
          for FILE in $CHANGED_FILES; do
 | 
					          for FILE in $CHANGED_FILES; do
 | 
				
			||||||
 | 
					            # Datei "ct/create_lxc.sh" explizit überspringen
 | 
				
			||||||
 | 
					            if [[ "$FILE" == "ct/create_lxc.sh" ]]; then
 | 
				
			||||||
 | 
					              continue
 | 
				
			||||||
 | 
					            fi
 | 
				
			||||||
            BASENAME=$(echo "$(basename "${FILE%.*}")")
 | 
					            BASENAME=$(echo "$(basename "${FILE%.*}")")
 | 
				
			||||||
            if [[ ! "$BASENAME" =~ ^[a-z0-9-]+$ ]]; then
 | 
					            if [[ ! "$BASENAME" =~ ^[a-z0-9-]+$ ]]; then
 | 
				
			||||||
                    NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
					              NON_COMPLIANT_FILES="$NON_COMPLIANT_FILES $FILE"
 | 
				
			||||||
            fi
 | 
					            fi
 | 
				
			||||||
          done
 | 
					          done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										5
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
					    "files.associations": {
 | 
				
			||||||
 | 
					        "*.func": "shellscript"
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										185
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										185
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -17,6 +17,191 @@ All LXC instances created using this repository come pre-installed with Midnight
 | 
				
			|||||||
Do not break established syntax in this file, as it is automatically updated by a Github Workflow
 | 
					Do not break established syntax in this file, as it is automatically updated by a Github Workflow
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-06
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New Script: Duplicati [@tremor021](https://github.com/tremor021) ([#2052](https://github.com/community-scripts/ProxmoxVE/pull/2052))
 | 
				
			||||||
 | 
					- New Script: Paperless-AI [@MickLesk](https://github.com/MickLesk) ([#2093](https://github.com/community-scripts/ProxmoxVE/pull/2093))
 | 
				
			||||||
 | 
					- New Script: Apache Tika [@andygrunwald](https://github.com/andygrunwald) ([#2079](https://github.com/community-scripts/ProxmoxVE/pull/2079))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Fix: Alpine IT-Tools Update [@MickLesk](https://github.com/MickLesk) ([#2067](https://github.com/community-scripts/ProxmoxVE/pull/2067))
 | 
				
			||||||
 | 
					- Fix: Pocket-ID Change link to GH Repo [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2082](https://github.com/community-scripts/ProxmoxVE/pull/2082))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Refactor JSON generator buttons layout for better alignment and consistency [@BramSuurdje](https://github.com/BramSuurdje) ([#2106](https://github.com/community-scripts/ProxmoxVE/pull/2106))
 | 
				
			||||||
 | 
					- Website: Refactor Footer for improved layout and styling consistency [@BramSuurdje](https://github.com/BramSuurdje) ([#2107](https://github.com/community-scripts/ProxmoxVE/pull/2107))
 | 
				
			||||||
 | 
					- Website: Update Footer for Json-Editor & Api [@MickLesk](https://github.com/MickLesk) ([#2100](https://github.com/community-scripts/ProxmoxVE/pull/2100))
 | 
				
			||||||
 | 
					- Website: Add Download for json-editor [@MickLesk](https://github.com/MickLesk) ([#2099](https://github.com/community-scripts/ProxmoxVE/pull/2099))
 | 
				
			||||||
 | 
					- Radicale: Provide additional information about configuration [@tremor021](https://github.com/tremor021) ([#2072](https://github.com/community-scripts/ProxmoxVE/pull/2072))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-05
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New Script: Zerotier Controller [@tremor021](https://github.com/tremor021) ([#1928](https://github.com/community-scripts/ProxmoxVE/pull/1928))
 | 
				
			||||||
 | 
					- New Script: Radicale [@tremor021](https://github.com/tremor021) ([#1941](https://github.com/community-scripts/ProxmoxVE/pull/1941))
 | 
				
			||||||
 | 
					- New Script: seelf [@tremor021](https://github.com/tremor021) ([#2023](https://github.com/community-scripts/ProxmoxVE/pull/2023))
 | 
				
			||||||
 | 
					- New Script: Crafty-Controller [@CrazyWolf13](https://github.com/CrazyWolf13) ([#1926](https://github.com/community-scripts/ProxmoxVE/pull/1926))
 | 
				
			||||||
 | 
					- New script: Koillection [@bvdberg01](https://github.com/bvdberg01) ([#2031](https://github.com/community-scripts/ProxmoxVE/pull/2031))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Bugfix: Jellyseerr pnpm Version [@vidonnus](https://github.com/vidonnus) ([#2033](https://github.com/community-scripts/ProxmoxVE/pull/2033))
 | 
				
			||||||
 | 
					- Radicale: Fixed missing htpasswd flag [@tremor021](https://github.com/tremor021) ([#2065](https://github.com/community-scripts/ProxmoxVE/pull/2065))
 | 
				
			||||||
 | 
					- [API] Update build.func / Improve error messages #2 [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2050](https://github.com/community-scripts/ProxmoxVE/pull/2050))
 | 
				
			||||||
 | 
					- [API] Update create-lxc.sh / Improve error messages #1 [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2049](https://github.com/community-scripts/ProxmoxVE/pull/2049))
 | 
				
			||||||
 | 
					- Feature: Element Synapse: add option to enter server name during LXC installation [@tremor021](https://github.com/tremor021) ([#2038](https://github.com/community-scripts/ProxmoxVE/pull/2038))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Paperless NGX: Mark it as updateable [@andygrunwald](https://github.com/andygrunwald) ([#2070](https://github.com/community-scripts/ProxmoxVE/pull/2070))
 | 
				
			||||||
 | 
					- Bump vitest from 2.1.6 to 2.1.9 in /frontend [@dependabot[bot]](https://github.com/dependabot[bot]) ([#2042](https://github.com/community-scripts/ProxmoxVE/pull/2042))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🧰 Maintenance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [API] Add API backend code [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2040](https://github.com/community-scripts/ProxmoxVE/pull/2040))
 | 
				
			||||||
 | 
					- Update auto-update-app-headers.yml: Enable auto approval [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2057](https://github.com/community-scripts/ProxmoxVE/pull/2057))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-04
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 💥 Breaking Changes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Rename & Optimize: Proxmox Backup Server (Renaming & Update fix) [@thost96](https://github.com/thost96) ([#2012](https://github.com/community-scripts/ProxmoxVE/pull/2012))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Fix: Authentik - Remove deprecated GO-Remove in Footer [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2020](https://github.com/community-scripts/ProxmoxVE/pull/2020))
 | 
				
			||||||
 | 
					- Fix: Authentik Fix wrong HDD Size [@thost96](https://github.com/thost96) ([#2001](https://github.com/community-scripts/ProxmoxVE/pull/2001))
 | 
				
			||||||
 | 
					- Fix: Tandoor - node Version [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#2010](https://github.com/community-scripts/ProxmoxVE/pull/2010))
 | 
				
			||||||
 | 
					- Fix actual update - missing hidden files, downloaded release cleanup [@maciejmatczak](https://github.com/maciejmatczak) ([#2027](https://github.com/community-scripts/ProxmoxVE/pull/2027))
 | 
				
			||||||
 | 
					- Fix Script: post-pmg-install.sh [@thost96](https://github.com/thost96) ([#2022](https://github.com/community-scripts/ProxmoxVE/pull/2022))
 | 
				
			||||||
 | 
					- Fix Tianji: Add heap-space value for nodejs [@MickLesk](https://github.com/MickLesk) ([#2011](https://github.com/community-scripts/ProxmoxVE/pull/2011))
 | 
				
			||||||
 | 
					- Fix: Ghost LXC - Use Node20 [@MickLesk](https://github.com/MickLesk) ([#2006](https://github.com/community-scripts/ProxmoxVE/pull/2006))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [API] Massive update to api (remove many, optimize website for users) [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1990](https://github.com/community-scripts/ProxmoxVE/pull/1990))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🧰 Maintenance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Fix header comments on contributor templates [@tremor021](https://github.com/tremor021) ([#2029](https://github.com/community-scripts/ProxmoxVE/pull/2029))
 | 
				
			||||||
 | 
					- [Fix]: Headername of Proxmox-Datacenter-Manager not in CamelCase [@MickLesk](https://github.com/MickLesk) ([#2017](https://github.com/community-scripts/ProxmoxVE/pull/2017))
 | 
				
			||||||
 | 
					- [Fix] Header breaks at long title - add width for figlet github action [@MickLesk](https://github.com/MickLesk) ([#2015](https://github.com/community-scripts/ProxmoxVE/pull/2015))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-03
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New Script: Element Synapse [@tremor021](https://github.com/tremor021) ([#1955](https://github.com/community-scripts/ProxmoxVE/pull/1955))
 | 
				
			||||||
 | 
					- New Script: Privatebin [@opastorello](https://github.com/opastorello) ([#1925](https://github.com/community-scripts/ProxmoxVE/pull/1925))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Fix: Monica Install with nodejs [@MickLesk](https://github.com/MickLesk) ([#1996](https://github.com/community-scripts/ProxmoxVE/pull/1996))
 | 
				
			||||||
 | 
					- Element Synapse sed fix [@tremor021](https://github.com/tremor021) ([#1994](https://github.com/community-scripts/ProxmoxVE/pull/1994))
 | 
				
			||||||
 | 
					- Fix Hoarder corepack install/update error [@vhsdream](https://github.com/vhsdream) ([#1957](https://github.com/community-scripts/ProxmoxVE/pull/1957))
 | 
				
			||||||
 | 
					- [Security & Maintenance] Update NodeJS Repo to 22 for new Installs [@MickLesk](https://github.com/MickLesk) ([#1984](https://github.com/community-scripts/ProxmoxVE/pull/1984))
 | 
				
			||||||
 | 
					- [Standardization]: Same Setup for GoLang on all LXC's & Clear Tarball [@MickLesk](https://github.com/MickLesk) ([#1977](https://github.com/community-scripts/ProxmoxVE/pull/1977))
 | 
				
			||||||
 | 
					- Feature: urbackupserver Include fuse&nesting features during install [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1968](https://github.com/community-scripts/ProxmoxVE/pull/1968))
 | 
				
			||||||
 | 
					- Fix: MSSQL-Server: Better gpg handling [@MickLesk](https://github.com/MickLesk) ([#1962](https://github.com/community-scripts/ProxmoxVE/pull/1962))
 | 
				
			||||||
 | 
					- Fix: Grist ran into a heap space during the update [@MickLesk](https://github.com/MickLesk) ([#1964](https://github.com/community-scripts/ProxmoxVE/pull/1964))
 | 
				
			||||||
 | 
					- Fix: FS-Trim Cancel / Error-Button [@MickLesk](https://github.com/MickLesk) ([#1965](https://github.com/community-scripts/ProxmoxVE/pull/1965))
 | 
				
			||||||
 | 
					- Fix: Increase HDD Space for Hoarder [@MickLesk](https://github.com/MickLesk) ([#1970](https://github.com/community-scripts/ProxmoxVE/pull/1970))
 | 
				
			||||||
 | 
					- Feature: Clean Orphan LVM without CEPH [@MickLesk](https://github.com/MickLesk) ([#1974](https://github.com/community-scripts/ProxmoxVE/pull/1974))
 | 
				
			||||||
 | 
					- [Standardization] Fix Spelling for "Setup Python3"  [@MickLesk](https://github.com/MickLesk) ([#1975](https://github.com/community-scripts/ProxmoxVE/pull/1975))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [Website] update data/page.tsx [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1969](https://github.com/community-scripts/ProxmoxVE/pull/1969))
 | 
				
			||||||
 | 
					- Prometheus Proxmox VE Exporter: Set correct website slug [@andygrunwald](https://github.com/andygrunwald) ([#1961](https://github.com/community-scripts/ProxmoxVE/pull/1961))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🧰 Maintenance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [API] Remove Hostname, Verbose, SSH and TAGS [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1967](https://github.com/community-scripts/ProxmoxVE/pull/1967))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-02
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Prometheus PVE Exporter: Add `--default-timeout=300` to pip install commands [@andygrunwald](https://github.com/andygrunwald) ([#1950](https://github.com/community-scripts/ProxmoxVE/pull/1950))
 | 
				
			||||||
 | 
					- fix z2m update function to 2.1.0 [@MickLesk](https://github.com/MickLesk) ([#1938](https://github.com/community-scripts/ProxmoxVE/pull/1938))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🧰 Maintenance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- VSCode: Add Shellscript Syntax highlighting for *.func files [@andygrunwald](https://github.com/andygrunwald) ([#1948](https://github.com/community-scripts/ProxmoxVE/pull/1948))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-02-01
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 💥 Breaking Changes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [DCMA] Delete scripts 5etools and pf2etools - Copyright abuse [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1922](https://github.com/community-scripts/ProxmoxVE/pull/1922))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New script: Baïkal [@bvdberg01](https://github.com/bvdberg01) ([#1913](https://github.com/community-scripts/ProxmoxVE/pull/1913))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Bug fix: Paymenter [@opastorello](https://github.com/opastorello) ([#1917](https://github.com/community-scripts/ProxmoxVE/pull/1917))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-01-31
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New Script: Paymenter [@opastorello](https://github.com/opastorello) ([#1827](https://github.com/community-scripts/ProxmoxVE/pull/1827))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [Fix] Alpine-IT-Tools, add missing ssh package for root ssh access [@CrazyWolf13](https://github.com/CrazyWolf13) ([#1891](https://github.com/community-scripts/ProxmoxVE/pull/1891))
 | 
				
			||||||
 | 
					- [Fix] Change Download of Trilium after there change the tag/release logic [@MickLesk](https://github.com/MickLesk) ([#1892](https://github.com/community-scripts/ProxmoxVE/pull/1892))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [Website] Enhance DataFetcher with better UI components and add reactive data fetching intervals [@BramSuurdje](https://github.com/BramSuurdje) ([#1902](https://github.com/community-scripts/ProxmoxVE/pull/1902))
 | 
				
			||||||
 | 
					- [Website] Update /data/page.tsx [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1900](https://github.com/community-scripts/ProxmoxVE/pull/1900))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 2025-01-30
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Changed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### ✨ New Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- New Script: IT-Tools [@nicedevil007](https://github.com/nicedevil007) ([#1862](https://github.com/community-scripts/ProxmoxVE/pull/1862))
 | 
				
			||||||
 | 
					- New Script: Mattermost [@Dracentis](https://github.com/Dracentis) ([#1856](https://github.com/community-scripts/ProxmoxVE/pull/1856))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🚀 Updated Scripts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Optimize PVE Manager Version-Check [@MickLesk](https://github.com/MickLesk) ([#1866](https://github.com/community-scripts/ProxmoxVE/pull/1866))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🌐 Website
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [API] Update build.func to set the status message correct [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1878](https://github.com/community-scripts/ProxmoxVE/pull/1878))
 | 
				
			||||||
 | 
					- [Website] Update /data/page.tsx [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1876](https://github.com/community-scripts/ProxmoxVE/pull/1876))
 | 
				
			||||||
 | 
					- Fix IT-Tools Website Entry (Default | Alpine)  [@MickLesk](https://github.com/MickLesk) ([#1869](https://github.com/community-scripts/ProxmoxVE/pull/1869))
 | 
				
			||||||
 | 
					- fix: remove rounded styles from command primitive [@steveiliop56](https://github.com/steveiliop56) ([#1840](https://github.com/community-scripts/ProxmoxVE/pull/1840))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 🧰 Maintenance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [API] Update build.func: add function to see if a script failed or not [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#1874](https://github.com/community-scripts/ProxmoxVE/pull/1874))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## 2025-01-29
 | 
					## 2025-01-29
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Changed
 | 
					### Changed
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										5
									
								
								api/.env.example
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								api/.env.example
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
				
			|||||||
 | 
					MONGO_USER=
 | 
				
			||||||
 | 
					MONGO_PASSWORD=
 | 
				
			||||||
 | 
					MONGO_IP=
 | 
				
			||||||
 | 
					MONGO_PORT=
 | 
				
			||||||
 | 
					MONGO_DATABASE=
 | 
				
			||||||
							
								
								
									
										32
									
								
								api/go.mod
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								api/go.mod
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,32 @@
 | 
				
			|||||||
 | 
					module proxmox-api
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					go 1.23.2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require go.mongodb.org/mongo-driver v1.17.2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require (
 | 
				
			||||||
 | 
						filippo.io/edwards25519 v1.1.0 // indirect
 | 
				
			||||||
 | 
						github.com/go-sql-driver/mysql v1.8.1 // indirect
 | 
				
			||||||
 | 
						github.com/golang/snappy v0.0.4 // indirect
 | 
				
			||||||
 | 
						github.com/gorilla/mux v1.8.1 // indirect
 | 
				
			||||||
 | 
						github.com/jackc/pgpassfile v1.0.0 // indirect
 | 
				
			||||||
 | 
						github.com/jackc/pgservicefile v0.0.0-20240606120523-5a60cdf6a761 // indirect
 | 
				
			||||||
 | 
						github.com/jackc/pgx/v5 v5.7.2 // indirect
 | 
				
			||||||
 | 
						github.com/jackc/puddle/v2 v2.2.2 // indirect
 | 
				
			||||||
 | 
						github.com/jinzhu/inflection v1.0.0 // indirect
 | 
				
			||||||
 | 
						github.com/jinzhu/now v1.1.5 // indirect
 | 
				
			||||||
 | 
						github.com/joho/godotenv v1.5.1 // indirect
 | 
				
			||||||
 | 
						github.com/klauspost/compress v1.16.7 // indirect
 | 
				
			||||||
 | 
						github.com/montanaflynn/stats v0.7.1 // indirect
 | 
				
			||||||
 | 
						github.com/rs/cors v1.11.1 // indirect
 | 
				
			||||||
 | 
						github.com/xdg-go/pbkdf2 v1.0.0 // indirect
 | 
				
			||||||
 | 
						github.com/xdg-go/scram v1.1.2 // indirect
 | 
				
			||||||
 | 
						github.com/xdg-go/stringprep v1.0.4 // indirect
 | 
				
			||||||
 | 
						github.com/youmark/pkcs8 v0.0.0-20240726163527-a2c0da244d78 // indirect
 | 
				
			||||||
 | 
						golang.org/x/crypto v0.32.0 // indirect
 | 
				
			||||||
 | 
						golang.org/x/sync v0.10.0 // indirect
 | 
				
			||||||
 | 
						golang.org/x/text v0.21.0 // indirect
 | 
				
			||||||
 | 
						gorm.io/driver/mysql v1.5.7 // indirect
 | 
				
			||||||
 | 
						gorm.io/driver/postgres v1.5.11 // indirect
 | 
				
			||||||
 | 
						gorm.io/gorm v1.25.12 // indirect
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
							
								
								
									
										83
									
								
								api/go.sum
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								api/go.sum
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,83 @@
 | 
				
			|||||||
 | 
					filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA=
 | 
				
			||||||
 | 
					filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4=
 | 
				
			||||||
 | 
					github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
 | 
				
			||||||
 | 
					github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
 | 
				
			||||||
 | 
					github.com/go-sql-driver/mysql v1.8.1 h1:LedoTUt/eveggdHS9qUFC1EFSa8bU2+1pZjSRpvNJ1Y=
 | 
				
			||||||
 | 
					github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqwuVSjsCm7DZg=
 | 
				
			||||||
 | 
					github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM=
 | 
				
			||||||
 | 
					github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
 | 
				
			||||||
 | 
					github.com/gorilla/mux v1.8.1 h1:TuBL49tXwgrFYWhqrNgrUNEY92u81SPhu7sTdzQEiWY=
 | 
				
			||||||
 | 
					github.com/gorilla/mux v1.8.1/go.mod h1:AKf9I4AEqPTmMytcMc0KkNouC66V3BtZ4qD5fmWSiMQ=
 | 
				
			||||||
 | 
					github.com/jackc/pgpassfile v1.0.0 h1:/6Hmqy13Ss2zCq62VdNG8tM1wchn8zjSGOBJ6icpsIM=
 | 
				
			||||||
 | 
					github.com/jackc/pgpassfile v1.0.0/go.mod h1:CEx0iS5ambNFdcRtxPj5JhEz+xB6uRky5eyVu/W2HEg=
 | 
				
			||||||
 | 
					github.com/jackc/pgservicefile v0.0.0-20240606120523-5a60cdf6a761 h1:iCEnooe7UlwOQYpKFhBabPMi4aNAfoODPEFNiAnClxo=
 | 
				
			||||||
 | 
					github.com/jackc/pgservicefile v0.0.0-20240606120523-5a60cdf6a761/go.mod h1:5TJZWKEWniPve33vlWYSoGYefn3gLQRzjfDlhSJ9ZKM=
 | 
				
			||||||
 | 
					github.com/jackc/pgx/v5 v5.7.2 h1:mLoDLV6sonKlvjIEsV56SkWNCnuNv531l94GaIzO+XI=
 | 
				
			||||||
 | 
					github.com/jackc/pgx/v5 v5.7.2/go.mod h1:ncY89UGWxg82EykZUwSpUKEfccBGGYq1xjrOpsbsfGQ=
 | 
				
			||||||
 | 
					github.com/jackc/puddle/v2 v2.2.2 h1:PR8nw+E/1w0GLuRFSmiioY6UooMp6KJv0/61nB7icHo=
 | 
				
			||||||
 | 
					github.com/jackc/puddle/v2 v2.2.2/go.mod h1:vriiEXHvEE654aYKXXjOvZM39qJ0q+azkZFrfEOc3H4=
 | 
				
			||||||
 | 
					github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
 | 
				
			||||||
 | 
					github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc=
 | 
				
			||||||
 | 
					github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ=
 | 
				
			||||||
 | 
					github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
 | 
				
			||||||
 | 
					github.com/joho/godotenv v1.5.1 h1:7eLL/+HRGLY0ldzfGMeQkb7vMd0as4CfYvUVzLqw0N0=
 | 
				
			||||||
 | 
					github.com/joho/godotenv v1.5.1/go.mod h1:f4LDr5Voq0i2e/R5DDNOoa2zzDfwtkZa6DnEwAbqwq4=
 | 
				
			||||||
 | 
					github.com/klauspost/compress v1.16.7 h1:2mk3MPGNzKyxErAw8YaohYh69+pa4sIQSC0fPGCFR9I=
 | 
				
			||||||
 | 
					github.com/klauspost/compress v1.16.7/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE=
 | 
				
			||||||
 | 
					github.com/montanaflynn/stats v0.7.1 h1:etflOAAHORrCC44V+aR6Ftzort912ZU+YLiSTuV8eaE=
 | 
				
			||||||
 | 
					github.com/montanaflynn/stats v0.7.1/go.mod h1:etXPPgVO6n31NxCd9KQUMvCM+ve0ruNzt6R8Bnaayow=
 | 
				
			||||||
 | 
					github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
 | 
				
			||||||
 | 
					github.com/rs/cors v1.11.1 h1:eU3gRzXLRK57F5rKMGMZURNdIG4EoAmX8k94r9wXWHA=
 | 
				
			||||||
 | 
					github.com/rs/cors v1.11.1/go.mod h1:XyqrcTp5zjWr1wsJ8PIRZssZ8b/WMcMf71DJnit4EMU=
 | 
				
			||||||
 | 
					github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
 | 
				
			||||||
 | 
					github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
 | 
				
			||||||
 | 
					github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
 | 
				
			||||||
 | 
					github.com/xdg-go/pbkdf2 v1.0.0 h1:Su7DPu48wXMwC3bs7MCNG+z4FhcyEuz5dlvchbq0B0c=
 | 
				
			||||||
 | 
					github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI=
 | 
				
			||||||
 | 
					github.com/xdg-go/scram v1.1.2 h1:FHX5I5B4i4hKRVRBCFRxq1iQRej7WO3hhBuJf+UUySY=
 | 
				
			||||||
 | 
					github.com/xdg-go/scram v1.1.2/go.mod h1:RT/sEzTbU5y00aCK8UOx6R7YryM0iF1N2MOmC3kKLN4=
 | 
				
			||||||
 | 
					github.com/xdg-go/stringprep v1.0.4 h1:XLI/Ng3O1Atzq0oBs3TWm+5ZVgkq2aqdlvP9JtoZ6c8=
 | 
				
			||||||
 | 
					github.com/xdg-go/stringprep v1.0.4/go.mod h1:mPGuuIYwz7CmR2bT9j4GbQqutWS1zV24gijq1dTyGkM=
 | 
				
			||||||
 | 
					github.com/youmark/pkcs8 v0.0.0-20240726163527-a2c0da244d78 h1:ilQV1hzziu+LLM3zUTJ0trRztfwgjqKnBWNtSRkbmwM=
 | 
				
			||||||
 | 
					github.com/youmark/pkcs8 v0.0.0-20240726163527-a2c0da244d78/go.mod h1:aL8wCCfTfSfmXjznFBSZNN13rSJjlIOI1fUNAtF7rmI=
 | 
				
			||||||
 | 
					github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
 | 
				
			||||||
 | 
					go.mongodb.org/mongo-driver v1.17.2 h1:gvZyk8352qSfzyZ2UMWcpDpMSGEr1eqE4T793SqyhzM=
 | 
				
			||||||
 | 
					go.mongodb.org/mongo-driver v1.17.2/go.mod h1:Hy04i7O2kC4RS06ZrhPRqj/u4DTYkFDAAccj+rVKqgQ=
 | 
				
			||||||
 | 
					golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
 | 
				
			||||||
 | 
					golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
 | 
				
			||||||
 | 
					golang.org/x/crypto v0.32.0 h1:euUpcYgM8WcP71gNpTqQCn6rC2t6ULUPiOzfWaXVVfc=
 | 
				
			||||||
 | 
					golang.org/x/crypto v0.32.0/go.mod h1:ZnnJkOaASj8g0AjIduWNlq2NRxL0PlBrbKVyZ6V/Ugc=
 | 
				
			||||||
 | 
					golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4=
 | 
				
			||||||
 | 
					golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
 | 
				
			||||||
 | 
					golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg=
 | 
				
			||||||
 | 
					golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
 | 
				
			||||||
 | 
					golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
 | 
				
			||||||
 | 
					golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
 | 
				
			||||||
 | 
					golang.org/x/sync v0.10.0 h1:3NQrjDixjgGwUOCaF8w2+VYHv0Ve/vGYSbdkTa98gmQ=
 | 
				
			||||||
 | 
					golang.org/x/sync v0.10.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
 | 
				
			||||||
 | 
					golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
 | 
				
			||||||
 | 
					golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
 | 
				
			||||||
 | 
					golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
 | 
				
			||||||
 | 
					golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
 | 
				
			||||||
 | 
					golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
 | 
				
			||||||
 | 
					golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
 | 
				
			||||||
 | 
					golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
 | 
				
			||||||
 | 
					golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
 | 
				
			||||||
 | 
					golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
 | 
				
			||||||
 | 
					golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
 | 
				
			||||||
 | 
					golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ=
 | 
				
			||||||
 | 
					golang.org/x/text v0.21.0 h1:zyQAAkrwaneQ066sspRyJaG9VNi/YJ1NfzcGB3hZ/qo=
 | 
				
			||||||
 | 
					golang.org/x/text v0.21.0/go.mod h1:4IBbMaMmOPCJ8SecivzSH54+73PCFmPWxNTLm+vZkEQ=
 | 
				
			||||||
 | 
					golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
 | 
				
			||||||
 | 
					golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
 | 
				
			||||||
 | 
					golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
 | 
				
			||||||
 | 
					golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
 | 
				
			||||||
 | 
					gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
 | 
				
			||||||
 | 
					gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
 | 
				
			||||||
 | 
					gorm.io/driver/mysql v1.5.7 h1:MndhOPYOfEp2rHKgkZIhJ16eVUIRf2HmzgoPmh7FCWo=
 | 
				
			||||||
 | 
					gorm.io/driver/mysql v1.5.7/go.mod h1:sEtPWMiqiN1N1cMXoXmBbd8C6/l+TESwriotuRRpkDM=
 | 
				
			||||||
 | 
					gorm.io/driver/postgres v1.5.11 h1:ubBVAfbKEUld/twyKZ0IYn9rSQh448EdelLYk9Mv314=
 | 
				
			||||||
 | 
					gorm.io/driver/postgres v1.5.11/go.mod h1:DX3GReXH+3FPWGrrgffdvCk3DQ1dwDPdmbenSkweRGI=
 | 
				
			||||||
 | 
					gorm.io/gorm v1.25.7/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
 | 
				
			||||||
 | 
					gorm.io/gorm v1.25.12 h1:I0u8i2hWQItBq1WfE0o2+WuL9+8L21K9e2HHSTE/0f8=
 | 
				
			||||||
 | 
					gorm.io/gorm v1.25.12/go.mod h1:xh7N7RHfYlNc5EmcI/El95gXusucDrQnHXe0+CgWcLQ=
 | 
				
			||||||
							
								
								
									
										167
									
								
								api/main.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										167
									
								
								api/main.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,167 @@
 | 
				
			|||||||
 | 
					// Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					// Author: Michel Roegl-Brunner (michelroegl-brunner)
 | 
				
			||||||
 | 
					// License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					package main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"context"
 | 
				
			||||||
 | 
						"encoding/json"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"log"
 | 
				
			||||||
 | 
						"net/http"
 | 
				
			||||||
 | 
						"os"
 | 
				
			||||||
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/gorilla/mux"
 | 
				
			||||||
 | 
						"github.com/joho/godotenv"
 | 
				
			||||||
 | 
						"github.com/rs/cors"
 | 
				
			||||||
 | 
						"go.mongodb.org/mongo-driver/bson"
 | 
				
			||||||
 | 
						"go.mongodb.org/mongo-driver/bson/primitive"
 | 
				
			||||||
 | 
						"go.mongodb.org/mongo-driver/mongo"
 | 
				
			||||||
 | 
						"go.mongodb.org/mongo-driver/mongo/options"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					var client *mongo.Client
 | 
				
			||||||
 | 
					var collection *mongo.Collection
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func loadEnv() {
 | 
				
			||||||
 | 
						if err := godotenv.Load(); err != nil {
 | 
				
			||||||
 | 
							log.Fatal("Error loading .env file")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type DataModel struct {
 | 
				
			||||||
 | 
						ID         primitive.ObjectID `json:"id" bson:"_id,omitempty"`
 | 
				
			||||||
 | 
						CT_TYPE    uint               `json:"ct_type" bson:"ct_type"`
 | 
				
			||||||
 | 
						DISK_SIZE  float32            `json:"disk_size" bson:"disk_size"`
 | 
				
			||||||
 | 
						CORE_COUNT uint               `json:"core_count" bson:"core_count"`
 | 
				
			||||||
 | 
						RAM_SIZE   uint               `json:"ram_size" bson:"ram_size"`
 | 
				
			||||||
 | 
						OS_TYPE    string             `json:"os_type" bson:"os_type"`
 | 
				
			||||||
 | 
						OS_VERSION string             `json:"os_version" bson:"os_version"`
 | 
				
			||||||
 | 
						DISABLEIP6 string             `json:"disableip6" bson:"disableip6"`
 | 
				
			||||||
 | 
						NSAPP      string             `json:"nsapp" bson:"nsapp"`
 | 
				
			||||||
 | 
						METHOD     string             `json:"method" bson:"method"`
 | 
				
			||||||
 | 
						CreatedAt  time.Time          `json:"created_at" bson:"created_at"`
 | 
				
			||||||
 | 
						PVEVERSION string             `json:"pve_version" bson:"pve_version"`
 | 
				
			||||||
 | 
						STATUS     string             `json:"status" bson:"status"`
 | 
				
			||||||
 | 
						RANDOM_ID  string             `json:"random_id" bson:"random_id"`
 | 
				
			||||||
 | 
						TYPE       string             `json:"type" bson:"type"`
 | 
				
			||||||
 | 
						ERROR      string             `json:"error" bson:"error"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type StatusModel struct {
 | 
				
			||||||
 | 
						RANDOM_ID string `json:"random_id" bson:"random_id"`
 | 
				
			||||||
 | 
						ERROR     string `json:"error" bson:"error"`
 | 
				
			||||||
 | 
						STATUS    string `json:"status" bson:"status"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func ConnectDatabase() {
 | 
				
			||||||
 | 
						loadEnv()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mongoURI := fmt.Sprintf("mongodb://%s:%s@%s:%s",
 | 
				
			||||||
 | 
							os.Getenv("MONGO_USER"),
 | 
				
			||||||
 | 
							os.Getenv("MONGO_PASSWORD"),
 | 
				
			||||||
 | 
							os.Getenv("MONGO_IP"),
 | 
				
			||||||
 | 
							os.Getenv("MONGO_PORT"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						database := os.Getenv("MONGO_DATABASE")
 | 
				
			||||||
 | 
						ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
 | 
				
			||||||
 | 
						defer cancel()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						var err error
 | 
				
			||||||
 | 
						client, err = mongo.Connect(ctx, options.Client().ApplyURI(mongoURI))
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							log.Fatal("Failed to connect to MongoDB!", err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						collection = client.Database(database).Collection("data_models")
 | 
				
			||||||
 | 
						fmt.Println("Connected to MongoDB on 10.10.10.18")
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func UploadJSON(w http.ResponseWriter, r *http.Request) {
 | 
				
			||||||
 | 
						var input DataModel
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if err := json.NewDecoder(r.Body).Decode(&input); err != nil {
 | 
				
			||||||
 | 
							http.Error(w, err.Error(), http.StatusBadRequest)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						input.CreatedAt = time.Now()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						_, err := collection.InsertOne(context.Background(), input)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							http.Error(w, err.Error(), http.StatusInternalServerError)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						log.Println("Received data:", input)
 | 
				
			||||||
 | 
						w.WriteHeader(http.StatusCreated)
 | 
				
			||||||
 | 
						json.NewEncoder(w).Encode(map[string]string{"message": "Data saved successfully"})
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func UpdateStatus(w http.ResponseWriter, r *http.Request) {
 | 
				
			||||||
 | 
						var input StatusModel
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if err := json.NewDecoder(r.Body).Decode(&input); err != nil {
 | 
				
			||||||
 | 
							http.Error(w, err.Error(), http.StatusBadRequest)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						filter := bson.M{"random_id": input.RANDOM_ID}
 | 
				
			||||||
 | 
						update := bson.M{"$set": bson.M{"status": input.STATUS, "error": input.ERROR}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						_, err := collection.UpdateOne(context.Background(), filter, update)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							http.Error(w, err.Error(), http.StatusInternalServerError)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						log.Println("Updated data:", input)
 | 
				
			||||||
 | 
						w.WriteHeader(http.StatusOK)
 | 
				
			||||||
 | 
						json.NewEncoder(w).Encode(map[string]string{"message": "Record updated successfully"})
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func GetDataJSON(w http.ResponseWriter, r *http.Request) {
 | 
				
			||||||
 | 
						var records []DataModel
 | 
				
			||||||
 | 
						ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
 | 
				
			||||||
 | 
						defer cancel()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						cursor, err := collection.Find(ctx, bson.M{})
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							http.Error(w, err.Error(), http.StatusInternalServerError)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						defer cursor.Close(ctx)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for cursor.Next(ctx) {
 | 
				
			||||||
 | 
							var record DataModel
 | 
				
			||||||
 | 
							if err := cursor.Decode(&record); err != nil {
 | 
				
			||||||
 | 
								http.Error(w, err.Error(), http.StatusInternalServerError)
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							records = append(records, record)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						w.Header().Set("Content-Type", "application/json")
 | 
				
			||||||
 | 
						json.NewEncoder(w).Encode(records)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func main() {
 | 
				
			||||||
 | 
						ConnectDatabase()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						router := mux.NewRouter()
 | 
				
			||||||
 | 
						router.HandleFunc("/upload", UploadJSON).Methods("POST")
 | 
				
			||||||
 | 
						router.HandleFunc("/upload/updatestatus", UpdateStatus).Methods("POST")
 | 
				
			||||||
 | 
						router.HandleFunc("/data/json", GetDataJSON).Methods("GET")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						c := cors.New(cors.Options{
 | 
				
			||||||
 | 
							AllowedOrigins:   []string{"*"},
 | 
				
			||||||
 | 
							AllowedMethods:   []string{"GET", "POST"},
 | 
				
			||||||
 | 
							AllowedHeaders:   []string{"Content-Type", "Authorization"},
 | 
				
			||||||
 | 
							AllowCredentials: true,
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						handler := c.Handler(router)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						fmt.Println("Server running on port 8080")
 | 
				
			||||||
 | 
						log.Fatal(http.ListenAndServe(":8080", handler))
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										113
									
								
								ct/5etools.sh
									
									
									
									
									
								
							
							
						
						
									
										113
									
								
								ct/5etools.sh
									
									
									
									
									
								
							@@ -1,113 +0,0 @@
 | 
				
			|||||||
#!/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}"
 | 
					 | 
				
			||||||
@@ -44,9 +44,8 @@ function update_script() {
 | 
				
			|||||||
        cd /tmp
 | 
					        cd /tmp
 | 
				
			||||||
        wget -q https://github.com/actualbudget/actual-server/archive/refs/tags/v${RELEASE}.tar.gz
 | 
					        wget -q https://github.com/actualbudget/actual-server/archive/refs/tags/v${RELEASE}.tar.gz
 | 
				
			||||||
        mv /opt/actualbudget /opt/actualbudget_bak
 | 
					        mv /opt/actualbudget /opt/actualbudget_bak
 | 
				
			||||||
        mkdir -p /opt/actualbudget/
 | 
					 | 
				
			||||||
        tar -xzf v${RELEASE}.tar.gz >/dev/null 2>&1
 | 
					        tar -xzf v${RELEASE}.tar.gz >/dev/null 2>&1
 | 
				
			||||||
        mv *ctual-server-*/* /opt/actualbudget
 | 
					        mv *ctual-server-* /opt/actualbudget
 | 
				
			||||||
        rm -rf /opt/actualbudget/.env
 | 
					        rm -rf /opt/actualbudget/.env
 | 
				
			||||||
        mv /opt/actualbudget_bak/.env /opt/actualbudget
 | 
					        mv /opt/actualbudget_bak/.env /opt/actualbudget
 | 
				
			||||||
        mv /opt/actualbudget_bak/server-files /opt/actualbudget/server-files
 | 
					        mv /opt/actualbudget_bak/server-files /opt/actualbudget/server-files
 | 
				
			||||||
@@ -61,7 +60,7 @@ function update_script() {
 | 
				
			|||||||
        
 | 
					        
 | 
				
			||||||
        msg_info "Cleaning Up"
 | 
					        msg_info "Cleaning Up"
 | 
				
			||||||
        rm -rf /opt/actualbudget_bak
 | 
					        rm -rf /opt/actualbudget_bak
 | 
				
			||||||
        rm -rf /tmp/actual-server.tar.gz
 | 
					        rm -rf /tmp/v${RELEASE}.tar.gz
 | 
				
			||||||
        msg_ok "Cleaned"
 | 
					        msg_ok "Cleaned"
 | 
				
			||||||
        msg_ok "Updated Successfully"
 | 
					        msg_ok "Updated Successfully"
 | 
				
			||||||
    else
 | 
					    else
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										63
									
								
								ct/alpine-it-tools.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								ct/alpine-it-tools.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					#!/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: nicedevil007 (NiceDevil)
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Alpine-IT-Tools"
 | 
				
			||||||
 | 
					var_tags="alpine;development"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="256"
 | 
				
			||||||
 | 
					var_disk="0.2"
 | 
				
			||||||
 | 
					var_os="alpine"
 | 
				
			||||||
 | 
					var_version="3.21"
 | 
				
			||||||
 | 
					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 /usr/share/nginx/html ]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit 1
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					RELEASE=$(curl -s https://api.github.com/repos/CorentinTh/it-tools/releases/latest | grep '"tag_name":' | cut -d '"' -f4)
 | 
				
			||||||
 | 
					if [ "${RELEASE}" != "$(cat /opt/${APP}_version.txt 2>/dev/null)" ] || [ ! -f /opt/${APP}_version.txt ]; then
 | 
				
			||||||
 | 
					    DOWNLOAD_URL="https://github.com/CorentinTh/it-tools/releases/download/${RELEASE}/it-tools-${RELEASE#v}.zip"
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP} LXC"
 | 
				
			||||||
 | 
					    curl -fsSL -o it-tools.zip "$DOWNLOAD_URL"
 | 
				
			||||||
 | 
					    mkdir -p /usr/share/nginx/html
 | 
				
			||||||
 | 
					    rm -rf /usr/share/nginx/html/*
 | 
				
			||||||
 | 
					    unzip -q it-tools.zip -d /tmp/it-tools
 | 
				
			||||||
 | 
					    cp -r /tmp/it-tools/dist/* /usr/share/nginx/html
 | 
				
			||||||
 | 
					    rm -rf /tmp/it-tools
 | 
				
			||||||
 | 
					    rm -f it-tools.zip
 | 
				
			||||||
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					    msg_ok "No update required. ${APP} is already at ${RELEASE}"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					exit 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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}http://${IP}${CL}"
 | 
				
			||||||
							
								
								
									
										69
									
								
								ct/apache-tika.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										69
									
								
								ct/apache-tika.sh
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,69 @@
 | 
				
			|||||||
 | 
					#!/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: Andy Grunwald (andygrunwald)
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/apache/tika/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Apache-Tika"
 | 
				
			||||||
 | 
					var_tags="document"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					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 [[ ! -f /etc/systemd/system/apache-tika.service ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE="$(wget -qO- https://dlcdn.apache.org/tika/ | grep -oP '(?<=href=")[0-9]+\.[0-9]+\.[0-9]+(?=/")' | sort -V | tail -n1)"
 | 
				
			||||||
 | 
					  if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then
 | 
				
			||||||
 | 
					    msg_info "Stopping ${APP}"
 | 
				
			||||||
 | 
					    systemctl stop apache-tika
 | 
				
			||||||
 | 
					    msg_ok "Stopped ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					    cd /opt/apache-tika
 | 
				
			||||||
 | 
					    wget -q "https://dlcdn.apache.org/tika/${RELEASE}/tika-server-standard-${RELEASE}.jar"
 | 
				
			||||||
 | 
					    mv --force tika-server-standard.jar tika-server-standard-prev-version.jar
 | 
				
			||||||
 | 
					    mv tika-server-standard-${RELEASE}.jar tika-server-standard.jar
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    msg_ok "Updated ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting ${APP}"
 | 
				
			||||||
 | 
					    systemctl start apache-tika
 | 
				
			||||||
 | 
					    msg_ok "Started ${APP}"
 | 
				
			||||||
 | 
					    msg_info "Cleaning Up"
 | 
				
			||||||
 | 
					    rm -rf /opt/apache-tika/tika-server-standard-prev-version.jar
 | 
				
			||||||
 | 
					    msg_ok "Cleanup Completed"
 | 
				
			||||||
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					  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}:9998${CL}"
 | 
				
			||||||
@@ -8,7 +8,7 @@ source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/m
 | 
				
			|||||||
# App Default Values
 | 
					# App Default Values
 | 
				
			||||||
APP="Authentik"
 | 
					APP="Authentik"
 | 
				
			||||||
var_tags="identity-provider"
 | 
					var_tags="identity-provider"
 | 
				
			||||||
var_disk="15"
 | 
					var_disk="12"
 | 
				
			||||||
var_cpu="6"
 | 
					var_cpu="6"
 | 
				
			||||||
var_ram="8192"
 | 
					var_ram="8192"
 | 
				
			||||||
var_os="debian"
 | 
					var_os="debian"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										75
									
								
								ct/baikal.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								ct/baikal.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,75 @@
 | 
				
			|||||||
 | 
					#!/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: bvdberg01
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://sabre.io/baikal/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Baikal"
 | 
				
			||||||
 | 
					var_tags="Dav"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="512"
 | 
				
			||||||
 | 
					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 [[ ! -d /opt/baikal ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/sabre-io/Baikal/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 apache2
 | 
				
			||||||
 | 
					    msg_ok "Stopped Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					    cd /opt
 | 
				
			||||||
 | 
					    wget -q "https://github.com/sabre-io/baikal/releases/download/${RELEASE}/baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					    mv /opt/baikal /opt/baikal-backup
 | 
				
			||||||
 | 
					    unzip -o -q "baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					    cp -r /opt/baikal-backup/config/baikal.yaml /opt/baikal/config/
 | 
				
			||||||
 | 
					    cp -r /opt/baikal-backup/Specific/ /opt/baikal/
 | 
				
			||||||
 | 
					    chown -R www-data:www-data /opt/baikal/
 | 
				
			||||||
 | 
					    chmod -R 755 /opt/baikal/
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    msg_ok "Updated $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting Service"
 | 
				
			||||||
 | 
					    systemctl start apache2
 | 
				
			||||||
 | 
					    msg_ok "Started Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Cleaning up"
 | 
				
			||||||
 | 
					    rm -rf "/opt/baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					    rm -rf /opt/baikal-backup
 | 
				
			||||||
 | 
					    msg_ok "Cleaned"
 | 
				
			||||||
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					  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}${CL}"
 | 
				
			||||||
							
								
								
									
										90
									
								
								ct/crafty-controller.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								ct/crafty-controller.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,90 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts
 | 
				
			||||||
 | 
					# Author: CrazyWolf13
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Crafty-Controller"
 | 
				
			||||||
 | 
					var_tags="gaming"
 | 
				
			||||||
 | 
					var_cpu="2"
 | 
				
			||||||
 | 
					var_ram="4096"
 | 
				
			||||||
 | 
					var_disk="16"
 | 
				
			||||||
 | 
					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/crafty-controller ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					   
 | 
				
			||||||
 | 
					    RELEASE=$(curl -s "https://gitlab.com/api/v4/projects/20430749/releases" | grep -o '"tag_name":"v[^"]*"' | head -n 1 | sed 's/"tag_name":"v//;s/"//')
 | 
				
			||||||
 | 
					    if [[ ! -f /opt/crafty-controller_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/crafty-controller_version.txt)" ]]; then
 | 
				
			||||||
 | 
					      
 | 
				
			||||||
 | 
					      msg_info "Stopping Crafty-Controller"
 | 
				
			||||||
 | 
					      systemctl stop crafty-controller
 | 
				
			||||||
 | 
					      msg_ok "Stopped Crafty-Controller"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      msg_info "Creating Backup of config"
 | 
				
			||||||
 | 
					      cp -a /opt/crafty-controller/crafty/crafty-4/app/config/. /opt/crafty-controller/backup
 | 
				
			||||||
 | 
					      rm /opt/crafty-controller/backup/version.json
 | 
				
			||||||
 | 
					      rm /opt/crafty-controller/backup/credits.json
 | 
				
			||||||
 | 
					      rm /opt/crafty-controller/backup/logging.json
 | 
				
			||||||
 | 
					      rm /opt/crafty-controller/backup/default.json.example
 | 
				
			||||||
 | 
					      rm /opt/crafty-controller/backup/motd_format.json
 | 
				
			||||||
 | 
					      msg_ok "Backup Created"
 | 
				
			||||||
 | 
					      
 | 
				
			||||||
 | 
					      msg_info "Updating Crafty-Controller to v${RELEASE}"
 | 
				
			||||||
 | 
					      wget -q "https://gitlab.com/crafty-controller/crafty-4/-/archive/v${RELEASE}/crafty-4-v${RELEASE}.zip"
 | 
				
			||||||
 | 
					      unzip -q crafty-4-v${RELEASE}.zip
 | 
				
			||||||
 | 
					      cp -a crafty-4-v${RELEASE}/. /opt/crafty-controller/crafty/crafty-4/
 | 
				
			||||||
 | 
					      rm -rf crafty-4-v${RELEASE}
 | 
				
			||||||
 | 
					      cd /opt/crafty-controller/crafty/crafty-4
 | 
				
			||||||
 | 
					      sudo -u crafty bash -c '
 | 
				
			||||||
 | 
					        source /opt/crafty-controller/crafty/.venv/bin/activate
 | 
				
			||||||
 | 
					        pip3 install --no-cache-dir -r requirements.txt
 | 
				
			||||||
 | 
					      ' &>/dev/null
 | 
				
			||||||
 | 
					      echo "${RELEASE}" >"/opt/crafty-controller_version.txt"
 | 
				
			||||||
 | 
					      msg_ok "Updated Crafty-Controller to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      msg_info "Restoring Backup of config"
 | 
				
			||||||
 | 
					      cp -a /opt/crafty-controller/backup/. /opt/crafty-controller/crafty/crafty-4/app/config
 | 
				
			||||||
 | 
					      rm -rf /opt/crafty-controller/backup
 | 
				
			||||||
 | 
					      chown -R crafty:crafty /opt/crafty-controller/
 | 
				
			||||||
 | 
					      msg_ok "Backup Restored"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      msg_info "Starting Crafty-Controller"
 | 
				
			||||||
 | 
					      systemctl start crafty-controller
 | 
				
			||||||
 | 
					      msg_ok "Started Crafty-Controller"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					      exit
 | 
				
			||||||
 | 
					  else
 | 
				
			||||||
 | 
					    msg_ok "No update required. Crafty-Controller is already at v${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}https://${IP}:8443${CL}"
 | 
				
			||||||
@@ -43,6 +43,7 @@ function error_handler() {
 | 
				
			|||||||
  local command="$2"
 | 
					  local command="$2"
 | 
				
			||||||
  local error_message="${RD}[ERROR]${CL} in line ${RD}$line_number${CL}: exit code ${RD}$exit_code${CL}: while executing command ${YW}$command${CL}"
 | 
					  local error_message="${RD}[ERROR]${CL} in line ${RD}$line_number${CL}: exit code ${RD}$exit_code${CL}: while executing command ${YW}$command${CL}"
 | 
				
			||||||
  echo -e "\n$error_message\n"
 | 
					  echo -e "\n$error_message\n"
 | 
				
			||||||
 | 
					  exit 200
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This function displays a spinner.
 | 
					# This function displays a spinner.
 | 
				
			||||||
@@ -112,7 +113,7 @@ function select_storage() {
 | 
				
			|||||||
    CONTENT='vztmpl'
 | 
					    CONTENT='vztmpl'
 | 
				
			||||||
    CONTENT_LABEL='Container template'
 | 
					    CONTENT_LABEL='Container template'
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
  *) false || exit "Invalid storage class." ;;
 | 
					  *) false || { msg_error "Invalid storage class."; exit 201; };
 | 
				
			||||||
  esac
 | 
					  esac
 | 
				
			||||||
  
 | 
					  
 | 
				
			||||||
  # This Queries all storage locations
 | 
					  # This Queries all storage locations
 | 
				
			||||||
@@ -138,7 +139,7 @@ function select_storage() {
 | 
				
			|||||||
      STORAGE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Storage Pools" --radiolist \
 | 
					      STORAGE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Storage Pools" --radiolist \
 | 
				
			||||||
      "Which storage pool you would like to use for the ${CONTENT_LABEL,,}?\nTo make a selection, use the Spacebar.\n" \
 | 
					      "Which storage pool you would like to use for the ${CONTENT_LABEL,,}?\nTo make a selection, use the Spacebar.\n" \
 | 
				
			||||||
      16 $(($MSG_MAX_LENGTH + 23)) 6 \
 | 
					      16 $(($MSG_MAX_LENGTH + 23)) 6 \
 | 
				
			||||||
      "${MENU[@]}" 3>&1 1>&2 2>&3) || exit "Menu aborted."
 | 
					      "${MENU[@]}" 3>&1 1>&2 2>&3) || { msg_error "Menu aborted."; exit 202; }
 | 
				
			||||||
      if [ $? -ne 0 ]; then
 | 
					      if [ $? -ne 0 ]; then
 | 
				
			||||||
        echo -e "${CROSS}${RD} Menu aborted by user.${CL}"
 | 
					        echo -e "${CROSS}${RD} Menu aborted by user.${CL}"
 | 
				
			||||||
        exit 0 
 | 
					        exit 0 
 | 
				
			||||||
@@ -148,17 +149,18 @@ function select_storage() {
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
# Test if required variables are set
 | 
					# Test if required variables are set
 | 
				
			||||||
[[ "${CTID:-}" ]] || exit "You need to set 'CTID' variable."
 | 
					[[ "${CTID:-}" ]] || { msg_error "You need to set 'CTID' variable."; exit 203; }
 | 
				
			||||||
[[ "${PCT_OSTYPE:-}" ]] || exit "You need to set 'PCT_OSTYPE' variable."
 | 
					[[ "${PCT_OSTYPE:-}" ]] || { msg_error "You need to set 'PCT_OSTYPE' variable."; exit 204; }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Test if ID is valid
 | 
					# Test if ID is valid
 | 
				
			||||||
[ "$CTID" -ge "100" ] || exit "ID cannot be less than 100."
 | 
					[ "$CTID" -ge "100" ] || { msg_error "ID cannot be less than 100."; exit 205; }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Test if ID is in use
 | 
					# Test if ID is in use
 | 
				
			||||||
if pct status $CTID &>/dev/null; then
 | 
					if pct status $CTID &>/dev/null; then
 | 
				
			||||||
  echo -e "ID '$CTID' is already in use."
 | 
					  echo -e "ID '$CTID' is already in use."
 | 
				
			||||||
  unset CTID
 | 
					  unset CTID
 | 
				
			||||||
  exit "Cannot use ID that is already in use."
 | 
					  msg_error "Cannot use ID that is already in use."
 | 
				
			||||||
 | 
					  exit 206
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Get template storage
 | 
					# Get template storage
 | 
				
			||||||
@@ -177,14 +179,15 @@ msg_ok "Updated LXC Template List"
 | 
				
			|||||||
# Get LXC template string
 | 
					# Get LXC template string
 | 
				
			||||||
TEMPLATE_SEARCH=${PCT_OSTYPE}-${PCT_OSVERSION:-}
 | 
					TEMPLATE_SEARCH=${PCT_OSTYPE}-${PCT_OSVERSION:-}
 | 
				
			||||||
mapfile -t TEMPLATES < <(pveam available -section system | sed -n "s/.*\($TEMPLATE_SEARCH.*\)/\1/p" | sort -t - -k 2 -V)
 | 
					mapfile -t TEMPLATES < <(pveam available -section system | sed -n "s/.*\($TEMPLATE_SEARCH.*\)/\1/p" | sort -t - -k 2 -V)
 | 
				
			||||||
[ ${#TEMPLATES[@]} -gt 0 ] || exit "Unable to find a template when searching for '$TEMPLATE_SEARCH'."
 | 
					[ ${#TEMPLATES[@]} -gt 0 ] || { msg_error "Unable to find a template when searching for '$TEMPLATE_SEARCH'."; exit 207; }
 | 
				
			||||||
TEMPLATE="${TEMPLATES[-1]}"
 | 
					TEMPLATE="${TEMPLATES[-1]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Download LXC template if needed
 | 
					# Download LXC template if needed
 | 
				
			||||||
if ! pveam list $TEMPLATE_STORAGE | grep -q $TEMPLATE; then
 | 
					if ! pveam list $TEMPLATE_STORAGE | grep -q $TEMPLATE; then
 | 
				
			||||||
  msg_info "Downloading LXC Template"
 | 
					  msg_info "Downloading LXC Template"
 | 
				
			||||||
  pveam download $TEMPLATE_STORAGE $TEMPLATE >/dev/null ||
 | 
					  pveam download $TEMPLATE_STORAGE $TEMPLATE >/dev/null ||
 | 
				
			||||||
    exit "A problem occured while downloading the LXC template."
 | 
					    msg_error "A problem occured while downloading the LXC template."
 | 
				
			||||||
 | 
					    exit 208
 | 
				
			||||||
  msg_ok "Downloaded LXC Template"
 | 
					  msg_ok "Downloaded LXC Template"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -197,6 +200,6 @@ PCT_OPTIONS=(${PCT_OPTIONS[@]:-${DEFAULT_PCT_OPTIONS[@]}})
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Create container
 | 
					# Create container
 | 
				
			||||||
msg_info "Creating LXC Container"
 | 
					msg_info "Creating LXC Container"
 | 
				
			||||||
pct create $CTID ${TEMPLATE_STORAGE}:vztmpl/${TEMPLATE} ${PCT_OPTIONS[@]} >/dev/null ||
 | 
					pct create $CTID ${TEMPLATE_STORAGE}:vztmpl/${TEMPLATE} ${PCT_OPTIONS[@]} >/dev/null || { msg_error "A problem occured while trying to create container.";  exit 200; }
 | 
				
			||||||
  exit "A problem occured while trying to create container."
 | 
					 | 
				
			||||||
msg_ok "LXC Container ${BL}$CTID${CL} ${GN}was successfully created."
 | 
					msg_ok "LXC Container ${BL}$CTID${CL} ${GN}was successfully created."
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -73,7 +73,7 @@ function update_script() {
 | 
				
			|||||||
    msg_info "Setting up Node.js Repository"
 | 
					    msg_info "Setting up Node.js Repository"
 | 
				
			||||||
    mkdir -p /etc/apt/keyrings
 | 
					    mkdir -p /etc/apt/keyrings
 | 
				
			||||||
    curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
					    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_ok "Set up Node.js Repository"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Installing Node.js"
 | 
					    msg_info "Installing Node.js"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										65
									
								
								ct/duplicati.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								ct/duplicati.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,65 @@
 | 
				
			|||||||
 | 
					#!/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: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/duplicati/duplicati/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					APP="Duplicati"
 | 
				
			||||||
 | 
					TAGS="backup"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="1024"
 | 
				
			||||||
 | 
					var_disk="10"
 | 
				
			||||||
 | 
					var_os="debian"
 | 
				
			||||||
 | 
					var_version="12"
 | 
				
			||||||
 | 
					var_unprivileged="1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					header_info "$APP"
 | 
				
			||||||
 | 
					base_settings
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					variables
 | 
				
			||||||
 | 
					color
 | 
				
			||||||
 | 
					catch_errors
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function update_script() {
 | 
				
			||||||
 | 
					    header_info
 | 
				
			||||||
 | 
					    check_container_storage
 | 
				
			||||||
 | 
					    check_container_resources
 | 
				
			||||||
 | 
					    if [[ ! -f /usr/bin/duplicati-server ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    RELEASE=$(curl -s https://api.github.com/repos/duplicati/duplicati/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4)}')
 | 
				
			||||||
 | 
					    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f /opt/${APP}_version.txt ]]; then
 | 
				
			||||||
 | 
					        msg_info "Stopping $APP"
 | 
				
			||||||
 | 
					        systemctl stop duplicati
 | 
				
			||||||
 | 
					        msg_ok "Stopped $APP"
 | 
				
			||||||
 | 
					        msg_info "Updating $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					        wget -q "https://github.com/duplicati/duplicati/releases/download/v${RELEASE}/duplicati-${RELEASE}-linux-x64-gui.deb"
 | 
				
			||||||
 | 
					        $STD dpkg -i duplicati-${RELEASE}-linux-x64-gui.deb
 | 
				
			||||||
 | 
					        echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					        msg_ok "Updated $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_info "Starting $APP"
 | 
				
			||||||
 | 
					        systemctl start duplicati
 | 
				
			||||||
 | 
					        msg_ok "Started $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_info "Cleaning Up"
 | 
				
			||||||
 | 
					        rm -rf ~/duplicati-${RELEASE}-linux-x64-gui.deb
 | 
				
			||||||
 | 
					        msg_ok "Cleanup Completed"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_ok "Update Successful"
 | 
				
			||||||
 | 
					    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}:8200${CL}"
 | 
				
			||||||
							
								
								
									
										49
									
								
								ct/elementsynapse.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								ct/elementsynapse.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,49 @@
 | 
				
			|||||||
 | 
					#!/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: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/element-hq/synapse
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Element Synapse"
 | 
				
			||||||
 | 
					var_tags="server"
 | 
				
			||||||
 | 
					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 [[ ! -d /etc/matrix-synapse ]]; then 
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    msg_info "Updating $APP LXC"
 | 
				
			||||||
 | 
					    apt-get update &>/dev/null
 | 
				
			||||||
 | 
					    apt-get -y upgrade &>/dev/null
 | 
				
			||||||
 | 
					    msg_ok "Updated $APP LXC"
 | 
				
			||||||
 | 
					    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}:8008${CL}"
 | 
				
			||||||
@@ -5,9 +5,9 @@ source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/m
 | 
				
			|||||||
# App Default Values
 | 
					# App Default Values
 | 
				
			||||||
APP="Grist"
 | 
					APP="Grist"
 | 
				
			||||||
var_tags="database;spreadsheet"
 | 
					var_tags="database;spreadsheet"
 | 
				
			||||||
var_cpu="1"
 | 
					var_cpu="2"
 | 
				
			||||||
var_ram="2048"
 | 
					var_ram="3072"
 | 
				
			||||||
var_disk="4"
 | 
					var_disk="6"
 | 
				
			||||||
var_os="debian"
 | 
					var_os="debian"
 | 
				
			||||||
var_version="12"
 | 
					var_version="12"
 | 
				
			||||||
var_unprivileged="1"
 | 
					var_unprivileged="1"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +0,0 @@
 | 
				
			|||||||
    ______     __              __    
 | 
					 | 
				
			||||||
   / ____/__  / /_____  ____  / /____
 | 
					 | 
				
			||||||
  /___ \/ _ \/ __/ __ \/ __ \/ / ___/
 | 
					 | 
				
			||||||
 ____/ /  __/ /_/ /_/ / /_/ / (__  ) 
 | 
					 | 
				
			||||||
/_____/\___/\__/\____/\____/_/____/  
 | 
					 | 
				
			||||||
                                     
 | 
					 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/alpine-it-tools
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/alpine-it-tools
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ___    __      _                  __________  ______            __    
 | 
				
			||||||
 | 
					   /   |  / /___  (_)___  ___        /  _/_  __/ /_  __/___  ____  / /____
 | 
				
			||||||
 | 
					  / /| | / / __ \/ / __ \/ _ \______ / /  / /_____/ / / __ \/ __ \/ / ___/
 | 
				
			||||||
 | 
					 / ___ |/ / /_/ / / / / /  __/_____// /  / /_____/ / / /_/ / /_/ / (__  ) 
 | 
				
			||||||
 | 
					/_/  |_/_/ .___/_/_/ /_/\___/     /___/ /_/     /_/  \____/\____/_/____/  
 | 
				
			||||||
 | 
					        /_/                                                               
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___    __      _                  _   __          __       __           
 | 
					    ___    __      _                  _   __          __       __                __
 | 
				
			||||||
   /   |  / /___  (_)___  ___        / | / /__  _  __/ /______/ /___  __  __
 | 
					   /   |  / /___  (_)___  ___        / | / /__  _  __/ /______/ /___  __  ______/ /
 | 
				
			||||||
  / /| | / / __ \/ / __ \/ _ \______/  |/ / _ \| |/_/ __/ ___/ / __ \/ / / /
 | 
					  / /| | / / __ \/ / __ \/ _ \______/  |/ / _ \| |/_/ __/ ___/ / __ \/ / / / __  / 
 | 
				
			||||||
 / ___ |/ / /_/ / / / / /  __/_____/ /|  /  __/>  </ /_/ /__/ / /_/ / /_/ / 
 | 
					 / ___ |/ / /_/ / / / / /  __/_____/ /|  /  __/>  </ /_/ /__/ / /_/ / /_/ / /_/ /  
 | 
				
			||||||
/_/  |_/_/ .___/_/_/ /_/\___/     /_/ |_/\___/_/|_|\__/\___/_/\____/\__,_/  
 | 
					/_/  |_/_/ .___/_/_/ /_/\___/     /_/ |_/\___/_/|_|\__/\___/_/\____/\__,_/\__,_/   
 | 
				
			||||||
        /_/                                                                 
 | 
					        /_/                                                                        
 | 
				
			||||||
       __
 | 
					 | 
				
			||||||
  ____/ /
 | 
					 | 
				
			||||||
 / __  / 
 | 
					 | 
				
			||||||
/ /_/ /  
 | 
					 | 
				
			||||||
\__,_/   
 | 
					 | 
				
			||||||
         
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___    __      _                _    __            ____                
 | 
					    ___    __      _                _    __            ____                          __         
 | 
				
			||||||
   /   |  / /___  (_)___  ___      | |  / /___ ___  __/ / /__      ______ _
 | 
					   /   |  / /___  (_)___  ___      | |  / /___ ___  __/ / /__      ______ __________/ /__  ____ 
 | 
				
			||||||
  / /| | / / __ \/ / __ \/ _ \_____| | / / __ `/ / / / / __/ | /| / / __ `/
 | 
					  / /| | / / __ \/ / __ \/ _ \_____| | / / __ `/ / / / / __/ | /| / / __ `/ ___/ __  / _ \/ __ \
 | 
				
			||||||
 / ___ |/ / /_/ / / / / /  __/_____/ |/ / /_/ / /_/ / / /_ | |/ |/ / /_/ / 
 | 
					 / ___ |/ / /_/ / / / / /  __/_____/ |/ / /_/ / /_/ / / /_ | |/ |/ / /_/ / /  / /_/ /  __/ / / /
 | 
				
			||||||
/_/  |_/_/ .___/_/_/ /_/\___/      |___/\__,_/\__,_/_/\__/ |__/|__/\__,_/  
 | 
					/_/  |_/_/ .___/_/_/ /_/\___/      |___/\__,_/\__,_/_/\__/ |__/|__/\__,_/_/   \__,_/\___/_/ /_/ 
 | 
				
			||||||
        /_/                                                                
 | 
					        /_/                                                                                     
 | 
				
			||||||
             __         
 | 
					 | 
				
			||||||
   _________/ /__  ____ 
 | 
					 | 
				
			||||||
  / ___/ __  / _ \/ __ \
 | 
					 | 
				
			||||||
 / /  / /_/ /  __/ / / /
 | 
					 | 
				
			||||||
/_/   \__,_/\___/_/ /_/ 
 | 
					 | 
				
			||||||
                        
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___    __      _               _____   _       __             ___   __  ___
 | 
					    ___    __      _               _____   _       __             ___   __  _______  ____________
 | 
				
			||||||
   /   |  / /___  (_)___  ___     /__  /  (_)___ _/ /_  ___  ___ |__ \ /  |/  /
 | 
					   /   |  / /___  (_)___  ___     /__  /  (_)___ _/ /_  ___  ___ |__ \ /  |/  / __ \/_  __/_  __/
 | 
				
			||||||
  / /| | / / __ \/ / __ \/ _ \______/ /  / / __ `/ __ \/ _ \/ _ \__/ // /|_/ / 
 | 
					  / /| | / / __ \/ / __ \/ _ \______/ /  / / __ `/ __ \/ _ \/ _ \__/ // /|_/ / / / / / /   / /   
 | 
				
			||||||
 / ___ |/ / /_/ / / / / /  __/_____/ /__/ / /_/ / /_/ /  __/  __/ __// /  / /  
 | 
					 / ___ |/ / /_/ / / / / /  __/_____/ /__/ / /_/ / /_/ /  __/  __/ __// /  / / /_/ / / /   / /    
 | 
				
			||||||
/_/  |_/_/ .___/_/_/ /_/\___/     /____/_/\__, /_.___/\___/\___/____/_/  /_/   
 | 
					/_/  |_/_/ .___/_/_/ /_/\___/     /____/_/\__, /_.___/\___/\___/____/_/  /_/\___\_\/_/   /_/     
 | 
				
			||||||
        /_/                              /____/                                
 | 
					        /_/                              /____/                                                  
 | 
				
			||||||
   ____  ____________
 | 
					 | 
				
			||||||
  / __ \/_  __/_  __/
 | 
					 | 
				
			||||||
 / / / / / /   / /   
 | 
					 | 
				
			||||||
/ /_/ / / /   / /    
 | 
					 | 
				
			||||||
\___\_\/_/   /_/     
 | 
					 | 
				
			||||||
                     
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___                     __               ______                          
 | 
					    ___                     __               ______                                __          
 | 
				
			||||||
   /   |  ____  ____ ______/ /_  ___        / ____/___ _______________ _____ 
 | 
					   /   |  ____  ____ ______/ /_  ___        / ____/___ _______________ _____  ____/ /________ _
 | 
				
			||||||
  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ /   / __ `/ ___/ ___/ __ `/ __ \
 | 
					  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ /   / __ `/ ___/ ___/ __ `/ __ \/ __  / ___/ __ `/
 | 
				
			||||||
 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /___/ /_/ (__  |__  ) /_/ / / / /
 | 
					 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /___/ /_/ (__  |__  ) /_/ / / / / /_/ / /  / /_/ / 
 | 
				
			||||||
/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\__,_/____/____/\__,_/_/ /_/ 
 | 
					/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\__,_/____/____/\__,_/_/ /_/\__,_/_/   \__,_/  
 | 
				
			||||||
      /_/                                                                    
 | 
					      /_/                                                                                      
 | 
				
			||||||
       __          
 | 
					 | 
				
			||||||
  ____/ /________ _
 | 
					 | 
				
			||||||
 / __  / ___/ __ `/
 | 
					 | 
				
			||||||
/ /_/ / /  / /_/ / 
 | 
					 | 
				
			||||||
\__,_/_/   \__,_/  
 | 
					 | 
				
			||||||
                   
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___                     __               ______                 __    ____ 
 | 
					    ___                     __               ______                 __    ____  ____ 
 | 
				
			||||||
   /   |  ____  ____ ______/ /_  ___        / ____/___  __  _______/ /_  / __ \
 | 
					   /   |  ____  ____ ______/ /_  ___        / ____/___  __  _______/ /_  / __ \/ __ )
 | 
				
			||||||
  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ /   / __ \/ / / / ___/ __ \/ / / /
 | 
					  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ /   / __ \/ / / / ___/ __ \/ / / / __  |
 | 
				
			||||||
 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /___/ /_/ / /_/ / /__/ / / / /_/ / 
 | 
					 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /___/ /_/ / /_/ / /__/ / / / /_/ / /_/ / 
 | 
				
			||||||
/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\____/\__,_/\___/_/ /_/_____/  
 | 
					/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\____/\__,_/\___/_/ /_/_____/_____/  
 | 
				
			||||||
      /_/                                                                      
 | 
					      /_/                                                                            
 | 
				
			||||||
    ____ 
 | 
					 | 
				
			||||||
   / __ )
 | 
					 | 
				
			||||||
  / __  |
 | 
					 | 
				
			||||||
 / /_/ / 
 | 
					 | 
				
			||||||
/_____/  
 | 
					 | 
				
			||||||
         
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ___                     __               ______                      
 | 
					    ___                     __               ______                                       __   
 | 
				
			||||||
   /   |  ____  ____ ______/ /_  ___        / ____/_  ______ __________ _
 | 
					   /   |  ____  ____ ______/ /_  ___        / ____/_  ______ __________ _____ ___  ____  / /__ 
 | 
				
			||||||
  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ / __/ / / / __ `/ ___/ __ `/
 | 
					  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ / __/ / / / __ `/ ___/ __ `/ __ `__ \/ __ \/ / _ \
 | 
				
			||||||
 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /_/ / /_/ / /_/ / /__/ /_/ / 
 | 
					 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ /_/ / /_/ / /_/ / /__/ /_/ / / / / / / /_/ / /  __/
 | 
				
			||||||
/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\__,_/\__,_/\___/\__,_/  
 | 
					/_/  |_/ .___/\__,_/\___/_/ /_/\___/      \____/\__,_/\__,_/\___/\__,_/_/ /_/ /_/\____/_/\___/ 
 | 
				
			||||||
      /_/                                                                
 | 
					      /_/                                                                                      
 | 
				
			||||||
                    __   
 | 
					 | 
				
			||||||
   ____ ___  ____  / /__ 
 | 
					 | 
				
			||||||
  / __ `__ \/ __ \/ / _ \
 | 
					 | 
				
			||||||
 / / / / / / /_/ / /  __/
 | 
					 | 
				
			||||||
/_/ /_/ /_/\____/_/\___/ 
 | 
					 | 
				
			||||||
                         
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/apache-tika
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/apache-tika
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ___                     __             _______ __        
 | 
				
			||||||
 | 
					   /   |  ____  ____ ______/ /_  ___      /_  __(_) /______ _
 | 
				
			||||||
 | 
					  / /| | / __ \/ __ `/ ___/ __ \/ _ \______/ / / / //_/ __ `/
 | 
				
			||||||
 | 
					 / ___ |/ /_/ / /_/ / /__/ / / /  __/_____/ / / / ,< / /_/ / 
 | 
				
			||||||
 | 
					/_/  |_/ .___/\__,_/\___/_/ /_/\___/     /_/ /_/_/|_|\__,_/  
 | 
				
			||||||
 | 
					      /_/                                                    
 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/baikal
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/baikal
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____        _ __         __
 | 
				
			||||||
 | 
					   / __ )____ _(_) /______ _/ /
 | 
				
			||||||
 | 
					  / __  / __ `/ / //_/ __ `/ / 
 | 
				
			||||||
 | 
					 / /_/ / /_/ / / ,< / /_/ / /  
 | 
				
			||||||
 | 
					/_____/\__,_/_/_/|_|\__,_/_/   
 | 
				
			||||||
 | 
					                               
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
   ________                         
 | 
					   ________                              ____       __            __  _           
 | 
				
			||||||
  / ____/ /_  ____ _____  ____ ____ 
 | 
					  / ____/ /_  ____ _____  ____ ____     / __ \___  / /____  _____/ /_(_)___  ____ 
 | 
				
			||||||
 / /   / __ \/ __ `/ __ \/ __ `/ _ \
 | 
					 / /   / __ \/ __ `/ __ \/ __ `/ _ \   / / / / _ \/ __/ _ \/ ___/ __/ / __ \/ __ \
 | 
				
			||||||
/ /___/ / / / /_/ / / / / /_/ /  __/
 | 
					/ /___/ / / / /_/ / / / / /_/ /  __/  / /_/ /  __/ /_/  __/ /__/ /_/ / /_/ / / / /
 | 
				
			||||||
\____/_/ /_/\__,_/_/ /_/\__, /\___/ 
 | 
					\____/_/ /_/\__,_/_/ /_/\__, /\___/  /_____/\___/\__/\___/\___/\__/_/\____/_/ /_/ 
 | 
				
			||||||
                       /____/       
 | 
					                       /____/                                                     
 | 
				
			||||||
    ____       __            __  _           
 | 
					 | 
				
			||||||
   / __ \___  / /____  _____/ /_(_)___  ____ 
 | 
					 | 
				
			||||||
  / / / / _ \/ __/ _ \/ ___/ __/ / __ \/ __ \
 | 
					 | 
				
			||||||
 / /_/ /  __/ /_/  __/ /__/ /_/ / /_/ / / / /
 | 
					 | 
				
			||||||
/_____/\___/\__/\___/\___/\__/_/\____/_/ /_/ 
 | 
					 | 
				
			||||||
                                             
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/crafty-controller
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/crafty-controller
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					   ______           ______              ______            __             ____         
 | 
				
			||||||
 | 
					  / ____/________ _/ __/ /___  __      / ____/___  ____  / /__________  / / /__  _____
 | 
				
			||||||
 | 
					 / /   / ___/ __ `/ /_/ __/ / / /_____/ /   / __ \/ __ \/ __/ ___/ __ \/ / / _ \/ ___/
 | 
				
			||||||
 | 
					/ /___/ /  / /_/ / __/ /_/ /_/ /_____/ /___/ /_/ / / / / /_/ /  / /_/ / / /  __/ /    
 | 
				
			||||||
 | 
					\____/_/   \__,_/_/  \__/\__, /      \____/\____/_/ /_/\__/_/   \____/_/_/\___/_/     
 | 
				
			||||||
 | 
					                        /____/                                                        
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ____        __             __     ___   _____ ____     _       __     __  
 | 
					    ____        __             __     ___   _____ ____     _       __     __       ___    ____  ____
 | 
				
			||||||
   / __ \____  / /_____  ___  / /_   /   | / ___// __ \   | |     / /__  / /_ 
 | 
					   / __ \____  / /_____  ___  / /_   /   | / ___// __ \   | |     / /__  / /_     /   |  / __ \/  _/
 | 
				
			||||||
  / / / / __ \/ __/ __ \/ _ \/ __/  / /| | \__ \/ /_/ /   | | /| / / _ \/ __ \
 | 
					  / / / / __ \/ __/ __ \/ _ \/ __/  / /| | \__ \/ /_/ /   | | /| / / _ \/ __ \   / /| | / /_/ // /  
 | 
				
			||||||
 / /_/ / /_/ / /_/ / / /  __/ /_   / ___ |___/ / ____/    | |/ |/ /  __/ /_/ /
 | 
					 / /_/ / /_/ / /_/ / / /  __/ /_   / ___ |___/ / ____/    | |/ |/ /  __/ /_/ /  / ___ |/ ____// /   
 | 
				
			||||||
/_____/\____/\__/_/ /_/\___/\__/  /_/  |_/____/_/         |__/|__/\___/_.___/ 
 | 
					/_____/\____/\__/_/ /_/\___/\__/  /_/  |_/____/_/         |__/|__/\___/_.___/  /_/  |_/_/   /___/   
 | 
				
			||||||
                                                                              
 | 
					                                                                                                    
 | 
				
			||||||
    ___    ____  ____
 | 
					 | 
				
			||||||
   /   |  / __ \/  _/
 | 
					 | 
				
			||||||
  / /| | / /_/ // /  
 | 
					 | 
				
			||||||
 / ___ |/ ____// /   
 | 
					 | 
				
			||||||
/_/  |_/_/   /___/   
 | 
					 | 
				
			||||||
                     
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/duplicati
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/duplicati
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____              ___            __  _ 
 | 
				
			||||||
 | 
					   / __ \__  ______  / (_)________ _/ /_(_)
 | 
				
			||||||
 | 
					  / / / / / / / __ \/ / / ___/ __ `/ __/ / 
 | 
				
			||||||
 | 
					 / /_/ / /_/ / /_/ / / / /__/ /_/ / /_/ /  
 | 
				
			||||||
 | 
					/_____/\__,_/ .___/_/_/\___/\__,_/\__/_/   
 | 
				
			||||||
 | 
					           /_/                             
 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/elementsynapse
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/elementsynapse
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ________                          __     _____                                 
 | 
				
			||||||
 | 
					   / ____/ /__  ____ ___  ___  ____  / /_   / ___/__  ______  ____ _____  ________ 
 | 
				
			||||||
 | 
					  / __/ / / _ \/ __ `__ \/ _ \/ __ \/ __/   \__ \/ / / / __ \/ __ `/ __ \/ ___/ _ \
 | 
				
			||||||
 | 
					 / /___/ /  __/ / / / / /  __/ / / / /_    ___/ / /_/ / / / / /_/ / /_/ (__  )  __/
 | 
				
			||||||
 | 
					/_____/_/\___/_/ /_/ /_/\___/_/ /_/\__/   /____/\__, /_/ /_/\__,_/ .___/____/\___/ 
 | 
				
			||||||
 | 
					                                               /____/           /_/                
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    __  __     _               __      ____      ____             __    __  
 | 
					    __  __     _               __      ____      ____             __    __                         __
 | 
				
			||||||
   / / / /__  (_)___ ___  ____/ /___ _/ / /     / __ \____ ______/ /_  / /_ 
 | 
					   / / / /__  (_)___ ___  ____/ /___ _/ / /     / __ \____ ______/ /_  / /_  ____  ____ __________/ /
 | 
				
			||||||
  / /_/ / _ \/ / __ `__ \/ __  / __ `/ / /_____/ / / / __ `/ ___/ __ \/ __ \
 | 
					  / /_/ / _ \/ / __ `__ \/ __  / __ `/ / /_____/ / / / __ `/ ___/ __ \/ __ \/ __ \/ __ `/ ___/ __  / 
 | 
				
			||||||
 / __  /  __/ / / / / / / /_/ / /_/ / / /_____/ /_/ / /_/ (__  ) / / / /_/ /
 | 
					 / __  /  __/ / / / / / / /_/ / /_/ / / /_____/ /_/ / /_/ (__  ) / / / /_/ / /_/ / /_/ / /  / /_/ /  
 | 
				
			||||||
/_/ /_/\___/_/_/ /_/ /_/\__,_/\__,_/_/_/     /_____/\__,_/____/_/ /_/_.___/ 
 | 
					/_/ /_/\___/_/_/ /_/ /_/\__,_/\__,_/_/_/     /_____/\__,_/____/_/ /_/_.___/\____/\__,_/_/   \__,_/   
 | 
				
			||||||
                                                                            
 | 
					                                                                                                     
 | 
				
			||||||
                        __
 | 
					 | 
				
			||||||
  ____  ____ __________/ /
 | 
					 | 
				
			||||||
 / __ \/ __ `/ ___/ __  / 
 | 
					 | 
				
			||||||
/ /_/ / /_/ / /  / /_/ /  
 | 
					 | 
				
			||||||
\____/\__,_/_/   \__,_/   
 | 
					 | 
				
			||||||
                          
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    __  __                   
 | 
					    __  __                        ___              _      __              __        ______              
 | 
				
			||||||
   / / / /___  ____ ___  ___ 
 | 
					   / / / /___  ____ ___  ___     /   |  __________(_)____/ /_____ _____  / /_      / ____/___  ________ 
 | 
				
			||||||
  / /_/ / __ \/ __ `__ \/ _ \
 | 
					  / /_/ / __ \/ __ `__ \/ _ \   / /| | / ___/ ___/ / ___/ __/ __ `/ __ \/ __/_____/ /   / __ \/ ___/ _ \
 | 
				
			||||||
 / __  / /_/ / / / / / /  __/
 | 
					 / __  / /_/ / / / / / /  __/  / ___ |(__  |__  ) (__  ) /_/ /_/ / / / / /_/_____/ /___/ /_/ / /  /  __/
 | 
				
			||||||
/_/ /_/\____/_/ /_/ /_/\___/ 
 | 
					/_/ /_/\____/_/ /_/ /_/\___/  /_/  |_/____/____/_/____/\__/\__,_/_/ /_/\__/      \____/\____/_/   \___/ 
 | 
				
			||||||
                             
 | 
					                                                                                                        
 | 
				
			||||||
    ___              _      __              __        ______              
 | 
					 | 
				
			||||||
   /   |  __________(_)____/ /_____ _____  / /_      / ____/___  ________ 
 | 
					 | 
				
			||||||
  / /| | / ___/ ___/ / ___/ __/ __ `/ __ \/ __/_____/ /   / __ \/ ___/ _ \
 | 
					 | 
				
			||||||
 / ___ |(__  |__  ) (__  ) /_/ /_/ / / / / /_/_____/ /___/ /_/ / /  /  __/
 | 
					 | 
				
			||||||
/_/  |_/____/____/_/____/\__/\__,_/_/ /_/\__/      \____/\____/_/   \___/ 
 | 
					 | 
				
			||||||
                                                                          
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/koillection
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/koillection
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    __ __      _ ____          __  _           
 | 
				
			||||||
 | 
					   / //_/___  (_) / /__  _____/ /_(_)___  ____ 
 | 
				
			||||||
 | 
					  / ,< / __ \/ / / / _ \/ ___/ __/ / __ \/ __ \
 | 
				
			||||||
 | 
					 / /| / /_/ / / / /  __/ /__/ /_/ / /_/ / / / /
 | 
				
			||||||
 | 
					/_/ |_\____/_/_/_/\___/\___/\__/_/\____/_/ /_/ 
 | 
				
			||||||
 | 
					                                               
 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/mattermost
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/mattermost
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    __  ___      __  __                                 __ 
 | 
				
			||||||
 | 
					   /  |/  /___ _/ /_/ /____  _________ ___  ____  _____/ /_
 | 
				
			||||||
 | 
					  / /|_/ / __ `/ __/ __/ _ \/ ___/ __ `__ \/ __ \/ ___/ __/
 | 
				
			||||||
 | 
					 / /  / / /_/ / /_/ /_/  __/ /  / / / / / / /_/ (__  ) /_  
 | 
				
			||||||
 | 
					/_/  /_/\__,_/\__/\__/\___/_/  /_/ /_/ /_/\____/____/\__/  
 | 
				
			||||||
 | 
					                                                           
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    _   __      _               ____                       
 | 
					    _   __      _               ____                           __  ___                                 
 | 
				
			||||||
   / | / /___ _(_)___  _  __   / __ \_________  _  ____  __
 | 
					   / | / /___ _(_)___  _  __   / __ \_________  _  ____  __   /  |/  /___ _____  ____ _____ ____  _____
 | 
				
			||||||
  /  |/ / __ `/ / __ \| |/_/  / /_/ / ___/ __ \| |/_/ / / /
 | 
					  /  |/ / __ `/ / __ \| |/_/  / /_/ / ___/ __ \| |/_/ / / /  / /|_/ / __ `/ __ \/ __ `/ __ `/ _ \/ ___/
 | 
				
			||||||
 / /|  / /_/ / / / / />  <   / ____/ /  / /_/ />  </ /_/ / 
 | 
					 / /|  / /_/ / / / / />  <   / ____/ /  / /_/ />  </ /_/ /  / /  / / /_/ / / / / /_/ / /_/ /  __/ /    
 | 
				
			||||||
/_/ |_/\__, /_/_/ /_/_/|_|  /_/   /_/   \____/_/|_|\__, /  
 | 
					/_/ |_/\__, /_/_/ /_/_/|_|  /_/   /_/   \____/_/|_|\__, /  /_/  /_/\__,_/_/ /_/\__,_/\__, /\___/_/     
 | 
				
			||||||
      /____/                                      /____/   
 | 
					      /____/                                      /____/                            /____/             
 | 
				
			||||||
    __  ___                                 
 | 
					 | 
				
			||||||
   /  |/  /___ _____  ____ _____ ____  _____
 | 
					 | 
				
			||||||
  / /|_/ / __ `/ __ \/ __ `/ __ `/ _ \/ ___/
 | 
					 | 
				
			||||||
 / /  / / /_/ / / / / /_/ / /_/ /  __/ /    
 | 
					 | 
				
			||||||
/_/  /_/\__,_/_/ /_/\__,_/\__, /\___/_/     
 | 
					 | 
				
			||||||
                         /____/             
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/paperless-ai
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/paperless-ai
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____                        __                     ___    ____
 | 
				
			||||||
 | 
					   / __ \____ _____  ___  _____/ /__  __________      /   |  /  _/
 | 
				
			||||||
 | 
					  / /_/ / __ `/ __ \/ _ \/ ___/ / _ \/ ___/ ___/_____/ /| |  / /  
 | 
				
			||||||
 | 
					 / ____/ /_/ / /_/ /  __/ /  / /  __(__  |__  )_____/ ___ |_/ /   
 | 
				
			||||||
 | 
					/_/    \__,_/ .___/\___/_/  /_/\___/____/____/     /_/  |_/___/   
 | 
				
			||||||
 | 
					           /_/                                                    
 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/paymenter
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/paymenter
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____                                   __           
 | 
				
			||||||
 | 
					   / __ \____ ___  ______ ___  ___  ____  / /____  _____
 | 
				
			||||||
 | 
					  / /_/ / __ `/ / / / __ `__ \/ _ \/ __ \/ __/ _ \/ ___/
 | 
				
			||||||
 | 
					 / ____/ /_/ / /_/ / / / / / /  __/ / / / /_/  __/ /    
 | 
				
			||||||
 | 
					/_/    \__,_/\__, /_/ /_/ /_/\___/_/ /_/\__/\___/_/     
 | 
				
			||||||
 | 
					            /____/                                      
 | 
				
			||||||
@@ -1,6 +0,0 @@
 | 
				
			|||||||
    ____  ____ _____
 | 
					 | 
				
			||||||
   / __ \/ __ ) ___/
 | 
					 | 
				
			||||||
  / /_/ / __  \__ \ 
 | 
					 | 
				
			||||||
 / ____/ /_/ /__/ / 
 | 
					 | 
				
			||||||
/_/   /_____/____/  
 | 
					 | 
				
			||||||
                    
 | 
					 | 
				
			||||||
@@ -1,6 +0,0 @@
 | 
				
			|||||||
    ____  _______      ______            __    
 | 
					 | 
				
			||||||
   / __ \/ __/__ \ ___/_  __/___  ____  / /____
 | 
					 | 
				
			||||||
  / /_/ / /_ __/ // _ \/ / / __ \/ __ \/ / ___/
 | 
					 | 
				
			||||||
 / ____/ __// __//  __/ / / /_/ / /_/ / (__  ) 
 | 
					 | 
				
			||||||
/_/   /_/  /____/\___/_/  \____/\____/_/____/  
 | 
					 | 
				
			||||||
                                               
 | 
					 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ____            __                            __  __                   
 | 
					    ____            __                            __  __                        ___              _      __              __ 
 | 
				
			||||||
   / __ \____  ____/ /___ ___  ____ _____        / / / /___  ____ ___  ___ 
 | 
					   / __ \____  ____/ /___ ___  ____ _____        / / / /___  ____ ___  ___     /   |  __________(_)____/ /_____ _____  / /_
 | 
				
			||||||
  / /_/ / __ \/ __  / __ `__ \/ __ `/ __ \______/ /_/ / __ \/ __ `__ \/ _ \
 | 
					  / /_/ / __ \/ __  / __ `__ \/ __ `/ __ \______/ /_/ / __ \/ __ `__ \/ _ \   / /| | / ___/ ___/ / ___/ __/ __ `/ __ \/ __/
 | 
				
			||||||
 / ____/ /_/ / /_/ / / / / / / /_/ / / / /_____/ __  / /_/ / / / / / /  __/
 | 
					 / ____/ /_/ / /_/ / / / / / / /_/ / / / /_____/ __  / /_/ / / / / / /  __/  / ___ |(__  |__  ) (__  ) /_/ /_/ / / / / /_  
 | 
				
			||||||
/_/    \____/\__,_/_/ /_/ /_/\__,_/_/ /_/     /_/ /_/\____/_/ /_/ /_/\___/ 
 | 
					/_/    \____/\__,_/_/ /_/ /_/\__,_/_/ /_/     /_/ /_/\____/_/ /_/ /_/\___/  /_/  |_/____/____/_/____/\__/\__,_/_/ /_/\__/  
 | 
				
			||||||
                                                                           
 | 
					                                                                                                                           
 | 
				
			||||||
    ___              _      __              __ 
 | 
					 | 
				
			||||||
   /   |  __________(_)____/ /_____ _____  / /_
 | 
					 | 
				
			||||||
  / /| | / ___/ ___/ / ___/ __/ __ `/ __ \/ __/
 | 
					 | 
				
			||||||
 / ___ |(__  |__  ) (__  ) /_/ /_/ / / / / /_  
 | 
					 | 
				
			||||||
/_/  |_/____/____/_/____/\__/\__,_/_/ /_/\__/  
 | 
					 | 
				
			||||||
                                               
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/privatebin
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/privatebin
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____       _             __       ____  _     
 | 
				
			||||||
 | 
					   / __ \_____(_)   ______ _/ /____  / __ )(_)___ 
 | 
				
			||||||
 | 
					  / /_/ / ___/ / | / / __ `/ __/ _ \/ __  / / __ \
 | 
				
			||||||
 | 
					 / ____/ /  / /| |/ / /_/ / /_/  __/ /_/ / / / / /
 | 
				
			||||||
 | 
					/_/   /_/  /_/ |___/\__,_/\__/\___/_____/_/_/ /_/ 
 | 
				
			||||||
 | 
					                                                  
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ____                            __  __                          ___    __
 | 
					    ____                            __  __                          ___    __          __                                             
 | 
				
			||||||
   / __ \_________  ____ ___  ___  / /_/ /_  ___  __  _______      /   |  / /
 | 
					   / __ \_________  ____ ___  ___  / /_/ /_  ___  __  _______      /   |  / /__  _____/ /_____ ___  ____ _____  ____ _____ ____  _____
 | 
				
			||||||
  / /_/ / ___/ __ \/ __ `__ \/ _ \/ __/ __ \/ _ \/ / / / ___/_____/ /| | / / 
 | 
					  / /_/ / ___/ __ \/ __ `__ \/ _ \/ __/ __ \/ _ \/ / / / ___/_____/ /| | / / _ \/ ___/ __/ __ `__ \/ __ `/ __ \/ __ `/ __ `/ _ \/ ___/
 | 
				
			||||||
 / ____/ /  / /_/ / / / / / /  __/ /_/ / / /  __/ /_/ (__  )_____/ ___ |/ /  
 | 
					 / ____/ /  / /_/ / / / / / /  __/ /_/ / / /  __/ /_/ (__  )_____/ ___ |/ /  __/ /  / /_/ / / / / / /_/ / / / / /_/ / /_/ /  __/ /    
 | 
				
			||||||
/_/   /_/   \____/_/ /_/ /_/\___/\__/_/ /_/\___/\__,_/____/     /_/  |_/_/   
 | 
					/_/   /_/   \____/_/ /_/ /_/\___/\__/_/ /_/\___/\__,_/____/     /_/  |_/_/\___/_/   \__/_/ /_/ /_/\__,_/_/ /_/\__,_/\__, /\___/_/     
 | 
				
			||||||
                                                                             
 | 
					                                                                                                                   /____/             
 | 
				
			||||||
             __                                             
 | 
					 | 
				
			||||||
  ___  _____/ /_____ ___  ____ _____  ____ _____ ____  _____
 | 
					 | 
				
			||||||
 / _ \/ ___/ __/ __ `__ \/ __ `/ __ \/ __ `/ __ `/ _ \/ ___/
 | 
					 | 
				
			||||||
/  __/ /  / /_/ / / / / / /_/ / / / / /_/ / /_/ /  __/ /    
 | 
					 | 
				
			||||||
\___/_/   \__/_/ /_/ /_/\__,_/_/ /_/\__,_/\__, /\___/_/     
 | 
					 | 
				
			||||||
                                         /____/             
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
    ____                            __  __                          ____ 
 | 
					    ____                            __  __                          ____ _    ________     ______                      __           
 | 
				
			||||||
   / __ \_________  ____ ___  ___  / /_/ /_  ___  __  _______      / __ \
 | 
					   / __ \_________  ____ ___  ___  / /_/ /_  ___  __  _______      / __ \ |  / / ____/    / ____/  ______  ____  _____/ /____  _____
 | 
				
			||||||
  / /_/ / ___/ __ \/ __ `__ \/ _ \/ __/ __ \/ _ \/ / / / ___/_____/ /_/ /
 | 
					  / /_/ / ___/ __ \/ __ `__ \/ _ \/ __/ __ \/ _ \/ / / / ___/_____/ /_/ / | / / __/______/ __/ | |/_/ __ \/ __ \/ ___/ __/ _ \/ ___/
 | 
				
			||||||
 / ____/ /  / /_/ / / / / / /  __/ /_/ / / /  __/ /_/ (__  )_____/ ____/ 
 | 
					 / ____/ /  / /_/ / / / / / /  __/ /_/ / / /  __/ /_/ (__  )_____/ ____/| |/ / /__/_____/ /____>  </ /_/ / /_/ / /  / /_/  __/ /    
 | 
				
			||||||
/_/   /_/   \____/_/ /_/ /_/\___/\__/_/ /_/\___/\__,_/____/     /_/      
 | 
					/_/   /_/   \____/_/ /_/ /_/\___/\__/_/ /_/\___/\__,_/____/     /_/     |___/_____/    /_____/_/|_/ .___/\____/_/   \__/\___/_/     
 | 
				
			||||||
                                                                         
 | 
					                                                                                                 /_/                                
 | 
				
			||||||
 _    ________     ______                      __           
 | 
					 | 
				
			||||||
| |  / / ____/    / ____/  ______  ____  _____/ /____  _____
 | 
					 | 
				
			||||||
| | / / __/______/ __/ | |/_/ __ \/ __ \/ ___/ __/ _ \/ ___/
 | 
					 | 
				
			||||||
| |/ / /__/_____/ /____>  </ /_/ / /_/ / /  / /_/  __/ /    
 | 
					 | 
				
			||||||
|___/_____/    /_____/_/|_/ .___/\____/_/   \__/\___/_/     
 | 
					 | 
				
			||||||
                         /_/                                
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/proxmox-backup-server
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/proxmox-backup-server
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____                                             ____             __                    _____                          
 | 
				
			||||||
 | 
					   / __ \_________  _  ______ ___  ____  _  __      / __ )____ ______/ /____  ______       / ___/___  ______   _____  _____
 | 
				
			||||||
 | 
					  / /_/ / ___/ __ \| |/_/ __ `__ \/ __ \| |/_/_____/ __  / __ `/ ___/ //_/ / / / __ \______\__ \/ _ \/ ___/ | / / _ \/ ___/
 | 
				
			||||||
 | 
					 / ____/ /  / /_/ />  </ / / / / / /_/ />  </_____/ /_/ / /_/ / /__/ ,< / /_/ / /_/ /_____/__/ /  __/ /   | |/ /  __/ /    
 | 
				
			||||||
 | 
					/_/   /_/   \____/_/|_/_/ /_/ /_/\____/_/|_|     /_____/\__,_/\___/_/|_|\__,_/ .___/     /____/\___/_/    |___/\___/_/     
 | 
				
			||||||
 | 
					                                                                            /_/                                            
 | 
				
			||||||
@@ -1,18 +1,6 @@
 | 
				
			|||||||
                                                          __      __       
 | 
					    ____                                             ____        __                        __                  __  ___                                 
 | 
				
			||||||
    ____  _________  _  ______ ___  ____  _  __      ____/ /___ _/ /_____ _
 | 
					   / __ \_________  _  ______ ___  ____  _  __      / __ \____ _/ /_____ _________  ____  / /____  _____      /  |/  /___ _____  ____ _____ ____  _____
 | 
				
			||||||
   / __ \/ ___/ __ \| |/_/ __ `__ \/ __ \| |/_/_____/ __  / __ `/ __/ __ `/
 | 
					  / /_/ / ___/ __ \| |/_/ __ `__ \/ __ \| |/_/_____/ / / / __ `/ __/ __ `/ ___/ _ \/ __ \/ __/ _ \/ ___/_____/ /|_/ / __ `/ __ \/ __ `/ __ `/ _ \/ ___/
 | 
				
			||||||
  / /_/ / /  / /_/ />  </ / / / / / /_/ />  </_____/ /_/ / /_/ / /_/ /_/ / 
 | 
					 / ____/ /  / /_/ />  </ / / / / / /_/ />  </_____/ /_/ / /_/ / /_/ /_/ / /__/  __/ / / / /_/  __/ /  /_____/ /  / / /_/ / / / / /_/ / /_/ /  __/ /    
 | 
				
			||||||
 / .___/_/   \____/_/|_/_/ /_/ /_/\____/_/|_|      \__,_/\__,_/\__/\__,_/  
 | 
					/_/   /_/   \____/_/|_/_/ /_/ /_/\____/_/|_|     /_____/\__,_/\__/\__,_/\___/\___/_/ /_/\__/\___/_/        /_/  /_/\__,_/_/ /_/\__,_/\__, /\___/_/     
 | 
				
			||||||
/_/                                                                        
 | 
					                                                                                                                                    /____/             
 | 
				
			||||||
                   __                                                       
 | 
					 | 
				
			||||||
  ________  ____  / /____  _____      ____ ___  ____ _____  ____ _____ ____ 
 | 
					 | 
				
			||||||
 / ___/ _ \/ __ \/ __/ _ \/ ___/_____/ __ `__ \/ __ `/ __ \/ __ `/ __ `/ _ \
 | 
					 | 
				
			||||||
/ /__/  __/ / / / /_/  __/ /  /_____/ / / / / / /_/ / / / / /_/ / /_/ /  __/
 | 
					 | 
				
			||||||
\___/\___/_/ /_/\__/\___/_/        /_/ /_/ /_/\__,_/_/ /_/\__,_/\__, /\___/ 
 | 
					 | 
				
			||||||
                                                               /____/       
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
   _____
 | 
					 | 
				
			||||||
  / ___/
 | 
					 | 
				
			||||||
 / /    
 | 
					 | 
				
			||||||
/_/     
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/radicale
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/radicale
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					    ____            ___            __   
 | 
				
			||||||
 | 
					   / __ \____ _____/ (_)________ _/ /__ 
 | 
				
			||||||
 | 
					  / /_/ / __ `/ __  / / ___/ __ `/ / _ \
 | 
				
			||||||
 | 
					 / _, _/ /_/ / /_/ / / /__/ /_/ / /  __/
 | 
				
			||||||
 | 
					/_/ |_|\__,_/\__,_/_/\___/\__,_/_/\___/ 
 | 
				
			||||||
 | 
					                                        
 | 
				
			||||||
							
								
								
									
										6
									
								
								ct/headers/seelf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/seelf
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					                   ______
 | 
				
			||||||
 | 
					   ________  ___  / / __/
 | 
				
			||||||
 | 
					  / ___/ _ \/ _ \/ / /_  
 | 
				
			||||||
 | 
					 (__  )  __/  __/ / __/  
 | 
				
			||||||
 | 
					/____/\___/\___/_/_/     
 | 
				
			||||||
 | 
					                         
 | 
				
			||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
   _____ ____    __       _____                          
 | 
					   _____ ____    __       _____                              ___   ____ ___  ___ 
 | 
				
			||||||
  / ___// __ \  / /      / ___/___  ______   _____  _____
 | 
					  / ___// __ \  / /      / ___/___  ______   _____  _____   |__ \ / __ \__ \|__ \
 | 
				
			||||||
  \__ \/ / / / / /       \__ \/ _ \/ ___/ | / / _ \/ ___/
 | 
					  \__ \/ / / / / /       \__ \/ _ \/ ___/ | / / _ \/ ___/   __/ // / / /_/ /__/ /
 | 
				
			||||||
 ___/ / /_/ / / /___    ___/ /  __/ /   | |/ /  __/ /    
 | 
					 ___/ / /_/ / / /___    ___/ /  __/ /   | |/ /  __/ /      / __// /_/ / __// __/ 
 | 
				
			||||||
/____/\___\_\/_____/   /____/\___/_/    |___/\___/_/     
 | 
					/____/\___\_\/_____/   /____/\___/_/    |___/\___/_/      /____/\____/____/____/ 
 | 
				
			||||||
                                                         
 | 
					                                                                                 
 | 
				
			||||||
   ___   ____ ___  ___ 
 | 
					 | 
				
			||||||
  |__ \ / __ \__ \|__ \
 | 
					 | 
				
			||||||
  __/ // / / /_/ /__/ /
 | 
					 | 
				
			||||||
 / __// /_/ / __// __/ 
 | 
					 | 
				
			||||||
/____/\____/____/____/ 
 | 
					 | 
				
			||||||
                       
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,6 @@
 | 
				
			|||||||
   __  __     ____             __             
 | 
					   __  __     ____             __                  _____                          
 | 
				
			||||||
  / / / /____/ __ )____ ______/ /____  ______ 
 | 
					  / / / /____/ __ )____ ______/ /____  ______     / ___/___  ______   _____  _____
 | 
				
			||||||
 / / / / ___/ __  / __ `/ ___/ //_/ / / / __ \
 | 
					 / / / / ___/ __  / __ `/ ___/ //_/ / / / __ \    \__ \/ _ \/ ___/ | / / _ \/ ___/
 | 
				
			||||||
/ /_/ / /  / /_/ / /_/ / /__/ ,< / /_/ / /_/ /
 | 
					/ /_/ / /  / /_/ / /_/ / /__/ ,< / /_/ / /_/ /   ___/ /  __/ /   | |/ /  __/ /    
 | 
				
			||||||
\____/_/  /_____/\__,_/\___/_/|_|\__,_/ .___/ 
 | 
					\____/_/  /_____/\__,_/\___/_/|_|\__,_/ .___/   /____/\___/_/    |___/\___/_/     
 | 
				
			||||||
                                     /_/      
 | 
					                                     /_/                                          
 | 
				
			||||||
   _____                          
 | 
					 | 
				
			||||||
  / ___/___  ______   _____  _____
 | 
					 | 
				
			||||||
  \__ \/ _ \/ ___/ | / / _ \/ ___/
 | 
					 | 
				
			||||||
 ___/ /  __/ /   | |/ /  __/ /    
 | 
					 | 
				
			||||||
/____/\___/_/    |___/\___/_/     
 | 
					 | 
				
			||||||
                                  
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								ct/headers/zerotier-one
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ct/headers/zerotier-one
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					 _____                   __  _                 ____           
 | 
				
			||||||
 | 
					/__  /  ___  _________  / /_(_)__  _____      / __ \____  ___ 
 | 
				
			||||||
 | 
					  / /  / _ \/ ___/ __ \/ __/ / _ \/ ___/_____/ / / / __ \/ _ \
 | 
				
			||||||
 | 
					 / /__/  __/ /  / /_/ / /_/ /  __/ /  /_____/ /_/ / / / /  __/
 | 
				
			||||||
 | 
					/____/\___/_/   \____/\__/_/\___/_/         \____/_/ /_/\___/ 
 | 
				
			||||||
 | 
					                                                              
 | 
				
			||||||
@@ -10,7 +10,7 @@ APP="Hoarder"
 | 
				
			|||||||
var_tags="bookmark"
 | 
					var_tags="bookmark"
 | 
				
			||||||
var_cpu="2"
 | 
					var_cpu="2"
 | 
				
			||||||
var_ram="4096"
 | 
					var_ram="4096"
 | 
				
			||||||
var_disk="8"
 | 
					var_disk="10"
 | 
				
			||||||
var_os="debian"
 | 
					var_os="debian"
 | 
				
			||||||
var_version="12"
 | 
					var_version="12"
 | 
				
			||||||
var_unprivileged="1"
 | 
					var_unprivileged="1"
 | 
				
			||||||
@@ -39,6 +39,9 @@ function update_script() {
 | 
				
			|||||||
    systemctl stop hoarder-web hoarder-workers hoarder-browser
 | 
					    systemctl stop hoarder-web hoarder-workers hoarder-browser
 | 
				
			||||||
    msg_ok "Stopped Services"
 | 
					    msg_ok "Stopped Services"
 | 
				
			||||||
    msg_info "Updating ${APP} to v${RELEASE}"
 | 
					    msg_info "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					    if [[ $(corepack -v) < "0.31.0" ]]; then
 | 
				
			||||||
 | 
					      npm install -g corepack@0.31.0 &>/dev/null
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
    cd /opt
 | 
					    cd /opt
 | 
				
			||||||
    if [[ -f /opt/hoarder/.env ]] && [[ ! -f /etc/hoarder/hoarder.env ]]; then
 | 
					    if [[ -f /opt/hoarder/.env ]] && [[ ! -f /etc/hoarder/hoarder.env ]]; then
 | 
				
			||||||
      mkdir -p /etc/hoarder
 | 
					      mkdir -p /etc/hoarder
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -50,17 +50,23 @@ function update_script() {
 | 
				
			|||||||
        msg_ok "Cleaning up"
 | 
					        msg_ok "Cleaning up"
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if ! command -v pnpm &> /dev/null; then
 | 
					    cd /opt/jellyseerr
 | 
				
			||||||
        msg_error "pnpm not found. Installing..."
 | 
					    output=$(git pull --no-rebase)
 | 
				
			||||||
        npm install -g pnpm &>/dev/null
 | 
					
 | 
				
			||||||
 | 
					    pnpm_current=$(pnpm --version 2>/dev/null)
 | 
				
			||||||
 | 
					    pnpm_desired=$(grep -Po '"pnpm":\s*"\K[^"]+' /opt/jellyseerr/package.json)
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    if [ -z "$pnpm_current" ]; then
 | 
				
			||||||
 | 
					        msg_error "pnpm not found. Installing version $pnpm_desired..."
 | 
				
			||||||
 | 
					        npm install -g pnpm@"$pnpm_desired" &>/dev/null
 | 
				
			||||||
 | 
					    elif ! node -e "const semver = require('semver'); process.exit(semver.satisfies('$pnpm_current', '$pnpm_desired') ? 0 : 1)" ; then
 | 
				
			||||||
 | 
					        msg_error "Updating pnpm from version $pnpm_current to $pnpm_desired..."
 | 
				
			||||||
 | 
					        npm install -g pnpm@"$pnpm_desired" &>/dev/null
 | 
				
			||||||
    else
 | 
					    else
 | 
				
			||||||
        msg_ok "pnpm is already installed."
 | 
					        msg_ok "pnpm is already installed and satisfies version $pnpm_desired."
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Updating $APP"
 | 
					    msg_info "Updating $APP"
 | 
				
			||||||
    cd /opt/jellyseerr
 | 
					 | 
				
			||||||
    output=$(git pull --no-rebase)
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    if echo "$output" | grep -q "Already up to date."; then
 | 
					    if echo "$output" | grep -q "Already up to date."; then
 | 
				
			||||||
        msg_ok "$APP is already up to date."
 | 
					        msg_ok "$APP is already up to date."
 | 
				
			||||||
        exit
 | 
					        exit
 | 
				
			||||||
@@ -102,4 +108,4 @@ description
 | 
				
			|||||||
msg_ok "Completed Successfully!\n"
 | 
					msg_ok "Completed Successfully!\n"
 | 
				
			||||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
					echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
				
			||||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
					echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
				
			||||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:5055${CL}"
 | 
					echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:5055${CL}"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										83
									
								
								ct/koillection.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								ct/koillection.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,83 @@
 | 
				
			|||||||
 | 
					#!/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: bvdberg01
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://koillection.github.io/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Koillection"
 | 
				
			||||||
 | 
					var_tags="network"
 | 
				
			||||||
 | 
					var_cpu="2"
 | 
				
			||||||
 | 
					var_ram="1024"
 | 
				
			||||||
 | 
					var_disk="8"
 | 
				
			||||||
 | 
					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/koillection ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/benjaminjonard/koillection/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 apache2
 | 
				
			||||||
 | 
					    msg_ok "Stopped Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					    cd /opt
 | 
				
			||||||
 | 
					    mv /opt/koillection/ /opt/koillection-backup
 | 
				
			||||||
 | 
					    wget -q "https://github.com/benjaminjonard/koillection/archive/refs/tags/${RELEASE}.zip"
 | 
				
			||||||
 | 
					    unzip -q "${RELEASE}.zip"
 | 
				
			||||||
 | 
					    mv "/opt/koillection-${RELEASE}" /opt/koillection
 | 
				
			||||||
 | 
					    cd /opt/koillection
 | 
				
			||||||
 | 
					    cp -r /opt/koillection-backup/.env.local /opt/koillection
 | 
				
			||||||
 | 
					    cp -r /opt/koillection-backup/public/uploads/. /opt/koillection/public/uploads/
 | 
				
			||||||
 | 
					    export COMPOSER_ALLOW_SUPERUSER=1
 | 
				
			||||||
 | 
					    composer install --no-dev -o --no-interaction --classmap-authoritative &>/dev/null
 | 
				
			||||||
 | 
					    php bin/console doctrine:migrations:migrate --no-interaction &>/dev/null
 | 
				
			||||||
 | 
					    php bin/console app:translations:dump &>/dev/null
 | 
				
			||||||
 | 
					    cd assets/
 | 
				
			||||||
 | 
					    yarn install &>/dev/null
 | 
				
			||||||
 | 
					    yarn build &>/dev/null
 | 
				
			||||||
 | 
					    chown -R www-data:www-data /opt/koillection/public/uploads
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    msg_ok "Updated $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting Service"
 | 
				
			||||||
 | 
					    systemctl start apache2
 | 
				
			||||||
 | 
					    msg_ok "Started Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Cleaning up"
 | 
				
			||||||
 | 
					    rm -r "/opt/${RELEASE}.zip"
 | 
				
			||||||
 | 
					    rm -r /opt/koillection-backup
 | 
				
			||||||
 | 
					    msg_ok "Cleaned"
 | 
				
			||||||
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					  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}${CL}"
 | 
				
			||||||
							
								
								
									
										49
									
								
								ct/mattermost.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								ct/mattermost.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,49 @@
 | 
				
			|||||||
 | 
					#!/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: Kaedon Cleland-Host (dracentis)
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://mattermost.com/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Mattermost"
 | 
				
			||||||
 | 
					var_tags="collaboration"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="2048"
 | 
				
			||||||
 | 
					var_disk="8"
 | 
				
			||||||
 | 
					var_os="ubuntu"
 | 
				
			||||||
 | 
					var_version="24.04"
 | 
				
			||||||
 | 
					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/apt/sources.list.d/mattermost.list ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP} LXC"
 | 
				
			||||||
 | 
					    apt-get update &>/dev/null
 | 
				
			||||||
 | 
					    apt-get -y upgrade &>/dev/null
 | 
				
			||||||
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
 | 
					    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}:8065${CL}"
 | 
				
			||||||
							
								
								
									
										75
									
								
								ct/paperless-ai.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								ct/paperless-ai.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,75 @@
 | 
				
			|||||||
 | 
					#!/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: MickLesk (CanbiZ)
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/clusterzx/paperless-ai
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Paperless-AI"
 | 
				
			||||||
 | 
					var_tags="ai;document"
 | 
				
			||||||
 | 
					var_cpu="2"
 | 
				
			||||||
 | 
					var_ram="2048"
 | 
				
			||||||
 | 
					var_disk="5"
 | 
				
			||||||
 | 
					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/paperless-ai ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/clusterzx/paperless-ai/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
				
			||||||
 | 
					  if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f /opt/${APP}_version.txt ]]; then
 | 
				
			||||||
 | 
					    msg_info "Stopping $APP"
 | 
				
			||||||
 | 
					    systemctl stop paperless-ai
 | 
				
			||||||
 | 
					    msg_ok "Stopped $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Updating $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					    cd /opt
 | 
				
			||||||
 | 
					    mv /opt/paperless-ai /opt/paperless-ai_bak
 | 
				
			||||||
 | 
					    wget -q "https://github.com/clusterzx/paperless-ai/archive/refs/tags/v${RELEASE}.zip"
 | 
				
			||||||
 | 
					    unzip -q v${RELEASE}.zip
 | 
				
			||||||
 | 
					    mv paperless-ai-${RELEASE} /opt/paperless-ai
 | 
				
			||||||
 | 
					    mkdir -p /opt/paperless-ai/data
 | 
				
			||||||
 | 
					    cp -a /opt/paperless-ai_bak/data/. /opt/paperless-ai/data/
 | 
				
			||||||
 | 
					    cd /opt/paperless-ai
 | 
				
			||||||
 | 
					    npm install &>/dev/null
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    msg_ok "Updated $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting $APP"
 | 
				
			||||||
 | 
					    systemctl start paperless-ai
 | 
				
			||||||
 | 
					    msg_ok "Started $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Cleaning Up"
 | 
				
			||||||
 | 
					    rm -rf /opt/v${RELEASE}.zip
 | 
				
			||||||
 | 
					    rm -rf /opt/paperless-ai_bak
 | 
				
			||||||
 | 
					    msg_ok "Cleanup Completed"
 | 
				
			||||||
 | 
					    msg_ok "Update Successful"
 | 
				
			||||||
 | 
					  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}:3000${CL}"
 | 
				
			||||||
							
								
								
									
										56
									
								
								ct/paymenter.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								ct/paymenter.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,56 @@
 | 
				
			|||||||
 | 
					#!/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="Paymenter"
 | 
				
			||||||
 | 
					var_tags="hosting;ecommerce;marketplace;"
 | 
				
			||||||
 | 
					var_cpu="2"
 | 
				
			||||||
 | 
					var_ram="1024"
 | 
				
			||||||
 | 
					var_disk="5"
 | 
				
			||||||
 | 
					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/paymenter ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/paymenter/paymenter/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_info "Updating ${APP} to ${RELEASE}"
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    cd /opt/paymenter
 | 
				
			||||||
 | 
					    php artisan p:upgrade --no-interaction &>/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 URL:${CL}"
 | 
				
			||||||
 | 
					echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:80${CL}"
 | 
				
			||||||
@@ -1,81 +0,0 @@
 | 
				
			|||||||
#!/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}"
 | 
					 | 
				
			||||||
@@ -3,7 +3,7 @@ source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/m
 | 
				
			|||||||
# Copyright (c) 2021-2025 community-scripts ORG
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
# Author: Snarkenfaugister
 | 
					# Author: Snarkenfaugister
 | 
				
			||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
# Source: https://github.com/stonith404/pocket-id
 | 
					# Source: https://github.com/pocket-id/pocket-id
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# App Default Values
 | 
					# App Default Values
 | 
				
			||||||
APP="PocketID"
 | 
					APP="PocketID"
 | 
				
			||||||
@@ -34,7 +34,7 @@ function update_script() {
 | 
				
			|||||||
        exit
 | 
					        exit
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    RELEASE=$(curl -fsSL https://api.github.com/repos/stonith404/pocket-id/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
					    RELEASE=$(curl -fsSL https://api.github.com/repos/pocket-id/pocket-id/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
				
			||||||
    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f /opt/${APP}_version.txt ]]; then
 | 
					    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f /opt/${APP}_version.txt ]]; then
 | 
				
			||||||
        msg_info "Updating $APP"
 | 
					        msg_info "Updating $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -50,7 +50,7 @@ function update_script() {
 | 
				
			|||||||
        cp /opt/pocket-id/backend/.env /opt/backend.env
 | 
					        cp /opt/pocket-id/backend/.env /opt/backend.env
 | 
				
			||||||
        cp /opt/pocket-id/frontend/.env /opt/frontend.env
 | 
					        cp /opt/pocket-id/frontend/.env /opt/frontend.env
 | 
				
			||||||
        rm -r /opt/pocket-id
 | 
					        rm -r /opt/pocket-id
 | 
				
			||||||
        wget -q "https://github.com/stonith404/pocket-id/archive/refs/tags/v${RELEASE}.zip"
 | 
					        wget -q "https://github.com/pocket-id/pocket-id/archive/refs/tags/v${RELEASE}.zip"
 | 
				
			||||||
        unzip -q v${RELEASE}.zip
 | 
					        unzip -q v${RELEASE}.zip
 | 
				
			||||||
        mv pocket-id-${RELEASE} /opt/pocket-id
 | 
					        mv pocket-id-${RELEASE} /opt/pocket-id
 | 
				
			||||||
        mv /opt/data /opt/pocket-id/backend/data
 | 
					        mv /opt/data /opt/pocket-id/backend/data
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										64
									
								
								ct/privatebin.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								ct/privatebin.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,64 @@
 | 
				
			|||||||
 | 
					#!/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="PrivateBin"
 | 
				
			||||||
 | 
					var_tags="paste;secure"
 | 
				
			||||||
 | 
					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 [[ ! -d /opt/privatebin ]]; then
 | 
				
			||||||
 | 
					    msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					    exit
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/PrivateBin/PrivateBin/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 "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    cp -f /opt/privatebin/cfg/conf.php /tmp/privatebin_conf.bak
 | 
				
			||||||
 | 
					    wget -q "https://github.com/PrivateBin/PrivateBin/archive/refs/tags/${RELEASE}.zip"
 | 
				
			||||||
 | 
					    unzip -q ${RELEASE}.zip
 | 
				
			||||||
 | 
					    rm -rf /opt/privatebin/*
 | 
				
			||||||
 | 
					    mv PrivateBin-${RELEASE}/* /opt/privatebin/
 | 
				
			||||||
 | 
					    mv /tmp/privatebin_conf.bak /opt/privatebin/cfg/conf.php
 | 
				
			||||||
 | 
					    chown -R www-data:www-data /opt/privatebin
 | 
				
			||||||
 | 
					    chmod -R 0755 /opt/privatebin/data
 | 
				
			||||||
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					    rm -rf ${RELEASE}.zip PrivateBin-${RELEASE}
 | 
				
			||||||
 | 
					    systemctl reload nginx php8.2-fpm
 | 
				
			||||||
 | 
					    msg_ok "Updated ${APP} to v${RELEASE}"
 | 
				
			||||||
 | 
					  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}https://${IP}${CL}"
 | 
				
			||||||
@@ -37,7 +37,7 @@ function update_script() {
 | 
				
			|||||||
    msg_ok "Stopped ${APP}"
 | 
					    msg_ok "Stopped ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Updating ${APP}"
 | 
					    msg_info "Updating ${APP}"
 | 
				
			||||||
    pip install prometheus-pve-exporter --upgrade --root-user-action=ignore &>/dev/null
 | 
					    pip install prometheus-pve-exporter --default-timeout=300 --upgrade --root-user-action=ignore &>/dev/null
 | 
				
			||||||
    msg_ok "Updated ${APP}"
 | 
					    msg_ok "Updated ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Starting ${APP}"
 | 
					    msg_info "Starting ${APP}"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,7 +16,7 @@ cat <<"EOF"
 | 
				
			|||||||
EOF
 | 
					EOF
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
header_info
 | 
					header_info
 | 
				
			||||||
APP="PBS"
 | 
					APP="Proxmox-Backup-Server"
 | 
				
			||||||
var_tags="backup"
 | 
					var_tags="backup"
 | 
				
			||||||
var_cpu="2"
 | 
					var_cpu="2"
 | 
				
			||||||
var_ram="2048"
 | 
					var_ram="2048"
 | 
				
			||||||
@@ -37,7 +37,7 @@ function update_script() {
 | 
				
			|||||||
    header_info
 | 
					    header_info
 | 
				
			||||||
    check_container_storage
 | 
					    check_container_storage
 | 
				
			||||||
    check_container_resources
 | 
					    check_container_resources
 | 
				
			||||||
    if [[ ! -d /var ]]; then msg_error "No ${APP} Installation Found!"; exit; fi
 | 
					    if [[ ! -e /usr/sbin/proxmox-backup-manager ]]; then msg_error "No ${APP} Installation Found!"; exit; fi
 | 
				
			||||||
        msg_info "Updating $APP LXC"
 | 
					        msg_info "Updating $APP LXC"
 | 
				
			||||||
        apt-get update &>/dev/null
 | 
					        apt-get update &>/dev/null
 | 
				
			||||||
        apt-get -y upgrade &>/dev/null
 | 
					        apt-get -y upgrade &>/dev/null
 | 
				
			||||||
@@ -6,7 +6,7 @@ source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/m
 | 
				
			|||||||
# Source: Proxmox Server Solution GmbH
 | 
					# Source: Proxmox Server Solution GmbH
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# App Default Values
 | 
					# App Default Values
 | 
				
			||||||
APP="proxmox-datacenter-manager"
 | 
					APP="Proxmox-Datacenter-Manager"
 | 
				
			||||||
var_tags="datacenter"
 | 
					var_tags="datacenter"
 | 
				
			||||||
var_cpu="2"
 | 
					var_cpu="2"
 | 
				
			||||||
var_ram="2048"
 | 
					var_ram="2048"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										56
									
								
								ct/radicale.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								ct/radicale.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,56 @@
 | 
				
			|||||||
 | 
					#!/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: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://radicale.org/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Radicale"
 | 
				
			||||||
 | 
					var_tags="calendar"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="512"
 | 
				
			||||||
 | 
					var_disk="2"
 | 
				
			||||||
 | 
					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/radicale ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP}"
 | 
				
			||||||
 | 
					    python3 -m venv /opt/radicale
 | 
				
			||||||
 | 
					    source /opt/radicale/bin/activate
 | 
				
			||||||
 | 
					    python3 -m pip install --upgrade https://github.com/Kozea/Radicale/archive/master.tar.gz
 | 
				
			||||||
 | 
					    msg_ok "Updated ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting Service"
 | 
				
			||||||
 | 
					    systemctl enable -q --now radicale
 | 
				
			||||||
 | 
					    msg_ok "Started Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    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}:5232${CL}"
 | 
				
			||||||
							
								
								
									
										77
									
								
								ct/seelf.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								ct/seelf.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,77 @@
 | 
				
			|||||||
 | 
					#!/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: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/YuukanOO/seelf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					APP="seelf"
 | 
				
			||||||
 | 
					TAGS="server;docker"
 | 
				
			||||||
 | 
					var_cpu="2"
 | 
				
			||||||
 | 
					var_ram="4096"
 | 
				
			||||||
 | 
					var_disk="10"
 | 
				
			||||||
 | 
					var_os="debian"
 | 
				
			||||||
 | 
					var_version="12"
 | 
				
			||||||
 | 
					var_unprivileged="1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					header_info "$APP"
 | 
				
			||||||
 | 
					base_settings
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					variables
 | 
				
			||||||
 | 
					color
 | 
				
			||||||
 | 
					catch_errors
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function update_script() {
 | 
				
			||||||
 | 
					    header_info
 | 
				
			||||||
 | 
					    check_container_storage
 | 
				
			||||||
 | 
					    check_container_resources
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if [[ ! -d /opt/seelf ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    RELEASE=$(curl -s https://api.github.com/repos/YuukanOO/seelf/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | 
				
			||||||
 | 
					    if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]] || [[ ! -f /opt/${APP}_version.txt ]]; then
 | 
				
			||||||
 | 
					        msg_info "Updating $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_info "Stopping $APP"
 | 
				
			||||||
 | 
					        systemctl stop seelf
 | 
				
			||||||
 | 
					        msg_ok "Stopped $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_info "Updating $APP to v${RELEASE}. Patience"
 | 
				
			||||||
 | 
					        export PATH=$PATH:/usr/local/go/bin
 | 
				
			||||||
 | 
					        source ~/.bashrc
 | 
				
			||||||
 | 
					        wget -q "https://github.com/YuukanOO/seelf/archive/refs/tags/v${RELEASE}.tar.gz"
 | 
				
			||||||
 | 
					        tar -xzf v${RELEASE}.tar.gz
 | 
				
			||||||
 | 
					        cp -r seelf-${RELEASE}/ /opt/seelf
 | 
				
			||||||
 | 
					        cd /opt/seelf
 | 
				
			||||||
 | 
					        make build &> /dev/null
 | 
				
			||||||
 | 
					        msg_ok "Updated $APP to v${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        msg_info "Starting $APP"
 | 
				
			||||||
 | 
					        systemctl start seelf
 | 
				
			||||||
 | 
					        msg_ok "Started $APP"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # Cleaning up
 | 
				
			||||||
 | 
					        msg_info "Cleaning Up"
 | 
				
			||||||
 | 
					        rm -f ~/*.tar.gz
 | 
				
			||||||
 | 
					        rm -rf ~/seelf-${RELEASE}
 | 
				
			||||||
 | 
					        msg_ok "Cleanup Completed"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
 | 
					        msg_ok "Update Successful"
 | 
				
			||||||
 | 
					    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}:8080${CL}" 
 | 
				
			||||||
@@ -45,6 +45,7 @@ function update_script() {
 | 
				
			|||||||
    unzip -q v${RELEASE}.zip
 | 
					    unzip -q v${RELEASE}.zip
 | 
				
			||||||
    mv tianji-${RELEASE} /opt/tianji
 | 
					    mv tianji-${RELEASE} /opt/tianji
 | 
				
			||||||
    cd tianji
 | 
					    cd tianji
 | 
				
			||||||
 | 
					    export NODE_OPTIONS="--max_old_space_size=4096"
 | 
				
			||||||
    pnpm install --filter @tianji/client... --config.dedupe-peer-dependents=false --frozen-lockfile >/dev/null 2>&1
 | 
					    pnpm install --filter @tianji/client... --config.dedupe-peer-dependents=false --frozen-lockfile >/dev/null 2>&1
 | 
				
			||||||
    pnpm build:static >/dev/null 2>&1
 | 
					    pnpm build:static >/dev/null 2>&1
 | 
				
			||||||
    pnpm install --filter @tianji/server... --config.dedupe-peer-dependents=false >/dev/null 2>&1
 | 
					    pnpm install --filter @tianji/server... --config.dedupe-peer-dependents=false >/dev/null 2>&1
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -35,22 +35,22 @@ function update_script() {
 | 
				
			|||||||
    RELEASE=$(curl -s https://api.github.com/repos/TriliumNext/Notes/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
					    RELEASE=$(curl -s https://api.github.com/repos/TriliumNext/Notes/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Stopping ${APP}"
 | 
					    msg_info "Stopping ${APP}"
 | 
				
			||||||
    systemctl stop trilium.service
 | 
					    systemctl stop trilium
 | 
				
			||||||
    sleep 1
 | 
					    sleep 1
 | 
				
			||||||
    msg_ok "Stopped ${APP}"
 | 
					    msg_ok "Stopped ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Updating to ${RELEASE}"
 | 
					    msg_info "Updating to ${RELEASE}"
 | 
				
			||||||
    wget -q https://github.com/TriliumNext/Notes/releases/download/${RELEASE}/TriliumNextNotes-${RELEASE}-server-linux-x64.tar.xz
 | 
					    wget -q https://github.com/TriliumNext/Notes/releases/download/${RELEASE}/TriliumNextNotes-linux-x64-${RELEASE}.tar.xz
 | 
				
			||||||
    tar -xf TriliumNextNotes-${RELEASE}-server-linux-x64.tar.xz
 | 
					    tar -xf TriliumNextNotes-linux-x64-${RELEASE}.tar.xz
 | 
				
			||||||
    cp -r trilium-linux-x64-server/* /opt/trilium/
 | 
					    cp -r trilium-linux-x64-server/* /opt/trilium/
 | 
				
			||||||
    msg_ok "Updated to ${RELEASE}"
 | 
					    msg_ok "Updated to ${RELEASE}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Cleaning up"
 | 
					    msg_info "Cleaning up"
 | 
				
			||||||
    rm -rf TriliumNextNotes-${RELEASE}-server-linux-x64.tar.xz trilium-linux-x64-server
 | 
					    rm -rf TriliumNextNotes-linux-x64-${RELEASE}.tar.xz trilium-linux-x64-server
 | 
				
			||||||
    msg_ok "Cleaned"
 | 
					    msg_ok "Cleaned"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Starting ${APP}"
 | 
					    msg_info "Starting ${APP}"
 | 
				
			||||||
    systemctl start trilium.service
 | 
					    systemctl start trilium
 | 
				
			||||||
    sleep 1
 | 
					    sleep 1
 | 
				
			||||||
    msg_ok "Started ${APP}"
 | 
					    msg_ok "Started ${APP}"
 | 
				
			||||||
    msg_ok "Updated Successfully"
 | 
					    msg_ok "Updated Successfully"
 | 
				
			||||||
@@ -64,4 +64,4 @@ description
 | 
				
			|||||||
msg_ok "Completed Successfully!\n"
 | 
					msg_ok "Completed Successfully!\n"
 | 
				
			||||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
					echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
				
			||||||
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
					echo -e "${INFO}${YW} Access it using the following URL:${CL}"
 | 
				
			||||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:8080${CL}"
 | 
					echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:8080${CL}"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -43,6 +43,9 @@ start
 | 
				
			|||||||
build_container
 | 
					build_container
 | 
				
			||||||
description
 | 
					description
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					pct set $CTID -features fuse=1,nesting=1
 | 
				
			||||||
 | 
					pct reboot $CTID
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_ok "Completed Successfully!\n"
 | 
					msg_ok "Completed Successfully!\n"
 | 
				
			||||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
					echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
 | 
				
			||||||
echo -e "${INFO}${YW} Access it using the following IP:${CL}"
 | 
					echo -e "${INFO}${YW} Access it using the following IP:${CL}"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										57
									
								
								ct/zerotier-one.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								ct/zerotier-one.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,57 @@
 | 
				
			|||||||
 | 
					#!/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: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# App Default Values
 | 
				
			||||||
 | 
					APP="Zerotier-One"
 | 
				
			||||||
 | 
					var_tags="networking"
 | 
				
			||||||
 | 
					var_cpu="1"
 | 
				
			||||||
 | 
					var_ram="512"
 | 
				
			||||||
 | 
					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 /usr/sbin/zerotier-one ]]; then
 | 
				
			||||||
 | 
					        msg_error "No ${APP} Installation Found!"
 | 
				
			||||||
 | 
					        exit
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    msg_info "Stopping Service"
 | 
				
			||||||
 | 
					    systemctl stop zerotier-one
 | 
				
			||||||
 | 
					    msg_ok "Stopping Service"
 | 
				
			||||||
 | 
					    msg_info "Updating ${APP}"
 | 
				
			||||||
 | 
					    apt-get update &>/dev/null
 | 
				
			||||||
 | 
					    apt-get -y upgrade
 | 
				
			||||||
 | 
					    msg_ok "Updated ${APP}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Starting Service"
 | 
				
			||||||
 | 
					    systemctl start zerotier-one
 | 
				
			||||||
 | 
					    msg_ok "Started Service"
 | 
				
			||||||
 | 
					    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}https://${IP}:3443${CL}"
 | 
				
			||||||
@@ -39,24 +39,33 @@ function update_script() {
 | 
				
			|||||||
    msg_ok "Stopped Service"
 | 
					    msg_ok "Stopped Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Creating Backup"
 | 
					    msg_info "Creating Backup"
 | 
				
			||||||
    mkdir -p /opt/z2m_backup
 | 
					      rm -rf /opt/${APP}_backup*.tar.gz
 | 
				
			||||||
    tar -czf /opt/z2m_backup/${APP}_backup_$(date +%Y%m%d%H%M%S).tar.gz -C /opt zigbee2mqtt &>/dev/null
 | 
					      mkdir -p /opt/z2m_backup
 | 
				
			||||||
    mv /opt/zigbee2mqtt/data /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_ok "Backup Created"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Updating ${APP} to v${RELEASE}"
 | 
					    msg_info "Updating ${APP} to v${RELEASE}"
 | 
				
			||||||
    cd /opt
 | 
					      cd /opt
 | 
				
			||||||
    wget -q "https://github.com/Koenkk/zigbee2mqtt/archive/refs/tags/${RELEASE}.zip"
 | 
					      wget -q "https://github.com/Koenkk/zigbee2mqtt/archive/refs/tags/${RELEASE}.zip"
 | 
				
			||||||
    unzip -q ${RELEASE}.zip
 | 
					      unzip -q ${RELEASE}.zip
 | 
				
			||||||
    mv zigbee2mqtt-${RELEASE} /opt/zigbee2mqtt
 | 
					      rm -rf /opt/zigbee2mqtt
 | 
				
			||||||
    rm -rf /opt/zigbee2mqtt/data
 | 
					      mv zigbee2mqtt-${RELEASE} /opt/zigbee2mqtt
 | 
				
			||||||
    mv /opt/z2m_backup/data /opt/zigbee2mqtt
 | 
					      rm -rf /opt/zigbee2mqtt/data
 | 
				
			||||||
    cd /opt/zigbee2mqtt 
 | 
					      mv /opt/z2m_backup/data /opt/zigbee2mqtt
 | 
				
			||||||
    pnpm install --frozen-lockfile &>/dev/null
 | 
					      cd /opt/zigbee2mqtt 
 | 
				
			||||||
    pnpm build &>/dev/null
 | 
					      pnpm install --frozen-lockfile &>/dev/null
 | 
				
			||||||
 | 
					      pnpm build &>/dev/null
 | 
				
			||||||
 | 
					    msg_ok "Updated Zigbee2MQTT"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    msg_info "Starting Service"
 | 
					    msg_info "Starting Service"
 | 
				
			||||||
    systemctl start zigbee2mqtt
 | 
					      systemctl start zigbee2mqtt
 | 
				
			||||||
    msg_ok "Started Service"
 | 
					    msg_ok "Started Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    msg_info "Cleaning up"
 | 
				
			||||||
 | 
					      rm -rf /opt/z2m_backup
 | 
				
			||||||
 | 
					      rm -rf /opt/${RELEASE}.zip
 | 
				
			||||||
 | 
					    msg_ok "Cleaned up"
 | 
				
			||||||
    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
					    echo "${RELEASE}" >/opt/${APP}_version.txt
 | 
				
			||||||
  else
 | 
					  else
 | 
				
			||||||
    msg_ok "No update required. ${APP} is already at v${RELEASE}."
 | 
					    msg_ok "No update required. ${APP} is already at v${RELEASE}."
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										462
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										462
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -23,6 +23,8 @@
 | 
				
			|||||||
        "@radix-ui/react-tabs": "^1.1.0",
 | 
					        "@radix-ui/react-tabs": "^1.1.0",
 | 
				
			||||||
        "@radix-ui/react-tooltip": "^1.1.2",
 | 
					        "@radix-ui/react-tooltip": "^1.1.2",
 | 
				
			||||||
        "@vercel/analytics": "^1.2.2",
 | 
					        "@vercel/analytics": "^1.2.2",
 | 
				
			||||||
 | 
					        "chart.js": "^4.4.1",
 | 
				
			||||||
 | 
					        "chartjs-plugin-datalabels": "^2.2.0",
 | 
				
			||||||
        "class-variance-authority": "^0.7.0",
 | 
					        "class-variance-authority": "^0.7.0",
 | 
				
			||||||
        "clsx": "^2.1.1",
 | 
					        "clsx": "^2.1.1",
 | 
				
			||||||
        "cmdk": "^1.0.0",
 | 
					        "cmdk": "^1.0.0",
 | 
				
			||||||
@@ -37,6 +39,7 @@
 | 
				
			|||||||
        "pocketbase": "^0.21.4",
 | 
					        "pocketbase": "^0.21.4",
 | 
				
			||||||
        "prettier-plugin-organize-imports": "^4.1.0",
 | 
					        "prettier-plugin-organize-imports": "^4.1.0",
 | 
				
			||||||
        "react": "19.0.0-rc-02c0e824-20241028",
 | 
					        "react": "19.0.0-rc-02c0e824-20241028",
 | 
				
			||||||
 | 
					        "react-chartjs-2": "^5.3.0",
 | 
				
			||||||
        "react-code-blocks": "^0.1.6",
 | 
					        "react-code-blocks": "^0.1.6",
 | 
				
			||||||
        "react-datepicker": "^7.6.0",
 | 
					        "react-datepicker": "^7.6.0",
 | 
				
			||||||
        "react-day-picker": "8.10.1",
 | 
					        "react-day-picker": "8.10.1",
 | 
				
			||||||
@@ -69,7 +72,7 @@
 | 
				
			|||||||
        "tailwindcss-animated": "^1.1.2",
 | 
					        "tailwindcss-animated": "^1.1.2",
 | 
				
			||||||
        "typescript": "^5",
 | 
					        "typescript": "^5",
 | 
				
			||||||
        "vite-tsconfig-paths": "^5.1.3",
 | 
					        "vite-tsconfig-paths": "^5.1.3",
 | 
				
			||||||
        "vitest": "^2.1.6"
 | 
					        "vitest": "^2.1.9"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@alloc/quick-lru": {
 | 
					    "node_modules/@alloc/quick-lru": {
 | 
				
			||||||
@@ -468,9 +471,9 @@
 | 
				
			|||||||
      "license": "MIT"
 | 
					      "license": "MIT"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/aix-ppc64": {
 | 
					    "node_modules/@esbuild/aix-ppc64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-thpVCb/rhxE/BnMLQ7GReQLLN8q9qbHmI55F4489/ByVg2aQaQ6kbcLb6FHkocZzQhxc4gx0sCk0tJkKBFzDhA==",
 | 
					      "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "ppc64"
 | 
					        "ppc64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -481,13 +484,13 @@
 | 
				
			|||||||
        "aix"
 | 
					        "aix"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/android-arm": {
 | 
					    "node_modules/@esbuild/android-arm": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-tmwl4hJkCfNHwFB3nBa8z1Uy3ypZpxqxfTQOcHX+xRByyYgunVbZ9MzUUfb0RxaHIMnbHagwAxuTL+tnNM+1/Q==",
 | 
					      "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm"
 | 
					        "arm"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -498,13 +501,13 @@
 | 
				
			|||||||
        "android"
 | 
					        "android"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/android-arm64": {
 | 
					    "node_modules/@esbuild/android-arm64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-cNLgeqCqV8WxfcTIOeL4OAtSmL8JjcN6m09XIgro1Wi7cF4t/THaWEa7eL5CMoMBdjoHOTh/vwTO/o2TRXIyzg==",
 | 
					      "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm64"
 | 
					        "arm64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -515,13 +518,13 @@
 | 
				
			|||||||
        "android"
 | 
					        "android"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/android-x64": {
 | 
					    "node_modules/@esbuild/android-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-B6Q0YQDqMx9D7rvIcsXfmJfvUYLoP722bgfBlO5cGvNVb5V/+Y7nhBE3mHV9OpxBf4eAS2S68KZztiPaWq4XYw==",
 | 
					      "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -532,13 +535,13 @@
 | 
				
			|||||||
        "android"
 | 
					        "android"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/darwin-arm64": {
 | 
					    "node_modules/@esbuild/darwin-arm64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-kj3AnYWc+CekmZnS5IPu9D+HWtUI49hbnyqk0FLEJDbzCIQt7hg7ucF1SQAilhtYpIujfaHr6O0UHlzzSPdOeA==",
 | 
					      "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm64"
 | 
					        "arm64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -549,13 +552,13 @@
 | 
				
			|||||||
        "darwin"
 | 
					        "darwin"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/darwin-x64": {
 | 
					    "node_modules/@esbuild/darwin-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-WeSrmwwHaPkNR5H3yYfowhZcbriGqooyu3zI/3GGpF8AyUdsrrP0X6KumITGA9WOyiJavnGZUwPGvxvwfWPHIA==",
 | 
					      "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -566,13 +569,13 @@
 | 
				
			|||||||
        "darwin"
 | 
					        "darwin"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/freebsd-arm64": {
 | 
					    "node_modules/@esbuild/freebsd-arm64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-UN8HXjtJ0k/Mj6a9+5u6+2eZ2ERD7Edt1Q9IZiB5UZAIdPnVKDoG7mdTVGhHJIeEml60JteamR3qhsr1r8gXvg==",
 | 
					      "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm64"
 | 
					        "arm64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -583,13 +586,13 @@
 | 
				
			|||||||
        "freebsd"
 | 
					        "freebsd"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/freebsd-x64": {
 | 
					    "node_modules/@esbuild/freebsd-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-TvW7wE/89PYW+IevEJXZ5sF6gJRDY/14hyIGFXdIucxCsbRmLUcjseQu1SyTko+2idmCw94TgyaEZi9HUSOe3Q==",
 | 
					      "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -600,13 +603,13 @@
 | 
				
			|||||||
        "freebsd"
 | 
					        "freebsd"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-arm": {
 | 
					    "node_modules/@esbuild/linux-arm": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-n0WRM/gWIdU29J57hJyUdIsk0WarGd6To0s+Y+LwvlC55wt+GT/OgkwoXCXvIue1i1sSNWblHEig00GBWiJgfA==",
 | 
					      "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm"
 | 
					        "arm"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -617,13 +620,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-arm64": {
 | 
					    "node_modules/@esbuild/linux-arm64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-7HnAD6074BW43YvvUmE/35Id9/NB7BeX5EoNkK9obndmZBUk8xmJJeU7DwmUeN7tkysslb2eSl6CTrYz6oEMQg==",
 | 
					      "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm64"
 | 
					        "arm64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -634,13 +637,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-ia32": {
 | 
					    "node_modules/@esbuild/linux-ia32": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-sfv0tGPQhcZOgTKO3oBE9xpHuUqguHvSo4jl+wjnKwFpapx+vUDcawbwPNuBIAYdRAvIDBfZVvXprIj3HA+Ugw==",
 | 
					      "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "ia32"
 | 
					        "ia32"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -651,13 +654,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-loong64": {
 | 
					    "node_modules/@esbuild/linux-loong64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-CN9AZr8kEndGooS35ntToZLTQLHEjtVB5n7dl8ZcTZMonJ7CCfStrYhrzF97eAecqVbVJ7APOEe18RPI4KLhwQ==",
 | 
					      "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "loong64"
 | 
					        "loong64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -668,13 +671,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-mips64el": {
 | 
					    "node_modules/@esbuild/linux-mips64el": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-iMkk7qr/wl3exJATwkISxI7kTcmHKE+BlymIAbHO8xanq/TjHaaVThFF6ipWzPHryoFsesNQJPE/3wFJw4+huw==",
 | 
					      "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "mips64el"
 | 
					        "mips64el"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -685,13 +688,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-ppc64": {
 | 
					    "node_modules/@esbuild/linux-ppc64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-shsVrgCZ57Vr2L8mm39kO5PPIb+843FStGt7sGGoqiiWYconSxwTiuswC1VJZLCjNiMLAMh34jg4VSEQb+iEbw==",
 | 
					      "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "ppc64"
 | 
					        "ppc64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -702,13 +705,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-riscv64": {
 | 
					    "node_modules/@esbuild/linux-riscv64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-4eSFWnU9Hhd68fW16GD0TINewo1L6dRrB+oLNNbYyMUAeOD2yCK5KXGK1GH4qD/kT+bTEXjsyTCiJGHPZ3eM9Q==",
 | 
					      "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "riscv64"
 | 
					        "riscv64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -719,13 +722,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-s390x": {
 | 
					    "node_modules/@esbuild/linux-s390x": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-S0Bh0A53b0YHL2XEXC20bHLuGMOhFDO6GN4b3YjRLK//Ep3ql3erpNcPlEFed93hsQAjAQDNsvcK+hV90FubSw==",
 | 
					      "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "s390x"
 | 
					        "s390x"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -736,13 +739,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/linux-x64": {
 | 
					    "node_modules/@esbuild/linux-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-8Qi4nQcCTbLnK9WoMjdC9NiTG6/E38RNICU6sUNqK0QFxCYgoARqVqxdFmWkdonVsvGqWhmm7MO0jyTqLqwj0Q==",
 | 
					      "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -753,30 +756,13 @@
 | 
				
			|||||||
        "linux"
 | 
					        "linux"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "node_modules/@esbuild/netbsd-arm64": {
 | 
					 | 
				
			||||||
      "version": "0.24.2",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.24.2.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-wuLK/VztRRpMt9zyHSazyCVdCXlpHkKm34WUyinD2lzK07FAHTq0KQvZZlXikNWkDGoT6x3TD51jKQ7gMVpopw==",
 | 
					 | 
				
			||||||
      "cpu": [
 | 
					 | 
				
			||||||
        "arm64"
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "license": "MIT",
 | 
					 | 
				
			||||||
      "optional": true,
 | 
					 | 
				
			||||||
      "os": [
 | 
					 | 
				
			||||||
        "netbsd"
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      "engines": {
 | 
					 | 
				
			||||||
        "node": ">=18"
 | 
					 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/netbsd-x64": {
 | 
					    "node_modules/@esbuild/netbsd-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-VefFaQUc4FMmJuAxmIHgUmfNiLXY438XrL4GDNV1Y1H/RW3qow68xTwjZKfj/+Plp9NANmzbH5R40Meudu8mmw==",
 | 
					      "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -787,30 +773,13 @@
 | 
				
			|||||||
        "netbsd"
 | 
					        "netbsd"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "node_modules/@esbuild/openbsd-arm64": {
 | 
					 | 
				
			||||||
      "version": "0.24.2",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.24.2.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-YQbi46SBct6iKnszhSvdluqDmxCJA+Pu280Av9WICNwQmMxV7nLRHZfjQzwbPs3jeWnuAhE9Jy0NrnJ12Oz+0A==",
 | 
					 | 
				
			||||||
      "cpu": [
 | 
					 | 
				
			||||||
        "arm64"
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "license": "MIT",
 | 
					 | 
				
			||||||
      "optional": true,
 | 
					 | 
				
			||||||
      "os": [
 | 
					 | 
				
			||||||
        "openbsd"
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      "engines": {
 | 
					 | 
				
			||||||
        "node": ">=18"
 | 
					 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/openbsd-x64": {
 | 
					    "node_modules/@esbuild/openbsd-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-+iDS6zpNM6EnJyWv0bMGLWSWeXGN/HTaF/LXHXHwejGsVi+ooqDfMCCTerNFxEkM3wYVcExkeGXNqshc9iMaOA==",
 | 
					      "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -821,13 +790,13 @@
 | 
				
			|||||||
        "openbsd"
 | 
					        "openbsd"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/sunos-x64": {
 | 
					    "node_modules/@esbuild/sunos-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-hTdsW27jcktEvpwNHJU4ZwWFGkz2zRJUz8pvddmXPtXDzVKTTINmlmga3ZzwcuMpUvLw7JkLy9QLKyGpD2Yxig==",
 | 
					      "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -838,13 +807,13 @@
 | 
				
			|||||||
        "sunos"
 | 
					        "sunos"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/win32-arm64": {
 | 
					    "node_modules/@esbuild/win32-arm64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-LihEQ2BBKVFLOC9ZItT9iFprsE9tqjDjnbulhHoFxYQtQfai7qfluVODIYxt1PgdoyQkz23+01rzwNwYfutxUQ==",
 | 
					      "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "arm64"
 | 
					        "arm64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -855,13 +824,13 @@
 | 
				
			|||||||
        "win32"
 | 
					        "win32"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/win32-ia32": {
 | 
					    "node_modules/@esbuild/win32-ia32": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-q+iGUwfs8tncmFC9pcnD5IvRHAzmbwQ3GPS5/ceCyHdjXubwQWI12MKWSNSMYLJMq23/IUCvJMS76PDqXe1fxA==",
 | 
					      "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "ia32"
 | 
					        "ia32"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -872,13 +841,13 @@
 | 
				
			|||||||
        "win32"
 | 
					        "win32"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@esbuild/win32-x64": {
 | 
					    "node_modules/@esbuild/win32-x64": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-7VTgWzgMGvup6aSqDPLiW5zHaxYJGTO4OokMjIlrCtf+VpEL+cXKtCvg723iguPYI5oaUNdS+/V7OU2gvXVWEg==",
 | 
					      "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==",
 | 
				
			||||||
      "cpu": [
 | 
					      "cpu": [
 | 
				
			||||||
        "x64"
 | 
					        "x64"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
@@ -889,7 +858,7 @@
 | 
				
			|||||||
        "win32"
 | 
					        "win32"
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@eslint-community/eslint-utils": {
 | 
					    "node_modules/@eslint-community/eslint-utils": {
 | 
				
			||||||
@@ -1573,6 +1542,12 @@
 | 
				
			|||||||
        "@jridgewell/sourcemap-codec": "^1.4.14"
 | 
					        "@jridgewell/sourcemap-codec": "^1.4.14"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "node_modules/@kurkle/color": {
 | 
				
			||||||
 | 
					      "version": "0.3.4",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@kurkle/color/-/color-0.3.4.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-M5UknZPHRu3DEDWoipU6sE8PdkZ6Z/S+v4dD+Ke8IaNlpdSQah50lz1KtcFBa2vsdOnwbbnxJwVM4wty6udA5w==",
 | 
				
			||||||
 | 
					      "license": "MIT"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "node_modules/@next/env": {
 | 
					    "node_modules/@next/env": {
 | 
				
			||||||
      "version": "15.1.3",
 | 
					      "version": "15.1.3",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@next/env/-/env-15.1.3.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@next/env/-/env-15.1.3.tgz",
 | 
				
			||||||
@@ -3454,14 +3429,14 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/expect": {
 | 
					    "node_modules/@vitest/expect": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-9M1UR9CAmrhJOMoSwVnPh2rELPKhYo0m/CSgqw9PyStpxtkwhmdM6XYlXGKeYyERY1N6EIuzkQ7e3Lm1WKCoUg==",
 | 
					      "integrity": "sha512-UJCIkTBenHeKT1TTlKMJWy1laZewsRIzYighyYiJKZreqtdxSos/S1t+ktRMQWu2CKqaarrkeszJx1cgC5tGZw==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/spy": "2.1.6",
 | 
					        "@vitest/spy": "2.1.9",
 | 
				
			||||||
        "@vitest/utils": "2.1.6",
 | 
					        "@vitest/utils": "2.1.9",
 | 
				
			||||||
        "chai": "^5.1.2",
 | 
					        "chai": "^5.1.2",
 | 
				
			||||||
        "tinyrainbow": "^1.2.0"
 | 
					        "tinyrainbow": "^1.2.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
@@ -3470,13 +3445,13 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/mocker": {
 | 
					    "node_modules/@vitest/mocker": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/mocker/-/mocker-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/mocker/-/mocker-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-MHZp2Z+Q/A3am5oD4WSH04f9B0T7UvwEb+v5W0kCYMhtXGYbdyl2NUk1wdSMqGthmhpiThPDp/hEoVwu16+u1A==",
 | 
					      "integrity": "sha512-tVL6uJgoUdi6icpxmdrn5YNo3g3Dxv+IHJBr0GXHaEdTcw3F+cPKnsXFhli6nO+f/6SDKPHEK1UN+k+TQv0Ehg==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/spy": "2.1.6",
 | 
					        "@vitest/spy": "2.1.9",
 | 
				
			||||||
        "estree-walker": "^3.0.3",
 | 
					        "estree-walker": "^3.0.3",
 | 
				
			||||||
        "magic-string": "^0.30.12"
 | 
					        "magic-string": "^0.30.12"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
@@ -3485,7 +3460,7 @@
 | 
				
			|||||||
      },
 | 
					      },
 | 
				
			||||||
      "peerDependencies": {
 | 
					      "peerDependencies": {
 | 
				
			||||||
        "msw": "^2.4.9",
 | 
					        "msw": "^2.4.9",
 | 
				
			||||||
        "vite": "^5.0.0 || ^6.0.0"
 | 
					        "vite": "^5.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "peerDependenciesMeta": {
 | 
					      "peerDependenciesMeta": {
 | 
				
			||||||
        "msw": {
 | 
					        "msw": {
 | 
				
			||||||
@@ -3497,9 +3472,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/pretty-format": {
 | 
					    "node_modules/@vitest/pretty-format": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/pretty-format/-/pretty-format-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/pretty-format/-/pretty-format-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-exZyLcEnHgDMKc54TtHca4McV4sKT+NKAe9ix/yhd/qkYb/TP8HTyXRFDijV19qKqTZM0hPL4753zU/U8L/gAA==",
 | 
					      "integrity": "sha512-KhRIdGV2U9HOUzxfiHmY8IFHTdqtOhIzCpd8WRdJiE7D/HUcZVD0EgQCVjm+Q9gkUXWgBvMmTtZgIG48wq7sOQ==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
@@ -3510,13 +3485,13 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/runner": {
 | 
					    "node_modules/@vitest/runner": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-SjkRGSFyrA82m5nz7To4CkRSEVWn/rwQISHoia/DB8c6IHIhaE/UNAo+7UfeaeJRE979XceGl00LNkIz09RFsA==",
 | 
					      "integrity": "sha512-ZXSSqTFIrzduD63btIfEyOmNcBmQvgOVsPNPe0jYtESiXkhd8u2erDLnMxmGrDCwHCCHE7hxwRDCT3pt0esT4g==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/utils": "2.1.6",
 | 
					        "@vitest/utils": "2.1.9",
 | 
				
			||||||
        "pathe": "^1.1.2"
 | 
					        "pathe": "^1.1.2"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "funding": {
 | 
					      "funding": {
 | 
				
			||||||
@@ -3524,13 +3499,13 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/snapshot": {
 | 
					    "node_modules/@vitest/snapshot": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-5JTWHw8iS9l3v4/VSuthCndw1lN/hpPB+mlgn1BUhFbobeIUj1J1V/Bj2t2ovGEmkXLTckFjQddsxS5T6LuVWw==",
 | 
					      "integrity": "sha512-oBO82rEjsxLNJincVhLhaxxZdEtV0EFHMK5Kmx5sJ6H9L183dHECjiefOAdnqpIgT5eZwT04PoggUnW88vOBNQ==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/pretty-format": "2.1.6",
 | 
					        "@vitest/pretty-format": "2.1.9",
 | 
				
			||||||
        "magic-string": "^0.30.12",
 | 
					        "magic-string": "^0.30.12",
 | 
				
			||||||
        "pathe": "^1.1.2"
 | 
					        "pathe": "^1.1.2"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
@@ -3539,9 +3514,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/spy": {
 | 
					    "node_modules/@vitest/spy": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-oTFObV8bd4SDdRka5O+mSh5w9irgx5IetrD5i+OsUUsk/shsBoHifwCzy45SAORzAhtNiprUVaK3hSCCzZh1jQ==",
 | 
					      "integrity": "sha512-E1B35FwzXXTs9FHNK6bDszs7mtydNi5MIfUWpceJ8Xbfb1gBMscAnwLbEu+B44ed6W3XjL9/ehLPHR1fkf1KLQ==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
@@ -3552,13 +3527,13 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@vitest/utils": {
 | 
					    "node_modules/@vitest/utils": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-ixNkFy3k4vokOUTU2blIUvOgKq/N2PW8vKIjZZYsGJCMX69MRa9J2sKqX5hY/k5O5Gty3YJChepkqZ3KM9LyIQ==",
 | 
					      "integrity": "sha512-v0psaMSkNJ3A2NMrUEHFRzJtDPFn+/VWZ5WxImB21T9fjucJRmS7xCS3ppEnARb9y11OAzaD+P2Ps+b+BGX5iQ==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/pretty-format": "2.1.6",
 | 
					        "@vitest/pretty-format": "2.1.9",
 | 
				
			||||||
        "loupe": "^3.1.2",
 | 
					        "loupe": "^3.1.2",
 | 
				
			||||||
        "tinyrainbow": "^1.2.0"
 | 
					        "tinyrainbow": "^1.2.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
@@ -4153,6 +4128,27 @@
 | 
				
			|||||||
        "url": "https://github.com/sponsors/wooorm"
 | 
					        "url": "https://github.com/sponsors/wooorm"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "node_modules/chart.js": {
 | 
				
			||||||
 | 
					      "version": "4.4.7",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/chart.js/-/chart.js-4.4.7.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-pwkcKfdzTMAU/+jNosKhNL2bHtJc/sSmYgVbuGTEDhzkrhmyihmP7vUc/5ZK9WopidMDHNe3Wm7jOd/WhuHWuw==",
 | 
				
			||||||
 | 
					      "license": "MIT",
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "@kurkle/color": "^0.3.0"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "engines": {
 | 
				
			||||||
 | 
					        "pnpm": ">=8"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "node_modules/chartjs-plugin-datalabels": {
 | 
				
			||||||
 | 
					      "version": "2.2.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/chartjs-plugin-datalabels/-/chartjs-plugin-datalabels-2.2.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-14ZU30lH7n89oq+A4bWaJPnAG8a7ZTk7dKf48YAzMvJjQtjrgg5Dpk9f+LbjCF6bpx3RAGTeL13IXpKQYyRvlw==",
 | 
				
			||||||
 | 
					      "license": "MIT",
 | 
				
			||||||
 | 
					      "peerDependencies": {
 | 
				
			||||||
 | 
					        "chart.js": ">=3.0.0"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "node_modules/check-error": {
 | 
					    "node_modules/check-error": {
 | 
				
			||||||
      "version": "2.1.1",
 | 
					      "version": "2.1.1",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/check-error/-/check-error-2.1.1.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/check-error/-/check-error-2.1.1.tgz",
 | 
				
			||||||
@@ -4799,9 +4795,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/es-module-lexer": {
 | 
					    "node_modules/es-module-lexer": {
 | 
				
			||||||
      "version": "1.5.4",
 | 
					      "version": "1.6.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.4.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.6.0.tgz",
 | 
				
			||||||
      "integrity": "sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==",
 | 
					      "integrity": "sha512-qqnD1yMU6tk/jnaMosogGySTZP8YtUgAffA9nMN+E/rjxcfRQ6IEk7IiozUjgxKoFHBGjTLnrHB/YC45r/59EQ==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT"
 | 
					      "license": "MIT"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -4862,9 +4858,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/esbuild": {
 | 
					    "node_modules/esbuild": {
 | 
				
			||||||
      "version": "0.24.2",
 | 
					      "version": "0.21.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.24.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-+9egpBW8I3CD5XPe0n6BfT5fxLzxrlDzqydF3aviG+9ni1lDC/OvMHcxqEFV0+LANZG5R1bFMWfUrjVsdwxJvA==",
 | 
					      "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "hasInstallScript": true,
 | 
					      "hasInstallScript": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
@@ -4872,34 +4868,32 @@
 | 
				
			|||||||
        "esbuild": "bin/esbuild"
 | 
					        "esbuild": "bin/esbuild"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": ">=18"
 | 
					        "node": ">=12"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "optionalDependencies": {
 | 
					      "optionalDependencies": {
 | 
				
			||||||
        "@esbuild/aix-ppc64": "0.24.2",
 | 
					        "@esbuild/aix-ppc64": "0.21.5",
 | 
				
			||||||
        "@esbuild/android-arm": "0.24.2",
 | 
					        "@esbuild/android-arm": "0.21.5",
 | 
				
			||||||
        "@esbuild/android-arm64": "0.24.2",
 | 
					        "@esbuild/android-arm64": "0.21.5",
 | 
				
			||||||
        "@esbuild/android-x64": "0.24.2",
 | 
					        "@esbuild/android-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/darwin-arm64": "0.24.2",
 | 
					        "@esbuild/darwin-arm64": "0.21.5",
 | 
				
			||||||
        "@esbuild/darwin-x64": "0.24.2",
 | 
					        "@esbuild/darwin-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/freebsd-arm64": "0.24.2",
 | 
					        "@esbuild/freebsd-arm64": "0.21.5",
 | 
				
			||||||
        "@esbuild/freebsd-x64": "0.24.2",
 | 
					        "@esbuild/freebsd-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-arm": "0.24.2",
 | 
					        "@esbuild/linux-arm": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-arm64": "0.24.2",
 | 
					        "@esbuild/linux-arm64": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-ia32": "0.24.2",
 | 
					        "@esbuild/linux-ia32": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-loong64": "0.24.2",
 | 
					        "@esbuild/linux-loong64": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-mips64el": "0.24.2",
 | 
					        "@esbuild/linux-mips64el": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-ppc64": "0.24.2",
 | 
					        "@esbuild/linux-ppc64": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-riscv64": "0.24.2",
 | 
					        "@esbuild/linux-riscv64": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-s390x": "0.24.2",
 | 
					        "@esbuild/linux-s390x": "0.21.5",
 | 
				
			||||||
        "@esbuild/linux-x64": "0.24.2",
 | 
					        "@esbuild/linux-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/netbsd-arm64": "0.24.2",
 | 
					        "@esbuild/netbsd-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/netbsd-x64": "0.24.2",
 | 
					        "@esbuild/openbsd-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/openbsd-arm64": "0.24.2",
 | 
					        "@esbuild/sunos-x64": "0.21.5",
 | 
				
			||||||
        "@esbuild/openbsd-x64": "0.24.2",
 | 
					        "@esbuild/win32-arm64": "0.21.5",
 | 
				
			||||||
        "@esbuild/sunos-x64": "0.24.2",
 | 
					        "@esbuild/win32-ia32": "0.21.5",
 | 
				
			||||||
        "@esbuild/win32-arm64": "0.24.2",
 | 
					        "@esbuild/win32-x64": "0.21.5"
 | 
				
			||||||
        "@esbuild/win32-ia32": "0.24.2",
 | 
					 | 
				
			||||||
        "@esbuild/win32-x64": "0.24.2"
 | 
					 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/escalade": {
 | 
					    "node_modules/escalade": {
 | 
				
			||||||
@@ -6915,9 +6909,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/loupe": {
 | 
					    "node_modules/loupe": {
 | 
				
			||||||
      "version": "3.1.2",
 | 
					      "version": "3.1.3",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/loupe/-/loupe-3.1.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/loupe/-/loupe-3.1.3.tgz",
 | 
				
			||||||
      "integrity": "sha512-23I4pFZHmAemUnz8WZXbYRSKYj801VDaNv9ETuMh7IrMc7VuVVSo+Z9iLE3ni30+U48iDWfi30d3twAXBYmnCg==",
 | 
					      "integrity": "sha512-kkIp7XSkP78ZxJEsSxW3712C6teJVoeHHwgo9zJ380de7IYyJ2ISlxojcH2pC5OFLewESmnRi/+XCDIEEVyoug==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT"
 | 
					      "license": "MIT"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -6962,9 +6956,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/magic-string": {
 | 
					    "node_modules/magic-string": {
 | 
				
			||||||
      "version": "0.30.14",
 | 
					      "version": "0.30.17",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.14.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.17.tgz",
 | 
				
			||||||
      "integrity": "sha512-5c99P1WKTed11ZC0HMJOj6CDIue6F8ySu+bJL+85q1zBEIY8IklrJ1eiKC2NDRh3Ct3FcvmJPyQHb9erXMTJNw==",
 | 
					      "integrity": "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
@@ -8000,6 +7994,16 @@
 | 
				
			|||||||
        "node": ">=0.10.0"
 | 
					        "node": ">=0.10.0"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "node_modules/react-chartjs-2": {
 | 
				
			||||||
 | 
					      "version": "5.3.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/react-chartjs-2/-/react-chartjs-2-5.3.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-UfZZFnDsERI3c3CZGxzvNJd02SHjaSJ8kgW1djn65H1KK8rehwTjyrRKOG3VTMG8wtHZ5rgAO5oTHtHi9GCCmw==",
 | 
				
			||||||
 | 
					      "license": "MIT",
 | 
				
			||||||
 | 
					      "peerDependencies": {
 | 
				
			||||||
 | 
					        "chart.js": "^4.1.1",
 | 
				
			||||||
 | 
					        "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "node_modules/react-code-blocks": {
 | 
					    "node_modules/react-code-blocks": {
 | 
				
			||||||
      "version": "0.1.6",
 | 
					      "version": "0.1.6",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/react-code-blocks/-/react-code-blocks-0.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/react-code-blocks/-/react-code-blocks-0.1.6.tgz",
 | 
				
			||||||
@@ -9600,21 +9604,21 @@
 | 
				
			|||||||
      "license": "MIT"
 | 
					      "license": "MIT"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/vite": {
 | 
					    "node_modules/vite": {
 | 
				
			||||||
      "version": "6.0.11",
 | 
					      "version": "5.4.14",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vite/-/vite-6.0.11.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.14.tgz",
 | 
				
			||||||
      "integrity": "sha512-4VL9mQPKoHy4+FE0NnRE/kbY51TOfaknxAjt3fJbGJxhIpBZiqVzlZDEesWWsuREXHwNdAoOFZ9MkPEVXczHwg==",
 | 
					      "integrity": "sha512-EK5cY7Q1D8JNhSaPKVK4pwBFvaTmZxEnoKXLG/U9gmdDcihQGNzFlgIvaxezFR4glP1LsuiedwMBqCXH3wZccA==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "esbuild": "^0.24.2",
 | 
					        "esbuild": "^0.21.3",
 | 
				
			||||||
        "postcss": "^8.4.49",
 | 
					        "postcss": "^8.4.43",
 | 
				
			||||||
        "rollup": "^4.23.0"
 | 
					        "rollup": "^4.20.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "bin": {
 | 
					      "bin": {
 | 
				
			||||||
        "vite": "bin/vite.js"
 | 
					        "vite": "bin/vite.js"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
 | 
					        "node": "^18.0.0 || >=20.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "funding": {
 | 
					      "funding": {
 | 
				
			||||||
        "url": "https://github.com/vitejs/vite?sponsor=1"
 | 
					        "url": "https://github.com/vitejs/vite?sponsor=1"
 | 
				
			||||||
@@ -9623,25 +9627,19 @@
 | 
				
			|||||||
        "fsevents": "~2.3.3"
 | 
					        "fsevents": "~2.3.3"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "peerDependencies": {
 | 
					      "peerDependencies": {
 | 
				
			||||||
        "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0",
 | 
					        "@types/node": "^18.0.0 || >=20.0.0",
 | 
				
			||||||
        "jiti": ">=1.21.0",
 | 
					 | 
				
			||||||
        "less": "*",
 | 
					        "less": "*",
 | 
				
			||||||
        "lightningcss": "^1.21.0",
 | 
					        "lightningcss": "^1.21.0",
 | 
				
			||||||
        "sass": "*",
 | 
					        "sass": "*",
 | 
				
			||||||
        "sass-embedded": "*",
 | 
					        "sass-embedded": "*",
 | 
				
			||||||
        "stylus": "*",
 | 
					        "stylus": "*",
 | 
				
			||||||
        "sugarss": "*",
 | 
					        "sugarss": "*",
 | 
				
			||||||
        "terser": "^5.16.0",
 | 
					        "terser": "^5.4.0"
 | 
				
			||||||
        "tsx": "^4.8.1",
 | 
					 | 
				
			||||||
        "yaml": "^2.4.2"
 | 
					 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "peerDependenciesMeta": {
 | 
					      "peerDependenciesMeta": {
 | 
				
			||||||
        "@types/node": {
 | 
					        "@types/node": {
 | 
				
			||||||
          "optional": true
 | 
					          "optional": true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        "jiti": {
 | 
					 | 
				
			||||||
          "optional": true
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "less": {
 | 
					        "less": {
 | 
				
			||||||
          "optional": true
 | 
					          "optional": true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
@@ -9662,19 +9660,13 @@
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
        "terser": {
 | 
					        "terser": {
 | 
				
			||||||
          "optional": true
 | 
					          "optional": true
 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "tsx": {
 | 
					 | 
				
			||||||
          "optional": true
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "yaml": {
 | 
					 | 
				
			||||||
          "optional": true
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/vite-node": {
 | 
					    "node_modules/vite-node": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-DBfJY0n9JUwnyLxPSSUmEePT21j8JZp/sR9n+/gBwQU6DcQOioPdb8/pibWfXForbirSagZCilseYIwaL3f95A==",
 | 
					      "integrity": "sha512-AM9aQ/IPrW/6ENLQg3AGY4K1N2TGZdR5e4gu/MmmR2xR3Ll1+dib+nook92g4TV3PXVyeyxdWwtaCAiUL0hMxA==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
@@ -9682,13 +9674,13 @@
 | 
				
			|||||||
        "debug": "^4.3.7",
 | 
					        "debug": "^4.3.7",
 | 
				
			||||||
        "es-module-lexer": "^1.5.4",
 | 
					        "es-module-lexer": "^1.5.4",
 | 
				
			||||||
        "pathe": "^1.1.2",
 | 
					        "pathe": "^1.1.2",
 | 
				
			||||||
        "vite": "^5.0.0 || ^6.0.0"
 | 
					        "vite": "^5.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "bin": {
 | 
					      "bin": {
 | 
				
			||||||
        "vite-node": "vite-node.mjs"
 | 
					        "vite-node": "vite-node.mjs"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
 | 
					        "node": "^18.0.0 || >=20.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "funding": {
 | 
					      "funding": {
 | 
				
			||||||
        "url": "https://opencollective.com/vitest"
 | 
					        "url": "https://opencollective.com/vitest"
 | 
				
			||||||
@@ -9715,19 +9707,19 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/vitest": {
 | 
					    "node_modules/vitest": {
 | 
				
			||||||
      "version": "2.1.6",
 | 
					      "version": "2.1.9",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vitest/-/vitest-2.1.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/vitest/-/vitest-2.1.9.tgz",
 | 
				
			||||||
      "integrity": "sha512-isUCkvPL30J4c5O5hgONeFRsDmlw6kzFEdLQHLezmDdKQHy8Ke/B/dgdTMEgU0vm+iZ0TjW8GuK83DiahBoKWQ==",
 | 
					      "integrity": "sha512-MSmPM9REYqDGBI8439mA4mWhV5sKmDlBKWIYbA3lRb2PTHACE0mgKwA8yQ2xq9vxDTuk4iPrECBAEW2aoFXY0Q==",
 | 
				
			||||||
      "dev": true,
 | 
					      "dev": true,
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@vitest/expect": "2.1.6",
 | 
					        "@vitest/expect": "2.1.9",
 | 
				
			||||||
        "@vitest/mocker": "2.1.6",
 | 
					        "@vitest/mocker": "2.1.9",
 | 
				
			||||||
        "@vitest/pretty-format": "^2.1.6",
 | 
					        "@vitest/pretty-format": "^2.1.9",
 | 
				
			||||||
        "@vitest/runner": "2.1.6",
 | 
					        "@vitest/runner": "2.1.9",
 | 
				
			||||||
        "@vitest/snapshot": "2.1.6",
 | 
					        "@vitest/snapshot": "2.1.9",
 | 
				
			||||||
        "@vitest/spy": "2.1.6",
 | 
					        "@vitest/spy": "2.1.9",
 | 
				
			||||||
        "@vitest/utils": "2.1.6",
 | 
					        "@vitest/utils": "2.1.9",
 | 
				
			||||||
        "chai": "^5.1.2",
 | 
					        "chai": "^5.1.2",
 | 
				
			||||||
        "debug": "^4.3.7",
 | 
					        "debug": "^4.3.7",
 | 
				
			||||||
        "expect-type": "^1.1.0",
 | 
					        "expect-type": "^1.1.0",
 | 
				
			||||||
@@ -9738,24 +9730,24 @@
 | 
				
			|||||||
        "tinyexec": "^0.3.1",
 | 
					        "tinyexec": "^0.3.1",
 | 
				
			||||||
        "tinypool": "^1.0.1",
 | 
					        "tinypool": "^1.0.1",
 | 
				
			||||||
        "tinyrainbow": "^1.2.0",
 | 
					        "tinyrainbow": "^1.2.0",
 | 
				
			||||||
        "vite": "^5.0.0 || ^6.0.0",
 | 
					        "vite": "^5.0.0",
 | 
				
			||||||
        "vite-node": "2.1.6",
 | 
					        "vite-node": "2.1.9",
 | 
				
			||||||
        "why-is-node-running": "^2.3.0"
 | 
					        "why-is-node-running": "^2.3.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "bin": {
 | 
					      "bin": {
 | 
				
			||||||
        "vitest": "vitest.mjs"
 | 
					        "vitest": "vitest.mjs"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "engines": {
 | 
					      "engines": {
 | 
				
			||||||
        "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
 | 
					        "node": "^18.0.0 || >=20.0.0"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "funding": {
 | 
					      "funding": {
 | 
				
			||||||
        "url": "https://opencollective.com/vitest"
 | 
					        "url": "https://opencollective.com/vitest"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      "peerDependencies": {
 | 
					      "peerDependencies": {
 | 
				
			||||||
        "@edge-runtime/vm": "*",
 | 
					        "@edge-runtime/vm": "*",
 | 
				
			||||||
        "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0",
 | 
					        "@types/node": "^18.0.0 || >=20.0.0",
 | 
				
			||||||
        "@vitest/browser": "2.1.6",
 | 
					        "@vitest/browser": "2.1.9",
 | 
				
			||||||
        "@vitest/ui": "2.1.6",
 | 
					        "@vitest/ui": "2.1.9",
 | 
				
			||||||
        "happy-dom": "*",
 | 
					        "happy-dom": "*",
 | 
				
			||||||
        "jsdom": "*"
 | 
					        "jsdom": "*"
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,6 +34,8 @@
 | 
				
			|||||||
    "@radix-ui/react-tabs": "^1.1.0",
 | 
					    "@radix-ui/react-tabs": "^1.1.0",
 | 
				
			||||||
    "@radix-ui/react-tooltip": "^1.1.2",
 | 
					    "@radix-ui/react-tooltip": "^1.1.2",
 | 
				
			||||||
    "@vercel/analytics": "^1.2.2",
 | 
					    "@vercel/analytics": "^1.2.2",
 | 
				
			||||||
 | 
					    "chart.js": "^4.4.1",
 | 
				
			||||||
 | 
					    "chartjs-plugin-datalabels": "^2.2.0",
 | 
				
			||||||
    "class-variance-authority": "^0.7.0",
 | 
					    "class-variance-authority": "^0.7.0",
 | 
				
			||||||
    "clsx": "^2.1.1",
 | 
					    "clsx": "^2.1.1",
 | 
				
			||||||
    "cmdk": "^1.0.0",
 | 
					    "cmdk": "^1.0.0",
 | 
				
			||||||
@@ -48,6 +50,7 @@
 | 
				
			|||||||
    "pocketbase": "^0.21.4",
 | 
					    "pocketbase": "^0.21.4",
 | 
				
			||||||
    "prettier-plugin-organize-imports": "^4.1.0",
 | 
					    "prettier-plugin-organize-imports": "^4.1.0",
 | 
				
			||||||
    "react": "19.0.0-rc-02c0e824-20241028",
 | 
					    "react": "19.0.0-rc-02c0e824-20241028",
 | 
				
			||||||
 | 
					    "react-chartjs-2": "^5.3.0",
 | 
				
			||||||
    "react-code-blocks": "^0.1.6",
 | 
					    "react-code-blocks": "^0.1.6",
 | 
				
			||||||
    "react-datepicker": "^7.6.0",
 | 
					    "react-datepicker": "^7.6.0",
 | 
				
			||||||
    "react-day-picker": "8.10.1",
 | 
					    "react-day-picker": "8.10.1",
 | 
				
			||||||
@@ -64,23 +67,23 @@
 | 
				
			|||||||
    "@testing-library/dom": "^10.4.0",
 | 
					    "@testing-library/dom": "^10.4.0",
 | 
				
			||||||
    "@testing-library/react": "^16.0.1",
 | 
					    "@testing-library/react": "^16.0.1",
 | 
				
			||||||
    "@types/node": "^22",
 | 
					    "@types/node": "^22",
 | 
				
			||||||
    "@types/react-dom": "npm:types-react-dom@19.0.0-rc.1",
 | 
					 | 
				
			||||||
    "@types/react": "npm:types-react@19.0.0-rc.1",
 | 
					    "@types/react": "npm:types-react@19.0.0-rc.1",
 | 
				
			||||||
 | 
					    "@types/react-dom": "npm:types-react-dom@19.0.0-rc.1",
 | 
				
			||||||
    "@typescript-eslint/eslint-plugin": "^8.8.1",
 | 
					    "@typescript-eslint/eslint-plugin": "^8.8.1",
 | 
				
			||||||
    "@typescript-eslint/parser": "^8.8.1",
 | 
					    "@typescript-eslint/parser": "^8.8.1",
 | 
				
			||||||
    "@vitejs/plugin-react": "^4.3.4",
 | 
					    "@vitejs/plugin-react": "^4.3.4",
 | 
				
			||||||
    "eslint-config-next": "15.0.2",
 | 
					 | 
				
			||||||
    "eslint": "^9.13.0",
 | 
					    "eslint": "^9.13.0",
 | 
				
			||||||
 | 
					    "eslint-config-next": "15.0.2",
 | 
				
			||||||
    "jsdom": "^25.0.1",
 | 
					    "jsdom": "^25.0.1",
 | 
				
			||||||
    "postcss": "^8",
 | 
					    "postcss": "^8",
 | 
				
			||||||
    "prettier-plugin-tailwindcss": "^0.6.5",
 | 
					 | 
				
			||||||
    "prettier": "^3.2.5",
 | 
					    "prettier": "^3.2.5",
 | 
				
			||||||
 | 
					    "prettier-plugin-tailwindcss": "^0.6.5",
 | 
				
			||||||
 | 
					    "tailwindcss": "^3.4.9",
 | 
				
			||||||
    "tailwindcss-animate": "^1.0.7",
 | 
					    "tailwindcss-animate": "^1.0.7",
 | 
				
			||||||
    "tailwindcss-animated": "^1.1.2",
 | 
					    "tailwindcss-animated": "^1.1.2",
 | 
				
			||||||
    "tailwindcss": "^3.4.9",
 | 
					 | 
				
			||||||
    "typescript": "^5",
 | 
					    "typescript": "^5",
 | 
				
			||||||
    "vite-tsconfig-paths": "^5.1.3",
 | 
					    "vite-tsconfig-paths": "^5.1.3",
 | 
				
			||||||
    "vitest": "^2.1.6"
 | 
					    "vitest": "^2.1.9"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "overrides": {
 | 
					  "overrides": {
 | 
				
			||||||
    "@types/react": "npm:types-react@19.0.0-rc.1",
 | 
					    "@types/react": "npm:types-react@19.0.0-rc.1",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,8 +3,7 @@
 | 
				
			|||||||
import React, { useEffect, useState } from "react";
 | 
					import React, { useEffect, useState } from "react";
 | 
				
			||||||
import DatePicker from 'react-datepicker';
 | 
					import DatePicker from 'react-datepicker';
 | 
				
			||||||
import 'react-datepicker/dist/react-datepicker.css';
 | 
					import 'react-datepicker/dist/react-datepicker.css';
 | 
				
			||||||
import { string } from "zod";
 | 
					import ApplicationChart from "../../components/ApplicationChart";
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
interface DataModel {
 | 
					interface DataModel {
 | 
				
			||||||
  id: number;
 | 
					  id: number;
 | 
				
			||||||
@@ -12,17 +11,16 @@ interface DataModel {
 | 
				
			|||||||
  disk_size: number;
 | 
					  disk_size: number;
 | 
				
			||||||
  core_count: number;
 | 
					  core_count: number;
 | 
				
			||||||
  ram_size: number;
 | 
					  ram_size: number;
 | 
				
			||||||
  verbose: string;
 | 
					 | 
				
			||||||
  os_type: string;
 | 
					  os_type: string;
 | 
				
			||||||
  os_version: string;
 | 
					  os_version: string;
 | 
				
			||||||
  hn: string;
 | 
					 | 
				
			||||||
  disableip6: string;
 | 
					  disableip6: string;
 | 
				
			||||||
  ssh: string;
 | 
					 | 
				
			||||||
  tags: string;
 | 
					 | 
				
			||||||
  nsapp: string;
 | 
					  nsapp: string;
 | 
				
			||||||
  created_at: string;
 | 
					  created_at: string;
 | 
				
			||||||
  method: string;
 | 
					  method: string;
 | 
				
			||||||
  pve_version: string;
 | 
					  pve_version: string;
 | 
				
			||||||
 | 
					  status: string;
 | 
				
			||||||
 | 
					  error: string;
 | 
				
			||||||
 | 
					  type: string;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -34,9 +32,12 @@ const DataFetcher: React.FC = () => {
 | 
				
			|||||||
  const [startDate, setStartDate] = useState<Date | null>(null);
 | 
					  const [startDate, setStartDate] = useState<Date | null>(null);
 | 
				
			||||||
  const [endDate, setEndDate] = useState<Date | null>(null);
 | 
					  const [endDate, setEndDate] = useState<Date | null>(null);
 | 
				
			||||||
  const [sortConfig, setSortConfig] = useState<{ key: keyof DataModel | null, direction: 'ascending' | 'descending' }>({ key: 'id', direction: 'descending' });
 | 
					  const [sortConfig, setSortConfig] = useState<{ key: keyof DataModel | null, direction: 'ascending' | 'descending' }>({ key: 'id', direction: 'descending' });
 | 
				
			||||||
  const [itemsPerPage, setItemsPerPage] = useState(5);
 | 
					  const [itemsPerPage, setItemsPerPage] = useState(25);
 | 
				
			||||||
  const [currentPage, setCurrentPage] = useState(1);
 | 
					  const [currentPage, setCurrentPage] = useState(1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const [showErrorRow, setShowErrorRow] = useState<number | null>(null);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  useEffect(() => {
 | 
					  useEffect(() => {
 | 
				
			||||||
    const fetchData = async () => {
 | 
					    const fetchData = async () => {
 | 
				
			||||||
      try {
 | 
					      try {
 | 
				
			||||||
@@ -115,9 +116,27 @@ const DataFetcher: React.FC = () => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  const paginatedData = sortedData.slice((currentPage - 1) * itemsPerPage, currentPage * itemsPerPage);
 | 
					  const paginatedData = sortedData.slice((currentPage - 1) * itemsPerPage, currentPage * itemsPerPage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (loading) return <p>Loading...</p>;
 | 
					  if (loading) return <p>Loading...</p>;
 | 
				
			||||||
  if (error) return <p>Error: {error}</p>;
 | 
					  if (error) return <p>Error: {error}</p>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  var installingCounts: number = 0;
 | 
				
			||||||
 | 
					  var failedCounts: number = 0;
 | 
				
			||||||
 | 
					  var doneCounts: number = 0
 | 
				
			||||||
 | 
					  var unknownCounts: number = 0;
 | 
				
			||||||
 | 
					  data.forEach((item) => {
 | 
				
			||||||
 | 
					    if (item.status === "installing") {
 | 
				
			||||||
 | 
					      installingCounts += 1;
 | 
				
			||||||
 | 
					    } else if (item.status === "failed") {
 | 
				
			||||||
 | 
					      failedCounts += 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    else if (item.status === "done") {
 | 
				
			||||||
 | 
					      doneCounts += 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    else {
 | 
				
			||||||
 | 
					      unknownCounts += 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return (
 | 
					  return (
 | 
				
			||||||
    <div className="p-6 mt-20">
 | 
					    <div className="p-6 mt-20">
 | 
				
			||||||
@@ -159,13 +178,15 @@ const DataFetcher: React.FC = () => {
 | 
				
			|||||||
          <label className="text-sm text-gray-600 mt-1 block">Set a end date</label>
 | 
					          <label className="text-sm text-gray-600 mt-1 block">Set a end date</label>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					      <ApplicationChart data={filteredData} />
 | 
				
			||||||
      <div className="mb-4 flex justify-between items-center">
 | 
					      <div className="mb-4 flex justify-between items-center">
 | 
				
			||||||
        <p className="text-lg font-bold">{filteredData.length} results found</p>
 | 
					        <p className="text-lg font-bold">{filteredData.length} results found</p>
 | 
				
			||||||
 | 
					        <p className="text-lg font">Status Legend: 🔄 installing {installingCounts} | ✔️ completetd {doneCounts} | ❌ failed {failedCounts} | ❓ unknown {unknownCounts}</p>
 | 
				
			||||||
        <select value={itemsPerPage} onChange={handleItemsPerPageChange} className="p-2 border">
 | 
					        <select value={itemsPerPage} onChange={handleItemsPerPageChange} className="p-2 border">
 | 
				
			||||||
          <option value={5}>5</option>
 | 
					          <option value={25}>25</option>
 | 
				
			||||||
          <option value={10}>10</option>
 | 
					 | 
				
			||||||
          <option value={20}>20</option>
 | 
					 | 
				
			||||||
          <option value={50}>50</option>
 | 
					          <option value={50}>50</option>
 | 
				
			||||||
 | 
					          <option value={100}>100</option>
 | 
				
			||||||
 | 
					          <option value={200}>200</option>
 | 
				
			||||||
        </select>
 | 
					        </select>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div className="overflow-x-auto">
 | 
					      <div className="overflow-x-auto">
 | 
				
			||||||
@@ -173,36 +194,63 @@ const DataFetcher: React.FC = () => {
 | 
				
			|||||||
          <table className="min-w-full table-auto border-collapse">
 | 
					          <table className="min-w-full table-auto border-collapse">
 | 
				
			||||||
            <thead>
 | 
					            <thead>
 | 
				
			||||||
              <tr>
 | 
					              <tr>
 | 
				
			||||||
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('status')}>Status</th>
 | 
				
			||||||
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('type')}>Type</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('nsapp')}>Application</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('nsapp')}>Application</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('os_type')}>OS</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('os_type')}>OS</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('os_version')}>OS Version</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('os_version')}>OS Version</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('disk_size')}>Disk Size</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('disk_size')}>Disk Size</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('core_count')}>Core Count</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('core_count')}>Core Count</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('ram_size')}>RAM Size</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('ram_size')}>RAM Size</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('hn')}>Hostname</th>
 | 
					 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('ssh')}>SSH</th>
 | 
					 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('verbose')}>Verb</th>
 | 
					 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('tags')}>Tags</th>
 | 
					 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('method')}>Method</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('method')}>Method</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('pve_version')}>PVE Version</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('pve_version')}>PVE Version</th>
 | 
				
			||||||
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('error')}>Error Message</th>
 | 
				
			||||||
                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('created_at')}>Created At</th>
 | 
					                <th className="px-4 py-2 border-b cursor-pointer" onClick={() => requestSort('created_at')}>Created At</th>
 | 
				
			||||||
              </tr>
 | 
					              </tr>
 | 
				
			||||||
            </thead>
 | 
					            </thead>
 | 
				
			||||||
            <tbody>
 | 
					            <tbody>
 | 
				
			||||||
              {paginatedData.map((item, index) => (
 | 
					              {paginatedData.map((item, index) => (
 | 
				
			||||||
                <tr key={index}>
 | 
					                <tr key={index}>
 | 
				
			||||||
 | 
					                  <td className="px-4 py-2 border-b">
 | 
				
			||||||
 | 
					                    {item.status === "done" ? (
 | 
				
			||||||
 | 
					                      "✔️"
 | 
				
			||||||
 | 
					                    ) : item.status === "failed" ? (
 | 
				
			||||||
 | 
					                      "❌"
 | 
				
			||||||
 | 
					                    ) : item.status === "installing" ? (
 | 
				
			||||||
 | 
					                      "🔄"
 | 
				
			||||||
 | 
					                    ) : (
 | 
				
			||||||
 | 
					                      item.status
 | 
				
			||||||
 | 
					                    )}
 | 
				
			||||||
 | 
					                  </td>
 | 
				
			||||||
 | 
					                  <td className="px-4 py-2 border-b">{item.type === "lxc" ? (
 | 
				
			||||||
 | 
					                    "📦"
 | 
				
			||||||
 | 
					                  ) : item.type === "vm" ? (
 | 
				
			||||||
 | 
					                    "🖥️"
 | 
				
			||||||
 | 
					                  ) : (
 | 
				
			||||||
 | 
					                    item.type
 | 
				
			||||||
 | 
					                  )}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.nsapp}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.nsapp}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.os_type}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.os_type}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.os_version}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.os_version}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.disk_size}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.disk_size}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.core_count}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.core_count}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.ram_size}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.ram_size}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.hn}</td>
 | 
					 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.ssh}</td>
 | 
					 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.verbose}</td>
 | 
					 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.tags.replace(/;/g, ' ')}</td>
 | 
					 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.method}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.method}</td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{item.pve_version}</td>
 | 
					                  <td className="px-4 py-2 border-b">{item.pve_version}</td>
 | 
				
			||||||
 | 
					                  <td className="px-4 py-2 border-b">
 | 
				
			||||||
 | 
					                    {item.error && item.error !== "none" ? (
 | 
				
			||||||
 | 
					                      showErrorRow === index ? (
 | 
				
			||||||
 | 
					                        <>
 | 
				
			||||||
 | 
					                          {item.error}
 | 
				
			||||||
 | 
					                          <button onClick={() => setShowErrorRow(null)}>{item.error}</button>
 | 
				
			||||||
 | 
					                        </>
 | 
				
			||||||
 | 
					                      ) : (
 | 
				
			||||||
 | 
					                        <button onClick={() => setShowErrorRow(index)}>Click to show error</button>
 | 
				
			||||||
 | 
					                      )
 | 
				
			||||||
 | 
					                    ) : (
 | 
				
			||||||
 | 
					                      "none"
 | 
				
			||||||
 | 
					                    )}
 | 
				
			||||||
 | 
					                  </td>
 | 
				
			||||||
                  <td className="px-4 py-2 border-b">{formatDate(item.created_at)}</td>
 | 
					                  <td className="px-4 py-2 border-b">{formatDate(item.created_at)}</td>
 | 
				
			||||||
                </tr>
 | 
					                </tr>
 | 
				
			||||||
              ))}
 | 
					              ))}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -23,7 +23,7 @@ import { fetchCategories } from "@/lib/data";
 | 
				
			|||||||
import { Category } from "@/lib/types";
 | 
					import { Category } from "@/lib/types";
 | 
				
			||||||
import { cn } from "@/lib/utils";
 | 
					import { cn } from "@/lib/utils";
 | 
				
			||||||
import { format } from "date-fns";
 | 
					import { format } from "date-fns";
 | 
				
			||||||
import { CalendarIcon, Check, Clipboard } from "lucide-react";
 | 
					import { CalendarIcon, Check, Clipboard, Download } from "lucide-react";
 | 
				
			||||||
import { useCallback, useEffect, useMemo, useState } from "react";
 | 
					import { useCallback, useEffect, useMemo, useState } from "react";
 | 
				
			||||||
import { toast } from "sonner";
 | 
					import { toast } from "sonner";
 | 
				
			||||||
import { z } from "zod";
 | 
					import { z } from "zod";
 | 
				
			||||||
@@ -97,6 +97,21 @@ export default function JSONGenerator() {
 | 
				
			|||||||
    toast.success("Copied metadata to clipboard");
 | 
					    toast.success("Copied metadata to clipboard");
 | 
				
			||||||
  }, [script]);
 | 
					  }, [script]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const handleDownload = useCallback(() => {
 | 
				
			||||||
 | 
					    const jsonString = JSON.stringify(script, null, 2);
 | 
				
			||||||
 | 
					    const blob = new Blob([jsonString], { type: "application/json" });
 | 
				
			||||||
 | 
					    const url = URL.createObjectURL(blob);
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					    const a = document.createElement("a");
 | 
				
			||||||
 | 
					    a.href = url;
 | 
				
			||||||
 | 
					    a.download = `${script.slug || "script"}.json`;
 | 
				
			||||||
 | 
					    document.body.appendChild(a);
 | 
				
			||||||
 | 
					    a.click();
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					    URL.revokeObjectURL(url);
 | 
				
			||||||
 | 
					    document.body.removeChild(a);
 | 
				
			||||||
 | 
					  }, [script]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const handleDateSelect = useCallback(
 | 
					  const handleDateSelect = useCallback(
 | 
				
			||||||
    (date: Date | undefined) => {
 | 
					    (date: Date | undefined) => {
 | 
				
			||||||
      updateScript("date_created", format(date || new Date(), "yyyy-MM-dd"));
 | 
					      updateScript("date_created", format(date || new Date(), "yyyy-MM-dd"));
 | 
				
			||||||
@@ -313,18 +328,23 @@ export default function JSONGenerator() {
 | 
				
			|||||||
      <div className="w-1/2 p-4 bg-background overflow-y-auto">
 | 
					      <div className="w-1/2 p-4 bg-background overflow-y-auto">
 | 
				
			||||||
        {validationAlert}
 | 
					        {validationAlert}
 | 
				
			||||||
        <div className="relative">
 | 
					        <div className="relative">
 | 
				
			||||||
          <Button
 | 
					          <div className="absolute right-2 top-2 flex gap-1">
 | 
				
			||||||
            className="absolute right-2 top-2"
 | 
					            <Button
 | 
				
			||||||
            size="icon"
 | 
					              size="icon"
 | 
				
			||||||
            variant="outline"
 | 
					              variant="outline"
 | 
				
			||||||
            onClick={handleCopy}
 | 
					              onClick={handleCopy}
 | 
				
			||||||
          >
 | 
					            >
 | 
				
			||||||
            {isCopied ? (
 | 
					              {isCopied ? <Check className="h-4 w-4" /> : <Clipboard className="h-4 w-4" />}
 | 
				
			||||||
              <Check className="h-4 w-4" />
 | 
					            </Button>
 | 
				
			||||||
            ) : (
 | 
					            <Button
 | 
				
			||||||
              <Clipboard className="h-4 w-4" />
 | 
					              size="icon"
 | 
				
			||||||
            )}
 | 
					              variant="outline"
 | 
				
			||||||
          </Button>
 | 
					              onClick={handleDownload}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              <Download className="h-4 w-4" />
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
          <pre className="mt-4 p-4 bg-secondary rounded shadow overflow-x-scroll">
 | 
					          <pre className="mt-4 p-4 bg-secondary rounded shadow overflow-x-scroll">
 | 
				
			||||||
            {JSON.stringify(script, null, 2)}
 | 
					            {JSON.stringify(script, null, 2)}
 | 
				
			||||||
          </pre>
 | 
					          </pre>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										193
									
								
								frontend/src/components/ApplicationChart.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										193
									
								
								frontend/src/components/ApplicationChart.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,193 @@
 | 
				
			|||||||
 | 
					"use client";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import { Button } from "@/components/ui/button";
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  Dialog,
 | 
				
			||||||
 | 
					  DialogContent,
 | 
				
			||||||
 | 
					  DialogHeader,
 | 
				
			||||||
 | 
					  DialogTitle,
 | 
				
			||||||
 | 
					} from "@/components/ui/dialog";
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  Table,
 | 
				
			||||||
 | 
					  TableBody,
 | 
				
			||||||
 | 
					  TableCell,
 | 
				
			||||||
 | 
					  TableHead,
 | 
				
			||||||
 | 
					  TableHeader,
 | 
				
			||||||
 | 
					  TableRow,
 | 
				
			||||||
 | 
					} from "@/components/ui/table";
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  Tooltip,
 | 
				
			||||||
 | 
					  TooltipContent,
 | 
				
			||||||
 | 
					  TooltipProvider,
 | 
				
			||||||
 | 
					  TooltipTrigger,
 | 
				
			||||||
 | 
					} from "@/components/ui/tooltip";
 | 
				
			||||||
 | 
					import { Chart as ChartJS, ArcElement, Tooltip as ChartTooltip, Legend } from "chart.js";
 | 
				
			||||||
 | 
					import ChartDataLabels from "chartjs-plugin-datalabels";
 | 
				
			||||||
 | 
					import { BarChart3, PieChart } from "lucide-react";
 | 
				
			||||||
 | 
					import React, { useState } from "react";
 | 
				
			||||||
 | 
					import { Pie } from "react-chartjs-2";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ChartJS.register(ArcElement, ChartTooltip, Legend, ChartDataLabels);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface ApplicationChartProps {
 | 
				
			||||||
 | 
					  data: { nsapp: string }[];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const ITEMS_PER_PAGE = 20;
 | 
				
			||||||
 | 
					const CHART_COLORS = [
 | 
				
			||||||
 | 
					  "#ff6384",
 | 
				
			||||||
 | 
					  "#36a2eb",
 | 
				
			||||||
 | 
					  "#ffce56",
 | 
				
			||||||
 | 
					  "#4bc0c0",
 | 
				
			||||||
 | 
					  "#9966ff",
 | 
				
			||||||
 | 
					  "#ff9f40",
 | 
				
			||||||
 | 
					  "#4dc9f6",
 | 
				
			||||||
 | 
					  "#f67019",
 | 
				
			||||||
 | 
					  "#537bc4",
 | 
				
			||||||
 | 
					  "#acc236",
 | 
				
			||||||
 | 
					  "#166a8f",
 | 
				
			||||||
 | 
					  "#00a950",
 | 
				
			||||||
 | 
					  "#58595b",
 | 
				
			||||||
 | 
					  "#8549ba",
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default function ApplicationChart({ data }: ApplicationChartProps) {
 | 
				
			||||||
 | 
					  const [isChartOpen, setIsChartOpen] = useState(false);
 | 
				
			||||||
 | 
					  const [isTableOpen, setIsTableOpen] = useState(false);
 | 
				
			||||||
 | 
					  const [chartStartIndex, setChartStartIndex] = useState(0);
 | 
				
			||||||
 | 
					  const [tableLimit, setTableLimit] = useState(ITEMS_PER_PAGE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // Calculate application counts
 | 
				
			||||||
 | 
					  const appCounts = data.reduce((acc, item) => {
 | 
				
			||||||
 | 
					    acc[item.nsapp] = (acc[item.nsapp] || 0) + 1;
 | 
				
			||||||
 | 
					    return acc;
 | 
				
			||||||
 | 
					  }, {} as Record<string, number>);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const sortedApps = Object.entries(appCounts)
 | 
				
			||||||
 | 
					    .sort(([, a], [, b]) => b - a);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const chartApps = sortedApps.slice(
 | 
				
			||||||
 | 
					    chartStartIndex,
 | 
				
			||||||
 | 
					    chartStartIndex + ITEMS_PER_PAGE
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const chartData = {
 | 
				
			||||||
 | 
					    labels: chartApps.map(([name]) => name),
 | 
				
			||||||
 | 
					    datasets: [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        data: chartApps.map(([, count]) => count),
 | 
				
			||||||
 | 
					        backgroundColor: CHART_COLORS,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ],
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const chartOptions = {
 | 
				
			||||||
 | 
					    plugins: {
 | 
				
			||||||
 | 
					      legend: { display: false },
 | 
				
			||||||
 | 
					      datalabels: {
 | 
				
			||||||
 | 
					        color: "white",
 | 
				
			||||||
 | 
					        font: { weight: "bold" as const },
 | 
				
			||||||
 | 
					        formatter: (value: number, context: any) => {
 | 
				
			||||||
 | 
					          const label = context.chart.data.labels?.[context.dataIndex];
 | 
				
			||||||
 | 
					          return `${label}\n(${value})`;
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    responsive: true,
 | 
				
			||||||
 | 
					    maintainAspectRatio: false,
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return (
 | 
				
			||||||
 | 
					    <div className="mt-6 flex justify-center gap-4">
 | 
				
			||||||
 | 
					      <TooltipProvider>
 | 
				
			||||||
 | 
					        <Tooltip>
 | 
				
			||||||
 | 
					          <TooltipTrigger asChild>
 | 
				
			||||||
 | 
					            <Button
 | 
				
			||||||
 | 
					              variant="outline"
 | 
				
			||||||
 | 
					              size="icon"
 | 
				
			||||||
 | 
					              onClick={() => setIsChartOpen(true)}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              <PieChart className="h-5 w-5" />
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					          </TooltipTrigger>
 | 
				
			||||||
 | 
					          <TooltipContent>Open Chart View</TooltipContent>
 | 
				
			||||||
 | 
					        </Tooltip>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <Tooltip>
 | 
				
			||||||
 | 
					          <TooltipTrigger asChild>
 | 
				
			||||||
 | 
					            <Button
 | 
				
			||||||
 | 
					              variant="outline"
 | 
				
			||||||
 | 
					              size="icon"
 | 
				
			||||||
 | 
					              onClick={() => setIsTableOpen(true)}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              <BarChart3 className="h-5 w-5" />
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					          </TooltipTrigger>
 | 
				
			||||||
 | 
					          <TooltipContent>Open Table View</TooltipContent>
 | 
				
			||||||
 | 
					        </Tooltip>
 | 
				
			||||||
 | 
					      </TooltipProvider>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <Dialog open={isChartOpen} onOpenChange={setIsChartOpen}>
 | 
				
			||||||
 | 
					        <DialogContent className="max-w-3xl">
 | 
				
			||||||
 | 
					          <DialogHeader>
 | 
				
			||||||
 | 
					            <DialogTitle>Applications Distribution</DialogTitle>
 | 
				
			||||||
 | 
					          </DialogHeader>
 | 
				
			||||||
 | 
					          <div className="h-[60vh] w-full">
 | 
				
			||||||
 | 
					            <Pie data={chartData} options={chartOptions} />
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div className="flex justify-center gap-4">
 | 
				
			||||||
 | 
					            <Button
 | 
				
			||||||
 | 
					              variant="outline"
 | 
				
			||||||
 | 
					              onClick={() => setChartStartIndex(Math.max(0, chartStartIndex - ITEMS_PER_PAGE))}
 | 
				
			||||||
 | 
					              disabled={chartStartIndex === 0}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              Previous {ITEMS_PER_PAGE}
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					            <Button
 | 
				
			||||||
 | 
					              variant="outline"
 | 
				
			||||||
 | 
					              onClick={() => setChartStartIndex(chartStartIndex + ITEMS_PER_PAGE)}
 | 
				
			||||||
 | 
					              disabled={chartStartIndex + ITEMS_PER_PAGE >= sortedApps.length}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              Next {ITEMS_PER_PAGE}
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </DialogContent>
 | 
				
			||||||
 | 
					      </Dialog>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      <Dialog open={isTableOpen} onOpenChange={setIsTableOpen}>
 | 
				
			||||||
 | 
					        <DialogContent className="max-w-2xl">
 | 
				
			||||||
 | 
					          <DialogHeader>
 | 
				
			||||||
 | 
					            <DialogTitle>Applications Count</DialogTitle>
 | 
				
			||||||
 | 
					          </DialogHeader>
 | 
				
			||||||
 | 
					          <div className="max-h-[60vh] overflow-y-auto">
 | 
				
			||||||
 | 
					            <Table>
 | 
				
			||||||
 | 
					              <TableHeader>
 | 
				
			||||||
 | 
					                <TableRow>
 | 
				
			||||||
 | 
					                  <TableHead>Application</TableHead>
 | 
				
			||||||
 | 
					                  <TableHead className="text-right">Count</TableHead>
 | 
				
			||||||
 | 
					                </TableRow>
 | 
				
			||||||
 | 
					              </TableHeader>
 | 
				
			||||||
 | 
					              <TableBody>
 | 
				
			||||||
 | 
					                {sortedApps.slice(0, tableLimit).map(([name, count]) => (
 | 
				
			||||||
 | 
					                  <TableRow key={name}>
 | 
				
			||||||
 | 
					                    <TableCell>{name}</TableCell>
 | 
				
			||||||
 | 
					                    <TableCell className="text-right">{count}</TableCell>
 | 
				
			||||||
 | 
					                  </TableRow>
 | 
				
			||||||
 | 
					                ))}
 | 
				
			||||||
 | 
					              </TableBody>
 | 
				
			||||||
 | 
					            </Table>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          {tableLimit < sortedApps.length && (
 | 
				
			||||||
 | 
					            <Button
 | 
				
			||||||
 | 
					              variant="outline"
 | 
				
			||||||
 | 
					              className="w-full"
 | 
				
			||||||
 | 
					              onClick={() => setTableLimit(prev => prev + ITEMS_PER_PAGE)}
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              Load More
 | 
				
			||||||
 | 
					            </Button>
 | 
				
			||||||
 | 
					          )}
 | 
				
			||||||
 | 
					        </DialogContent>
 | 
				
			||||||
 | 
					      </Dialog>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,22 +1,41 @@
 | 
				
			|||||||
import { basePath } from "@/config/siteConfig";
 | 
					import { basePath } from "@/config/siteConfig";
 | 
				
			||||||
import Link from "next/link";
 | 
					import Link from "next/link";
 | 
				
			||||||
 | 
					import { FileJson, Server, ExternalLink } from "lucide-react";
 | 
				
			||||||
 | 
					import { buttonVariants } from "./ui/button";
 | 
				
			||||||
 | 
					import { cn } from "@/lib/utils";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default function Footer() {
 | 
					export default function Footer() {
 | 
				
			||||||
  return (
 | 
					  return (
 | 
				
			||||||
    <div className="supports-backdrop-blur:bg-background/90 mt-auto flex border-t border-border bg-background/40 py-6 backdrop-blur-lg">
 | 
					    <div className="supports-backdrop-blur:bg-background/90 mt-auto border-t w-full flex justify-between border-border bg-background/40 py-6 backdrop-blur-lg">
 | 
				
			||||||
      <div className="flex w-full justify-between">
 | 
					      <div className="mx-6 w-full flex justify-between text-xs sm:text-sm text-muted-foreground">
 | 
				
			||||||
        <div className="mx-6 w-full max-w-7xl text-xs sm:text-sm text-muted-foreground">
 | 
					        <div className="flex items-center">
 | 
				
			||||||
          Website built by the community. The source code is avaliable on{" "}
 | 
					          <p>
 | 
				
			||||||
 | 
					            Website built by the community. The source code is available on{" "}
 | 
				
			||||||
 | 
					            <Link
 | 
				
			||||||
 | 
					              href={`https://github.com/community-scripts/${basePath}`}
 | 
				
			||||||
 | 
					              target="_blank"
 | 
				
			||||||
 | 
					              rel="noreferrer"
 | 
				
			||||||
 | 
					              className="font-semibold underline-offset-2 duration-300 hover:underline"
 | 
				
			||||||
 | 
					              data-umami-event="View Website Source Code on Github"
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              GitHub
 | 
				
			||||||
 | 
					            </Link>
 | 
				
			||||||
 | 
					            .
 | 
				
			||||||
 | 
					          </p>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					        <div className="sm:flex hidden">
 | 
				
			||||||
          <Link
 | 
					          <Link
 | 
				
			||||||
            href={`https://github.com/community-scripts/${basePath}`}
 | 
					            href="/json-editor"
 | 
				
			||||||
            target="_blank"
 | 
					            className={cn(buttonVariants({ variant: "link" }), "text-muted-foreground flex items-center gap-2")}
 | 
				
			||||||
            rel="noreferrer"
 | 
					 | 
				
			||||||
            className="font-semibold underline-offset-2 duration-300 hover:underline"
 | 
					 | 
				
			||||||
            data-umami-event="View Website Source Code on Github"
 | 
					 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            GitHub
 | 
					            <FileJson className="h-4 w-4" /> JSON Editor
 | 
				
			||||||
 | 
					          </Link>
 | 
				
			||||||
 | 
					          <Link
 | 
				
			||||||
 | 
					            href="/data"
 | 
				
			||||||
 | 
					            className={cn(buttonVariants({ variant: "link" }), "text-muted-foreground flex items-center gap-2")}
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <Server className="h-4 w-4" /> API Data
 | 
				
			||||||
          </Link>
 | 
					          </Link>
 | 
				
			||||||
          .
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										29
									
								
								frontend/src/components/Modal.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								frontend/src/components/Modal.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
				
			|||||||
 | 
					"use client";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import React from "react";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface ModalProps {
 | 
				
			||||||
 | 
					  isOpen: boolean;
 | 
				
			||||||
 | 
					  onClose: () => void;
 | 
				
			||||||
 | 
					  children: React.ReactNode;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const Modal: React.FC<ModalProps> = ({ isOpen, onClose, children }) => {
 | 
				
			||||||
 | 
					  if (!isOpen) return null;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return (
 | 
				
			||||||
 | 
					    <div className="fixed inset-0 bg-black bg-opacity-50 flex justify-center items-center z-50">
 | 
				
			||||||
 | 
					      <div className="bg-white dark:bg-gray-900 p-6 rounded-lg shadow-lg w-11/12 max-w-4xl relative max-h-[90vh] overflow-y-auto">
 | 
				
			||||||
 | 
					        <button
 | 
				
			||||||
 | 
					          onClick={onClose}
 | 
				
			||||||
 | 
					          className="absolute top-2 right-2 bg-red-500 text-white p-1 rounded"
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          ✖
 | 
				
			||||||
 | 
					        </button>
 | 
				
			||||||
 | 
					        {children}
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default Modal;
 | 
				
			||||||
@@ -15,7 +15,7 @@ const Command = React.forwardRef<
 | 
				
			|||||||
  <CommandPrimitive
 | 
					  <CommandPrimitive
 | 
				
			||||||
    ref={ref}
 | 
					    ref={ref}
 | 
				
			||||||
    className={cn(
 | 
					    className={cn(
 | 
				
			||||||
      "flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",
 | 
					      "flex h-full w-full flex-col overflow-hidden bg-popover text-popover-foreground",
 | 
				
			||||||
      className,
 | 
					      className,
 | 
				
			||||||
    )}
 | 
					    )}
 | 
				
			||||||
    {...props}
 | 
					    {...props}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										120
									
								
								frontend/src/components/ui/table.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								frontend/src/components/ui/table.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,120 @@
 | 
				
			|||||||
 | 
					import * as React from "react"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import { cn } from "@/lib/utils"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const Table = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <div className="relative w-full overflow-auto">
 | 
				
			||||||
 | 
					    <table
 | 
				
			||||||
 | 
					      ref={ref}
 | 
				
			||||||
 | 
					      className={cn("w-full caption-bottom text-sm", className)}
 | 
				
			||||||
 | 
					      {...props}
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					Table.displayName = "Table"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableHeader = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableSectionElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableSectionElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <thead ref={ref} className={cn("[&_tr]:border-b", className)} {...props} />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableHeader.displayName = "TableHeader"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableBody = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableSectionElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableSectionElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <tbody
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn("[&_tr:last-child]:border-0", className)}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableBody.displayName = "TableBody"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableFooter = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableSectionElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableSectionElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <tfoot
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn(
 | 
				
			||||||
 | 
					      "border-t bg-muted/50 font-medium [&>tr]:last:border-b-0",
 | 
				
			||||||
 | 
					      className
 | 
				
			||||||
 | 
					    )}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableFooter.displayName = "TableFooter"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableRow = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableRowElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableRowElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <tr
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn(
 | 
				
			||||||
 | 
					      "border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted",
 | 
				
			||||||
 | 
					      className
 | 
				
			||||||
 | 
					    )}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableRow.displayName = "TableRow"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableHead = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableCellElement,
 | 
				
			||||||
 | 
					  React.ThHTMLAttributes<HTMLTableCellElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <th
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn(
 | 
				
			||||||
 | 
					      "h-10 px-2 text-left align-middle font-medium text-muted-foreground [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",
 | 
				
			||||||
 | 
					      className
 | 
				
			||||||
 | 
					    )}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableHead.displayName = "TableHead"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableCell = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableCellElement,
 | 
				
			||||||
 | 
					  React.TdHTMLAttributes<HTMLTableCellElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <td
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn(
 | 
				
			||||||
 | 
					      "p-2 align-middle [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",
 | 
				
			||||||
 | 
					      className
 | 
				
			||||||
 | 
					    )}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableCell.displayName = "TableCell"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const TableCaption = React.forwardRef<
 | 
				
			||||||
 | 
					  HTMLTableCaptionElement,
 | 
				
			||||||
 | 
					  React.HTMLAttributes<HTMLTableCaptionElement>
 | 
				
			||||||
 | 
					>(({ className, ...props }, ref) => (
 | 
				
			||||||
 | 
					  <caption
 | 
				
			||||||
 | 
					    ref={ref}
 | 
				
			||||||
 | 
					    className={cn("mt-4 text-sm text-muted-foreground", className)}
 | 
				
			||||||
 | 
					    {...props}
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					))
 | 
				
			||||||
 | 
					TableCaption.displayName = "TableCaption"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export {
 | 
				
			||||||
 | 
					  Table,
 | 
				
			||||||
 | 
					  TableHeader,
 | 
				
			||||||
 | 
					  TableBody,
 | 
				
			||||||
 | 
					  TableFooter,
 | 
				
			||||||
 | 
					  TableHead,
 | 
				
			||||||
 | 
					  TableRow,
 | 
				
			||||||
 | 
					  TableCell,
 | 
				
			||||||
 | 
					  TableCaption,
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,83 +0,0 @@
 | 
				
			|||||||
#!/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
 | 
					 | 
				
			||||||
@@ -31,7 +31,7 @@ msg_ok "Installed Dependencies"
 | 
				
			|||||||
msg_info "Setting up Node.js Repository"
 | 
					msg_info "Setting up Node.js Repository"
 | 
				
			||||||
mkdir -p /etc/apt/keyrings
 | 
					mkdir -p /etc/apt/keyrings
 | 
				
			||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
					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_ok "Set up Node.js Repository"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Setting up PostgreSQL Repository"
 | 
					msg_info "Setting up PostgreSQL Repository"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										57
									
								
								install/alpine-it-tools-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								install/alpine-it-tools-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,57 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					# Author: nicedevil007 (NiceDevil)
 | 
				
			||||||
 | 
					# 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 apk add \
 | 
				
			||||||
 | 
					  curl \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  openssh \
 | 
				
			||||||
 | 
					  nginx \
 | 
				
			||||||
 | 
					  unzip
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing IT-Tools"
 | 
				
			||||||
 | 
					RELEASE=$(curl -s https://api.github.com/repos/CorentinTh/it-tools/releases/latest | grep '"tag_name":' | cut -d '"' -f4)
 | 
				
			||||||
 | 
					DOWNLOAD_URL="https://github.com/CorentinTh/it-tools/releases/download/${RELEASE}/it-tools-${RELEASE#v}.zip"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					curl -fsSL -o it-tools.zip "$DOWNLOAD_URL"
 | 
				
			||||||
 | 
					mkdir -p /usr/share/nginx/html
 | 
				
			||||||
 | 
					unzip -q it-tools.zip -d /tmp/it-tools
 | 
				
			||||||
 | 
					cp -r /tmp/it-tools/dist/* /usr/share/nginx/html
 | 
				
			||||||
 | 
					cat <<'EOF' > /etc/nginx/http.d/default.conf
 | 
				
			||||||
 | 
					server {
 | 
				
			||||||
 | 
					  listen 80;
 | 
				
			||||||
 | 
					  server_name localhost;
 | 
				
			||||||
 | 
					  root /usr/share/nginx/html;
 | 
				
			||||||
 | 
					  index index.html;
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					  location / {
 | 
				
			||||||
 | 
					      try_files $uri $uri/ /index.html;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					$STD rc-update add nginx default
 | 
				
			||||||
 | 
					$STD rc-service nginx start
 | 
				
			||||||
 | 
					echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
 | 
				
			||||||
 | 
					msg_ok "Installed IT-Tools"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					rm -rf /tmp/it-tools
 | 
				
			||||||
 | 
					rm -f it-tools.zip
 | 
				
			||||||
 | 
					$STD apk cache clean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
							
								
								
									
										78
									
								
								install/apache-tika-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								install/apache-tika-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,78 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					# Author: Andy Grunwald (andygrunwald)
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/apache/tika/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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 \
 | 
				
			||||||
 | 
					  sudo \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  software-properties-common \
 | 
				
			||||||
 | 
					  gdal-bin \
 | 
				
			||||||
 | 
					  tesseract-ocr \
 | 
				
			||||||
 | 
					  tesseract-ocr-eng \
 | 
				
			||||||
 | 
					  tesseract-ocr-ita \
 | 
				
			||||||
 | 
					  tesseract-ocr-fra \
 | 
				
			||||||
 | 
					  tesseract-ocr-spa \
 | 
				
			||||||
 | 
					  tesseract-ocr-deu
 | 
				
			||||||
 | 
					$STD echo ttf-mscorefonts-installer msttcorefonts/accepted-mscorefonts-eula select true | debconf-set-selections
 | 
				
			||||||
 | 
					$STD apt-get install -y \
 | 
				
			||||||
 | 
					  xfonts-utils \
 | 
				
			||||||
 | 
					  fonts-freefont-ttf \
 | 
				
			||||||
 | 
					  fonts-liberation \
 | 
				
			||||||
 | 
					  ttf-mscorefonts-installer \
 | 
				
			||||||
 | 
					  cabextract
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setup OpenJDK"
 | 
				
			||||||
 | 
					$STD apt-get install -y \
 | 
				
			||||||
 | 
					  openjdk-17-jre-headless
 | 
				
			||||||
 | 
					msg_ok "Setup OpenJDK"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing Apache Tika"
 | 
				
			||||||
 | 
					mkdir -p /opt/apache-tika
 | 
				
			||||||
 | 
					cd /opt/apache-tika
 | 
				
			||||||
 | 
					RELEASE="$(wget -qO- https://dlcdn.apache.org/tika/ | grep -oP '(?<=href=")[0-9]+\.[0-9]+\.[0-9]+(?=/")' | sort -V | tail -n1)"
 | 
				
			||||||
 | 
					wget -q "https://dlcdn.apache.org/tika/${RELEASE}/tika-server-standard-${RELEASE}.jar"
 | 
				
			||||||
 | 
					mv tika-server-standard-${RELEASE}.jar tika-server-standard.jar
 | 
				
			||||||
 | 
					echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
 | 
				
			||||||
 | 
					msg_ok "Installed Apache Tika"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Creating Service"
 | 
				
			||||||
 | 
					cat <<EOF >/etc/systemd/system/apache-tika.service
 | 
				
			||||||
 | 
					[Unit]
 | 
				
			||||||
 | 
					Description=Apache Tika
 | 
				
			||||||
 | 
					Documentation=https://tika.apache.org/
 | 
				
			||||||
 | 
					After=syslog.target network.target
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Service]
 | 
				
			||||||
 | 
					User=root
 | 
				
			||||||
 | 
					Restart=always
 | 
				
			||||||
 | 
					Type=simple
 | 
				
			||||||
 | 
					ExecStart=java -jar /opt/apache-tika/tika-server-standard.jar --host 0.0.0.0 --port 9998
 | 
				
			||||||
 | 
					ExecReload=/bin/kill -HUP \$MAINPID
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Install]
 | 
				
			||||||
 | 
					WantedBy=multi-user.target
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					systemctl enable -q --now apache-tika
 | 
				
			||||||
 | 
					msg_ok "Created Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					$STD apt-get -y autoremove
 | 
				
			||||||
 | 
					$STD apt-get -y autoclean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
@@ -39,7 +39,7 @@ msg_ok "Installed Python Dependencies"
 | 
				
			|||||||
msg_info "Setting up Node.js Repository"
 | 
					msg_info "Setting up Node.js Repository"
 | 
				
			||||||
mkdir -p /etc/apt/keyrings
 | 
					mkdir -p /etc/apt/keyrings
 | 
				
			||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
					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_ok "Set up Node.js Repository"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Installing Node.js"
 | 
					msg_info "Installing Node.js"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -81,12 +81,13 @@ $STD apt-get install -y nodejs
 | 
				
			|||||||
msg_ok "Installed Node.js"
 | 
					msg_ok "Installed Node.js"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Installing Golang"
 | 
					msg_info "Installing Golang"
 | 
				
			||||||
cd /tmp
 | 
					 | 
				
			||||||
set +o pipefail
 | 
					set +o pipefail
 | 
				
			||||||
GO_RELEASE=$(curl -s https://go.dev/dl/ | grep -o -m 1 "go.*\linux-amd64.tar.gz")
 | 
					temp_file=$(mktemp)
 | 
				
			||||||
wget -q https://golang.org/dl/${GO_RELEASE}
 | 
					golang_tarball=$(curl -s https://go.dev/dl/ | grep -oP 'go[\d\.]+\.linux-amd64\.tar\.gz' | head -n 1)
 | 
				
			||||||
tar -xzf ${GO_RELEASE} -C /usr/local
 | 
					wget -q https://golang.org/dl/"$golang_tarball" -O "$temp_file"
 | 
				
			||||||
ln -s /usr/local/go/bin/go /usr/bin/go
 | 
					tar -C /usr/local -xzf "$temp_file"
 | 
				
			||||||
 | 
					ln -sf /usr/local/go/bin/go /usr/local/bin/go
 | 
				
			||||||
 | 
					rm -f "$temp_file"
 | 
				
			||||||
set -o pipefail
 | 
					set -o pipefail
 | 
				
			||||||
msg_ok "Installed Golang"
 | 
					msg_ok "Installed Golang"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -186,7 +187,6 @@ msg_info "Cleaning up"
 | 
				
			|||||||
rm -rf /tmp/Python-3.12.1
 | 
					rm -rf /tmp/Python-3.12.1
 | 
				
			||||||
rm -rf /tmp/Python.tgz
 | 
					rm -rf /tmp/Python.tgz
 | 
				
			||||||
rm -rf go/
 | 
					rm -rf go/
 | 
				
			||||||
rm -rf /tmp/${GO_RELEASE}
 | 
					 | 
				
			||||||
rm -rf /tmp/geoipupdate.deb
 | 
					rm -rf /tmp/geoipupdate.deb
 | 
				
			||||||
rm -rf authentik.tar.gz
 | 
					rm -rf authentik.tar.gz
 | 
				
			||||||
$STD apt-get -y remove yq
 | 
					$STD apt-get -y remove yq
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										97
									
								
								install/baikal-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								install/baikal-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,97 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					# Author: bvdberg01
 | 
				
			||||||
 | 
					# 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 \
 | 
				
			||||||
 | 
					  sudo \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  postgresql \
 | 
				
			||||||
 | 
					  apache2 \
 | 
				
			||||||
 | 
					  libapache2-mod-php \
 | 
				
			||||||
 | 
					  php-{pgsql,dom}
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setting up PostgreSQL"
 | 
				
			||||||
 | 
					DB_NAME=baikal
 | 
				
			||||||
 | 
					DB_USER=baikal
 | 
				
			||||||
 | 
					DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)
 | 
				
			||||||
 | 
					$STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';"
 | 
				
			||||||
 | 
					$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER TEMPLATE template0;"
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					echo "Baikal Credentials"
 | 
				
			||||||
 | 
					echo "Baikal Database User: $DB_USER"
 | 
				
			||||||
 | 
					echo "Baikal Database Password: $DB_PASS"
 | 
				
			||||||
 | 
					echo "Baikal Database Name: $DB_NAME"
 | 
				
			||||||
 | 
					} >> ~/baikal.creds
 | 
				
			||||||
 | 
					msg_ok "Set up PostgreSQL"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing Baikal"
 | 
				
			||||||
 | 
					RELEASE=$(curl -s https://api.github.com/repos/sabre-io/Baikal/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
				
			||||||
 | 
					cd /opt
 | 
				
			||||||
 | 
					wget -q "https://github.com/sabre-io/baikal/releases/download/${RELEASE}/baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					unzip -q "baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					cat <<EOF >/opt/baikal/config/baikal.yaml
 | 
				
			||||||
 | 
					database:
 | 
				
			||||||
 | 
					    backend: pgsql
 | 
				
			||||||
 | 
					    pgsql_host: localhost
 | 
				
			||||||
 | 
					    pgsql_dbname: $DB_NAME
 | 
				
			||||||
 | 
					    pgsql_username: $DB_USER
 | 
				
			||||||
 | 
					    pgsql_password: $DB_PASS
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					chown -R www-data:www-data /opt/baikal/
 | 
				
			||||||
 | 
					chmod -R 755 /opt/baikal/
 | 
				
			||||||
 | 
					echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
 | 
				
			||||||
 | 
					msg_ok "Installed Baikal"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Creating Service"
 | 
				
			||||||
 | 
					cat <<EOF > /etc/apache2/sites-available/baikal.conf
 | 
				
			||||||
 | 
					<VirtualHost *:80>
 | 
				
			||||||
 | 
					    ServerName baikal
 | 
				
			||||||
 | 
					    DocumentRoot /opt/baikal/html
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    RewriteEngine on
 | 
				
			||||||
 | 
					    RewriteRule /.well-known/carddav /dav.php [R=308,L]
 | 
				
			||||||
 | 
					    RewriteRule /.well-known/caldav  /dav.php [R=308,L]
 | 
				
			||||||
 | 
					    RewriteCond %{REQUEST_URI} ^/dav.php$ [NC]
 | 
				
			||||||
 | 
					    RewriteRule ^(.*)$ /dav.php/ [R=301,L]
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					    <Directory /opt/baikal/html>
 | 
				
			||||||
 | 
					        Options FollowSymLinks
 | 
				
			||||||
 | 
					        AllowOverride All
 | 
				
			||||||
 | 
					        Require all granted
 | 
				
			||||||
 | 
					    </Directory>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <IfModule mod_expires.c>
 | 
				
			||||||
 | 
					        ExpiresActive Off
 | 
				
			||||||
 | 
					    </IfModule>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    ErrorLog /var/log/apache2/baikal_error.log
 | 
				
			||||||
 | 
					    CustomLog /var/log/apache2/baikal_access.log combined
 | 
				
			||||||
 | 
					</VirtualHost>
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					$STD a2ensite baikal
 | 
				
			||||||
 | 
					$STD a2enmod rewrite
 | 
				
			||||||
 | 
					$STD a2dissite 000-default.conf
 | 
				
			||||||
 | 
					$STD systemctl reload apache2
 | 
				
			||||||
 | 
					msg_ok "Created Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					rm -rf "/opt/baikal-${RELEASE}.zip"
 | 
				
			||||||
 | 
					$STD apt-get -y autoremove
 | 
				
			||||||
 | 
					$STD apt-get -y autoclean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
@@ -4,7 +4,7 @@
 | 
				
			|||||||
# Author: tteck (tteckster) | Co-Author: MickLesk (CanbiZ)
 | 
					# Author: tteck (tteckster) | Co-Author: MickLesk (CanbiZ)
 | 
				
			||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
source /dev/stdin <<< "$FUNCTIONS_FILE_PATH"
 | 
					source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | 
				
			||||||
color
 | 
					color
 | 
				
			||||||
verb_ip6
 | 
					verb_ip6
 | 
				
			||||||
catch_errors
 | 
					catch_errors
 | 
				
			||||||
@@ -33,16 +33,16 @@ msg_ok "Installed Caddy"
 | 
				
			|||||||
read -r -p "Would you like to install xCaddy Addon? <y/N> " prompt
 | 
					read -r -p "Would you like to install xCaddy Addon? <y/N> " prompt
 | 
				
			||||||
if [[ "${prompt,,}" =~ ^(y|yes)$ ]]; then
 | 
					if [[ "${prompt,,}" =~ ^(y|yes)$ ]]; then
 | 
				
			||||||
  msg_info "Installing Golang"
 | 
					  msg_info "Installing Golang"
 | 
				
			||||||
  cd /opt
 | 
					 | 
				
			||||||
  set +o pipefail
 | 
					  set +o pipefail
 | 
				
			||||||
  GOLANG=$(curl -s https://go.dev/dl/ | grep -o "go.*\linux-amd64.tar.gz" | head -n 1)
 | 
					  temp_file=$(mktemp)
 | 
				
			||||||
  wget -q https://golang.org/dl/$GOLANG
 | 
					  golang_tarball=$(curl -s https://go.dev/dl/ | grep -oP 'go[\d\.]+\.linux-amd64\.tar\.gz' | head -n 1)
 | 
				
			||||||
  tar -xzf $GOLANG -C /usr/local
 | 
					  wget -q https://golang.org/dl/"$golang_tarball" -O "$temp_file"
 | 
				
			||||||
  ln -s /usr/local/go/bin/go /usr/local/bin/go
 | 
					  tar -C /usr/local -xzf "$temp_file"
 | 
				
			||||||
 | 
					  ln -sf /usr/local/go/bin/go /usr/local/bin/go
 | 
				
			||||||
 | 
					  rm -f "$temp_file"
 | 
				
			||||||
  set -o pipefail
 | 
					  set -o pipefail
 | 
				
			||||||
  rm -rf /opt/go*
 | 
					 | 
				
			||||||
  msg_ok "Installed Golang"
 | 
					  msg_ok "Installed Golang"
 | 
				
			||||||
	
 | 
					
 | 
				
			||||||
  msg_info "Setup xCaddy"
 | 
					  msg_info "Setup xCaddy"
 | 
				
			||||||
  cd /opt
 | 
					  cd /opt
 | 
				
			||||||
  RELEASE=$(curl -s https://api.github.com/repos/caddyserver/xcaddy/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
					  RELEASE=$(curl -s https://api.github.com/repos/caddyserver/xcaddy/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }')
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -58,7 +58,7 @@ msg_ok "Setup Python3"
 | 
				
			|||||||
msg_info "Setting up Node.js Repository"
 | 
					msg_info "Setting up Node.js Repository"
 | 
				
			||||||
mkdir -p /etc/apt/keyrings
 | 
					mkdir -p /etc/apt/keyrings
 | 
				
			||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
					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_ok "Set up Node.js Repository"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Installing Node.js"
 | 
					msg_info "Installing Node.js"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										97
									
								
								install/crafty-controller-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								install/crafty-controller-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,97 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts
 | 
				
			||||||
 | 
					# Author: CrazyWolf13
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://docs.craftycontrol.com/pages/getting-started/installation/linux/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					source /dev/stdin <<< "$FUNCTIONS_FILE_PATH"
 | 
				
			||||||
 | 
					color
 | 
				
			||||||
 | 
					verb_ip6
 | 
				
			||||||
 | 
					catch_errors
 | 
				
			||||||
 | 
					setting_up_container
 | 
				
			||||||
 | 
					network_check
 | 
				
			||||||
 | 
					update_os
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing Dependencies (a lot of patience)"
 | 
				
			||||||
 | 
					$STD apt-get install -y \
 | 
				
			||||||
 | 
					  curl \
 | 
				
			||||||
 | 
					  sudo \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  git \
 | 
				
			||||||
 | 
					  sed \
 | 
				
			||||||
 | 
					  lsb-release \
 | 
				
			||||||
 | 
					  apt-transport-https \
 | 
				
			||||||
 | 
					  coreutils \
 | 
				
			||||||
 | 
					  software-properties-common \
 | 
				
			||||||
 | 
					  openjdk-17-jdk 
 | 
				
			||||||
 | 
					wget -q https://download.oracle.com/java/21/latest/jdk-21_linux-x64_bin.deb
 | 
				
			||||||
 | 
					$STD sudo dpkg -i jdk-21_linux-x64_bin.deb
 | 
				
			||||||
 | 
					rm -f jdk-21_linux-x64_bin.deb
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setup Python3"
 | 
				
			||||||
 | 
					$STD apt-get install -y \
 | 
				
			||||||
 | 
					  python3 \
 | 
				
			||||||
 | 
					  python3-dev \
 | 
				
			||||||
 | 
					  python3-pip \
 | 
				
			||||||
 | 
					  python3-venv
 | 
				
			||||||
 | 
					rm -rf /usr/lib/python3.*/EXTERNALLY-MANAGED
 | 
				
			||||||
 | 
					msg_ok "Setup Python3"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing Craty-Controller (Patience)"
 | 
				
			||||||
 | 
					useradd crafty -m -s /bin/bash
 | 
				
			||||||
 | 
					cd /opt
 | 
				
			||||||
 | 
					mkdir -p /opt/crafty-controller/crafty /opt/crafty-controller/server
 | 
				
			||||||
 | 
					RELEASE=$(curl -s "https://gitlab.com/api/v4/projects/20430749/releases" | grep -o '"tag_name":"v[^"]*"' | head -n 1 | sed 's/"tag_name":"v//;s/"//')
 | 
				
			||||||
 | 
					echo "${RELEASE}" >"/opt/crafty-controller_version.txt"
 | 
				
			||||||
 | 
					wget -q "https://gitlab.com/crafty-controller/crafty-4/-/archive/v${RELEASE}/crafty-4-v${RELEASE}.zip"
 | 
				
			||||||
 | 
					unzip -q crafty-4-v${RELEASE}.zip
 | 
				
			||||||
 | 
					cp -a crafty-4-v${RELEASE}/. /opt/crafty-controller/crafty/crafty-4/
 | 
				
			||||||
 | 
					rm -rf crafty-4-v${RELEASE}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					cd /opt/crafty-controller/crafty
 | 
				
			||||||
 | 
					python3 -m venv .venv
 | 
				
			||||||
 | 
					chown -R crafty:crafty /opt/crafty-controller/
 | 
				
			||||||
 | 
					$STD sudo -u crafty bash -c '
 | 
				
			||||||
 | 
					    source /opt/crafty-controller/crafty/.venv/bin/activate
 | 
				
			||||||
 | 
					    cd /opt/crafty-controller/crafty/crafty-4
 | 
				
			||||||
 | 
					    pip3 install --no-cache-dir -r requirements.txt
 | 
				
			||||||
 | 
					'
 | 
				
			||||||
 | 
					msg_ok "Installed Craft-Controller and dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setting up Crafty-Controller service"
 | 
				
			||||||
 | 
					cat > /etc/systemd/system/crafty-controller.service << 'EOF'
 | 
				
			||||||
 | 
					[Unit]
 | 
				
			||||||
 | 
					Description=Crafty 4
 | 
				
			||||||
 | 
					After=network.target
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Service]
 | 
				
			||||||
 | 
					Type=simple
 | 
				
			||||||
 | 
					User=crafty
 | 
				
			||||||
 | 
					WorkingDirectory=/opt/crafty-controller/crafty/crafty-4
 | 
				
			||||||
 | 
					Environment=PATH=/opt/crafty-controller/crafty/.venv/bin:$PATH
 | 
				
			||||||
 | 
					ExecStart=/opt/crafty-controller/crafty/.venv/bin/python3 main.py -d
 | 
				
			||||||
 | 
					Restart=on-failure
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Install]
 | 
				
			||||||
 | 
					WantedBy=multi-user.target
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					$STD systemctl enable -q --now crafty-controller
 | 
				
			||||||
 | 
					sleep 10
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    echo "Crafty-Controller-Credentials"
 | 
				
			||||||
 | 
					    echo "Username: $(grep -oP '(?<="username": ")[^"]*' /opt/crafty-controller/crafty/crafty-4/app/config/default-creds.txt)"
 | 
				
			||||||
 | 
					    echo "Password: $(grep -oP '(?<="password": ")[^"]*' /opt/crafty-controller/crafty/crafty-4/app/config/default-creds.txt)"
 | 
				
			||||||
 | 
					} >> ~/crafty-controller.creds
 | 
				
			||||||
 | 
					msg_ok "Crafty-Controller service started"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					rm -rf /opt/crafty-4-v${RELEASE}.zip
 | 
				
			||||||
 | 
					$STD apt-get -y autoremove
 | 
				
			||||||
 | 
					$STD apt-get -y autoclean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
@@ -23,7 +23,7 @@ msg_ok "Installed Dependencies"
 | 
				
			|||||||
msg_info "Setting up Node.js Repository"
 | 
					msg_info "Setting up Node.js Repository"
 | 
				
			||||||
mkdir -p /etc/apt/keyrings
 | 
					mkdir -p /etc/apt/keyrings
 | 
				
			||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
 | 
					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_ok "Set up Node.js Repository"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg_info "Installing Node.js"
 | 
					msg_info "Installing Node.js"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										66
									
								
								install/duplicati-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								install/duplicati-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					# Author: tremor021
 | 
				
			||||||
 | 
					# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | 
				
			||||||
 | 
					# Source: https://github.com/duplicati/duplicati
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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 \
 | 
				
			||||||
 | 
					  sudo \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  libice6 \
 | 
				
			||||||
 | 
					  libsm6 \
 | 
				
			||||||
 | 
					  libfontconfig1
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Setting up Duplicati"
 | 
				
			||||||
 | 
					RELEASE=$(curl -s https://api.github.com/repos/duplicati/duplicati/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4)}')
 | 
				
			||||||
 | 
					wget -q "https://github.com/duplicati/duplicati/releases/download/v${RELEASE}/duplicati-${RELEASE}-linux-x64-gui.deb"
 | 
				
			||||||
 | 
					$STD dpkg -i duplicati-${RELEASE}-linux-x64-gui.deb
 | 
				
			||||||
 | 
					echo "${RELEASE}" >/opt/Duplicati_version.txt
 | 
				
			||||||
 | 
					msg_ok "Finished setting up Duplicati"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DECRYPTKEY=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)
 | 
				
			||||||
 | 
					ADMINPASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    echo "Admin password = ${ADMINPASS}"
 | 
				
			||||||
 | 
					    echo "Database encryption key = ${DECRYPTKEY}"
 | 
				
			||||||
 | 
					} >> ~/duplicati.creds
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Creating Service"
 | 
				
			||||||
 | 
					cat <<EOF >/etc/systemd/system/duplicati.service
 | 
				
			||||||
 | 
					[Unit]
 | 
				
			||||||
 | 
					Description=Duplicati Service
 | 
				
			||||||
 | 
					After=network.target
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Service]
 | 
				
			||||||
 | 
					ExecStart=/usr/bin/duplicati-server --webservice-interface=any --webservice-password=$ADMINPASS --settings-encryption-key=$DECRYPTKEY
 | 
				
			||||||
 | 
					Restart=always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[Install]
 | 
				
			||||||
 | 
					WantedBy=multi-user.target
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
 | 
					systemctl enable -q --now duplicati
 | 
				
			||||||
 | 
					msg_ok "Created Service"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					rm -f duplicati-${RELEASE}-linux-x64-gui.deb
 | 
				
			||||||
 | 
					$STD apt-get -y autoremove
 | 
				
			||||||
 | 
					$STD apt-get -y autoclean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
							
								
								
									
										46
									
								
								install/elementsynapse-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								install/elementsynapse-install.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,46 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (c) 2021-2025 community-scripts ORG
 | 
				
			||||||
 | 
					# Author: tremor021
 | 
				
			||||||
 | 
					# 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 \
 | 
				
			||||||
 | 
					  sudo \
 | 
				
			||||||
 | 
					  curl \
 | 
				
			||||||
 | 
					  mc \
 | 
				
			||||||
 | 
					  lsb-release \
 | 
				
			||||||
 | 
					  wget \
 | 
				
			||||||
 | 
					  apt-transport-https \
 | 
				
			||||||
 | 
					  debconf-utils
 | 
				
			||||||
 | 
					msg_ok "Installed Dependencies"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					read -p "Please enter the name for your server: " servername
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Installing Element Synapse"
 | 
				
			||||||
 | 
					wget -O /usr/share/keyrings/matrix-org-archive-keyring.gpg https://packages.matrix.org/debian/matrix-org-archive-keyring.gpg
 | 
				
			||||||
 | 
					echo "deb [signed-by=/usr/share/keyrings/matrix-org-archive-keyring.gpg] https://packages.matrix.org/debian/ $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/matrix-org.list
 | 
				
			||||||
 | 
					$STD apt-get update
 | 
				
			||||||
 | 
					echo "matrix-synapse-py3 matrix-synapse/server-name string $servername" | debconf-set-selections
 | 
				
			||||||
 | 
					echo "matrix-synapse-py3 matrix-synapse/report-stats boolean false" | debconf-set-selections
 | 
				
			||||||
 | 
					$STD apt-get install matrix-synapse-py3 -y
 | 
				
			||||||
 | 
					sed -i 's/127.0.0.1/0.0.0.0/g' /etc/matrix-synapse/homeserver.yaml
 | 
				
			||||||
 | 
					sed -i 's/'\''::1'\'', //g' /etc/matrix-synapse/homeserver.yaml
 | 
				
			||||||
 | 
					systemctl enable -q --now matrix-synapse
 | 
				
			||||||
 | 
					msg_ok "Installed Element Synapse"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					motd_ssh
 | 
				
			||||||
 | 
					customize
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					msg_info "Cleaning up"
 | 
				
			||||||
 | 
					$STD apt-get -y autoremove
 | 
				
			||||||
 | 
					$STD apt-get -y autoclean
 | 
				
			||||||
 | 
					msg_ok "Cleaned"
 | 
				
			||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user