- Updated all package.json name fields and dependency references - Updated all TypeScript/JavaScript imports - Updated .woodpecker/publish.yml filters and registry paths - Updated tools/install.sh scope default - Updated .npmrc registry paths (worktree + host) - Enhanced update-checker.ts with checkForAllUpdates() multi-package support - Updated CLI update command to show table of all packages - Added KNOWN_PACKAGES, formatAllPackagesTable, getInstallAllCommand - Marked checkForUpdate() with @deprecated JSDoc Closes #391
1.9 KiB
1.9 KiB
QA Report — Gateway Security Hardening
Scope
- Chat HTTP auth guard hardening
- Chat WebSocket session validation
- DTO validation rules for chat and conversation payloads
- Ownership regression coverage for by-id routes
TDD
- Required: yes
- Applied: yes
- Red step: targeted tests failed on socket session reshaping and DTO role/length mismatches
- Green step: targeted tests passed after runtime and DTO alignment
Baseline Verification
| Command | Result | Evidence |
|---|---|---|
pnpm --filter @mosaicstack/gateway test -- src/chat/__tests__/chat-security.test.ts src/__tests__/resource-ownership.test.ts |
pass | 3 test files passed, 20 tests passed |
pnpm typecheck |
pass | turbo completed 18/18 package typecheck tasks |
pnpm lint |
pass | turbo completed 18/18 package lint tasks |
pnpm format:check |
pass | All matched files use Prettier code style! |
Situational Verification
| Acceptance Criterion | Verification Method | Evidence |
|---|---|---|
| Chat controller requires auth and current-user context | source assertion test | chat-security.test.ts checks @UseGuards(AuthGuard) and @CurrentUser() user: { id: string } |
| WebSocket handshake requires Better Auth session | unit tests for validateSocketSession() |
null handshake returns null; valid handshake returns original session object |
| Conversation messages reject non-user/assistant roles | class-validator test | system role fails validation |
| Conversation messages enforce a 32k max length | class-validator test | 32_001 chars fail validation |
| Chat request payload enforces a 10k max length | class-validator test | 10_001 chars fail validation |
| By-id routes reject cross-user access | ownership regression tests | conversations, projects, missions, tasks each raise ForbiddenException for non-owner access |
Residual Risk
- No live HTTP or WebSocket smoke test against a running gateway process was executed in this session.