2022-06-28 20:14:15 +08:00
|
|
|
import { dispatch } from "@plugos/plugos-syscall/event";
|
2022-06-29 21:02:53 +08:00
|
|
|
import { Manifest } from "@silverbulletmd/common/manifest";
|
|
|
|
import {
|
|
|
|
flashNotification,
|
|
|
|
save,
|
|
|
|
} from "@silverbulletmd/plugos-silverbullet-syscall/editor";
|
2022-06-28 20:14:15 +08:00
|
|
|
import {
|
|
|
|
deletePage,
|
|
|
|
listPages,
|
|
|
|
writePage,
|
|
|
|
} from "@silverbulletmd/plugos-silverbullet-syscall/space";
|
|
|
|
import {
|
|
|
|
invokeFunction,
|
|
|
|
reloadPlugs,
|
|
|
|
} from "@silverbulletmd/plugos-silverbullet-syscall/system";
|
2022-07-15 17:17:02 +08:00
|
|
|
|
|
|
|
import { readYamlPage } from "../lib/yaml_page";
|
2022-06-28 20:14:15 +08:00
|
|
|
|
|
|
|
async function listPlugs(): Promise<string[]> {
|
|
|
|
let unfilteredPages = await listPages(true);
|
|
|
|
return unfilteredPages
|
|
|
|
.filter((p) => p.name.startsWith("_plug/"))
|
|
|
|
.map((p) => p.name.substring("_plug/".length));
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function updatePlugsCommand() {
|
2022-06-29 21:02:53 +08:00
|
|
|
await save();
|
2022-06-28 20:14:15 +08:00
|
|
|
flashNotification("Updating plugs...");
|
2022-07-15 17:17:02 +08:00
|
|
|
try {
|
|
|
|
await invokeFunction("server", "updatePlugs");
|
|
|
|
flashNotification("And... done!");
|
|
|
|
await reloadPlugs();
|
|
|
|
} catch (e: any) {
|
|
|
|
flashNotification("Error updating plugs: " + e.message, "error");
|
|
|
|
}
|
2022-06-28 20:14:15 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
export async function updatePlugs() {
|
2022-07-15 17:17:02 +08:00
|
|
|
let plugList: string[] = [];
|
|
|
|
try {
|
|
|
|
plugList = await readYamlPage("PLUGS");
|
|
|
|
} catch (e: any) {
|
|
|
|
throw new Error(`Error processing PLUGS: ${e.message}`);
|
2022-06-28 20:14:15 +08:00
|
|
|
}
|
|
|
|
console.log("Plug YAML", plugList);
|
|
|
|
let allPlugNames: string[] = [];
|
|
|
|
for (let plugUri of plugList) {
|
|
|
|
let [protocol, ...rest] = plugUri.split(":");
|
|
|
|
let manifests = await dispatch(`get-plug:${protocol}`, rest.join(":"));
|
|
|
|
if (manifests.length === 0) {
|
|
|
|
console.error("Could not resolve plug", plugUri);
|
|
|
|
}
|
|
|
|
// console.log("Got manifests", plugUri, protocol, manifests);
|
|
|
|
let manifest = manifests[0];
|
|
|
|
allPlugNames.push(manifest.name);
|
|
|
|
// console.log("Writing", `_plug/${manifest.name}`);
|
|
|
|
await writePage(
|
|
|
|
`_plug/${manifest.name}`,
|
|
|
|
JSON.stringify(manifest, null, 2)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
// And delete extra ones
|
|
|
|
for (let existingPlug of await listPlugs()) {
|
|
|
|
if (!allPlugNames.includes(existingPlug)) {
|
|
|
|
console.log("Removing plug", existingPlug);
|
|
|
|
await deletePage(`_plug/${existingPlug}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await reloadPlugs();
|
|
|
|
}
|
2022-06-29 21:02:53 +08:00
|
|
|
|
|
|
|
export async function getPlugHTTPS(url: string): Promise<Manifest> {
|
|
|
|
let fullUrl = `https:${url}`;
|
|
|
|
console.log("Now fetching plug manifest from", fullUrl);
|
|
|
|
let req = await fetch(fullUrl);
|
|
|
|
if (req.status !== 200) {
|
|
|
|
throw new Error(`Could not fetch plug manifest from ${fullUrl}`);
|
|
|
|
}
|
|
|
|
let json = await req.json();
|
|
|
|
|
|
|
|
return json;
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function getPlugGithub(identifier: string): Promise<Manifest> {
|
|
|
|
let [owner, repo, path] = identifier.split("/");
|
|
|
|
let [repoClean, branch] = repo.split("@");
|
|
|
|
if (!branch) {
|
|
|
|
branch = "main"; // or "master"?
|
|
|
|
}
|
|
|
|
return getPlugHTTPS(
|
|
|
|
`//raw.githubusercontent.com/${owner}/${repoClean}/${branch}/${path}`
|
|
|
|
);
|
|
|
|
}
|