GET/api/v1/redteam/findings/triage

List red-team finding triage queue

Returns the human-in-loop review queue for adaptive red-team findings. Every red_team_findings INSERT auto-creates a triage row via DB trigger (migration 20260512_red_team_findings_triage). Org-scoped via projectId. Embeds the parent finding's plugin/severity/title so the UI doesn't need a second query per row.

Authentication

Send Authorization: Bearer YOUR_API_KEY on every request. Generate API keys at /dashboard/api-keys.

Parameters

projectId in queryrequired
string
status in query

Comma-separated subset of: open, in_review, dismissed, resolved. Invalid values silently dropped; if nothing valid remains, defaults to 'open,in_review' (active queue).

string
assignee in query

'me' (= caller), 'unassigned' (IS NULL filter), or a UUID. Garbage values dropped.

string
severity in query

Comma-separated subset of: critical, high, medium, low, info. Applied client-side after fetch (severity lives on the joined finding).

string
limit in query
integer
offset in query
integer

Response

200 example

{
  "success": true
}

All status codes

200Triage queue with embedded findings.
400(no description)
401(no description)
403Forbidden — caller is not a member of the project's organization.
429(no description)
500Internal DB error (with masked message).

Code samples

cURL

curl -X GET \
  https://evalguard.ai/api/v1/redteam/findings/triage \
  -H "Authorization: Bearer $EVALGUARD_API_KEY" \

TypeScript

import { EvalGuard } from "@evalguard/sdk";

const client = new EvalGuard({ apiKey: process.env.EVALGUARD_API_KEY });

const response = await client.request({
  method: "GET",
  path: "/api/v1/redteam/findings/triage",
});
console.log(response);

Python

from evalguard import EvalGuard
import os

client = EvalGuard(api_key=os.environ["EVALGUARD_API_KEY"])

response = client.request(method="GET", path="/api/v1/redteam/findings/triage")
print(response)

Go

package main

import (
	"context"
	"fmt"
	"os"

	"github.com/evalguard/evalguard-go"
)

func main() {
	client := evalguard.NewClient(os.Getenv("EVALGUARD_API_KEY"))
	resp, err := client.Request(context.Background(), "GET", "/api/v1/redteam/findings/triage", nil)
	if err != nil { panic(err) }
	fmt.Println(resp)
}

Errors

400401403429500

Other Security endpoints