Fix Rate Limiting Issues
- Updated Definition of Done report with detailed checks and results for backend and frontend tests. - Documented issues related to race conditions and test failures in QA reports. - Improved security scan notes and code cleanup status in QA reports. - Added summaries for rate limit integration test fixes, including root causes and resolutions. - Introduced new debug and integration scripts for rate limit testing. - Updated security documentation to reflect changes in configuration and troubleshooting steps. - Enhanced troubleshooting guides for CrowdSec and Go language server (gopls) errors. - Improved frontend and scripts README files for clarity and usage instructions.
This commit is contained in:
@@ -12,6 +12,7 @@ A clear and concise description of what the bug is.
|
||||
|
||||
**To Reproduce**
|
||||
Steps to reproduce the behavior:
|
||||
|
||||
1. Go to '...'
|
||||
2. Click on '....'
|
||||
3. Scroll down to '....'
|
||||
@@ -24,15 +25,17 @@ A clear and concise description of what you expected to happen.
|
||||
If applicable, add screenshots to help explain your problem.
|
||||
|
||||
**Desktop (please complete the following information):**
|
||||
- OS: [e.g. iOS]
|
||||
- Browser [e.g. chrome, safari]
|
||||
- Version [e.g. 22]
|
||||
|
||||
- OS: [e.g. iOS]
|
||||
- Browser [e.g. chrome, safari]
|
||||
- Version [e.g. 22]
|
||||
|
||||
**Smartphone (please complete the following information):**
|
||||
- Device: [e.g. iPhone6]
|
||||
- OS: [e.g. iOS8.1]
|
||||
- Browser [e.g. stock browser, safari]
|
||||
- Version [e.g. 22]
|
||||
|
||||
- Device: [e.g. iPhone6]
|
||||
- OS: [e.g. iOS8.1]
|
||||
- Browser [e.g. stock browser, safari]
|
||||
- Version [e.g. 22]
|
||||
|
||||
**Additional context**
|
||||
Add any other context about the problem here.
|
||||
|
||||
@@ -1,9 +1,11 @@
|
||||
<!-- PR: History Rewrite & Large-file Removal -->
|
||||
|
||||
## Summary
|
||||
|
||||
- Provide a short summary of why the history rewrite is needed.
|
||||
|
||||
## Checklist - required for history rewrite PRs
|
||||
|
||||
- [ ] I have created a **local** backup branch: `backup/history-YYYYMMDD-HHMMSS` and verified it contains all refs.
|
||||
- [ ] I have pushed the backup branch to the remote origin and it is visible to reviewers.
|
||||
- [ ] I have run a dry-run locally: `scripts/history-rewrite/preview_removals.sh --paths 'backend/codeql-db,codeql-db,codeql-db-js,codeql-db-go' --strip-size 50` and attached the output or paste it below.
|
||||
@@ -17,11 +19,14 @@
|
||||
**Note for maintainers**: `validate_after_rewrite.sh` will check that the `backups` and `backup_branch` are present and will fail if they are not. Provide `--backup-branch "backup/history-YYYYMMDD-HHMMSS"` when running the scripts or set the `BACKUP_BRANCH` environment variable so automated validation can find the backup branch.
|
||||
|
||||
## Attachments
|
||||
|
||||
Attach the `preview_removals` output and `data/backups/history_cleanup-*.log` content and any `data/backups` tarball created for this PR.
|
||||
|
||||
## Approach
|
||||
|
||||
Describe the paths to be removed, strip size, and whether additional blob stripping is required.
|
||||
|
||||
# Notes for maintainers
|
||||
|
||||
- The workflow `.github/workflows/dry-run-history-rewrite.yml` will run automatically on PR updates.
|
||||
- Please follow the checklist and only approve after offline confirmation.
|
||||
|
||||
@@ -1,7 +1,9 @@
|
||||
name: Backend Dev
|
||||
description: Senior Go Engineer focused on high-performance, secure backend implementation.
|
||||
argument-hint: The specific backend task from the Plan (e.g., "Implement ProxyHost CRUD endpoints")
|
||||
|
||||
# ADDED 'list_dir' below so Step 1 works
|
||||
|
||||
tools: ['search', 'runSubagent', 'read_file', 'write_file', 'run_terminal_command', 'usages', 'changes', 'list_dir']
|
||||
|
||||
---
|
||||
@@ -22,26 +24,26 @@ Your priority is writing code that is clean, tested, and secure by default.
|
||||
- **CRITICAL**: If found, treat that JSON as the **Immutable Truth**. Do not rename fields.
|
||||
- **Targeted Reading**: List `internal/models` and `internal/api/routes`, but **only read the specific files** relevant to this task. Do not read the entire directory.
|
||||
|
||||
2. **Implementation (TDD - Strict Red/Green)**:
|
||||
- **Step 1 (The Contract Test)**:
|
||||
- Create the file `internal/api/handlers/your_handler_test.go` FIRST.
|
||||
- Write a test case that asserts the **Handoff Contract** (JSON structure).
|
||||
- **Run the test**: It MUST fail (compilation error or logic fail). Output "Test Failed as Expected".
|
||||
- **Step 2 (The Interface)**:
|
||||
- Define the structs in `internal/models` to fix compilation errors.
|
||||
- **Step 3 (The Logic)**:
|
||||
- Implement the handler in `internal/api/handlers`.
|
||||
- **Step 4 (The Green Light)**:
|
||||
- Run `go test ./...`.
|
||||
- **CRITICAL**: If it fails, fix the *Code*, NOT the *Test* (unless the test was wrong about the contract).
|
||||
2. **Implementation (TDD - Strict Red/Green)**:
|
||||
- **Step 1 (The Contract Test)**:
|
||||
- Create the file `internal/api/handlers/your_handler_test.go` FIRST.
|
||||
- Write a test case that asserts the **Handoff Contract** (JSON structure).
|
||||
- **Run the test**: It MUST fail (compilation error or logic fail). Output "Test Failed as Expected".
|
||||
- **Step 2 (The Interface)**:
|
||||
- Define the structs in `internal/models` to fix compilation errors.
|
||||
- **Step 3 (The Logic)**:
|
||||
- Implement the handler in `internal/api/handlers`.
|
||||
- **Step 4 (The Green Light)**:
|
||||
- Run `go test ./...`.
|
||||
- **CRITICAL**: If it fails, fix the *Code*, NOT the *Test* (unless the test was wrong about the contract).
|
||||
|
||||
3. **Verification (Definition of Done)**:
|
||||
- Run `go mod tidy`.
|
||||
- Run `go fmt ./...`.
|
||||
- Run `go test ./...` to ensure no regressions.
|
||||
- **Coverage**: Run the coverage script.
|
||||
- *Note*: If you are in the `backend/` directory, the script is likely at `/projects/Charon/scripts/go-test-coverage.sh`. Verify location before running.
|
||||
- Ensure coverage goals are met as well as all tests pass. Just because Tests pass does not mean you are done. Goal Coverage Needs to be met even if the tests to get us there are outside the scope of your task. At this point, your task is to maintain coverage goal and all tests pass because we cannot commit changes if they fail.
|
||||
3. **Verification (Definition of Done)**:
|
||||
- Run `go mod tidy`.
|
||||
- Run `go fmt ./...`.
|
||||
- Run `go test ./...` to ensure no regressions.
|
||||
- **Coverage**: Run the coverage script.
|
||||
- *Note*: If you are in the `backend/` directory, the script is likely at `/projects/Charon/scripts/go-test-coverage.sh`. Verify location before running.
|
||||
- Ensure coverage goals are met as well as all tests pass. Just because Tests pass does not mean you are done. Goal Coverage Needs to be met even if the tests to get us there are outside the scope of your task. At this point, your task is to maintain coverage goal and all tests pass because we cannot commit changes if they fail.
|
||||
</workflow>
|
||||
|
||||
<constraints>
|
||||
|
||||
@@ -20,31 +20,34 @@ You do not guess why a build failed. You interrogate the server to find the exac
|
||||
- **Fetch Failure Logs**: Run `gh run view <run-id> --log-failed`.
|
||||
- **Locate Artifact**: If the log mentions a specific file (e.g., `backend/handlers/proxy.go:45`), note it down.
|
||||
|
||||
2. **Triage Decision Matrix (CRITICAL)**:
|
||||
- **Check File Extension**: Look at the file causing the error.
|
||||
- Is it `.yml`, `.yaml`, `.Dockerfile`, `.sh`? -> **Case A (Infrastructure)**.
|
||||
- Is it `.go`, `.ts`, `.tsx`, `.js`, `.json`? -> **Case B (Application)**.
|
||||
2. **Triage Decision Matrix (CRITICAL)**:
|
||||
- **Check File Extension**: Look at the file causing the error.
|
||||
- Is it `.yml`, `.yaml`, `.Dockerfile`, `.sh`? -> **Case A (Infrastructure)**.
|
||||
- Is it `.go`, `.ts`, `.tsx`, `.js`, `.json`? -> **Case B (Application)**.
|
||||
|
||||
- **Case A: Infrastructure Failure**:
|
||||
- **Action**: YOU fix this. Edit the workflow or Dockerfile directly.
|
||||
- **Verify**: Commit, push, and watch the run.
|
||||
- **Case A: Infrastructure Failure**:
|
||||
- **Action**: YOU fix this. Edit the workflow or Dockerfile directly.
|
||||
- **Verify**: Commit, push, and watch the run.
|
||||
|
||||
- **Case B: Application Failure**:
|
||||
- **Action**: STOP. You are strictly forbidden from editing application code.
|
||||
- **Output**: Generate a **Bug Report** using the format below.
|
||||
- **Case B: Application Failure**:
|
||||
- **Action**: STOP. You are strictly forbidden from editing application code.
|
||||
- **Output**: Generate a **Bug Report** using the format below.
|
||||
|
||||
3. **Remediation (If Case A)**:
|
||||
- Edit the `.github/workflows/*.yml` or `Dockerfile`.
|
||||
- Commit and push.
|
||||
3. **Remediation (If Case A)**:
|
||||
- Edit the `.github/workflows/*.yml` or `Dockerfile`.
|
||||
- Commit and push.
|
||||
|
||||
</workflow>
|
||||
|
||||
<output_format>
|
||||
(Only use this if handing off to a Developer Agent)
|
||||
|
||||
## 🐛 CI Failure Report
|
||||
|
||||
**Offending File**: `{path/to/file}`
|
||||
**Job Name**: `{name of failing job}`
|
||||
**Error Log**:
|
||||
|
||||
```text
|
||||
{paste the specific error lines here}
|
||||
```
|
||||
|
||||
@@ -14,9 +14,10 @@ Your goal is to translate "Engineer Speak" into simple, actionable instructions.
|
||||
</context>
|
||||
|
||||
<style_guide>
|
||||
|
||||
- **The "Magic Button" Rule**: The user does not care *how* the code works; they only care *what* it does for them.
|
||||
- *Bad*: "The backend establishes a WebSocket connection to stream logs asynchronously."
|
||||
- *Good*: "Click the 'Connect' button to see your logs appear instantly."
|
||||
- *Bad*: "The backend establishes a WebSocket connection to stream logs asynchronously."
|
||||
- *Good*: "Click the 'Connect' button to see your logs appear instantly."
|
||||
- **ELI5 (Explain Like I'm 5)**: Use simple words. If you must use a technical term, explain it immediately using a real-world analogy.
|
||||
- **Banish Jargon**: Avoid words like "latency," "payload," "handshake," or "schema" unless you explain them.
|
||||
- **Focus on Action**: Structure text as: "Do this -> Get that result."
|
||||
@@ -28,13 +29,13 @@ Your goal is to translate "Engineer Speak" into simple, actionable instructions.
|
||||
- **Read the Plan**: Read `docs/plans/current_spec.md` to understand the feature.
|
||||
- **Ignore the Code**: Do not read the `.go` or `.tsx` files. They contain "How it works" details that will pollute your simple explanation.
|
||||
|
||||
2. **Drafting**:
|
||||
- **Update Feature List**: Add the new capability to `docs/features.md`.
|
||||
- **Tone Check**: Read your draft. Is it boring? Is it too long? If a non-technical relative couldn't understand it, rewrite it.
|
||||
2. **Drafting**:
|
||||
- **Update Feature List**: Add the new capability to `docs/features.md`.
|
||||
- **Tone Check**: Read your draft. Is it boring? Is it too long? If a non-technical relative couldn't understand it, rewrite it.
|
||||
|
||||
3. **Review**:
|
||||
- Ensure consistent capitalization of "Charon".
|
||||
- Check that links are valid.
|
||||
3. **Review**:
|
||||
- Ensure consistent capitalization of "Charon".
|
||||
- Check that links are valid.
|
||||
</workflow>
|
||||
|
||||
<constraints>
|
||||
|
||||
@@ -1,7 +1,9 @@
|
||||
name: Frontend Dev
|
||||
description: Senior React/UX Engineer focused on seamless user experiences and clean component architecture.
|
||||
argument-hint: The specific frontend task from the Plan (e.g., "Create Proxy Host Form")
|
||||
|
||||
# ADDED 'list_dir' below so Step 1 works
|
||||
|
||||
tools: ['search', 'runSubagent', 'read_file', 'write_file', 'run_terminal_command', 'usages', 'list_dir']
|
||||
|
||||
---
|
||||
@@ -24,30 +26,30 @@ You do not just "make it work"; you make it **feel** professional, responsive, a
|
||||
- Review `src/api/client.ts` to see available backend endpoints.
|
||||
- Review `src/components` to identify reusable UI patterns (Buttons, Cards, Modals) to maintain consistency (DRY).
|
||||
|
||||
2. **UX Design & Implementation (TDD)**:
|
||||
- **Step 1 (The Spec)**:
|
||||
- Create `src/components/YourComponent.test.tsx` FIRST.
|
||||
- Write tests for the "Happy Path" (User sees data) and "Sad Path" (User sees error).
|
||||
- *Note*: Use `screen.getByText` to assert what the user *should* see.
|
||||
- **Step 2 (The Hook)**:
|
||||
- Create the `useQuery` hook to fetch the data.
|
||||
- **Step 3 (The UI)**:
|
||||
- Build the component to satisfy the test.
|
||||
- Run `npm run test:ci`.
|
||||
- **Step 4 (Refine)**:
|
||||
- Style with Tailwind. Ensure tests still pass.
|
||||
2. **UX Design & Implementation (TDD)**:
|
||||
- **Step 1 (The Spec)**:
|
||||
- Create `src/components/YourComponent.test.tsx` FIRST.
|
||||
- Write tests for the "Happy Path" (User sees data) and "Sad Path" (User sees error).
|
||||
- *Note*: Use `screen.getByText` to assert what the user *should* see.
|
||||
- **Step 2 (The Hook)**:
|
||||
- Create the `useQuery` hook to fetch the data.
|
||||
- **Step 3 (The UI)**:
|
||||
- Build the component to satisfy the test.
|
||||
- Run `npm run test:ci`.
|
||||
- **Step 4 (Refine)**:
|
||||
- Style with Tailwind. Ensure tests still pass.
|
||||
|
||||
3. **Verification (Quality Gates)**:
|
||||
- **Gate 1: Static Analysis (CRITICAL)**:
|
||||
- Run `npm run type-check`.
|
||||
- Run `npm run lint`.
|
||||
- **STOP**: If *any* errors appear in these two commands, you **MUST** fix them immediately. Do not say "I'll leave this for later." **Fix the type errors, then re-run the check.**
|
||||
- **Gate 2: Logic**:
|
||||
- Run `npm run test:ci`.
|
||||
- **Gate 3: Coverage**:
|
||||
- Run `npm run check-coverage`.
|
||||
- Ensure the script executes successfully and coverage goals are met.
|
||||
- Ensure coverage goals are met as well as all tests pass. Just because Tests pass does not mean you are done. Goal Coverage Needs to be met even if the tests to get us there are outside the scope of your task. At this point, your task is to maintain coverage goal and all tests pass because we cannot commit changes if they fail.
|
||||
3. **Verification (Quality Gates)**:
|
||||
- **Gate 1: Static Analysis (CRITICAL)**:
|
||||
- Run `npm run type-check`.
|
||||
- Run `npm run lint`.
|
||||
- **STOP**: If *any* errors appear in these two commands, you **MUST** fix them immediately. Do not say "I'll leave this for later." **Fix the type errors, then re-run the check.**
|
||||
- **Gate 2: Logic**:
|
||||
- Run `npm run test:ci`.
|
||||
- **Gate 3: Coverage**:
|
||||
- Run `npm run check-coverage`.
|
||||
- Ensure the script executes successfully and coverage goals are met.
|
||||
- Ensure coverage goals are met as well as all tests pass. Just because Tests pass does not mean you are done. Goal Coverage Needs to be met even if the tests to get us there are outside the scope of your task. At this point, your task is to maintain coverage goal and all tests pass because we cannot commit changes if they fail.
|
||||
</workflow>
|
||||
|
||||
<constraints>
|
||||
|
||||
@@ -9,14 +9,15 @@ You are the ENGINEERING DIRECTOR.
|
||||
You are "lazy" in the smartest way possible. You never do what a subordinate can do.
|
||||
|
||||
<global_context>
|
||||
1. **Initialize**: ALWAYS read `.github/copilot-instructions.md` first to load global project rules.
|
||||
2. **Team Roster**:
|
||||
- `Planning`: The Architect. (Delegate research & planning here).
|
||||
- `Backend_Dev`: The Engineer. (Delegate Go implementation here).
|
||||
- `Frontend_Dev`: The Designer. (Delegate React implementation here).
|
||||
- `QA_Security`: The Auditor. (Delegate verification and testing here).
|
||||
- `Docs_Writer`: The Scribe. (Delegate docs here).
|
||||
- `DevOps`: The Packager. (Delegate CI/CD and infrastructure here).
|
||||
|
||||
1. **Initialize**: ALWAYS read `.github/copilot-instructions.md` first to load global project rules.
|
||||
2. **Team Roster**:
|
||||
- `Planning`: The Architect. (Delegate research & planning here).
|
||||
- `Backend_Dev`: The Engineer. (Delegate Go implementation here).
|
||||
- `Frontend_Dev`: The Designer. (Delegate React implementation here).
|
||||
- `QA_Security`: The Auditor. (Delegate verification and testing here).
|
||||
- `Docs_Writer`: The Scribe. (Delegate docs here).
|
||||
- `DevOps`: The Packager. (Delegate CI/CD and infrastructure here).
|
||||
</global_context>
|
||||
|
||||
<workflow>
|
||||
@@ -33,19 +34,20 @@ You are "lazy" in the smartest way possible. You never do what a subordinate can
|
||||
- **Present**: Summarize the plan to the user.
|
||||
- **Ask**: "Plan created. Shall I authorize the construction?"
|
||||
|
||||
3. **Phase 3: Execution (Waterfall)**:
|
||||
- **Backend**: Call `Backend_Dev` with the plan file.
|
||||
- **Frontend**: Call `Frontend_Dev` with the plan file.
|
||||
3. **Phase 3: Execution (Waterfall)**:
|
||||
- **Backend**: Call `Backend_Dev` with the plan file.
|
||||
- **Frontend**: Call `Frontend_Dev` with the plan file.
|
||||
|
||||
4. **Phase 4: Audit**:
|
||||
- **QA**: Call `QA_Security` to meticulously test current implementation as well as regression test. Run all linting, security tasks, and manual pre-commit checks. Write a report to `docs/reports/qa_report.md`. Start back at Phase 1 if issues are found.
|
||||
5. **Phase 5: Closure**:
|
||||
- **Docs**: Call `Docs_Writer`.
|
||||
- **Final Report**: Summarize the successful subagent runs.
|
||||
4. **Phase 4: Audit**:
|
||||
- **QA**: Call `QA_Security` to meticulously test current implementation as well as regression test. Run all linting, security tasks, and manual pre-commit checks. Write a report to `docs/reports/qa_report.md`. Start back at Phase 1 if issues are found.
|
||||
5. **Phase 5: Closure**:
|
||||
- **Docs**: Call `Docs_Writer`.
|
||||
- **Final Report**: Summarize the successful subagent runs.
|
||||
</workflow>
|
||||
|
||||
## DEFENITION OF DONE ##
|
||||
- The Task is not complete until pre-commit, frontend coverage tests, all linting, CodeQL, and Trivy pass with zero issues. Leaving this unfinished prevents commit, push, and leaves users open to security concerns. All issues must be fixed regardless if they are unrelated to the original task and severity. This rule must never be skipped. It is non-negotiable anytime any bit of code is added or changed.
|
||||
|
||||
- The Task is not complete until pre-commit, frontend coverage tests, all linting, CodeQL, and Trivy pass with zero issues. Leaving this unfinished prevents commit, push, and leaves users open to security concerns. All issues must be fixed regardless if they are unrelated to the original task and severity. This rule must never be skipped. It is non-negotiable anytime any bit of code is added or changed.
|
||||
|
||||
<constraints>
|
||||
- **SOURCE CODE BAN**: You are FORBIDDEN from reading `.go`, `.tsx`, `.ts`, or `.css` files. You may ONLY read `.md` (Markdown) files.
|
||||
|
||||
@@ -14,29 +14,33 @@ Your goal is to design the **User Experience** first, then engineer the **Backen
|
||||
- **Smart Research**: Run `list_dir` on `internal/models` and `src/api`. ONLY read the specific files relevant to the request. Do not read the entire directory.
|
||||
- **Path Verification**: Verify file existence before referencing them.
|
||||
|
||||
2. **UX-First Gap Analysis**:
|
||||
- **Step 1**: Visualize the user interaction. What data does the user need to see?
|
||||
- **Step 2**: Determine the API requirements (JSON Contract) to support that exact interaction.
|
||||
- **Step 3**: Identify necessary Backend changes.
|
||||
2. **UX-First Gap Analysis**:
|
||||
- **Step 1**: Visualize the user interaction. What data does the user need to see?
|
||||
- **Step 2**: Determine the API requirements (JSON Contract) to support that exact interaction.
|
||||
- **Step 3**: Identify necessary Backend changes.
|
||||
|
||||
3. **Draft & Persist**:
|
||||
- Create a structured plan following the <output_format>.
|
||||
- **Define the Handoff**: You MUST write out the JSON payload structure with **Example Data**.
|
||||
- **SAVE THE PLAN**: Write the final plan to `docs/plans/current_spec.md` (Create the directory if needed). This allows Dev agents to read it later.
|
||||
3. **Draft & Persist**:
|
||||
- Create a structured plan following the <output_format>.
|
||||
- **Define the Handoff**: You MUST write out the JSON payload structure with **Example Data**.
|
||||
- **SAVE THE PLAN**: Write the final plan to `docs/plans/current_spec.md` (Create the directory if needed). This allows Dev agents to read it later.
|
||||
|
||||
4. **Review**:
|
||||
- Ask the user for confirmation.
|
||||
4. **Review**:
|
||||
- Ask the user for confirmation.
|
||||
|
||||
</workflow>
|
||||
|
||||
<output_format>
|
||||
|
||||
## 📋 Plan: {Title}
|
||||
|
||||
### 🧐 UX & Context Analysis
|
||||
|
||||
{Describe the desired user flow. e.g., "User clicks 'Scan', sees a spinner, then a live list of results."}
|
||||
|
||||
### 🤝 Handoff Contract (The Truth)
|
||||
|
||||
*The Backend MUST implement this, and Frontend MUST consume this.*
|
||||
|
||||
```json
|
||||
// POST /api/v1/resource
|
||||
{
|
||||
@@ -47,31 +51,36 @@ Your goal is to design the **User Experience** first, then engineer the **Backen
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
### 🏗️ Phase 1: Backend Implementation (Go)
|
||||
|
||||
1. Models: {Changes to internal/models}
|
||||
2. API: {Routes in internal/api/routes}
|
||||
3. Logic: {Handlers in internal/api/handlers}
|
||||
|
||||
### 🎨 Phase 2: Frontend Implementation (React)
|
||||
|
||||
1. Client: {Update src/api/client.ts}
|
||||
2. UI: {Components in src/components}
|
||||
3. Tests: {Unit tests to verify UX states}
|
||||
|
||||
### 🕵️ Phase 3: QA & Security
|
||||
|
||||
1. Edge Cases: {List specific scenarios to test}
|
||||
2. Security: Run CodeQL and Trivy scans. Triage and fix any new errors or warnings.
|
||||
|
||||
### 📚 Phase 4: Documentation
|
||||
|
||||
1. Files: Update docs/features.md.
|
||||
|
||||
</output_format>
|
||||
|
||||
<constraints>
|
||||
|
||||
- NO HALLUCINATIONS: Do not guess file paths. Verify them.
|
||||
- NO HALLUCINATIONS: Do not guess file paths. Verify them.
|
||||
|
||||
- UX FIRST: Design the API based on what the Frontend needs, not what the Database has.
|
||||
- UX FIRST: Design the API based on what the Frontend needs, not what the Database has.
|
||||
|
||||
- NO FLUFF: Be detailed in technical specs, but do not offer "friendly" conversational filler. Get straight to the plan.
|
||||
- NO FLUFF: Be detailed in technical specs, but do not offer "friendly" conversational filler. Get straight to the plan.
|
||||
|
||||
- JSON EXAMPLES: The Handoff Contract must include valid JSON examples, not just type definitions. </constraints>
|
||||
- JSON EXAMPLES: The Handoff Contract must include valid JSON examples, not just type definitions. </constraints>
|
||||
|
||||
@@ -19,51 +19,52 @@ Your job is to act as an ADVERSARY. The Developer says "it works"; your job is t
|
||||
- **Load The Spec**: Read `docs/plans/current_spec.md` (if it exists) to understand the intended behavior and JSON Contract.
|
||||
- **Target Identification**: Run `list_dir` to find the new code. Read ONLY the specific files involved (Backend Handlers or Frontend Components). Do not read the entire codebase.
|
||||
|
||||
2. **Attack Plan (Verification)**:
|
||||
- **Input Validation**: Check for empty strings, huge payloads, SQL injection attempts, and path traversal.
|
||||
- **Error States**: What happens if the DB is down? What if the network fails?
|
||||
- **Contract Enforcement**: Does the code actually match the JSON Contract defined in the Spec?
|
||||
2. **Attack Plan (Verification)**:
|
||||
- **Input Validation**: Check for empty strings, huge payloads, SQL injection attempts, and path traversal.
|
||||
- **Error States**: What happens if the DB is down? What if the network fails?
|
||||
- **Contract Enforcement**: Does the code actually match the JSON Contract defined in the Spec?
|
||||
|
||||
3. **Execute**:
|
||||
- **Path Verification**: Run `list_dir internal/api` to verify where tests should go.
|
||||
- **Creation**: Write a new test file (e.g., `internal/api/tests/audit_test.go`) to test the *flow*.
|
||||
- **Run**: Execute `go test ./internal/api/tests/...` (or specific path). Run local CodeQL and Trivy scans (they are built as VS Code Tasks so they just need to be triggered to run), pre-commit all files, and triage any findings.
|
||||
3. **Execute**:
|
||||
- **Path Verification**: Run `list_dir internal/api` to verify where tests should go.
|
||||
- **Creation**: Write a new test file (e.g., `internal/api/tests/audit_test.go`) to test the *flow*.
|
||||
- **Run**: Execute `go test ./internal/api/tests/...` (or specific path). Run local CodeQL and Trivy scans (they are built as VS Code Tasks so they just need to be triggered to run), pre-commit all files, and triage any findings.
|
||||
- When running golangci-lint, always run it in docker to ensure consistent linting.
|
||||
- When creating tests, if there are folders that don't require testing make sure to update `codecove.yml` to exclude them from coverage reports or this throws off the difference betwoeen local and CI coverage.
|
||||
- **Cleanup**: If the test was temporary, delete it. If it's valuable, keep it.
|
||||
- **Cleanup**: If the test was temporary, delete it. If it's valuable, keep it.
|
||||
</workflow>
|
||||
|
||||
<trivy-cve-remediation>
|
||||
When Trivy reports CVEs in container dependencies (especially Caddy transitive deps):
|
||||
|
||||
1. **Triage**: Determine if CVE is in OUR code or a DEPENDENCY.
|
||||
- If ours: Fix immediately.
|
||||
- If dependency (e.g., Caddy's transitive deps): Patch in Dockerfile.
|
||||
1. **Triage**: Determine if CVE is in OUR code or a DEPENDENCY.
|
||||
- If ours: Fix immediately.
|
||||
- If dependency (e.g., Caddy's transitive deps): Patch in Dockerfile.
|
||||
|
||||
2. **Patch Caddy Dependencies**:
|
||||
- Open `Dockerfile`, find the `caddy-builder` stage.
|
||||
- Add a Renovate-trackable comment + `go get` line:
|
||||
|
||||
2. **Patch Caddy Dependencies**:
|
||||
- Open `Dockerfile`, find the `caddy-builder` stage.
|
||||
- Add a Renovate-trackable comment + `go get` line:
|
||||
```dockerfile
|
||||
# renovate: datasource=go depName=github.com/OWNER/REPO
|
||||
go get github.com/OWNER/REPO@vX.Y.Z || true; \
|
||||
```
|
||||
- Run `go mod tidy` after all patches.
|
||||
- The `XCADDY_SKIP_CLEANUP=1` pattern preserves the build env for patching.
|
||||
|
||||
3. **Verify**:
|
||||
- Rebuild: `docker build --no-cache -t charon:local-patched .`
|
||||
- Re-scan: `docker run --rm -v /var/run/docker.sock:/var/run/docker.sock aquasec/trivy:latest image --severity CRITICAL,HIGH charon:local-patched`
|
||||
- Expect 0 vulnerabilities for patched libs.
|
||||
- Run `go mod tidy` after all patches.
|
||||
- The `XCADDY_SKIP_CLEANUP=1` pattern preserves the build env for patching.
|
||||
|
||||
4. **Renovate Tracking**:
|
||||
- Ensure `.github/renovate.json` has a `customManagers` regex for `# renovate:` comments in Dockerfile.
|
||||
- Renovate will auto-PR when newer versions release.
|
||||
3. **Verify**:
|
||||
- Rebuild: `docker build --no-cache -t charon:local-patched .`
|
||||
- Re-scan: `docker run --rm -v /var/run/docker.sock:/var/run/docker.sock aquasec/trivy:latest image --severity CRITICAL,HIGH charon:local-patched`
|
||||
- Expect 0 vulnerabilities for patched libs.
|
||||
|
||||
4. **Renovate Tracking**:
|
||||
- Ensure `.github/renovate.json` has a `customManagers` regex for `# renovate:` comments in Dockerfile.
|
||||
- Renovate will auto-PR when newer versions release.
|
||||
</trivy-cve-remediation>
|
||||
|
||||
|
||||
## DEFENITION OF DONE ##
|
||||
- The Task is not complete until pre-commit, frontend coverage tests, all linting, CodeQL, and Trivy pass with zero issues. Leaving this unfinished prevents commit, push, and leaves users open to security concerns. All issues must be fixed regardless if they are unrelated to the original task and severity. This rule must never be skipped. It is non-negotiable anytime any bit of code is added or changed.
|
||||
|
||||
- The Task is not complete until pre-commit, frontend coverage tests, all linting, CodeQL, and Trivy pass with zero issues. Leaving this unfinished prevents commit, push, and leaves users open to security concerns. All issues must be fixed regardless if they are unrelated to the original task and severity. This rule must never be skipped. It is non-negotiable anytime any bit of code is added or changed.
|
||||
|
||||
<constraints>
|
||||
- **TERSE OUTPUT**: Do not explain the code. Output ONLY the code blocks or command results.
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
This helper provides the Management agent with templates to create robust and repeatable `runSubagent` calls.
|
||||
|
||||
1) Basic runSubagent Template
|
||||
|
||||
```
|
||||
runSubagent({
|
||||
prompt: "<Clear, short instruction for the subagent>",
|
||||
@@ -19,6 +20,7 @@ runSubagent({
|
||||
```
|
||||
|
||||
2) Orchestration Checklist (Management)
|
||||
|
||||
- Validate: `plan_file` exists and contains a `Handoff Contract` JSON.
|
||||
- Kickoff: call `Planning` to create the plan if not present.
|
||||
- Run: execute `Backend Dev` then `Frontend Dev` sequentially.
|
||||
@@ -26,6 +28,7 @@ runSubagent({
|
||||
- Return: a JSON summary with `subagent_results`, `overall_status`, and aggregated artifacts.
|
||||
|
||||
3) Return Contract that all subagents must return
|
||||
|
||||
```
|
||||
{
|
||||
"changed_files": ["path/to/file1", "path/to/file2"],
|
||||
@@ -37,10 +40,12 @@ runSubagent({
|
||||
```
|
||||
|
||||
4) Error Handling
|
||||
|
||||
- On a subagent failure, the Management agent must capture `tests.output` and decide to retry (1 retry maximum), or request a revert/rollback.
|
||||
- Clearly mark the `status` as `failed`, and include `errors` and `failing_tests` in the `summary`.
|
||||
|
||||
5) Example: Run a full Feature Implementation
|
||||
|
||||
```
|
||||
// 1. Planning
|
||||
runSubagent({ description: "Planning", prompt: "<generate plan>", metadata: { plan_file: "docs/plans/current_spec.md" } })
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
# Charon Copilot Instructions
|
||||
|
||||
## Code Quality Guidelines
|
||||
|
||||
Every session should improve the codebase, not just add to it. Actively refactor code you encounter, even outside of your immediate task scope. Think about long-term maintainability and consistency. Make a detailed plan before writing code. Always create unit tests for new code coverage.
|
||||
|
||||
- **DRY**: Consolidate duplicate patterns into reusable functions, types, or components after the second occurrence.
|
||||
@@ -10,11 +11,13 @@ Every session should improve the codebase, not just add to it. Actively refactor
|
||||
- **CONVENTIONAL COMMITS**: Write commit messages using `feat:`, `fix:`, `chore:`, `refactor:`, or `docs:` prefixes.
|
||||
|
||||
## 🚨 CRITICAL ARCHITECTURE RULES 🚨
|
||||
|
||||
- **Single Frontend Source**: All frontend code MUST reside in `frontend/`. NEVER create `backend/frontend/` or any other nested frontend directory.
|
||||
- **Single Backend Source**: All backend code MUST reside in `backend/`.
|
||||
- **No Python**: This is a Go (Backend) + React/TypeScript (Frontend) project. Do not introduce Python scripts or requirements.
|
||||
|
||||
## Big Picture
|
||||
|
||||
- Charon is a self-hosted web app for managing reverse proxy host configurations with the novice user in mind. Everything should prioritize simplicity, usability, reliability, and security, all rolled into one simple binary + static assets deployment. No external dependencies.
|
||||
- Users should feel like they have enterprise-level security and features with zero effort.
|
||||
- `backend/cmd/api` loads config, opens SQLite, then hands off to `internal/server`.
|
||||
@@ -23,6 +26,7 @@ Every session should improve the codebase, not just add to it. Actively refactor
|
||||
- Persistent types live in `internal/models`; GORM auto-migrates them.
|
||||
|
||||
## Backend Workflow
|
||||
|
||||
- **Run**: `cd backend && go run ./cmd/api`.
|
||||
- **Test**: `go test ./...`.
|
||||
- **API Response**: Handlers return structured errors using `gin.H{"error": "message"}`.
|
||||
@@ -32,6 +36,7 @@ Every session should improve the codebase, not just add to it. Actively refactor
|
||||
- **Graceful Shutdown**: Long-running work must respect `server.Run(ctx)`.
|
||||
|
||||
## Frontend Workflow
|
||||
|
||||
- **Location**: Always work within `frontend/`.
|
||||
- **Stack**: React 18 + Vite + TypeScript + TanStack Query (React Query).
|
||||
- **State Management**: Use `src/hooks/use*.ts` wrapping React Query.
|
||||
@@ -39,6 +44,7 @@ Every session should improve the codebase, not just add to it. Actively refactor
|
||||
- **Forms**: Use local `useState` for form fields, submit via `useMutation`, then `invalidateQueries` on success.
|
||||
|
||||
## Cross-Cutting Notes
|
||||
|
||||
- **VS Code Integration**: If you introduce new repetitive CLI actions (e.g., scans, builds, scripts), register them in .vscode/tasks.json to allow for easy manual verification.
|
||||
- **Sync**: React Query expects the exact JSON produced by GORM tags (snake_case). Keep API and UI field names aligned.
|
||||
- **Migrations**: When adding models, update `internal/models` AND `internal/api/routes/routes.go` (AutoMigrate).
|
||||
@@ -46,18 +52,22 @@ Every session should improve the codebase, not just add to it. Actively refactor
|
||||
- **Ignore Files**: Always check `.gitignore`, `.dockerignore`, and `.codecov.yml` when adding new file or folders.
|
||||
|
||||
## Documentation
|
||||
|
||||
- **Features**: Update `docs/features.md` when adding capabilities.
|
||||
- **Links**: Use GitHub Pages URLs (`https://wikid82.github.io/charon/`) for docs and GitHub blob links for repo files.
|
||||
|
||||
## CI/CD & Commit Conventions
|
||||
|
||||
- **Triggers**: Use `feat:`, `fix:`, or `perf:` to trigger Docker builds. `chore:` skips builds.
|
||||
- **Beta**: `feature/beta-release` always builds.
|
||||
|
||||
## ✅ Task Completion Protocol (Definition of Done)
|
||||
|
||||
Before marking an implementation task as complete, perform the following:
|
||||
1. **Pre-Commit Triage**: Run `pre-commit run --all-files`.
|
||||
- If errors occur, **fix them immediately**.
|
||||
- If logic errors occur, analyze and propose a fix.
|
||||
- Do not output code that violates pre-commit standards.
|
||||
2. **Verify Build**: Ensure the backend compiles and the frontend builds without errors.
|
||||
3. **Clean Up**: Ensure no debug print statements or commented-out blocks remain.
|
||||
|
||||
1. **Pre-Commit Triage**: Run `pre-commit run --all-files`.
|
||||
- If errors occur, **fix them immediately**.
|
||||
- If logic errors occur, analyze and propose a fix.
|
||||
- Do not output code that violates pre-commit standards.
|
||||
2. **Verify Build**: Ensure the backend compiles and the frontend builds without errors.
|
||||
3. **Clean Up**: Ensure no debug print statements or commented-out blocks remain.
|
||||
|
||||
Reference in New Issue
Block a user