mirror of
https://github.com/garrytan/gstack.git
synced 2026-05-20 19:29:56 +08:00
refactor: split handleCommand into handleCommandInternal + HTTP wrapper
Chain subcommands now route through handleCommandInternal for full security enforcement (scope, domain, tab ownership, rate limiting, content wrapping). Adds recursion guard for nested chains, rate-limit exemption for chain subcommands, and activity event suppression (1 event per chain, not per sub). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -44,10 +44,13 @@ describe('Server auth security', () => {
|
||||
});
|
||||
|
||||
// Test 1c: newtab must check domain restrictions (CSO finding #5)
|
||||
// Domain check for newtab is now unified with goto in the scope check section:
|
||||
// (command === 'goto' || command === 'newtab') && args[0] → checkDomain
|
||||
test('newtab enforces domain restrictions', () => {
|
||||
const newtabBlock = sliceBetween(SERVER_SRC, "newtab with ownership for scoped tokens", "Block mutation commands while watching");
|
||||
expect(newtabBlock).toContain('checkDomain');
|
||||
expect(newtabBlock).toContain('Domain not allowed');
|
||||
const scopeBlock = sliceBetween(SERVER_SRC, "Scope check (for scoped tokens)", "Pin to a specific tab");
|
||||
expect(scopeBlock).toContain("command === 'newtab'");
|
||||
expect(scopeBlock).toContain('checkDomain');
|
||||
expect(scopeBlock).toContain('Domain not allowed');
|
||||
});
|
||||
|
||||
// Test 2: /refs endpoint requires auth via validateAuth
|
||||
@@ -168,7 +171,7 @@ describe('Server auth security', () => {
|
||||
|
||||
// Test 10d: server passes tokenInfo to handleMetaCommand
|
||||
test('server passes tokenInfo to handleMetaCommand', () => {
|
||||
expect(SERVER_SRC).toContain('handleMetaCommand(command, args, browserManager, shutdown, tokenInfo)');
|
||||
expect(SERVER_SRC).toContain('handleMetaCommand(command, args, browserManager, shutdown, tokenInfo,');
|
||||
});
|
||||
|
||||
// Test 10e: activity attribution includes clientId
|
||||
|
||||
Reference in New Issue
Block a user