summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAAGaming <aa@mail.catvibers.me>2022-08-24 23:51:20 -0400
committerAAGaming <aa@mail.catvibers.me>2022-08-24 23:51:20 -0400
commit79db0c779d6942c6bdc6823a5faef57b5307f7b3 (patch)
tree3ba46c46750d7cdfc04f6c14191e0dd1177c170f
parentfe2b6b02831c918c25d88604df94d8d2f360b75a (diff)
downloaddecky-loader-79db0c779d6942c6bdc6823a5faef57b5307f7b3.tar.gz
decky-loader-79db0c779d6942c6bdc6823a5faef57b5307f7b3.zip
Settings API for loader, preview branch select
-rw-r--r--backend/main.py7
-rw-r--r--backend/settings.py38
-rw-r--r--backend/utilities.py9
-rw-r--r--frontend/src/components/settings/pages/general/BranchSelect.tsx33
-rw-r--r--frontend/src/components/settings/pages/general/RemoteDebugging.tsx13
-rw-r--r--frontend/src/components/settings/pages/general/Updater.tsx3
-rw-r--r--frontend/src/components/settings/pages/general/index.tsx2
-rw-r--r--frontend/src/utils/hooks/useSetting.ts39
8 files changed, 127 insertions, 17 deletions
diff --git a/backend/main.py b/backend/main.py
index a5730fbd..41ecfc77 100644
--- a/backend/main.py
+++ b/backend/main.py
@@ -18,6 +18,7 @@ from injector import inject_to_tab, tab_has_global_var
from loader import Loader
from updater import Updater
from utilities import Utilities
+from settings import SettingsManager
# Ensure USER and GROUP vars are set first.
# TODO: This isn't the best way to do this but supports the current
@@ -48,9 +49,6 @@ async def chown_plugin_dir(_):
if code_chown != 0 or code_chmod != 0:
logger.error(f"chown/chmod exited with a non-zero exit code (chown: {code_chown}, chmod: {code_chmod})")
-def remote_debugging_allowed():
- return path.exists(HOMEBREW_PATH + "/allow_remote_debugging")
-
class PluginManager:
def __init__(self) -> None:
self.loop = get_event_loop()
@@ -62,6 +60,7 @@ class PluginManager:
})
self.plugin_loader = Loader(self.web_app, CONFIG["plugin_path"], self.loop, CONFIG["live_reload"])
self.plugin_browser = PluginBrowser(CONFIG["plugin_path"], self.web_app, self.plugin_loader.plugins)
+ self.settings = SettingsManager("loader", path.join(HOMEBREW_PATH, "settings"))
self.utilities = Utilities(self)
self.updater = Updater(self)
@@ -70,7 +69,7 @@ class PluginManager:
self.web_app.on_startup.append(chown_plugin_dir)
self.loop.create_task(self.loader_reinjector())
self.loop.create_task(self.load_plugins())
- if not remote_debugging_allowed():
+ if not self.settings.getSetting("cef_forward", False):
self.loop.create_task(stop_systemd_unit(REMOTE_DEBUGGER_UNIT))
self.loop.set_exception_handler(self.exception_handler)
self.web_app.add_routes([get("/auth/token", self.get_auth_token)])
diff --git a/backend/settings.py b/backend/settings.py
new file mode 100644
index 00000000..03718dab
--- /dev/null
+++ b/backend/settings.py
@@ -0,0 +1,38 @@
+from os import path, mkdir
+from json import load, dump
+
+class SettingsManager:
+ def __init__(self, name, settings_directory) -> None:
+ self.path = path.join(settings_directory, name + ".json")
+
+ if not path.exists(settings_directory):
+ mkdir(settings_directory)
+
+ self.settings = {}
+
+ try:
+ open(self.path, "x")
+ except FileExistsError as e:
+ self.read()
+ pass
+
+ def read(self):
+ try:
+ with open(self.path, "r") as file:
+ self.settings = load(file)
+ except Exception as e:
+ print(e)
+ pass
+
+ def commit(self):
+ with open(self.path, "w+") as file:
+ dump(self.settings, file, indent=4)
+
+ def getSetting(self, key, default):
+ if key in self.settings:
+ return self.settings[key]
+ return default
+
+ def setSetting(self, key, value):
+ self.settings[key] = value
+ self.commit() \ No newline at end of file
diff --git a/backend/utilities.py b/backend/utilities.py
index 9c0c6388..e06e770d 100644
--- a/backend/utilities.py
+++ b/backend/utilities.py
@@ -20,7 +20,8 @@ class Utilities:
"remove_css_from_tab": self.remove_css_from_tab,
"allow_remote_debugging": self.allow_remote_debugging,
"disallow_remote_debugging": self.disallow_remote_debugging,
- "remote_debugging_allowed": self.remote_debugging_allowed
+ "set_setting": self.set_setting,
+ "get_setting": self.get_setting
}
if context:
@@ -138,9 +139,11 @@ class Utilities:
"result": e
}
+ async def get_setting(self, key, default):
+ return self.context.settings.getSetting(key, default)
- async def remote_debugging_allowed(self):
- return await helpers.is_systemd_unit_active(helpers.REMOTE_DEBUGGER_UNIT)
+ async def set_setting(self, key, value):
+ return self.context.settings.setSetting(key, value)
async def allow_remote_debugging(self):
await helpers.start_systemd_unit(helpers.REMOTE_DEBUGGER_UNIT)
diff --git a/frontend/src/components/settings/pages/general/BranchSelect.tsx b/frontend/src/components/settings/pages/general/BranchSelect.tsx
new file mode 100644
index 00000000..91e814e5
--- /dev/null
+++ b/frontend/src/components/settings/pages/general/BranchSelect.tsx
@@ -0,0 +1,33 @@
+import { Dropdown, Field } from 'decky-frontend-lib';
+import { FunctionComponent } from 'react';
+
+import { useSetting } from '../../../../utils/hooks/useSetting';
+
+enum UpdateBranch {
+ Stable,
+ Prerelease,
+ Nightly,
+}
+
+const BranchSelect: FunctionComponent<{}> = () => {
+ const [selectedBranch, setSelectedBranch] = useSetting<UpdateBranch>('branch', UpdateBranch.Prerelease);
+
+ return (
+ <Field label="Update Channel">
+ <Dropdown
+ rgOptions={Object.values(UpdateBranch)
+ .filter((branch) => typeof branch == 'string')
+ .map((branch) => ({
+ label: branch,
+ data: UpdateBranch[branch],
+ }))}
+ selectedOption={selectedBranch}
+ onChange={(newVal) => {
+ setSelectedBranch(newVal.data);
+ }}
+ />
+ </Field>
+ );
+};
+
+export default BranchSelect;
diff --git a/frontend/src/components/settings/pages/general/RemoteDebugging.tsx b/frontend/src/components/settings/pages/general/RemoteDebugging.tsx
index 3fea0513..36badf45 100644
--- a/frontend/src/components/settings/pages/general/RemoteDebugging.tsx
+++ b/frontend/src/components/settings/pages/general/RemoteDebugging.tsx
@@ -1,15 +1,10 @@
import { Field, Toggle } from 'decky-frontend-lib';
-import { useEffect, useState } from 'react';
import { FaBug } from 'react-icons/fa';
+import { useSetting } from '../../../../utils/hooks/useSetting';
+
export default function RemoteDebuggingSettings() {
- const [allowRemoteDebugging, setAllowRemoteDebugging] = useState<boolean>(false);
- useEffect(() => {
- (async () => {
- const res = (await window.DeckyPluginLoader.callServerMethod('remote_debugging_allowed')) as { result: boolean };
- setAllowRemoteDebugging(res.result);
- })();
- }, []);
+ const [allowRemoteDebugging, setAllowRemoteDebugging] = useSetting<boolean>('cef_forward', false);
return (
<Field
@@ -22,7 +17,7 @@ export default function RemoteDebuggingSettings() {
icon={<FaBug style={{ display: 'block' }} />}
>
<Toggle
- value={allowRemoteDebugging}
+ value={allowRemoteDebugging || false}
onChange={(toggleValue) => {
setAllowRemoteDebugging(toggleValue);
if (toggleValue) window.DeckyPluginLoader.callServerMethod('allow_remote_debugging');
diff --git a/frontend/src/components/settings/pages/general/Updater.tsx b/frontend/src/components/settings/pages/general/Updater.tsx
index e0abe0a0..f7e4a29d 100644
--- a/frontend/src/components/settings/pages/general/Updater.tsx
+++ b/frontend/src/components/settings/pages/general/Updater.tsx
@@ -6,9 +6,10 @@ import { VerInfo, callUpdaterMethod, finishUpdate } from '../../../../updater';
import { useDeckyState } from '../../../DeckyState';
export default function UpdaterSettings() {
+ const { isLoaderUpdating, setIsLoaderUpdating } = useDeckyState();
+
const [versionInfo, setVersionInfo] = useState<VerInfo | null>(null);
const [checkingForUpdates, setCheckingForUpdates] = useState<boolean>(false);
- const { isLoaderUpdating, setIsLoaderUpdating } = useDeckyState();
const [updateProgress, setUpdateProgress] = useState<number>(-1);
const [reloading, setReloading] = useState<boolean>(false);
diff --git a/frontend/src/components/settings/pages/general/index.tsx b/frontend/src/components/settings/pages/general/index.tsx
index c6680026..a37d8dab 100644
--- a/frontend/src/components/settings/pages/general/index.tsx
+++ b/frontend/src/components/settings/pages/general/index.tsx
@@ -3,6 +3,7 @@ import { useState } from 'react';
import { FaShapes } from 'react-icons/fa';
import { installFromURL } from '../../../../store';
+import BranchSelect from './BranchSelect';
import RemoteDebuggingSettings from './RemoteDebugging';
import UpdaterSettings from './Updater';
@@ -21,6 +22,7 @@ export default function GeneralSettings() {
/>
</Field> */}
<UpdaterSettings />
+ <BranchSelect />
<RemoteDebuggingSettings />
<Field
label="Manual plugin install"
diff --git a/frontend/src/utils/hooks/useSetting.ts b/frontend/src/utils/hooks/useSetting.ts
new file mode 100644
index 00000000..2425ed16
--- /dev/null
+++ b/frontend/src/utils/hooks/useSetting.ts
@@ -0,0 +1,39 @@
+import { useEffect, useState } from 'react';
+
+interface GetSettingArgs<T> {
+ key: string;
+ default: T;
+}
+
+interface SetSettingArgs<T> {
+ key: string;
+ value: T;
+}
+
+export function useSetting<T>(key: string, def: T): [value: T | null, setValue: (value: T) => void] {
+ const [value, setValue] = useState(def);
+ const [ready, setReady] = useState<boolean>(false);
+
+ useEffect(() => {
+ (async () => {
+ const res = (await window.DeckyPluginLoader.callServerMethod('get_setting', {
+ key,
+ default: def,
+ } as GetSettingArgs<T>)) as { result: T };
+ setReady(true);
+ setValue(res.result);
+ })();
+ }, []);
+
+ useEffect(() => {
+ if (ready)
+ (async () => {
+ await window.DeckyPluginLoader.callServerMethod('set_setting', {
+ key,
+ value,
+ } as SetSettingArgs<T>);
+ })();
+ }, [value]);
+
+ return [value, setValue];
+}