1. 15 Sep, 2025 26 commits
    • nextime's avatar
      Update version to 1.4.4 and documentation · 7c86df54
      nextime authored
      - Updated CHANGELOG.md with new features and fixes for v1.4.4
      - Updated README.md with version 1.4.4 information and new features
      - Updated DOCUMENTATION.md with enhanced feature descriptions
      - Updated TODO.md to reflect completed tasks and new version
      - Updated Debian changelog files for both wsssh-server and wsssh-tools packages
      - Added comprehensive documentation for:
        * Dynamic terminal sizing and resize support
        * Force echo mode implementation
        * Enhanced logging with logrotate integration
        * Terminal dimension fixes and improvements
        * Backend API enhancements for terminal management
      7c86df54
    • nextime's avatar
      Fix terminal dimensions calculation at startup and resize · e857d27e
      nextime authored
      - Calculate terminal dimensions after initial fit to container
      - Store initial dimensions for use during connection
      - Use calculated dimensions for both startup and resize events
      - Ensure proper terminal sizing for applications like top
      - Handle browser window resize to update remote terminal dynamically
      e857d27e
    • nextime's avatar
      Force terminal echo by running stty echo before wsssh · dc3db4b2
      nextime authored
      - Modify wssshd.py to run 'stty echo' before launching wsssh
      - Use shell command wrapper to execute stty echo && wsssh
      - Ensure echo mode is forced before SSH connection is established
      - Remove JavaScript-based stty echo attempts
      - Fix terminal echo issue by setting echo mode at the right time
      dc3db4b2
    • nextime's avatar
      Simplify terminal echo: let SSH server control echo behavior · 675df299
      nextime authored
      - Remove JavaScript-based echo handling and password mode detection
      - Send all keystrokes directly to server without local echo manipulation
      - Let SSH server handle echo control through terminal protocol
      - Proper terminal behavior where server controls what gets displayed
      - No more manual echo logic, respects SSH server's echo settings
      675df299
    • nextime's avatar
      Fix password echo security issue in web terminal · c0b3a4bd
      nextime authored
      - Add passwordMode flag to detect password prompts from SSH server
      - Disable local echo when password prompts are detected (Password:, password:, etc.)
      - Re-enable echo after password is submitted (on Enter key or new prompt)
      - Reset passwordMode on disconnect for clean state
      - Maintain security by not displaying passwords in plain text
      - Preserve normal command echo for non-password input
      c0b3a4bd
    • nextime's avatar
      Fix terminal echo: restore local command echoing in web terminal · 09245516
      nextime authored
      - Add proper xterm.js configuration with disableStdin: false and other settings
      - Implement local echo handling for printable characters, backspace, and enter
      - Ensure terminal input is visible to user while maintaining server communication
      - Fix input handling to properly display typed commands in the web interface
      09245516
    • nextime's avatar
      Fix web terminal sizing: make xterm.js terminal use full available area · f3fe7c6d
      nextime authored
      - Update .terminal-container CSS to use calc(100vh - 200px) for responsive height
      - Remove fixed padding and height constraints
      - Add xterm-addon-fit for proper terminal resizing
      - Update terminal initialization to use fit addon for dynamic sizing
      - Ensure terminal fills entire container width and height
      - Add window resize event handler for responsive terminal sizing
      f3fe7c6d
    • nextime's avatar
      Update documentation for logging improvements · 47bb3803
      nextime authored
      - Add logging section to README.md with logrotate configuration details
      - Add comprehensive Logging Configuration section to DOCUMENTATION.md
      - Update CHANGELOG.md with version 1.4.4 entry for logging features
      - Update table of contents in DOCUMENTATION.md to include logging section
      
      Features documented:
      - Automatic log rotation with logrotate
      - Log file locations and management
      - Manual log management commands
      - Troubleshooting with logs
      - Log analysis techniques
      47bb3803
    • nextime's avatar
      Fix wssshd init script: use --output option to redirect stdout and stderr to log file · fc736a9c
      nextime authored
      Use start-stop-daemon --output option to properly redirect both stdout and stderr
      to /var/log/wssshd/wssshd.log while preserving correct PID storage in the PID file
      fc736a9c
    • nextime's avatar
      Configure wssshd and wssshc init scripts to redirect output to log files managed by logrotate · 1f6b7f9d
      nextime authored
      - Add wssshd.log and wssshc.log to respective logrotate configurations
      - Modify init scripts to redirect stdout and stderr to log files
      - Ensure proper log rotation with weekly rotation, compression, and HUP signals
      1f6b7f9d
    • nextime's avatar
      Fix PID file creation in watchdog start case · 51f99873
      nextime authored
      - Create PID file in start case with correct background process PID
      - Remove PID file creation from main() function to avoid empty files
      - Validate background process is running before reporting success
      - Clean up PID file if process fails to start
      - Fix both wssshd and wssshc watchdogs
      51f99873
    • nextime's avatar
      Fix watchdog PID file to store correct background process PID · 5ee95a9f
      nextime authored
      - Capture PID of background main() process with MAIN_PID=
      - Store correct PID in watchdog PID file instead of main() function PID
      - Prevent PID file from containing exited process PID
      - Fix both wssshd and wssshc watchdogs
      - Watchdog PID file now contains PID of actual running process
      5ee95a9f
    • nextime's avatar
      Fix bash condition evaluation in init scripts · 24611f90
      nextime authored
      - Separate PID file reading from process checking
      - Prevent command substitution failures in kill command
      - Add proper error handling for PID file operations
      - Fix false 'watchdog failed' reports due to bash syntax issues
      - Fixed both wssshd and wssshc init scripts
      24611f90
    • nextime's avatar
      Add debug logging to watchdog monitoring loops · a15aa00d
      nextime authored
      - Add detailed logging to main() monitoring loops
      - Track loop iterations and daemon status checks
      - Log sleep intervals and monitoring status
      - Help diagnose why watchdog exits prematurely
      - Fixed both wssshd and wssshc watchdogs
      a15aa00d
    • nextime's avatar
      Fix init scripts to handle existing watchdog processes · 299eed2b
      nextime authored
      - Stop existing watchdog before starting new one
      - Use pgrep to detect running watchdog processes
      - Prevent 'watchdog already running' conflicts
      - Ensure clean watchdog startup in init scripts
      - Fixed both wssshd and wssshc init scripts
      299eed2b
    • nextime's avatar
      Fix duplicate check_restart_limits() functions in watchdogs · 844a88ba
      nextime authored
      - Removed duplicate function definitions causing bash arithmetic errors
      - Kept the more complete check_restart_limits() function with awk timestamp parsing
      - Fixed both wssshd and wssshc watchdog scripts
      - Eliminates 'integer expression expected' errors
      844a88ba
    • nextime's avatar
      Refactor init scripts to start daemons directly before watchdog · 7c51589c
      nextime authored
      - Init scripts now start wssshd/wssshc daemons directly
      - Wait for daemons to be fully running before starting watchdog
      - Watchdog only monitors existing daemons, doesn't start them
      - Watchdog exits if daemon restart fails
      - Proper startup sequence: daemon → verify running → watchdog
      - Fixed both wssshd and wssshc init scripts and watchdogs
      7c51589c
    • nextime's avatar
      Add startup delay for daemon initialization · fa858590
      nextime authored
      - Watchdog now waits 3 seconds after starting daemon before checking status
      - Prevents false detection of daemon failure during startup
      - Gives daemon time to fully initialize and create PID file
      - Fixed both wssshd and wssshc watchdogs
      - Improves reliability of daemon startup detection
      fa858590
    • nextime's avatar
      Fix watchdog daemonization with setsid · 309d1940
      nextime authored
      - Use setsid to properly daemonize main() function
      - setsid bash -c 'main' & creates independent process group
      - Prevents main() from being killed when parent script exits
      - Fixed both wssshd and wssshc watchdogs
      - Watchdog processes should now persist correctly
      309d1940
    • nextime's avatar
      Fix watchdog daemonization issue · cab9eefd
      nextime authored
      - Watchdog now properly daemonizes by running main() in background
      - Removed complex PID file waiting logic that was causing issues
      - Simplified start case to just run main() and check for PID file
      - Fixed both wssshd and wssshc watchdogs
      - Watchdog processes should now persist after script exits
      cab9eefd
    • nextime's avatar
      Fix init scripts to kill processes even without PID file · 81f5c328
      nextime authored
      - Stop functions now kill daemon processes regardless of PID file existence
      - Added fallback pkill mechanism for processes without PID files
      - Uses graceful TERM signal followed by force KILL signal
      - Fixed both wssshd and wssshc init scripts
      - Ensures complete process cleanup in all scenarios
      81f5c328
    • nextime's avatar
      Fix init scripts to stop daemons directly when watchdog not running · 9c51519e
      nextime authored
      - Init scripts now stop daemons directly even if watchdog PID file doesn't exist
      - Added graceful termination (TERM) followed by force kill (KILL) if needed
      - Added pkill fallback to catch any remaining daemon processes
      - Fixed both wssshd and wssshc init scripts
      - Ensures complete daemon shutdown regardless of watchdog status
      9c51519e
    • nextime's avatar
      Fix watchdog stop command to kill all running processes · f8f89d64
      nextime authored
      - Stop command now kills processes from PID file AND any other running watchdog processes
      - Prevents zombie watchdog processes when PID file doesn't exist
      - Added aggressive cleanup of all watchdog processes
      - Fixed both wssshd and wssshc watchdogs
      - Ensures complete watchdog shutdown even with startup failures
      f8f89d64
    • nextime's avatar
      Add debug logging to watchdog scripts · 1c1a2538
      nextime authored
      - Log START configuration values and validation
      - Add detailed startup debugging in start case
      - Track main() function PID and PID file creation
      - Help identify why watchdog fails to start properly
      - Applied to both wssshd and wssshc watchdogs
      1c1a2538
    • nextime's avatar
      Fix all bash syntax errors: remove 'local' keyword from script body · 646ff942
      nextime authored
      - Removed 'local' from stop and status case handlers in both watchdogs
      - 'local' can only be used inside functions, not in main script body
      - Fixed both wssshd-watchdog and wssshc-watchdog scripts
      - All bash syntax errors should now be resolved
      646ff942
    • nextime's avatar
      Fix bash syntax error: remove 'local' keyword from script body · dea963e9
      nextime authored
      - 'local' can only be used inside functions, not in main script body
      - Fixed both wssshd-watchdog and wssshc-watchdog scripts
      - Removed 'local count=0' from start case handlers
      dea963e9
  2. 14 Sep, 2025 14 commits
    • nextime's avatar
      Restore proper watchdog continuous monitoring behavior · 9932ff92
      nextime authored
      - Watchdogs now run in infinite loop monitoring daemons every 30 seconds
      - Check START=yes configuration before starting monitoring
      - Restart daemons if they die, with max 20 restarts per minute limit
      - Double-check processes are actually running and correct
      - Fixed both wssshd and wssshc watchdogs to run continuously
      - Removed one-time start logic, restored continuous monitoring
      9932ff92
    • nextime's avatar
      Fix wssshd user permission issue for home directory · 4282f289
      nextime authored
      - Add permission verification in postinst scripts for both wssshd and wssshc
      - Test if users can write to their home directories
      - Fix permissions if write access is denied (chmod 775)
      - Ensure users are in correct groups
      - Prevent 'Permission denied' errors when creating .config directories
      4282f289
    • nextime's avatar
      Complete watchdog fix with restart limiting · 3a5568d4
      nextime authored
      - Implement one-time start logic (no continuous monitoring)
      - Add restart limiting: max 20 restarts per minute
      - Watchdog exits after successful start or if limits exceeded
      - Double-check processes are actually running and correct
      - Clean up PID files properly on exit
      - Fixed both wssshd and wssshc watchdogs
      3a5568d4
    • nextime's avatar
      Fix watchdog behavior to prevent unnecessary restarts · 153db18a
      nextime authored
      - Change watchdogs from continuous monitoring to one-time start
      - Check START=yes in /etc/default/ before starting services
      - Only start services if they're not already running
      - Double-check processes are actually running and correct
      - Improve status and stop functions with process verification
      - Fix both wssshd and wssshc watchdogs
      153db18a
    • nextime's avatar
      Fix watchdog PID file race condition · e348dd54
      nextime authored
      - Watchdog scripts now wait for PID file creation before exiting
      - Reduced init script sleep time from 3 to 1 second
      - Prevents 'Watchdog failed to start properly' timing issues
      - Fixed both wssshd and wssshc watchdog/init scripts
      e348dd54
    • nextime's avatar
      Fix --debian-only to build only wsssh-tools package · 50a1e7af
      nextime authored
      - --debian-only now builds only wsssh-tools, not wsssh-server
      - Updated help text to clarify --debian-only behavior
      - Updated output messages for --debian-only vs --packages
      50a1e7af
    • nextime's avatar
      d2d3fc32
    • nextime's avatar
      Update clean.sh to remove wsssh-server Debian packages · e7c202a8
      nextime authored
      - Add cleanup for wsssh-server*.deb packages and artifacts
      - Add cleanup for wsssh-server debian build directory
      - Ensure both wsssh-server and wsssh-tools packages are cleaned
      e7c202a8
    • nextime's avatar
      Add systemd startup files to Debian packages · 9b90a3c6
      nextime authored
      - Create systemd service files for wssshd and wssshc
      - Add conditions to prevent conflicts with sysv init
      - Update debian/rules to install systemd services
      - Update postinst scripts to enable systemd services
      - Ensure sysv init has precedence over systemd
      9b90a3c6
    • nextime's avatar
      Fix watchdog START configuration handling · 8faacbfb
      nextime authored
      - Remove set -x tracing from init and watchdog scripts
      - Fix wssshd and wssshc watchdogs to accept various START values
      - Support yes, YES, Y, 1, true, TRUE as documented in config files
      8faacbfb
    • nextime's avatar
      Add proper log rotation support to Debian packages · c476d907
      nextime authored
      - Created logrotate configuration files for both wssshd and wssshc
      - wssshd.logrotate: Rotates /var/log/wssshd/watchdog.log weekly
      - wssshc.logrotate: Rotates /var/log/wssshc/watchdog.log weekly
      - Both configs include postrotate scripts to HUP watchdog processes
      - Install logrotate configs to /etc/logrotate.d/ in both packages
      - Added /etc/logrotate.d directory creation to debian/rules
      - Log rotation settings: weekly, 52 rotations, compress, proper permissions
      - Ensures logs don't grow indefinitely and consume disk space
      - Follows Debian packaging standards for log management
      - Automatic log rotation prevents production system issues
      c476d907
    • nextime's avatar
      Improve watchdog scripts robustness and error handling · 19a0ac29
      nextime authored
      - Added fallback mechanism when start-stop-daemon fails
      - Try direct daemon execution if start-stop-daemon fails
      - Added better error checking for daemon binary existence
      - Simplified complex awk-based restart limit checking
      - Added proper error suppression for directory operations
      - Made watchdog scripts more robust for testing/development environments
      - Disabled restart limiting temporarily to avoid parsing issues
      - Improved logging for troubleshooting startup failures
      - Both wssshd-watchdog and wssshc-watchdog updated with same improvements
      19a0ac29
    • nextime's avatar
      Fix wsssh-server Debian package build - missing /usr/sbin directory · c3479481
      nextime authored
      - Added mkdir command to create /usr/sbin directory in wsssh-server debian/rules
      - Fixed 'No such file or directory' error when installing wssshd-watchdog
      - Ensures proper directory structure for watchdog script installation
      - Resolves build failure when running build.sh --packages or --debian-only
      - Maintains consistency with other directory creation commands
      c3479481
    • nextime's avatar
      Fix wssshtools Debian package build - missing /usr/sbin directory · 28618aa1
      nextime authored
      - Added mkdir command to create /usr/sbin directory in debian/rules
      - Fixed 'No such file or directory' error when installing wssshc-watchdog
      - Ensures proper directory structure for watchdog script installation
      - Resolves build failure when running build.sh --packages or --debian-only
      - Maintains consistency with other directory creation commands
      28618aa1