3 changed files with 312 additions and 0 deletions
@ -0,0 +1,242 @@ |
|||
#!/bin/bash |
|||
# https://github.com/Weilbyte/PVEDiscordDark |
|||
|
|||
#region Consts |
|||
RED='\033[0;31m' |
|||
BRED='\033[0;31m\033[1m' |
|||
GRN='\033[92m' |
|||
WARN='\033[93m' |
|||
BOLD='\033[1m' |
|||
REG='\033[0m' |
|||
CHECKMARK='\033[0;32m\xE2\x9C\x94\033[0m' |
|||
|
|||
TEMPLATE_FILE="/usr/share/javascript/proxmox-backup/index.hbs" |
|||
SCRIPTPATH="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/$(basename "${BASH_SOURCE[0]}")" |
|||
|
|||
REPO=${REPO:-"Weilbyte/PVEDiscordDark"} |
|||
DEFAULT_TAG="master" |
|||
TAG=${TAG:-$DEFAULT_TAG} |
|||
BASE_URL="https://raw.githubusercontent.com/$REPO/$TAG" |
|||
#endregion Consts |
|||
|
|||
#region Prerun checks |
|||
hash sed 2>/dev/null || { |
|||
echo -e >&2 "${BRED}sed is required but missing from your system${REG}"; |
|||
exit 1; |
|||
} |
|||
|
|||
hash curl 2>/dev/null || { |
|||
echo -e >&2 "${BRED}cURL is required but missing from your system${REG}"; |
|||
exit 1; |
|||
} |
|||
|
|||
#echo -e >&2 "${pbsversion}" |
|||
#hash proxmox-backup-manager versions 2>/dev/null || { |
|||
# echo -e >&2 "${BRED}PBS installation required but missing from your system${REG}"; |
|||
# exit 1; |
|||
#} |
|||
|
|||
curl -sSf -f https://github.com/robots.txt &> /dev/null || { |
|||
echo -e >&2 "${BRED}Could not establish a connection to GitHub (github.com)${REG}"; |
|||
exit 1; |
|||
} |
|||
|
|||
if [ $TAG != $DEFAULT_TAG ]; then |
|||
if !([[ $TAG =~ [0-9] ]] && [ ${#TAG} -ge 7 ] && (! [[ $TAG =~ ['!@#$%^&*()_+.'] ]]) ); then |
|||
echo -e "${WARN}It appears like you are using a non-default tag. For security purposes, please use the SHA-1 hash of said tag instead${REG}" |
|||
fi |
|||
fi |
|||
#endregion Prerun checks |
|||
|
|||
PBSVersion=$(proxmox-backup-manager versions | grep proxmox-backup-server | cut -c 23- | cut -c -7) # Below pbsversion pre-run check |
|||
PBSVersionMajor=$(echo $PBSVersion | cut -d'-' -f1) |
|||
|
|||
#region Helper functions |
|||
function checkSupported { |
|||
local SUPPORTED=$(curl -f -s "$BASE_URL/meta/supported") |
|||
if [ -z "$SUPPORTED" ]; then |
|||
echo -e "${WARN}Could not reach supported version file ($BASE_URL/meta/supported). Skipping support check.${REG}" |
|||
else |
|||
local SUPPORTEDARR=($(echo "$SUPPORTED" | tr ',' '\n')) |
|||
if ! (printf '%s\n' "${SUPPORTEDARR[@]}" | grep -q -P "$PBSVersionMajor"); then |
|||
echo -e "${WARN}You might encounter issues because your version ($PBSVersionMajor) is not matching currently supported versions ($SUPPORTED)." |
|||
echo -e "If you do run into any issues on >newer< versions, please consider opening an issue at https://github.com/Weilbyte/PVEDiscordDark/issues.${REG}" |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
function isInstalled { |
|||
if (grep -Fq "<link rel='stylesheet' type='text/css' href='/css/dd_style.css'>" $TEMPLATE_FILE && |
|||
grep -Fq "<script type='text/javascript' src='/js/dd_patcher.js'></script>" $TEMPLATE_FILE && |
|||
[ -f "/usr/share/javascript/proxmox-backup/css/dd_style.css" ] && [ -f "/usr/share/javascript/proxmox-backup/js/dd_patcher.js" ]); then |
|||
true |
|||
else |
|||
false |
|||
fi |
|||
} |
|||
|
|||
#endregion Helper functions |
|||
|
|||
#region Main functions |
|||
function usage { |
|||
if [ "$_silent" = false ]; then |
|||
echo -e "Usage: $0 [OPTIONS...] {COMMAND}\n" |
|||
echo -e "Manages the PBSDiscordDark theme." |
|||
echo -e " -h --help Show this help" |
|||
echo -e " -s --silent Silent mode\n" |
|||
echo -e "Commands:" |
|||
echo -e " status Check current theme status (in silent mode, returns 0 if installed, and 1 if not installed)" |
|||
echo -e " install Install the theme" |
|||
echo -e " uninstall Uninstall the theme" |
|||
echo -e " update Update the theme (runs uninstall, then install)" |
|||
# echo -e " utility-update Update this utility\n" (to be implemented) |
|||
echo -e "Exit status:" |
|||
echo -e " 0 OK" |
|||
echo -e " 1 Failure" |
|||
echo -e " 2 Already installed, OR not installed (when using install/uninstall commands)\n" |
|||
echo -e "Report issues at: <https://github.com/Weilbyte/PVEDiscordDark/issues>" |
|||
fi |
|||
} |
|||
|
|||
function status { |
|||
if [ "$_silent" = false ]; then |
|||
echo -e "Theme" |
|||
if isInstalled; then |
|||
echo -e " Status: ${GRN}present${REG}" |
|||
else |
|||
echo -e " Status: ${RED}not present${REG}" |
|||
fi |
|||
echo -e " CSS: $(sha256sum /usr/share/javascript/proxmox-backup/css/dd_style.css 2>/dev/null || echo N/A)" |
|||
echo -e " JS: $(sha256sum /usr/share/javascript/proxmox-backup/js/dd_patcher.js 2>/dev/null || echo N/A)\n" |
|||
echo -e "PBS" |
|||
echo -e " Version: $PBSVersion (major $PBSVersionMajor)\n" |
|||
echo -e "Utility hash: $(sha256sum $SCRIPTPATH 2>/dev/null || echo N/A)" |
|||
exit 0 |
|||
else |
|||
if isInstalled; then exit 0; else exit 1; fi |
|||
fi |
|||
} |
|||
|
|||
function install { |
|||
if isInstalled; then |
|||
if [ "$_silent" = false ]; then echo -e "${RED}Theme already installed${REG}"; fi |
|||
exit 2 |
|||
else |
|||
if [ "$_silent" = false ]; then checkSupported; fi |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Backing up template file"; fi |
|||
cp $TEMPLATE_FILE $TEMPLATE_FILE.bak |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Downloading stylesheet"; fi |
|||
curl -s $BASE_URL/PVEDiscordDark/sass/PVEDiscordDark.css > /usr/share/javascript/proxmox-backup/css/dd_style.css |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Downloading patcher"; fi |
|||
curl -s $BASE_URL/PVEDiscordDark/js/PVEDiscordDark.js > /usr/share/javascript/proxmox-backup/js/dd_patcher.js |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Applying changes to template file"; fi |
|||
if !(grep -Fq "<link rel='stylesheet' type='text/css' href='/css/dd_style.css'>" $TEMPLATE_FILE); then |
|||
echo "<link rel='stylesheet' type='text/css' href='/css/dd_style.css'>" >> $TEMPLATE_FILE |
|||
fi |
|||
if !(grep -Fq "<script type='text/javascript' src='/js/dd_patcher.js'></script>" $TEMPLATE_FILE); then |
|||
echo "<script type='text/javascript' src='/js/dd_patcher.js'></script>" >> $TEMPLATE_FILE |
|||
fi |
|||
|
|||
local IMAGELIST=$(curl -f -s "$BASE_URL/meta/imagelist") |
|||
local IMAGELISTARR=($(echo "$IMAGELIST" | tr ',' '\n')) |
|||
if [ "$_silent" = false ]; then echo -e "Downloading images (0/${#IMAGELISTARR[@]})"; fi |
|||
ITER=0 |
|||
for image in "${IMAGELISTARR[@]}" |
|||
do |
|||
curl -s $BASE_URL/PVEDiscordDark/images/$image > /usr/share/javascript/proxmox-backup/images/$image |
|||
((ITER++)) |
|||
if [ "$_silent" = false ]; then echo -e "\e[1A\e[KDownloading images ($ITER/${#IMAGELISTARR[@]})"; fi |
|||
done |
|||
if [ "$_silent" = false ]; then echo -e "\e[1A\e[K${CHECKMARK} Downloading images (${#IMAGELISTARR[@]}/${#IMAGELISTARR[@]})"; fi |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "Theme installed."; fi |
|||
if [ "$_noexit" = false ]; then exit 0; fi |
|||
fi |
|||
} |
|||
|
|||
function uninstall { |
|||
if ! isInstalled; then |
|||
echo -e "${RED}Theme not installed${REG}" |
|||
exit 2 |
|||
else |
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Removing stylesheet"; fi |
|||
rm /usr/share/javascript/proxmox-backup/css/dd_style.css |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Removing patcher"; fi |
|||
rm /usr/share/javascript/proxmox-backup/js/dd_patcher.js |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Reverting changes to template file"; fi |
|||
sed -i "/<link rel='stylesheet' type='text\/css' href='\/css\/dd_style.css'>/d" /usr/share/javascript/proxmox-backup/index.hbs |
|||
sed -i "/<script type='text\/javascript' src='\/js\/dd_patcher.js'><\/script>/d" /usr/share/javascript/proxmox-backup/index.hbs |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "${CHECKMARK} Removing images"; fi |
|||
rm /usr/share/javascript/proxmox-backup/images/dd_* |
|||
|
|||
if [ "$_silent" = false ]; then echo -e "Theme uninstalled."; fi |
|||
if [ "$_noexit" = false ]; then exit 0; fi |
|||
fi |
|||
} |
|||
|
|||
#endregion Main functions |
|||
|
|||
_silent=false |
|||
_command=false |
|||
_noexit=false |
|||
|
|||
parse_cli() |
|||
{ |
|||
while test $# -gt -0 |
|||
do |
|||
_key="$1" |
|||
case "$_key" in |
|||
-h|--help) |
|||
usage |
|||
exit 0 |
|||
;; |
|||
-s|--silent) |
|||
_silent=true |
|||
;; |
|||
status) |
|||
if [ "$_command" = false ]; then |
|||
_command=true |
|||
status |
|||
fi |
|||
;; |
|||
install) |
|||
if [ "$_command" = false ]; then |
|||
_command=true |
|||
install |
|||
exit 0 |
|||
fi |
|||
;; |
|||
uninstall) |
|||
if [ "$_command" = false ]; then |
|||
_command=true |
|||
uninstall |
|||
exit 0 |
|||
fi |
|||
;; |
|||
update) |
|||
if [ "$_command" = false ]; then |
|||
_command=true |
|||
_noexit=true |
|||
uninstall |
|||
install |
|||
exit 0 |
|||
fi |
|||
;; |
|||
*) |
|||
echo -e "${BRED}Error: Got an unexpected argument \"$_key\"${REG}\n"; |
|||
usage; |
|||
exit 1; |
|||
;; |
|||
esac |
|||
shift |
|||
done |
|||
} |
|||
|
|||
parse_cli "$@" |
@ -0,0 +1,69 @@ |
|||
const swapLogo = async function() { |
|||
const imgElements = document.getElementsByTagName('img'); |
|||
var found = false; |
|||
for (var i = 0; i< imgElements.length; i++) { |
|||
var node = imgElements[i] |
|||
if (node.src.includes('proxmox_logo.png')) { |
|||
found = true; |
|||
var width = (node.parentElement.clientWidth == undefined || node.parentElement.clientWidth == 0) ? 172 : node.parentElement.clientWidth; |
|||
var height = (node.parentElement.clientHeight == undefined || node.parentElement.clientHeight == 0) ? 30 : node.parentElement.clientHeight; |
|||
node.parentElement.parentElement.style.background = '#23272A'; |
|||
node.setAttribute('height', `${height}px`); |
|||
node.setAttribute('width', `${width}px`); |
|||
node.setAttribute('src', '/images/dd_logo.png'); |
|||
} |
|||
} |
|||
if (!found) { |
|||
await new Promise(resolve => setTimeout(resolve, 60)); |
|||
await swapLogo(); |
|||
}; |
|||
}; |
|||
|
|||
const patchCharts = function() { |
|||
Ext.chart.theme.Base.prototype.config.chart.defaults.background = '#23272a'; |
|||
Ext.chart.theme.Base.prototype.config.axis.defaults.label.color = 'white'; |
|||
Ext.chart.theme.Base.prototype.config.axis.defaults.title.color = 'white'; |
|||
Ext.chart.theme.Base.prototype.config.axis.defaults.style.strokeStyle = '#7289DA'; |
|||
Ext.chart.theme.Base.prototype.config.axis.defaults.grid.strokeStyle = 'rgba(44, 47, 51, 1)'; |
|||
Ext.chart.theme.Base.prototype.config.sprites.text.color = 'white'; |
|||
}; |
|||
|
|||
function patchGaugeWidget() { |
|||
Proxmox.panel.GaugeWidget.prototype.backgroundColor = '#2C2F33'; |
|||
Proxmox.panel.GaugeWidget.prototype.criticalColor = '#f04747'; |
|||
Proxmox.panel.GaugeWidget.prototype.warningColor = '#faa61a'; |
|||
Proxmox.panel.GaugeWidget.prototype.defaultColor = '#7289DA'; |
|||
Proxmox.panel.GaugeWidget.prototype.items[1].series[0].colors[0] = '#2C2F33'; |
|||
}; |
|||
|
|||
function patchBackupConfig() { |
|||
//PBS.window.BackupConfig.prototype.items.style['background-color'] = '#23272a';
|
|||
}; |
|||
|
|||
function patchDiskSmartWindow() { |
|||
const target = PBS.DiskSmartWindow || Proxmox.window.DiskSmart; |
|||
target.prototype.items[1].style['background-color'] = '#23272a'; |
|||
} |
|||
|
|||
function patchTFAEdit() { |
|||
//PBS.window.TFAEdit.prototype.items[0].items[0].items[1].style["background-color"] = 'transparent';
|
|||
} |
|||
|
|||
function patchCreateWidget() { |
|||
_createWidget = Ext.createWidget |
|||
Ext.createWidget = function(c, p) { |
|||
if (typeof p === 'object' && typeof p.style === 'object') { |
|||
if (c === 'component' && typeof p.style['background-color'] === 'string' && p.style['background-color'] === 'white') p.style['background-color'] = '#2C2F33' |
|||
} |
|||
return _createWidget(c, p) |
|||
} |
|||
} |
|||
|
|||
swapLogo(); |
|||
patchCharts(); |
|||
patchGaugeWidget(); |
|||
patchBackupConfig(); |
|||
patchDiskSmartWindow(); |
|||
patchTFAEdit(); |
|||
patchCreateWidget(); |
|||
console.log('PBSDiscordDark :: Patched'); |
File diff suppressed because one or more lines are too long
Loading…
Reference in new issue