@bolt-foundry/gambit 0.8.3 → 0.8.5-rc.4
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/CHANGELOG.md +34 -2
- package/README.md +79 -16
- package/esm/_dnt.polyfills.d.ts +17 -0
- package/esm/_dnt.polyfills.d.ts.map +1 -1
- package/esm/_dnt.polyfills.js +122 -0
- package/esm/deps/jsr.io/@std/collections/1.1.5/deep_merge.d.ts +322 -0
- package/esm/deps/jsr.io/@std/collections/1.1.5/deep_merge.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.1.5/deep_merge.js +105 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.d.ts +14 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.js +34 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.d.ts +13 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.js +18 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_same_path.d.ts +10 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_same_path.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_same_path.js +17 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_subdir.d.ts +12 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_subdir.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_is_subdir.js +25 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_to_path_string.d.ts +9 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_to_path_string.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/_to_path_string.js +13 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/copy.d.ts +117 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/copy.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/copy.js +313 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/empty_dir.d.ts +48 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/empty_dir.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/empty_dir.js +87 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_dir.d.ts +49 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_dir.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_dir.js +102 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_file.d.ts +47 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_file.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_file.js +90 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_link.d.ts +49 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_link.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_link.js +61 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.d.ts +70 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.js +156 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/eol.d.ts +52 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/eol.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/eol.js +67 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/exists.d.ts +218 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/exists.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/exists.js +271 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/expand_glob.d.ts +267 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/expand_glob.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/expand_glob.js +442 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/mod.d.ts +29 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/mod.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/mod.js +29 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/move.d.ts +86 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/move.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/move.js +142 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/walk.d.ts +777 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/walk.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/fs/1.0.22/walk.js +846 -0
- package/esm/deps/jsr.io/@std/json/1.0.2/types.d.ts +5 -0
- package/esm/deps/jsr.io/@std/json/1.0.2/types.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/json/1.0.2/types.js +3 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/mod.d.ts +20 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/mod.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/mod.js +21 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/parse.d.ts +21 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/parse.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/jsonc/1.0.2/parse.js +320 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/_parser.d.ts +93 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/_parser.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/_parser.js +753 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/mod.d.ts +109 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/mod.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/mod.js +110 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/parse.d.ts +21 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/parse.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/parse.js +25 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/stringify.d.ts +35 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/stringify.d.ts.map +1 -0
- package/esm/deps/jsr.io/@std/toml/1.0.11/stringify.js +283 -0
- package/esm/gambit/simulator-ui/dist/bundle.js +10647 -4637
- package/esm/gambit/simulator-ui/dist/bundle.js.map +4 -4
- package/esm/mod.d.ts +13 -3
- package/esm/mod.d.ts.map +1 -1
- package/esm/mod.js +8 -2
- package/esm/src/cli_utils.d.ts +1 -0
- package/esm/src/cli_utils.d.ts.map +1 -1
- package/esm/src/cli_utils.js +13 -1
- package/esm/src/default_runtime.d.ts +46 -0
- package/esm/src/default_runtime.d.ts.map +1 -0
- package/esm/src/default_runtime.js +415 -0
- package/esm/src/durable_streams.js +26 -1
- package/esm/src/model_matchers.d.ts +10 -0
- package/esm/src/model_matchers.d.ts.map +1 -0
- package/esm/src/model_matchers.js +26 -0
- package/esm/src/openai_compat.d.ts +12 -1
- package/esm/src/openai_compat.d.ts.map +1 -1
- package/esm/src/openai_compat.js +53 -1
- package/esm/src/project_config.d.ts +47 -0
- package/esm/src/project_config.d.ts.map +1 -0
- package/esm/src/project_config.js +134 -0
- package/esm/src/providers/codex.d.ts +37 -0
- package/esm/src/providers/codex.d.ts.map +1 -0
- package/esm/src/providers/codex.js +810 -0
- package/esm/src/providers/google.d.ts +3 -1
- package/esm/src/providers/google.d.ts.map +1 -1
- package/esm/src/providers/google.js +82 -6
- package/esm/src/providers/ollama.d.ts +3 -1
- package/esm/src/providers/ollama.d.ts.map +1 -1
- package/esm/src/providers/ollama.js +238 -15
- package/esm/src/providers/openrouter.d.ts +6 -2
- package/esm/src/providers/openrouter.d.ts.map +1 -1
- package/esm/src/providers/openrouter.js +260 -23
- package/esm/src/providers/router.d.ts +19 -0
- package/esm/src/providers/router.d.ts.map +1 -0
- package/esm/src/providers/router.js +93 -0
- package/esm/src/server.d.ts +9 -0
- package/esm/src/server.d.ts.map +1 -1
- package/esm/src/server.js +3186 -652
- package/esm/src/server_feedback_grading_routes.d.ts +32 -0
- package/esm/src/server_feedback_grading_routes.d.ts.map +1 -0
- package/esm/src/server_feedback_grading_routes.js +305 -0
- package/esm/src/server_helpers.d.ts +4 -0
- package/esm/src/server_helpers.d.ts.map +1 -0
- package/esm/src/server_helpers.js +46 -0
- package/esm/src/server_session_store.d.ts +87 -0
- package/esm/src/server_session_store.d.ts.map +1 -0
- package/esm/src/server_session_store.js +873 -0
- package/esm/src/server_types.d.ts +110 -0
- package/esm/src/server_types.d.ts.map +1 -0
- package/esm/src/server_types.js +1 -0
- package/esm/src/server_ui_routes.d.ts +33 -0
- package/esm/src/server_ui_routes.d.ts.map +1 -0
- package/esm/src/server_ui_routes.js +135 -0
- package/esm/src/session_artifacts.d.ts +22 -0
- package/esm/src/session_artifacts.d.ts.map +1 -0
- package/esm/src/session_artifacts.js +243 -0
- package/esm/src/trace.d.ts.map +1 -1
- package/esm/src/trace.js +6 -3
- package/esm/src/workspace.d.ts +19 -0
- package/esm/src/workspace.d.ts.map +1 -0
- package/esm/src/workspace.js +164 -0
- package/esm/src/workspace_contract.d.ts +76 -0
- package/esm/src/workspace_contract.d.ts.map +1 -0
- package/esm/src/workspace_contract.js +74 -0
- package/package.json +2 -2
- package/script/_dnt.polyfills.d.ts +17 -0
- package/script/_dnt.polyfills.d.ts.map +1 -1
- package/script/_dnt.polyfills.js +122 -0
- package/script/deps/jsr.io/@std/collections/1.1.5/deep_merge.d.ts +322 -0
- package/script/deps/jsr.io/@std/collections/1.1.5/deep_merge.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/collections/1.1.5/deep_merge.js +108 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.d.ts +14 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_create_walk_entry.js +71 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.d.ts +13 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_get_file_info_type.js +21 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_same_path.d.ts +10 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_same_path.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_same_path.js +20 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_subdir.d.ts +12 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_subdir.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_is_subdir.js +28 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_to_path_string.d.ts +9 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_to_path_string.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/_to_path_string.js +16 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/copy.d.ts +117 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/copy.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/copy.js +350 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/empty_dir.d.ts +48 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/empty_dir.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/empty_dir.js +124 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_dir.d.ts +49 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_dir.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_dir.js +139 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_file.d.ts +47 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_file.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_file.js +127 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_link.d.ts +49 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_link.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_link.js +98 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.d.ts +70 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/ensure_symlink.js +193 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/eol.d.ts +52 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/eol.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/eol.js +105 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/exists.d.ts +218 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/exists.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/exists.js +308 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/expand_glob.d.ts +267 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/expand_glob.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/expand_glob.js +479 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/mod.d.ts +29 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/mod.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/mod.js +45 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/move.d.ts +86 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/move.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/move.js +179 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/walk.d.ts +777 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/walk.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/fs/1.0.22/walk.js +883 -0
- package/script/deps/jsr.io/@std/json/1.0.2/types.d.ts +5 -0
- package/script/deps/jsr.io/@std/json/1.0.2/types.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/json/1.0.2/types.js +4 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/mod.d.ts +20 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/mod.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/mod.js +37 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/parse.d.ts +21 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/parse.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/jsonc/1.0.2/parse.js +323 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/_parser.d.ts +93 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/_parser.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/_parser.js +781 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/mod.d.ts +109 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/mod.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/mod.js +126 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/parse.d.ts +21 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/parse.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/parse.js +28 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/stringify.d.ts +35 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/stringify.d.ts.map +1 -0
- package/script/deps/jsr.io/@std/toml/1.0.11/stringify.js +286 -0
- package/script/gambit/simulator-ui/dist/bundle.js +10647 -4637
- package/script/gambit/simulator-ui/dist/bundle.js.map +4 -4
- package/script/mod.d.ts +13 -3
- package/script/mod.d.ts.map +1 -1
- package/script/mod.js +14 -5
- package/script/src/cli_utils.d.ts +1 -0
- package/script/src/cli_utils.d.ts.map +1 -1
- package/script/src/cli_utils.js +14 -1
- package/script/src/default_runtime.d.ts +46 -0
- package/script/src/default_runtime.d.ts.map +1 -0
- package/script/src/default_runtime.js +452 -0
- package/script/src/durable_streams.js +26 -1
- package/script/src/model_matchers.d.ts +10 -0
- package/script/src/model_matchers.d.ts.map +1 -0
- package/script/src/model_matchers.js +29 -0
- package/script/src/openai_compat.d.ts +12 -1
- package/script/src/openai_compat.d.ts.map +1 -1
- package/script/src/openai_compat.js +85 -0
- package/script/src/project_config.d.ts +47 -0
- package/script/src/project_config.d.ts.map +1 -0
- package/script/src/project_config.js +173 -0
- package/script/src/providers/codex.d.ts +37 -0
- package/script/src/providers/codex.d.ts.map +1 -0
- package/script/src/providers/codex.js +850 -0
- package/script/src/providers/google.d.ts +3 -1
- package/script/src/providers/google.d.ts.map +1 -1
- package/script/src/providers/google.js +82 -6
- package/script/src/providers/ollama.d.ts +3 -1
- package/script/src/providers/ollama.d.ts.map +1 -1
- package/script/src/providers/ollama.js +238 -15
- package/script/src/providers/openrouter.d.ts +6 -2
- package/script/src/providers/openrouter.d.ts.map +1 -1
- package/script/src/providers/openrouter.js +260 -23
- package/script/src/providers/router.d.ts +19 -0
- package/script/src/providers/router.d.ts.map +1 -0
- package/script/src/providers/router.js +96 -0
- package/script/src/server.d.ts +9 -0
- package/script/src/server.d.ts.map +1 -1
- package/script/src/server.js +3193 -659
- package/script/src/server_feedback_grading_routes.d.ts +32 -0
- package/script/src/server_feedback_grading_routes.d.ts.map +1 -0
- package/script/src/server_feedback_grading_routes.js +343 -0
- package/script/src/server_helpers.d.ts +4 -0
- package/script/src/server_helpers.d.ts.map +1 -0
- package/script/src/server_helpers.js +84 -0
- package/script/src/server_session_store.d.ts +87 -0
- package/script/src/server_session_store.d.ts.map +1 -0
- package/script/src/server_session_store.js +910 -0
- package/script/src/server_types.d.ts +110 -0
- package/script/src/server_types.d.ts.map +1 -0
- package/script/src/server_types.js +2 -0
- package/script/src/server_ui_routes.d.ts +33 -0
- package/script/src/server_ui_routes.d.ts.map +1 -0
- package/script/src/server_ui_routes.js +172 -0
- package/script/src/session_artifacts.d.ts +22 -0
- package/script/src/session_artifacts.d.ts.map +1 -0
- package/script/src/session_artifacts.js +279 -0
- package/script/src/trace.d.ts.map +1 -1
- package/script/src/trace.js +6 -3
- package/script/src/workspace.d.ts +19 -0
- package/script/src/workspace.d.ts.map +1 -0
- package/script/src/workspace.js +201 -0
- package/script/src/workspace_contract.d.ts +76 -0
- package/script/src/workspace_contract.d.ts.map +1 -0
- package/script/src/workspace_contract.js +82 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openai_compat.d.ts","sourceRoot":"","sources":["../../src/src/openai_compat.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"openai_compat.d.ts","sourceRoot":"","sources":["../../src/src/openai_compat.ts"],"names":[],"mappings":"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"}
|
package/esm/src/openai_compat.js
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import
|
|
1
|
+
import * as dntShim from "../_dnt.shims.js";
|
|
2
|
+
import * as path from "../deps/jsr.io/@std/path/1.1.4/mod.js";
|
|
3
|
+
import { assertZodSchema, DEFAULT_GUARDRAILS, loadDeck, RESERVED_TOOL_PREFIX, resolveEffectivePermissions, runDeck, toJsonSchema, } from "@bolt-foundry/gambit-core";
|
|
2
4
|
export const logger = console;
|
|
3
5
|
function randomId(prefix) {
|
|
4
6
|
const suffix = crypto.randomUUID().replace(/-/g, "").slice(0, 24);
|
|
@@ -146,6 +148,32 @@ export async function chatCompletionsWithDeck(args) {
|
|
|
146
148
|
const guardrails = { ...DEFAULT_GUARDRAILS, ...args.guardrails };
|
|
147
149
|
const runId = randomId("run");
|
|
148
150
|
const deck = await loadDeck(args.deckPath);
|
|
151
|
+
const rootPermissions = resolveEffectivePermissions({
|
|
152
|
+
baseDir: path.dirname(deck.path),
|
|
153
|
+
parent: args.parentPermissions,
|
|
154
|
+
workspace: args.workspacePermissions
|
|
155
|
+
? {
|
|
156
|
+
baseDir: args.workspacePermissionsBaseDir ?? path.dirname(deck.path),
|
|
157
|
+
permissions: args.workspacePermissions,
|
|
158
|
+
}
|
|
159
|
+
: undefined,
|
|
160
|
+
declaration: deck.permissions
|
|
161
|
+
? {
|
|
162
|
+
baseDir: path.dirname(deck.path),
|
|
163
|
+
permissions: deck.permissions,
|
|
164
|
+
}
|
|
165
|
+
: undefined,
|
|
166
|
+
session: args.sessionPermissions
|
|
167
|
+
? {
|
|
168
|
+
baseDir: args.sessionPermissionsBaseDir ?? dntShim.Deno.cwd(),
|
|
169
|
+
permissions: args.sessionPermissions,
|
|
170
|
+
}
|
|
171
|
+
: undefined,
|
|
172
|
+
});
|
|
173
|
+
args.trace?.({
|
|
174
|
+
type: "openai_compat.permissions",
|
|
175
|
+
permissions: rootPermissions.trace,
|
|
176
|
+
});
|
|
149
177
|
const systemPrompt = deckSystemPrompt(deck);
|
|
150
178
|
const providedMessages = normalizeMessages(args.request.messages);
|
|
151
179
|
const messages = [];
|
|
@@ -180,6 +208,7 @@ export async function chatCompletionsWithDeck(args) {
|
|
|
180
208
|
messages,
|
|
181
209
|
tools: tools.length ? tools : undefined,
|
|
182
210
|
stream: Boolean(args.request.stream),
|
|
211
|
+
deckPath: deck.path,
|
|
183
212
|
onStreamText: args.onStreamText,
|
|
184
213
|
params: providerParamsFromRequest(args.request),
|
|
185
214
|
});
|
|
@@ -215,6 +244,21 @@ export async function chatCompletionsWithDeck(args) {
|
|
|
215
244
|
if (!actionPath)
|
|
216
245
|
continue;
|
|
217
246
|
try {
|
|
247
|
+
const actionRef = deck.actionDecks.find((entry) => entry.name === call.name);
|
|
248
|
+
const actionPermissions = resolveEffectivePermissions({
|
|
249
|
+
baseDir: path.dirname(deck.path),
|
|
250
|
+
parent: rootPermissions.effective,
|
|
251
|
+
reference: actionRef?.permissions
|
|
252
|
+
? {
|
|
253
|
+
baseDir: path.dirname(deck.path),
|
|
254
|
+
permissions: actionRef.permissions,
|
|
255
|
+
}
|
|
256
|
+
: undefined,
|
|
257
|
+
});
|
|
258
|
+
args.trace?.({
|
|
259
|
+
type: "openai_compat.action.permissions",
|
|
260
|
+
permissions: actionPermissions.trace,
|
|
261
|
+
});
|
|
218
262
|
const childResult = await runDeck({
|
|
219
263
|
path: actionPath,
|
|
220
264
|
input: call.args,
|
|
@@ -230,6 +274,14 @@ export async function chatCompletionsWithDeck(args) {
|
|
|
230
274
|
stream: Boolean(args.request.stream),
|
|
231
275
|
onStreamText: args.onStreamText,
|
|
232
276
|
inputProvided: true,
|
|
277
|
+
parentPermissions: rootPermissions.effective,
|
|
278
|
+
referencePermissions: actionRef?.permissions,
|
|
279
|
+
referencePermissionsBaseDir: path.dirname(deck.path),
|
|
280
|
+
workspacePermissions: args.workspacePermissions,
|
|
281
|
+
workspacePermissionsBaseDir: args.workspacePermissionsBaseDir,
|
|
282
|
+
sessionPermissions: args.sessionPermissions,
|
|
283
|
+
sessionPermissionsBaseDir: args.sessionPermissionsBaseDir,
|
|
284
|
+
workerSandbox: args.workerSandbox,
|
|
233
285
|
});
|
|
234
286
|
messages.push({
|
|
235
287
|
role: "tool",
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { PermissionDeclarationInput } from "@bolt-foundry/gambit-core";
|
|
2
|
+
export type WorkspaceConfig = {
|
|
3
|
+
decks?: string;
|
|
4
|
+
actions?: string;
|
|
5
|
+
graders?: string;
|
|
6
|
+
tests?: string;
|
|
7
|
+
schemas?: string;
|
|
8
|
+
permissions?: PermissionDeclarationInput;
|
|
9
|
+
};
|
|
10
|
+
export type ModelAliasConfig = {
|
|
11
|
+
model?: string | Array<string>;
|
|
12
|
+
description?: string;
|
|
13
|
+
params?: Record<string, unknown>;
|
|
14
|
+
};
|
|
15
|
+
export type GambitConfig = {
|
|
16
|
+
workspace?: WorkspaceConfig;
|
|
17
|
+
execution?: {
|
|
18
|
+
workerSandbox?: boolean;
|
|
19
|
+
worker_sandbox?: boolean;
|
|
20
|
+
legacyExec?: boolean;
|
|
21
|
+
legacy_exec?: boolean;
|
|
22
|
+
};
|
|
23
|
+
models?: {
|
|
24
|
+
aliases?: Record<string, ModelAliasConfig>;
|
|
25
|
+
};
|
|
26
|
+
providers?: {
|
|
27
|
+
fallback?: string;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
export type LoadedProjectConfig = {
|
|
31
|
+
root: string;
|
|
32
|
+
path: string;
|
|
33
|
+
config: GambitConfig;
|
|
34
|
+
};
|
|
35
|
+
export declare function loadProjectConfig(startPath?: string): Promise<LoadedProjectConfig | null>;
|
|
36
|
+
export type ModelAliasResolution = {
|
|
37
|
+
model?: string | Array<string>;
|
|
38
|
+
params?: Record<string, unknown>;
|
|
39
|
+
alias?: string;
|
|
40
|
+
applied: boolean;
|
|
41
|
+
missingAlias?: boolean;
|
|
42
|
+
};
|
|
43
|
+
export type ModelAliasResolver = (model?: string) => ModelAliasResolution;
|
|
44
|
+
export declare function createModelAliasResolver(config?: GambitConfig | null): ModelAliasResolver;
|
|
45
|
+
export declare function resolveWorkspacePermissions(config?: GambitConfig | null): PermissionDeclarationInput | undefined;
|
|
46
|
+
export declare function resolveWorkerSandboxSetting(config?: GambitConfig | null): boolean | undefined;
|
|
47
|
+
//# sourceMappingURL=project_config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project_config.d.ts","sourceRoot":"","sources":["../../src/src/project_config.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,2BAA2B,CAAC;AAE5E,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,0BAA0B,CAAC;CAC1C,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IAC/B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,SAAS,CAAC,EAAE,eAAe,CAAC;IAC5B,SAAS,CAAC,EAAE;QACV,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB,cAAc,CAAC,EAAE,OAAO,CAAC;QACzB,UAAU,CAAC,EAAE,OAAO,CAAC;QACrB,WAAW,CAAC,EAAE,OAAO,CAAC;KACvB,CAAC;IACF,MAAM,CAAC,EAAE;QACP,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;KAC5C,CAAC;IACF,SAAS,CAAC,EAAE;QACV,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,YAAY,CAAC;CACtB,CAAC;AAsCF,wBAAsB,iBAAiB,CACrC,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,mBAAmB,GAAG,IAAI,CAAC,CAiBrC;AAED,MAAM,MAAM,oBAAoB,GAAG;IACjC,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,KAAK,oBAAoB,CAAC;AAE1E,wBAAgB,wBAAwB,CACtC,MAAM,CAAC,EAAE,YAAY,GAAG,IAAI,GAC3B,kBAAkB,CA8CpB;AAED,wBAAgB,2BAA2B,CACzC,MAAM,CAAC,EAAE,YAAY,GAAG,IAAI,GAC3B,0BAA0B,GAAG,SAAS,CAIxC;AAOD,wBAAgB,2BAA2B,CACzC,MAAM,CAAC,EAAE,YAAY,GAAG,IAAI,GAC3B,OAAO,GAAG,SAAS,CAsBrB"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import * as dntShim from "../_dnt.shims.js";
|
|
2
|
+
import { parse as parseToml } from "../deps/jsr.io/@std/toml/1.0.11/mod.js";
|
|
3
|
+
import * as path from "../deps/jsr.io/@std/path/1.1.4/mod.js";
|
|
4
|
+
const CONFIG_FILENAME = "gambit.toml";
|
|
5
|
+
const configCache = new Map();
|
|
6
|
+
function isPlainObject(value) {
|
|
7
|
+
return Boolean(value && typeof value === "object" && !Array.isArray(value));
|
|
8
|
+
}
|
|
9
|
+
function resolveStartDir(target) {
|
|
10
|
+
if (!target)
|
|
11
|
+
return dntShim.Deno.cwd();
|
|
12
|
+
const resolved = path.resolve(target);
|
|
13
|
+
try {
|
|
14
|
+
const info = dntShim.Deno.statSync(resolved);
|
|
15
|
+
if (info.isDirectory)
|
|
16
|
+
return resolved;
|
|
17
|
+
return path.dirname(resolved);
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return path.dirname(resolved);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function findConfigPath(startDir) {
|
|
24
|
+
let current = startDir;
|
|
25
|
+
while (true) {
|
|
26
|
+
const candidate = path.join(current, CONFIG_FILENAME);
|
|
27
|
+
try {
|
|
28
|
+
const info = dntShim.Deno.statSync(candidate);
|
|
29
|
+
if (info.isFile)
|
|
30
|
+
return candidate;
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
// ignore and continue walking up the tree
|
|
34
|
+
}
|
|
35
|
+
const parent = path.dirname(current);
|
|
36
|
+
if (parent === current)
|
|
37
|
+
break;
|
|
38
|
+
current = parent;
|
|
39
|
+
}
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
export async function loadProjectConfig(startPath) {
|
|
43
|
+
const startDir = resolveStartDir(startPath);
|
|
44
|
+
const configPath = findConfigPath(startDir);
|
|
45
|
+
if (!configPath)
|
|
46
|
+
return null;
|
|
47
|
+
const cached = configCache.get(configPath);
|
|
48
|
+
if (cached !== undefined) {
|
|
49
|
+
return cached;
|
|
50
|
+
}
|
|
51
|
+
const text = await dntShim.Deno.readTextFile(configPath);
|
|
52
|
+
const parsed = parseToml(text);
|
|
53
|
+
const loaded = {
|
|
54
|
+
root: path.dirname(configPath),
|
|
55
|
+
path: configPath,
|
|
56
|
+
config: parsed ?? {},
|
|
57
|
+
};
|
|
58
|
+
configCache.set(configPath, loaded);
|
|
59
|
+
return loaded;
|
|
60
|
+
}
|
|
61
|
+
export function createModelAliasResolver(config) {
|
|
62
|
+
const resolved = new Map();
|
|
63
|
+
const aliases = config?.models?.aliases;
|
|
64
|
+
if (isPlainObject(aliases)) {
|
|
65
|
+
for (const [name, raw] of Object.entries(aliases)) {
|
|
66
|
+
if (!isPlainObject(raw))
|
|
67
|
+
continue;
|
|
68
|
+
let model;
|
|
69
|
+
if (typeof raw.model === "string") {
|
|
70
|
+
const trimmed = raw.model.trim();
|
|
71
|
+
if (trimmed)
|
|
72
|
+
model = trimmed;
|
|
73
|
+
}
|
|
74
|
+
else if (Array.isArray(raw.model)) {
|
|
75
|
+
const entries = raw.model
|
|
76
|
+
.map((entry) => (typeof entry === "string" ? entry.trim() : ""))
|
|
77
|
+
.filter(Boolean);
|
|
78
|
+
if (entries.length > 0)
|
|
79
|
+
model = entries;
|
|
80
|
+
}
|
|
81
|
+
if (!model)
|
|
82
|
+
continue;
|
|
83
|
+
const params = isPlainObject(raw.params)
|
|
84
|
+
? structuredClone(raw.params)
|
|
85
|
+
: undefined;
|
|
86
|
+
resolved.set(name, { model, params });
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
const hasAliases = resolved.size > 0;
|
|
90
|
+
return (model) => {
|
|
91
|
+
if (!model) {
|
|
92
|
+
return { model, applied: false };
|
|
93
|
+
}
|
|
94
|
+
const entry = resolved.get(model);
|
|
95
|
+
if (entry) {
|
|
96
|
+
return {
|
|
97
|
+
model: entry.model,
|
|
98
|
+
params: entry.params ? structuredClone(entry.params) : undefined,
|
|
99
|
+
alias: model,
|
|
100
|
+
applied: true,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
const missingAlias = hasAliases && !model.includes("/");
|
|
104
|
+
return { model, applied: false, missingAlias };
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
export function resolveWorkspacePermissions(config) {
|
|
108
|
+
const raw = config?.workspace?.permissions;
|
|
109
|
+
if (!isPlainObject(raw))
|
|
110
|
+
return undefined;
|
|
111
|
+
return raw;
|
|
112
|
+
}
|
|
113
|
+
function resolveBooleanField(value) {
|
|
114
|
+
if (typeof value === "boolean")
|
|
115
|
+
return value;
|
|
116
|
+
return undefined;
|
|
117
|
+
}
|
|
118
|
+
export function resolveWorkerSandboxSetting(config) {
|
|
119
|
+
const execution = config?.execution;
|
|
120
|
+
if (!isPlainObject(execution))
|
|
121
|
+
return undefined;
|
|
122
|
+
const workerSandbox = resolveBooleanField(execution.workerSandbox ?? execution.worker_sandbox);
|
|
123
|
+
const legacyExec = resolveBooleanField(execution.legacyExec ?? execution.legacy_exec);
|
|
124
|
+
if (workerSandbox !== undefined && legacyExec !== undefined) {
|
|
125
|
+
if (workerSandbox === legacyExec) {
|
|
126
|
+
throw new Error("gambit.toml execution config is conflicting: worker_sandbox and legacy_exec must be opposites when both are set.");
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
if (workerSandbox !== undefined)
|
|
130
|
+
return workerSandbox;
|
|
131
|
+
if (legacyExec !== undefined)
|
|
132
|
+
return !legacyExec;
|
|
133
|
+
return undefined;
|
|
134
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { JSONValue, ModelMessage, ModelProvider, SavedState } from "@bolt-foundry/gambit-core";
|
|
2
|
+
export declare const CODEX_PREFIX = "codex-cli/";
|
|
3
|
+
type CommandOutput = {
|
|
4
|
+
success: boolean;
|
|
5
|
+
code: number;
|
|
6
|
+
stdout: Uint8Array;
|
|
7
|
+
stderr: Uint8Array;
|
|
8
|
+
};
|
|
9
|
+
type CommandRunner = (input: {
|
|
10
|
+
args: Array<string>;
|
|
11
|
+
cwd: string;
|
|
12
|
+
signal?: AbortSignal;
|
|
13
|
+
onStdoutLine?: (line: string) => void;
|
|
14
|
+
}) => Promise<CommandOutput>;
|
|
15
|
+
export declare function createCodexProvider(opts?: {
|
|
16
|
+
runCommand?: CommandRunner;
|
|
17
|
+
}): ModelProvider;
|
|
18
|
+
export declare function parseCodexArgsForTest(input: {
|
|
19
|
+
model: string;
|
|
20
|
+
state?: SavedState;
|
|
21
|
+
messages: Array<ModelMessage>;
|
|
22
|
+
params?: Record<string, unknown>;
|
|
23
|
+
cwd?: string;
|
|
24
|
+
deckPath?: string;
|
|
25
|
+
}): Array<string>;
|
|
26
|
+
export declare function parseCodexStdoutForTest(stdout: string): {
|
|
27
|
+
threadId?: string;
|
|
28
|
+
assistantText: string;
|
|
29
|
+
usage?: {
|
|
30
|
+
promptTokens: number;
|
|
31
|
+
completionTokens: number;
|
|
32
|
+
totalTokens: number;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
export declare function safeJsonForTest(text: string): Record<string, JSONValue>;
|
|
36
|
+
export {};
|
|
37
|
+
//# sourceMappingURL=codex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codex.d.ts","sourceRoot":"","sources":["../../../src/src/providers/codex.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAGV,SAAS,EACT,YAAY,EACZ,aAAa,EAIb,UAAU,EACX,MAAM,2BAA2B,CAAC;AAEnC,eAAO,MAAM,YAAY,eAAe,CAAC;AAiCzC,KAAK,aAAa,GAAG;IACnB,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,UAAU,CAAC;IACnB,MAAM,EAAE,UAAU,CAAC;CACpB,CAAC;AAEF,KAAK,aAAa,GAAG,CAAC,KAAK,EAAE;IAC3B,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACvC,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC;AA0oB7B,wBAAgB,mBAAmB,CAAC,IAAI,CAAC,EAAE;IACzC,UAAU,CAAC,EAAE,aAAa,CAAC;CAC5B,GAAG,aAAa,CAmNhB;AAED,wBAAgB,qBAAqB,CAAC,KAAK,EAAE;IAC3C,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACjC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,GAAG,KAAK,CAAC,MAAM,CAAC,CA2BhB;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE;QACN,YAAY,EAAE,MAAM,CAAC;QACrB,gBAAgB,EAAE,MAAM,CAAC;QACzB,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC;CACH,CAEA;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAEvE"}
|