Browse Source

Merge pull request #88 from Weilbyte/next

Take in changes from next to master
pull/94/head 2021.09.10
Weilbyte 3 years ago
committed by GitHub
parent
commit
f9a877bc0d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      LICENSE
  2. 191
      PVEDiscordDark.py
  3. BIN
      PVEDiscordDark/images/dd_date-trigger.png
  4. 2
      PVEDiscordDark/sass/PVEDiscordDark.css
  5. 6
      PVEDiscordDark/sass/proxmox/_pveDc.sass
  6. 3
      PVEDiscordDark/sass/special/_icons.sass
  7. 14
      PVEDiscordDark/sass/special/_specific.sass
  8. 3
      PVEDiscordDark/sass/x/_form.sass
  9. 5
      PVEDiscordDark/sass/x/_misc.sass
  10. 61
      PVEDiscordDark/serve.py
  11. 73
      UtilityUpdater.sh
  12. 2
      meta/imagelist

2
LICENSE

@ -1,6 +1,6 @@
MIT License
Copyright (c) 2019
Copyright 2021 Weilbyte
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal

191
PVEDiscordDark.py

@ -1,191 +0,0 @@
#!/usr/bin/python3
import os
import sys
import time
import subprocess
import urllib.request
import os.path
import shutil
import argparse
ACTION = None
images = [
'dd_cephblurp.png', 'dd_cephwhite.png',
'dd_icon-cpu.png', 'dd_icon-hdd.png',
'dd_icon-ram.png', 'dd_icon-swap.png',
'dd_icon-cd.png', 'dd_icon-display.png',
'dd_icon-network.png', 'dd_icon-cloud.png',
'dd_icon-serial.png', 'dd_icon-usb.png',
'dd_icon-pci.png', 'dd_logo.png',
'dd_mini-bottom.png', 'dd_mini-top.png',
'dd_readme', '/dd_tool-sprites.png',
'dd_trigger.png', 'dd_loading.svg',
'dd_icon-die.svg', 'dd_clear-trigger.png']
class colors:
HEADER = '\033[95m'
OKBLUE = '\033[94m'
OKGREEN = '\033[92m'
WARNING = '\033[93m'
FAIL = '\033[91m'
NORMAL = '\033[0m'
BOLD = '\033[1m'
UNDERLINE = '\033[4m'
def clear():
if ACTION == None:
print("\033c", end="")
def cprint(color, text, bold=False, inline=False):
endc = '\n'
if inline:
endc = ''
if bold:
print(colors.BOLD)
print(color + text + colors.NORMAL, end=endc)
def getPVEVersion():
pv = subprocess.check_output('pveversion --verbose | grep pve-manager | cut -c 14- | cut -c -6', shell=True, stderr=open(os.devnull, 'w'))
pv = pv.decode('ascii').replace(" ", "").replace("\n","")
if (('/bin/' in pv) or (len(pv) > 7)):
return ""
else:
return pv
def checkPVE():
ver = getPVEVersion()
if (len(ver) < 1):
cprint(colors.FAIL, 'Unable to detect Proxmox.', True)
cprint(colors.NORMAL, 'A Proxmox installation could not be detected.')
exit(1)
else:
cprint(colors.OKGREEN, '\nPVE ' + ver + ' detected.')
def checkConn():
try:
urllib.request.urlopen('http://github.com')
return
except:
cprint(colors.FAIL, 'An Internet connection is required to install PVEDiscordDark.', True)
cprint(colors.NORMAL, 'Connect to the Internet and try again.')
exit(1)
def themeIsInstalled():
tplUsesTheme = False
tplFile = open('/usr/share/pve-manager/index.html.tpl')
tplLines = tplFile.readlines()
for line in tplLines:
if ("<link rel='stylesheet' type='text/css' href='/pve2/css/dd_style.css'>" in line or "<script type='text/javascript' src='/pve2/js/dd_patcher.js'></script>" in line):
tplUsesTheme = True
if (os.path.isfile('/usr/share/pve-manager/css/dd_style.css') or tplUsesTheme):
return True
return False
def installTheme():
clear()
doHeader()
baseURL = os.getenv('BASEURL', 'https://github.com/Weilbyte/PVEDiscordDark/raw/' + os.getenv("BRANCH", "master"))
cprint(colors.NORMAL, '\nBacking up index template file..')
shutil.copyfile('/usr/share/pve-manager/index.html.tpl', '/usr/share/pve-manager/index.html.tpl.bak')
cprint(colors.NORMAL, 'Downloading stylesheet..')
urllib.request.urlretrieve(baseURL + '/PVEDiscordDark/sass/PVEDiscordDark.css', '/usr/share/pve-manager/css/dd_style.css')
cprint(colors.NORMAL, 'Downloading patcher..')
urllib.request.urlretrieve(baseURL + '/PVEDiscordDark/js/PVEDiscordDark.js', '/usr/share/pve-manager/js/dd_patcher.js')
cprint(colors.NORMAL, 'Applying stylesheet and patcher..')
with open('/usr/share/pve-manager/index.html.tpl', 'a') as tplFile:
tplFile.write("<link rel='stylesheet' type='text/css' href='/pve2/css/dd_style.css'>")
tplFile.write("<script type='text/javascript' src='/pve2/js/dd_patcher.js'></script>")
for index, image in enumerate(images):
imageCurrent = index + 1
cprint(colors.NORMAL, 'Downloading images [' + str(imageCurrent) + '/' + str(len(images)) + ']..\r', False, True)
urllib.request.urlretrieve(baseURL + '/PVEDiscordDark/images/' + image, '/usr/share/pve-manager/images/' + image)
cprint(colors.OKGREEN, '\nTheme installed successfully!', True)
if ACTION == None:
cprint(colors.NORMAL, 'Press [ENTER] to go back.')
input('')
doMainMenu()
def uninstallTheme():
clear()
doHeader()
cprint(colors.NORMAL, '\nCleaning up index template file..')
with open('/usr/share/pve-manager/index.html.tpl', 'r+') as tplFile:
tplLines = tplFile.readlines()
tplFile.seek(0)
for line in tplLines:
if ("<link rel='stylesheet' type='text/css' href='/pve2/css/dd_style.css'>" not in line or "<script type='text/javascript' src='/pve2/js/dd_patcher.js'></script>" not in line):
tplFile.write(line)
tplFile.truncate()
if os.path.exists('/usr/share/javascript/extjs/charts.js.bak'):
cprint(colors.NORMAL, 'Reverting charts.js replacement..')
os.remove('/usr/share/javascript/extjs/charts.js')
shutil.copyfile('/usr/share/javascript/extjs/charts.js.bak', '/usr/share/javascript/extjs/charts.js')
os.remove('/usr/share/javascript/extjs/charts.js.bak')
if os.path.exists('/usr/share/pve-manager/css/dd_style.css'):
cprint(colors.NORMAL, 'Removing stylesheet..')
os.remove('/usr/share/pve-manager/css/dd_style.css')
if os.path.exists('/usr/share/pve-manager/js/dd_patcher.js'):
cprint(colors.NORMAL, 'Removing patcher..')
os.remove('/usr/share/pve-manager/js/dd_patcher.js')
cprint(colors.NORMAL, 'Removing images..')
for asset in os.listdir('/usr/share/pve-manager/images/'):
if asset.startswith('dd_'):
os.remove('/usr/share/pve-manager/images/' + asset)
cprint(colors.OKGREEN, '\n\nTheme uninstalled successfully!', True)
if ACTION == None:
cprint(colors.NORMAL, 'Press [ENTER] to go back.')
input('')
doMainMenu()
def doHeader():
cprint(colors.HEADER, '[~]', True, True)
cprint(colors.NORMAL, ' PVEDiscordDark Utility (DEPRECATED)\nThis installer is now deprecated, please use PVEDiscordDark.sh\n', False, True)
def doMainMenu():
clear()
doHeader()
isInstalled = themeIsInstalled()
cprint(colors.NORMAL, '[I]', True, True)
cprint(colors.NORMAL, ' Install theme', False, True)
if isInstalled:
cprint(colors.NORMAL, '[U]', True, True)
cprint(colors.NORMAL, ' Uninstall theme', False, True)
cprint(colors.NORMAL, '[Q]', True, True)
cprint(colors.NORMAL, ' Exit', False, True)
choice = input('\n\n>? ')
choice = choice.upper().replace(" ", "")
if choice == 'I':
installTheme()
elif (choice == 'U' and isInstalled):
uninstallTheme()
elif choice == 'Q':
exit(0)
else:
doMainMenu()
def main():
parser = argparse.ArgumentParser(description='PVEDiscordDark Theme Utility (DEPRECATED)')
parser.add_argument('--action', '-a', choices=['install', 'uninstall'], help='action for unattended mode')
args = parser.parse_args()
global ACTION
ACTION = args.action
checkPVE()
checkConn()
time.sleep(0.5)
if ACTION == None:
try:
doMainMenu()
except KeyboardInterrupt:
print('\n')
exit(0)
else:
if ACTION == 'install':
installTheme()
else:
if themeIsInstalled():
uninstallTheme()
if __name__ == "__main__":
main()

