Always regenerate web credentials on install, prompt for username
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -164,22 +164,22 @@ enable_web="n"
|
|||||||
read -rp "Enable web dashboard (TUI in browser)? (y/n) [n]: " enable_web </dev/tty || true
|
read -rp "Enable web dashboard (TUI in browser)? (y/n) [n]: " enable_web </dev/tty || true
|
||||||
if [ "$enable_web" = "y" ] || [ "$enable_web" = "Y" ]; then
|
if [ "$enable_web" = "y" ] || [ "$enable_web" = "Y" ]; then
|
||||||
# Set up web credentials
|
# Set up web credentials
|
||||||
if ! grep -q "^WEB_USER=" "$CONFIG_DIR/gniza.conf" 2>/dev/null; then
|
web_user="admin"
|
||||||
echo 'WEB_USER="admin"' >> "$CONFIG_DIR/gniza.conf"
|
read -rp "Web username [admin]: " web_user </dev/tty || true
|
||||||
fi
|
web_user="${web_user:-admin}"
|
||||||
if ! grep -q "^WEB_API_KEY=" "$CONFIG_DIR/gniza.conf" 2>/dev/null || \
|
api_key="$(python3 -c 'import secrets; print(secrets.token_urlsafe(32))')"
|
||||||
[ -z "$(grep '^WEB_API_KEY=' "$CONFIG_DIR/gniza.conf" 2>/dev/null | sed 's/^WEB_API_KEY="//' | sed 's/"$//')" ]; then
|
if grep -q "^WEB_USER=" "$CONFIG_DIR/gniza.conf" 2>/dev/null; then
|
||||||
api_key="$(python3 -c 'import secrets; print(secrets.token_urlsafe(32))')"
|
sed -i "s|^WEB_USER=.*|WEB_USER=\"${web_user}\"|" "$CONFIG_DIR/gniza.conf"
|
||||||
if grep -q "^WEB_API_KEY=" "$CONFIG_DIR/gniza.conf" 2>/dev/null; then
|
|
||||||
sed -i "s|^WEB_API_KEY=.*|WEB_API_KEY=\"${api_key}\"|" "$CONFIG_DIR/gniza.conf"
|
|
||||||
else
|
|
||||||
echo "WEB_API_KEY=\"${api_key}\"" >> "$CONFIG_DIR/gniza.conf"
|
|
||||||
fi
|
|
||||||
info "Web credentials: user=admin password=$api_key"
|
|
||||||
echo "Save these -- you will need them to access the dashboard."
|
|
||||||
else
|
else
|
||||||
info "Web credentials already configured."
|
echo "WEB_USER=\"${web_user}\"" >> "$CONFIG_DIR/gniza.conf"
|
||||||
fi
|
fi
|
||||||
|
if grep -q "^WEB_API_KEY=" "$CONFIG_DIR/gniza.conf" 2>/dev/null; then
|
||||||
|
sed -i "s|^WEB_API_KEY=.*|WEB_API_KEY=\"${api_key}\"|" "$CONFIG_DIR/gniza.conf"
|
||||||
|
else
|
||||||
|
echo "WEB_API_KEY=\"${api_key}\"" >> "$CONFIG_DIR/gniza.conf"
|
||||||
|
fi
|
||||||
|
info "Web credentials: user=$web_user password=$api_key"
|
||||||
|
echo "Save these -- you will need them to access the dashboard."
|
||||||
# Install systemd service
|
# Install systemd service
|
||||||
if [ "$MODE" = "root" ]; then
|
if [ "$MODE" = "root" ]; then
|
||||||
"$INSTALL_DIR/bin/gniza" web install-service || warn "Failed to install web service"
|
"$INSTALL_DIR/bin/gniza" web install-service || warn "Failed to install web service"
|
||||||
|
|||||||
Reference in New Issue
Block a user