silverbullet/plug-api/syscalls/system.ts

38 lines
1.1 KiB
TypeScript
Raw Normal View History

import type { CommandDef } from "$common/hooks/command.ts";
import { SyscallMeta } from "$type/types.ts";
import { syscall } from "../syscall.ts";
2022-04-01 23:07:08 +08:00
export function invokeFunction(
2022-04-01 23:07:08 +08:00
name: string,
...args: any[]
): Promise<any> {
2023-08-28 23:12:15 +08:00
return syscall("system.invokeFunction", name, ...args);
2022-04-01 23:07:08 +08:00
}
2022-04-27 01:04:36 +08:00
2022-09-06 20:36:06 +08:00
// Only available on the client
export function invokeCommand(name: string, args?: string[]): Promise<any> {
return syscall("system.invokeCommand", name, args);
2022-07-11 15:08:22 +08:00
}
2022-09-06 20:36:06 +08:00
// Only available on the client
export function listCommands(): Promise<{ [key: string]: CommandDef }> {
2022-09-06 20:36:06 +08:00
return syscall("system.listCommands");
}
export function listSyscalls(): Promise<SyscallMeta[]> {
return syscall("system.listSyscalls");
}
export function reloadPlugs() {
2022-04-27 02:31:31 +08:00
syscall("system.reloadPlugs");
2022-04-27 01:04:36 +08:00
}
2023-01-15 01:51:00 +08:00
// Returns what runtime environment this plug is run in, e.g. "server" or "client" can be undefined, which would mean a hybrid environment (such as mobile)
export function getEnv(): Promise<string | undefined> {
return syscall("system.getEnv");
}
export function getMode(): Promise<"ro" | "rw"> {
return syscall("system.getMode");
}