veryfront 0.1.514 → 0.1.516

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.
Files changed (96) hide show
  1. package/README.md +0 -1
  2. package/esm/cli/commands/build/command.js +2 -2
  3. package/esm/cli/shared/{ensure-content-transformer.d.ts → ensure-content-processor.d.ts} +3 -3
  4. package/esm/cli/shared/ensure-content-processor.d.ts.map +1 -0
  5. package/esm/cli/shared/{ensure-content-transformer.js → ensure-content-processor.js} +5 -5
  6. package/esm/cli/shared/server-startup.js +4 -4
  7. package/esm/deno.d.ts +0 -5
  8. package/esm/deno.js +4 -9
  9. package/esm/extensions/ext-transform-mdx/src/compiler/markdown-compile.d.ts +2 -2
  10. package/esm/extensions/ext-transform-mdx/src/compiler/markdown-compile.d.ts.map +1 -1
  11. package/esm/extensions/ext-transform-mdx/src/compiler/mdx-compile.d.ts +2 -2
  12. package/esm/extensions/ext-transform-mdx/src/compiler/mdx-compile.d.ts.map +1 -1
  13. package/esm/extensions/ext-transform-mdx/src/index.d.ts +10 -10
  14. package/esm/extensions/ext-transform-mdx/src/index.d.ts.map +1 -1
  15. package/esm/extensions/ext-transform-mdx/src/index.js +11 -11
  16. package/esm/src/agent/index.d.ts +2 -1
  17. package/esm/src/agent/index.d.ts.map +1 -1
  18. package/esm/src/agent/index.js +1 -0
  19. package/esm/src/agent/runtime/constants.d.ts.map +1 -1
  20. package/esm/src/agent/runtime/constants.js +5 -1
  21. package/esm/src/agent/runtime/model-resolution.d.ts.map +1 -1
  22. package/esm/src/agent/runtime/model-resolution.js +17 -3
  23. package/esm/src/agent/runtime-agent-markdown-adapter.d.ts +6 -0
  24. package/esm/src/agent/runtime-agent-markdown-adapter.d.ts.map +1 -0
  25. package/esm/src/agent/runtime-agent-markdown-adapter.js +20 -0
  26. package/esm/src/agent/types.d.ts +22 -10
  27. package/esm/src/agent/types.d.ts.map +1 -1
  28. package/esm/src/agent/veryfront-cloud-agent-service.d.ts.map +1 -1
  29. package/esm/src/agent/veryfront-cloud-agent-service.js +19 -8
  30. package/esm/src/channels/control-plane.d.ts +30 -54
  31. package/esm/src/channels/control-plane.d.ts.map +1 -1
  32. package/esm/src/channels/control-plane.js +13 -15
  33. package/esm/src/discovery/discovery-engine.d.ts.map +1 -1
  34. package/esm/src/discovery/discovery-engine.js +2 -0
  35. package/esm/src/discovery/file-discovery.d.ts +6 -1
  36. package/esm/src/discovery/file-discovery.d.ts.map +1 -1
  37. package/esm/src/discovery/file-discovery.js +25 -5
  38. package/esm/src/discovery/handlers/runtime-agent-markdown-handler.d.ts +3 -0
  39. package/esm/src/discovery/handlers/runtime-agent-markdown-handler.d.ts.map +1 -0
  40. package/esm/src/discovery/handlers/runtime-agent-markdown-handler.js +51 -0
  41. package/esm/src/extensions/builtin-extensions.js +1 -1
  42. package/esm/src/extensions/recommendations.js +1 -1
  43. package/esm/src/extensions/transform/{content-transformer.d.ts → content-processor.d.ts} +21 -21
  44. package/esm/src/extensions/transform/content-processor.d.ts.map +1 -0
  45. package/esm/src/extensions/transform/{content-transformer.js → content-processor.js} +5 -5
  46. package/esm/src/extensions/transform/index.d.ts +3 -3
  47. package/esm/src/extensions/transform/index.d.ts.map +1 -1
  48. package/esm/src/extensions/transform/index.js +1 -1
  49. package/esm/src/oauth/handlers/init-handler.d.ts.map +1 -1
  50. package/esm/src/oauth/handlers/init-handler.js +9 -4
  51. package/esm/src/transforms/md/compiler/md-compiler.d.ts +2 -2
  52. package/esm/src/transforms/md/compiler/md-compiler.d.ts.map +1 -1
  53. package/esm/src/transforms/md/compiler/md-compiler.js +2 -2
  54. package/esm/src/transforms/mdx/compiler/index.d.ts +3 -3
  55. package/esm/src/transforms/mdx/compiler/index.d.ts.map +1 -1
  56. package/esm/src/transforms/mdx/compiler/mdx-compiler.d.ts +2 -2
  57. package/esm/src/transforms/mdx/compiler/mdx-compiler.d.ts.map +1 -1
  58. package/esm/src/transforms/mdx/compiler/mdx-compiler.js +2 -2
  59. package/esm/src/transforms/plugins/plugin-loader.d.ts +2 -2
  60. package/esm/src/transforms/plugins/plugin-loader.js +6 -6
  61. package/esm/src/utils/version-constant.d.ts +1 -1
  62. package/esm/src/utils/version-constant.js +1 -1
  63. package/package.json +4 -4
  64. package/src/cli/commands/build/command.ts +2 -2
  65. package/src/cli/shared/{ensure-content-transformer.ts → ensure-content-processor.ts} +6 -6
  66. package/src/cli/shared/server-startup.ts +4 -4
  67. package/src/deno.js +4 -9
  68. package/src/deps/esm.sh/@types/react-dom@19.2.3/client.d.ts +1 -1
  69. package/src/deps/esm.sh/@types/{react@19.2.14 → react@19.2.3}/global.d.ts +0 -1
  70. package/src/deps/esm.sh/@types/{react@19.2.14 → react@19.2.3}/index.d.ts +24 -93
  71. package/src/deps/esm.sh/react-dom@19.2.4/client.d.ts +1 -1
  72. package/src/extensions/ext-transform-mdx/src/compiler/markdown-compile.ts +5 -2
  73. package/src/extensions/ext-transform-mdx/src/compiler/mdx-compile.ts +5 -2
  74. package/src/extensions/ext-transform-mdx/src/index.ts +15 -15
  75. package/src/src/agent/index.ts +8 -2
  76. package/src/src/agent/runtime/constants.ts +6 -1
  77. package/src/src/agent/runtime/model-resolution.ts +17 -3
  78. package/src/src/agent/runtime-agent-markdown-adapter.ts +31 -0
  79. package/src/src/agent/types.ts +23 -10
  80. package/src/src/agent/veryfront-cloud-agent-service.ts +23 -10
  81. package/src/src/channels/control-plane.ts +18 -20
  82. package/src/src/discovery/discovery-engine.ts +2 -0
  83. package/src/src/discovery/file-discovery.ts +40 -5
  84. package/src/src/discovery/handlers/runtime-agent-markdown-handler.ts +78 -0
  85. package/src/src/extensions/builtin-extensions.ts +1 -1
  86. package/src/src/extensions/recommendations.ts +1 -1
  87. package/src/src/extensions/transform/{content-transformer.ts → content-processor.ts} +20 -20
  88. package/src/src/extensions/transform/index.ts +5 -5
  89. package/src/src/oauth/handlers/init-handler.ts +10 -5
  90. package/src/src/transforms/md/compiler/md-compiler.ts +6 -6
  91. package/src/src/transforms/mdx/compiler/index.ts +3 -3
  92. package/src/src/transforms/mdx/compiler/mdx-compiler.ts +5 -5
  93. package/src/src/transforms/plugins/plugin-loader.ts +7 -7
  94. package/src/src/utils/version-constant.ts +1 -1
  95. package/esm/cli/shared/ensure-content-transformer.d.ts.map +0 -1
  96. package/esm/src/extensions/transform/content-transformer.d.ts.map +0 -1