BIN
PVEDiscordDark/images/dd_date-trigger.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

2
PVEDiscordDark/sass/PVEDiscordDark.css

File diff suppressed because one or more lines are too long

6
PVEDiscordDark/sass/proxmox/_pveDc.sass

@ -1,5 +1,7 @@
div[id^="pveDcHealth-"][id$="-body"], div[id^="pveDcGuests-"][id$="-body"], div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(3) > div:nth-child(2), div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(5) > div:nth-child(2) > div > div
div[id^="pveDcHealth-"][id$="-body"], div[id^="pveDcGuests-"][id$="-body"],
div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(3) > div:nth-child(2), div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(5) > div:nth-child(2) > div > div,
div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(3) > div:nth-child(2) > div
background-color: $darker
div[id^="pveDcSummary-"][id$="-innerCt"] > div:nth-child(4) > div:nth-child(3)
border: 1px solid $darker
border: 1px solid $darker

3
PVEDiscordDark/sass/special/_icons.sass

@ -52,6 +52,9 @@
.fa-usb:before
color: white
.fa-object-group:before
color: white
.fa-hdd-o:before
color: white

14
PVEDiscordDark/sass/special/_specific.sass

@ -21,7 +21,7 @@
background: $darker
div[id^="toolbar-"][id$="-innerCt"] div[id^="toolbar-"][id$="-targetEl"] div ul li div
background-color: $dark
background-color: $dark
div[id^="pveGuestStatusView-"][id$="-body"]
background: $darker
@ -89,9 +89,13 @@ a[id^="menuitem-"][id$="-itemEl"] div[class*="fa-trash-o"]:before
background-color: transparent !important
border: 1px solid #d23d3f !important
div[id="menu-1029-targetEl"] > div[class*="x-menu-item"]
background: $dark
background: $dark
div[id="menu-1029-targetEl"] > div[class*="x-menu-item"] > a[class*="x-menu-item-focus"]
background: $darker
background: $darker
div[id="menu-1029-targetEl"] > div[class*="x-menu-item"] > div[class*="x-menu-item"] > a[aria-disabled="true"]
opacity: 0.5
background: $darker
opacity: 0.5
background: $darker
// Panels on "My Settings"
div[id^="form-"][id$="-innerCt"][style="height: 160px; width: 356px;"], div[id^="fieldset-"][id$="-innerCt"]
background: $darker

