2022-10-10 20:50:21 +08:00
import type { CommandDef } from "../../web/hooks/command.ts" ;
import { syscall } from "./syscall.ts" ;
2022-04-01 23:07:08 +08:00
2022-10-10 20:50:21 +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
2023-11-26 01:57:00 +08:00
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
2022-10-10 20:50:21 +08:00
export function listCommands ( ) : Promise < { [ key : string ] : CommandDef } > {
2022-09-06 20:36:06 +08:00
return syscall ( "system.listCommands" ) ;
}
2022-10-10 20:50:21 +08:00
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" ) ;
}
2024-01-27 00:05:10 +08:00
export function getMode ( ) : Promise < "ro" | "rw" > {
return syscall ( "system.getMode" ) ;
}