@rizom/brain 0.2.0-alpha.46 → 0.2.0-alpha.48

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -1,50 +1,64 @@
1
- /** Public root library export for brain definitions and plugin API compatibility. */
2
-
3
- import type { Plugin } from "./plugins";
4
-
5
- export const PLUGIN_API_VERSION: string;
6
-
7
- export type BrainEnvironment = Record<string, string | undefined>;
8
- export type PluginConfig = Record<string, unknown>;
9
- export type CapabilityConfig =
10
- | PluginConfig
11
- | ((env: BrainEnvironment) => PluginConfig)
12
- | undefined;
13
- export type PluginFactory = (config: PluginConfig) => Plugin | Plugin[];
14
- export type CapabilityEntry = [
15
- id: string,
16
- factory: PluginFactory,
17
- config: CapabilityConfig,
1
+ /** Public brain definition contract for external authors. */
2
+ type BrainEnvironment = Record<string, string | undefined>;
3
+ type PluginConfig = Record<string, unknown>;
4
+ interface Plugin {
5
+ readonly id: string;
6
+ readonly version: string;
7
+ readonly type: "core" | "entity" | "service" | "interface";
8
+ readonly packageName: string;
9
+ readonly description?: string;
10
+ readonly dependencies?: string[];
11
+ ready?(): Promise<void>;
12
+ shutdown?(): Promise<void>;
13
+ requiresDaemonStartup?(): boolean;
14
+ }
15
+ type CapabilityConfig = PluginConfig | ((env: BrainEnvironment) => PluginConfig) | undefined;
16
+ type PluginFactory = (config: PluginConfig) => Plugin | Plugin[];
17
+ type CapabilityEntry = [
18
+ id: string,
19
+ factory: PluginFactory,
20
+ config: CapabilityConfig
18
21
  ];
19
- export type InterfaceConstructor = new (config: PluginConfig) => Plugin;
20
- export type InterfaceEntry = [
21
- id: string,
22
- constructor: InterfaceConstructor,
23
- envMapper: (env: BrainEnvironment) => PluginConfig | null,
22
+ type InterfaceConstructor = new (config: PluginConfig) => Plugin;
23
+ type InterfaceEntry = [
24
+ id: string,
25
+ constructor: InterfaceConstructor,
26
+ envMapper: (env: BrainEnvironment) => PluginConfig | null
24
27
  ];
25
- export type PresetName = "core" | "default" | "full";
26
- export type BrainMode = "eval";
27
-
28
- export interface BrainIdentity {
29
- characterName: string;
30
- role: string;
31
- purpose: string;
32
- values: string[];
28
+ type PresetName = "core" | "default" | "full";
29
+ type BrainMode = "eval";
30
+ interface BrainIdentity {
31
+ characterName: string;
32
+ role: string;
33
+ purpose: string;
34
+ values: string[];
33
35
  }
34
- export interface BrainDefinition {
35
- name: string;
36
- version: string;
37
- model?: string;
38
- identity?: BrainIdentity;
39
- site?: unknown;
40
- theme?: string;
41
- capabilities: CapabilityEntry[];
42
- interfaces: InterfaceEntry[];
43
- presets?: Partial<Record<PresetName, string[]>>;
44
- defaultPreset?: PresetName;
45
- permissions?: unknown;
46
- deployment?: unknown;
47
- evalDisable?: string[];
48
- extra?: Record<string, unknown>;
36
+ interface BrainDefinition {
37
+ name: string;
38
+ version: string;
39
+ model?: string;
40
+ identity?: BrainIdentity;
41
+ site?: unknown;
42
+ theme?: string;
43
+ capabilities: CapabilityEntry[];
44
+ interfaces: InterfaceEntry[];
45
+ presets?: Partial<Record<PresetName, string[]>>;
46
+ defaultPreset?: PresetName;
47
+ permissions?: unknown;
48
+ deployment?: unknown;
49
+ evalDisable?: string[];
50
+ extra?: Record<string, unknown>;
49
51
  }
50
- export function defineBrain(definition: BrainDefinition): BrainDefinition;
52
+ declare function defineBrain(definition: BrainDefinition): BrainDefinition;
53
+
54
+ /**
55
+ * Pre-v1 external plugin API marker.
56
+ *
57
+ * During alpha, the external plugin API compatibility marker tracks the
58
+ * published @rizom/brain package version. Once the plugin API is declared
59
+ * stable, this can move to an independent semver contract such as 1.0.0.
60
+ */
61
+ declare const PLUGIN_API_VERSION: string;
62
+
63
+ export { PLUGIN_API_VERSION, defineBrain };
64
+ export type { BrainDefinition, BrainEnvironment, BrainIdentity, BrainMode, CapabilityConfig, CapabilityEntry, InterfaceConstructor, InterfaceEntry, Plugin, PluginConfig, PluginFactory, PresetName };