3
PVEDiscordDark/sass/x/_form.sass

@ -37,3 +37,6 @@
.x-form-cb-label-default
color: inherit
.x-form-field-date .x-form-date-trigger
background-image: url('/pve2/images/dd_date-trigger.png')

5
PVEDiscordDark/sass/x/_misc.sass

@ -23,3 +23,8 @@
.install-mask
color: white
background-color: $darker
hr[class*="x-component"]
border-width: 1px
border-bottom-width: 0px
border-color: rgba($blurple, 0.35)

61
PVEDiscordDark/serve.py

@ -0,0 +1,61 @@
# Script to assist with PVEDiscordDark development
#
# By default serves HTTP on port 3000, any *.js request gets the JS script, any *.css request gets the CSS file and any image request gets corresponding image
# Meant to be used with the "Requestly" browser extension to redirect PVEDD requests from PVE server to localhost:3000
#
from http.server import HTTPServer, BaseHTTPRequestHandler
import json
import os
PORT = 3000
DIR_SASS = os.path.join(os.path.dirname(__file__), "sass")
DIR_IMAGES = os.path.join(os.path.dirname(__file__), "images")
DIR_JS = os.path.join(os.path.dirname(__file__), "js")
class Server(BaseHTTPRequestHandler):
def log_message(self, format, *args):
return
def _set_headers(self, status, type):
self.send_response(status)
self.send_header("Content-type", type)
self.end_headers()
def do_GET(self):
status = 200
type = "application/json"
data = None
file = self.path.rpartition("/")[2]
ext = file.rpartition(".")[2]
if ext == "css":
data = open(os.path.join(DIR_SASS, "PVEDiscordDark.css"), "rb").read()
type = "text/css"
elif ext == "js":
data = open(os.path.join(DIR_JS, "PVEDiscordDark.js"), "rb").read()
type = "application/javascript"
elif ext == "png" or ext == "jpg" or ext == "jpeg":
try:
data = open(os.path.join(DIR_IMAGES, file), "rb").read()
type = f"image/{ext}"
except FileNotFoundError:
status = 404
else:
status = 400
self._set_headers(status, type)
if status == 200:
self.wfile.write(data)
else:
self.wfile.write(json.dumps({"error": status}).encode())
if __name__ == "__main__":
print(f"Serving on localhost:{PORT}")
server = HTTPServer(server_address=("", PORT), RequestHandlerClass=Server)
try:
server.serve_forever()
except KeyboardInterrupt:
quit()

