silverbullet/common/manifest.ts

35 lines
1.3 KiB
TypeScript
Raw Normal View History

import * as plugos from "../plugos/types.ts";
import { CronHookT } from "../plugos/hooks/cron.ts";
import { EventHookT } from "../plugos/hooks/event.ts";
import { CommandHookT } from "./hooks/command.ts";
import { SlashCommandHookT } from "../web/hooks/slash_command.ts";
2023-07-14 22:48:35 +08:00
import { PlugNamespaceHookT } from "./hooks/plug_namespace.ts";
2022-12-22 23:20:05 +08:00
import { CodeWidgetT } from "../web/hooks/code_widget.ts";
2023-08-11 00:32:41 +08:00
import { MQHookT } from "../plugos/hooks/mq.ts";
2023-08-12 02:37:13 +08:00
import { EndpointHookT } from "../plugos/hooks/endpoint.ts";
import { PanelWidgetT } from "../web/hooks/panel_widget.ts";
/** Silverbullet hooks give plugs access to silverbullet core systems.
*
* Hooks are associated with typescript functions through a manifest file.
* On various triggers (user enters a slash command, an HTTP endpoint is hit, user clicks, etc) the typescript function is called.
*
* related: plugos/type.ts#FunctionDef
*/
export type SilverBulletHooks =
& CommandHookT
& SlashCommandHookT
& CronHookT
2023-08-11 00:32:41 +08:00
& MQHookT
& EventHookT
2022-12-22 23:20:05 +08:00
& CodeWidgetT
& PanelWidgetT
2023-08-12 02:37:13 +08:00
& EndpointHookT
2023-07-14 22:48:35 +08:00
& PlugNamespaceHookT;
/** A plug manifest configures hooks, declares syntax extensions, and describes plug metadata.
*
* Typically the manifest file is in a plug's root directory, named `${plugName}.plug.yaml`.
*/
2024-01-24 20:34:12 +08:00
export type Manifest = plugos.Manifest<SilverBulletHooks>;