Files
api/plugin/scripts/deploy-dev.sh
Eli Bosley ce61fee41c feat: improve local dev with install path (#1221)
- also add better watcher support

<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

- **New Features**
- Added a helper that displays a local installation URL to simplify
setting up the plugin.

- **Chores**
- Updated service and container port configurations to ensure consistent
network connectivity (changed from 8080 to 5858).
- Refined container management to gracefully handle running instances
during startup.
- Improved build and installation routines for streamlined deployment
and enhanced reliability.
- Enhanced documentation to clarify installation and usage instructions
for better user experience.
- Introduced a new document outlining development workflows for better
guidance.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->

---
- To see the specific tasks where the Asana app for GitHub is being
used, see below:
  - https://app.asana.com/0/0/1209561202532053
2025-03-17 09:44:10 -04:00

70 lines
1.9 KiB
Bash
Executable File

#!/bin/bash
# Arguments
# $1: SSH server name (required)
# $2: {--wc-deploy|--wc-build|--wc-skip} / deploy or build web components w/o prompt
# Check if the server name is provided
if [[ -z "$1" ]]; then
echo "Error: SSH server name is required."
echo "Usage: $0 <server_name> [--wc-deploy|--wc-build|--wc-skip]"
exit 1
fi
# Set server name from command-line argument
server_name="$1"
# Source directory path
source_directory="plugin/source/dynamix.unraid.net/usr/local/emhttp/plugins"
# Destination directory path
destination_directory="/usr/local/emhttp/plugins"
# Replace the value inside the rsync command with the user's input
rsync_command="rsync -avz --progress --stats -m -e ssh \"$source_directory/\" \"root@${server_name}:$destination_directory/\""
echo "Executing the following command:"
echo "$rsync_command"
# Execute the rsync command and capture the exit code
eval "$rsync_command"
exit_code=$?
# if $2 is --wc-deploy, deploy the web components without prompting
if [ "$2" = "--wc-deploy" ]; then
deploy="yes"
elif [ "$2" = "--wc-build" ]; then
deploy="build"
elif [ "$2" = "--wc-skip" ]; then
deploy="no"
fi
# if not deploy yes then ask
if [ -z "$deploy" ]; then
echo
echo
read -rp "Do you want to also deploy the built web components? (yes/no/build): " deploy
fi
if [ "$deploy" = "yes" ]; then
cd web || exit
npm run deploy-to-unraid:dev
elif [ "$deploy" = "build" ]; then
cd web || exit
npm run build:dev
fi
# Play built-in sound based on the operating system
if [[ "$OSTYPE" == "darwin"* ]]; then
# macOS
afplay /System/Library/Sounds/Submarine.aiff
elif [[ "$OSTYPE" == "linux-gnu" ]]; then
# Linux
paplay /usr/share/sounds/freedesktop/stereo/complete.oga
elif [[ "$OSTYPE" == "msys" || "$OSTYPE" == "win32" ]]; then
# Windows
powershell.exe -c "(New-Object Media.SoundPlayer 'C:\Windows\Media\Windows Default.wav').PlaySync()"
fi
# Exit with the rsync command's exit code
exit $exit_code