Compare commits
2 Commits
f5abc5a54b
...
3b40a9d62f
Author | SHA1 | Date | |
---|---|---|---|
3b40a9d62f | |||
71c14465b2 |
66
ObsidianUpdateChecker/main.py
Normal file
66
ObsidianUpdateChecker/main.py
Normal file
@ -0,0 +1,66 @@
|
||||
# Import json parsing and urllib
|
||||
import json
|
||||
import urllib.request
|
||||
# Import subprocess for running dpkg
|
||||
import subprocess
|
||||
|
||||
# Endpoint for the latest release
|
||||
API_URL = "https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest"
|
||||
|
||||
# DEB file name, will be filled in later
|
||||
DEB_NAME = ""
|
||||
# URL for the latest deb file, will be filled in later
|
||||
DEB_URL = ""
|
||||
# Version number, will be filled in later
|
||||
DEB_VERSION = ""
|
||||
# Installed version number, will be filled in later
|
||||
INSTALLED_VERSION = ""
|
||||
|
||||
# Get the latest release from the API
|
||||
with urllib.request.urlopen(API_URL) as url:
|
||||
data = json.loads(url.read().decode())
|
||||
assets = data["assets"]
|
||||
for asset in assets
|
||||
if asset["name"].endswith(".deb"):
|
||||
DEB_NAME = asset["name"]
|
||||
DEB_URL = asset["browser_download_url"]
|
||||
|
||||
# Parse the version number from the deb file name
|
||||
# Example: obsidian_0.12.15_amd64.deb -> 0.12.15
|
||||
DEB_VERSION = DEB_NAME.split("_")[1]
|
||||
|
||||
print("Latest version: " + DEB_VERSION)
|
||||
|
||||
# Get the installed version number by parsing the output of dpkg -s obsidian
|
||||
output = subprocess.run(["dpkg", "-s", "obsidian"], capture_output=True)
|
||||
# Parse the output for the version number
|
||||
# Example: Version: 0.12.15
|
||||
for line in output.stdout.decode().split("\n"):
|
||||
if line.startswith("Version:"):
|
||||
INSTALLED_VERSION = line.split(" ")[1]
|
||||
|
||||
print("Installed version: " + INSTALLED_VERSION)
|
||||
|
||||
def semver_check_new(old, new):
|
||||
# Split the version numbers into arrays of numbers
|
||||
old_split = old.split(".")
|
||||
new_split = new.split(".")
|
||||
# Loop through the numbers
|
||||
for i in range(len(old_split)):
|
||||
# If the new version is higher, return true
|
||||
if int(new_split[i]) > int(old_split[i]):
|
||||
return True
|
||||
# If the new version is the same or lower, return false
|
||||
return False
|
||||
|
||||
# Check if the new version is higher than the installed version
|
||||
if semver_check_new(INSTALLED_VERSION, DEB_VERSION):
|
||||
print("New version available!")
|
||||
# Download the deb file
|
||||
urllib.request.urlretrieve(DEB_URL, DEB_NAME)
|
||||
# Install the deb file
|
||||
subprocess.run(["pkexec", "apt", "install", f"./{DEB_NAME}"])
|
||||
# Remove the deb file
|
||||
subprocess.run(["rm", DEB_NAME])
|
||||
else:
|
||||
print("No new version available")
|
120
OpenAsarInjector/main.py
Normal file
120
OpenAsarInjector/main.py
Normal file
@ -0,0 +1,120 @@
|
||||
ASAR = "app.asar"
|
||||
ASAR_BACKUP = ASAR + ".bak"
|
||||
SYMLINK_PATH = ""
|
||||
REAL_PATH = ""
|
||||
DISCORD_FOLDER = ""
|
||||
RESOURCES_PATH = ""
|
||||
|
||||
def root():
|
||||
import os
|
||||
if os.geteuid() != 0:
|
||||
print("Script not running as root")
|
||||
exit()
|
||||
|
||||
def backup():
|
||||
import os
|
||||
# Check for existing backup
|
||||
if os.path.isfile(RESOURCES_PATH + ASAR_BACKUP):
|
||||
print("Backup already exists, openasar is already installed")
|
||||
exit()
|
||||
try:
|
||||
print(RESOURCES_PATH + ASAR)
|
||||
os.rename(RESOURCES_PATH + ASAR, RESOURCES_PATH + ASAR_BACKUP)
|
||||
except Exception as e:
|
||||
print("Couldn't rename file: " + str(e))
|
||||
|
||||
def find():
|
||||
import os
|
||||
from shutil import which
|
||||
|
||||
# Get full path of discord symlink on path
|
||||
global SYMLINK_PATH
|
||||
SYMLINK_PATH = which("discord")
|
||||
# Parse real path of discord symlink
|
||||
global REAL_PATH
|
||||
REAL_PATH = os.path.realpath(SYMLINK_PATH)
|
||||
# Get containing folder
|
||||
global DISCORD_FOLDER
|
||||
DISCORD_FOLDER = os.path.dirname(REAL_PATH)
|
||||
# Add /resources/ to the real path
|
||||
global RESOURCES_PATH
|
||||
RESOURCES_PATH = DISCORD_FOLDER + "/resources/"
|
||||
|
||||
|
||||
def download():
|
||||
import urllib.request
|
||||
import json
|
||||
# Get nightly release from github
|
||||
# url: https://github.com/GooseMod/OpenAsar/
|
||||
# release: https://github.com/GooseMod/OpenAsar/releases/tag/nightly
|
||||
API_URL = "https://api.github.com/repos/GooseMod/OpenAsar/releases/latest"
|
||||
DOWNLOAD_URL = ""
|
||||
|
||||
with urllib.request.urlopen(API_URL) as url:
|
||||
data = json.loads(url.read().decode())
|
||||
DOWNLOAD_URL = data['assets'][0]['browser_download_url']
|
||||
|
||||
# Download the file
|
||||
urllib.request.urlretrieve(DOWNLOAD_URL, RESOURCES_PATH + ASAR)
|
||||
|
||||
def kill():
|
||||
import os
|
||||
import signal
|
||||
import psutil
|
||||
|
||||
# Get discord process
|
||||
for proc in psutil.process_iter():
|
||||
if proc.name() == "Discord":
|
||||
# Kill discord
|
||||
os.kill(proc.pid, signal.SIGTERM)
|
||||
|
||||
def uninstall():
|
||||
import os
|
||||
if os.path.isfile(RESOURCES_PATH + ASAR_BACKUP):
|
||||
try:
|
||||
os.remove(RESOURCES_PATH + ASAR)
|
||||
os.rename(RESOURCES_PATH + ASAR_BACKUP, RESOURCES_PATH + ASAR)
|
||||
except Exception as e:
|
||||
print("Couldn't remove/rename file: " + str(e))
|
||||
else:
|
||||
print("No backup found, openasar is not installed")
|
||||
exit()
|
||||
|
||||
|
||||
# Should check if the package has been updated, as discords asar is much larger
|
||||
def sanity_check():
|
||||
import os
|
||||
# Get file size of asar
|
||||
asar_size = os.path.getsize(RESOURCES_PATH + ASAR)
|
||||
# If the asar is larger than 1MB, discord has probably updated
|
||||
if asar_size > 1000000:
|
||||
print("Discord has probably updated, please clear backups and reinstall")
|
||||
print("Would you like to clear backups? (y/n)")
|
||||
answer = input().lower()
|
||||
if answer == "y":
|
||||
os.remove(RESOURCES_PATH + ASAR_BACKUP)
|
||||
print("Backups cleared, installation will continue as normal")
|
||||
else:
|
||||
print("Backups not cleared, please clean manually")
|
||||
exit()
|
||||
|
||||
|
||||
def main():
|
||||
import sys
|
||||
root()
|
||||
kill()
|
||||
find()
|
||||
sanity_check()
|
||||
if len(sys.argv) > 1:
|
||||
if sys.argv[1] == "uninstall":
|
||||
uninstall()
|
||||
print("Uninstalled openasar")
|
||||
else:
|
||||
print("Unknown argument")
|
||||
else:
|
||||
backup()
|
||||
download()
|
||||
print("Installed openasar")
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
Loading…
Reference in New Issue
Block a user