mirror of
https://github.com/SteamDeckHomebrew/decky-loader.git
synced 2026-06-14 09:34:01 +03:00
* Plugin callsigns, filechangehandler thread bug fix, plugin file perms - Plugins are now assigned a callsign (a random string), which they use for all internal identification, like resource fetching and method calls. This is to ensure that plugins only access their own resources and methods. - Made FileChangeHandler send off events to a queue, that is then consumed by the Loader, instead of calling import_plugin on its own, since that caused weird issues with the event loop and the thread watchdog is using. - Plugins are now owned by root and have read-only permissions. This is handled automatically. * Improved general look and feel of plugin tab * Make all plugin entries have the same padding between them * Make "No plugins installed" text look the same as "No new notifications" Co-authored-by: WerWolv <werwolv98@gmail.com>
98 lines
4.6 KiB
JavaScript
98 lines
4.6 KiB
JavaScript
function reloadIframe() {
|
|
document.getElementById("plugin_iframe").contentWindow.location.href = "http://127.0.0.1:1337/plugins/iframe";
|
|
}
|
|
|
|
function resolveMethodCall(call_id, result) {
|
|
let iframe = document.getElementById("plugin_iframe").contentWindow;
|
|
iframe.postMessage({'call_id': call_id, 'result': result}, "http://127.0.0.1:1337");
|
|
}
|
|
|
|
function installPlugin(request_id) {
|
|
let id = `${new Date().getTime()}`;
|
|
console.debug(JSON.stringify({
|
|
"id": id,
|
|
"method": "confirm_plugin_install",
|
|
"args": {"request_id": request_id}
|
|
}));
|
|
document.getElementById('plugin_install_list').removeChild(document.getElementById(`plugin_install_prompt_${request_id}`));
|
|
}
|
|
|
|
function addPluginInstallPrompt(artifact, version, request_id) {
|
|
let text = `
|
|
<link rel="stylesheet" href="/static/styles.css">
|
|
|
|
<div id="plugin_install_prompt_${request_id}" style="background-color: #0c131b; display: block; border: 1px solid #22262f; box-shadow: 0px 0px 8px #202020; width: calc(100% - 50px); padding: 0px 10px 10px 10px;">
|
|
<h3>Install Plugin?</h3>
|
|
<p style="font-size: 12px;">
|
|
${artifact}
|
|
Version: ${version}
|
|
</p>
|
|
<button type="button" tabindex="0" class="DialogButton _DialogLayout Secondary basicdialog_Button_1Ievp Focusable"
|
|
onclick="installPlugin('${request_id}')">
|
|
Install
|
|
</button>
|
|
<p style="margin: 2px;"></p>
|
|
<button type="button" tabindex="0" class="DialogButton _DialogLayout Secondary basicdialog_Button_1Ievp Focusable"
|
|
onclick="document.getElementById('plugin_install_list').removeChild(document.getElementById('plugin_install_prompt_${request_id}'))">
|
|
Cancel
|
|
</button>
|
|
</div>
|
|
`;
|
|
document.getElementById('plugin_install_list').innerHTML = text;
|
|
|
|
execute_in_tab('SP', false, 'FocusNavController.DispatchVirtualButtonClick(28)')
|
|
}
|
|
|
|
(function () {
|
|
const PLUGIN_ICON = `
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-plugin" viewBox="0 0 16 16">
|
|
<path fill-rule="evenodd" d="M1 8a7 7 0 1 1 2.898 5.673c-.167-.121-.216-.406-.002-.62l1.8-1.8a3.5 3.5 0 0 0
|
|
4.572-.328l1.414-1.415a.5.5 0 0 0 0-.707l-.707-.707 1.559-1.563a.5.5 0 1 0-.708-.706l-1.559 1.562-1.414-1.414
|
|
1.56-1.562a.5.5 0 1 0-.707-.706l-1.56 1.56-.707-.706a.5.5 0 0 0-.707 0L5.318 5.975a3.5 3.5 0 0 0-.328
|
|
4.571l-1.8 1.8c-.58.58-.62 1.6.121 2.137A8 8 0 1 0 0 8a.5.5 0 0 0 1 0Z"/>
|
|
</svg>
|
|
`;
|
|
|
|
function createTitle(text) {
|
|
return `<div id="plugin_title" class="quickaccessmenu_Title_34nl5">${text}</div>`;
|
|
}
|
|
|
|
function createPluginList() {
|
|
let pages = document.getElementsByClassName("quickaccessmenu_AllTabContents_2yKG4 quickaccessmenu_Down_3rR0o")[0];
|
|
let pluginPage = pages.children[pages.children.length - 1];
|
|
pluginPage.innerHTML = createTitle("Plugins");
|
|
|
|
pluginPage.innerHTML += `<div id="plugin_install_list" style="position: fixed; height: 100%; z-index: 99; transform: translate(5%, 0);"></div>`
|
|
|
|
pluginPage.innerHTML += `<iframe id="plugin_iframe" style="border: none; width: 100%; height: 100%;" src="http://127.0.0.1:1337/plugins/iframe"></iframe>`;
|
|
}
|
|
|
|
function inject() {
|
|
let tabs = document.getElementsByClassName("quickaccessmenu_TabContentColumn_2z5NL Panel Focusable")[0];
|
|
tabs.children[tabs.children.length - 1].innerHTML = PLUGIN_ICON;
|
|
|
|
createPluginList();
|
|
}
|
|
|
|
let injector = setInterval(function () {
|
|
if (document.hasFocus()) {
|
|
inject();
|
|
document.getElementById("plugin_title").onclick = function() {
|
|
reloadIframe();
|
|
document.getElementById("plugin_title").innerText = "Plugins";
|
|
}
|
|
window.onmessage = function(ev) {
|
|
let title = ev.data;
|
|
if (title.startsWith("PLUGIN_LOADER__")) {
|
|
document.getElementById("plugin_title").innerHTML = `
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-arrow-left-square-fill" viewBox="0 0 16 16">
|
|
<path d="M16 14a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V2a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12zm-4.5-6.5H5.707l2.147-2.146a.5.5 0 1 0-.708-.708l-3 3a.5.5 0 0 0 0 .708l3 3a.5.5 0 0 0 .708-.708L5.707 8.5H11.5a.5.5 0 0 0 0-1z"/>
|
|
</svg>
|
|
${title.replace("PLUGIN_LOADER__", "")}
|
|
`;
|
|
}
|
|
}
|
|
clearInterval(injector);
|
|
}
|
|
}, 100);
|
|
})(); |