@agentuity/cli 0.0.60 → 0.0.61
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/bin/cli.ts +15 -4
- package/dist/banner.d.ts +1 -0
- package/dist/banner.d.ts.map +1 -1
- package/dist/banner.js +28 -13
- package/dist/banner.js.map +1 -1
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +85 -9
- package/dist/cli.js.map +1 -1
- package/dist/cmd/ai/capabilities/index.d.ts.map +1 -1
- package/dist/cmd/ai/capabilities/index.js +4 -0
- package/dist/cmd/ai/capabilities/index.js.map +1 -1
- package/dist/cmd/ai/capabilities/show.d.ts.map +1 -1
- package/dist/cmd/ai/capabilities/show.js +13 -2
- package/dist/cmd/ai/capabilities/show.js.map +1 -1
- package/dist/cmd/ai/index.d.ts.map +1 -1
- package/dist/cmd/ai/index.js +11 -0
- package/dist/cmd/ai/index.js.map +1 -1
- package/dist/cmd/ai/prompt/agent.d.ts +3 -0
- package/dist/cmd/ai/prompt/agent.d.ts.map +1 -0
- package/dist/cmd/ai/prompt/agent.js +340 -0
- package/dist/cmd/ai/prompt/agent.js.map +1 -0
- package/dist/cmd/ai/prompt/api.d.ts +3 -0
- package/dist/cmd/ai/prompt/api.d.ts.map +1 -0
- package/dist/cmd/ai/prompt/api.js +272 -0
- package/dist/cmd/ai/prompt/api.js.map +1 -0
- package/dist/cmd/ai/prompt/index.d.ts +1 -2
- package/dist/cmd/ai/prompt/index.d.ts.map +1 -1
- package/dist/cmd/ai/prompt/index.js +17 -1
- package/dist/cmd/ai/prompt/index.js.map +1 -1
- package/dist/cmd/ai/prompt/llm.d.ts +1 -0
- package/dist/cmd/ai/prompt/llm.d.ts.map +1 -1
- package/dist/cmd/ai/prompt/llm.js +2 -2
- package/dist/cmd/ai/prompt/llm.js.map +1 -1
- package/dist/cmd/ai/prompt/web.d.ts +3 -0
- package/dist/cmd/ai/prompt/web.d.ts.map +1 -0
- package/dist/cmd/ai/prompt/web.js +299 -0
- package/dist/cmd/ai/prompt/web.js.map +1 -0
- package/dist/cmd/ai/schema/generate.js +1 -1
- package/dist/cmd/ai/schema/generate.js.map +1 -1
- package/dist/cmd/ai/schema/index.d.ts.map +1 -1
- package/dist/cmd/ai/schema/index.js +2 -0
- package/dist/cmd/ai/schema/index.js.map +1 -1
- package/dist/cmd/ai/schema/show.d.ts.map +1 -1
- package/dist/cmd/ai/schema/show.js +4 -1
- package/dist/cmd/ai/schema/show.js.map +1 -1
- package/dist/cmd/auth/api.d.ts.map +1 -1
- package/dist/cmd/auth/api.js +12 -6
- package/dist/cmd/auth/api.js.map +1 -1
- package/dist/cmd/auth/index.d.ts.map +1 -1
- package/dist/cmd/auth/index.js +5 -0
- package/dist/cmd/auth/index.js.map +1 -1
- package/dist/cmd/auth/login.d.ts.map +1 -1
- package/dist/cmd/auth/login.js +5 -22
- package/dist/cmd/auth/login.js.map +1 -1
- package/dist/cmd/auth/logout.d.ts.map +1 -1
- package/dist/cmd/auth/logout.js +4 -1
- package/dist/cmd/auth/logout.js.map +1 -1
- package/dist/cmd/auth/signup.d.ts.map +1 -1
- package/dist/cmd/auth/signup.js +4 -1
- package/dist/cmd/auth/signup.js.map +1 -1
- package/dist/cmd/auth/ssh/add.d.ts.map +1 -1
- package/dist/cmd/auth/ssh/add.js +13 -4
- package/dist/cmd/auth/ssh/add.js.map +1 -1
- package/dist/cmd/auth/ssh/api.d.ts.map +1 -1
- package/dist/cmd/auth/ssh/api.js +11 -5
- package/dist/cmd/auth/ssh/api.js.map +1 -1
- package/dist/cmd/auth/ssh/delete.js +4 -4
- package/dist/cmd/auth/ssh/delete.js.map +1 -1
- package/dist/cmd/auth/ssh/index.d.ts.map +1 -1
- package/dist/cmd/auth/ssh/index.js +5 -0
- package/dist/cmd/auth/ssh/index.js.map +1 -1
- package/dist/cmd/auth/ssh/list.js +3 -3
- package/dist/cmd/auth/ssh/list.js.map +1 -1
- package/dist/cmd/auth/whoami.d.ts.map +1 -1
- package/dist/cmd/auth/whoami.js +4 -4
- package/dist/cmd/auth/whoami.js.map +1 -1
- package/dist/cmd/build/ast.d.ts +24 -1
- package/dist/cmd/build/ast.d.ts.map +1 -1
- package/dist/cmd/build/ast.js +526 -14
- package/dist/cmd/build/ast.js.map +1 -1
- package/dist/cmd/build/bundler.d.ts +3 -1
- package/dist/cmd/build/bundler.d.ts.map +1 -1
- package/dist/cmd/build/bundler.js +89 -38
- package/dist/cmd/build/bundler.js.map +1 -1
- package/dist/cmd/build/file.js +1 -1
- package/dist/cmd/build/file.js.map +1 -1
- package/dist/cmd/build/fix-duplicate-exports.d.ts.map +1 -1
- package/dist/cmd/build/fix-duplicate-exports.js +4 -1
- package/dist/cmd/build/fix-duplicate-exports.js.map +1 -1
- package/dist/cmd/build/index.d.ts.map +1 -1
- package/dist/cmd/build/index.js +55 -13
- package/dist/cmd/build/index.js.map +1 -1
- package/dist/cmd/build/plugin.d.ts.map +1 -1
- package/dist/cmd/build/plugin.js +183 -38
- package/dist/cmd/build/plugin.js.map +1 -1
- package/dist/cmd/cloud/agent/get.d.ts.map +1 -1
- package/dist/cmd/cloud/agent/get.js +5 -2
- package/dist/cmd/cloud/agent/get.js.map +1 -1
- package/dist/cmd/cloud/agent/index.d.ts.map +1 -1
- package/dist/cmd/cloud/agent/index.js +5 -0
- package/dist/cmd/cloud/agent/index.js.map +1 -1
- package/dist/cmd/cloud/agent/list.js +3 -3
- package/dist/cmd/cloud/agent/list.js.map +1 -1
- package/dist/cmd/cloud/apikey/create.d.ts.map +1 -1
- package/dist/cmd/cloud/apikey/create.js +12 -3
- package/dist/cmd/cloud/apikey/create.js.map +1 -1
- package/dist/cmd/cloud/apikey/delete.js +3 -3
- package/dist/cmd/cloud/apikey/delete.js.map +1 -1
- package/dist/cmd/cloud/apikey/get.js +1 -1
- package/dist/cmd/cloud/apikey/get.js.map +1 -1
- package/dist/cmd/cloud/apikey/index.d.ts.map +1 -1
- package/dist/cmd/cloud/apikey/index.js +8 -0
- package/dist/cmd/cloud/apikey/index.js.map +1 -1
- package/dist/cmd/cloud/apikey/list.d.ts.map +1 -1
- package/dist/cmd/cloud/apikey/list.js +4 -1
- package/dist/cmd/cloud/apikey/list.js.map +1 -1
- package/dist/cmd/cloud/db/create.d.ts.map +1 -1
- package/dist/cmd/cloud/db/create.js +35 -21
- package/dist/cmd/cloud/db/create.js.map +1 -1
- package/dist/cmd/cloud/db/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/db/delete.js +34 -21
- package/dist/cmd/cloud/db/delete.js.map +1 -1
- package/dist/cmd/cloud/db/get.d.ts.map +1 -1
- package/dist/cmd/cloud/db/get.js +9 -3
- package/dist/cmd/cloud/db/get.js.map +1 -1
- package/dist/cmd/cloud/db/index.d.ts.map +1 -1
- package/dist/cmd/cloud/db/index.js +5 -0
- package/dist/cmd/cloud/db/index.js.map +1 -1
- package/dist/cmd/cloud/db/list.d.ts.map +1 -1
- package/dist/cmd/cloud/db/list.js +16 -6
- package/dist/cmd/cloud/db/list.js.map +1 -1
- package/dist/cmd/cloud/db/sql.d.ts.map +1 -1
- package/dist/cmd/cloud/db/sql.js +12 -3
- package/dist/cmd/cloud/db/sql.js.map +1 -1
- package/dist/cmd/cloud/deploy.d.ts.map +1 -1
- package/dist/cmd/cloud/deploy.js +9 -3
- package/dist/cmd/cloud/deploy.js.map +1 -1
- package/dist/cmd/cloud/deployment/index.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/index.js +5 -0
- package/dist/cmd/cloud/deployment/index.js.map +1 -1
- package/dist/cmd/cloud/deployment/list.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/list.js +12 -3
- package/dist/cmd/cloud/deployment/list.js.map +1 -1
- package/dist/cmd/cloud/deployment/logs.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/logs.js +16 -4
- package/dist/cmd/cloud/deployment/logs.js.map +1 -1
- package/dist/cmd/cloud/deployment/remove.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/remove.js +12 -3
- package/dist/cmd/cloud/deployment/remove.js.map +1 -1
- package/dist/cmd/cloud/deployment/rollback.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/rollback.js +8 -2
- package/dist/cmd/cloud/deployment/rollback.js.map +1 -1
- package/dist/cmd/cloud/deployment/show.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/show.js +8 -2
- package/dist/cmd/cloud/deployment/show.js.map +1 -1
- package/dist/cmd/cloud/deployment/undeploy.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/undeploy.js +12 -3
- package/dist/cmd/cloud/deployment/undeploy.js.map +1 -1
- package/dist/cmd/cloud/deployment/utils.d.ts.map +1 -1
- package/dist/cmd/cloud/deployment/utils.js +3 -1
- package/dist/cmd/cloud/deployment/utils.js.map +1 -1
- package/dist/cmd/cloud/domain.d.ts.map +1 -1
- package/dist/cmd/cloud/domain.js +4 -2
- package/dist/cmd/cloud/domain.js.map +1 -1
- package/dist/cmd/cloud/env/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/env/delete.js +4 -1
- package/dist/cmd/cloud/env/delete.js.map +1 -1
- package/dist/cmd/cloud/env/get.d.ts.map +1 -1
- package/dist/cmd/cloud/env/get.js +4 -1
- package/dist/cmd/cloud/env/get.js.map +1 -1
- package/dist/cmd/cloud/env/import.d.ts.map +1 -1
- package/dist/cmd/cloud/env/import.js +10 -0
- package/dist/cmd/cloud/env/import.js.map +1 -1
- package/dist/cmd/cloud/env/index.d.ts.map +1 -1
- package/dist/cmd/cloud/env/index.js +8 -0
- package/dist/cmd/cloud/env/index.js.map +1 -1
- package/dist/cmd/cloud/env/list.d.ts.map +1 -1
- package/dist/cmd/cloud/env/list.js +4 -1
- package/dist/cmd/cloud/env/list.js.map +1 -1
- package/dist/cmd/cloud/env/pull.d.ts.map +1 -1
- package/dist/cmd/cloud/env/pull.js +4 -1
- package/dist/cmd/cloud/env/pull.js.map +1 -1
- package/dist/cmd/cloud/env/push.js +1 -1
- package/dist/cmd/cloud/env/push.js.map +1 -1
- package/dist/cmd/cloud/env/set.js +3 -3
- package/dist/cmd/cloud/env/set.js.map +1 -1
- package/dist/cmd/cloud/index.d.ts.map +1 -1
- package/dist/cmd/cloud/index.js +5 -0
- package/dist/cmd/cloud/index.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/create-namespace.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/create-namespace.js +9 -3
- package/dist/cmd/cloud/keyvalue/create-namespace.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/delete-namespace.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/delete-namespace.js +12 -3
- package/dist/cmd/cloud/keyvalue/delete-namespace.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/delete.js +6 -3
- package/dist/cmd/cloud/keyvalue/delete.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/get.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/get.js +3 -3
- package/dist/cmd/cloud/keyvalue/get.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/index.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/index.js +8 -0
- package/dist/cmd/cloud/keyvalue/index.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/keys.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/keys.js +3 -3
- package/dist/cmd/cloud/keyvalue/keys.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/list-namespaces.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/list-namespaces.js +3 -3
- package/dist/cmd/cloud/keyvalue/list-namespaces.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/repl.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/repl.js +1 -1
- package/dist/cmd/cloud/keyvalue/repl.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/search.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/search.js +9 -3
- package/dist/cmd/cloud/keyvalue/search.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/set.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/set.js +12 -3
- package/dist/cmd/cloud/keyvalue/set.js.map +1 -1
- package/dist/cmd/cloud/keyvalue/stats.d.ts.map +1 -1
- package/dist/cmd/cloud/keyvalue/stats.js +6 -3
- package/dist/cmd/cloud/keyvalue/stats.js.map +1 -1
- package/dist/cmd/cloud/objectstore/delete-bucket.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/delete-bucket.js +8 -2
- package/dist/cmd/cloud/objectstore/delete-bucket.js.map +1 -1
- package/dist/cmd/cloud/objectstore/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/delete.js +12 -3
- package/dist/cmd/cloud/objectstore/delete.js.map +1 -1
- package/dist/cmd/cloud/objectstore/get.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/get.js +12 -3
- package/dist/cmd/cloud/objectstore/get.js.map +1 -1
- package/dist/cmd/cloud/objectstore/index.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/index.js +8 -0
- package/dist/cmd/cloud/objectstore/index.js.map +1 -1
- package/dist/cmd/cloud/objectstore/list-buckets.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/list-buckets.js +6 -1
- package/dist/cmd/cloud/objectstore/list-buckets.js.map +1 -1
- package/dist/cmd/cloud/objectstore/list-keys.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/list-keys.js +6 -3
- package/dist/cmd/cloud/objectstore/list-keys.js.map +1 -1
- package/dist/cmd/cloud/objectstore/put.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/put.js +12 -3
- package/dist/cmd/cloud/objectstore/put.js.map +1 -1
- package/dist/cmd/cloud/objectstore/repl.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/repl.js +6 -1
- package/dist/cmd/cloud/objectstore/repl.js.map +1 -1
- package/dist/cmd/cloud/objectstore/url.d.ts.map +1 -1
- package/dist/cmd/cloud/objectstore/url.js +12 -3
- package/dist/cmd/cloud/objectstore/url.js.map +1 -1
- package/dist/cmd/cloud/scp/download.d.ts.map +1 -1
- package/dist/cmd/cloud/scp/download.js +16 -4
- package/dist/cmd/cloud/scp/download.js.map +1 -1
- package/dist/cmd/cloud/scp/index.d.ts.map +1 -1
- package/dist/cmd/cloud/scp/index.js +11 -0
- package/dist/cmd/cloud/scp/index.js.map +1 -1
- package/dist/cmd/cloud/scp/upload.d.ts.map +1 -1
- package/dist/cmd/cloud/scp/upload.js +16 -4
- package/dist/cmd/cloud/scp/upload.js.map +1 -1
- package/dist/cmd/cloud/secret/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/delete.js +4 -1
- package/dist/cmd/cloud/secret/delete.js.map +1 -1
- package/dist/cmd/cloud/secret/get.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/get.js +5 -2
- package/dist/cmd/cloud/secret/get.js.map +1 -1
- package/dist/cmd/cloud/secret/import.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/import.js +5 -2
- package/dist/cmd/cloud/secret/import.js.map +1 -1
- package/dist/cmd/cloud/secret/index.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/index.js +8 -0
- package/dist/cmd/cloud/secret/index.js.map +1 -1
- package/dist/cmd/cloud/secret/list.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/list.js +4 -1
- package/dist/cmd/cloud/secret/list.js.map +1 -1
- package/dist/cmd/cloud/secret/pull.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/pull.js +4 -1
- package/dist/cmd/cloud/secret/pull.js.map +1 -1
- package/dist/cmd/cloud/secret/push.js +1 -1
- package/dist/cmd/cloud/secret/push.js.map +1 -1
- package/dist/cmd/cloud/secret/set.d.ts.map +1 -1
- package/dist/cmd/cloud/secret/set.js +8 -2
- package/dist/cmd/cloud/secret/set.js.map +1 -1
- package/dist/cmd/cloud/session/get.js +1 -1
- package/dist/cmd/cloud/session/get.js.map +1 -1
- package/dist/cmd/cloud/session/index.d.ts.map +1 -1
- package/dist/cmd/cloud/session/index.js +5 -0
- package/dist/cmd/cloud/session/index.js.map +1 -1
- package/dist/cmd/cloud/session/list.d.ts.map +1 -1
- package/dist/cmd/cloud/session/list.js +29 -8
- package/dist/cmd/cloud/session/list.js.map +1 -1
- package/dist/cmd/cloud/session/logs.d.ts.map +1 -1
- package/dist/cmd/cloud/session/logs.js +8 -2
- package/dist/cmd/cloud/session/logs.js.map +1 -1
- package/dist/cmd/cloud/ssh.d.ts.map +1 -1
- package/dist/cmd/cloud/ssh.js +15 -6
- package/dist/cmd/cloud/ssh.js.map +1 -1
- package/dist/cmd/cloud/storage/create.js +3 -3
- package/dist/cmd/cloud/storage/create.js.map +1 -1
- package/dist/cmd/cloud/storage/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/delete.js +7 -4
- package/dist/cmd/cloud/storage/delete.js.map +1 -1
- package/dist/cmd/cloud/storage/download.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/download.js +16 -4
- package/dist/cmd/cloud/storage/download.js.map +1 -1
- package/dist/cmd/cloud/storage/get.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/get.js +12 -3
- package/dist/cmd/cloud/storage/get.js.map +1 -1
- package/dist/cmd/cloud/storage/index.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/index.js +8 -0
- package/dist/cmd/cloud/storage/index.js.map +1 -1
- package/dist/cmd/cloud/storage/list.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/list.js +35 -12
- package/dist/cmd/cloud/storage/list.js.map +1 -1
- package/dist/cmd/cloud/storage/upload.d.ts.map +1 -1
- package/dist/cmd/cloud/storage/upload.js +21 -9
- package/dist/cmd/cloud/storage/upload.js.map +1 -1
- package/dist/cmd/cloud/stream/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/stream/delete.js +9 -3
- package/dist/cmd/cloud/stream/delete.js.map +1 -1
- package/dist/cmd/cloud/stream/get.d.ts.map +1 -1
- package/dist/cmd/cloud/stream/get.js +10 -4
- package/dist/cmd/cloud/stream/get.js.map +1 -1
- package/dist/cmd/cloud/stream/index.d.ts.map +1 -1
- package/dist/cmd/cloud/stream/index.js +5 -0
- package/dist/cmd/cloud/stream/index.js.map +1 -1
- package/dist/cmd/cloud/stream/list.d.ts.map +1 -1
- package/dist/cmd/cloud/stream/list.js +8 -5
- package/dist/cmd/cloud/stream/list.js.map +1 -1
- package/dist/cmd/cloud/vector/delete.d.ts.map +1 -1
- package/dist/cmd/cloud/vector/delete.js +12 -3
- package/dist/cmd/cloud/vector/delete.js.map +1 -1
- package/dist/cmd/cloud/vector/get.d.ts.map +1 -1
- package/dist/cmd/cloud/vector/get.js +12 -3
- package/dist/cmd/cloud/vector/get.js.map +1 -1
- package/dist/cmd/cloud/vector/index.d.ts.map +1 -1
- package/dist/cmd/cloud/vector/index.js +8 -0
- package/dist/cmd/cloud/vector/index.js.map +1 -1
- package/dist/cmd/cloud/vector/search.d.ts.map +1 -1
- package/dist/cmd/cloud/vector/search.js +20 -5
- package/dist/cmd/cloud/vector/search.js.map +1 -1
- package/dist/cmd/dev/agents.d.ts.map +1 -1
- package/dist/cmd/dev/agents.js +7 -2
- package/dist/cmd/dev/agents.js.map +1 -1
- package/dist/cmd/dev/api.d.ts.map +1 -1
- package/dist/cmd/dev/api.js +3 -1
- package/dist/cmd/dev/api.js.map +1 -1
- package/dist/cmd/dev/index.d.ts.map +1 -1
- package/dist/cmd/dev/index.js +13 -5
- package/dist/cmd/dev/index.js.map +1 -1
- package/dist/cmd/help/index.d.ts +2 -0
- package/dist/cmd/help/index.d.ts.map +1 -0
- package/dist/cmd/help/index.js +35 -0
- package/dist/cmd/help/index.js.map +1 -0
- package/dist/cmd/index.d.ts.map +1 -1
- package/dist/cmd/index.js +1 -0
- package/dist/cmd/index.js.map +1 -1
- package/dist/cmd/profile/create.js +3 -3
- package/dist/cmd/profile/create.js.map +1 -1
- package/dist/cmd/profile/delete.d.ts.map +1 -1
- package/dist/cmd/profile/delete.js +6 -3
- package/dist/cmd/profile/delete.js.map +1 -1
- package/dist/cmd/profile/index.d.ts.map +1 -1
- package/dist/cmd/profile/index.js +8 -0
- package/dist/cmd/profile/index.js.map +1 -1
- package/dist/cmd/profile/list.d.ts.map +1 -1
- package/dist/cmd/profile/list.js +4 -1
- package/dist/cmd/profile/list.js.map +1 -1
- package/dist/cmd/profile/show.d.ts.map +1 -1
- package/dist/cmd/profile/show.js +6 -3
- package/dist/cmd/profile/show.js.map +1 -1
- package/dist/cmd/profile/use.js +3 -3
- package/dist/cmd/profile/use.js.map +1 -1
- package/dist/cmd/project/create.d.ts.map +1 -1
- package/dist/cmd/project/create.js +11 -5
- package/dist/cmd/project/create.js.map +1 -1
- package/dist/cmd/project/delete.d.ts.map +1 -1
- package/dist/cmd/project/delete.js +15 -6
- package/dist/cmd/project/delete.js.map +1 -1
- package/dist/cmd/project/download.d.ts +1 -1
- package/dist/cmd/project/download.d.ts.map +1 -1
- package/dist/cmd/project/download.js +28 -2
- package/dist/cmd/project/download.js.map +1 -1
- package/dist/cmd/project/index.d.ts.map +1 -1
- package/dist/cmd/project/index.js +5 -0
- package/dist/cmd/project/index.js.map +1 -1
- package/dist/cmd/project/list.js +3 -3
- package/dist/cmd/project/list.js.map +1 -1
- package/dist/cmd/project/show.d.ts.map +1 -1
- package/dist/cmd/project/show.js +6 -3
- package/dist/cmd/project/show.js.map +1 -1
- package/dist/cmd/project/templates.d.ts.map +1 -1
- package/dist/cmd/project/templates.js +10 -2
- package/dist/cmd/project/templates.js.map +1 -1
- package/dist/cmd/repl/index.js +1 -1
- package/dist/cmd/repl/index.js.map +1 -1
- package/dist/cmd/version/index.d.ts.map +1 -1
- package/dist/cmd/version/index.js +4 -1
- package/dist/cmd/version/index.js.map +1 -1
- package/dist/command-prefix.d.ts.map +1 -1
- package/dist/command-prefix.js +5 -3
- package/dist/command-prefix.js.map +1 -1
- package/dist/config.d.ts +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +3 -1
- package/dist/config.js.map +1 -1
- package/dist/crypto/box.d.ts.map +1 -1
- package/dist/crypto/box.js +31 -17
- package/dist/crypto/box.js.map +1 -1
- package/dist/download.d.ts.map +1 -1
- package/dist/download.js +7 -1
- package/dist/download.js.map +1 -1
- package/dist/env-util.d.ts +3 -0
- package/dist/env-util.d.ts.map +1 -1
- package/dist/env-util.js +43 -2
- package/dist/env-util.js.map +1 -1
- package/dist/errors.d.ts +4 -2
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +7 -1
- package/dist/errors.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/schema-generator.d.ts +5 -1
- package/dist/schema-generator.d.ts.map +1 -1
- package/dist/schema-generator.js +1 -0
- package/dist/schema-generator.js.map +1 -1
- package/dist/steps.js +17 -13
- package/dist/steps.js.map +1 -1
- package/dist/tui.d.ts +2 -1
- package/dist/tui.d.ts.map +1 -1
- package/dist/tui.js +21 -14
- package/dist/tui.js.map +1 -1
- package/dist/types.d.ts +10 -6
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/date.d.ts.map +1 -1
- package/dist/utils/date.js +7 -2
- package/dist/utils/date.js.map +1 -1
- package/package.json +3 -3
- package/src/banner.ts +29 -13
- package/src/cli.ts +109 -13
- package/src/cmd/ai/capabilities/index.ts +4 -0
- package/src/cmd/ai/capabilities/show.ts +13 -2
- package/src/cmd/ai/index.ts +11 -0
- package/src/cmd/ai/prompt/agent.ts +342 -0
- package/src/cmd/ai/prompt/api.ts +274 -0
- package/src/cmd/ai/prompt/index.ts +18 -3
- package/src/cmd/ai/prompt/llm.ts +2 -2
- package/src/cmd/ai/prompt/web.ts +301 -0
- package/src/cmd/ai/schema/generate.ts +1 -1
- package/src/cmd/ai/schema/index.ts +2 -0
- package/src/cmd/ai/schema/show.ts +4 -1
- package/src/cmd/auth/api.ts +28 -6
- package/src/cmd/auth/index.ts +5 -0
- package/src/cmd/auth/login.ts +5 -22
- package/src/cmd/auth/logout.ts +4 -1
- package/src/cmd/auth/signup.ts +4 -1
- package/src/cmd/auth/ssh/add.ts +13 -4
- package/src/cmd/auth/ssh/api.ts +21 -5
- package/src/cmd/auth/ssh/delete.ts +4 -4
- package/src/cmd/auth/ssh/index.ts +5 -0
- package/src/cmd/auth/ssh/list.ts +3 -3
- package/src/cmd/auth/whoami.ts +4 -7
- package/src/cmd/build/ast.ts +605 -31
- package/src/cmd/build/bundler.ts +110 -37
- package/src/cmd/build/file.ts +1 -1
- package/src/cmd/build/fix-duplicate-exports.ts +4 -1
- package/src/cmd/build/index.ts +58 -13
- package/src/cmd/build/plugin.ts +210 -46
- package/src/cmd/cloud/agent/get.ts +5 -2
- package/src/cmd/cloud/agent/index.ts +5 -0
- package/src/cmd/cloud/agent/list.ts +3 -3
- package/src/cmd/cloud/apikey/create.ts +14 -5
- package/src/cmd/cloud/apikey/delete.ts +3 -3
- package/src/cmd/cloud/apikey/get.ts +1 -1
- package/src/cmd/cloud/apikey/index.ts +8 -0
- package/src/cmd/cloud/apikey/list.ts +4 -1
- package/src/cmd/cloud/db/create.ts +37 -22
- package/src/cmd/cloud/db/delete.ts +36 -21
- package/src/cmd/cloud/db/get.ts +12 -4
- package/src/cmd/cloud/db/index.ts +5 -0
- package/src/cmd/cloud/db/list.ts +19 -7
- package/src/cmd/cloud/db/sql.ts +12 -3
- package/src/cmd/cloud/deploy.ts +9 -3
- package/src/cmd/cloud/deployment/index.ts +5 -0
- package/src/cmd/cloud/deployment/list.ts +12 -3
- package/src/cmd/cloud/deployment/logs.ts +16 -4
- package/src/cmd/cloud/deployment/remove.ts +14 -4
- package/src/cmd/cloud/deployment/rollback.ts +8 -3
- package/src/cmd/cloud/deployment/show.ts +8 -2
- package/src/cmd/cloud/deployment/undeploy.ts +12 -4
- package/src/cmd/cloud/deployment/utils.ts +7 -1
- package/src/cmd/cloud/domain.ts +9 -2
- package/src/cmd/cloud/env/delete.ts +4 -1
- package/src/cmd/cloud/env/get.ts +4 -1
- package/src/cmd/cloud/env/import.ts +10 -0
- package/src/cmd/cloud/env/index.ts +8 -0
- package/src/cmd/cloud/env/list.ts +4 -1
- package/src/cmd/cloud/env/pull.ts +4 -1
- package/src/cmd/cloud/env/push.ts +1 -1
- package/src/cmd/cloud/env/set.ts +3 -3
- package/src/cmd/cloud/index.ts +5 -1
- package/src/cmd/cloud/keyvalue/create-namespace.ts +9 -4
- package/src/cmd/cloud/keyvalue/delete-namespace.ts +12 -4
- package/src/cmd/cloud/keyvalue/delete.ts +6 -4
- package/src/cmd/cloud/keyvalue/get.ts +3 -4
- package/src/cmd/cloud/keyvalue/index.ts +8 -0
- package/src/cmd/cloud/keyvalue/keys.ts +3 -4
- package/src/cmd/cloud/keyvalue/list-namespaces.ts +3 -4
- package/src/cmd/cloud/keyvalue/repl.ts +1 -2
- package/src/cmd/cloud/keyvalue/search.ts +9 -4
- package/src/cmd/cloud/keyvalue/set.ts +14 -4
- package/src/cmd/cloud/keyvalue/stats.ts +6 -4
- package/src/cmd/cloud/objectstore/delete-bucket.ts +8 -3
- package/src/cmd/cloud/objectstore/delete.ts +12 -4
- package/src/cmd/cloud/objectstore/get.ts +12 -4
- package/src/cmd/cloud/objectstore/index.ts +8 -0
- package/src/cmd/cloud/objectstore/list-buckets.ts +6 -2
- package/src/cmd/cloud/objectstore/list-keys.ts +6 -4
- package/src/cmd/cloud/objectstore/put.ts +16 -4
- package/src/cmd/cloud/objectstore/repl.ts +6 -2
- package/src/cmd/cloud/objectstore/url.ts +12 -4
- package/src/cmd/cloud/scp/download.ts +16 -5
- package/src/cmd/cloud/scp/index.ts +11 -0
- package/src/cmd/cloud/scp/upload.ts +16 -5
- package/src/cmd/cloud/secret/delete.ts +4 -1
- package/src/cmd/cloud/secret/get.ts +5 -2
- package/src/cmd/cloud/secret/import.ts +5 -2
- package/src/cmd/cloud/secret/index.ts +8 -0
- package/src/cmd/cloud/secret/list.ts +4 -1
- package/src/cmd/cloud/secret/pull.ts +4 -1
- package/src/cmd/cloud/secret/push.ts +1 -1
- package/src/cmd/cloud/secret/set.ts +8 -2
- package/src/cmd/cloud/session/get.ts +1 -1
- package/src/cmd/cloud/session/index.ts +5 -0
- package/src/cmd/cloud/session/list.ts +29 -8
- package/src/cmd/cloud/session/logs.ts +8 -2
- package/src/cmd/cloud/ssh.ts +15 -7
- package/src/cmd/cloud/storage/create.ts +3 -3
- package/src/cmd/cloud/storage/delete.ts +7 -4
- package/src/cmd/cloud/storage/download.ts +16 -4
- package/src/cmd/cloud/storage/get.ts +12 -3
- package/src/cmd/cloud/storage/index.ts +8 -0
- package/src/cmd/cloud/storage/list.ts +39 -15
- package/src/cmd/cloud/storage/upload.ts +24 -9
- package/src/cmd/cloud/stream/delete.ts +9 -4
- package/src/cmd/cloud/stream/get.ts +10 -5
- package/src/cmd/cloud/stream/index.ts +5 -0
- package/src/cmd/cloud/stream/list.ts +8 -6
- package/src/cmd/cloud/vector/delete.ts +17 -6
- package/src/cmd/cloud/vector/get.ts +12 -4
- package/src/cmd/cloud/vector/index.ts +8 -0
- package/src/cmd/cloud/vector/search.ts +20 -6
- package/src/cmd/dev/agents.ts +7 -2
- package/src/cmd/dev/api.ts +4 -1
- package/src/cmd/dev/index.ts +16 -5
- package/src/cmd/help/index.ts +40 -0
- package/src/cmd/index.ts +1 -0
- package/src/cmd/profile/create.ts +3 -3
- package/src/cmd/profile/delete.ts +6 -3
- package/src/cmd/profile/index.ts +8 -0
- package/src/cmd/profile/list.ts +4 -1
- package/src/cmd/profile/show.ts +6 -3
- package/src/cmd/profile/use.ts +3 -3
- package/src/cmd/project/create.ts +11 -5
- package/src/cmd/project/delete.ts +15 -6
- package/src/cmd/project/download.ts +35 -3
- package/src/cmd/project/index.ts +5 -0
- package/src/cmd/project/list.ts +3 -3
- package/src/cmd/project/show.ts +6 -3
- package/src/cmd/project/templates.ts +12 -2
- package/src/cmd/repl/index.ts +1 -1
- package/src/cmd/version/index.ts +4 -1
- package/src/command-prefix.ts +5 -3
- package/src/config.ts +4 -2
- package/src/crypto/box.ts +69 -17
- package/src/download.ts +7 -1
- package/src/env-util.ts +44 -2
- package/src/errors.ts +9 -1
- package/src/index.ts +6 -1
- package/src/schema-generator.ts +7 -1
- package/src/steps.ts +22 -13
- package/src/tui.ts +28 -16
- package/src/types.ts +11 -6
- package/src/utils/date.ts +9 -4
package/dist/cmd/build/ast.js
CHANGED
|
@@ -3,6 +3,10 @@ import { basename, dirname, relative } from 'node:path';
|
|
|
3
3
|
import { generate } from 'astring';
|
|
4
4
|
import { createLogger } from '@agentuity/server';
|
|
5
5
|
import * as ts from 'typescript';
|
|
6
|
+
import { StructuredError } from '@agentuity/core';
|
|
7
|
+
import { join } from 'node:path';
|
|
8
|
+
import { existsSync, mkdirSync } from 'node:fs';
|
|
9
|
+
import JSON5 from 'json5';
|
|
6
10
|
const logger = createLogger((process.env.AGENTUITY_LOG_LEVEL || 'info'));
|
|
7
11
|
function parseObjectExpressionToMap(expr) {
|
|
8
12
|
const result = new Map();
|
|
@@ -76,16 +80,25 @@ function generateStableAgentId(projectId, name) {
|
|
|
76
80
|
function generateStableEvalId(projectId, agentId, name) {
|
|
77
81
|
return `evalid_${hashSHA1(projectId, agentId, name)}`.substring(0, 64);
|
|
78
82
|
}
|
|
83
|
+
const MetadataError = StructuredError('MetatadataNameMissingError')();
|
|
79
84
|
function augmentAgentMetadataNode(projectId, id, identifier, rel, version, ast, propvalue, filename) {
|
|
80
85
|
const metadata = parseObjectExpressionToMap(propvalue);
|
|
81
86
|
if (!metadata.has('name')) {
|
|
82
87
|
const location = ast.loc?.start ? ` on line ${ast.loc.start}` : '';
|
|
83
|
-
throw new
|
|
88
|
+
throw new MetadataError({
|
|
89
|
+
filename,
|
|
90
|
+
line: ast.loc?.start?.line,
|
|
91
|
+
message: `missing required metadata.name in ${filename}${location}. This Agent should have a unique and human readable name for this project.`,
|
|
92
|
+
});
|
|
84
93
|
}
|
|
85
94
|
const name = metadata.get('name');
|
|
86
95
|
if (metadata.has('identifier') && identifier !== metadata.get('identifier')) {
|
|
87
96
|
const location = ast.loc?.start ? ` on line ${ast.loc.start}` : '';
|
|
88
|
-
throw new
|
|
97
|
+
throw new MetadataError({
|
|
98
|
+
filename,
|
|
99
|
+
line: ast.loc?.start?.line,
|
|
100
|
+
message: `metadata.identifier (${metadata.get('identifier')}) in ${filename}${location} is mismatched (${name}). This is an internal error.`,
|
|
101
|
+
});
|
|
89
102
|
}
|
|
90
103
|
const descriptionNode = propvalue.properties.find((x) => x.key.name === 'description')?.value;
|
|
91
104
|
const description = descriptionNode ? descriptionNode.value : '';
|
|
@@ -120,7 +133,7 @@ function createAgentMetadataNode(id, name, rel, version, ast, callargexp, _filen
|
|
|
120
133
|
function camelToKebab(str) {
|
|
121
134
|
return str
|
|
122
135
|
.replace(/([a-z0-9])([A-Z])/g, '$1-$2')
|
|
123
|
-
.replace(/([A-Z])([A-Z][a-z])/g, '$1-$2')
|
|
136
|
+
.replace(/([A-Z]+)([A-Z][a-z])/g, '$1-$2')
|
|
124
137
|
.toLowerCase();
|
|
125
138
|
}
|
|
126
139
|
function setLiteralValue(literal, value) {
|
|
@@ -229,6 +242,7 @@ function augmentEvalMetadataNode(projectId, agentId, id, name, rel, version, _as
|
|
|
229
242
|
}
|
|
230
243
|
}
|
|
231
244
|
}
|
|
245
|
+
const DuplicateNameError = StructuredError('DuplicateNameError')();
|
|
232
246
|
export function parseEvalMetadata(rootDir, filename, contents, projectId, deploymentId, agentId) {
|
|
233
247
|
const logLevel = (process.env.AGENTUITY_LOG_LEVEL || 'info');
|
|
234
248
|
const logger = createLogger(logLevel);
|
|
@@ -302,7 +316,11 @@ export function parseEvalMetadata(rootDir, filename, contents, projectId, deploy
|
|
|
302
316
|
finalName = camelToKebab(variableName);
|
|
303
317
|
}
|
|
304
318
|
else {
|
|
305
|
-
throw new
|
|
319
|
+
throw new MetadataError({
|
|
320
|
+
filename,
|
|
321
|
+
line: body.loc?.start?.line,
|
|
322
|
+
message: 'Eval is missing a name. Please provide metadata.name or use a named export.',
|
|
323
|
+
});
|
|
306
324
|
}
|
|
307
325
|
logger.trace(`Found eval: ${finalName}${evalDescription ? ` - ${evalDescription}` : ''}`);
|
|
308
326
|
const evalId = getEvalId(projectId, deploymentId, rel, finalName, version);
|
|
@@ -352,13 +370,18 @@ export function parseEvalMetadata(rootDir, filename, contents, projectId, deploy
|
|
|
352
370
|
}
|
|
353
371
|
}
|
|
354
372
|
if (duplicates.length > 0) {
|
|
355
|
-
throw new
|
|
356
|
-
|
|
373
|
+
throw new DuplicateNameError({
|
|
374
|
+
filename,
|
|
375
|
+
message: `Duplicate eval names found in ${rel}: ${duplicates.join(', ')}. ` +
|
|
376
|
+
'Eval names must be unique within the same file to prevent ID collisions.',
|
|
377
|
+
});
|
|
357
378
|
}
|
|
358
379
|
const newsource = generate(ast);
|
|
359
380
|
logger.trace(`Parsed ${evals.length} eval(s) from ${filename}`);
|
|
360
381
|
return [newsource, evals];
|
|
361
382
|
}
|
|
383
|
+
const InvalidExportError = StructuredError('InvalidExportError')();
|
|
384
|
+
const InvalidCreateAgentError = StructuredError('InvalidCreateAgentError')();
|
|
362
385
|
export async function parseAgentMetadata(rootDir, filename, contents, projectId, deploymentId) {
|
|
363
386
|
const ast = acornLoose.parse(contents, { ecmaVersion: 'latest', sourceType: 'module' });
|
|
364
387
|
let exportName;
|
|
@@ -395,7 +418,10 @@ export async function parseAgentMetadata(rootDir, filename, contents, projectId,
|
|
|
395
418
|
}
|
|
396
419
|
}
|
|
397
420
|
if (!result && !exportName) {
|
|
398
|
-
throw new
|
|
421
|
+
throw new InvalidExportError({
|
|
422
|
+
filename,
|
|
423
|
+
message: `could not find default export for ${filename} using ${rootDir}`,
|
|
424
|
+
});
|
|
399
425
|
}
|
|
400
426
|
if (!result) {
|
|
401
427
|
for (const body of ast.body) {
|
|
@@ -430,7 +456,10 @@ export async function parseAgentMetadata(rootDir, filename, contents, projectId,
|
|
|
430
456
|
}
|
|
431
457
|
}
|
|
432
458
|
if (!result) {
|
|
433
|
-
throw new
|
|
459
|
+
throw new InvalidCreateAgentError({
|
|
460
|
+
filename,
|
|
461
|
+
message: `error parsing: ${filename}. could not find an proper createAgent defined in this file`,
|
|
462
|
+
});
|
|
434
463
|
}
|
|
435
464
|
// Parse evals from eval.ts file in the same directory
|
|
436
465
|
const logLevel = (process.env.AGENTUITY_LOG_LEVEL || 'info');
|
|
@@ -459,6 +488,8 @@ export async function parseAgentMetadata(rootDir, filename, contents, projectId,
|
|
|
459
488
|
}
|
|
460
489
|
return result;
|
|
461
490
|
}
|
|
491
|
+
const InvalidCreateRouterError = StructuredError('InvalidCreateRouterError')();
|
|
492
|
+
const InvalidRouterConfigError = StructuredError('InvalidRouterConfigError')();
|
|
462
493
|
export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
463
494
|
const contents = await Bun.file(filename).text();
|
|
464
495
|
const version = hash(contents);
|
|
@@ -473,7 +504,10 @@ export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
|
473
504
|
}
|
|
474
505
|
}
|
|
475
506
|
if (!exportName) {
|
|
476
|
-
throw new
|
|
507
|
+
throw new InvalidExportError({
|
|
508
|
+
filename,
|
|
509
|
+
message: `could not find default export for ${filename} using ${rootDir}`,
|
|
510
|
+
});
|
|
477
511
|
}
|
|
478
512
|
for (const body of ast.body) {
|
|
479
513
|
if (body.type === 'VariableDeclaration') {
|
|
@@ -494,7 +528,10 @@ export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
|
494
528
|
}
|
|
495
529
|
}
|
|
496
530
|
if (!variableName) {
|
|
497
|
-
throw new
|
|
531
|
+
throw new InvalidCreateRouterError({
|
|
532
|
+
filename,
|
|
533
|
+
message: `error parsing: ${filename}. could not find an proper createRouter defined in this file`,
|
|
534
|
+
});
|
|
498
535
|
}
|
|
499
536
|
const rel = relative(rootDir, filename);
|
|
500
537
|
const dir = dirname(filename);
|
|
@@ -541,7 +578,11 @@ export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
|
541
578
|
suffix = action.value;
|
|
542
579
|
}
|
|
543
580
|
else {
|
|
544
|
-
throw new
|
|
581
|
+
throw new InvalidRouterConfigError({
|
|
582
|
+
filename,
|
|
583
|
+
line: body.start,
|
|
584
|
+
message: `unsupported HTTP method ${method} in ${filename} at line ${body.start}`,
|
|
585
|
+
});
|
|
545
586
|
}
|
|
546
587
|
break;
|
|
547
588
|
}
|
|
@@ -601,7 +642,11 @@ export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
|
601
642
|
break;
|
|
602
643
|
}
|
|
603
644
|
default: {
|
|
604
|
-
throw new
|
|
645
|
+
throw new InvalidRouterConfigError({
|
|
646
|
+
filename,
|
|
647
|
+
line: body.start,
|
|
648
|
+
message: `unsupported router method ${method} in ${filename} at line ${body.start}`,
|
|
649
|
+
});
|
|
605
650
|
}
|
|
606
651
|
}
|
|
607
652
|
const thepath = `${routePrefix}/${routeName}/${suffix}`
|
|
@@ -623,8 +668,13 @@ export async function parseRoute(rootDir, filename, projectId, deploymentId) {
|
|
|
623
668
|
}
|
|
624
669
|
}
|
|
625
670
|
catch (error) {
|
|
626
|
-
|
|
627
|
-
|
|
671
|
+
if (error instanceof InvalidRouterConfigError) {
|
|
672
|
+
throw error;
|
|
673
|
+
}
|
|
674
|
+
throw new InvalidRouterConfigError({
|
|
675
|
+
filename,
|
|
676
|
+
cause: error,
|
|
677
|
+
});
|
|
628
678
|
}
|
|
629
679
|
return routes;
|
|
630
680
|
}
|
|
@@ -700,6 +750,383 @@ export function checkRouteConflicts(content, workbenchEndpoint) {
|
|
|
700
750
|
return false;
|
|
701
751
|
}
|
|
702
752
|
}
|
|
753
|
+
/**
|
|
754
|
+
* Extract AppState type from setup() return value in createApp call
|
|
755
|
+
*
|
|
756
|
+
* @param content - The TypeScript source code from app.ts
|
|
757
|
+
* @returns Type definition string or null if no setup found
|
|
758
|
+
*/
|
|
759
|
+
export function extractAppStateType(content) {
|
|
760
|
+
try {
|
|
761
|
+
const sourceFile = ts.createSourceFile('app.ts', content, ts.ScriptTarget.Latest, true);
|
|
762
|
+
let appStateType = null;
|
|
763
|
+
let foundCreateApp = false;
|
|
764
|
+
let foundSetup = false;
|
|
765
|
+
function visitNode(node) {
|
|
766
|
+
// Look for createApp call expression (can be on await expression)
|
|
767
|
+
let callExpr;
|
|
768
|
+
if (ts.isCallExpression(node) && ts.isIdentifier(node.expression)) {
|
|
769
|
+
if (node.expression.text === 'createApp') {
|
|
770
|
+
foundCreateApp = true;
|
|
771
|
+
callExpr = node;
|
|
772
|
+
}
|
|
773
|
+
}
|
|
774
|
+
else if (ts.isAwaitExpression(node) && ts.isCallExpression(node.expression)) {
|
|
775
|
+
const call = node.expression;
|
|
776
|
+
if (ts.isIdentifier(call.expression) && call.expression.text === 'createApp') {
|
|
777
|
+
foundCreateApp = true;
|
|
778
|
+
callExpr = call;
|
|
779
|
+
}
|
|
780
|
+
}
|
|
781
|
+
if (callExpr) {
|
|
782
|
+
// Check if it has a config object argument
|
|
783
|
+
if (callExpr.arguments.length > 0) {
|
|
784
|
+
const configArg = callExpr.arguments[0];
|
|
785
|
+
if (ts.isObjectLiteralExpression(configArg)) {
|
|
786
|
+
// Find setup property
|
|
787
|
+
for (const prop of configArg.properties) {
|
|
788
|
+
if (ts.isPropertyAssignment(prop) &&
|
|
789
|
+
ts.isIdentifier(prop.name) &&
|
|
790
|
+
prop.name.text === 'setup') {
|
|
791
|
+
foundSetup = true;
|
|
792
|
+
// Found setup function - extract return type
|
|
793
|
+
const setupFunc = prop.initializer;
|
|
794
|
+
if (ts.isFunctionExpression(setupFunc) || ts.isArrowFunction(setupFunc)) {
|
|
795
|
+
// Find return statement
|
|
796
|
+
const returnObj = findReturnObject(setupFunc);
|
|
797
|
+
if (returnObj) {
|
|
798
|
+
appStateType = objectLiteralToTypeDefinition(returnObj, sourceFile);
|
|
799
|
+
}
|
|
800
|
+
else {
|
|
801
|
+
logger.debug('No return object found in setup function');
|
|
802
|
+
}
|
|
803
|
+
}
|
|
804
|
+
else {
|
|
805
|
+
logger.debug(`Setup is not a function expression or arrow function, it's: ${ts.SyntaxKind[setupFunc.kind]}`);
|
|
806
|
+
}
|
|
807
|
+
}
|
|
808
|
+
}
|
|
809
|
+
}
|
|
810
|
+
}
|
|
811
|
+
}
|
|
812
|
+
ts.forEachChild(node, visitNode);
|
|
813
|
+
}
|
|
814
|
+
function findReturnObject(func) {
|
|
815
|
+
let returnObject = null;
|
|
816
|
+
function visitFuncNode(node) {
|
|
817
|
+
if (ts.isReturnStatement(node) && node.expression) {
|
|
818
|
+
// Handle direct object literal
|
|
819
|
+
if (ts.isObjectLiteralExpression(node.expression)) {
|
|
820
|
+
returnObject = node.expression;
|
|
821
|
+
}
|
|
822
|
+
// Handle variable reference (const state = {...}; return state;)
|
|
823
|
+
else if (ts.isIdentifier(node.expression)) {
|
|
824
|
+
// Try to find the variable declaration
|
|
825
|
+
const varName = node.expression.text;
|
|
826
|
+
// Walk back through the function to find the declaration
|
|
827
|
+
findVariableDeclaration(func.body, varName);
|
|
828
|
+
}
|
|
829
|
+
}
|
|
830
|
+
ts.forEachChild(node, visitFuncNode);
|
|
831
|
+
}
|
|
832
|
+
function findVariableDeclaration(body, varName) {
|
|
833
|
+
function visitForVar(node) {
|
|
834
|
+
if (ts.isVariableStatement(node)) {
|
|
835
|
+
for (const decl of node.declarationList.declarations) {
|
|
836
|
+
if (ts.isIdentifier(decl.name) && decl.name.text === varName) {
|
|
837
|
+
if (decl.initializer && ts.isObjectLiteralExpression(decl.initializer)) {
|
|
838
|
+
returnObject = decl.initializer;
|
|
839
|
+
}
|
|
840
|
+
}
|
|
841
|
+
}
|
|
842
|
+
}
|
|
843
|
+
ts.forEachChild(node, visitForVar);
|
|
844
|
+
}
|
|
845
|
+
visitForVar(body);
|
|
846
|
+
}
|
|
847
|
+
if (func.body) {
|
|
848
|
+
visitFuncNode(func.body);
|
|
849
|
+
}
|
|
850
|
+
return returnObject;
|
|
851
|
+
}
|
|
852
|
+
function objectLiteralToTypeDefinition(obj, sourceFile) {
|
|
853
|
+
const properties = [];
|
|
854
|
+
for (const prop of obj.properties) {
|
|
855
|
+
if (ts.isPropertyAssignment(prop)) {
|
|
856
|
+
const name = prop.name.getText(sourceFile);
|
|
857
|
+
const value = prop.initializer;
|
|
858
|
+
const typeStr = inferTypeFromValue(value, sourceFile);
|
|
859
|
+
properties.push(`\t${name}: ${typeStr};`);
|
|
860
|
+
}
|
|
861
|
+
else if (ts.isShorthandPropertyAssignment(prop)) {
|
|
862
|
+
const name = prop.name.getText(sourceFile);
|
|
863
|
+
properties.push(`\t${name}: unknown;`);
|
|
864
|
+
}
|
|
865
|
+
}
|
|
866
|
+
return `{\n${properties.join('\n')}\n}`;
|
|
867
|
+
}
|
|
868
|
+
function inferTypeFromValue(value, sourceFile) {
|
|
869
|
+
if (ts.isStringLiteral(value)) {
|
|
870
|
+
return 'string';
|
|
871
|
+
}
|
|
872
|
+
if (ts.isNumericLiteral(value)) {
|
|
873
|
+
return 'number';
|
|
874
|
+
}
|
|
875
|
+
if (value.kind === ts.SyntaxKind.TrueKeyword ||
|
|
876
|
+
value.kind === ts.SyntaxKind.FalseKeyword) {
|
|
877
|
+
return 'boolean';
|
|
878
|
+
}
|
|
879
|
+
if (ts.isNewExpression(value) && ts.isIdentifier(value.expression)) {
|
|
880
|
+
if (value.expression.text === 'Date') {
|
|
881
|
+
return 'Date';
|
|
882
|
+
}
|
|
883
|
+
}
|
|
884
|
+
if (ts.isObjectLiteralExpression(value)) {
|
|
885
|
+
return objectLiteralToTypeDefinition(value, sourceFile);
|
|
886
|
+
}
|
|
887
|
+
if (ts.isArrayLiteralExpression(value)) {
|
|
888
|
+
return 'unknown[]';
|
|
889
|
+
}
|
|
890
|
+
return 'unknown';
|
|
891
|
+
}
|
|
892
|
+
visitNode(sourceFile);
|
|
893
|
+
if (!foundCreateApp) {
|
|
894
|
+
logger.debug('Did not find createApp call in app.ts');
|
|
895
|
+
}
|
|
896
|
+
else if (!foundSetup) {
|
|
897
|
+
logger.debug('Found createApp but no setup property');
|
|
898
|
+
}
|
|
899
|
+
else if (!appStateType) {
|
|
900
|
+
logger.debug('Found createApp and setup but could not extract type');
|
|
901
|
+
}
|
|
902
|
+
return appStateType;
|
|
903
|
+
}
|
|
904
|
+
catch (error) {
|
|
905
|
+
logger.warn('AppState type extraction failed:', error);
|
|
906
|
+
return null;
|
|
907
|
+
}
|
|
908
|
+
}
|
|
909
|
+
/**
|
|
910
|
+
* Update tsconfig.json to add path mapping for @agentuity/runtime
|
|
911
|
+
*
|
|
912
|
+
* @param rootDir - Root directory of the project
|
|
913
|
+
* @param shouldAdd - If true, add the mapping; if false, remove it
|
|
914
|
+
*/
|
|
915
|
+
async function updateTsconfigPathMapping(rootDir, shouldAdd) {
|
|
916
|
+
const tsconfigPath = join(rootDir, 'tsconfig.json');
|
|
917
|
+
if (!(await Bun.file(tsconfigPath).exists())) {
|
|
918
|
+
logger.debug('No tsconfig.json found, skipping path mapping update');
|
|
919
|
+
return;
|
|
920
|
+
}
|
|
921
|
+
try {
|
|
922
|
+
const tsconfigContent = await Bun.file(tsconfigPath).text();
|
|
923
|
+
// Use JSON5 to parse tsconfig.json (handles comments in input)
|
|
924
|
+
const tsconfig = JSON5.parse(tsconfigContent);
|
|
925
|
+
const _before = JSON.stringify(tsconfig);
|
|
926
|
+
// Initialize compilerOptions and paths if they don't exist
|
|
927
|
+
if (!tsconfig.compilerOptions) {
|
|
928
|
+
tsconfig.compilerOptions = {};
|
|
929
|
+
}
|
|
930
|
+
if (!tsconfig.compilerOptions.paths) {
|
|
931
|
+
tsconfig.compilerOptions.paths = {};
|
|
932
|
+
}
|
|
933
|
+
if (shouldAdd) {
|
|
934
|
+
// Add or update the path mapping
|
|
935
|
+
tsconfig.compilerOptions.paths['@agentuity/runtime'] = [
|
|
936
|
+
'./.agentuity/.agentuity_runtime.ts',
|
|
937
|
+
];
|
|
938
|
+
// Ensure .agentuity_types.ts is included so module augmentation works
|
|
939
|
+
if (!tsconfig.include) {
|
|
940
|
+
tsconfig.include = [];
|
|
941
|
+
}
|
|
942
|
+
if (!tsconfig.include.includes('.agentuity/.agentuity_types.ts')) {
|
|
943
|
+
tsconfig.include.push('.agentuity/.agentuity_types.ts');
|
|
944
|
+
}
|
|
945
|
+
logger.debug('Added @agentuity/runtime path mapping to tsconfig.json');
|
|
946
|
+
}
|
|
947
|
+
else {
|
|
948
|
+
// Remove the path mapping if it exists
|
|
949
|
+
if (tsconfig.compilerOptions.paths['@agentuity/runtime']) {
|
|
950
|
+
delete tsconfig.compilerOptions.paths['@agentuity/runtime'];
|
|
951
|
+
logger.debug('Removed @agentuity/runtime path mapping from tsconfig.json');
|
|
952
|
+
}
|
|
953
|
+
// Clean up empty paths object
|
|
954
|
+
if (Object.keys(tsconfig.compilerOptions.paths).length === 0) {
|
|
955
|
+
delete tsconfig.compilerOptions.paths;
|
|
956
|
+
}
|
|
957
|
+
}
|
|
958
|
+
const _after = JSON.stringify(tsconfig);
|
|
959
|
+
if (_before === _after) {
|
|
960
|
+
return;
|
|
961
|
+
}
|
|
962
|
+
// Write back using standard JSON (TypeScript requires strict JSON format)
|
|
963
|
+
await Bun.write(tsconfigPath, JSON.stringify(tsconfig, null, '\t') + '\n');
|
|
964
|
+
}
|
|
965
|
+
catch (error) {
|
|
966
|
+
logger.warn('Failed to update tsconfig.json:', error);
|
|
967
|
+
}
|
|
968
|
+
}
|
|
969
|
+
const RuntimePackageNotFound = StructuredError('RuntimePackageNotFound');
|
|
970
|
+
/**
|
|
971
|
+
* Generate lifecycle type files (.agentuity/types.ts and .agentuity/.agentuity_runtime.ts)
|
|
972
|
+
*
|
|
973
|
+
* @param rootDir - Root directory of the project
|
|
974
|
+
* @param appFilePath - Path to app.ts file
|
|
975
|
+
* @returns true if files were generated, false if no setup found
|
|
976
|
+
*/
|
|
977
|
+
export async function generateLifecycleTypes(rootDir, outDir, appFilePath) {
|
|
978
|
+
const appContent = await Bun.file(appFilePath).text();
|
|
979
|
+
if (typeof appContent !== 'string') {
|
|
980
|
+
return false;
|
|
981
|
+
}
|
|
982
|
+
const appStateType = extractAppStateType(appContent);
|
|
983
|
+
if (!appStateType) {
|
|
984
|
+
logger.debug('No setup() function found in app.ts, skipping lifecycle type generation');
|
|
985
|
+
// Remove path mapping if no setup found
|
|
986
|
+
await updateTsconfigPathMapping(rootDir, false);
|
|
987
|
+
return false;
|
|
988
|
+
}
|
|
989
|
+
const agentuityDir = join(rootDir, '.agentuity');
|
|
990
|
+
// Ensure .agentuity directory exists
|
|
991
|
+
if (!existsSync(agentuityDir)) {
|
|
992
|
+
mkdirSync(agentuityDir, { recursive: true });
|
|
993
|
+
}
|
|
994
|
+
// First, determine the runtime package location
|
|
995
|
+
// Try multiple locations: app-level node_modules, then monorepo root
|
|
996
|
+
const appLevelPath = join(rootDir, 'node_modules', '@agentuity', 'runtime');
|
|
997
|
+
// From apps/testing/auth-app to monorepo root is 3 levels up (../../..)
|
|
998
|
+
const rootLevelPath = join(rootDir, '..', '..', '..', 'node_modules', '@agentuity', 'runtime');
|
|
999
|
+
let runtimePkgPath;
|
|
1000
|
+
if (existsSync(appLevelPath)) {
|
|
1001
|
+
runtimePkgPath = appLevelPath;
|
|
1002
|
+
logger.debug(`Found runtime package at app level: ${appLevelPath}`);
|
|
1003
|
+
}
|
|
1004
|
+
else if (existsSync(rootLevelPath)) {
|
|
1005
|
+
runtimePkgPath = rootLevelPath;
|
|
1006
|
+
logger.debug(`Found runtime package at root level: ${rootLevelPath}`);
|
|
1007
|
+
}
|
|
1008
|
+
else {
|
|
1009
|
+
throw new RuntimePackageNotFound({
|
|
1010
|
+
message: `@agentuity/runtime package not found in:\n` +
|
|
1011
|
+
` - ${appLevelPath}\n` +
|
|
1012
|
+
` - ${rootLevelPath}\n` +
|
|
1013
|
+
`Make sure dependencies are installed by running 'bun install' or 'npm install'`,
|
|
1014
|
+
});
|
|
1015
|
+
}
|
|
1016
|
+
let runtimeImportPath = null;
|
|
1017
|
+
// Calculate relative path from .agentuity/ to the package location
|
|
1018
|
+
// Don't resolve symlinks - we want to use the symlink path so it works in both
|
|
1019
|
+
// local dev (symlinked to packages/) and CI (actual node_modules)
|
|
1020
|
+
if (existsSync(runtimePkgPath)) {
|
|
1021
|
+
// Calculate relative path from .agentuity/ to node_modules package
|
|
1022
|
+
const relPath = relative(agentuityDir, runtimePkgPath);
|
|
1023
|
+
runtimeImportPath = relPath;
|
|
1024
|
+
logger.debug(`Using relative path to runtime package: ${relPath}`);
|
|
1025
|
+
}
|
|
1026
|
+
else {
|
|
1027
|
+
throw new RuntimePackageNotFound({
|
|
1028
|
+
message: `Failed to access @agentuity/runtime package at ${runtimePkgPath}\n` +
|
|
1029
|
+
`Make sure dependencies are installed`,
|
|
1030
|
+
});
|
|
1031
|
+
}
|
|
1032
|
+
if (!runtimeImportPath) {
|
|
1033
|
+
throw new RuntimePackageNotFound({
|
|
1034
|
+
message: `Failed to determine import path for @agentuity/runtime`,
|
|
1035
|
+
});
|
|
1036
|
+
}
|
|
1037
|
+
// Now generate .agentuity_types.ts
|
|
1038
|
+
// NOTE: We can ONLY augment the package name, not relative paths
|
|
1039
|
+
// TypeScript resolves @agentuity/runtime through path mapping -> wrapper -> actual package
|
|
1040
|
+
const typesContent = `// AUTO-GENERATED from app.ts setup() return type
|
|
1041
|
+
// This file is auto-generated by the build tool - do not edit manually
|
|
1042
|
+
|
|
1043
|
+
/**
|
|
1044
|
+
* Application state type inferred from your createApp setup function.
|
|
1045
|
+
* This type is automatically generated and available throughout your app via ctx.app.
|
|
1046
|
+
*
|
|
1047
|
+
* @example
|
|
1048
|
+
* \`\`\`typescript
|
|
1049
|
+
* // In your agents:
|
|
1050
|
+
* const agent = createAgent({
|
|
1051
|
+
* handler: async (ctx, input) => {
|
|
1052
|
+
* // ctx.app is strongly typed as GeneratedAppState
|
|
1053
|
+
* const value = ctx.app; // All properties from your setup return value
|
|
1054
|
+
* return 'result';
|
|
1055
|
+
* }
|
|
1056
|
+
* });
|
|
1057
|
+
* \`\`\`
|
|
1058
|
+
*/
|
|
1059
|
+
export type GeneratedAppState = ${appStateType};
|
|
1060
|
+
|
|
1061
|
+
// Augment the @agentuity/runtime module with AppState
|
|
1062
|
+
// This will be picked up when imported through the wrapper
|
|
1063
|
+
declare module '@agentuity/runtime' {
|
|
1064
|
+
interface AppState extends GeneratedAppState {}
|
|
1065
|
+
}
|
|
1066
|
+
`;
|
|
1067
|
+
const typesPath = join(outDir, '.agentuity_types.ts');
|
|
1068
|
+
await Bun.write(typesPath, typesContent);
|
|
1069
|
+
logger.debug(`Generated lifecycle types: ${typesPath}`);
|
|
1070
|
+
const wrapperContent = `// AUTO-GENERATED runtime wrapper
|
|
1071
|
+
// This file is auto-generated by the build tool - do not edit manually
|
|
1072
|
+
|
|
1073
|
+
// Import augmentations file (NOT type-only) to trigger module augmentation
|
|
1074
|
+
import type { GeneratedAppState } from './.agentuity_types';
|
|
1075
|
+
import './.agentuity_types';
|
|
1076
|
+
|
|
1077
|
+
// Import from actual package location
|
|
1078
|
+
import { createRouter as baseCreateRouter, type Env } from '${runtimeImportPath}/src/index';
|
|
1079
|
+
import type { Hono } from 'hono';
|
|
1080
|
+
|
|
1081
|
+
// Type aliases to avoid repeating the generic parameter
|
|
1082
|
+
type AppEnv = Env<GeneratedAppState>;
|
|
1083
|
+
type AppRouter = Hono<AppEnv>;
|
|
1084
|
+
|
|
1085
|
+
/**
|
|
1086
|
+
* Creates a Hono router with extended methods for Agentuity-specific routing patterns.
|
|
1087
|
+
*
|
|
1088
|
+
* In addition to standard HTTP methods (get, post, put, delete, patch), the router includes:
|
|
1089
|
+
* - **stream()** - Stream responses with ReadableStream
|
|
1090
|
+
* - **websocket()** - WebSocket connections
|
|
1091
|
+
* - **sse()** - Server-Sent Events
|
|
1092
|
+
* - **email()** - Email handler routing
|
|
1093
|
+
* - **sms()** - SMS handler routing
|
|
1094
|
+
* - **cron()** - Scheduled task routing
|
|
1095
|
+
*
|
|
1096
|
+
* @returns Extended Hono router with custom methods and app state typing
|
|
1097
|
+
*
|
|
1098
|
+
* @example
|
|
1099
|
+
* \`\`\`typescript
|
|
1100
|
+
* const router = createRouter();
|
|
1101
|
+
*
|
|
1102
|
+
* // Standard HTTP routes
|
|
1103
|
+
* router.get('/hello', (c) => c.text('Hello!'));
|
|
1104
|
+
* router.post('/data', async (c) => {
|
|
1105
|
+
* const body = await c.req.json();
|
|
1106
|
+
* return c.json({ received: body });
|
|
1107
|
+
* });
|
|
1108
|
+
*
|
|
1109
|
+
* // Access app state (strongly typed!)
|
|
1110
|
+
* router.get('/db', (c) => {
|
|
1111
|
+
* const db = c.var.app; // Your app state from createApp setup
|
|
1112
|
+
* return c.json({ connected: true });
|
|
1113
|
+
* });
|
|
1114
|
+
* \`\`\`
|
|
1115
|
+
*/
|
|
1116
|
+
export function createRouter(): AppRouter {
|
|
1117
|
+
return baseCreateRouter() as any;
|
|
1118
|
+
}
|
|
1119
|
+
|
|
1120
|
+
// Re-export everything else
|
|
1121
|
+
export * from '${runtimeImportPath}/src/index';
|
|
1122
|
+
`;
|
|
1123
|
+
const wrapperPath = join(outDir, '.agentuity_runtime.ts');
|
|
1124
|
+
await Bun.write(wrapperPath, wrapperContent);
|
|
1125
|
+
logger.debug(`Generated lifecycle wrapper: ${wrapperPath}`);
|
|
1126
|
+
// Update tsconfig.json with path mapping
|
|
1127
|
+
await updateTsconfigPathMapping(rootDir, true);
|
|
1128
|
+
return true;
|
|
1129
|
+
}
|
|
703
1130
|
/**
|
|
704
1131
|
* Analyze workbench usage and extract configuration
|
|
705
1132
|
*
|
|
@@ -784,4 +1211,89 @@ function parseConfigObject(node) {
|
|
|
784
1211
|
}
|
|
785
1212
|
return config;
|
|
786
1213
|
}
|
|
1214
|
+
/**
|
|
1215
|
+
* Find the end position of createApp call statement in the source code
|
|
1216
|
+
* Uses AST parsing to reliably find the complete statement including await/const assignment
|
|
1217
|
+
*
|
|
1218
|
+
* @param content - The source code content
|
|
1219
|
+
* @returns The character position after the createApp statement, or -1 if not found
|
|
1220
|
+
*/
|
|
1221
|
+
export function findCreateAppEndPosition(content) {
|
|
1222
|
+
try {
|
|
1223
|
+
const ast = acornLoose.parse(content, {
|
|
1224
|
+
ecmaVersion: 'latest',
|
|
1225
|
+
sourceType: 'module',
|
|
1226
|
+
});
|
|
1227
|
+
// Walk through all top-level statements
|
|
1228
|
+
for (const node of ast.body) {
|
|
1229
|
+
let targetNode;
|
|
1230
|
+
// Check for: const app = await createApp(...)
|
|
1231
|
+
if (node.type === 'VariableDeclaration') {
|
|
1232
|
+
const varDecl = node;
|
|
1233
|
+
for (const declarator of varDecl.declarations) {
|
|
1234
|
+
if (declarator.init) {
|
|
1235
|
+
// Handle await createApp(...)
|
|
1236
|
+
if (declarator.init.type === 'AwaitExpression') {
|
|
1237
|
+
const awaitExpr = declarator.init;
|
|
1238
|
+
if (awaitExpr.argument?.type === 'CallExpression' &&
|
|
1239
|
+
isCreateAppCall(awaitExpr.argument)) {
|
|
1240
|
+
targetNode = node;
|
|
1241
|
+
break;
|
|
1242
|
+
}
|
|
1243
|
+
}
|
|
1244
|
+
// Handle createApp(...) without await
|
|
1245
|
+
else if (declarator.init.type === 'CallExpression') {
|
|
1246
|
+
if (isCreateAppCall(declarator.init)) {
|
|
1247
|
+
targetNode = node;
|
|
1248
|
+
break;
|
|
1249
|
+
}
|
|
1250
|
+
}
|
|
1251
|
+
}
|
|
1252
|
+
}
|
|
1253
|
+
}
|
|
1254
|
+
// Check for: await createApp(...)
|
|
1255
|
+
else if (node.type === 'ExpressionStatement') {
|
|
1256
|
+
const exprStmt = node;
|
|
1257
|
+
if (exprStmt.expression.type === 'AwaitExpression') {
|
|
1258
|
+
const awaitExpr = exprStmt.expression;
|
|
1259
|
+
if (awaitExpr.argument?.type === 'CallExpression' &&
|
|
1260
|
+
isCreateAppCall(awaitExpr.argument)) {
|
|
1261
|
+
targetNode = node;
|
|
1262
|
+
}
|
|
1263
|
+
}
|
|
1264
|
+
else if (exprStmt.expression.type === 'CallExpression') {
|
|
1265
|
+
if (isCreateAppCall(exprStmt.expression)) {
|
|
1266
|
+
targetNode = node;
|
|
1267
|
+
}
|
|
1268
|
+
}
|
|
1269
|
+
}
|
|
1270
|
+
if (targetNode && targetNode.end !== undefined) {
|
|
1271
|
+
// Find the semicolon after the statement (if it exists)
|
|
1272
|
+
const afterStmt = content.slice(targetNode.end);
|
|
1273
|
+
const semiMatch = afterStmt.match(/^\s*;/);
|
|
1274
|
+
if (semiMatch) {
|
|
1275
|
+
return targetNode.end + semiMatch[0].length;
|
|
1276
|
+
}
|
|
1277
|
+
// No semicolon, return end of statement
|
|
1278
|
+
return targetNode.end;
|
|
1279
|
+
}
|
|
1280
|
+
}
|
|
1281
|
+
return -1;
|
|
1282
|
+
}
|
|
1283
|
+
catch (error) {
|
|
1284
|
+
logger.warn('Failed to parse AST for createApp detection:', error);
|
|
1285
|
+
return -1;
|
|
1286
|
+
}
|
|
1287
|
+
}
|
|
1288
|
+
/**
|
|
1289
|
+
* Check if a CallExpression is a call to createApp
|
|
1290
|
+
*/
|
|
1291
|
+
function isCreateAppCall(node) {
|
|
1292
|
+
const callee = node.callee;
|
|
1293
|
+
if (callee.type === 'Identifier') {
|
|
1294
|
+
const id = callee;
|
|
1295
|
+
return id.name === 'createApp';
|
|
1296
|
+
}
|
|
1297
|
+
return false;
|
|
1298
|
+
}
|
|
787
1299
|
//# sourceMappingURL=ast.js.map
|