Restore legacy host config fetch compatibility (#1254)
Some checks are pending
Build and Test / Secret Scan (push) Waiting to run
Build and Test / Frontend & Backend (push) Waiting to run
Core E2E Tests / Playwright Core E2E (push) Waiting to run

This commit is contained in:
rcourtman 2026-03-30 19:30:48 +01:00
parent 4120d75359
commit 04a828264a
3 changed files with 70 additions and 1 deletions

View file

@ -325,7 +325,7 @@ func TestHandleConfigMissingConfigScope(t *testing.T) {
req := httptest.NewRequest(http.MethodGet, "/api/agents/host/"+hostID+"/config", nil)
attachAPITokenRecord(req, &config.APITokenRecord{
ID: "token-other",
Scopes: []string{config.ScopeHostReport},
Scopes: []string{config.ScopeMonitoringRead},
})
rec := httptest.NewRecorder()
@ -336,6 +336,38 @@ func TestHandleConfigMissingConfigScope(t *testing.T) {
}
}
func TestHandleConfigAllowsBoundHostReportScope(t *testing.T) {
t.Parallel()
handler := newHostAgentHandlerForTests(t, models.Host{
ID: "host-1",
TokenID: "token-expected",
})
req := httptest.NewRequest(http.MethodGet, "/api/agents/host/other-host/config", nil)
attachAPITokenRecord(req, &config.APITokenRecord{
ID: "token-expected",
Scopes: []string{config.ScopeHostReport},
})
rec := httptest.NewRecorder()
handler.HandleConfig(rec, req)
if rec.Code != http.StatusOK {
t.Fatalf("expected status %d, got %d", http.StatusOK, rec.Code)
}
var resp struct {
HostID string `json:"hostId"`
}
if err := json.NewDecoder(rec.Body).Decode(&resp); err != nil {
t.Fatalf("failed to decode response: %v", err)
}
if resp.HostID != "host-1" {
t.Fatalf("expected host id %q, got %q", "host-1", resp.HostID)
}
}
func TestHandleConfigUsesTokenBinding(t *testing.T) {
t.Parallel()