mirror of
https://github.com/N0rthernL1ghts/wordpress.git
synced 2025-12-10 03:42:40 +01:00
Move wp-* utils to it's own space in src/
This commit is contained in:
@@ -1,36 +0,0 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -e
|
||||
|
||||
# Applies patch for preventing WordPress updates
|
||||
function main() {
|
||||
PATCH_FILE="${1:?PATCH_FILE is required}"
|
||||
TARGET_FILE="${2:?TARGET_FILE is required}"
|
||||
|
||||
if [ ! -f "${PATCH_FILE}" ]; then
|
||||
echo "> No such file [PATCH]: ${PATCH_FILE}"
|
||||
return 1
|
||||
fi
|
||||
|
||||
if [ ! -f "${TARGET_FILE}" ]; then
|
||||
echo "> No such file [TARGET]: ${TARGET_FILE}"
|
||||
return 1
|
||||
fi
|
||||
|
||||
echo "> Loading patch ${PATCH_FILE}"
|
||||
echo " Patching '${TARGET_FILE}'..."
|
||||
patch --verbose "${TARGET_FILE}" <"${PATCH_FILE}"
|
||||
|
||||
MARK_READ_ONLY="${3:-true}"
|
||||
if [ "${MARK_READ_ONLY}" = "true" ]; then
|
||||
# This is done in order to prevent WordPress overwriting the file
|
||||
echo " Marking the patched file read-only..."
|
||||
chmod 0440 "${TARGET_FILE}"
|
||||
fi
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
# Usage: main /etc/wp-mods/wp-admin-update-core.patch /var/www/html/wp-admin/update-core.php ?true|false
|
||||
main "${@}"
|
||||
exit $?
|
||||
@@ -1,125 +0,0 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
# Download plugin (curl)
|
||||
# $1 - plugin slug
|
||||
# $2 - plugin version (optional)
|
||||
# Returns 0 on success, X on failure
|
||||
download() {
|
||||
PLUGIN_SLUG="${1:?download: PLUGIN_SLUG is required}"
|
||||
PLUGIN_VERSION="${2:-}"
|
||||
|
||||
if [ -n "${PLUGIN_VERSION}" ]; then
|
||||
PLUGIN_FILENAME="${PLUGIN_SLUG}.${PLUGIN_VERSION}.zip"
|
||||
else
|
||||
PLUGIN_FILENAME="${PLUGIN_SLUG}.zip"
|
||||
fi
|
||||
|
||||
curl --fail -gsO "https://downloads.wordpress.org/plugin/${PLUGIN_FILENAME}" || return $?
|
||||
echo "${PLUGIN_FILENAME}"
|
||||
return 0
|
||||
}
|
||||
|
||||
# Unpack plugin (unzip)
|
||||
# $1 - plugin slug
|
||||
# $2 - plugin version (optional)
|
||||
# $3 - target directory (optional)
|
||||
# Returns 0 on success, 1 on failure
|
||||
unpack() {
|
||||
TARGET_PLUGINS_DIR="${TARGET_PLUGINS_DIR:?check: TARGET_PLUGINS_DIR is required}"
|
||||
PLUGIN_SLUG="${1:?unpack: PLUGIN_SLUG is required}"
|
||||
PLUGIN_VERSION="${2:-}"
|
||||
|
||||
if [ -n "${PLUGIN_VERSION}" ]; then
|
||||
PLUGIN_FILENAME="${PLUGIN_SLUG}.${PLUGIN_VERSION}.zip"
|
||||
else
|
||||
PLUGIN_FILENAME="${PLUGIN_SLUG}.zip"
|
||||
fi
|
||||
|
||||
if [ -f "${PLUGIN_FILENAME}" ]; then
|
||||
unzip -qq -d "${TARGET_PLUGINS_DIR}" "${PLUGIN_FILENAME}" || return $?
|
||||
rm "${PLUGIN_FILENAME}" -f
|
||||
return 0
|
||||
fi
|
||||
return 1
|
||||
}
|
||||
|
||||
# Check if plugin is installed
|
||||
# $1 - plugin slug
|
||||
# Returns 0 if plugin is installed, 1 otherwise
|
||||
check() {
|
||||
TARGET_PLUGINS_DIR="${TARGET_PLUGINS_DIR:?check: TARGET_PLUGINS_DIR is required}"
|
||||
PLUGIN_SLUG="${1:?check: PLUGIN_SLUG is required}"
|
||||
|
||||
PLUGIN_PATH="${TARGET_PLUGINS_DIR}/${PLUGIN_SLUG}"
|
||||
|
||||
# Check if plugin directory exists
|
||||
if [ ! -d "${PLUGIN_PATH}" ]; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Check if plugin file exists - if yes, plugin is probably installed successfully
|
||||
if [ -f "${PLUGIN_PATH}/${PLUGIN_SLUG}.php" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# Check if plugin directory is empty - if not, plugin is probably installed successfully
|
||||
if [ "$(ls -A "${PLUGIN_PATH}")" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# If we got here, then plugin is not installed
|
||||
return 1
|
||||
}
|
||||
|
||||
# Delete plugin
|
||||
# $1 - plugin slug
|
||||
# Returns 0 on success, X on failure
|
||||
delete() {
|
||||
TARGET_PLUGINS_DIR="${TARGET_PLUGINS_DIR:?delete: TARGET_PLUGINS_DIR is required}"
|
||||
PLUGIN_SLUG="${1:?delete: PLUGIN_SLUG is required}"
|
||||
|
||||
PLUGIN_PATH="${TARGET_PLUGINS_DIR}/${PLUGIN_SLUG}"
|
||||
|
||||
# Check if plugin directory exists
|
||||
if [ ! -d "${PLUGIN_PATH}" ]; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
rm -rf "${PLUGIN_PATH}"
|
||||
return $?
|
||||
}
|
||||
|
||||
# Main function
|
||||
main() {
|
||||
COMMAND="${1:?COMMAND is required}"
|
||||
TARGET_PLUGINS_DIR="${WP_PLUGINS_PATH:?WP_PLUGINS_PATH is required}"
|
||||
|
||||
export TARGET_PLUGINS_DIR
|
||||
|
||||
# Execute command by calling function with the same name
|
||||
case "${COMMAND}" in
|
||||
download)
|
||||
download "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
unpack)
|
||||
unpack "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
check)
|
||||
check "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
delete)
|
||||
delete "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
*)
|
||||
echo "Error: Unknown command '${COMMAND}'"
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
main "${@}"
|
||||
exit $?
|
||||
@@ -1,130 +0,0 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
# Download theme (curl)
|
||||
# $1 - theme slug
|
||||
# $2 - theme version (optional)
|
||||
# Returns 0 on success, X on failure
|
||||
download() {
|
||||
THEME_SLUG="${1:?download: THEME_SLUG is required}"
|
||||
THEME_VERSION="${2:-}"
|
||||
|
||||
if [ -n "${THEME_VERSION}" ]; then
|
||||
THEME_FILENAME="${THEME_SLUG}.${THEME_VERSION}.zip"
|
||||
else
|
||||
THEME_FILENAME="${THEME_SLUG}.zip"
|
||||
fi
|
||||
|
||||
curl --fail -gsO "https://downloads.wordpress.org/theme/${THEME_FILENAME}" || return $?
|
||||
echo "${THEME_FILENAME}"
|
||||
return 0
|
||||
}
|
||||
|
||||
# Unpack theme (unzip)
|
||||
# $1 - theme slug
|
||||
# $2 - theme version (optional)
|
||||
# Returns 0 on success, 1 on failure
|
||||
unpack() {
|
||||
TARGET_THEMES_DIR="${TARGET_THEMES_DIR:?check: TARGET_THEMES_DIR is required}"
|
||||
THEME_SLUG="${1:?unpack: THEME_SLUG is required}"
|
||||
THEME_VERSION="${2:-}"
|
||||
|
||||
if [ -n "${THEME_VERSION}" ]; then
|
||||
THEME_FILENAME="${THEME_SLUG}.${THEME_VERSION}.zip"
|
||||
else
|
||||
THEME_FILENAME="${THEME_SLUG}.zip"
|
||||
fi
|
||||
|
||||
if [ -f "${THEME_FILENAME}" ]; then
|
||||
unzip -qq -d "${TARGET_THEMES_DIR}" "${THEME_FILENAME}" || return $?
|
||||
rm "${THEME_FILENAME}" -f
|
||||
return 0
|
||||
fi
|
||||
return 1
|
||||
}
|
||||
|
||||
# Check if theme is installed
|
||||
# $1 - theme slug
|
||||
# Returns 0 if theme is installed, 1 otherwise
|
||||
check() {
|
||||
TARGET_THEMES_DIR="${TARGET_THEMES_DIR:?check: TARGET_THEMES_DIR is required}"
|
||||
THEME_SLUG="${1:?check: THEME_SLUG is required}"
|
||||
|
||||
THEME_PATH="${TARGET_THEMES_DIR}/${THEME_SLUG}"
|
||||
|
||||
# Check if theme directory exists
|
||||
if [ ! -d "${THEME_PATH}" ]; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Check if theme theme.json exists - if yes, theme is probably installed successfully
|
||||
if [ -f "${THEME_PATH}/theme.json" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# Check if theme index.php exists - if yes, theme is probably installed successfully
|
||||
if [ -f "${THEME_PATH}/index.php" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# Check if theme directory is empty - if not, theme is probably installed successfully
|
||||
if [ "$(ls -A "${THEME_PATH}")" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
# If we got here, then theme is not installed
|
||||
return 1
|
||||
}
|
||||
|
||||
# Delete theme
|
||||
# $1 - theme slug
|
||||
# Returns 0 on success, X on failure
|
||||
delete() {
|
||||
TARGET_THEMES_DIR="${TARGET_THEMES_DIR:?delete: TARGET_THEMES_DIR is required}"
|
||||
THEME_SLUG="${1:?delete: THEME_SLUG is required}"
|
||||
|
||||
THEME_PATH="${TARGET_THEMES_DIR}/${THEME_SLUG}"
|
||||
|
||||
# Check if theme directory exists
|
||||
if [ ! -d "${THEME_PATH}" ]; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
rm -rf "${THEME_PATH}"
|
||||
return $?
|
||||
}
|
||||
|
||||
|
||||
# Main function
|
||||
main() {
|
||||
COMMAND="${1:?COMMAND is required}"
|
||||
TARGET_THEMES_DIR="${WP_THEMES_PATH:?WP_THEMES_PATH is required}"
|
||||
|
||||
export TARGET_THEMES_DIR
|
||||
|
||||
# Execute command by calling function with the same name
|
||||
case "${COMMAND}" in
|
||||
download)
|
||||
download "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
unpack)
|
||||
unpack "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
check)
|
||||
check "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
delete)
|
||||
delete "${@:2}"
|
||||
return $?
|
||||
;;
|
||||
*)
|
||||
echo "Error: Unknown command '${COMMAND}'"
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
main "${@}"
|
||||
exit $?
|
||||
Reference in New Issue
Block a user