@dxos/assistant-toolkit 0.8.4-main.9be5663bfe → 0.8.4-main.abd8ff62ef
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/lib/neutral/{add-artifact-5TOKSVLY.mjs → add-artifact-BA5WQRDU.mjs} +7 -7
- package/dist/lib/neutral/add-artifact-BA5WQRDU.mjs.map +7 -0
- package/dist/lib/neutral/agent-M2EW5M36.mjs +65 -0
- package/dist/lib/neutral/agent-M2EW5M36.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-V77TCYSP.mjs → chunk-CLHVRIYF.mjs} +76 -29
- package/dist/lib/neutral/chunk-CLHVRIYF.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-IVXBQQDJ.mjs → chunk-CVUA23QI.mjs} +2 -2
- package/dist/lib/neutral/chunk-CVUA23QI.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-MEQYXSDY.mjs → chunk-D5MG5OKX.mjs} +5 -6
- package/dist/lib/neutral/chunk-D5MG5OKX.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-B5NOGNUG.mjs → chunk-E2XRNXWP.mjs} +7 -10
- package/dist/lib/neutral/chunk-E2XRNXWP.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-BO4ZVH7M.mjs → chunk-EJAQUAKM.mjs} +3 -3
- package/dist/lib/neutral/chunk-EJAQUAKM.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-PWGX4QYR.mjs → chunk-J37DYY7A.mjs} +7 -9
- package/dist/lib/neutral/chunk-J37DYY7A.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-TCRQCJEJ.mjs → chunk-JCYLFOFK.mjs} +9 -9
- package/dist/lib/neutral/chunk-JCYLFOFK.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-YBTLIXQK.mjs → chunk-KGU725LW.mjs} +2 -2
- package/dist/lib/neutral/{chunk-YBTLIXQK.mjs.map → chunk-KGU725LW.mjs.map} +3 -3
- package/dist/lib/neutral/{chunk-VD2WAUU2.mjs → chunk-KY2TIPJ5.mjs} +47 -17
- package/dist/lib/neutral/chunk-KY2TIPJ5.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-B35UIL3R.mjs → chunk-MMTKJBB5.mjs} +3 -3
- package/dist/lib/neutral/chunk-MMTKJBB5.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-DV5DCOUE.mjs → chunk-NR3GTWRC.mjs} +3 -2
- package/dist/lib/neutral/chunk-NR3GTWRC.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-6DPL2YY5.mjs → chunk-TO5IX24K.mjs} +3 -4
- package/dist/lib/neutral/chunk-TO5IX24K.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-MEZ4UFR6.mjs → chunk-WLR3BGO4.mjs} +2 -2
- package/dist/lib/neutral/chunk-WLR3BGO4.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-AGG6OZNB.mjs → chunk-ZFXLTBZG.mjs} +4 -5
- package/dist/lib/neutral/chunk-ZFXLTBZG.mjs.map +7 -0
- package/dist/lib/neutral/{context-add-QAHU6I24.mjs → context-add-IIDPRRVB.mjs} +3 -3
- package/dist/lib/neutral/{context-add-QAHU6I24.mjs.map → context-add-IIDPRRVB.mjs.map} +1 -1
- package/dist/lib/neutral/{context-remove-VMZPMZ4E.mjs → context-remove-RDYV4PD4.mjs} +3 -3
- package/dist/lib/neutral/{context-remove-VMZPMZ4E.mjs.map → context-remove-RDYV4PD4.mjs.map} +1 -1
- package/dist/lib/neutral/{create-project-SI5SZ7LJ.mjs → create-project-GLDEAWTT.mjs} +10 -11
- package/dist/lib/neutral/create-project-GLDEAWTT.mjs.map +7 -0
- package/dist/lib/neutral/{delete-LHMZDJFA.mjs → delete-J3PMWP7Z.mjs} +4 -4
- package/dist/lib/neutral/delete-J3PMWP7Z.mjs.map +7 -0
- package/dist/lib/neutral/{enable-blueprints-4UMPKGUD.mjs → enable-blueprints-LBDZH2CY.mjs} +3 -4
- package/dist/lib/neutral/enable-blueprints-LBDZH2CY.mjs.map +7 -0
- package/dist/lib/neutral/{fetch-TLKREIZA.mjs → fetch-KHMHV7JR.mjs} +3 -3
- package/dist/lib/neutral/{fetch-TLKREIZA.mjs.map → fetch-KHMHV7JR.mjs.map} +1 -1
- package/dist/lib/neutral/{fetch-messages-AFX7ZAVE.mjs → fetch-messages-PWGUG5G3.mjs} +8 -23
- package/dist/lib/neutral/fetch-messages-PWGUG5G3.mjs.map +7 -0
- package/dist/lib/neutral/{get-context-57JQM4HZ.mjs → get-context-B55SX5Y4.mjs} +7 -7
- package/dist/lib/neutral/get-context-B55SX5Y4.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +787 -131
- package/dist/lib/neutral/index.mjs.map +4 -4
- package/dist/lib/neutral/{load-ZTOGVHWP.mjs → load-LI7HHVD6.mjs} +3 -3
- package/dist/lib/neutral/{load-ZTOGVHWP.mjs.map → load-LI7HHVD6.mjs.map} +3 -3
- package/dist/lib/neutral/meta.json +1 -1
- package/dist/lib/neutral/{object-create-7QCGL56E.mjs → object-create-52Z7YKIA.mjs} +4 -12
- package/dist/lib/neutral/object-create-52Z7YKIA.mjs.map +7 -0
- package/dist/lib/neutral/{object-delete-KXBWC4Q4.mjs → object-delete-I266YAXI.mjs} +3 -3
- package/dist/lib/neutral/object-delete-I266YAXI.mjs.map +7 -0
- package/dist/lib/neutral/{object-update-B7RDX3JC.mjs → object-update-HY4GI7LA.mjs} +4 -4
- package/dist/lib/neutral/object-update-HY4GI7LA.mjs.map +7 -0
- package/dist/lib/neutral/{project-3J3AJCJK.mjs → project-2YBPW5N7.mjs} +6 -6
- package/dist/lib/neutral/{project-rules-NO3QVDZS.mjs → project-rules-XUBEPDP6.mjs} +7 -7
- package/dist/lib/neutral/project-rules-XUBEPDP6.mjs.map +7 -0
- package/dist/lib/neutral/{prompt-K5CIRXOD.mjs → prompt-2WZQERT4.mjs} +39 -65
- package/dist/lib/neutral/prompt-2WZQERT4.mjs.map +7 -0
- package/dist/lib/neutral/{qualifier-KSGP4CFL.mjs → qualifier-2AC2ICOB.mjs} +12 -28
- package/dist/lib/neutral/qualifier-2AC2ICOB.mjs.map +7 -0
- package/dist/lib/neutral/{query-FMGIPWJG.mjs → query-B3NOYFCK.mjs} +4 -5
- package/dist/lib/neutral/query-B3NOYFCK.mjs.map +7 -0
- package/dist/lib/neutral/{query-MN5B3MQF.mjs → query-U56GNEV6.mjs} +4 -4
- package/dist/lib/neutral/query-U56GNEV6.mjs.map +7 -0
- package/dist/lib/neutral/{query-blueprints-EKHEZAGD.mjs → query-blueprints-KXADGHSA.mjs} +3 -4
- package/dist/lib/neutral/query-blueprints-KXADGHSA.mjs.map +7 -0
- package/dist/lib/neutral/{relation-create-FSHBM5CJ.mjs → relation-create-Z3NGW4VU.mjs} +4 -12
- package/dist/lib/neutral/relation-create-Z3NGW4VU.mjs.map +7 -0
- package/dist/lib/neutral/{relation-delete-CYYQUIZY.mjs → relation-delete-LXY7W2YO.mjs} +3 -3
- package/dist/lib/neutral/relation-delete-LXY7W2YO.mjs.map +7 -0
- package/dist/lib/neutral/{save-ZWWNTBOD.mjs → save-GWAPLT3Z.mjs} +4 -4
- package/dist/lib/neutral/save-GWAPLT3Z.mjs.map +7 -0
- package/dist/lib/neutral/{schema-add-RVV364G6.mjs → schema-add-4TXJO2V7.mjs} +3 -3
- package/dist/lib/neutral/schema-add-4TXJO2V7.mjs.map +7 -0
- package/dist/lib/neutral/{schema-list-DVKEWYIU.mjs → schema-list-PJS5AFZ3.mjs} +13 -5
- package/dist/lib/neutral/schema-list-PJS5AFZ3.mjs.map +7 -0
- package/dist/lib/neutral/{sync-issues-BBAMXSZN.mjs → sync-issues-LOLHZNFL.mjs} +8 -20
- package/dist/lib/neutral/sync-issues-LOLHZNFL.mjs.map +7 -0
- package/dist/lib/neutral/{sync-triggers-6EXPBHIQ.mjs → sync-triggers-EYJM4QWR.mjs} +39 -20
- package/dist/lib/neutral/sync-triggers-EYJM4QWR.mjs.map +7 -0
- package/dist/lib/neutral/{tag-add-OUDUBR3E.mjs → tag-add-5NOHUTIE.mjs} +4 -4
- package/dist/lib/neutral/tag-add-5NOHUTIE.mjs.map +7 -0
- package/dist/lib/neutral/{tag-remove-DI3ZSLFK.mjs → tag-remove-QTKYDJAW.mjs} +4 -4
- package/dist/lib/neutral/tag-remove-QTKYDJAW.mjs.map +7 -0
- package/dist/lib/neutral/testing/index.mjs +7 -12
- package/dist/lib/neutral/testing/index.mjs.map +3 -3
- package/dist/lib/neutral/{update-blueprints-ZNWR7BBN.mjs → update-blueprints-N2AK2VUR.mjs} +3 -4
- package/dist/lib/neutral/update-blueprints-N2AK2VUR.mjs.map +7 -0
- package/dist/lib/neutral/{update-tasks-3YZ3YXIU.mjs → update-tasks-ML2FCYU5.mjs} +7 -7
- package/dist/lib/neutral/update-tasks-ML2FCYU5.mjs.map +7 -0
- package/dist/types/src/blueprints/automation/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/automation/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/blueprint-manager/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/definitions.d.ts +11 -12
- package/dist/types/src/blueprints/blueprint-manager/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/enable-blueprints.d.ts +6 -7
- package/dist/types/src/blueprints/blueprint-manager/functions/enable-blueprints.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/query-blueprints.d.ts +5 -6
- package/dist/types/src/blueprints/blueprint-manager/functions/query-blueprints.d.ts.map +1 -1
- package/dist/types/src/blueprints/blueprint-manager/functions/update-blueprints.d.ts +2 -3
- package/dist/types/src/blueprints/blueprint-manager/functions/update-blueprints.d.ts.map +1 -1
- package/dist/types/src/blueprints/browser/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/browser/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/database/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/context-add.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/context-add.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/context-remove.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/context-remove.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/definitions.d.ts +5 -5
- package/dist/types/src/blueprints/database/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/load.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/load.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/object-create.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/object-create.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/object-delete.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/object-delete.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/object-update.d.ts +2 -2
- package/dist/types/src/blueprints/database/functions/object-update.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/query.d.ts +3 -3
- package/dist/types/src/blueprints/database/functions/query.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/relation-create.d.ts +2 -2
- package/dist/types/src/blueprints/database/functions/relation-create.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/relation-delete.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/relation-delete.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/schema-add.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/schema-add.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/schema-list.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/schema-list.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/tag-add.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/tag-add.d.ts.map +1 -1
- package/dist/types/src/blueprints/database/functions/tag-remove.d.ts +1 -1
- package/dist/types/src/blueprints/database/functions/tag-remove.d.ts.map +1 -1
- package/dist/types/src/blueprints/discord/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/discord/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/discord/functions/definitions.d.ts +2 -3
- package/dist/types/src/blueprints/discord/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/discord/functions/fetch-messages.d.ts +2 -3
- package/dist/types/src/blueprints/discord/functions/fetch-messages.d.ts.map +1 -1
- package/dist/types/src/blueprints/discord/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/discord/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/github/functions/definitions.d.ts +2 -3
- package/dist/types/src/blueprints/github/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/github/functions/fetch-prs.d.ts +2 -3
- package/dist/types/src/blueprints/github/functions/fetch-prs.d.ts.map +1 -1
- package/dist/types/src/blueprints/github/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/github/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/index.d.ts +0 -3
- package/dist/types/src/blueprints/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/linear/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/linear/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/linear/functions/definitions.d.ts +2 -3
- package/dist/types/src/blueprints/linear/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/linear/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/linear/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/linear/functions/sync-issues.d.ts +2 -3
- package/dist/types/src/blueprints/linear/functions/sync-issues.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/memory/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/functions/definitions.d.ts +4 -4
- package/dist/types/src/blueprints/memory/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/functions/delete.d.ts +2 -2
- package/dist/types/src/blueprints/memory/functions/delete.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/memory/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/functions/query.d.ts +2 -2
- package/dist/types/src/blueprints/memory/functions/query.d.ts.map +1 -1
- package/dist/types/src/blueprints/memory/functions/save.d.ts +2 -2
- package/dist/types/src/blueprints/memory/functions/save.d.ts.map +1 -1
- package/dist/types/src/blueprints/planning/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/planning/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/planning/functions/definitions.d.ts +3 -3
- package/dist/types/src/blueprints/planning/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/planning/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/planning/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/planning/functions/update-tasks.d.ts +3 -3
- package/dist/types/src/blueprints/planning/functions/update-tasks.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/project/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/add-artifact.d.ts +2 -2
- package/dist/types/src/blueprints/project/functions/add-artifact.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/agent.d.ts +1 -1
- package/dist/types/src/blueprints/project/functions/agent.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/definitions.d.ts +46 -39
- package/dist/types/src/blueprints/project/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/get-context.d.ts +4 -4
- package/dist/types/src/blueprints/project/functions/get-context.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/project/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/project/functions/qualifier.d.ts +20 -16
- package/dist/types/src/blueprints/project/functions/qualifier.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/project-wizard/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/create-project.d.ts +20 -17
- package/dist/types/src/blueprints/project-wizard/functions/create-project.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/definitions.d.ts +36 -29
- package/dist/types/src/blueprints/project-wizard/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/project-rules.d.ts +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/project-rules.d.ts.map +1 -1
- package/dist/types/src/blueprints/project-wizard/functions/sync-triggers.d.ts +17 -13
- package/dist/types/src/blueprints/project-wizard/functions/sync-triggers.d.ts.map +1 -1
- package/dist/types/src/blueprints/testing.d.ts +5 -13
- package/dist/types/src/blueprints/testing.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/websearch/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/functions/definitions.d.ts +1 -1
- package/dist/types/src/blueprints/websearch/functions/definitions.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/functions/fetch.d.ts +1 -1
- package/dist/types/src/blueprints/websearch/functions/fetch.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/functions/index.d.ts +1 -1
- package/dist/types/src/blueprints/websearch/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/index.d.ts +1 -1
- package/dist/types/src/blueprints/websearch/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/websearch/toolkit.d.ts +2 -2
- package/dist/types/src/blueprints/websearch/toolkit.d.ts.map +1 -1
- package/dist/types/src/crud/graph.d.ts +1 -1
- package/dist/types/src/crud/graph.d.ts.map +1 -1
- package/dist/types/src/errors.d.ts +6 -6
- package/dist/types/src/errors.d.ts.map +1 -1
- package/dist/types/src/functions/agent/definitions.d.ts +15 -15
- package/dist/types/src/functions/agent/definitions.d.ts.map +1 -1
- package/dist/types/src/functions/agent/index.d.ts +1 -1
- package/dist/types/src/functions/agent/index.d.ts.map +1 -1
- package/dist/types/src/functions/agent/prompt.d.ts +1 -1
- package/dist/types/src/functions/agent/prompt.d.ts.map +1 -1
- package/dist/types/src/functions/index.d.ts +0 -2
- package/dist/types/src/functions/index.d.ts.map +1 -1
- package/dist/types/src/sync/sync.d.ts.map +1 -1
- package/dist/types/src/testing/plugins.d.ts.map +1 -1
- package/dist/types/src/types/Agent.d.ts +19 -15
- package/dist/types/src/types/Agent.d.ts.map +1 -1
- package/dist/types/src/types/Chat.d.ts +8 -4
- package/dist/types/src/types/Chat.d.ts.map +1 -1
- package/dist/types/src/types/McpServer.d.ts +18 -0
- package/dist/types/src/types/McpServer.d.ts.map +1 -0
- package/dist/types/src/types/Memory.d.ts +1 -1
- package/dist/types/src/types/Memory.d.ts.map +1 -1
- package/dist/types/src/types/Plan.d.ts +17 -14
- package/dist/types/src/types/Plan.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +1 -0
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/util/graphql.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +25 -30
- package/src/blueprints/automation/blueprint.ts +2 -5
- package/src/blueprints/blueprint-manager/blueprint.conversations.json +1 -1
- package/src/blueprints/blueprint-manager/blueprint.test.ts +59 -37
- package/src/blueprints/blueprint-manager/blueprint.ts +2 -3
- package/src/blueprints/blueprint-manager/functions/definitions.ts +2 -3
- package/src/blueprints/blueprint-manager/functions/enable-blueprints.ts +1 -2
- package/src/blueprints/blueprint-manager/functions/index.ts +1 -1
- package/src/blueprints/blueprint-manager/functions/query-blueprints.ts +1 -2
- package/src/blueprints/blueprint-manager/functions/update-blueprints.ts +1 -2
- package/src/blueprints/browser/blueprint.test.ts +6 -8
- package/src/blueprints/browser/blueprint.ts +2 -3
- package/src/blueprints/database/blueprint.conversations.json +1 -1
- package/src/blueprints/database/blueprint.test.ts +49 -8
- package/src/blueprints/database/blueprint.ts +2 -3
- package/src/blueprints/database/functions/context-add.ts +1 -1
- package/src/blueprints/database/functions/context-remove.ts +1 -1
- package/src/blueprints/database/functions/definitions.ts +1 -1
- package/src/blueprints/database/functions/index.ts +1 -1
- package/src/blueprints/database/functions/load.ts +1 -1
- package/src/blueprints/database/functions/object-create.ts +1 -1
- package/src/blueprints/database/functions/object-delete.ts +1 -1
- package/src/blueprints/database/functions/object-update.ts +2 -2
- package/src/blueprints/database/functions/query.ts +2 -3
- package/src/blueprints/database/functions/relation-create.ts +1 -1
- package/src/blueprints/database/functions/relation-delete.ts +1 -1
- package/src/blueprints/database/functions/schema-add.ts +1 -1
- package/src/blueprints/database/functions/schema-list.ts +16 -10
- package/src/blueprints/database/functions/tag-add.ts +2 -2
- package/src/blueprints/database/functions/tag-remove.ts +2 -2
- package/src/blueprints/discord/blueprint.ts +2 -3
- package/src/blueprints/discord/functions/definitions.ts +2 -3
- package/src/blueprints/discord/functions/fetch-messages.test.ts +15 -26
- package/src/blueprints/discord/functions/fetch-messages.ts +4 -5
- package/src/blueprints/discord/functions/index.ts +1 -1
- package/src/blueprints/github/functions/definitions.ts +2 -3
- package/src/blueprints/github/functions/fetch-prs.ts +3 -3
- package/src/blueprints/github/functions/index.ts +1 -1
- package/src/blueprints/index.ts +0 -3
- package/src/blueprints/linear/blueprint.ts +2 -3
- package/src/blueprints/linear/functions/definitions.ts +2 -3
- package/src/blueprints/linear/functions/index.ts +1 -1
- package/src/blueprints/linear/functions/linear.test.ts +4 -5
- package/src/blueprints/linear/functions/sync-issues.ts +3 -3
- package/src/blueprints/memory/blueprint.conversations.json +1 -1
- package/src/blueprints/memory/blueprint.test.ts +5 -5
- package/src/blueprints/memory/blueprint.ts +3 -4
- package/src/blueprints/memory/functions/definitions.ts +1 -1
- package/src/blueprints/memory/functions/delete.ts +1 -1
- package/src/blueprints/memory/functions/index.ts +1 -1
- package/src/blueprints/memory/functions/query.ts +1 -1
- package/src/blueprints/memory/functions/save.ts +1 -1
- package/src/blueprints/planning/blueprint.ts +2 -3
- package/src/blueprints/planning/functions/definitions.ts +1 -1
- package/src/blueprints/planning/functions/index.ts +1 -1
- package/src/blueprints/planning/functions/update-tasks.ts +2 -2
- package/src/blueprints/project/blueprint.conversations.json +1 -1
- package/src/blueprints/project/blueprint.test.ts +127 -36
- package/src/blueprints/project/blueprint.ts +6 -7
- package/src/blueprints/project/functions/add-artifact.ts +2 -2
- package/src/blueprints/project/functions/agent.ts +15 -37
- package/src/blueprints/project/functions/definitions.ts +5 -8
- package/src/blueprints/project/functions/get-context.ts +3 -3
- package/src/blueprints/project/functions/index.ts +1 -1
- package/src/blueprints/project/functions/qualifier.ts +5 -5
- package/src/blueprints/project-wizard/blueprint.ts +12 -8
- package/src/blueprints/project-wizard/functions/create-project.ts +3 -4
- package/src/blueprints/project-wizard/functions/definitions.ts +3 -4
- package/src/blueprints/project-wizard/functions/index.ts +1 -1
- package/src/blueprints/project-wizard/functions/project-rules.ts +2 -2
- package/src/blueprints/project-wizard/functions/sync-triggers.ts +34 -15
- package/src/blueprints/testing.ts +7 -21
- package/src/blueprints/websearch/blueprint.conversations.json +1 -1
- package/src/blueprints/websearch/blueprint.test.ts +4 -4
- package/src/blueprints/websearch/blueprint.ts +2 -3
- package/src/blueprints/websearch/functions/definitions.ts +1 -1
- package/src/blueprints/websearch/functions/fetch.ts +1 -1
- package/src/blueprints/websearch/functions/index.ts +1 -1
- package/src/blueprints/websearch/index.ts +1 -1
- package/src/blueprints/websearch/toolkit.ts +2 -2
- package/src/crud/graph.test.ts +10 -12
- package/src/functions/agent/definitions.ts +5 -7
- package/src/functions/agent/index.ts +1 -1
- package/src/functions/agent/prompt.conversations.json +1 -1
- package/src/functions/agent/prompt.test.ts +5 -6
- package/src/functions/agent/prompt.ts +44 -42
- package/src/functions/index.ts +0 -2
- package/src/sync/sync.ts +18 -7
- package/src/testing/plugins.tsx +9 -7
- package/src/types/Agent.ts +51 -20
- package/src/types/Chat.ts +1 -0
- package/src/types/McpServer.ts +37 -0
- package/src/types/Memory.ts +2 -1
- package/src/types/Plan.ts +2 -2
- package/src/types/index.ts +1 -0
- package/dist/lib/neutral/add-artifact-5TOKSVLY.mjs.map +0 -7
- package/dist/lib/neutral/agent-SZV3Q7CN.mjs +0 -97
- package/dist/lib/neutral/agent-SZV3Q7CN.mjs.map +0 -7
- package/dist/lib/neutral/chunk-6DPL2YY5.mjs.map +0 -7
- package/dist/lib/neutral/chunk-6FL4C6KD.mjs +0 -86
- package/dist/lib/neutral/chunk-6FL4C6KD.mjs.map +0 -7
- package/dist/lib/neutral/chunk-AGG6OZNB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-B35UIL3R.mjs.map +0 -7
- package/dist/lib/neutral/chunk-B5NOGNUG.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BO4ZVH7M.mjs.map +0 -7
- package/dist/lib/neutral/chunk-DV5DCOUE.mjs.map +0 -7
- package/dist/lib/neutral/chunk-ILZ2ODWC.mjs +0 -95
- package/dist/lib/neutral/chunk-ILZ2ODWC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-IVXBQQDJ.mjs.map +0 -7
- package/dist/lib/neutral/chunk-LI6VMCJW.mjs +0 -27
- package/dist/lib/neutral/chunk-LI6VMCJW.mjs.map +0 -7
- package/dist/lib/neutral/chunk-MEQYXSDY.mjs.map +0 -7
- package/dist/lib/neutral/chunk-MEZ4UFR6.mjs.map +0 -7
- package/dist/lib/neutral/chunk-PWGX4QYR.mjs.map +0 -7
- package/dist/lib/neutral/chunk-RW4H4TKD.mjs +0 -694
- package/dist/lib/neutral/chunk-RW4H4TKD.mjs.map +0 -7
- package/dist/lib/neutral/chunk-TCRQCJEJ.mjs.map +0 -7
- package/dist/lib/neutral/chunk-V77TCYSP.mjs.map +0 -7
- package/dist/lib/neutral/chunk-VD2WAUU2.mjs.map +0 -7
- package/dist/lib/neutral/chunk-VDEDVOS6.mjs +0 -39
- package/dist/lib/neutral/chunk-VDEDVOS6.mjs.map +0 -7
- package/dist/lib/neutral/chunk-XT5ZSUS6.mjs +0 -363
- package/dist/lib/neutral/chunk-XT5ZSUS6.mjs.map +0 -7
- package/dist/lib/neutral/create-P6I22VS5.mjs +0 -23
- package/dist/lib/neutral/create-P6I22VS5.mjs.map +0 -7
- package/dist/lib/neutral/create-project-SI5SZ7LJ.mjs.map +0 -7
- package/dist/lib/neutral/delete-LHMZDJFA.mjs.map +0 -7
- package/dist/lib/neutral/document-create-53ZVNGFR.mjs +0 -57
- package/dist/lib/neutral/document-create-53ZVNGFR.mjs.map +0 -7
- package/dist/lib/neutral/enable-blueprints-4UMPKGUD.mjs.map +0 -7
- package/dist/lib/neutral/entity-extraction-B2CTBGNA.mjs +0 -196
- package/dist/lib/neutral/entity-extraction-B2CTBGNA.mjs.map +0 -7
- package/dist/lib/neutral/exa-P4G3DCYB.mjs +0 -28
- package/dist/lib/neutral/exa-P4G3DCYB.mjs.map +0 -7
- package/dist/lib/neutral/fetch-messages-AFX7ZAVE.mjs.map +0 -7
- package/dist/lib/neutral/get-context-57JQM4HZ.mjs.map +0 -7
- package/dist/lib/neutral/mock-2ARYZ54S.mjs +0 -556
- package/dist/lib/neutral/mock-2ARYZ54S.mjs.map +0 -7
- package/dist/lib/neutral/object-create-7QCGL56E.mjs.map +0 -7
- package/dist/lib/neutral/object-delete-KXBWC4Q4.mjs.map +0 -7
- package/dist/lib/neutral/object-update-B7RDX3JC.mjs.map +0 -7
- package/dist/lib/neutral/project-rules-NO3QVDZS.mjs.map +0 -7
- package/dist/lib/neutral/prompt-K5CIRXOD.mjs.map +0 -7
- package/dist/lib/neutral/qualifier-KSGP4CFL.mjs.map +0 -7
- package/dist/lib/neutral/query-FMGIPWJG.mjs.map +0 -7
- package/dist/lib/neutral/query-MN5B3MQF.mjs.map +0 -7
- package/dist/lib/neutral/query-blueprints-EKHEZAGD.mjs.map +0 -7
- package/dist/lib/neutral/read-JJN7YXHI.mjs +0 -19
- package/dist/lib/neutral/read-JJN7YXHI.mjs.map +0 -7
- package/dist/lib/neutral/relation-create-FSHBM5CJ.mjs.map +0 -7
- package/dist/lib/neutral/relation-delete-CYYQUIZY.mjs.map +0 -7
- package/dist/lib/neutral/research-7JQEX7MU.mjs +0 -109
- package/dist/lib/neutral/research-7JQEX7MU.mjs.map +0 -7
- package/dist/lib/neutral/save-ZWWNTBOD.mjs.map +0 -7
- package/dist/lib/neutral/schema-add-RVV364G6.mjs.map +0 -7
- package/dist/lib/neutral/schema-list-DVKEWYIU.mjs.map +0 -7
- package/dist/lib/neutral/sync-issues-BBAMXSZN.mjs.map +0 -7
- package/dist/lib/neutral/sync-triggers-6EXPBHIQ.mjs.map +0 -7
- package/dist/lib/neutral/tag-add-OUDUBR3E.mjs.map +0 -7
- package/dist/lib/neutral/tag-remove-DI3ZSLFK.mjs.map +0 -7
- package/dist/lib/neutral/update-J64AYUS5.mjs +0 -20
- package/dist/lib/neutral/update-J64AYUS5.mjs.map +0 -7
- package/dist/lib/neutral/update-blueprints-ZNWR7BBN.mjs.map +0 -7
- package/dist/lib/neutral/update-tasks-3YZ3YXIU.mjs.map +0 -7
- package/dist/types/src/blueprints/design/blueprint.d.ts +0 -4
- package/dist/types/src/blueprints/design/blueprint.d.ts.map +0 -1
- package/dist/types/src/blueprints/design/blueprint.test.d.ts +0 -2
- package/dist/types/src/blueprints/design/blueprint.test.d.ts.map +0 -1
- package/dist/types/src/blueprints/design/index.d.ts +0 -2
- package/dist/types/src/blueprints/design/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/blueprint.d.ts +0 -4
- package/dist/types/src/blueprints/markdown/blueprint.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/functions/create.d.ts +0 -8
- package/dist/types/src/blueprints/markdown/functions/create.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/functions/definitions.d.ts +0 -45
- package/dist/types/src/blueprints/markdown/functions/definitions.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/functions/index.d.ts +0 -4
- package/dist/types/src/blueprints/markdown/functions/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/functions/read.d.ts +0 -17
- package/dist/types/src/blueprints/markdown/functions/read.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/functions/update.d.ts +0 -16
- package/dist/types/src/blueprints/markdown/functions/update.d.ts.map +0 -1
- package/dist/types/src/blueprints/markdown/index.d.ts +0 -3
- package/dist/types/src/blueprints/markdown/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/blueprint.d.ts +0 -4
- package/dist/types/src/blueprints/planning-old/blueprint.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/blueprint.test.d.ts +0 -2
- package/dist/types/src/blueprints/planning-old/blueprint.test.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/definitions.d.ts +0 -31
- package/dist/types/src/blueprints/planning-old/functions/definitions.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/index.d.ts +0 -4
- package/dist/types/src/blueprints/planning-old/functions/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/read.d.ts +0 -17
- package/dist/types/src/blueprints/planning-old/functions/read.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/task-list.d.ts +0 -74
- package/dist/types/src/blueprints/planning-old/functions/task-list.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/task-list.test.d.ts +0 -2
- package/dist/types/src/blueprints/planning-old/functions/task-list.test.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/functions/update.d.ts +0 -19
- package/dist/types/src/blueprints/planning-old/functions/update.d.ts.map +0 -1
- package/dist/types/src/blueprints/planning-old/index.d.ts +0 -3
- package/dist/types/src/blueprints/planning-old/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/blueprint.d.ts +0 -4
- package/dist/types/src/blueprints/research/blueprint.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/blueprint.test.d.ts +0 -2
- package/dist/types/src/blueprints/research/blueprint.test.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/functions/definitions.d.ts +0 -21
- package/dist/types/src/blueprints/research/functions/definitions.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/functions/document-create.d.ts +0 -12
- package/dist/types/src/blueprints/research/functions/document-create.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/functions/index.d.ts +0 -4
- package/dist/types/src/blueprints/research/functions/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/functions/research.d.ts +0 -18
- package/dist/types/src/blueprints/research/functions/research.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/functions/research.test.d.ts +0 -2
- package/dist/types/src/blueprints/research/functions/research.test.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/index.d.ts +0 -4
- package/dist/types/src/blueprints/research/index.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/types/ResearchGraph.d.ts +0 -24
- package/dist/types/src/blueprints/research/types/ResearchGraph.d.ts.map +0 -1
- package/dist/types/src/blueprints/research/types/index.d.ts +0 -7
- package/dist/types/src/blueprints/research/types/index.d.ts.map +0 -1
- package/dist/types/src/functions/entity-extraction/definitions.d.ts +0 -182
- package/dist/types/src/functions/entity-extraction/definitions.d.ts.map +0 -1
- package/dist/types/src/functions/entity-extraction/entity-extraction.d.ts +0 -4
- package/dist/types/src/functions/entity-extraction/entity-extraction.d.ts.map +0 -1
- package/dist/types/src/functions/entity-extraction/entity-extraction.test.d.ts +0 -2
- package/dist/types/src/functions/entity-extraction/entity-extraction.test.d.ts.map +0 -1
- package/dist/types/src/functions/entity-extraction/index.d.ts +0 -4
- package/dist/types/src/functions/entity-extraction/index.d.ts.map +0 -1
- package/dist/types/src/functions/exa/data/exa-search-1748337321991.d.ts +0 -38
- package/dist/types/src/functions/exa/data/exa-search-1748337321991.d.ts.map +0 -1
- package/dist/types/src/functions/exa/data/exa-search-1748337331526.d.ts +0 -37
- package/dist/types/src/functions/exa/data/exa-search-1748337331526.d.ts.map +0 -1
- package/dist/types/src/functions/exa/data/exa-search-1748337344119.d.ts +0 -58
- package/dist/types/src/functions/exa/data/exa-search-1748337344119.d.ts.map +0 -1
- package/dist/types/src/functions/exa/data/index.d.ts +0 -3
- package/dist/types/src/functions/exa/data/index.d.ts.map +0 -1
- package/dist/types/src/functions/exa/definitions.d.ts +0 -9
- package/dist/types/src/functions/exa/definitions.d.ts.map +0 -1
- package/dist/types/src/functions/exa/exa.d.ts +0 -7
- package/dist/types/src/functions/exa/exa.d.ts.map +0 -1
- package/dist/types/src/functions/exa/index.d.ts +0 -4
- package/dist/types/src/functions/exa/index.d.ts.map +0 -1
- package/dist/types/src/functions/exa/mock.d.ts +0 -6
- package/dist/types/src/functions/exa/mock.d.ts.map +0 -1
- package/src/blueprints/browser/blueprint.conversations.json +0 -1
- package/src/blueprints/design/blueprint.test.ts +0 -97
- package/src/blueprints/design/blueprint.ts +0 -41
- package/src/blueprints/design/index.ts +0 -5
- package/src/blueprints/markdown/blueprint.ts +0 -36
- package/src/blueprints/markdown/functions/create.ts +0 -20
- package/src/blueprints/markdown/functions/definitions.ts +0 -80
- package/src/blueprints/markdown/functions/index.ts +0 -13
- package/src/blueprints/markdown/functions/read.ts +0 -22
- package/src/blueprints/markdown/functions/update.ts +0 -22
- package/src/blueprints/markdown/index.ts +0 -11
- package/src/blueprints/planning-old/blueprint.test.ts +0 -122
- package/src/blueprints/planning-old/blueprint.ts +0 -106
- package/src/blueprints/planning-old/functions/definitions.ts +0 -53
- package/src/blueprints/planning-old/functions/index.ts +0 -12
- package/src/blueprints/planning-old/functions/read.ts +0 -24
- package/src/blueprints/planning-old/functions/task-list.test.ts +0 -99
- package/src/blueprints/planning-old/functions/task-list.ts +0 -165
- package/src/blueprints/planning-old/functions/update.ts +0 -31
- package/src/blueprints/planning-old/index.ts +0 -6
- package/src/blueprints/research/blueprint.test.ts +0 -7
- package/src/blueprints/research/blueprint.ts +0 -61
- package/src/blueprints/research/functions/definitions.ts +0 -87
- package/src/blueprints/research/functions/document-create.ts +0 -50
- package/src/blueprints/research/functions/index.ts +0 -12
- package/src/blueprints/research/functions/research-instructions.tpl +0 -106
- package/src/blueprints/research/functions/research.conversations.json +0 -1
- package/src/blueprints/research/functions/research.test.ts +0 -150
- package/src/blueprints/research/functions/research.ts +0 -137
- package/src/blueprints/research/index.ts +0 -7
- package/src/blueprints/research/types/ResearchGraph.ts +0 -62
- package/src/blueprints/research/types/index.ts +0 -32
- package/src/functions/entity-extraction/definitions.ts +0 -44
- package/src/functions/entity-extraction/entity-extraction.conversations.json +0 -1
- package/src/functions/entity-extraction/entity-extraction.test.ts +0 -74
- package/src/functions/entity-extraction/entity-extraction.ts +0 -159
- package/src/functions/entity-extraction/index.ts +0 -9
- package/src/functions/exa/data/exa-search-1748337321991.ts +0 -131
- package/src/functions/exa/data/exa-search-1748337331526.ts +0 -144
- package/src/functions/exa/data/exa-search-1748337344119.ts +0 -133
- package/src/functions/exa/data/index.ts +0 -11
- package/src/functions/exa/definitions.ts +0 -37
- package/src/functions/exa/exa.ts +0 -32
- package/src/functions/exa/index.ts +0 -12
- package/src/functions/exa/mock.ts +0 -62
- /package/dist/lib/neutral/{project-3J3AJCJK.mjs.map → project-2YBPW5N7.mjs.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"conversations":[{"parameters":{"model":"@anthropic/claude-opus-4-6","stream":true,"tools":[{"name":"
|
|
1
|
+
{"conversations":[{"parameters":{"model":"@anthropic/claude-opus-4-6","stream":true,"tools":[{"name":"completeJob","inputSchema":{"type":"object","required":[],"properties":{"success":{"$id":"/schemas/any","title":"any"},"failure":{"type":"object","required":["message"],"properties":{"message":{"type":"string","description":"Short message describing the error."},"description":{"type":"string","description":"Optional longer message describing in detail what went wrong"}},"additionalProperties":false}},"additionalProperties":false}}]},"prompt":{"content":[{"role":"system","content":"You are an agent running in the non-interactive mode.\nThe user is unable to see what you are doing, and cannot answer any questions.\nDo not ask questions.\nComplete the task before you, and at the end call [completeJob] with the output.\nIf you are unable to complete the task, call [completeJob] with the failure reason.\nIf no output is required, call [completeJob] with an empty object: {}\nDo not stop until you call [completeJob].","options":{}},{"role":"user","content":"Reply with a single word: ack.\n<input>{}</input>","options":{"anthropic":{"cacheControl":{"ttl":"5m","type":"ephemeral"}}}}]},"response":[{"type":"response-metadata","id":"msg_01BJnJPY3oMFLFRKBzfm18k4","modelId":"claude-opus-4-6","timestamp":"1970-01-01T00:00:00.000Z","metadata":{}},{"type":"reasoning-start","id":"0","metadata":{}},{"type":"reasoning-delta","id":"0","delta":"The user wants me to reply with a single word: \"ack\".","metadata":{}},{"type":"reasoning-delta","id":"0","delta":"","metadata":{"anthropic":{"type":"thinking","signature":"EvABClkIDRgCKkDoETBa+lesagv7ixB9LGrYHpBYfS/DCnRnegAetRGGWDl0kkFyqVQI7oDc+ZWbyk9tB+4ePqoqNXQXwE3240/HMg9jbGF1ZGUtb3B1cy00LTY4ABIMZ4jEaKNKFseHE6SGGgxDCMKKPXa0JrDQ52ciMG+cUvHgNQwSWMWlYEBfsVvvwZnDif1WmjybXm26QJIGtpnF/4kQQkk8Re1W0OPoYCpFYVSQgk56gj+oWRLRn8FgcWrdoxhpuw6BVArd0/EEeXi78h9AJPLa7BN30HyfNmAOQ5LiuW8fznNPRzCv1yHLrjw4IE+GGAE="}}},{"type":"reasoning-end","id":"0","metadata":{}},{"type":"tool-params-start","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","name":"completeJob","providerExecuted":false,"metadata":{}},{"type":"tool-params-delta","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","delta":"","metadata":{}},{"type":"tool-params-delta","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","delta":"{\"success\": ","metadata":{}},{"type":"tool-params-delta","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","delta":"\"ack\"}","metadata":{}},{"type":"tool-params-end","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","metadata":{}},{"type":"finish","reason":"tool-calls","usage":{"inputTokens":757,"outputTokens":85,"totalTokens":842},"metadata":{"anthropic":{"usage":{"cache_creation":{"ephemeral_1h_input_tokens":0,"ephemeral_5m_input_tokens":0},"cache_creation_input_tokens":0,"cache_read_input_tokens":0,"input_tokens":757,"output_tokens":60,"server_tool_use":null,"service_tier":"standard"}}}}]},{"parameters":{"model":"@anthropic/claude-opus-4-6","stream":true,"tools":[{"name":"completeJob","inputSchema":{"type":"object","required":[],"properties":{"success":{"$id":"/schemas/any","title":"any"},"failure":{"type":"object","required":["message"],"properties":{"message":{"type":"string","description":"Short message describing the error."},"description":{"type":"string","description":"Optional longer message describing in detail what went wrong"}},"additionalProperties":false}},"additionalProperties":false}}]},"prompt":{"content":[{"role":"system","content":"You are an agent running in the non-interactive mode.\nThe user is unable to see what you are doing, and cannot answer any questions.\nDo not ask questions.\nComplete the task before you, and at the end call [completeJob] with the output.\nIf you are unable to complete the task, call [completeJob] with the failure reason.\nIf no output is required, call [completeJob] with an empty object: {}\nDo not stop until you call [completeJob].","options":{}},{"role":"user","content":"Reply with a single word: ack.\n<input>{}</input>","options":{}},{"role":"assistant","content":[{"type":"reasoning","text":"The user wants me to reply with a single word: \"ack\".","options":{}},{"type":"tool-call","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","name":"completeJob","params":{"success":"ack"},"providerExecuted":false,"options":{}}],"options":{}},{"role":"tool","content":[{"type":"tool-result","id":"toolu_01N1FCMswXa62WFdsMrbu4Kv","name":"completeJob","isFailure":false,"result":{},"providerExecuted":false,"options":{}}],"options":{"anthropic":{"cacheControl":{"ttl":"5m","type":"ephemeral"}}}}]},"response":[{"type":"response-metadata","id":"msg_01XmKNsc4F8Re8N5UEDdxcjp","modelId":"claude-opus-4-6","timestamp":"1970-01-01T00:00:00.000Z","metadata":{}},{"type":"finish","reason":"stop","usage":{"inputTokens":824,"outputTokens":2,"totalTokens":826},"metadata":{"anthropic":{"usage":{"cache_creation":{"ephemeral_1h_input_tokens":0,"ephemeral_5m_input_tokens":0},"cache_creation_input_tokens":0,"cache_read_input_tokens":0,"input_tokens":824,"output_tokens":2,"server_tool_use":null,"service_tier":"standard"}}}}]}]}
|
|
@@ -6,13 +6,12 @@ import { describe, expect, it } from '@effect/vitest';
|
|
|
6
6
|
import * as Effect from 'effect/Effect';
|
|
7
7
|
|
|
8
8
|
import { ContextBinding } from '@dxos/assistant';
|
|
9
|
-
import {
|
|
10
|
-
import { Prompt } from '@dxos/blueprints';
|
|
9
|
+
import { Routine, Operation, OperationHandlerSet } from '@dxos/compute';
|
|
11
10
|
import { Database, Feed, Obj, Ref } from '@dxos/echo';
|
|
12
11
|
import { TestHelpers } from '@dxos/effect/testing';
|
|
13
|
-
import {
|
|
12
|
+
import { QueueService } from '@dxos/functions';
|
|
13
|
+
import { AssistantTestLayer } from '@dxos/functions-runtime/testing';
|
|
14
14
|
import { ObjectId } from '@dxos/keys';
|
|
15
|
-
import { OperationHandlerSet } from '@dxos/operation';
|
|
16
15
|
import { Text } from '@dxos/schema';
|
|
17
16
|
import { Message } from '@dxos/types';
|
|
18
17
|
|
|
@@ -53,7 +52,7 @@ describe('Agent prompt', () => {
|
|
|
53
52
|
);
|
|
54
53
|
|
|
55
54
|
const prompt = yield* Database.add(
|
|
56
|
-
|
|
55
|
+
Routine.make({
|
|
57
56
|
name: 'chat-mode-test',
|
|
58
57
|
instructions: 'Reply with a single word: ack.',
|
|
59
58
|
blueprints: [],
|
|
@@ -63,7 +62,7 @@ describe('Agent prompt', () => {
|
|
|
63
62
|
|
|
64
63
|
yield* Database.flush();
|
|
65
64
|
|
|
66
|
-
const result = yield*
|
|
65
|
+
const result = yield* Operation.invoke(AgentPrompt, {
|
|
67
66
|
prompt: Ref.make(prompt),
|
|
68
67
|
input: {},
|
|
69
68
|
chat: Ref.make(chat),
|
|
@@ -12,22 +12,18 @@ import * as Layer from 'effect/Layer';
|
|
|
12
12
|
import * as Option from 'effect/Option';
|
|
13
13
|
import * as Schema from 'effect/Schema';
|
|
14
14
|
|
|
15
|
-
import { AiService,
|
|
15
|
+
import { AiService, OpaqueToolkit, ModelName } from '@dxos/ai';
|
|
16
16
|
import {
|
|
17
|
-
|
|
18
|
-
GenerationObserver,
|
|
19
|
-
functionInvocationServiceFromOperations,
|
|
17
|
+
AiSession,
|
|
20
18
|
getOperationFromTool,
|
|
21
19
|
makeToolExecutionService,
|
|
22
20
|
makeToolResolverFromOperations,
|
|
23
21
|
} from '@dxos/assistant';
|
|
24
|
-
import { Template } from '@dxos/
|
|
22
|
+
import { Template, Trace, Operation } from '@dxos/compute';
|
|
25
23
|
import { Database, Feed, Obj, Ref } from '@dxos/echo';
|
|
26
24
|
import { acquireReleaseResource } from '@dxos/effect';
|
|
27
|
-
import { TracingService } from '@dxos/functions';
|
|
28
25
|
import { invariant } from '@dxos/invariant';
|
|
29
26
|
import { log } from '@dxos/log';
|
|
30
|
-
import { Operation } from '@dxos/operation';
|
|
31
27
|
import { trim } from '@dxos/util';
|
|
32
28
|
|
|
33
29
|
import { PromptError } from '../../errors';
|
|
@@ -36,8 +32,6 @@ import { AgentPrompt } from './definitions';
|
|
|
36
32
|
|
|
37
33
|
const DEFAULT_MODEL: ModelName = '@anthropic/claude-opus-4-6';
|
|
38
34
|
|
|
39
|
-
const observer = GenerationObserver.fromPrinter(new ConsolePrinter({ tag: 'agent' }));
|
|
40
|
-
|
|
41
35
|
export default AgentPrompt.pipe(
|
|
42
36
|
Operation.withHandler(
|
|
43
37
|
Effect.fnUntraced(
|
|
@@ -50,7 +44,7 @@ export default AgentPrompt.pipe(
|
|
|
50
44
|
|
|
51
45
|
yield* Database.flush();
|
|
52
46
|
const prompt = yield* Database.load(data.prompt);
|
|
53
|
-
yield*
|
|
47
|
+
yield* Trace.emitStatus(`Running ${prompt.id}`);
|
|
54
48
|
|
|
55
49
|
log.info('starting agent', { prompt: prompt.id, input });
|
|
56
50
|
|
|
@@ -69,16 +63,20 @@ export default AgentPrompt.pipe(
|
|
|
69
63
|
);
|
|
70
64
|
|
|
71
65
|
const promptInstructions = yield* Database.load(prompt.instructions.source);
|
|
72
|
-
|
|
66
|
+
let promptText = Template.process(promptInstructions.content, input);
|
|
67
|
+
|
|
68
|
+
if (input !== undefined) {
|
|
69
|
+
promptText += `\n<input>${JSON.stringify(input)}</input>`;
|
|
70
|
+
}
|
|
73
71
|
|
|
74
72
|
let systemText = trim`
|
|
75
73
|
You are an agent running in the non-interactive mode.
|
|
76
74
|
The user is unable to see what you are doing, and cannot answer any questions.
|
|
77
75
|
Do not ask questions.
|
|
78
|
-
Complete the task before you, and at the end call [
|
|
79
|
-
If you are unable to complete the task, call [
|
|
80
|
-
If no output is required, call [
|
|
81
|
-
Do not stop until you call [
|
|
76
|
+
Complete the task before you, and at the end call [completeJob] with the output.
|
|
77
|
+
If you are unable to complete the task, call [completeJob] with the failure reason.
|
|
78
|
+
If no output is required, call [completeJob] with an empty object: {}
|
|
79
|
+
Do not stop until you call [completeJob].
|
|
82
80
|
`;
|
|
83
81
|
if (data.systemInstructions) {
|
|
84
82
|
systemText += `\n\n${data.systemInstructions}`;
|
|
@@ -102,53 +100,57 @@ export default AgentPrompt.pipe(
|
|
|
102
100
|
});
|
|
103
101
|
|
|
104
102
|
const runtime = yield* Effect.runtime<Feed.FeedService>();
|
|
105
|
-
const
|
|
103
|
+
const session = yield* acquireReleaseResource(() => new AiSession({ feed, runtime }));
|
|
106
104
|
|
|
107
105
|
yield* Effect.promise(() =>
|
|
108
|
-
|
|
106
|
+
session.context.bind({
|
|
109
107
|
blueprints: blueprints.map((blueprint) => Ref.make(blueprint)),
|
|
110
108
|
objects: objects.map((object) => Ref.make(object as Obj.Unknown)),
|
|
111
109
|
}),
|
|
112
110
|
);
|
|
113
111
|
|
|
114
|
-
yield*
|
|
112
|
+
yield* session
|
|
115
113
|
.createRequest({
|
|
116
114
|
prompt: promptText,
|
|
117
115
|
system: systemText,
|
|
118
|
-
|
|
119
|
-
toolkit: promptToolkit.toolkit,
|
|
116
|
+
toolkit: promptToolkit,
|
|
120
117
|
})
|
|
121
118
|
.pipe(
|
|
122
119
|
Effect.provide(
|
|
123
|
-
Layer.mergeAll(
|
|
124
|
-
modelLayer,
|
|
125
|
-
promptToolkit.layer,
|
|
126
|
-
ToolExecutionService({ feed }),
|
|
127
|
-
makeToolResolverFromOperations(),
|
|
128
|
-
),
|
|
120
|
+
Layer.mergeAll(modelLayer, ToolExecutionService({ feed }), makeToolResolverFromOperations()),
|
|
129
121
|
),
|
|
130
122
|
);
|
|
131
123
|
|
|
132
124
|
return yield* Deferred.poll(resultSink).pipe(
|
|
133
125
|
Effect.flatten,
|
|
134
|
-
Effect.catchTag('NoSuchElementException', () => Effect.die('Agent did not signal task completion.')),
|
|
135
126
|
Effect.flatten,
|
|
136
|
-
Effect.
|
|
137
|
-
(
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
127
|
+
Effect.catchTag('NoSuchElementException', () =>
|
|
128
|
+
Effect.gen(function* () {
|
|
129
|
+
yield* session
|
|
130
|
+
.createRequest({
|
|
131
|
+
prompt: 'You must signal task completion by calling [completeJob] with the output or failure reason.',
|
|
132
|
+
system: systemText,
|
|
133
|
+
toolkit: promptToolkit,
|
|
134
|
+
})
|
|
135
|
+
.pipe(
|
|
136
|
+
Effect.provide(
|
|
137
|
+
Layer.mergeAll(modelLayer, ToolExecutionService({ feed }), makeToolResolverFromOperations()),
|
|
138
|
+
),
|
|
139
|
+
);
|
|
140
|
+
|
|
141
|
+
return yield* Deferred.poll(resultSink).pipe(
|
|
142
|
+
Effect.flatten,
|
|
143
|
+
Effect.flatten,
|
|
144
|
+
Effect.catchTag('NoSuchElementException', () =>
|
|
145
|
+
Effect.fail(new PromptError('Agent did not signal task completion.', {})),
|
|
146
|
+
),
|
|
147
|
+
);
|
|
148
|
+
}),
|
|
142
149
|
),
|
|
143
150
|
);
|
|
144
151
|
},
|
|
145
152
|
Effect.scoped,
|
|
146
|
-
Effect.provide(
|
|
147
|
-
Layer.empty.pipe(
|
|
148
|
-
Layer.provideMerge(functionInvocationServiceFromOperations),
|
|
149
|
-
Layer.provideMerge(TracingService.layerNoop),
|
|
150
|
-
),
|
|
151
|
-
),
|
|
153
|
+
Effect.provide(Trace.writerLayerNoop),
|
|
152
154
|
),
|
|
153
155
|
),
|
|
154
156
|
Operation.opaqueHandler,
|
|
@@ -159,7 +161,7 @@ const makePromptAgentToolkit = (options: {
|
|
|
159
161
|
resultSink: Deferred.Deferred<unknown, PromptError>;
|
|
160
162
|
}) => {
|
|
161
163
|
class PromptAgentToolkit extends Toolkit.make(
|
|
162
|
-
Tool.make('
|
|
164
|
+
Tool.make('completeJob', {
|
|
163
165
|
parameters: {
|
|
164
166
|
success: Schema.optional(Schema.Any), // TODO(dmaretskyi): Pipe output schema here.
|
|
165
167
|
failure: Schema.optional(
|
|
@@ -176,7 +178,7 @@ const makePromptAgentToolkit = (options: {
|
|
|
176
178
|
}),
|
|
177
179
|
) {}
|
|
178
180
|
const layer = PromptAgentToolkit.toLayer({
|
|
179
|
-
|
|
181
|
+
completeJob: Effect.fnUntraced(function* (result) {
|
|
180
182
|
if (result.failure) {
|
|
181
183
|
yield* Deferred.fail(
|
|
182
184
|
options.resultSink,
|
|
@@ -190,7 +192,7 @@ const makePromptAgentToolkit = (options: {
|
|
|
190
192
|
}),
|
|
191
193
|
});
|
|
192
194
|
|
|
193
|
-
return
|
|
195
|
+
return OpaqueToolkit.make(PromptAgentToolkit, layer);
|
|
194
196
|
};
|
|
195
197
|
|
|
196
198
|
interface ToolExecutionServiceOptions {
|
package/src/functions/index.ts
CHANGED
package/src/sync/sync.ts
CHANGED
|
@@ -29,10 +29,16 @@ export const syncObjects: (
|
|
|
29
29
|
Effect.fnUntraced(function* (obj) {
|
|
30
30
|
// Sync referenced objects.
|
|
31
31
|
for (const key of Object.keys(obj)) {
|
|
32
|
-
if (typeof key !== 'string' || key === 'id')
|
|
33
|
-
|
|
32
|
+
if (typeof key !== 'string' || key === 'id') {
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (!Ref.isRef((obj as any)[key])) {
|
|
36
|
+
continue;
|
|
37
|
+
}
|
|
34
38
|
const ref: Ref.Unknown = (obj as any)[key];
|
|
35
|
-
if (!ref.target)
|
|
39
|
+
if (!ref.target) {
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
36
42
|
if (Obj.getDXN(ref.target).isLocalObjectId()) {
|
|
37
43
|
// obj not persisted to db.
|
|
38
44
|
const [target] = yield* syncObjects([ref.target], { foreignKeyId });
|
|
@@ -63,23 +69,28 @@ export const syncObjects: (
|
|
|
63
69
|
});
|
|
64
70
|
|
|
65
71
|
const copyObjectData = (existing: Obj.Unknown, newObj: Obj.Unknown) => {
|
|
66
|
-
Obj.
|
|
72
|
+
Obj.update(existing, (existing) => {
|
|
67
73
|
// Copy properties from newObj to existing.
|
|
68
74
|
for (const key of Object.keys(newObj)) {
|
|
69
|
-
if (typeof key !== 'string' || key === 'id')
|
|
75
|
+
if (typeof key !== 'string' || key === 'id') {
|
|
76
|
+
continue;
|
|
77
|
+
}
|
|
70
78
|
if (
|
|
71
79
|
typeof (newObj as any)[key] !== 'string' &&
|
|
72
80
|
typeof (newObj as any)[key] !== 'number' &&
|
|
73
81
|
typeof (newObj as any)[key] !== 'boolean' &&
|
|
74
82
|
!Ref.isRef((newObj as any)[key])
|
|
75
|
-
)
|
|
83
|
+
) {
|
|
76
84
|
continue;
|
|
85
|
+
}
|
|
77
86
|
(existing as any)[key] = (newObj as any)[key];
|
|
78
87
|
}
|
|
79
88
|
|
|
80
89
|
// Delete properties that don't exist in newObj.
|
|
81
90
|
for (const key of Object.keys(existing)) {
|
|
82
|
-
if (typeof key !== 'string' || key === 'id')
|
|
91
|
+
if (typeof key !== 'string' || key === 'id') {
|
|
92
|
+
continue;
|
|
93
|
+
}
|
|
83
94
|
if (!(key in newObj)) {
|
|
84
95
|
delete (existing as any)[key];
|
|
85
96
|
}
|
package/src/testing/plugins.tsx
CHANGED
|
@@ -9,7 +9,7 @@ import { Capabilities, Capability } from '@dxos/app-framework';
|
|
|
9
9
|
import { Surface } from '@dxos/app-framework/ui';
|
|
10
10
|
import { Format, type Obj, Type } from '@dxos/echo';
|
|
11
11
|
import { Card } from '@dxos/react-ui';
|
|
12
|
-
import {
|
|
12
|
+
import { Syntax } from '@dxos/react-ui-syntax-highlighter';
|
|
13
13
|
|
|
14
14
|
export const MapSchema = Schema.Struct({
|
|
15
15
|
coordinates: Format.GeoPoint,
|
|
@@ -64,12 +64,14 @@ export const capabilities: Capability.Any[] = [
|
|
|
64
64
|
position: 'fallback',
|
|
65
65
|
component: ({ data }) => (
|
|
66
66
|
<Card.Content>
|
|
67
|
-
<
|
|
68
|
-
<
|
|
69
|
-
<
|
|
70
|
-
<
|
|
71
|
-
|
|
72
|
-
|
|
67
|
+
<Syntax.Root data={data}>
|
|
68
|
+
<Syntax.Content>
|
|
69
|
+
<Syntax.Filter />
|
|
70
|
+
<Syntax.Viewport>
|
|
71
|
+
<Syntax.Code />
|
|
72
|
+
</Syntax.Viewport>
|
|
73
|
+
</Syntax.Content>
|
|
74
|
+
</Syntax.Root>
|
|
73
75
|
</Card.Content>
|
|
74
76
|
),
|
|
75
77
|
}),
|
package/src/types/Agent.ts
CHANGED
|
@@ -9,8 +9,8 @@ import * as Function from 'effect/Function';
|
|
|
9
9
|
import * as Schema from 'effect/Schema';
|
|
10
10
|
|
|
11
11
|
import { AiContextBinder, AiContextService } from '@dxos/assistant';
|
|
12
|
-
import { type Blueprint } from '@dxos/
|
|
13
|
-
import { Annotation, Database, Feed, Obj, Ref, Relation, Type } from '@dxos/echo';
|
|
12
|
+
import { type Blueprint } from '@dxos/compute';
|
|
13
|
+
import { Annotation, Database, Feed, Format, Obj, Ref, Relation, Type } from '@dxos/echo';
|
|
14
14
|
import { Queue } from '@dxos/echo-db';
|
|
15
15
|
import { type ObjectNotFoundError } from '@dxos/echo/Err';
|
|
16
16
|
import { FormInputAnnotation, LabelAnnotation } from '@dxos/echo/internal';
|
|
@@ -28,31 +28,49 @@ import * as Plan from './Plan';
|
|
|
28
28
|
export const Agent = Schema.Struct({
|
|
29
29
|
name: Schema.optional(Schema.String),
|
|
30
30
|
|
|
31
|
+
/**
|
|
32
|
+
* When false, agent triggers are disabled after sync-triggers runs.
|
|
33
|
+
*/
|
|
34
|
+
enabled: Schema.optional(Schema.Boolean).annotations({
|
|
35
|
+
title: 'Enabled',
|
|
36
|
+
description: 'Master switch for agent automation; propagated to all triggers on sync.',
|
|
37
|
+
}),
|
|
38
|
+
|
|
31
39
|
/**
|
|
32
40
|
* Instructions for the agent.
|
|
33
41
|
*/
|
|
34
|
-
|
|
35
|
-
|
|
42
|
+
instructions: Ref.Ref(Text.Text).pipe(
|
|
43
|
+
Format.FormatAnnotation.set(Format.TypeFormat.Markdown),
|
|
44
|
+
Schema.annotations({ title: 'Instructions' }),
|
|
45
|
+
),
|
|
36
46
|
|
|
47
|
+
/**
|
|
48
|
+
* Primary chat for the agent.
|
|
49
|
+
*/
|
|
50
|
+
// TODO(dmaretskyi): Multiple chats; RB: branching hierarchy.
|
|
51
|
+
chat: Schema.optional(Ref.Ref(Chat.Chat).pipe(FormInputAnnotation.set(false))),
|
|
52
|
+
|
|
53
|
+
// TODO(burdon): Is this used? Should it be an artifact?
|
|
54
|
+
// Format.FormatAnnotation.set(Format.TypeFormat.Markdown)
|
|
37
55
|
plan: Ref.Ref(Plan.Plan).pipe(FormInputAnnotation.set(false)),
|
|
38
56
|
|
|
57
|
+
// TODO(burdon): Currently Memory.Memory objects are global to the space; make them artifacts?
|
|
39
58
|
artifacts: Schema.Array(
|
|
40
59
|
Schema.Struct({
|
|
41
60
|
// TODO(dmaretskyi): Consider gettings names from the artifact itself using Obj.getLabel.
|
|
42
61
|
name: Schema.String,
|
|
62
|
+
// TODO(burdon): Rename object.
|
|
43
63
|
data: Ref.Ref(Obj.Unknown),
|
|
44
64
|
}),
|
|
45
65
|
).pipe(FormInputAnnotation.set(false)),
|
|
46
66
|
|
|
47
67
|
/**
|
|
48
|
-
*
|
|
68
|
+
* Input feed for subscriptions.
|
|
49
69
|
*/
|
|
70
|
+
// TODO(burdon): Rename to Feed?
|
|
50
71
|
// NOTE: Named `queue` to conform to subscribable schema (see QueueAnnotation).
|
|
51
72
|
queue: Schema.optional(Ref.Ref(Queue).pipe(FormInputAnnotation.set(false))),
|
|
52
73
|
|
|
53
|
-
// TODO(dmaretskyi): Multiple chats.
|
|
54
|
-
chat: Schema.optional(Ref.Ref(Chat.Chat).pipe(FormInputAnnotation.set(false))),
|
|
55
|
-
|
|
56
74
|
/**
|
|
57
75
|
* References to objects with a canonical queue property.
|
|
58
76
|
* Schema must have the QueueAnnotation.
|
|
@@ -60,11 +78,23 @@ export const Agent = Schema.Struct({
|
|
|
60
78
|
// TODO(dmaretskyi): Turn into an array of objects when form-data
|
|
61
79
|
subscriptions: Schema.Array(Ref.Ref(Obj.Unknown)).pipe(FormInputAnnotation.set(false)),
|
|
62
80
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
81
|
+
/**
|
|
82
|
+
* Allow the agent to filter events.
|
|
83
|
+
* Related events will be added to the input queue of the agent.
|
|
84
|
+
* It is recommended to enable this.
|
|
85
|
+
*/
|
|
86
|
+
filterEvents: Schema.optional(Schema.Boolean).annotations({
|
|
87
|
+
title: 'Filter events',
|
|
88
|
+
description: 'Allow the agent to filter events.',
|
|
89
|
+
}),
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Cron expression for a timer trigger that invokes the agent worker on a schedule.
|
|
93
|
+
* The timer trigger bypasses the qualifier and goes straight to the agent worker.
|
|
94
|
+
*/
|
|
95
|
+
cron: Schema.optional(Schema.String).annotations({
|
|
96
|
+
title: 'Cron',
|
|
97
|
+
description: 'Cron expression for a timer trigger that invokes the agent on a schedule.',
|
|
68
98
|
}),
|
|
69
99
|
}).pipe(
|
|
70
100
|
Type.object({
|
|
@@ -72,11 +102,11 @@ export const Agent = Schema.Struct({
|
|
|
72
102
|
version: '0.1.0',
|
|
73
103
|
}),
|
|
74
104
|
LabelAnnotation.set(['name']),
|
|
105
|
+
QueueAnnotation.set(true),
|
|
75
106
|
Annotation.IconAnnotation.set({
|
|
76
107
|
icon: 'ph--drone--regular',
|
|
77
108
|
hue: 'sky',
|
|
78
109
|
}),
|
|
79
|
-
QueueAnnotation.set(true),
|
|
80
110
|
);
|
|
81
111
|
|
|
82
112
|
export interface Agent extends Schema.Schema.Type<typeof Agent> {}
|
|
@@ -89,9 +119,9 @@ export interface Agent extends Schema.Schema.Type<typeof Agent> {}
|
|
|
89
119
|
* @returns An Effect that yields the initialized Agent.
|
|
90
120
|
*/
|
|
91
121
|
export const makeInitialized = (
|
|
92
|
-
props: Omit<Obj.MakeProps<typeof Agent>, '
|
|
122
|
+
props: Omit<Obj.MakeProps<typeof Agent>, 'instructions' | 'plan' | 'artifacts' | 'subscriptions' | 'chat'> &
|
|
93
123
|
Partial<Pick<Obj.MakeProps<typeof Agent>, 'artifacts' | 'subscriptions'>> & {
|
|
94
|
-
|
|
124
|
+
instructions: string;
|
|
95
125
|
blueprints?: Ref.Ref<Blueprint.Blueprint>[];
|
|
96
126
|
contextObjects?: Ref.Ref<Obj.Any>[];
|
|
97
127
|
},
|
|
@@ -100,11 +130,12 @@ export const makeInitialized = (
|
|
|
100
130
|
Effect.gen(function* () {
|
|
101
131
|
const agent = Obj.make(Agent, {
|
|
102
132
|
...props,
|
|
103
|
-
|
|
133
|
+
instructions: Ref.make(Text.make(props.instructions)),
|
|
104
134
|
plan: Ref.make(Plan.makePlan({ tasks: [] })),
|
|
105
135
|
artifacts: props.artifacts ?? [],
|
|
106
136
|
subscriptions: props.subscriptions ?? [],
|
|
107
|
-
|
|
137
|
+
filterEvents: props.filterEvents ?? true,
|
|
138
|
+
enabled: props.enabled ?? true,
|
|
108
139
|
});
|
|
109
140
|
yield* Database.add(agent);
|
|
110
141
|
const feed = yield* Database.add(Feed.make());
|
|
@@ -134,7 +165,7 @@ export const makeInitialized = (
|
|
|
134
165
|
|
|
135
166
|
const inputQueue = yield* QueueService.createQueue();
|
|
136
167
|
|
|
137
|
-
Obj.
|
|
168
|
+
Obj.update(agent, (agent) => {
|
|
138
169
|
agent.chat = Ref.make(chat);
|
|
139
170
|
agent.queue = Ref.fromDXN(inputQueue.dxn);
|
|
140
171
|
});
|
|
@@ -185,7 +216,7 @@ export const resetChatHistory = (
|
|
|
185
216
|
}),
|
|
186
217
|
);
|
|
187
218
|
Obj.setParent(feed, chat);
|
|
188
|
-
Obj.
|
|
219
|
+
Obj.update(agent, (agent) => {
|
|
189
220
|
agent.chat = Ref.make(chat);
|
|
190
221
|
});
|
|
191
222
|
|
package/src/types/Chat.ts
CHANGED
|
@@ -15,6 +15,7 @@ import { FormInputAnnotation, LabelAnnotation } from '@dxos/echo/internal';
|
|
|
15
15
|
export const Chat = Schema.Struct({
|
|
16
16
|
name: Schema.String.pipe(Schema.optional),
|
|
17
17
|
feed: Ref.Ref(Feed.Feed).pipe(FormInputAnnotation.set(false)),
|
|
18
|
+
view: Schema.String.pipe(Schema.optional),
|
|
18
19
|
}).pipe(
|
|
19
20
|
Type.object({
|
|
20
21
|
typename: 'org.dxos.type.assistant.chat',
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
// @import-as-namespace
|
|
6
|
+
|
|
7
|
+
import * as Schema from 'effect/Schema';
|
|
8
|
+
|
|
9
|
+
import { Annotation, Type } from '@dxos/echo';
|
|
10
|
+
import { LabelAnnotation } from '@dxos/echo/internal';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* MCP server configuration stored as a space-level ECHO object.
|
|
14
|
+
*
|
|
15
|
+
* NOTE: `apiKey` is stored in plaintext and replicated to all peers with access to the space.
|
|
16
|
+
* A future iteration should move secrets to per-device credential storage or use envelope encryption.
|
|
17
|
+
*/
|
|
18
|
+
export const McpServer = Schema.Struct({
|
|
19
|
+
name: Schema.String,
|
|
20
|
+
url: Schema.String,
|
|
21
|
+
protocol: Schema.Union(Schema.Literal('sse'), Schema.Literal('http')),
|
|
22
|
+
/** Stored in plaintext; replicated to all peers in the space. */
|
|
23
|
+
apiKey: Schema.optional(Schema.String),
|
|
24
|
+
enabled: Schema.optional(Schema.Boolean),
|
|
25
|
+
}).pipe(
|
|
26
|
+
Type.object({
|
|
27
|
+
typename: 'org.dxos.type.assistant.mcpServer',
|
|
28
|
+
version: '0.1.0',
|
|
29
|
+
}),
|
|
30
|
+
LabelAnnotation.set(['name']),
|
|
31
|
+
Annotation.IconAnnotation.set({
|
|
32
|
+
icon: 'ph--plugs-connected--regular',
|
|
33
|
+
hue: 'sky',
|
|
34
|
+
}),
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
export interface McpServer extends Schema.Schema.Type<typeof McpServer> {}
|
package/src/types/Memory.ts
CHANGED
|
@@ -13,11 +13,12 @@ export const Memory = Schema.Struct({
|
|
|
13
13
|
title: Schema.String,
|
|
14
14
|
content: Schema.String,
|
|
15
15
|
}).pipe(
|
|
16
|
-
Type.object({ typename: 'dxos.
|
|
16
|
+
Type.object({ typename: 'org.dxos.type.memory', version: '0.1.0' }),
|
|
17
17
|
Annotation.LabelAnnotation.set(['title']),
|
|
18
18
|
Annotation.IconAnnotation.set({
|
|
19
19
|
icon: 'ph--brain--regular',
|
|
20
20
|
hue: 'pink',
|
|
21
21
|
}),
|
|
22
22
|
);
|
|
23
|
+
|
|
23
24
|
export interface Memory extends Schema.Schema.Type<typeof Memory> {}
|
package/src/types/Plan.ts
CHANGED
|
@@ -72,7 +72,7 @@ export const generateTaskId = (plan: Plan): TaskId => {
|
|
|
72
72
|
|
|
73
73
|
/**
|
|
74
74
|
* Add new tasks to a plan, generating IDs for new tasks.
|
|
75
|
-
* Use inside an `Obj.
|
|
75
|
+
* Use inside an `Obj.update` callback.
|
|
76
76
|
*/
|
|
77
77
|
export const addTasks = (
|
|
78
78
|
plan: Obj.Mutable<Plan>,
|
|
@@ -94,7 +94,7 @@ interface MakePlanProps {
|
|
|
94
94
|
|
|
95
95
|
export const makePlan = (props: MakePlanProps): Plan => {
|
|
96
96
|
const plan = Obj.make(Plan, { tasks: [] });
|
|
97
|
-
Obj.
|
|
97
|
+
Obj.update(plan, (plan) => {
|
|
98
98
|
addTasks(plan, props.tasks);
|
|
99
99
|
});
|
|
100
100
|
return plan;
|
package/src/types/index.ts
CHANGED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/blueprints/project/functions/add-artifact.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Database, Obj } from '@dxos/echo';\nimport { Operation } from '@dxos/operation';\n\nimport { Agent } from '../../../types';\nimport { AddArtifact } from './definitions';\n\nexport default AddArtifact.pipe(\n Operation.withHandler(\n Effect.fnUntraced(function* ({ name, artifact }) {\n if (!(yield* Database.load(artifact))) {\n throw new Error('Artifact not found.');\n }\n\n const agent = yield* Agent.getFromChatContext;\n\n Obj.change(agent, (agent) => {\n agent.artifacts.push({\n name,\n data: artifact,\n });\n });\n }) as any,\n ),\n);\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,UAAUC,WAAW;AAC9B,SAASC,iBAAiB;AAK1B,IAAA,uBAAeC,YAAYC,KACzBC,UAAUC,YACDC,kBAAW,WAAW,EAAEC,MAAMC,SAAQ,GAAE;AAC7C,MAAI,EAAE,OAAOC,SAASC,KAAKF,QAAAA,IAAY;AACrC,UAAM,IAAIG,MAAM,qBAAA;EAClB;AAEA,QAAMC,QAAQ,OAAOC,cAAMC;AAE3BC,MAAIC,OAAOJ,OAAO,CAACA,WAAAA;AACjBA,IAAAA,OAAMK,UAAUC,KAAK;MACnBX;MACAY,MAAMX;IACR,CAAA;EACF,CAAA;AACF,CAAA,CAAA,CAAA;",
|
|
6
|
-
"names": ["Effect", "Database", "Obj", "Operation", "AddArtifact", "pipe", "Operation", "withHandler", "fnUntraced", "name", "artifact", "Database", "load", "Error", "agent", "Agent", "getFromChatContext", "Obj", "change", "artifacts", "push", "data"]
|
|
7
|
-
}
|