From 51a90260e4298e3b8726731a6ebbaa22f8b2d609 Mon Sep 17 00:00:00 2001 From: XuJiacheng Date: Sat, 28 Mar 2026 15:13:04 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0=20PocketBase=20MiniA?= =?UTF-8?q?pp=20=E5=85=AC=E5=8F=B8=20API=20=E6=96=87=E6=A1=A3=E5=92=8C?= =?UTF-8?q?=E6=96=87=E4=BB=B6=E5=AD=97=E6=AE=B5=E8=BF=81=E7=A7=BB=E8=84=9A?= =?UTF-8?q?=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 新增 openapi-miniapp-company.yaml 文件,定义 tbl_company 的基础 CRUD 接口文档,包括查询、创建、更新和删除公司记录的详细描述和示例。 - 新增 pocketbase.file-fields-to-attachments.js 脚本,用于迁移 PocketBase 中的文件字段到文本字段,并处理 tbl_attachments 集合的公开规则。 --- .codex/skills/openspec-apply-change/SKILL.md | 156 ++++ .../skills/openspec-archive-change/SKILL.md | 114 +++ .codex/skills/openspec-explore/SKILL.md | 288 +++++++ .codex/skills/openspec-propose/SKILL.md | 110 +++ .gitignore | 1 + docs/ARCHIVE.md | 104 +++ docs/api.md | 27 +- docs/pb_document_tables.md | 4 +- docs/tbl_auth_tables.md | 10 +- .../.openspec.yaml | 2 + .../design.md | 77 ++ .../proposal.md | 29 + .../specs/attachment-backed-media/spec.md | 62 ++ .../specs/document-manage-console/spec.md | 57 ++ .../specs/sdk-collection-permissions/spec.md | 57 ++ .../tasks.md | 22 + openspec/changes/probe-change/.openspec.yaml | 2 + .../specs/attachment-backed-media/spec.md | 65 ++ .../specs/document-manage-console/spec.md | 60 ++ .../specs/sdk-collection-permissions/spec.md | 60 ++ pocket-base/README.md | 8 + pocket-base/bai-api-main.pb.js | 6 + pocket-base/bai-web-main.pb.js | 1 + .../bai_api_routes/attachment/upload.js | 2 +- .../sdk-permission/collection-save.js | 14 + .../bai_api_routes/sdk-permission/context.js | 13 + .../sdk-permission/manageplatform-sync.js | 13 + .../sdk-permission/role-delete.js | 14 + .../sdk-permission/role-save.js | 14 + .../sdk-permission/user-role-update.js | 14 + .../middlewares/requestGuards.js | 136 +++- .../services/documentService.js | 85 ++- .../services/sdkPermissionService.js | 560 ++++++++++++++ .../bai_api_shared/services/userService.js | 76 +- .../bai_api_shared/utils/appError.js | 36 +- .../pages/dictionary-manage.js | 140 +++- .../bai_web_pb_hooks/pages/document-manage.js | 286 ++++++- pocket-base/bai_web_pb_hooks/pages/index.js | 4 + .../pages/sdk-permission-manage.js | 717 ++++++++++++++++++ ...6-03-23-pocketbase-hooks-auth-hardening.md | 34 +- pocket-base/spec/openapi-manage.yaml | 95 ++- pocket-base/spec/openapi-miniapp-company.yaml | 449 +++++++++++ pocket-base/spec/openapi-wx.yaml | 34 +- pocket-base/spec/openapi.yaml | 119 ++- script/database_schema.md | 10 +- script/package.json | 3 +- script/pocketbase.documents.js | 13 + .../pocketbase.file-fields-to-attachments.js | 142 ++++ script/pocketbase.js | 10 +- script/pocketbase.newpb.js | 8 +- 50 files changed, 4250 insertions(+), 113 deletions(-) create mode 100644 .codex/skills/openspec-apply-change/SKILL.md create mode 100644 .codex/skills/openspec-archive-change/SKILL.md create mode 100644 .codex/skills/openspec-explore/SKILL.md create mode 100644 .codex/skills/openspec-propose/SKILL.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/.openspec.yaml create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/design.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/proposal.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/specs/attachment-backed-media/spec.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/specs/document-manage-console/spec.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/specs/sdk-collection-permissions/spec.md create mode 100644 openspec/changes/archive/2026-03-28-pocketbase-manage-media-and-sdk-permissions/tasks.md create mode 100644 openspec/changes/probe-change/.openspec.yaml create mode 100644 openspec/specs/attachment-backed-media/spec.md create mode 100644 openspec/specs/document-manage-console/spec.md create mode 100644 openspec/specs/sdk-collection-permissions/spec.md create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/collection-save.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/context.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/manageplatform-sync.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/role-delete.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/role-save.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_routes/sdk-permission/user-role-update.js create mode 100644 pocket-base/bai_api_pb_hooks/bai_api_shared/services/sdkPermissionService.js create mode 100644 pocket-base/bai_web_pb_hooks/pages/sdk-permission-manage.js create mode 100644 pocket-base/spec/openapi-miniapp-company.yaml create mode 100644 script/pocketbase.file-fields-to-attachments.js diff --git a/.codex/skills/openspec-apply-change/SKILL.md b/.codex/skills/openspec-apply-change/SKILL.md new file mode 100644 index 0000000..d474dc1 --- /dev/null +++ b/.codex/skills/openspec-apply-change/SKILL.md @@ -0,0 +1,156 @@ +--- +name: openspec-apply-change +description: Implement tasks from an OpenSpec change. Use when the user wants to start implementing, continue implementation, or work through tasks. +license: MIT +compatibility: Requires openspec CLI. +metadata: + author: openspec + version: "1.0" + generatedBy: "1.2.0" +--- + +Implement tasks from an OpenSpec change. + +**Input**: Optionally specify a change name. 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 - could be proposal/specs/design/tasks or spec/tests/implementation/docs) + - 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 openspec-continue-change + - 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! Ready to archive this change. +``` + +**Output On Pause (Issue Encountered)** + +``` +## Implementation Paused + +**Change:** +**Schema:** +**Progress:** 4/7 tasks complete + +### Issue Encountered + + +**Options:** +1.