2024-07-30 23:33:33 +08:00
|
|
|
import type { System } from "./system.ts";
|
|
|
|
import type { AssetJson } from "../asset_bundle/bundle.ts";
|
2022-03-20 16:56:28 +08:00
|
|
|
|
2023-08-20 13:24:17 +08:00
|
|
|
/** The generic top level of a plug manifest file.
|
|
|
|
* Defines plug metadata and functions.
|
|
|
|
*/
|
2022-03-20 16:56:28 +08:00
|
|
|
export interface Manifest<HookT> {
|
2023-08-20 13:24:17 +08:00
|
|
|
/** The plug's name. Typically this is the name of the manifest file, without the file extension. */
|
2022-04-27 01:04:36 +08:00
|
|
|
name: string;
|
2023-08-20 13:24:17 +08:00
|
|
|
|
|
|
|
/** A list of syscall permissions required for this plug to function.
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* Possible values:
|
|
|
|
* - `fetch`: enables `fetch` function. (see: plug-api/plugos-syscall/fetch.ts, and plug-api/lib/fetch.ts)
|
|
|
|
* - `shell`: enables the `shell.run` syscall. (see: plug-api/plugos-syscall/shell.ts)
|
|
|
|
*/
|
2022-03-25 19:03:06 +08:00
|
|
|
requiredPermissions?: string[];
|
2023-08-20 13:24:17 +08:00
|
|
|
|
|
|
|
/** A list of files or glob patterns that should be bundled with the plug.
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* These files will be accessible through the `asset.readAsset` function.
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* see: plug-api/plugos-syscall/asset.ts#readAsset
|
|
|
|
*/
|
2022-10-12 17:47:13 +08:00
|
|
|
assets?: string[] | AssetJson;
|
2023-08-20 13:24:17 +08:00
|
|
|
|
|
|
|
/** A map of function names to definitions. Declared functions are public, and may be associated with various hooks
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* see: common/manifest.ts#SilverBulletHooks
|
|
|
|
*/
|
2023-08-27 20:13:18 +08:00
|
|
|
functions: Record<string, FunctionDef<HookT>>;
|
2022-03-20 16:56:28 +08:00
|
|
|
}
|
|
|
|
|
2023-08-20 13:24:17 +08:00
|
|
|
/** Associates hooks with a function. This is the generic base structure, that identifies the function. Hooks are defined by the type parameter. */
|
2022-03-27 17:26:13 +08:00
|
|
|
export type FunctionDef<HookT> = {
|
2023-08-20 13:24:17 +08:00
|
|
|
/** A function path, in the form `${relativeFilename}:${functionName}`.
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* During compilation (see `../build_plugs.ts`) the function is read from the file and inlined into the plug bundle.
|
2023-08-27 20:13:18 +08:00
|
|
|
*
|
2023-08-20 13:24:17 +08:00
|
|
|
* This field and `FunctionDef.redirect` are mutually exclusive.
|
|
|
|
*/
|
2022-03-20 16:56:28 +08:00
|
|
|
path?: string;
|
2023-08-20 13:24:17 +08:00
|
|
|
|
|
|
|
/** A function from another plug, in the form `${plugName}.${functionName}` that will be attached to the given hooks. */
|
2022-10-28 22:17:40 +08:00
|
|
|
redirect?: string;
|
2023-08-20 13:24:17 +08:00
|
|
|
|
|
|
|
/** Environments where this plug is allowed to run, current may be one of "cli", "server", or "client". */
|
2023-08-05 00:56:55 +08:00
|
|
|
env?: string;
|
2022-03-27 17:26:13 +08:00
|
|
|
} & HookT;
|
2022-03-20 16:56:28 +08:00
|
|
|
|
2022-03-29 17:21:32 +08:00
|
|
|
export interface Hook<HookT> {
|
2022-03-23 22:41:12 +08:00
|
|
|
validateManifest(manifest: Manifest<HookT>): string[];
|
|
|
|
apply(system: System<HookT>): void;
|
2022-03-20 16:56:28 +08:00
|
|
|
}
|