73
UtilityUpdater.sh

@ -1,73 +0,0 @@
#!/bin/bash
#Script by RisedSky to allow users to update their python script of ProxmoxDiscordDark
#Created : 05/12/2020
currentuser=`whoami | grep 'root'`
default="\e[39m"
green="\e[32m"
red="\e[91m"
yellow="\e[93m"
clear
echo -ne "Verifying that you're root to prevent perm errors \r"
sleep 1
if [ -z "$currentuser" ]
then
echo -ne "Verifying that you're root to prevent perm errors$red [ERROR] $default \r"
echo -ne "\nYou are not root !"
exit 1
fi
echo -ne "Verifying that you're root to prevent perm errors$green [OK] $default \r"
echo -ne '\n'
sleep 1
echo -ne '\n'
sleep 1
echo -ne '# (0%) Checking the latestversion\r'
latestversion=`curl -s "https://api.github.com/repos/Weilbyte/PVEDiscordDark/releases/latest" | awk -F '"' '/tag_name/{print $4}'`
echo -ne '####################### (100%) Checking the latestversion\r'
sleep 1
echo -ne '\n'
file="./currentversion.txt"
currentversion=""
if [ ! -f "$file" ]
then
echo "$latestversion" > "$file"
currentversion="$latestversion"
else
currentversion=`cat $file`
fi
echo "Your version : $currentversion"
echo "Latest version : $latestversion"
if [ ! "$currentversion" = "$latestversion" ]
then
#Not up tp date
read -p "$(echo -e $yellow)[Warning] Your version is different, would you like to update ? $(echo -e $default)[y/n]" -n 1 -r
echo "" # (optional) move to a new line
if [[ $REPLY =~ ^[YyOo]$ ]]
then
echo -ne "Downloading...\n"
wget -O "PVEDiscordDark.py" "https://raw.githubusercontent.com/Weilbyte/PVEDiscordDark/master/PVEDiscordDark.py"
echo "$latestversion" > $file
read -p "$(echo -e $yellow)[Warning] Start the updated script ? $(echo -e $default)[y/n]" -n 1 -r
echo "" # (optional) move to a new line
if [[ $REPLY =~ ^[YyOo]$ ]]
then
python3 PVEDiscordDark.py
exit 0
fi
else
echo -ne "Exiting...\n"
exit 0
fi
else
#Up to date
echo -e "$green""You have the latest version of the script ! $default"
exit 0
fi

2
meta/imagelist

@ -1 +1 @@
dd_cephblurp.png dd_cephwhite.png dd_icon-cpu.png dd_icon-hdd.png dd_icon-ram.png dd_icon-swap.png dd_icon-cd.png dd_icon-display.png dd_icon-network.png dd_icon-cloud.png dd_icon-serial.png dd_icon-usb.png dd_icon-pci.png dd_logo.png dd_mini-bottom.png dd_mini-top.png dd_tool-sprites.png dd_trigger.png dd_loading.svg dd_icon-die.svg dd_arrows.png dd_default-toolbar-small-arrow.png dd_default-toolbar-small-s-arrow.png dd_icon-cdblurp.png
dd_cephblurp.png dd_cephwhite.png dd_icon-cpu.png dd_icon-hdd.png dd_icon-ram.png dd_icon-swap.png dd_icon-cd.png dd_icon-display.png dd_icon-network.png dd_icon-cloud.png dd_icon-serial.png dd_icon-usb.png dd_icon-pci.png dd_logo.png dd_mini-bottom.png dd_mini-top.png dd_tool-sprites.png dd_trigger.png dd_loading.svg dd_icon-die.svg dd_arrows.png dd_default-toolbar-small-arrow.png dd_default-toolbar-small-s-arrow.png dd_icon-cdblurp.png dd_date-trigger.png
Loading…
Cancel
Save