@@ -16,7 +16,6 @@ type NativeKeyboardEvent = KeyboardEvent;
16
16
  type NativeMouseEvent = MouseEvent;
17
17
  type NativeTouchEvent = TouchEvent;
18
18
  type NativePointerEvent = PointerEvent;
19
- type NativeSubmitEvent = SubmitEvent;
20
19
  type NativeToggleEvent = ToggleEvent;
21
20
  type NativeTransitionEvent = TransitionEvent;
22
21
  type NativeUIEvent = UIEvent;
@@ -226,20 +225,12 @@ declare namespace React {
226
225
 
227
226
  type ComponentState = any;
228
227
 
229
- interface DO_NOT_USE_OR_YOU_WILL_BE_FIRED_EXPERIMENTAL_KEY_TYPES {}
230
-
231
228
  /**
232
229
  * A value which uniquely identifies a node among items in an array.
233
230
  *
234
231
  * @see {@link https://react.dev/learn/rendering-lists#keeping-list-items-in-order-with-key React Docs}
235
232
  */
236
- type Key =
237
- | string
238
- | number
239
- | bigint
240
- | DO_NOT_USE_OR_YOU_WILL_BE_FIRED_EXPERIMENTAL_KEY_TYPES[
241
- keyof DO_NOT_USE_OR_YOU_WILL_BE_FIRED_EXPERIMENTAL_KEY_TYPES
242
- ];
233
+ type Key = string | number | bigint;
243
234
 
244
235
  /**
245
236
  * @internal The props any component can receive.
@@ -1893,7 +1884,7 @@ declare namespace React {
1893
1884
  *
1894
1885
  * @param callback A synchronous, void callback that will execute as a single, complete React commit.
1895
1886
  *
1896
- * @see {@link https://reactjs.org/blog/2019/02/06/react-v16.8.0.html#testing-hooks}
1887
+ * @see https://reactjs.org/blog/2019/02/06/react-v16.8.0.html#testing-hooks
1897
1888
  */
1898
1889
  // NOTES
1899
1890
  // - the order of these signatures matters - typescript will check the signatures in source order.
@@ -1935,31 +1926,7 @@ declare namespace React {
1935
1926
  reducer: (state: State, action: Action) => State,
1936
1927
  ): [State, (action: Action) => void];
1937
1928
 
1938
- interface UntrackedReactPromise<T> extends PromiseLike<T> {
1939
- status?: void;
1940
- }
1941
-
1942
- export interface PendingReactPromise<T> extends PromiseLike<T> {
1943
- status: "pending";
1944
- }
1945
-
1946
- export interface FulfilledReactPromise<T> extends PromiseLike<T> {
1947
- status: "fulfilled";
1948
- value: T;
1949
- }
1950
-
1951
- export interface RejectedReactPromise<T> extends PromiseLike<T> {
1952
- status: "rejected";
1953
- reason: unknown;
1954
- }
1955
-
1956
- export type ReactPromise<T> =
1957
- | UntrackedReactPromise<T>
1958
- | PendingReactPromise<T>
1959
- | FulfilledReactPromise<T>
1960
- | RejectedReactPromise<T>;
1961
-
1962
- export type Usable<T> = ReactPromise<T> | Context<T>;
1929
+ export type Usable<T> = PromiseLike<T> | Context<T>;
1963
1930
 
1964
1931
  export function use<T>(usable: Usable<T>): T;
1965
1932
 
@@ -2074,28 +2041,15 @@ declare namespace React {
2074
2041
  target: EventTarget & Target;
2075
2042
  }
2076
2043
 
2077
- /**
2078
- * @deprecated FormEvent doesn't actually exist.
2079
- * You probably meant to use {@link ChangeEvent}, {@link InputEvent}, {@link SubmitEvent}, or just {@link SyntheticEvent} instead
2080
- * depending on the event type.
2081
- */
2082
2044
  interface FormEvent<T = Element> extends SyntheticEvent<T> {
2083
2045
  }
2084
2046
 
2085
2047
  interface InvalidEvent<T = Element> extends SyntheticEvent<T> {
2048
+ target: EventTarget & T;
2086
2049
  }
2087
2050
 
2088
- /**
2089
- * change events bubble in React so their target is generally unknown.
2090
- * Only for form elements we know their target type because form events can't
2091
- * be nested.
2092
- * This type exists purely to narrow `target` for form elements. It doesn't
2093
- * reflect a DOM event. Change events are just fired as standard {@link SyntheticEvent}.
2094
- */
2095
- interface ChangeEvent<CurrentTarget = Element, Target = Element> extends SyntheticEvent<CurrentTarget> {
2096
- // TODO: This is wrong for change event handlers on arbitrary. Should
2097
- // be EventTarget & Target, but kept for backward compatibility until React 20.
2098
- target: EventTarget & CurrentTarget;
2051
+ interface ChangeEvent<T = Element> extends SyntheticEvent<T> {
2052
+ target: EventTarget & T;
2099
2053
  }
2100
2054
 
2101
2055
  interface InputEvent<T = Element> extends SyntheticEvent<T, NativeInputEvent> {
@@ -2165,13 +2119,6 @@ declare namespace React {
2165
2119
  shiftKey: boolean;
2166
2120
  }
2167
2121
 
2168
- interface SubmitEvent<T = Element> extends SyntheticEvent<T, NativeSubmitEvent> {
2169
- // `submitter` is available in react@canary
2170
- // submitter: HTMLElement | null;
2171
- // SubmitEvents are always targetted at HTMLFormElements.
2172
- target: EventTarget & HTMLFormElement;
2173
- }
2174
-
2175
2122
  interface TouchEvent<T = Element> extends UIEvent<T, NativeTouchEvent> {
2176
2123
  altKey: boolean;
2177
2124
  changedTouches: TouchList;
@@ -2227,19 +2174,11 @@ declare namespace React {
2227
2174
  type CompositionEventHandler<T = Element> = EventHandler<CompositionEvent<T>>;
2228
2175
  type DragEventHandler<T = Element> = EventHandler<DragEvent<T>>;
2229
2176
  type FocusEventHandler<T = Element> = EventHandler<FocusEvent<T>>;
2230
- /**
2231
- * @deprecated FormEventHandler doesn't actually exist.
2232
- * You probably meant to use {@link ChangeEventHandler}, {@link InputEventHandler}, {@link SubmitEventHandler}, or just {@link EventHandler} instead
2233
- * depending on the event type.
2234
- */
2235
2177
  type FormEventHandler<T = Element> = EventHandler<FormEvent<T>>;
2236
- type ChangeEventHandler<CurrentTarget = Element, Target = Element> = EventHandler<
2237
- ChangeEvent<CurrentTarget, Target>
2238
- >;
2178
+ type ChangeEventHandler<T = Element> = EventHandler<ChangeEvent<T>>;
2239
2179
  type InputEventHandler<T = Element> = EventHandler<InputEvent<T>>;
2240
2180
  type KeyboardEventHandler<T = Element> = EventHandler<KeyboardEvent<T>>;
2241
2181
  type MouseEventHandler<T = Element> = EventHandler<MouseEvent<T>>;
2242
- type SubmitEventHandler<T = Element> = EventHandler<SubmitEvent<T>>;
2243
2182
  type TouchEventHandler<T = Element> = EventHandler<TouchEvent<T>>;
2244
2183
  type PointerEventHandler<T = Element> = EventHandler<PointerEvent<T>>;
2245
2184
  type UIEventHandler<T = Element> = EventHandler<UIEvent<T>>;
@@ -2293,19 +2232,19 @@ declare namespace React {
2293
2232
  onBlur?: FocusEventHandler<T> | undefined;
2294
2233
  onBlurCapture?: FocusEventHandler<T> | undefined;
2295
2234
 
2296
- // form related Events
2297
- onChange?: ChangeEventHandler<T> | undefined;
2298
- onChangeCapture?: ChangeEventHandler<T> | undefined;
2235
+ // Form Events
2236
+ onChange?: FormEventHandler<T> | undefined;
2237
+ onChangeCapture?: FormEventHandler<T> | undefined;
2299
2238
  onBeforeInput?: InputEventHandler<T> | undefined;
2300
- onBeforeInputCapture?: InputEventHandler<T> | undefined;
2301
- onInput?: InputEventHandler<T> | undefined;
2302
- onInputCapture?: InputEventHandler<T> | undefined;
2303
- onReset?: ReactEventHandler<T> | undefined;
2304
- onResetCapture?: ReactEventHandler<T> | undefined;
2305
- onSubmit?: SubmitEventHandler<T> | undefined;
2306
- onSubmitCapture?: SubmitEventHandler<T> | undefined;
2307
- onInvalid?: ReactEventHandler<T> | undefined;
2308
- onInvalidCapture?: ReactEventHandler<T> | undefined;
2239
+ onBeforeInputCapture?: FormEventHandler<T> | undefined;
2240
+ onInput?: FormEventHandler<T> | undefined;
2241
+ onInputCapture?: FormEventHandler<T> | undefined;
2242
+ onReset?: FormEventHandler<T> | undefined;
2243
+ onResetCapture?: FormEventHandler<T> | undefined;
2244
+ onSubmit?: FormEventHandler<T> | undefined;
2245
+ onSubmitCapture?: FormEventHandler<T> | undefined;
2246
+ onInvalid?: FormEventHandler<T> | undefined;
2247
+ onInvalidCapture?: FormEventHandler<T> | undefined;
2309
2248
 
2310
2249
  // Image Events
2311
2250
  onLoad?: ReactEventHandler<T> | undefined;
@@ -2849,7 +2788,7 @@ declare namespace React {
2849
2788
 
2850
2789
  // Living Standard
2851
2790
  /**
2852
- * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/inert}
2791
+ * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/inert
2853
2792
  */
2854
2793
  inert?: boolean | undefined;
2855
2794
  /**
@@ -3312,9 +3251,7 @@ declare namespace React {
3312
3251
  value?: string | readonly string[] | number | undefined;
3313
3252
  width?: number | string | undefined;
3314
3253
 
3315
- // No other element dispatching change events can be nested in a <input>
3316
- // so we know the target will be a HTMLInputElement.
3317
- onChange?: ChangeEventHandler<T, HTMLInputElement> | undefined;
3254
+ onChange?: ChangeEventHandler<T> | undefined;
3318
3255
  }
3319
3256
 
3320
3257
  interface KeygenHTMLAttributes<T> extends HTMLAttributes<T> {
@@ -3479,9 +3416,7 @@ declare namespace React {
3479
3416
  required?: boolean | undefined;
3480
3417
  size?: number | undefined;
3481
3418
  value?: string | readonly string[] | number | undefined;
3482
- // No other element dispatching change events can be nested in a <select>
3483
- // so we know the target will be a HTMLSelectElement.
3484
- onChange?: ChangeEventHandler<T, HTMLSelectElement> | undefined;
3419
+ onChange?: ChangeEventHandler<T> | undefined;
3485
3420
  }
3486
3421
 
3487
3422
  interface SourceHTMLAttributes<T> extends HTMLAttributes<T> {
@@ -3533,9 +3468,7 @@ declare namespace React {
3533
3468
  value?: string | readonly string[] | number | undefined;
3534
3469
  wrap?: string | undefined;
3535
3470
 
3536
- // No other element dispatching change events can be nested in a <textarea>
3537
- // so we know the target will be a HTMLTextAreaElement.
3538
- onChange?: ChangeEventHandler<T, HTMLTextAreaElement> | undefined;
3471
+ onChange?: ChangeEventHandler<T> | undefined;
3539
3472
  }
3540
3473
 
3541
3474
  interface TdHTMLAttributes<T> extends HTMLAttributes<T> {
@@ -3607,9 +3540,6 @@ declare namespace React {
3607
3540
  method?: string | undefined;
3608
3541
  min?: number | string | undefined;
3609
3542
  name?: string | undefined;
3610
- nonce?: string | undefined;
3611
- part?: string | undefined;
3612
- slot?: string | undefined;
3613
3543
  style?: CSSProperties | undefined;
3614
3544
  target?: string | undefined;
3615
3545
  type?: string | undefined;
@@ -4127,6 +4057,7 @@ declare namespace React {
4127
4057
  * Captures which component contained the exception, and its ancestors.
4128
4058
  */
4129
4059
  componentStack?: string | null;
4060
+ digest?: string | null;
4130
4061
  }
4131
4062
 
4132
4063
  // Keep in sync with JSX namespace in ./jsx-runtime.d.ts and ./jsx-dev-runtime.d.ts
@@ -4,7 +4,7 @@
4
4
 
5
5
  // See https://github.com/facebook/react/blob/main/packages/react-dom/client.js to see how the exports are declared,
6
6
 
7
- import React = require("https://esm.sh/@types/react@19.2.14/index.d.ts");
7
+ import React = require("https://esm.sh/@types/react@19.2.3/index.d.ts");
8
8
 
9
9
  export {};
10
10
 
@@ -12,7 +12,10 @@ import { visit } from "unist-util-visit";
12
12
  import { toString } from "mdast-util-to-string";
13
13
  import Slugger from "github-slugger";
14
14
  import type { Heading, Root as MdastRoot } from "@types/mdast";
15
- import type { ContentCompileOptions, ContentRuntimeBundle } from "../../../../src/extensions/transform/index.js";
15
+ import type {
16
+ ContentCompileOptions,
17
+ ContentProcessingResult,
18
+ } from "../../../../src/extensions/transform/index.js";
16
19
  import { extractFrontmatter } from "../../../../src/transforms/mdx/compiler/frontmatter-extractor.js";
17
20
  import { isMarkdownPreview } from "../../../../src/transforms/md/utils.js";
18
21
  import { rehypeNodePositions } from "../plugins/rehype-node-positions.js";
@@ -64,7 +67,7 @@ export default function MDContent({ components, params, className, ...props }) {
64
67
 
65
68
  export async function compileMarkdown(
66
69
  options: ContentCompileOptions,
67
- ): Promise<ContentRuntimeBundle> {
70
+ ): Promise<ContentProcessingResult> {
68
71
  const { content, frontmatter: providedFrontmatter, filePath, studioEmbed } = options;
69
72
 
70
73
  const { body, frontmatter: extractedFrontmatter } = extractFrontmatter(
@@ -1,6 +1,9 @@
1
1
  import { compile } from "@mdx-js/mdx";
2
2
  import type { Pluggable } from "unified";
3
- import type { ContentCompileOptions, ContentRuntimeBundle } from "../../../../src/extensions/transform/index.js";
3
+ import type {
4
+ ContentCompileOptions,
5
+ ContentProcessingResult,
6
+ } from "../../../../src/extensions/transform/index.js";
4
7
  import { extractFrontmatter } from "../../../../src/transforms/mdx/compiler/frontmatter-extractor.js";
5
8
  import { rewriteBodyImports, rewriteCompiledImports } from "../../../../src/transforms/mdx/compiler/import-rewriter.js";
6
9
  import { getRehypePlugins, getRemarkPlugins } from "../plugins/plugin-loader.js";
@@ -8,7 +11,7 @@ import { rehypeNodePositions } from "../plugins/rehype-node-positions.js";
8
11
 
9
12
  type PluggableList = Pluggable[];
10
13
 
11
- export async function compileMdx(options: ContentCompileOptions): Promise<ContentRuntimeBundle> {
14
+ export async function compileMdx(options: ContentCompileOptions): Promise<ContentProcessingResult> {
12
15
  const {
13
16
  projectDir,
14
17
  content,
@@ -1,12 +1,12 @@
1
1
  /**
2
- * ext-mdx ContentTransformer implementation backed by MDX + remark/rehype.
2
+ * ext-mdx: ContentProcessor implementation backed by MDX + remark/rehype.
3
3
  *
4
- * Provides the `ContentTransformer` contract:
5
- * - `compileMdx(options)` runs @mdx-js/mdx through veryfront's remark +
4
+ * Provides the `ContentProcessor` contract:
5
+ * - `compileMdx(options)` runs @mdx-js/mdx through Veryfront's remark +
6
6
  * rehype plugin stack and returns compiled ESM plus extracted headings
7
7
  * and frontmatter.
8
- * - `compileMarkdown(options)` runs a unified markdown pipeline
9
- * (remark-parse remark-rehype rehype-sanitize rehype-stringify)
8
+ * - `compileMarkdown(options)` runs a unified markdown pipeline
9
+ * (remark-parse to remark-rehype to rehype-sanitize to rehype-stringify)
10
10
  * producing sanitized HTML wrapped in a React component.
11
11
  *
12
12
  * Core's `src/transforms/md/compiler` and `src/transforms/mdx/compiler`
@@ -21,18 +21,18 @@ import type { ExtensionFactory } from "../../../src/extensions/index.js";
21
21
  import type {
22
22
  ContentCompileOptions,
23
23
  ContentPlugin,
24
- ContentRuntimeBundle,
25
- ContentTransformer,
24
+ ContentProcessingResult,
25
+ ContentProcessor,
26
26
  } from "../../../src/extensions/transform/index.js";
27
27
  import { compileMdx } from "./compiler/mdx-compile.js";
28
28
  import { compileMarkdown } from "./compiler/markdown-compile.js";
29
29
  import { getRehypePlugins, getRemarkPlugins } from "./plugins/plugin-loader.js";
30
30
 
31
- class MdxContentTransformer implements ContentTransformer {
32
- compileMdx(options: ContentCompileOptions): Promise<ContentRuntimeBundle> {
31
+ class MdxContentProcessor implements ContentProcessor {
32
+ compileMdx(options: ContentCompileOptions): Promise<ContentProcessingResult> {
33
33
  return compileMdx(options);
34
34
  }
35
- compileMarkdown(options: ContentCompileOptions): Promise<ContentRuntimeBundle> {
35
+ compileMarkdown(options: ContentCompileOptions): Promise<ContentProcessingResult> {
36
36
  return compileMarkdown(options);
37
37
  }
38
38
  getRemarkPlugins(): ContentPlugin[] {
@@ -44,14 +44,14 @@ class MdxContentTransformer implements ContentTransformer {
44
44
  }
45
45
 
46
46
  const extMdx: ExtensionFactory = () => {
47
- const impl = new MdxContentTransformer();
47
+ const impl = new MdxContentProcessor();
48
48
  return {
49
49
  name: "ext-transform-mdx",
50
50
  version: "0.1.0",
51
- capabilities: [{ type: "contract", name: "ContentTransformer" }],
51
+ capabilities: [{ type: "contract", name: "ContentProcessor" }],
52
52
  setup(ctx) {
53
- ctx.provide("ContentTransformer", impl);
54
- ctx.logger.info("[ext-mdx] ContentTransformer registered");
53
+ ctx.provide("ContentProcessor", impl);
54
+ ctx.logger.info("[ext-mdx] ContentProcessor registered");
55
55
  },
56
56
  teardown() {
57
57
  // No resources to release.
@@ -60,4 +60,4 @@ const extMdx: ExtensionFactory = () => {
60
60
  };
61
61
 
62
62
  export default extMdx;
63
- export { MdxContentTransformer };
63
+ export { MdxContentProcessor };
@@ -89,8 +89,6 @@ export type {
89
89
  AgentResponse,
90
90
  AgentStatus,
91
91
  AgentStreamResult,
92
- AgentSuggestion,
93
- AgentSuggestions,
94
92
  EdgeConfig,
95
93
  MemoryConfig,
96
94
  Message as AgentMessage,
@@ -105,6 +103,8 @@ export type {
105
103
  RuntimeStateRequest,
106
104
  RuntimeStateResolver,
107
105
  StreamToolCall,
106
+ Suggestion,
107
+ Suggestions,
108
108
  ToolCall,
109
109
  ToolCallPart,
110
110
  ToolCallPartWithArgs,
@@ -177,6 +177,12 @@ export {
177
177
  type PrepareDefaultHostedChildForkToolSourcesInput,
178
178
  } from "./hosted-child-fork-tool-sources.js";
179
179
 
180
+ export {
181
+ createRuntimeAgentFromMarkdownDefinition,
182
+ getRuntimeAgentMarkdownDefinition,
183
+ isRuntimeAgentMarkdownAgent,
184
+ } from "./runtime-agent-markdown-adapter.js";
185
+
180
186
  export {
181
187
  loadRuntimeAgentMarkdownDefinitionFromFile,
182
188
  type LoadRuntimeAgentMarkdownDefinitionFromFileInput,
@@ -15,10 +15,15 @@ const MODEL_MAX_OUTPUT_TOKENS: Record<string, number> = {
15
15
  "google-ai-studio/gemini-2.5-flash": 8_192,
16
16
  };
17
17
 
18
+ const MODEL_MAX_OUTPUT_TOKEN_ALIASES: Record<string, string> = {
19
+ "google/gemini-2.5-pro": "google-ai-studio/gemini-2.5-pro",
20
+ "google/gemini-2.5-flash": "google-ai-studio/gemini-2.5-flash",
21
+ };
22
+
18
23
  /** Look up max output tokens for a model, stripping the `veryfront-cloud/` prefix. */
19
24
  export function getModelMaxOutputTokens(modelString: string): number | undefined {
20
25
  const normalized = modelString.startsWith("veryfront-cloud/")
21
26
  ? modelString.slice("veryfront-cloud/".length)
22
27
  : modelString;
23
- return MODEL_MAX_OUTPUT_TOKENS[normalized];
28
+ return MODEL_MAX_OUTPUT_TOKENS[MODEL_MAX_OUTPUT_TOKEN_ALIASES[normalized] ?? normalized];
24
29
  }
@@ -9,7 +9,19 @@ import { isVeryfrontCloudEnabled } from "../../platform/cloud/resolver.js";
9
9
 
10
10
  export const AUTO_AGENT_MODEL = "auto";
11
11
 
12
- const HOSTED_PROVIDER_NAMES = new Set(["anthropic", "google", "openai"]);
12
+ const HOSTED_PROVIDER_NAMES = new Set([
13
+ "anthropic",
14
+ "google",
15
+ "google-ai-studio",
16
+ "moonshotai",
17
+ "openai",
18
+ ]);
19
+ const DIRECT_CREDENTIAL_PROVIDER_ALIASES: Record<string, string> = {
20
+ "google-ai-studio": "google",
21
+ };
22
+ const DIRECT_RUNTIME_PROVIDER_ALIASES: Record<string, string> = {
23
+ "google-ai-studio": "google",
24
+ };
13
25
  const LEGACY_MODEL_ALIASES: Record<string, string> = {
14
26
  opus: "anthropic/claude-opus-4-6",
15
27
  sonnet: "anthropic/claude-sonnet-4-6",
@@ -25,6 +37,7 @@ const LEGACY_MODEL_ALIASES: Record<string, string> = {
25
37
  "gemini-3.1-pro": "google-ai-studio/gemini-2.5-pro",
26
38
  "gemini-2.5-pro": "google-ai-studio/gemini-2.5-pro",
27
39
  "gemini-2.5-flash": "google-ai-studio/gemini-2.5-flash",
40
+ "kimi-k2.5": "moonshotai/kimi-k2.5",
28
41
  };
29
42
 
30
43
  export function normalizeAgentModelConfig(model?: string): string {
@@ -46,7 +59,7 @@ export function resolveConfiguredAgentModel(model?: string): string {
46
59
  }
47
60
 
48
61
  function hasDirectProviderCredentials(provider: string): boolean {
49
- switch (provider) {
62
+ switch (DIRECT_CREDENTIAL_PROVIDER_ALIASES[provider] ?? provider) {
50
63
  case "anthropic":
51
64
  return Boolean(getAnthropicEnvConfig().apiKey);
52
65
  case "google":
@@ -92,7 +105,8 @@ export function resolveRuntimeModel(model?: string): string {
92
105
  }
93
106
 
94
107
  if (!isVeryfrontCloudEnabled() || hasDirectProviderCredentials(provider)) {
95
- return configuredModel;
108
+ const runtimeProvider = DIRECT_RUNTIME_PROVIDER_ALIASES[provider] ?? provider;
109
+ return `${runtimeProvider}/${modelId}`;
96
110
  }
97
111
 
98
112
  return `veryfront-cloud/${provider}/${modelId}`;
@@ -0,0 +1,31 @@
1
+ import { agent } from "./factory.js";
2
+ import type { Agent } from "./types.js";
3
+ import type { RuntimeAgentMarkdownDefinition } from "./runtime-agent-definition.js";
4
+
5
+ const markdownDefinitionByAgent = new WeakMap<Agent, RuntimeAgentMarkdownDefinition>();
6
+
7
+ export function createRuntimeAgentFromMarkdownDefinition(
8
+ definition: RuntimeAgentMarkdownDefinition,
9
+ ): Agent {
10
+ const runtimeAgent = agent({
11
+ id: definition.id,
12
+ name: definition.name,
13
+ description: definition.description,
14
+ system: definition.instructions,
15
+ ...(definition.model ? { model: definition.model } : {}),
16
+ ...(definition.maxSteps === undefined ? {} : { maxSteps: definition.maxSteps }),
17
+ });
18
+
19
+ markdownDefinitionByAgent.set(runtimeAgent, definition);
20
+ return runtimeAgent;
21
+ }
22
+
23
+ export function getRuntimeAgentMarkdownDefinition(
24
+ runtimeAgent: Agent,
25
+ ): RuntimeAgentMarkdownDefinition | null {
26
+ return markdownDefinitionByAgent.get(runtimeAgent) ?? null;
27
+ }
28
+
29
+ export function isRuntimeAgentMarkdownAgent(runtimeAgent: Agent): boolean {
30
+ return markdownDefinitionByAgent.has(runtimeAgent);
31
+ }
@@ -44,30 +44,43 @@ export type ModelString = string;
44
44
  // Import for use in AgentConfig
45
45
  import type { EdgeConfig, MemoryConfig } from "./schemas/index.js";
46
46
 
47
- export type AgentSuggestion =
47
+ export type Suggestion =
48
48
  | {
49
- id: string;
50
49
  type: "prompt";
50
+ id?: never;
51
51
  title: string;
52
- description?: string;
53
52
  prompt: string;
53
+ description?: never;
54
+ task?: never;
55
+ }
56
+ | {
57
+ id: string;
58
+ type: "prompt";
59
+ title?: never;
60
+ prompt?: never;
61
+ description?: never;
62
+ task?: never;
54
63
  }
55
64
  | {
56
65
  id: string;
57
66
  type: "task";
58
- title: string;
59
- description?: string;
60
- task: string;
61
- prompt?: string;
67
+ title?: never;
68
+ prompt?: never;
69
+ description?: never;
70
+ task?: never;
62
71
  };
63
72
 
64
- export interface AgentSuggestions {
73
+ export interface Suggestions {
65
74
  welcomeMessage?: string;
66
- suggestions: AgentSuggestion[];
75
+ suggestions: Suggestion[];
67
76
  }
68
77
 
69
78
  export interface AgentConfig {
70
79
  id?: string;
80
+ /** Human-readable display name for registry and control-plane listings. */
81
+ name?: string;
82
+ /** Optional summary shown in registry and control-plane listings. */
83
+ description?: string;
71
84
  /**
72
85
  * Optional model string in "provider/model" format.
73
86
  *
@@ -121,7 +134,7 @@ export interface AgentConfig {
121
134
  * and registers the skill tools.
122
135
  */
123
136
  skills?: true | string[];
124
- suggestions?: AgentSuggestions;
137
+ suggestions?: Suggestions;
125
138
  /** Set to false to disable the default security middleware */
126
139
  security?: false;
127
140
  }
@@ -69,8 +69,11 @@ import type { AgentServiceMcpServerConfig } from "./agent-service-mcp-server-con
69
69
  import type { RuntimeLoadSkillToolContext } from "./runtime-load-skill-tool.js";
70
70
  import type { RuntimeProjectSteeringLookup } from "./runtime-project-skill-catalog.js";
71
71
  import type { RuntimeSkillDefinition } from "./runtime-skill-metadata.js";
72
- import { listRuntimeAgentMarkdownDefinitionIds } from "./runtime-agent-definition-files.js";
73
72
  import type { RuntimeAgentMarkdownDefinition } from "./runtime-agent-definition.js";
73
+ import {
74
+ getRuntimeAgentMarkdownDefinition,
75
+ isRuntimeAgentMarkdownAgent,
76
+ } from "./runtime-agent-markdown-adapter.js";
74
77
  import {
75
78
  buildVeryfrontCloudRuntimeInstructions,
76
79
  } from "./veryfront-cloud-runtime-system-messages.js";
@@ -401,8 +404,8 @@ async function createRuntimeAgentDefinitionFromCodeAgent(
401
404
  ): Promise<RuntimeAgentMarkdownDefinition> {
402
405
  return {
403
406
  id: codeAgent.id,
404
- name: codeAgent.id,
405
- description: "",
407
+ name: codeAgent.config.name ?? codeAgent.id,
408
+ description: codeAgent.config.description ?? "",
406
409
  instructions: await resolveAgentSystem(codeAgent.config.system),
407
410
  model: codeAgent.config.model,
408
411
  maxSteps: codeAgent.config.maxSteps,
@@ -435,7 +438,7 @@ async function resolveAgentConfig(
435
438
  const source = context.options.agentSource ?? "auto";
436
439
  const codeAgent = getAgent(agentId);
437
440
 
438
- if (source !== "markdown" && codeAgent) {
441
+ if (source !== "markdown" && codeAgent && !isRuntimeAgentMarkdownAgent(codeAgent)) {
439
442
  const agentConfig = await createRuntimeAgentDefinitionFromCodeAgent(codeAgent);
440
443
  context.agentConfigs.set(agentConfig.id, agentConfig);
441
444
  return agentConfig;
@@ -445,6 +448,14 @@ async function resolveAgentConfig(
445
448
  throw new Error(`Code agent "${agentId}" was not discovered.`);
446
449
  }
447
450
 
451
+ const discoveredMarkdownDefinition = codeAgent
452
+ ? getRuntimeAgentMarkdownDefinition(codeAgent)
453
+ : null;
454
+ if (discoveredMarkdownDefinition) {
455
+ context.agentConfigs.set(discoveredMarkdownDefinition.id, discoveredMarkdownDefinition);
456
+ return discoveredMarkdownDefinition;
457
+ }
458
+
448
459
  const agentConfig = loadMarkdownAgentConfig(context, agentId);
449
460
  context.agentConfigs.set(agentConfig.id, agentConfig);
450
461
  return agentConfig;
@@ -477,15 +488,17 @@ async function discoverProjectPrimitives(
477
488
  }
478
489
 
479
490
  function getDiscoveredCodeAgentIds(context: NodeVeryfrontCloudAgentServiceContext): string[] {
480
- return [...(context.discoveryResult?.agents.keys() ?? [])].sort((left, right) =>
481
- left.localeCompare(right)
482
- );
491
+ return [...(context.discoveryResult?.agents.entries() ?? [])]
492
+ .filter(([, discoveredAgent]) => !isRuntimeAgentMarkdownAgent(discoveredAgent))
493
+ .map(([id]) => id)
494
+ .sort((left, right) => left.localeCompare(right));
483
495
  }
484
496
 
485
497
  function getDiscoveredMarkdownAgentIds(context: NodeVeryfrontCloudAgentServiceContext): string[] {
486
- return listRuntimeAgentMarkdownDefinitionIds({
487
- baseDir: resolveBaseDir(context.options),
488
- });
498
+ return [...(context.discoveryResult?.agents.entries() ?? [])]
499
+ .filter(([, discoveredAgent]) => isRuntimeAgentMarkdownAgent(discoveredAgent))
500
+ .map(([id]) => id)
501
+ .sort((left, right) => left.localeCompare(right));
489
502
  }
490
503
 
491
504
  function describeAgentIdCandidates(input: {