Use canonical domain files in detect-existing credentials
Agent-Logs-Url: https://github.com/naturallaw777/staging_alpha/sessions/f9e2b5f9-b25b-4ab9-a3cf-5b8bd4ea22de Co-authored-by: naturallaw777 <99053422+naturallaw777@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
5e33a250d5
commit
a1db5773fc
@@ -217,33 +217,33 @@ CREDS
|
|||||||
RemainAfterExit = true;
|
RemainAfterExit = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
path = with pkgs; [ php coreutils gnused ];
|
path = with pkgs; [ coreutils gnused ];
|
||||||
|
|
||||||
script = ''
|
script = ''
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
CONFIG_FILE="/var/lib/www/nextcloud/config/config.php"
|
|
||||||
CREDS_FILE="/var/lib/secrets/nextcloud-admin"
|
CREDS_FILE="/var/lib/secrets/nextcloud-admin"
|
||||||
DOMAIN_FILE="/var/lib/domains/nextcloud"
|
DOMAIN_FILE="/var/lib/domains/nextcloud"
|
||||||
DOMAIN=""
|
DOMAIN="your-domain"
|
||||||
|
|
||||||
DOMAIN="$(php -r '$cfg = @include "/var/lib/www/nextcloud/config/config.php"; if (!is_array($cfg)) { exit(0); } $url = $cfg["overwrite.cli.url"] ?? ""; if (is_string($url) && $url !== "") { $host = parse_url($url, PHP_URL_HOST); if (is_string($host) && $host !== "") { echo $host; exit(0); } } $trusted = $cfg["trusted_domains"] ?? []; if (is_array($trusted)) { foreach ($trusted as $entry) { if (is_string($entry) && $entry !== "") { $entry = preg_replace("#^https?://#", "", $entry); $entry = preg_replace("#/.*$#", "", $entry); if ($entry !== "") { echo $entry; exit(0); } } } } if (is_string($trusted) && $trusted !== "") { $trusted = preg_replace("#^https?://#", "", $trusted); $trusted = preg_replace("#/.*$#", "", $trusted); echo $trusted; }' 2>/dev/null || true)"
|
if [ -f "$DOMAIN_FILE" ]; then
|
||||||
|
FILE_DOMAIN="$(sed -n '1{s/^[[:space:]]*//;s/[[:space:]]*$//;p;}' "$DOMAIN_FILE")"
|
||||||
|
if [ -n "$FILE_DOMAIN" ]; then
|
||||||
|
DOMAIN="$FILE_DOMAIN"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
mkdir -p /var/lib/secrets /var/lib/domains
|
mkdir -p /var/lib/secrets
|
||||||
|
|
||||||
cat > "$CREDS_FILE" << CREDS
|
cat > "$CREDS_FILE" << CREDS
|
||||||
Nextcloud Existing Installation
|
Nextcloud (Pre-existing Installation)
|
||||||
═══════════════════════════════
|
═══════════════════════════════════════
|
||||||
URL: ''${DOMAIN:+https://$DOMAIN/}''${DOMAIN:-Unknown (set in $CONFIG_FILE)}
|
URL: https://$DOMAIN/
|
||||||
Note: Credentials were set before this flake.
|
Note: This Nextcloud was installed before Sovran_SystemsOS.
|
||||||
Use existing credentials or reset via:
|
Use your existing admin credentials to log in.
|
||||||
php /var/lib/www/nextcloud/occ user:resetpassword <admin-user>
|
Reset: sudo -u caddy php /var/lib/www/nextcloud/occ user:resetpassword <username>
|
||||||
CREDS
|
CREDS
|
||||||
chmod 600 "$CREDS_FILE"
|
chmod 600 "$CREDS_FILE"
|
||||||
|
|
||||||
if [ -n "$DOMAIN" ] && [ ! -f "$DOMAIN_FILE" ]; then
|
|
||||||
printf '%s\n' "$DOMAIN" > "$DOMAIN_FILE"
|
|
||||||
fi
|
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -180,42 +180,33 @@ CREDS
|
|||||||
RemainAfterExit = true;
|
RemainAfterExit = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
path = with pkgs; [ php wp-cli coreutils gnused shadow util-linux ];
|
path = with pkgs; [ coreutils gnused ];
|
||||||
|
|
||||||
script = ''
|
script = ''
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
CONFIG_FILE="/var/lib/www/wordpress/wp-config.php"
|
|
||||||
CREDS_FILE="/var/lib/secrets/wordpress-admin"
|
CREDS_FILE="/var/lib/secrets/wordpress-admin"
|
||||||
DOMAIN_FILE="/var/lib/domains/wordpress"
|
DOMAIN_FILE="/var/lib/domains/wordpress"
|
||||||
URL=""
|
DOMAIN="your-domain"
|
||||||
DOMAIN=""
|
|
||||||
|
|
||||||
URL="$(php -r '$cfg = @file_get_contents("/var/lib/www/wordpress/wp-config.php"); if ($cfg === false) { exit(0); } if (preg_match("/define\\(\\s*[\"\\x27]WP_HOME[\"\\x27]\\s*,\\s*[\"\\x27]([^\"\\x27]+)[\"\\x27]\\s*\\)/", $cfg, $m)) { echo $m[1]; exit(0); } if (preg_match("/define\\(\\s*[\"\\x27]WP_SITEURL[\"\\x27]\\s*,\\s*[\"\\x27]([^\"\\x27]+)[\"\\x27]\\s*\\)/", $cfg, $m)) { echo $m[1]; }' 2>/dev/null || true)"
|
if [ -f "$DOMAIN_FILE" ]; then
|
||||||
|
FILE_DOMAIN="$(sed -n '1{s/^[[:space:]]*//;s/[[:space:]]*$//;p;}' "$DOMAIN_FILE")"
|
||||||
if [ -z "$URL" ] && [ -f /var/lib/www/wordpress/wp-load.php ]; then
|
if [ -n "$FILE_DOMAIN" ]; then
|
||||||
URL=$(/run/wrappers/bin/su -s /bin/sh caddy -c "cd /var/lib/www/wordpress && wp option get siteurl 2>/dev/null" || true)
|
DOMAIN="$FILE_DOMAIN"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$URL" ]; then
|
mkdir -p /var/lib/secrets
|
||||||
DOMAIN="$(printf '%s' "$URL" | sed -E 's#^[A-Za-z][A-Za-z0-9+.-]*://##; s#/.*$##')"
|
|
||||||
fi
|
|
||||||
|
|
||||||
mkdir -p /var/lib/secrets /var/lib/domains
|
|
||||||
|
|
||||||
cat > "$CREDS_FILE" << CREDS
|
cat > "$CREDS_FILE" << CREDS
|
||||||
WordPress Existing Installation
|
WordPress (Pre-existing Installation)
|
||||||
═══════════════════════════════
|
═══════════════════════════════════════
|
||||||
URL: ''${URL:-Unknown (set in $CONFIG_FILE)}
|
URL: https://$DOMAIN/wp-admin/
|
||||||
Note: Credentials were set before this flake.
|
Note: This WordPress was installed before Sovran_SystemsOS.
|
||||||
Use existing credentials or reset via:
|
Use your existing admin credentials to log in.
|
||||||
wp user update <admin-user> --user_pass='<new-password>'
|
Reset: wp user update <username> --user_pass=<new-password>
|
||||||
CREDS
|
CREDS
|
||||||
chmod 600 "$CREDS_FILE"
|
chmod 600 "$CREDS_FILE"
|
||||||
|
|
||||||
if [ -n "$DOMAIN" ] && [ ! -f "$DOMAIN_FILE" ]; then
|
|
||||||
printf '%s\n' "$DOMAIN" > "$DOMAIN_FILE"
|
|
||||||
fi
|
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user