devchain-cli 0.1.0
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/LICENSE +53 -0
- package/README.md +74 -0
- package/dist/cli.js +782 -0
- package/dist/drizzle/0000_flippant_the_spike.sql +220 -0
- package/dist/drizzle/0001_shiny_snowbird.sql +7 -0
- package/dist/drizzle/0002_high_zemo.sql +19 -0
- package/dist/drizzle/0003_noisy_scarecrow.sql +21 -0
- package/dist/drizzle/0004_mcp_metadata.sql +5 -0
- package/dist/drizzle/0005_agent_profile_instructions.sql +3 -0
- package/dist/drizzle/0006_wakeful_marvex.sql +15 -0
- package/dist/drizzle/0007_agent_profile_options.sql +7 -0
- package/dist/drizzle/0008_event_logs.sql +31 -0
- package/dist/drizzle/0009_chat_tables.sql +42 -0
- package/dist/drizzle/0010_amazing_the_initiative.sql +11 -0
- package/dist/drizzle/0011_curved_payback.sql +16 -0
- package/dist/drizzle/0012_terminal_activity.sql +8 -0
- package/dist/drizzle/0013_chat_activities.sql +18 -0
- package/dist/drizzle/0014_chat_activities_start_msg_nullable.sql +5 -0
- package/dist/drizzle/0015_projects_is_template.sql +4 -0
- package/dist/drizzle/0016_agent_profiles_project_scoped.sql +4 -0
- package/dist/drizzle/meta/0000_snapshot.json +1388 -0
- package/dist/drizzle/meta/0001_snapshot.json +1434 -0
- package/dist/drizzle/meta/0002_snapshot.json +1434 -0
- package/dist/drizzle/meta/0003_snapshot.json +1583 -0
- package/dist/drizzle/meta/0004_snapshot.json +1605 -0
- package/dist/drizzle/meta/0005_snapshot.json +1612 -0
- package/dist/drizzle/meta/0006_snapshot.json +1742 -0
- package/dist/drizzle/meta/0007_snapshot.json +1742 -0
- package/dist/drizzle/meta/0008_snapshot.json +1897 -0
- package/dist/drizzle/meta/0009_snapshot.json +2202 -0
- package/dist/drizzle/meta/0010_snapshot.json +2283 -0
- package/dist/drizzle/meta/0011_snapshot.json +2407 -0
- package/dist/drizzle/meta/_journal.json +125 -0
- package/dist/lib/interactive-cli.js +279 -0
- package/dist/server/app.module.d.ts +4 -0
- package/dist/server/app.module.js +64 -0
- package/dist/server/app.module.js.map +1 -0
- package/dist/server/common/config/env.config.d.ts +23 -0
- package/dist/server/common/config/env.config.js +60 -0
- package/dist/server/common/config/env.config.js.map +1 -0
- package/dist/server/common/config/feature-flags.d.ts +5 -0
- package/dist/server/common/config/feature-flags.js +8 -0
- package/dist/server/common/config/feature-flags.js.map +1 -0
- package/dist/server/common/errors/error-types.d.ts +30 -0
- package/dist/server/common/errors/error-types.js +63 -0
- package/dist/server/common/errors/error-types.js.map +1 -0
- package/dist/server/common/filters/http-exception.filter.d.ts +4 -0
- package/dist/server/common/filters/http-exception.filter.js +72 -0
- package/dist/server/common/filters/http-exception.filter.js.map +1 -0
- package/dist/server/common/filters/ws-exception.filter.d.ts +5 -0
- package/dist/server/common/filters/ws-exception.filter.js +102 -0
- package/dist/server/common/filters/ws-exception.filter.js.map +1 -0
- package/dist/server/common/logging/logger.d.ts +3 -0
- package/dist/server/common/logging/logger.js +29 -0
- package/dist/server/common/logging/logger.js.map +1 -0
- package/dist/server/common/middleware/request-id.middleware.d.ts +12 -0
- package/dist/server/common/middleware/request-id.middleware.js +24 -0
- package/dist/server/common/middleware/request-id.middleware.js.map +1 -0
- package/dist/server/main.d.ts +1 -0
- package/dist/server/main.js +94 -0
- package/dist/server/main.js.map +1 -0
- package/dist/server/modules/agents/agents.module.d.ts +2 -0
- package/dist/server/modules/agents/agents.module.js +22 -0
- package/dist/server/modules/agents/agents.module.js.map +1 -0
- package/dist/server/modules/agents/controllers/agents.controller.d.ts +12 -0
- package/dist/server/modules/agents/controllers/agents.controller.js +115 -0
- package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -0
- package/dist/server/modules/chat/chat.module.d.ts +2 -0
- package/dist/server/modules/chat/chat.module.js +28 -0
- package/dist/server/modules/chat/chat.module.js.map +1 -0
- package/dist/server/modules/chat/controllers/chat-settings.controller.d.ts +8 -0
- package/dist/server/modules/chat/controllers/chat-settings.controller.js +66 -0
- package/dist/server/modules/chat/controllers/chat-settings.controller.js.map +1 -0
- package/dist/server/modules/chat/controllers/chat.controller.d.ts +15 -0
- package/dist/server/modules/chat/controllers/chat.controller.js +152 -0
- package/dist/server/modules/chat/controllers/chat.controller.js.map +1 -0
- package/dist/server/modules/chat/dtos/chat-settings.dto.d.ts +31 -0
- package/dist/server/modules/chat/dtos/chat-settings.dto.js +17 -0
- package/dist/server/modules/chat/dtos/chat-settings.dto.js.map +1 -0
- package/dist/server/modules/chat/dtos/chat.dto.d.ts +309 -0
- package/dist/server/modules/chat/dtos/chat.dto.js +80 -0
- package/dist/server/modules/chat/dtos/chat.dto.js.map +1 -0
- package/dist/server/modules/chat/services/chat-settings.service.d.ts +12 -0
- package/dist/server/modules/chat/services/chat-settings.service.js +120 -0
- package/dist/server/modules/chat/services/chat-settings.service.js.map +1 -0
- package/dist/server/modules/chat/services/chat.service.d.ts +45 -0
- package/dist/server/modules/chat/services/chat.service.js +730 -0
- package/dist/server/modules/chat/services/chat.service.js.map +1 -0
- package/dist/server/modules/chat/services/invite-template.util.d.ts +17 -0
- package/dist/server/modules/chat/services/invite-template.util.js +70 -0
- package/dist/server/modules/chat/services/invite-template.util.js.map +1 -0
- package/dist/server/modules/core/controllers/health.controller.d.ts +7 -0
- package/dist/server/modules/core/controllers/health.controller.js +39 -0
- package/dist/server/modules/core/controllers/health.controller.js.map +1 -0
- package/dist/server/modules/core/controllers/preflight.controller.d.ts +10 -0
- package/dist/server/modules/core/controllers/preflight.controller.js +58 -0
- package/dist/server/modules/core/controllers/preflight.controller.js.map +1 -0
- package/dist/server/modules/core/core.module.d.ts +2 -0
- package/dist/server/modules/core/core.module.js +27 -0
- package/dist/server/modules/core/core.module.js.map +1 -0
- package/dist/server/modules/core/services/preflight.service.d.ts +44 -0
- package/dist/server/modules/core/services/preflight.service.js +400 -0
- package/dist/server/modules/core/services/preflight.service.js.map +1 -0
- package/dist/server/modules/documents/controllers/documents.controller.d.ts +12 -0
- package/dist/server/modules/documents/controllers/documents.controller.js +173 -0
- package/dist/server/modules/documents/controllers/documents.controller.js.map +1 -0
- package/dist/server/modules/documents/documents.module.d.ts +2 -0
- package/dist/server/modules/documents/documents.module.js +22 -0
- package/dist/server/modules/documents/documents.module.js.map +1 -0
- package/dist/server/modules/epics/controllers/epic-comments.controller.d.ts +10 -0
- package/dist/server/modules/epics/controllers/epic-comments.controller.js +94 -0
- package/dist/server/modules/epics/controllers/epic-comments.controller.js.map +1 -0
- package/dist/server/modules/epics/controllers/epics.controller.d.ts +16 -0
- package/dist/server/modules/epics/controllers/epics.controller.js +201 -0
- package/dist/server/modules/epics/controllers/epics.controller.js.map +1 -0
- package/dist/server/modules/epics/epics.module.d.ts +2 -0
- package/dist/server/modules/epics/epics.module.js +28 -0
- package/dist/server/modules/epics/epics.module.js.map +1 -0
- package/dist/server/modules/epics/services/epics.service.d.ts +34 -0
- package/dist/server/modules/epics/services/epics.service.js +251 -0
- package/dist/server/modules/epics/services/epics.service.js.map +1 -0
- package/dist/server/modules/events/catalog/epic.assigned.d.ts +36 -0
- package/dist/server/modules/events/catalog/epic.assigned.js +19 -0
- package/dist/server/modules/events/catalog/epic.assigned.js.map +1 -0
- package/dist/server/modules/events/catalog/index.d.ts +71 -0
- package/dist/server/modules/events/catalog/index.js +15 -0
- package/dist/server/modules/events/catalog/index.js.map +1 -0
- package/dist/server/modules/events/catalog/session.crashed.d.ts +15 -0
- package/dist/server/modules/events/catalog/session.crashed.js +12 -0
- package/dist/server/modules/events/catalog/session.crashed.js.map +1 -0
- package/dist/server/modules/events/catalog/session.started.d.ts +21 -0
- package/dist/server/modules/events/catalog/session.started.js +14 -0
- package/dist/server/modules/events/catalog/session.started.js.map +1 -0
- package/dist/server/modules/events/catalog/session.stopped.d.ts +12 -0
- package/dist/server/modules/events/catalog/session.stopped.js +11 -0
- package/dist/server/modules/events/catalog/session.stopped.js.map +1 -0
- package/dist/server/modules/events/controllers/event-log.controller.d.ts +7 -0
- package/dist/server/modules/events/controllers/event-log.controller.js +75 -0
- package/dist/server/modules/events/controllers/event-log.controller.js.map +1 -0
- package/dist/server/modules/events/dtos/event-log.dto.d.ts +33 -0
- package/dist/server/modules/events/dtos/event-log.dto.js +3 -0
- package/dist/server/modules/events/dtos/event-log.dto.js.map +1 -0
- package/dist/server/modules/events/events.module.d.ts +2 -0
- package/dist/server/modules/events/events.module.js +45 -0
- package/dist/server/modules/events/events.module.js.map +1 -0
- package/dist/server/modules/events/index.d.ts +6 -0
- package/dist/server/modules/events/index.js +23 -0
- package/dist/server/modules/events/index.js.map +1 -0
- package/dist/server/modules/events/services/event-log.service.d.ts +38 -0
- package/dist/server/modules/events/services/event-log.service.js +272 -0
- package/dist/server/modules/events/services/event-log.service.js.map +1 -0
- package/dist/server/modules/events/services/events-stream.service.d.ts +23 -0
- package/dist/server/modules/events/services/events-stream.service.js +45 -0
- package/dist/server/modules/events/services/events-stream.service.js.map +1 -0
- package/dist/server/modules/events/services/events.service.d.ts +14 -0
- package/dist/server/modules/events/services/events.service.js +65 -0
- package/dist/server/modules/events/services/events.service.js.map +1 -0
- package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.d.ts +20 -0
- package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js +47 -0
- package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js.map +1 -0
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.d.ts +24 -0
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js +81 -0
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js.map +1 -0
- package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.d.ts +25 -0
- package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js +223 -0
- package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/events/subscribers/index.d.ts +2 -0
- package/dist/server/modules/events/subscribers/index.js +12 -0
- package/dist/server/modules/events/subscribers/index.js.map +1 -0
- package/dist/server/modules/fs/fs.controller.d.ts +18 -0
- package/dist/server/modules/fs/fs.controller.js +56 -0
- package/dist/server/modules/fs/fs.controller.js.map +1 -0
- package/dist/server/modules/fs/fs.module.d.ts +2 -0
- package/dist/server/modules/fs/fs.module.js +20 -0
- package/dist/server/modules/fs/fs.module.js.map +1 -0
- package/dist/server/modules/mcp/constants.d.ts +9 -0
- package/dist/server/modules/mcp/constants.js +38 -0
- package/dist/server/modules/mcp/constants.js.map +1 -0
- package/dist/server/modules/mcp/controllers/mcp-http.controller.d.ts +16 -0
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js +790 -0
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js.map +1 -0
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.d.ts +12 -0
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js +676 -0
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js.map +1 -0
- package/dist/server/modules/mcp/controllers/mcp-test.controller.d.ts +50 -0
- package/dist/server/modules/mcp/controllers/mcp-test.controller.js +115 -0
- package/dist/server/modules/mcp/controllers/mcp-test.controller.js.map +1 -0
- package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +1094 -0
- package/dist/server/modules/mcp/dtos/mcp.dto.js +257 -0
- package/dist/server/modules/mcp/dtos/mcp.dto.js.map +1 -0
- package/dist/server/modules/mcp/gateways/mcp.gateway.d.ts +21 -0
- package/dist/server/modules/mcp/gateways/mcp.gateway.js +141 -0
- package/dist/server/modules/mcp/gateways/mcp.gateway.js.map +1 -0
- package/dist/server/modules/mcp/mcp.module.d.ts +2 -0
- package/dist/server/modules/mcp/mcp.module.js +83 -0
- package/dist/server/modules/mcp/mcp.module.js.map +1 -0
- package/dist/server/modules/mcp/services/instructions-resolver.d.ts +24 -0
- package/dist/server/modules/mcp/services/instructions-resolver.js +203 -0
- package/dist/server/modules/mcp/services/instructions-resolver.js.map +1 -0
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.d.ts +52 -0
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.js +327 -0
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.js.map +1 -0
- package/dist/server/modules/mcp/services/mcp-server.service.d.ts +6 -0
- package/dist/server/modules/mcp/services/mcp-server.service.js +26 -0
- package/dist/server/modules/mcp/services/mcp-server.service.js.map +1 -0
- package/dist/server/modules/mcp/services/mcp.service.d.ts +69 -0
- package/dist/server/modules/mcp/services/mcp.service.js +2056 -0
- package/dist/server/modules/mcp/services/mcp.service.js.map +1 -0
- package/dist/server/modules/mcp/services/terminal-activity.service.d.ts +9 -0
- package/dist/server/modules/mcp/services/terminal-activity.service.js +51 -0
- package/dist/server/modules/mcp/services/terminal-activity.service.js.map +1 -0
- package/dist/server/modules/profiles/controllers/profiles.controller.d.ts +45 -0
- package/dist/server/modules/profiles/controllers/profiles.controller.js +188 -0
- package/dist/server/modules/profiles/controllers/profiles.controller.js.map +1 -0
- package/dist/server/modules/profiles/dto.d.ts +75 -0
- package/dist/server/modules/profiles/dto.js +24 -0
- package/dist/server/modules/profiles/dto.js.map +1 -0
- package/dist/server/modules/profiles/profiles.module.d.ts +2 -0
- package/dist/server/modules/profiles/profiles.module.js +22 -0
- package/dist/server/modules/profiles/profiles.module.js.map +1 -0
- package/dist/server/modules/projects/controllers/projects.controller.d.ts +131 -0
- package/dist/server/modules/projects/controllers/projects.controller.js +196 -0
- package/dist/server/modules/projects/controllers/projects.controller.js.map +1 -0
- package/dist/server/modules/projects/projects.module.d.ts +2 -0
- package/dist/server/modules/projects/projects.module.js +26 -0
- package/dist/server/modules/projects/projects.module.js.map +1 -0
- package/dist/server/modules/projects/services/projects.service.d.ts +138 -0
- package/dist/server/modules/projects/services/projects.service.js +564 -0
- package/dist/server/modules/projects/services/projects.service.js.map +1 -0
- package/dist/server/modules/prompts/controllers/prompts.controller.d.ts +11 -0
- package/dist/server/modules/prompts/controllers/prompts.controller.js +112 -0
- package/dist/server/modules/prompts/controllers/prompts.controller.js.map +1 -0
- package/dist/server/modules/prompts/prompts.module.d.ts +2 -0
- package/dist/server/modules/prompts/prompts.module.js +22 -0
- package/dist/server/modules/prompts/prompts.module.js.map +1 -0
- package/dist/server/modules/providers/adapters/claude.adapter.d.ts +9 -0
- package/dist/server/modules/providers/adapters/claude.adapter.js +46 -0
- package/dist/server/modules/providers/adapters/claude.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/codex.adapter.d.ts +9 -0
- package/dist/server/modules/providers/adapters/codex.adapter.js +46 -0
- package/dist/server/modules/providers/adapters/codex.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/index.d.ts +4 -0
- package/dist/server/modules/providers/adapters/index.js +21 -0
- package/dist/server/modules/providers/adapters/index.js.map +1 -0
- package/dist/server/modules/providers/adapters/provider-adapter.factory.d.ts +8 -0
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js +42 -0
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js.map +1 -0
- package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +18 -0
- package/dist/server/modules/providers/adapters/provider-adapter.interface.js +3 -0
- package/dist/server/modules/providers/adapters/provider-adapter.interface.js.map +1 -0
- package/dist/server/modules/providers/controllers/providers.controller.d.ts +33 -0
- package/dist/server/modules/providers/controllers/providers.controller.js +399 -0
- package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -0
- package/dist/server/modules/providers/providers.module.d.ts +2 -0
- package/dist/server/modules/providers/providers.module.js +27 -0
- package/dist/server/modules/providers/providers.module.js.map +1 -0
- package/dist/server/modules/records/controllers/records.controller.d.ts +13 -0
- package/dist/server/modules/records/controllers/records.controller.js +83 -0
- package/dist/server/modules/records/controllers/records.controller.js.map +1 -0
- package/dist/server/modules/records/records.module.d.ts +2 -0
- package/dist/server/modules/records/records.module.js +22 -0
- package/dist/server/modules/records/records.module.js.map +1 -0
- package/dist/server/modules/sessions/controllers/sessions.controller.d.ts +13 -0
- package/dist/server/modules/sessions/controllers/sessions.controller.js +93 -0
- package/dist/server/modules/sessions/controllers/sessions.controller.js.map +1 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.d.ts +67 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.js +18 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.js.map +1 -0
- package/dist/server/modules/sessions/services/activity-tracker.service.d.ts +15 -0
- package/dist/server/modules/sessions/services/activity-tracker.service.js +103 -0
- package/dist/server/modules/sessions/services/activity-tracker.service.js.map +1 -0
- package/dist/server/modules/sessions/services/sessions.service.d.ts +49 -0
- package/dist/server/modules/sessions/services/sessions.service.js +511 -0
- package/dist/server/modules/sessions/services/sessions.service.js.map +1 -0
- package/dist/server/modules/sessions/sessions.module.d.ts +2 -0
- package/dist/server/modules/sessions/sessions.module.js +36 -0
- package/dist/server/modules/sessions/sessions.module.js.map +1 -0
- package/dist/server/modules/sessions/utils/profile-options.d.ts +4 -0
- package/dist/server/modules/sessions/utils/profile-options.js +70 -0
- package/dist/server/modules/sessions/utils/profile-options.js.map +1 -0
- package/dist/server/modules/sessions/utils/template-renderer.d.ts +27 -0
- package/dist/server/modules/sessions/utils/template-renderer.js +38 -0
- package/dist/server/modules/sessions/utils/template-renderer.js.map +1 -0
- package/dist/server/modules/settings/controllers/settings.controller.d.ts +10 -0
- package/dist/server/modules/settings/controllers/settings.controller.js +77 -0
- package/dist/server/modules/settings/controllers/settings.controller.js.map +1 -0
- package/dist/server/modules/settings/dtos/settings.dto.d.ts +104 -0
- package/dist/server/modules/settings/dtos/settings.dto.js +44 -0
- package/dist/server/modules/settings/dtos/settings.dto.js.map +1 -0
- package/dist/server/modules/settings/services/settings.service.d.ts +20 -0
- package/dist/server/modules/settings/services/settings.service.js +310 -0
- package/dist/server/modules/settings/services/settings.service.js.map +1 -0
- package/dist/server/modules/settings/settings.module.d.ts +2 -0
- package/dist/server/modules/settings/settings.module.js +26 -0
- package/dist/server/modules/settings/settings.module.js.map +1 -0
- package/dist/server/modules/statuses/controllers/statuses.controller.d.ts +17 -0
- package/dist/server/modules/statuses/controllers/statuses.controller.js +124 -0
- package/dist/server/modules/statuses/controllers/statuses.controller.js.map +1 -0
- package/dist/server/modules/statuses/statuses.module.d.ts +2 -0
- package/dist/server/modules/statuses/statuses.module.js +22 -0
- package/dist/server/modules/statuses/statuses.module.js.map +1 -0
- package/dist/server/modules/storage/db/db.config.d.ts +5 -0
- package/dist/server/modules/storage/db/db.config.js +19 -0
- package/dist/server/modules/storage/db/db.config.js.map +1 -0
- package/dist/server/modules/storage/db/db.module.d.ts +2 -0
- package/dist/server/modules/storage/db/db.module.js +22 -0
- package/dist/server/modules/storage/db/db.module.js.map +1 -0
- package/dist/server/modules/storage/db/db.provider.d.ts +3 -0
- package/dist/server/modules/storage/db/db.provider.js +61 -0
- package/dist/server/modules/storage/db/db.provider.js.map +1 -0
- package/dist/server/modules/storage/db/migrate.d.ts +1 -0
- package/dist/server/modules/storage/db/migrate.js +32 -0
- package/dist/server/modules/storage/db/migrate.js.map +1 -0
- package/dist/server/modules/storage/db/schema.d.ts +4058 -0
- package/dist/server/modules/storage/db/schema.js +393 -0
- package/dist/server/modules/storage/db/schema.js.map +1 -0
- package/dist/server/modules/storage/db/sqlite-raw.d.ts +3 -0
- package/dist/server/modules/storage/db/sqlite-raw.js +8 -0
- package/dist/server/modules/storage/db/sqlite-raw.js.map +1 -0
- package/dist/server/modules/storage/interfaces/storage.interface.d.ts +193 -0
- package/dist/server/modules/storage/interfaces/storage.interface.js +5 -0
- package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -0
- package/dist/server/modules/storage/local/local-storage.service.d.ts +105 -0
- package/dist/server/modules/storage/local/local-storage.service.js +2069 -0
- package/dist/server/modules/storage/local/local-storage.service.js.map +1 -0
- package/dist/server/modules/storage/models/domain.models.d.ts +152 -0
- package/dist/server/modules/storage/models/domain.models.js +3 -0
- package/dist/server/modules/storage/models/domain.models.js.map +1 -0
- package/dist/server/modules/storage/storage.module.d.ts +2 -0
- package/dist/server/modules/storage/storage.module.js +29 -0
- package/dist/server/modules/storage/storage.module.js.map +1 -0
- package/dist/server/modules/terminal/dtos/ws-envelope.dto.d.ts +103 -0
- package/dist/server/modules/terminal/dtos/ws-envelope.dto.js +50 -0
- package/dist/server/modules/terminal/dtos/ws-envelope.dto.js.map +1 -0
- package/dist/server/modules/terminal/gateways/terminal.gateway.d.ts +83 -0
- package/dist/server/modules/terminal/gateways/terminal.gateway.js +622 -0
- package/dist/server/modules/terminal/gateways/terminal.gateway.js.map +1 -0
- package/dist/server/modules/terminal/services/pty.service.d.ts +29 -0
- package/dist/server/modules/terminal/services/pty.service.js +236 -0
- package/dist/server/modules/terminal/services/pty.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-emulator.service.d.ts +40 -0
- package/dist/server/modules/terminal/services/terminal-emulator.service.js +356 -0
- package/dist/server/modules/terminal/services/terminal-emulator.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-seed.service.d.ts +29 -0
- package/dist/server/modules/terminal/services/terminal-seed.service.js +233 -0
- package/dist/server/modules/terminal/services/terminal-seed.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.d.ts +5 -0
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js +36 -0
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-stream.service.d.ts +17 -0
- package/dist/server/modules/terminal/services/terminal-stream.service.js +88 -0
- package/dist/server/modules/terminal/services/terminal-stream.service.js.map +1 -0
- package/dist/server/modules/terminal/services/tmux.service.d.ts +42 -0
- package/dist/server/modules/terminal/services/tmux.service.js +318 -0
- package/dist/server/modules/terminal/services/tmux.service.js.map +1 -0
- package/dist/server/modules/terminal/terminal.module.d.ts +2 -0
- package/dist/server/modules/terminal/terminal.module.js +47 -0
- package/dist/server/modules/terminal/terminal.module.js.map +1 -0
- package/dist/server/modules/terminal/utils/ansi-sanitizer.d.ts +8 -0
- package/dist/server/modules/terminal/utils/ansi-sanitizer.js +48 -0
- package/dist/server/modules/terminal/utils/ansi-sanitizer.js.map +1 -0
- package/dist/server/modules/terminal/utils/control-keys.d.ts +3 -0
- package/dist/server/modules/terminal/utils/control-keys.js +30 -0
- package/dist/server/modules/terminal/utils/control-keys.js.map +1 -0
- package/dist/server/modules/ui/ui.controller.d.ts +4 -0
- package/dist/server/modules/ui/ui.controller.js +55 -0
- package/dist/server/modules/ui/ui.controller.js.map +1 -0
- package/dist/server/modules/ui/ui.module.d.ts +2 -0
- package/dist/server/modules/ui/ui.module.js +22 -0
- package/dist/server/modules/ui/ui.module.js.map +1 -0
- package/dist/server/test-setup.d.ts +1 -0
- package/dist/server/test-setup.js +14 -0
- package/dist/server/test-setup.js.map +1 -0
- package/dist/server/tsconfig.tsbuildinfo +1 -0
- package/dist/server/ui/assets/index-DFChYYFN.css +32 -0
- package/dist/server/ui/assets/index-DpXRypHy.js +636 -0
- package/dist/server/ui/index.html +26 -0
- package/dist/templates/simple-codex.json +134 -0
- package/package.json +105 -0
- package/prebuilds/README.md +7 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.EpicCommentsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const zod_1 = require("zod");
|
|
18
|
+
const storage_interface_1 = require("../../storage/interfaces/storage.interface");
|
|
19
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
20
|
+
const logger = (0, logger_1.createLogger)('EpicCommentsController');
|
|
21
|
+
const CreateEpicCommentSchema = zod_1.z.object({
|
|
22
|
+
authorName: zod_1.z.string().min(1),
|
|
23
|
+
content: zod_1.z.string().min(1),
|
|
24
|
+
});
|
|
25
|
+
let EpicCommentsController = class EpicCommentsController {
|
|
26
|
+
constructor(storage) {
|
|
27
|
+
this.storage = storage;
|
|
28
|
+
}
|
|
29
|
+
async listEpicComments(id, limit, offset) {
|
|
30
|
+
logger.info({ id, limit, offset }, 'GET /api/epics/:id/comments');
|
|
31
|
+
const options = this.parseListOptions(limit, offset);
|
|
32
|
+
return this.storage.listEpicComments(id, options);
|
|
33
|
+
}
|
|
34
|
+
async createEpicComment(id, body) {
|
|
35
|
+
logger.info({ id }, 'POST /api/epics/:id/comments');
|
|
36
|
+
const parsed = CreateEpicCommentSchema.parse(body);
|
|
37
|
+
return this.storage.createEpicComment({
|
|
38
|
+
epicId: id,
|
|
39
|
+
authorName: parsed.authorName,
|
|
40
|
+
content: parsed.content,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async deleteEpicComment(id) {
|
|
44
|
+
logger.info({ id }, 'DELETE /api/comments/:id');
|
|
45
|
+
await this.storage.deleteEpicComment(id);
|
|
46
|
+
}
|
|
47
|
+
parseListOptions(limit, offset) {
|
|
48
|
+
const options = {};
|
|
49
|
+
if (limit !== undefined) {
|
|
50
|
+
const parsed = parseInt(limit, 10);
|
|
51
|
+
if (!Number.isNaN(parsed)) {
|
|
52
|
+
options.limit = parsed;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
if (offset !== undefined) {
|
|
56
|
+
const parsed = parseInt(offset, 10);
|
|
57
|
+
if (!Number.isNaN(parsed)) {
|
|
58
|
+
options.offset = parsed;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return options;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
exports.EpicCommentsController = EpicCommentsController;
|
|
65
|
+
__decorate([
|
|
66
|
+
(0, common_1.Get)('epics/:id/comments'),
|
|
67
|
+
__param(0, (0, common_1.Param)('id')),
|
|
68
|
+
__param(1, (0, common_1.Query)('limit')),
|
|
69
|
+
__param(2, (0, common_1.Query)('offset')),
|
|
70
|
+
__metadata("design:type", Function),
|
|
71
|
+
__metadata("design:paramtypes", [String, String, String]),
|
|
72
|
+
__metadata("design:returntype", Promise)
|
|
73
|
+
], EpicCommentsController.prototype, "listEpicComments", null);
|
|
74
|
+
__decorate([
|
|
75
|
+
(0, common_1.Post)('epics/:id/comments'),
|
|
76
|
+
__param(0, (0, common_1.Param)('id')),
|
|
77
|
+
__param(1, (0, common_1.Body)()),
|
|
78
|
+
__metadata("design:type", Function),
|
|
79
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
80
|
+
__metadata("design:returntype", Promise)
|
|
81
|
+
], EpicCommentsController.prototype, "createEpicComment", null);
|
|
82
|
+
__decorate([
|
|
83
|
+
(0, common_1.Delete)('comments/:id'),
|
|
84
|
+
__param(0, (0, common_1.Param)('id')),
|
|
85
|
+
__metadata("design:type", Function),
|
|
86
|
+
__metadata("design:paramtypes", [String]),
|
|
87
|
+
__metadata("design:returntype", Promise)
|
|
88
|
+
], EpicCommentsController.prototype, "deleteEpicComment", null);
|
|
89
|
+
exports.EpicCommentsController = EpicCommentsController = __decorate([
|
|
90
|
+
(0, common_1.Controller)('api'),
|
|
91
|
+
__param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
92
|
+
__metadata("design:paramtypes", [Object])
|
|
93
|
+
], EpicCommentsController);
|
|
94
|
+
//# sourceMappingURL=epic-comments.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"epic-comments.controller.js","sourceRoot":"","sources":["../../../../src/modules/epics/controllers/epic-comments.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ListResult } from '../../storage/interfaces/storage.interface';
|
|
2
|
+
import { Epic } from '../../storage/models/domain.models';
|
|
3
|
+
import { EpicsService } from '../services/epics.service';
|
|
4
|
+
export declare class EpicsController {
|
|
5
|
+
private readonly epicsService;
|
|
6
|
+
constructor(epicsService: EpicsService);
|
|
7
|
+
listEpics(projectId?: string, statusId?: string, parentId?: string, limit?: string, offset?: string, type?: string): Promise<ListResult<Epic>>;
|
|
8
|
+
listSubEpicsForEpic(id: string, limit?: string, offset?: string): Promise<ListResult<Epic>>;
|
|
9
|
+
countSubEpicsByStatus(id: string): Promise<Record<string, number>>;
|
|
10
|
+
getEpic(id: string): Promise<Epic>;
|
|
11
|
+
createEpic(body: unknown): Promise<Epic>;
|
|
12
|
+
bulkUpdateEpics(body: unknown): Promise<Epic[]>;
|
|
13
|
+
updateEpic(id: string, body: unknown): Promise<Epic>;
|
|
14
|
+
deleteEpic(id: string): Promise<void>;
|
|
15
|
+
private parseListOptions;
|
|
16
|
+
}
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.EpicsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const zod_1 = require("zod");
|
|
18
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
19
|
+
const epics_service_1 = require("../services/epics.service");
|
|
20
|
+
const logger = (0, logger_1.createLogger)('EpicsController');
|
|
21
|
+
const CreateEpicSchema = zod_1.z.object({
|
|
22
|
+
projectId: zod_1.z.string(),
|
|
23
|
+
title: zod_1.z.string().min(1),
|
|
24
|
+
description: zod_1.z.string().nullable().optional(),
|
|
25
|
+
statusId: zod_1.z.string(),
|
|
26
|
+
data: zod_1.z.record(zod_1.z.unknown()).nullable().optional(),
|
|
27
|
+
tags: zod_1.z.array(zod_1.z.string()).optional(),
|
|
28
|
+
parentId: zod_1.z.string().nullable().optional(),
|
|
29
|
+
agentId: zod_1.z.string().nullable().optional(),
|
|
30
|
+
});
|
|
31
|
+
const UpdateEpicSchema = zod_1.z.object({
|
|
32
|
+
title: zod_1.z.string().min(1).optional(),
|
|
33
|
+
description: zod_1.z.string().nullable().optional(),
|
|
34
|
+
statusId: zod_1.z.string().optional(),
|
|
35
|
+
data: zod_1.z.record(zod_1.z.unknown()).nullable().optional(),
|
|
36
|
+
tags: zod_1.z.array(zod_1.z.string()).optional(),
|
|
37
|
+
parentId: zod_1.z.string().nullable().optional(),
|
|
38
|
+
agentId: zod_1.z.string().nullable().optional(),
|
|
39
|
+
version: zod_1.z.number().optional(),
|
|
40
|
+
});
|
|
41
|
+
const BulkUpdateEntrySchema = zod_1.z.object({
|
|
42
|
+
id: zod_1.z.string(),
|
|
43
|
+
statusId: zod_1.z.string().optional(),
|
|
44
|
+
agentId: zod_1.z.string().nullable().optional(),
|
|
45
|
+
version: zod_1.z.number(),
|
|
46
|
+
});
|
|
47
|
+
const BulkUpdateSchema = zod_1.z.object({
|
|
48
|
+
parentId: zod_1.z.string().nullable().optional(),
|
|
49
|
+
updates: zod_1.z.array(BulkUpdateEntrySchema).min(1),
|
|
50
|
+
});
|
|
51
|
+
let EpicsController = class EpicsController {
|
|
52
|
+
constructor(epicsService) {
|
|
53
|
+
this.epicsService = epicsService;
|
|
54
|
+
}
|
|
55
|
+
async listEpics(projectId, statusId, parentId, limit, offset, type) {
|
|
56
|
+
logger.info({ projectId, statusId, parentId, limit, offset, type }, 'GET /api/epics');
|
|
57
|
+
const options = this.parseListOptions(limit, offset);
|
|
58
|
+
if (parentId) {
|
|
59
|
+
return this.epicsService.listEpics({ parentId, options });
|
|
60
|
+
}
|
|
61
|
+
if (statusId) {
|
|
62
|
+
return this.epicsService.listEpics({ statusId, options });
|
|
63
|
+
}
|
|
64
|
+
if (!projectId) {
|
|
65
|
+
throw new common_1.BadRequestException('Provide projectId, statusId, or parentId to list epics.');
|
|
66
|
+
}
|
|
67
|
+
const normalized = (type || 'active').toLowerCase();
|
|
68
|
+
const allowed = new Set(['active', 'archived', 'all']);
|
|
69
|
+
const listType = (allowed.has(normalized) ? normalized : 'active');
|
|
70
|
+
return this.epicsService.listEpics({ projectId, type: listType, options });
|
|
71
|
+
}
|
|
72
|
+
async listSubEpicsForEpic(id, limit, offset) {
|
|
73
|
+
logger.info({ id, limit, offset }, 'GET /api/epics/:id/sub-epics');
|
|
74
|
+
const options = this.parseListOptions(limit, offset);
|
|
75
|
+
return this.epicsService.listSubEpics(id, options);
|
|
76
|
+
}
|
|
77
|
+
async countSubEpicsByStatus(id) {
|
|
78
|
+
logger.info({ id }, 'GET /api/epics/:id/sub-epics/counts');
|
|
79
|
+
return this.epicsService.countSubEpicsByStatus(id);
|
|
80
|
+
}
|
|
81
|
+
async getEpic(id) {
|
|
82
|
+
logger.info({ id }, 'GET /api/epics/:id');
|
|
83
|
+
return this.epicsService.getEpicById(id);
|
|
84
|
+
}
|
|
85
|
+
async createEpic(body) {
|
|
86
|
+
logger.info('POST /api/epics');
|
|
87
|
+
const parsed = CreateEpicSchema.parse(body);
|
|
88
|
+
const data = {
|
|
89
|
+
projectId: parsed.projectId,
|
|
90
|
+
title: parsed.title,
|
|
91
|
+
description: parsed.description ?? null,
|
|
92
|
+
statusId: parsed.statusId,
|
|
93
|
+
data: parsed.data ?? null,
|
|
94
|
+
tags: parsed.tags ?? [],
|
|
95
|
+
parentId: parsed.parentId ?? null,
|
|
96
|
+
agentId: parsed.agentId ?? null,
|
|
97
|
+
};
|
|
98
|
+
return this.epicsService.createEpic(data);
|
|
99
|
+
}
|
|
100
|
+
async bulkUpdateEpics(body) {
|
|
101
|
+
logger.info('POST /api/epics/bulk-update');
|
|
102
|
+
const parsed = BulkUpdateSchema.parse(body);
|
|
103
|
+
return this.epicsService.bulkUpdateEpics(parsed.updates, parsed.parentId ?? null);
|
|
104
|
+
}
|
|
105
|
+
async updateEpic(id, body) {
|
|
106
|
+
logger.info({ id }, 'PUT /api/epics/:id');
|
|
107
|
+
const { version = 1, ...rest } = UpdateEpicSchema.parse(body);
|
|
108
|
+
const data = rest;
|
|
109
|
+
return this.epicsService.updateEpic(id, data, version);
|
|
110
|
+
}
|
|
111
|
+
async deleteEpic(id) {
|
|
112
|
+
logger.info({ id }, 'DELETE /api/epics/:id');
|
|
113
|
+
await this.epicsService.deleteEpic(id);
|
|
114
|
+
}
|
|
115
|
+
parseListOptions(limit, offset) {
|
|
116
|
+
const options = {};
|
|
117
|
+
if (limit !== undefined) {
|
|
118
|
+
const parsed = parseInt(limit, 10);
|
|
119
|
+
if (!Number.isNaN(parsed)) {
|
|
120
|
+
options.limit = parsed;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (offset !== undefined) {
|
|
124
|
+
const parsed = parseInt(offset, 10);
|
|
125
|
+
if (!Number.isNaN(parsed)) {
|
|
126
|
+
options.offset = parsed;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return options;
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
exports.EpicsController = EpicsController;
|
|
133
|
+
__decorate([
|
|
134
|
+
(0, common_1.Get)(),
|
|
135
|
+
__param(0, (0, common_1.Query)('projectId')),
|
|
136
|
+
__param(1, (0, common_1.Query)('statusId')),
|
|
137
|
+
__param(2, (0, common_1.Query)('parentId')),
|
|
138
|
+
__param(3, (0, common_1.Query)('limit')),
|
|
139
|
+
__param(4, (0, common_1.Query)('offset')),
|
|
140
|
+
__param(5, (0, common_1.Query)('type')),
|
|
141
|
+
__metadata("design:type", Function),
|
|
142
|
+
__metadata("design:paramtypes", [String, String, String, String, String, String]),
|
|
143
|
+
__metadata("design:returntype", Promise)
|
|
144
|
+
], EpicsController.prototype, "listEpics", null);
|
|
145
|
+
__decorate([
|
|
146
|
+
(0, common_1.Get)(':id/sub-epics'),
|
|
147
|
+
__param(0, (0, common_1.Param)('id')),
|
|
148
|
+
__param(1, (0, common_1.Query)('limit')),
|
|
149
|
+
__param(2, (0, common_1.Query)('offset')),
|
|
150
|
+
__metadata("design:type", Function),
|
|
151
|
+
__metadata("design:paramtypes", [String, String, String]),
|
|
152
|
+
__metadata("design:returntype", Promise)
|
|
153
|
+
], EpicsController.prototype, "listSubEpicsForEpic", null);
|
|
154
|
+
__decorate([
|
|
155
|
+
(0, common_1.Get)(':id/sub-epics/counts'),
|
|
156
|
+
__param(0, (0, common_1.Param)('id')),
|
|
157
|
+
__metadata("design:type", Function),
|
|
158
|
+
__metadata("design:paramtypes", [String]),
|
|
159
|
+
__metadata("design:returntype", Promise)
|
|
160
|
+
], EpicsController.prototype, "countSubEpicsByStatus", null);
|
|
161
|
+
__decorate([
|
|
162
|
+
(0, common_1.Get)(':id'),
|
|
163
|
+
__param(0, (0, common_1.Param)('id')),
|
|
164
|
+
__metadata("design:type", Function),
|
|
165
|
+
__metadata("design:paramtypes", [String]),
|
|
166
|
+
__metadata("design:returntype", Promise)
|
|
167
|
+
], EpicsController.prototype, "getEpic", null);
|
|
168
|
+
__decorate([
|
|
169
|
+
(0, common_1.Post)(),
|
|
170
|
+
__param(0, (0, common_1.Body)()),
|
|
171
|
+
__metadata("design:type", Function),
|
|
172
|
+
__metadata("design:paramtypes", [Object]),
|
|
173
|
+
__metadata("design:returntype", Promise)
|
|
174
|
+
], EpicsController.prototype, "createEpic", null);
|
|
175
|
+
__decorate([
|
|
176
|
+
(0, common_1.Post)('bulk-update'),
|
|
177
|
+
__param(0, (0, common_1.Body)()),
|
|
178
|
+
__metadata("design:type", Function),
|
|
179
|
+
__metadata("design:paramtypes", [Object]),
|
|
180
|
+
__metadata("design:returntype", Promise)
|
|
181
|
+
], EpicsController.prototype, "bulkUpdateEpics", null);
|
|
182
|
+
__decorate([
|
|
183
|
+
(0, common_1.Put)(':id'),
|
|
184
|
+
__param(0, (0, common_1.Param)('id')),
|
|
185
|
+
__param(1, (0, common_1.Body)()),
|
|
186
|
+
__metadata("design:type", Function),
|
|
187
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
188
|
+
__metadata("design:returntype", Promise)
|
|
189
|
+
], EpicsController.prototype, "updateEpic", null);
|
|
190
|
+
__decorate([
|
|
191
|
+
(0, common_1.Delete)(':id'),
|
|
192
|
+
__param(0, (0, common_1.Param)('id')),
|
|
193
|
+
__metadata("design:type", Function),
|
|
194
|
+
__metadata("design:paramtypes", [String]),
|
|
195
|
+
__metadata("design:returntype", Promise)
|
|
196
|
+
], EpicsController.prototype, "deleteEpic", null);
|
|
197
|
+
exports.EpicsController = EpicsController = __decorate([
|
|
198
|
+
(0, common_1.Controller)('api/epics'),
|
|
199
|
+
__metadata("design:paramtypes", [epics_service_1.EpicsService])
|
|
200
|
+
], EpicsController);
|
|
201
|
+
//# sourceMappingURL=epics.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"epics.controller.js","sourceRoot":"","sources":["../../../../src/modules/epics/controllers/epics.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.EpicsModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const epics_controller_1 = require("./controllers/epics.controller");
|
|
12
|
+
const epic_comments_controller_1 = require("./controllers/epic-comments.controller");
|
|
13
|
+
const storage_module_1 = require("../storage/storage.module");
|
|
14
|
+
const events_module_1 = require("../events/events.module");
|
|
15
|
+
const epics_service_1 = require("./services/epics.service");
|
|
16
|
+
const terminal_module_1 = require("../terminal/terminal.module");
|
|
17
|
+
let EpicsModule = class EpicsModule {
|
|
18
|
+
};
|
|
19
|
+
exports.EpicsModule = EpicsModule;
|
|
20
|
+
exports.EpicsModule = EpicsModule = __decorate([
|
|
21
|
+
(0, common_1.Module)({
|
|
22
|
+
imports: [storage_module_1.StorageModule, events_module_1.EventsModule, (0, common_1.forwardRef)(() => terminal_module_1.TerminalModule)],
|
|
23
|
+
controllers: [epics_controller_1.EpicsController, epic_comments_controller_1.EpicCommentsController],
|
|
24
|
+
providers: [epics_service_1.EpicsService],
|
|
25
|
+
exports: [epics_service_1.EpicsService],
|
|
26
|
+
})
|
|
27
|
+
], EpicsModule);
|
|
28
|
+
//# sourceMappingURL=epics.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"epics.module.js","sourceRoot":"","sources":["../../../src/modules/epics/epics.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,qEAAiE;AACjE,qFAAgF;AAChF,8DAA0D;AAC1D,2DAAuD;AACvD,4DAAwD;AACxD,iEAA6D;AAQtD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IANvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,8BAAa,EAAE,4BAAY,EAAE,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,gCAAc,CAAC,CAAC;QACxE,WAAW,EAAE,CAAC,kCAAe,EAAE,iDAAsB,CAAC;QACtD,SAAS,EAAE,CAAC,4BAAY,CAAC;QACzB,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { type StorageService, type CreateEpicForProjectInput, type ListOptions, type ListResult } from '../../storage/interfaces/storage.interface';
|
|
2
|
+
import type { Epic, UpdateEpic, CreateEpic } from '../../storage/models/domain.models';
|
|
3
|
+
import { EventsService } from '../../events/services/events.service';
|
|
4
|
+
import { TerminalGateway } from '../../terminal/gateways/terminal.gateway';
|
|
5
|
+
export declare class EpicsService {
|
|
6
|
+
private readonly storage;
|
|
7
|
+
private readonly eventsService;
|
|
8
|
+
private readonly terminalGateway?;
|
|
9
|
+
private readonly logger;
|
|
10
|
+
constructor(storage: StorageService, eventsService: EventsService, terminalGateway?: TerminalGateway | undefined);
|
|
11
|
+
createEpic(data: CreateEpic): Promise<Epic>;
|
|
12
|
+
listEpics(params: {
|
|
13
|
+
projectId?: string;
|
|
14
|
+
statusId?: string;
|
|
15
|
+
parentId?: string;
|
|
16
|
+
type?: 'active' | 'archived' | 'all';
|
|
17
|
+
options?: ListOptions;
|
|
18
|
+
}): Promise<ListResult<Epic>>;
|
|
19
|
+
getEpicById(id: string): Promise<Epic>;
|
|
20
|
+
listSubEpics(parentId: string, options?: ListOptions): Promise<ListResult<Epic>>;
|
|
21
|
+
countSubEpicsByStatus(parentId: string): Promise<Record<string, number>>;
|
|
22
|
+
createEpicForProject(projectId: string, input: CreateEpicForProjectInput): Promise<Epic>;
|
|
23
|
+
updateEpic(id: string, data: UpdateEpic, expectedVersion: number): Promise<Epic>;
|
|
24
|
+
bulkUpdateEpics(updates: Array<{
|
|
25
|
+
id: string;
|
|
26
|
+
statusId?: string;
|
|
27
|
+
agentId?: string | null;
|
|
28
|
+
version: number;
|
|
29
|
+
}>, expectedParentId?: string | null): Promise<Epic[]>;
|
|
30
|
+
deleteEpic(id: string): Promise<void>;
|
|
31
|
+
private buildEpicSnapshot;
|
|
32
|
+
private buildEpicChanges;
|
|
33
|
+
private broadcastEpicEvent;
|
|
34
|
+
}
|
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var EpicsService_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.EpicsService = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const storage_interface_1 = require("../../storage/interfaces/storage.interface");
|
|
19
|
+
const events_service_1 = require("../../events/services/events.service");
|
|
20
|
+
const terminal_gateway_1 = require("../../terminal/gateways/terminal.gateway");
|
|
21
|
+
const error_types_1 = require("../../../common/errors/error-types");
|
|
22
|
+
let EpicsService = EpicsService_1 = class EpicsService {
|
|
23
|
+
constructor(storage, eventsService, terminalGateway) {
|
|
24
|
+
this.storage = storage;
|
|
25
|
+
this.eventsService = eventsService;
|
|
26
|
+
this.terminalGateway = terminalGateway;
|
|
27
|
+
this.logger = new common_1.Logger(EpicsService_1.name);
|
|
28
|
+
}
|
|
29
|
+
async createEpic(data) {
|
|
30
|
+
const epic = await this.storage.createEpic(data);
|
|
31
|
+
if (epic.agentId) {
|
|
32
|
+
try {
|
|
33
|
+
const [project, agent] = await Promise.all([
|
|
34
|
+
this.storage.getProject(epic.projectId),
|
|
35
|
+
this.storage.getAgent(epic.agentId),
|
|
36
|
+
]);
|
|
37
|
+
await this.eventsService.publish('epic.assigned', {
|
|
38
|
+
epicId: epic.id,
|
|
39
|
+
projectId: epic.projectId,
|
|
40
|
+
agentId: epic.agentId,
|
|
41
|
+
previousAgentId: null,
|
|
42
|
+
epicTitle: epic.title,
|
|
43
|
+
projectName: project.name,
|
|
44
|
+
agentName: agent.name,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
this.logger.error({ epicId: epic.id, agentId: epic.agentId, error }, 'Failed to publish epic.assigned event');
|
|
49
|
+
throw error;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
this.broadcastEpicEvent(epic.projectId, 'created', {
|
|
53
|
+
epic: this.buildEpicSnapshot(epic),
|
|
54
|
+
});
|
|
55
|
+
return epic;
|
|
56
|
+
}
|
|
57
|
+
async listEpics(params) {
|
|
58
|
+
const { projectId, statusId, parentId, type = 'active', options = {} } = params;
|
|
59
|
+
if (parentId) {
|
|
60
|
+
return this.storage.listSubEpics(parentId, options);
|
|
61
|
+
}
|
|
62
|
+
if (statusId) {
|
|
63
|
+
return this.storage.listEpicsByStatus(statusId, options);
|
|
64
|
+
}
|
|
65
|
+
if (!projectId) {
|
|
66
|
+
throw new error_types_1.ValidationError('Provide projectId, statusId, or parentId to list epics.');
|
|
67
|
+
}
|
|
68
|
+
return this.storage.listProjectEpics(projectId, { ...options, type });
|
|
69
|
+
}
|
|
70
|
+
async getEpicById(id) {
|
|
71
|
+
return this.storage.getEpic(id);
|
|
72
|
+
}
|
|
73
|
+
async listSubEpics(parentId, options = {}) {
|
|
74
|
+
return this.storage.listSubEpics(parentId, options);
|
|
75
|
+
}
|
|
76
|
+
async countSubEpicsByStatus(parentId) {
|
|
77
|
+
return this.storage.countSubEpicsByStatus(parentId);
|
|
78
|
+
}
|
|
79
|
+
async createEpicForProject(projectId, input) {
|
|
80
|
+
const epic = await this.storage.createEpicForProject(projectId, input);
|
|
81
|
+
if (epic.agentId) {
|
|
82
|
+
try {
|
|
83
|
+
const [project, agent] = await Promise.all([
|
|
84
|
+
this.storage.getProject(epic.projectId),
|
|
85
|
+
this.storage.getAgent(epic.agentId),
|
|
86
|
+
]);
|
|
87
|
+
await this.eventsService.publish('epic.assigned', {
|
|
88
|
+
epicId: epic.id,
|
|
89
|
+
projectId: epic.projectId,
|
|
90
|
+
agentId: epic.agentId,
|
|
91
|
+
previousAgentId: null,
|
|
92
|
+
epicTitle: epic.title,
|
|
93
|
+
projectName: project.name,
|
|
94
|
+
agentName: agent.name,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
this.logger.error({ epicId: epic.id, agentId: epic.agentId, error }, 'Failed to publish epic.assigned event');
|
|
99
|
+
throw error;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
this.broadcastEpicEvent(epic.projectId, 'created', {
|
|
103
|
+
epic: this.buildEpicSnapshot(epic),
|
|
104
|
+
});
|
|
105
|
+
return epic;
|
|
106
|
+
}
|
|
107
|
+
async updateEpic(id, data, expectedVersion) {
|
|
108
|
+
const before = await this.storage.getEpic(id);
|
|
109
|
+
const updated = await this.storage.updateEpic(id, data, expectedVersion);
|
|
110
|
+
const agentChanged = data.agentId !== undefined && updated.agentId !== before.agentId && updated.agentId !== null;
|
|
111
|
+
if (agentChanged && updated.agentId) {
|
|
112
|
+
try {
|
|
113
|
+
const [project, agent] = await Promise.all([
|
|
114
|
+
this.storage.getProject(updated.projectId),
|
|
115
|
+
this.storage.getAgent(updated.agentId),
|
|
116
|
+
]);
|
|
117
|
+
await this.eventsService.publish('epic.assigned', {
|
|
118
|
+
epicId: updated.id,
|
|
119
|
+
projectId: updated.projectId,
|
|
120
|
+
agentId: updated.agentId,
|
|
121
|
+
previousAgentId: before.agentId,
|
|
122
|
+
epicTitle: updated.title,
|
|
123
|
+
projectName: project.name,
|
|
124
|
+
agentName: agent.name,
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
catch (error) {
|
|
128
|
+
this.logger.error({ id, agentId: updated.agentId, error }, 'Failed to publish epic.assigned event');
|
|
129
|
+
throw error;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
this.broadcastEpicEvent(updated.projectId, 'updated', {
|
|
133
|
+
epic: this.buildEpicSnapshot(updated),
|
|
134
|
+
changes: this.buildEpicChanges(before, updated),
|
|
135
|
+
});
|
|
136
|
+
return updated;
|
|
137
|
+
}
|
|
138
|
+
async bulkUpdateEpics(updates, expectedParentId = null) {
|
|
139
|
+
if (!updates.length) {
|
|
140
|
+
return [];
|
|
141
|
+
}
|
|
142
|
+
const seen = new Set();
|
|
143
|
+
const results = [];
|
|
144
|
+
let projectId = null;
|
|
145
|
+
for (const update of updates) {
|
|
146
|
+
if (seen.has(update.id)) {
|
|
147
|
+
throw new error_types_1.ValidationError('Duplicate epic id in bulk update payload', {
|
|
148
|
+
epicId: update.id,
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
seen.add(update.id);
|
|
152
|
+
if (typeof update.version !== 'number') {
|
|
153
|
+
throw new error_types_1.ValidationError('version is required for bulk epic updates', {
|
|
154
|
+
epicId: update.id,
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
const current = await this.storage.getEpic(update.id);
|
|
158
|
+
if (projectId && current.projectId !== projectId) {
|
|
159
|
+
throw new error_types_1.ValidationError('All epics in a bulk update must belong to the same project', {
|
|
160
|
+
epicId: current.id,
|
|
161
|
+
projectId: current.projectId,
|
|
162
|
+
expectedProjectId: projectId,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
projectId = projectId ?? current.projectId;
|
|
166
|
+
if (expectedParentId &&
|
|
167
|
+
current.id !== expectedParentId &&
|
|
168
|
+
current.parentId !== expectedParentId) {
|
|
169
|
+
throw new error_types_1.ValidationError('Epic is not part of the requested parent hierarchy', {
|
|
170
|
+
epicId: current.id,
|
|
171
|
+
parentId: current.parentId,
|
|
172
|
+
expectedParentId,
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
const targetStatusId = update.statusId ?? current.statusId;
|
|
176
|
+
const targetAgentId = update.agentId === undefined ? current.agentId : (update.agentId ?? null);
|
|
177
|
+
if (targetStatusId === current.statusId && targetAgentId === current.agentId) {
|
|
178
|
+
continue;
|
|
179
|
+
}
|
|
180
|
+
const payload = {};
|
|
181
|
+
if (update.statusId !== undefined) {
|
|
182
|
+
payload.statusId = update.statusId;
|
|
183
|
+
}
|
|
184
|
+
if (update.agentId !== undefined) {
|
|
185
|
+
payload.agentId = update.agentId ?? null;
|
|
186
|
+
}
|
|
187
|
+
results.push(await this.updateEpic(update.id, payload, update.version));
|
|
188
|
+
}
|
|
189
|
+
return results;
|
|
190
|
+
}
|
|
191
|
+
async deleteEpic(id) {
|
|
192
|
+
const epic = await this.storage.getEpic(id);
|
|
193
|
+
await this.storage.deleteEpic(id);
|
|
194
|
+
this.broadcastEpicEvent(epic.projectId, 'deleted', {
|
|
195
|
+
epicId: epic.id,
|
|
196
|
+
projectId: epic.projectId,
|
|
197
|
+
parentId: epic.parentId,
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
buildEpicSnapshot(epic) {
|
|
201
|
+
const { id, projectId, title, statusId, agentId, parentId, tags, version, createdAt, updatedAt, } = epic;
|
|
202
|
+
return {
|
|
203
|
+
id,
|
|
204
|
+
projectId,
|
|
205
|
+
title,
|
|
206
|
+
statusId,
|
|
207
|
+
agentId,
|
|
208
|
+
parentId,
|
|
209
|
+
tags,
|
|
210
|
+
version,
|
|
211
|
+
createdAt,
|
|
212
|
+
updatedAt,
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
buildEpicChanges(before, after) {
|
|
216
|
+
const changes = {};
|
|
217
|
+
if (before.title !== after.title) {
|
|
218
|
+
changes.title = { previous: before.title, current: after.title };
|
|
219
|
+
}
|
|
220
|
+
if (before.statusId !== after.statusId) {
|
|
221
|
+
changes.statusId = { previous: before.statusId ?? null, current: after.statusId ?? null };
|
|
222
|
+
}
|
|
223
|
+
if (before.agentId !== after.agentId) {
|
|
224
|
+
changes.agentId = { previous: before.agentId ?? null, current: after.agentId ?? null };
|
|
225
|
+
}
|
|
226
|
+
return changes;
|
|
227
|
+
}
|
|
228
|
+
broadcastEpicEvent(projectId, type, payload) {
|
|
229
|
+
if (!this.terminalGateway) {
|
|
230
|
+
this.logger.warn({ projectId, type }, 'TerminalGateway not available; skipping epic broadcast event');
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
const topic = `project/${projectId}/epics`;
|
|
234
|
+
try {
|
|
235
|
+
this.terminalGateway.broadcastEvent(topic, type, payload);
|
|
236
|
+
}
|
|
237
|
+
catch (error) {
|
|
238
|
+
this.logger.error({ projectId, type, error }, 'Failed to broadcast epic event');
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
};
|
|
242
|
+
exports.EpicsService = EpicsService;
|
|
243
|
+
exports.EpicsService = EpicsService = EpicsService_1 = __decorate([
|
|
244
|
+
(0, common_1.Injectable)(),
|
|
245
|
+
__param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
246
|
+
__param(2, (0, common_1.Optional)()),
|
|
247
|
+
__param(2, (0, common_1.Inject)((0, common_1.forwardRef)(() => terminal_gateway_1.TerminalGateway))),
|
|
248
|
+
__metadata("design:paramtypes", [Object, events_service_1.EventsService,
|
|
249
|
+
terminal_gateway_1.TerminalGateway])
|
|
250
|
+
], EpicsService);
|
|
251
|
+
//# sourceMappingURL=epics.service.js.map
|