From 282c642da6c7bc3636ac43cea748062caf7ef807 Mon Sep 17 00:00:00 2001 From: mahdahar <89adham@gmail.com> Date: Mon, 9 Mar 2026 07:00:12 +0700 Subject: [PATCH] feat: add OpenSpec workflow, Serena integration, User API, and Specimen delete endpoint - Add OpenSpec experimental workflow with commands (opsx-apply, opsx-archive, opsx-explore, opsx-propose) - Add Serena memory system for project context - Implement User API (UserController, UserModel, routes) - Add Specimen delete endpoint - Update Test definitions and Routes - Sync API documentation (OpenAPI) - Archive completed 2026-03-08-backend-specs change --- .gitignore | 4 +- .opencode/command/opsx-apply.md | 149 ++++ .opencode/command/opsx-archive.md | 154 ++++ .opencode/command/opsx-explore.md | 170 +++++ .opencode/command/opsx-propose.md | 103 +++ .../skills/openspec-apply-change/SKILL.md | 156 ++++ .../skills/openspec-archive-change/SKILL.md | 114 +++ .opencode/skills/openspec-explore/SKILL.md | 288 ++++++++ .opencode/skills/openspec-propose/SKILL.md | 110 +++ .serena/.gitignore | 1 + .serena/memories/architecture_structure.md | 419 +++++++++++ .serena/memories/code_style_conventions.md | 481 +++++++++++++ .serena/memories/important_patterns.md | 669 ++++++++++++++++++ .serena/memories/project_overview.md | 55 ++ .serena/memories/suggested_commands.md | 393 ++++++++++ .serena/memories/task_completion_checklist.md | 227 ++++++ .serena/project.yml | 127 ++++ TODO.md | 334 --------- app/Config/Routes.php | 20 +- .../Specimen/SpecimenController.php | 46 ++ app/Controllers/Test/TestsController.php | 3 + app/Controllers/User/UserController.php | 293 ++++++++ ...026-01-01-000004_CreateTestDefinitions.php | 2 +- ...-03-043304_AddRequestableToTestDefSite.php | 28 - app/Database/Seeds/DBSeeder.php | 1 + app/Models/Test/TestDefSiteModel.php | 7 + app/Models/User/UserModel.php | 138 ++++ issues.md | 1 + .../2026-03-08-backend-specs/.openspec.yaml | 2 + .../2026-03-08-backend-specs/QUICKSTART.md | 74 ++ .../2026-03-08-backend-specs/README.md | 55 ++ .../code-templates/Routes-additions.php | 42 ++ .../SpecimenController-delete-method.php | 49 ++ .../code-templates/UserController.php | 290 ++++++++ .../code-templates/UserModel.php | 138 ++++ .../2026-03-08-backend-specs/design.md | 165 +++++ .../2026-03-08-backend-specs/proposal.md | 63 ++ .../specimen-delete.md | 119 ++++ .../archive/2026-03-08-backend-specs/tasks.md | 92 +++ .../2026-03-08-backend-specs/user-api.md | 243 +++++++ openspec/config.yaml | 20 + public/api-docs.bundled.yaml | 399 ++++++++++- public/api-docs.yaml | 12 + public/components/schemas/user.yaml | 121 ++++ public/paths/specimen.yaml | 62 ++ public/paths/tests.yaml | 4 +- public/paths/users.yaml | 212 ++++++ 47 files changed, 6280 insertions(+), 375 deletions(-) create mode 100644 .opencode/command/opsx-apply.md create mode 100644 .opencode/command/opsx-archive.md create mode 100644 .opencode/command/opsx-explore.md create mode 100644 .opencode/command/opsx-propose.md create mode 100644 .opencode/skills/openspec-apply-change/SKILL.md create mode 100644 .opencode/skills/openspec-archive-change/SKILL.md create mode 100644 .opencode/skills/openspec-explore/SKILL.md create mode 100644 .opencode/skills/openspec-propose/SKILL.md create mode 100644 .serena/.gitignore create mode 100644 .serena/memories/architecture_structure.md create mode 100644 .serena/memories/code_style_conventions.md create mode 100644 .serena/memories/important_patterns.md create mode 100644 .serena/memories/project_overview.md create mode 100644 .serena/memories/suggested_commands.md create mode 100644 .serena/memories/task_completion_checklist.md create mode 100644 .serena/project.yml delete mode 100644 TODO.md create mode 100644 app/Controllers/User/UserController.php delete mode 100644 app/Database/Migrations/2026-03-03-043304_AddRequestableToTestDefSite.php create mode 100644 app/Models/User/UserModel.php create mode 100644 issues.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/.openspec.yaml create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/QUICKSTART.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/README.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/code-templates/Routes-additions.php create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/code-templates/SpecimenController-delete-method.php create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/code-templates/UserController.php create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/code-templates/UserModel.php create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/design.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/proposal.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/specimen-delete.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/tasks.md create mode 100644 openspec/changes/archive/2026-03-08-backend-specs/user-api.md create mode 100644 openspec/config.yaml create mode 100644 public/components/schemas/user.yaml create mode 100644 public/paths/users.yaml diff --git a/.gitignore b/.gitignore index 8912ef5..5b495ab 100644 --- a/.gitignore +++ b/.gitignore @@ -124,6 +124,4 @@ _modules/* /results/ /phpunit*.xml -/public/.htaccess - -/.serena \ No newline at end of file +/public/.htaccess \ No newline at end of file diff --git a/.opencode/command/opsx-apply.md b/.opencode/command/opsx-apply.md new file mode 100644 index 0000000..94b8c1e --- /dev/null +++ b/.opencode/command/opsx-apply.md @@ -0,0 +1,149 @@ +--- +description: Implement tasks from an OpenSpec change (Experimental) +--- + +Implement tasks from an OpenSpec change. + +**Input**: Optionally specify a change name (e.g., `/opsx-apply add-auth`). If omitted, check if it can be inferred from conversation context. If vague or ambiguous you MUST prompt for available changes. + +**Steps** + +1. **Select the change** + + If a name is provided, use it. Otherwise: + - Infer from conversation context if the user mentioned a change + - Auto-select if only one active change exists + - If ambiguous, run `openspec list --json` to get available changes and use the **AskUserQuestion tool** to let the user select + + Always announce: "Using change: " and how to override (e.g., `/opsx-apply `). + +2. **Check status to understand the schema** + ```bash + openspec status --change "" --json + ``` + Parse the JSON to understand: + - `schemaName`: The workflow being used (e.g., "spec-driven") + - Which artifact contains the tasks (typically "tasks" for spec-driven, check status for others) + +3. **Get apply instructions** + + ```bash + openspec instructions apply --change "" --json + ``` + + This returns: + - Context file paths (varies by schema) + - Progress (total, complete, remaining) + - Task list with status + - Dynamic instruction based on current state + + **Handle states:** + - If `state: "blocked"` (missing artifacts): show message, suggest using `/opsx-continue` + - If `state: "all_done"`: congratulate, suggest archive + - Otherwise: proceed to implementation + +4. **Read context files** + + Read the files listed in `contextFiles` from the apply instructions output. + The files depend on the schema being used: + - **spec-driven**: proposal, specs, design, tasks + - Other schemas: follow the contextFiles from CLI output + +5. **Show current progress** + + Display: + - Schema being used + - Progress: "N/M tasks complete" + - Remaining tasks overview + - Dynamic instruction from CLI + +6. **Implement tasks (loop until done or blocked)** + + For each pending task: + - Show which task is being worked on + - Make the code changes required + - Keep changes minimal and focused + - Mark task complete in the tasks file: `- [ ]` → `- [x]` + - Continue to next task + + **Pause if:** + - Task is unclear → ask for clarification + - Implementation reveals a design issue → suggest updating artifacts + - Error or blocker encountered → report and wait for guidance + - User interrupts + +7. **On completion or pause, show status** + + Display: + - Tasks completed this session + - Overall progress: "N/M tasks complete" + - If all done: suggest archive + - If paused: explain why and wait for guidance + +**Output During Implementation** + +``` +## Implementing: (schema: ) + +Working on task 3/7: +[...implementation happening...] +✓ Task complete + +Working on task 4/7: +[...implementation happening...] +✓ Task complete +``` + +**Output On Completion** + +``` +## Implementation Complete + +**Change:** +**Schema:** +**Progress:** 7/7 tasks complete ✓ + +### Completed This Session +- [x] Task 1 +- [x] Task 2 +... + +All tasks complete! You can archive this change with `/opsx-archive`. +``` + +**Output On Pause (Issue Encountered)** + +``` +## Implementation Paused + +**Change:** +**Schema:** +**Progress:** 4/7 tasks complete + +### Issue Encountered + + +**Options:** +1.