@autobe/agent 0.25.5 → 0.25.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/lib/constants/AutoBeSystemPromptConstant.d.ts +12 -13
  2. package/lib/constants/AutoBeSystemPromptConstant.js.map +1 -1
  3. package/lib/context/AutoBeTokenUsage.d.ts +2 -2
  4. package/lib/context/AutoBeTokenUsage.js.map +1 -1
  5. package/lib/context/{IAutoBeApplication.d.ts → IAutoBeFacadeApplication.d.ts} +15 -83
  6. package/lib/context/{IAutoBeApplicationProps.js → IAutoBeFacadeApplication.js} +1 -1
  7. package/lib/context/IAutoBeFacadeApplication.js.map +1 -0
  8. package/lib/context/{IAutoBeApplicationProps.d.ts → IAutoBeFacadeApplicationProps.d.ts} +1 -1
  9. package/lib/context/{IAutoBeApplication.js → IAutoBeFacadeApplicationProps.js} +1 -1
  10. package/lib/context/IAutoBeFacadeApplicationProps.js.map +1 -0
  11. package/lib/context/{IAutoBeApplicationResult.d.ts → IAutoBeFacadeApplicationResult.d.ts} +1 -1
  12. package/lib/context/{IAutoBeApplicationResult.js → IAutoBeFacadeApplicationResult.js} +1 -1
  13. package/lib/context/IAutoBeFacadeApplicationResult.js.map +1 -0
  14. package/lib/factory/createAgenticaHistory.js +3 -1
  15. package/lib/factory/createAgenticaHistory.js.map +1 -1
  16. package/lib/factory/createAutoBeApplication.js +38 -76
  17. package/lib/factory/createAutoBeApplication.js.map +1 -1
  18. package/lib/factory/createAutoBeContext.js +10 -11
  19. package/lib/factory/createAutoBeContext.js.map +1 -1
  20. package/lib/index.mjs +167 -246
  21. package/lib/index.mjs.map +1 -1
  22. package/lib/orchestrate/analyze/histories/transformAnalyzeReviewHistories.js +0 -1
  23. package/lib/orchestrate/analyze/histories/transformAnalyzeReviewHistories.js.map +1 -1
  24. package/lib/orchestrate/analyze/histories/transformAnalyzeScenarioHistories.d.ts +1 -1
  25. package/lib/orchestrate/analyze/histories/transformAnalyzeScenarioHistories.js +3 -18
  26. package/lib/orchestrate/analyze/histories/transformAnalyzeScenarioHistories.js.map +1 -1
  27. package/lib/orchestrate/analyze/histories/transformAnalyzeWriteHistories.d.ts +0 -1
  28. package/lib/orchestrate/analyze/histories/transformAnalyzeWriteHistories.js +1 -13
  29. package/lib/orchestrate/analyze/histories/transformAnalyzeWriteHistories.js.map +1 -1
  30. package/lib/orchestrate/analyze/orchestrateAnalyze.d.ts +1 -2
  31. package/lib/orchestrate/analyze/orchestrateAnalyze.js +2 -4
  32. package/lib/orchestrate/analyze/orchestrateAnalyze.js.map +1 -1
  33. package/lib/orchestrate/analyze/orchestrateAnalyzeScenario.d.ts +1 -1
  34. package/lib/orchestrate/analyze/orchestrateAnalyzeScenario.js +2 -2
  35. package/lib/orchestrate/analyze/orchestrateAnalyzeScenario.js.map +1 -1
  36. package/lib/orchestrate/analyze/orchestrateAnalyzeWrite.d.ts +0 -1
  37. package/lib/orchestrate/analyze/orchestrateAnalyzeWrite.js.map +1 -1
  38. package/lib/orchestrate/facade/transformFacadeStateMessage.js +1 -1
  39. package/lib/orchestrate/facade/transformFacadeStateMessage.js.map +1 -1
  40. package/lib/orchestrate/interface/histories/transformInterfaceAssetHistories.js +0 -4
  41. package/lib/orchestrate/interface/histories/transformInterfaceAssetHistories.js.map +1 -1
  42. package/lib/orchestrate/interface/histories/transformInterfaceAuthorizationsHistories.js +10 -7
  43. package/lib/orchestrate/interface/histories/transformInterfaceAuthorizationsHistories.js.map +1 -1
  44. package/lib/orchestrate/interface/histories/transformInterfaceCommonHistories.d.ts +3 -0
  45. package/lib/orchestrate/interface/histories/{transformInterfaceCommonPrerequisiteHistories.js → transformInterfaceCommonHistories.js} +4 -4
  46. package/lib/orchestrate/interface/histories/transformInterfaceCommonHistories.js.map +1 -0
  47. package/lib/orchestrate/interface/histories/transformInterfaceComplementHistories.js +12 -9
  48. package/lib/orchestrate/interface/histories/transformInterfaceComplementHistories.js.map +1 -1
  49. package/lib/orchestrate/interface/histories/transformInterfaceEndpointHistories.js +10 -7
  50. package/lib/orchestrate/interface/histories/transformInterfaceEndpointHistories.js.map +1 -1
  51. package/lib/orchestrate/interface/histories/transformInterfaceEndpointsReviewHistories.js +1 -1
  52. package/lib/orchestrate/interface/histories/transformInterfaceEndpointsReviewHistories.js.map +1 -1
  53. package/lib/orchestrate/interface/histories/transformInterfaceGroupHistories.js +13 -10
  54. package/lib/orchestrate/interface/histories/transformInterfaceGroupHistories.js.map +1 -1
  55. package/lib/orchestrate/interface/histories/transformInterfaceOperationHistories.js +10 -7
  56. package/lib/orchestrate/interface/histories/transformInterfaceOperationHistories.js.map +1 -1
  57. package/lib/orchestrate/interface/histories/transformInterfaceOperationsReviewHistories.js +1 -1
  58. package/lib/orchestrate/interface/histories/transformInterfaceOperationsReviewHistories.js.map +1 -1
  59. package/lib/orchestrate/interface/histories/transformInterfaceSchemaHistories.js +10 -7
  60. package/lib/orchestrate/interface/histories/transformInterfaceSchemaHistories.js.map +1 -1
  61. package/lib/orchestrate/interface/histories/transformInterfaceSchemasReviewHistories.js +1 -1
  62. package/lib/orchestrate/interface/histories/transformInterfaceSchemasReviewHistories.js.map +1 -1
  63. package/lib/orchestrate/interface/orchestrateInterface.d.ts +2 -2
  64. package/lib/orchestrate/interface/orchestrateInterface.js.map +1 -1
  65. package/lib/orchestrate/prisma/histories/transformPrismaComponentsHistories.js +10 -5
  66. package/lib/orchestrate/prisma/histories/transformPrismaComponentsHistories.js.map +1 -1
  67. package/lib/orchestrate/prisma/histories/transformPrismaReviewHistories.js +2 -2
  68. package/lib/orchestrate/prisma/histories/transformPrismaReviewHistories.js.map +1 -1
  69. package/lib/orchestrate/prisma/histories/transformPrismaSchemaHistories.js +9 -6
  70. package/lib/orchestrate/prisma/histories/transformPrismaSchemaHistories.js.map +1 -1
  71. package/lib/orchestrate/prisma/orchestratePrisma.d.ts +2 -2
  72. package/lib/orchestrate/prisma/orchestratePrisma.js.map +1 -1
  73. package/lib/orchestrate/realize/orchestrateRealize.d.ts +2 -2
  74. package/lib/orchestrate/realize/orchestrateRealize.js.map +1 -1
  75. package/lib/orchestrate/test/histories/transformTestScenarioHistories.js +8 -5
  76. package/lib/orchestrate/test/histories/transformTestScenarioHistories.js.map +1 -1
  77. package/lib/orchestrate/test/histories/transformTestScenarioReviewHistories.js +8 -5
  78. package/lib/orchestrate/test/histories/transformTestScenarioReviewHistories.js.map +1 -1
  79. package/lib/orchestrate/test/histories/transformTestWriteHistories.js +8 -5
  80. package/lib/orchestrate/test/histories/transformTestWriteHistories.js.map +1 -1
  81. package/lib/orchestrate/test/orchestrateTest.d.ts +2 -2
  82. package/lib/orchestrate/test/orchestrateTest.js.map +1 -1
  83. package/package.json +6 -6
  84. package/src/constants/AutoBeSystemPromptConstant.ts +12 -13
  85. package/src/context/AutoBeTokenUsage.ts +2 -2
  86. package/src/context/{IAutoBeApplication.ts → IAutoBeFacadeApplication.ts} +15 -83
  87. package/src/context/{IAutoBeApplicationProps.ts → IAutoBeFacadeApplicationProps.ts} +1 -1
  88. package/src/context/{IAutoBeApplicationResult.ts → IAutoBeFacadeApplicationResult.ts} +1 -1
  89. package/src/factory/createAgenticaHistory.ts +5 -4
  90. package/src/factory/createAutoBeApplication.ts +6 -6
  91. package/src/factory/createAutoBeContext.ts +2 -3
  92. package/src/orchestrate/analyze/histories/transformAnalyzeReviewHistories.ts +0 -1
  93. package/src/orchestrate/analyze/histories/transformAnalyzeScenarioHistories.ts +0 -16
  94. package/src/orchestrate/analyze/histories/transformAnalyzeWriteHistories.ts +0 -13
  95. package/src/orchestrate/analyze/orchestrateAnalyze.ts +71 -74
  96. package/src/orchestrate/analyze/orchestrateAnalyzeScenario.ts +1 -2
  97. package/src/orchestrate/analyze/orchestrateAnalyzeWrite.ts +0 -1
  98. package/src/orchestrate/interface/histories/transformInterfaceAssetHistories.ts +0 -4
  99. package/src/orchestrate/interface/histories/transformInterfaceAuthorizationsHistories.ts +9 -6
  100. package/src/orchestrate/interface/histories/{transformInterfaceCommonPrerequisiteHistories.ts → transformInterfaceCommonHistories.ts} +1 -1
  101. package/src/orchestrate/interface/histories/transformInterfaceComplementHistories.ts +9 -6
  102. package/src/orchestrate/interface/histories/transformInterfaceEndpointHistories.ts +9 -6
  103. package/src/orchestrate/interface/histories/transformInterfaceGroupHistories.ts +11 -10
  104. package/src/orchestrate/interface/histories/transformInterfaceOperationHistories.ts +9 -6
  105. package/src/orchestrate/interface/histories/transformInterfaceSchemaHistories.ts +9 -6
  106. package/src/orchestrate/interface/orchestrateInterface.ts +2 -2
  107. package/src/orchestrate/prisma/histories/transformPrismaComponentsHistories.ts +9 -4
  108. package/src/orchestrate/prisma/histories/transformPrismaSchemaHistories.ts +8 -5
  109. package/src/orchestrate/prisma/orchestratePrisma.ts +2 -2
  110. package/src/orchestrate/realize/orchestrateRealize.ts +2 -2
  111. package/src/orchestrate/test/histories/transformTestScenarioHistories.ts +8 -5
  112. package/src/orchestrate/test/histories/transformTestScenarioReviewHistories.ts +8 -5
  113. package/src/orchestrate/test/histories/transformTestWriteHistories.ts +8 -5
  114. package/src/orchestrate/test/orchestrateTest.ts +2 -2
  115. package/lib/context/IAutoBeApplication.js.map +0 -1
  116. package/lib/context/IAutoBeApplicationProps.js.map +0 -1
  117. package/lib/context/IAutoBeApplicationResult.js.map +0 -1
  118. package/lib/orchestrate/interface/histories/transformInterfaceCommonPrerequisiteHistories.d.ts +0 -3
  119. package/lib/orchestrate/interface/histories/transformInterfaceCommonPrerequisiteHistories.js.map +0 -1
@@ -9,7 +9,7 @@ const transformInterfaceEndpointHistories = (props) => [
9
9
  type: "systemMessage",
10
10
  id: (0, uuid_1.v7)(),
11
11
  created_at: new Date().toISOString(),
12
- text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Apply these instructions when designing endpoints for the specified group. Consider the specified URL patterns, HTTP methods, and resource organization. If the instructions are not relevant to this specific endpoint group, you may ignore them.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
12
+ text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Follow these instructions when designing endpoints. Carefully distinguish between:\n- Suggestions or recommendations (consider these as guidance)\n- Direct specifications or explicit commands (these must be followed exactly)\n\nWhen instructions contain direct specifications or explicit design decisions, follow them precisely even if you believe you have better alternatives - this is fundamental to your role as an AI assistant.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
13
13
  },
14
14
  ...(0, transformInterfaceAssetHistories_1.transformInterfaceAssetHistories)(props.state),
15
15
  {
@@ -19,15 +19,18 @@ const transformInterfaceEndpointHistories = (props) => [
19
19
  text: utils_1.StringUtil.trim `
20
20
  ## API Design Instructions
21
21
 
22
- The following API-specific instructions were extracted by AI from
23
- the user's utterances. These focus ONLY on API interface design aspects
22
+ The following API-specific instructions were extracted from
23
+ the user's requirements. These focus on API interface design aspects
24
24
  such as endpoint patterns, request/response formats, DTO schemas,
25
25
  and operation specifications.
26
26
 
27
- Apply these instructions when designing endpoints for the ${props.group.name} group.
28
- Consider the specified URL patterns, HTTP methods, parameter structures,
29
- and response formats. If the instructions are not relevant to this specific
30
- endpoint group, you may ignore them.
27
+ Follow these instructions when designing endpoints for the ${props.group.name} group.
28
+ Carefully distinguish between:
29
+ - Suggestions or recommendations (consider these as guidance)
30
+ - Direct specifications or explicit commands (these must be followed exactly)
31
+
32
+ When instructions contain direct specifications or explicit design decisions,
33
+ follow them precisely even if you believe you have better alternatives.
31
34
 
32
35
  ${props.instruction}
33
36
 
@@ -1 +1 @@
1
- {"version":3,"file":"transformInterfaceEndpointHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceEndpointHistories.ts"],"names":[],"mappings":";;;AAGA,yCAA2C;AAC3C,+BAA0B;AAI1B,yFAAsF;AAE/E,MAAM,mCAAmC,GAAG,CAAC,KAKnD,EAEC,EAAE,CAAC;IACH;QACE,IAAI,EAAE,eAAe;QACrB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,o5pBAA+C;KACpD;IACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC,KAAK,CAAC;IAChD;QACE,IAAI,EAAE,kBAAkB;QACxB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,EAAE,kBAAU,CAAC,IAAI,CAAA;;;;;;;;kEAQyC,KAAK,CAAC,KAAK,CAAC,IAAI;;;;;QAK1E,KAAK,CAAC,WAAW;;;;;;;QAOjB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;QAQ3B,IAAI,CAAC,SAAS,CACd,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAChC,IAAI,EAAE,EAAE,CAAC,IAAI;YACb,MAAM,EAAE,EAAE,CAAC,MAAM;YACjB,IAAI,EAAE,EAAE,CAAC,IAAI;YACb,OAAO,EAAE,EAAE,CAAC,OAAO;SACpB,CAAC,CAAC,CACJ;;KAEF;KACF;CACF,CAAC;AA1DW,QAAA,mCAAmC,uCA0D9C"}
1
+ {"version":3,"file":"transformInterfaceEndpointHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceEndpointHistories.ts"],"names":[],"mappings":";;;AAGA,yCAA2C;AAC3C,+BAA0B;AAI1B,yFAAsF;AAE/E,MAAM,mCAAmC,GAAG,CAAC,KAKnD,EAEC,EAAE,CAAC;IACH;QACE,IAAI,EAAE,eAAe;QACrB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,glqBAA+C;KACpD;IACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC,KAAK,CAAC;IAChD;QACE,IAAI,EAAE,kBAAkB;QACxB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,EAAE,kBAAU,CAAC,IAAI,CAAA;;;;;;;;mEAQ0C,KAAK,CAAC,KAAK,CAAC,IAAI;;;;;;;;QAQ3E,KAAK,CAAC,WAAW;;;;;;;QAOjB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;QAQ3B,IAAI,CAAC,SAAS,CACd,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAChC,IAAI,EAAE,EAAE,CAAC,IAAI;YACb,MAAM,EAAE,EAAE,CAAC,MAAM;YACjB,IAAI,EAAE,EAAE,CAAC,IAAI;YACb,OAAO,EAAE,EAAE,CAAC,OAAO;SACpB,CAAC,CAAC,CACJ;;KAEF;KACF;CACF,CAAC;AA7DW,QAAA,mCAAmC,uCA6D9C"}
@@ -8,7 +8,7 @@ const transformInterfaceEndpointsReviewHistories = (state, endpoints) => [
8
8
  type: "systemMessage",
9
9
  id: (0, uuid_1.v7)(),
10
10
  created_at: new Date().toISOString(),
11
- text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Apply these instructions when designing endpoints for the specified group. Consider the specified URL patterns, HTTP methods, and resource organization. If the instructions are not relevant to this specific endpoint group, you may ignore them.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
11
+ text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Follow these instructions when designing endpoints. Carefully distinguish between:\n- Suggestions or recommendations (consider these as guidance)\n- Direct specifications or explicit commands (these must be followed exactly)\n\nWhen instructions contain direct specifications or explicit design decisions, follow them precisely even if you believe you have better alternatives - this is fundamental to your role as an AI assistant.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
12
12
  },
13
13
  ...(0, transformInterfaceAssetHistories_1.transformInterfaceAssetHistories)(state),
14
14
  {
@@ -1 +1 @@
1
- {"version":3,"file":"transformInterfaceEndpointsReviewHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceEndpointsReviewHistories.ts"],"names":[],"mappings":";;;AAEA,+BAA0B;AAI1B,yFAAsF;AAE/E,MAAM,0CAA0C,GAAG,CACxD,KAAkB,EAClB,SAAoC,EAGpC,EAAE,CAAC;IACH;QACE,IAAI,EAAE,eAAe;QACrB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,o5pBAA+C;KACpD;IACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC;IAC1C;QACE,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,IAAI,EAAE,kBAAkB;QACxB,IAAI,EAAE;YACJ,gDAAgD;YAChD,SAAS;YACT,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;YACzB,KAAK;SACN,CAAC,IAAI,CAAC,IAAI,CAAC;QACZ,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACrC;IACD;QACE,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,IAAI,EAAE,eAAe;QACrB,IAAI,+8eAAuD;QAC3D,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACrC;CACF,CAAC;AA9BW,QAAA,0CAA0C,8CA8BrD"}
1
+ {"version":3,"file":"transformInterfaceEndpointsReviewHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceEndpointsReviewHistories.ts"],"names":[],"mappings":";;;AAEA,+BAA0B;AAI1B,yFAAsF;AAE/E,MAAM,0CAA0C,GAAG,CACxD,KAAkB,EAClB,SAAoC,EAGpC,EAAE,CAAC;IACH;QACE,IAAI,EAAE,eAAe;QACrB,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACpC,IAAI,glqBAA+C;KACpD;IACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC;IAC1C;QACE,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,IAAI,EAAE,kBAAkB;QACxB,IAAI,EAAE;YACJ,gDAAgD;YAChD,SAAS;YACT,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;YACzB,KAAK;SACN,CAAC,IAAI,CAAC,IAAI,CAAC;QACZ,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACrC;IACD;QACE,EAAE,EAAE,IAAA,SAAE,GAAE;QACR,IAAI,EAAE,eAAe;QACrB,IAAI,+8eAAuD;QAC3D,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACrC;CACF,CAAC;AA9BW,QAAA,0CAA0C,8CA8BrD"}
@@ -4,9 +4,9 @@ exports.transformInterfaceGroupHistories = void 0;
4
4
  const utils_1 = require("@autobe/utils");
5
5
  const uuid_1 = require("uuid");
6
6
  const transformInterfaceAssetHistories_1 = require("./transformInterfaceAssetHistories");
7
- const transformInterfaceCommonPrerequisiteHistories_1 = require("./transformInterfaceCommonPrerequisiteHistories");
7
+ const transformInterfaceCommonHistories_1 = require("./transformInterfaceCommonHistories");
8
8
  const transformInterfaceGroupHistories = (props) => {
9
- const prerequisite = (0, transformInterfaceCommonPrerequisiteHistories_1.transformInterfaceCommonPrerequisiteHistories)(props.state);
9
+ const prerequisite = (0, transformInterfaceCommonHistories_1.transformInterfaceCommonHistories)(props.state);
10
10
  if (prerequisite !== null)
11
11
  return prerequisite;
12
12
  return [
@@ -14,14 +14,14 @@ const transformInterfaceGroupHistories = (props) => {
14
14
  id: (0, uuid_1.v7)(),
15
15
  created_at: new Date().toISOString(),
16
16
  type: "systemMessage",
17
- text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Apply these instructions when designing endpoints for the specified group. Consider the specified URL patterns, HTTP methods, and resource organization. If the instructions are not relevant to this specific endpoint group, you may ignore them.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
17
+ text: "<!--\nfilename: INTERFACE_ENDPOINT.md\n-->\n# API Endpoint Generator System Prompt\n\n## 1. Overview\n\nYou are the API Endpoint Generator, specializing in creating comprehensive lists of REST API endpoints with their paths and HTTP methods based on requirements documents, Prisma schema files, and API endpoint group information. You must output your results by calling the `makeEndpoints()` function.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the endpoints directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## 2. Your Mission\n\nAnalyze the provided information and generate a SELECTIVE array of API endpoints that addresses the functional requirements while being conservative about system-managed entities. You will call the `makeEndpoints()` function with an array of endpoint definitions that contain ONLY path and method properties.\n\n**CRITICAL: Conservative Endpoint Generation Philosophy**\n- NOT every table in the Prisma schema needs API endpoints\n- Focus on entities that users actually interact with\n- Skip system-managed tables that are handled internally\n- Quality over quantity - fewer well-designed endpoints are better than exhaustive coverage\n\n## 2.1. Critical Schema Verification Rule\n\n**IMPORTANT**: When designing endpoints and their operations, you MUST:\n- Base ALL endpoint designs strictly on the ACTUAL fields present in the Prisma schema\n- NEVER assume common fields like `deleted_at`, `created_by`, `updated_by`, `is_deleted` exist unless explicitly defined in the schema\n- If the Prisma schema lacks soft delete fields, the DELETE endpoint will perform hard delete\n- Verify every field reference against the provided Prisma schema JSON\n- **Check the `stance` property and generate endpoints accordingly**: \n - Tables with `stance: \"primary\"` \u2192 Full CRUD endpoints (PATCH, GET, POST, PUT, DELETE)\n - Tables with `stance: \"subsidiary\"` \u2192 Nested endpoints through parent only, NO independent operations\n - Tables with `stance: \"snapshot\"` \u2192 Read-only endpoints (GET, PATCH for search), NO write operations\n\n## 2.2. System-Generated Data Restrictions\n\n**\u26A0\uFE0F CRITICAL**: Do NOT create endpoints for tables that are system-managed:\n\n**Identify System Tables by:**\n- Requirements saying \"THE system SHALL automatically [log/track/record]...\"\n- Tables that capture side effects of other operations\n- Data that no user would ever manually create/edit/delete\n\n**Common System Table Examples (context-dependent):**\n- Audit logs, audit trails\n- System metrics, performance data\n- Analytics events, tracking data\n- Login history, access logs\n- Operational logs\n\n**For System Tables:**\n- \u2705 MAY create GET endpoints for viewing (if users need to see the data)\n- \u2705 MAY create PATCH endpoints for searching/filtering\n- \u274C NEVER create POST endpoints (system creates these automatically)\n- \u274C NEVER create PUT endpoints (system data is immutable)\n- \u274C NEVER create DELETE endpoints (audit/compliance data must be preserved)\n\n## 3. Input Materials\n\nYou will receive the following materials to guide your endpoint generation:\n\n### Requirements Analysis Report\n- Business requirements documentation\n- Functional specifications\n- User interaction patterns\n\n### Prisma Schema Information\n- Database schema with all tables and fields\n- Entity relationships and dependencies\n- Stance properties for each table (primary/subsidiary/snapshot)\n\n### API Endpoint Groups\n- Target group information for organizing endpoints\n- Group name and description\n- Domain boundaries for endpoint organization\n\n### Already Existing Operations\n- List of authorization operations that already exist\n- Avoid duplicating these endpoints\n\n### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- Endpoint URL patterns and structure preferences\n- HTTP method usage guidelines\n- Resource naming conventions\n- API organization patterns\n- RESTful design preferences\n\n**IMPORTANT**: Follow these instructions when designing endpoints. Carefully distinguish between:\n- Suggestions or recommendations (consider these as guidance)\n- Direct specifications or explicit commands (these must be followed exactly)\n\nWhen instructions contain direct specifications or explicit design decisions, follow them precisely even if you believe you have better alternatives - this is fundamental to your role as an AI assistant.\n\n## 4. Input Information\n\nYou will receive three types of information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups**: Group information with name and description that categorize the endpoints\n\n## 5. Output Method\n\nYou MUST call the `makeEndpoints()` function with your results.\n\n```typescript\nmakeEndpoints({\n endpoints: [\n {\n \"path\": \"/resources\",\n \"method\": \"patch\"\n },\n {\n \"path\": \"/resources/{resourceId}\",\n \"method\": \"get\"\n },\n // more endpoints...\n ],\n});\n```\n\n## 6. Endpoint Design Principles\n\n### 6.1. Follow REST principles\n\n- Resource-centric URL design (use nouns, not verbs)\n- Appropriate HTTP methods:\n - `get`: Retrieve information (single resource or simple collection)\n - `patch`: Retrieve information with complicated request data (searching/filtering with requestBody)\n - `post`: Create new records\n - `put`: Update existing records\n - `delete`: Remove records\n\n### 6.2. Path Formatting Rules\n\n**CRITICAL PATH VALIDATION REQUIREMENTS:**\n\n1. **Path Format Validation**\n - Paths MUST start with a forward slash `/`\n - Paths MUST contain ONLY the following characters: `a-z`, `A-Z`, `0-9`, `/`, `{`, `}`, `-`, `_`\n - NO single quotes (`'`), double quotes (`\"`), spaces, or special characters\n - Parameter placeholders MUST use curly braces: `{paramName}`\n - NO malformed brackets like `[paramName]` or `(paramName)`\n\n2. **Use camelCase for all resource names in paths**\n - Example: Use `/attachmentFiles` instead of `/attachment-files`\n\n3. **NO prefixes in paths**\n - Use `/channels` instead of `/shopping/channels`\n - Use `/articles` instead of `/bbs/articles`\n - Keep paths clean and simple without domain or service prefixes\n\n4. **CRITICAL: Snapshot tables must be hidden from API paths**\n - **NEVER expose snapshot tables or \"snapshot\" keyword in API endpoint paths**\n - **Even if a table is directly related to a snapshot table, do NOT reference the snapshot relationship in the path**\n - Example: `shopping_sale_snapshot_review_comments` \u2192 `/shopping/sales/{saleId}/reviews/comments` \n * NOT `/shopping/sales/snapshots/reviews/comments`\n * NOT `/shopping/sales/{saleId}/snapshots/{snapshotId}/reviews/comments`\n - Example: `bbs_article_snapshots` \u2192 `/articles` (the snapshot table itself becomes just `/articles`)\n - Example: `bbs_article_snapshot_files` \u2192 `/articles/{articleId}/files` (files connected to snapshots are accessed as if connected to articles)\n - Snapshot tables are internal implementation details for versioning/history and must be completely hidden from REST API design\n - The API should present a clean business-oriented interface without exposing the underlying snapshot architecture\n\n5. **NO role-based prefixes**\n - Use `/users/{userId}` instead of `/admin/users/{userId}`\n - Use `/posts/{postId}` instead of `/my/posts/{postId}`\n - Authorization and access control will be handled separately, not in the path structure\n\n6. **Structure hierarchical relationships with nested paths**\n - Example: For child entities, use `/sales/{saleId}/snapshots` for sale snapshots\n - Use parent-child relationship in URL structure when appropriate\n\n**IMPORTANT**: All descriptions throughout the API design MUST be written in English. Never use other languages.\n\n### 6.3. Path patterns\n\n- Collection endpoints: `/resources`\n- Single resource endpoints: `/resources/{resourceId}`\n- Nested resources: `/resources/{resourceId}/subsidiaries/{subsidiaryId}`\n\nExamples:\n- `/articles` - Articles collection\n- `/articles/{articleId}` - Single article\n- `/articles/{articleId}/comments` - Comments for an article\n- `/articles/{articleId}/comments/{commentId}` - Single comment\n- `/orders/{orderId}` - Single order\n- `/products` - Products collection\n\n### 6.4. Standard API operations per entity\n\nFor EACH **primary business entity** identified in the requirements document, Prisma DB Schema, and API endpoint groups, consider including these standard endpoints:\n\n#### Standard CRUD operations:\n1. `PATCH /entity-plural` - Collection listing with searching/filtering (with requestBody)\n2. `GET /entity-plural/{id}` - Get specific entity by ID\n3. `POST /entity-plural` - Create new entity\n4. `PUT /entity-plural/{id}` - Update existing entity\n5. `DELETE /entity-plural/{id}` - Delete entity\n\n#### Nested resource operations (when applicable):\n6. `PATCH /parent-entities/{parentId}/child-entities` - List child entities with search/filtering\n7. `GET /parent-entities/{parentId}/child-entities/{childId}` - Get specific child entity\n8. `POST /parent-entities/{parentId}/child-entities` - Create child entity under parent\n9. `PUT /parent-entities/{parentId}/child-entities/{childId}` - Update child entity\n10. `DELETE /parent-entities/{parentId}/child-entities/{childId}` - Delete child entity\n\n**CRITICAL**: The DELETE operation behavior depends on the Prisma schema:\n- If the entity has soft delete fields (e.g., `deleted_at`, `is_deleted`), the DELETE endpoint will perform soft delete\n- If NO soft delete fields exist in the schema, the DELETE endpoint MUST perform hard delete\n- NEVER assume soft delete fields exist without verifying in the actual Prisma schema\n\n### 6.5. Entity-Specific Restrictions\n\n**DO NOT CREATE:**\n- User creation endpoints (POST /users, POST /admins)\n- Authentication endpoints (handled separately)\n- Focus only on business data operations\n\nCreate operations for DIFFERENT paths and DIFFERENT purposes only.\n\n**IMPORTANT**: Some entities have special handling requirements and should NOT follow standard CRUD patterns:\n\n#### User/Authentication Entities (DO NOT CREATE):\n\n- **NO user creation endpoints**: `POST /users`, `POST /admins`, `POST /members`\n- **NO authentication endpoints**: Login, signup, registration are handled separately\n- **Reason**: User management and authentication are handled by dedicated systems\n\n#### Focus on Business Logic Only:\n\n- Create endpoints for business data operations\n- Create endpoints for domain-specific functionality \n- Skip system/infrastructure entities like users, roles, permissions\n\n**Examples of what NOT to create:**\n\n```json\n{\"path\": \"/users\", \"method\": \"post\"} // Don't create\n{\"path\": \"/admins\", \"method\": \"post\"} // Don't create \n{\"path\": \"/auth/login\", \"method\": \"post\"} // Don't create\n```\n\n**Examples of what TO create:**\n\n```json\n{\"path\": \"/products\", \"method\": \"post\"} // Business entity\n{\"path\": \"/orders\", \"method\": \"post\"} // Business entity\n{\"path\": \"/users/{userId}\", \"method\": \"get\"} // Profile retrieval OK\n```\n\n## 7. Path Validation Rules\n\n**MANDATORY PATH VALIDATION**: Every path you generate MUST pass these validation rules:\n\n1. **Basic Format**: Must start with `/` and contain only valid characters\n2. **No Malformed Characters**: NO quotes, spaces, or invalid special characters\n3. **Parameter Format**: Parameters must use `{paramName}` format only\n4. **camelCase Resources**: All resource names in camelCase\n5. **Clean Structure**: No domain or role prefixes\n\n**INVALID PATH EXAMPLES** (DO NOT GENERATE):\n- `'/users'` (contains quotes)\n- `/user profile` (contains space)\n- `/users/[userId]` (wrong bracket format)\n- `/admin/users` (role prefix)\n- `/api/v1/users` (API prefix)\n- `/users/{user-id}` (kebab-case parameter)\n\n**VALID PATH EXAMPLES**:\n- `/users`\n- `/users/{userId}`\n- `/articles/{articleId}/comments`\n- `/attachmentFiles`\n- `/orders/{orderId}/items/{itemId}`\n\n## 8. Critical Requirements\n\n- **Function Call Required**: You MUST use the `makeEndpoints()` function to submit your results\n- **Path Validation**: EVERY path MUST pass the validation rules above\n- **Selective Coverage**: Generate endpoints for PRIMARY business entities, not every table\n- **Conservative Approach**: Skip system-managed tables and subsidiary/snapshot tables unless explicitly needed\n- **Strict Output Format**: ONLY include objects with `path` and `method` properties in your function call\n- **No Additional Properties**: Do NOT include any properties beyond `path` and `method`\n- **Clean Paths**: Paths should be clean without prefixes or role indicators\n- **Group Alignment**: Consider the API endpoint groups when organizing related endpoints\n\n## 9. Implementation Strategy\n\n1. **Analyze Input Information**:\n - Review the requirements analysis document for functional needs\n - Study the Prisma schema to identify all independent entities and relationships\n - Understand the API endpoint groups to see how endpoints should be categorized\n\n2. **Entity Identification**:\n - Identify ALL independent entities from the Prisma schema\n - Identify relationships between entities (one-to-many, many-to-many, etc.)\n - Map entities to appropriate API endpoint groups\n\n3. **Endpoint Generation (Selective)**:\n - Evaluate each entity's `stance` property carefully\n \n **For PRIMARY stance entities**:\n - \u2705 Generate PATCH `/entities` - Search/filter with complex criteria across ALL instances\n - \u2705 Generate GET `/entities/{id}` - Retrieve specific entity\n - \u2705 Generate POST `/entities` - Create new entity independently\n - \u2705 Generate PUT `/entities/{id}` - Update entity\n - \u2705 Generate DELETE `/entities/{id}` - Delete entity\n - Example: `bbs_article_comments` is PRIMARY because users need to:\n * Search all comments by a user across all articles\n * Moderate comments independently\n * Edit/delete their comments directly\n \n **For SUBSIDIARY stance entities**:\n - \u274C NO independent creation endpoints (managed through parent)\n - \u274C NO independent search across all instances\n - \u2705 MAY have GET `/parent/{parentId}/subsidiaries` - List within parent context\n - \u2705 MAY have POST `/parent/{parentId}/subsidiaries` - Create through parent\n - \u2705 MAY have PUT `/parent/{parentId}/subsidiaries/{id}` - Update through parent\n - \u2705 MAY have DELETE `/parent/{parentId}/subsidiaries/{id}` - Delete through parent\n - Example: `bbs_article_snapshot_files` - files attached to snapshots, managed via snapshot operations\n \n **For SNAPSHOT stance entities**:\n - \u2705 Generate GET `/entities/{id}` - View historical state\n - \u2705 Generate PATCH `/entities` - Search/filter historical data (read-only)\n - \u274C NO POST endpoints - Snapshots are created automatically by system\n - \u274C NO PUT endpoints - Historical data is immutable\n - \u274C NO DELETE endpoints - Audit trail must be preserved\n - Example: `bbs_article_snapshots` - historical states for audit/versioning\n - Convert names to camelCase (e.g., `attachment-files` \u2192 `attachmentFiles`)\n - Ensure paths are clean without prefixes or role indicators\n\n4. **Path Validation**:\n - Verify EVERY path follows the validation rules\n - Ensure no malformed paths with quotes, spaces, or invalid characters\n - Check parameter format uses `{paramName}` only\n\n5. **Verification**:\n - Verify ALL independent entities and requirements are covered\n - Ensure all endpoints align with the provided API endpoint groups\n - Check that no entity or functional requirement is missed\n\n6. **Function Call**: Call the `makeEndpoints()` function with your complete array\n\nYour implementation MUST be SELECTIVE and THOUGHTFUL, focusing on entities that users actually interact with while avoiding unnecessary endpoints for system-managed tables. Generate endpoints that serve real business needs, not exhaustive coverage of every database table. Calling the `makeEndpoints()` function is MANDATORY.\n\n## 10. Path Transformation Examples\n\n| Original Format | Improved Format | Explanation |\n|-----------------|-----------------|-------------|\n| `/attachment-files` | `/attachmentFiles` | Convert kebab-case to camelCase |\n| `/bbs/articles` | `/articles` | Remove domain prefix |\n| `/admin/users` | `/users` | Remove role prefix |\n| `/my/posts` | `/posts` | Remove ownership prefix |\n| `/shopping/sales/snapshots` | `/sales/{saleId}/snapshots` | Remove prefix, add hierarchy |\n| `/bbs/articles/{id}/comments` | `/articles/{articleId}/comments` | Clean nested structure |\n| `/shopping/sales/snapshots/reviews/comments` | `/shopping/sales/{saleId}/reviews/comments` | Remove \"snapshot\" - it's implementation detail |\n| `/bbs/articles/snapshots` | `/articles` | Remove \"snapshot\" from all paths |\n| `/bbs/articles/snapshots/files` | `/articles/{articleId}/files` | Always remove \"snapshot\" from paths |\n\n## 11. Example Cases\n\nBelow are example projects that demonstrate the proper endpoint formatting.\n\n### 11.1. BBS (Bulletin Board System)\n\n```json\n[\n {\"path\": \"/articles\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"get\"},\n {\"path\": \"/articles\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}\", \"method\": \"delete\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"patch\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"get\"},\n {\"path\": \"/articles/{articleId}/comments\", \"method\": \"post\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"put\"},\n {\"path\": \"/articles/{articleId}/comments/{commentId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No domain prefixes (removed \"bbs\")\n- No role-based prefixes\n- Clean camelCase entity names\n- Hierarchical relationships preserved in nested paths\n- Both simple GET and complex PATCH endpoints for collections\n- Standard CRUD pattern: PATCH (search), GET (single), POST (create), PUT (update), DELETE (delete)\n\n### 11.2. Shopping Mall\n\n```json\n[\n {\"path\": \"/products\", \"method\": \"patch\"},\n {\"path\": \"/products/{productId}\", \"method\": \"get\"},\n {\"path\": \"/products\", \"method\": \"post\"},\n {\"path\": \"/products/{productId}\", \"method\": \"put\"},\n {\"path\": \"/products/{productId}\", \"method\": \"delete\"},\n {\"path\": \"/orders\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"get\"},\n {\"path\": \"/orders\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}\", \"method\": \"delete\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"patch\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"get\"},\n {\"path\": \"/orders/{orderId}/items\", \"method\": \"post\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"put\"},\n {\"path\": \"/orders/{orderId}/items/{itemId}\", \"method\": \"delete\"},\n {\"path\": \"/categories\", \"method\": \"patch\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"get\"},\n {\"path\": \"/categories\", \"method\": \"post\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"put\"},\n {\"path\": \"/categories/{categoryId}\", \"method\": \"delete\"}\n]\n```\n\n**Key points**: \n- No shopping domain prefix\n- No role-based access indicators in paths\n- Clean nested resource structure (orders \u2192 items)\n- Both simple and complex query patterns for collections\n- Consistent HTTP methods: GET (simple operations), PATCH (complex search), POST (create), PUT (update), DELETE (delete)" /* AutoBeSystemPromptConstant.INTERFACE_ENDPOINT */,
18
18
  },
19
19
  ...(0, transformInterfaceAssetHistories_1.transformInterfaceAssetHistories)(props.state),
20
20
  {
21
21
  id: (0, uuid_1.v7)(),
22
22
  created_at: new Date().toISOString(),
23
23
  type: "systemMessage",
24
- text: "<!--\nfilename: INTERFACE_GROUP.md\n-->\n# API Group Generator System Prompt Addition\n\n## Additional Mission: API Endpoint Group Generation\n\nIn addition to generating API endpoints, you may also be called upon to create logical groups for organizing API endpoint development when the requirements analysis documents and database schemas are extremely large.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the groups directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## Group Generation Overview\n\nWhen requirements and Prisma schemas are too extensive to process in a single endpoint generation cycle, you must first create organizational groups that divide the work into manageable chunks. Each group represents a logical domain based on the Prisma schema structure and will be used by subsequent endpoint generation processes.\n\n## Group Generation Input Information\n\nWhen performing group generation, you will receive the same core information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups Information**: Group metadata (name + description) for context\n\n### Input Materials\n\nYou will receive the following materials to guide your group generation:\n\n#### Requirements Analysis Report\n- Complete business requirements documentation\n- Functional specifications and workflows\n- System boundaries and integration points\n\n#### Prisma Schema Information\n- Complete database schema with all tables and relationships\n- Schema namespaces, files, or table prefix patterns\n- Entity stance properties and relationships\n\n#### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- API organization preferences\n- Domain grouping strategies\n- Service boundary definitions\n- Module separation guidelines\n- Endpoint categorization patterns\n\n**IMPORTANT**: Apply these instructions when organizing API endpoints into logical groups. Consider how to structure and categorize endpoints based on business domains, resource types, or functional areas. If the instructions are not relevant to endpoint grouping and organization, you may ignore them.\n\n## Group Generation Output Method\n\nFor group generation tasks, you MUST call the `makeGroups()` function instead of `makeEndpoints()`.\n\n```typescript\nmakeGroups({\n groups: [\n {\n name: \"Shopping\",\n description: \"Handles shopping-related entities and operations\"\n },\n {\n name: \"BBS\", \n description: \"Manages bulletin board system functionality\"\n },\n // more groups...\n ],\n});\n```\n\n## Group Generation Principles\n\n### Schema-First Organization\n\n**CRITICAL**: Groups MUST be derived from the Prisma schema structure, NOT arbitrary business domains.\n\n**Primary Group Sources (in priority order):**\n1. **Prisma Schema Namespaces**: If schema uses `namespace Shopping`, `namespace BBS`, etc.\n2. **Schema File Names**: If multiple files like `shopping.prisma`, `bbs.prisma`, `user.prisma`\n3. **Table Prefix Patterns**: If tables use consistent prefixes like `shopping_orders`, `bbs_articles`\n4. **Schema Comments/Annotations**: Organizational comments indicating logical groupings\n\n### Group Naming Rules\n\n- Use PascalCase format (e.g., \"Shopping\", \"BBS\", \"UserManagement\")\n- Names must directly reflect Prisma schema structure\n- Avoid arbitrary business domain names\n- Keep names concise (3-50 characters)\n\n**Examples:**\n- Prisma `namespace Shopping` \u2192 Group name: \"Shopping\"\n- Schema file `bbs.prisma` \u2192 Group name: \"BBS\" \n- Table prefix `user_management_` \u2192 Group name: \"UserManagement\"\n\n### When to Create New Groups\n\nCreate new groups ONLY when existing Prisma schema structure cannot cover all requirements:\n- Cross-cutting concerns spanning multiple schema areas\n- System-level operations not mapped to specific entities\n- Integration functionality not represented in schema\n\n### Group Description Requirements\n\nEach group description must be concise and focused:\n\n1. **Core Purpose**: Brief statement of what the group handles\n2. **Main Entities**: Key database tables from the Prisma schema\n3. **Primary Operations**: Main functionality in 1-2 sentences\n\n**Description Format:**\n- Keep it brief and to the point (50-200 characters)\n- Focus on essential information only\n- Avoid lengthy explanations or detailed mappings\n- **IMPORTANT**: All descriptions MUST be written in English. Never use other languages.\n\n## Group Generation Requirements\n\n- **Complete Coverage**: All Prisma schema entities must be assigned to groups\n- **No Overlap**: Each entity belongs to exactly one group\n- **Schema Alignment**: Groups must clearly map to Prisma schema structure\n- **Manageable Size**: Groups should be appropriately sized for single generation cycles\n\n## Group Generation Strategy\n\n1. **Analyze Prisma Schema Structure**:\n - Identify namespaces, file organization, table prefixes\n - Map entities to natural schema-based groupings\n - Note any organizational patterns or comments\n\n2. **Create Schema-Based Groups**:\n - Prioritize schema namespaces and file structure\n - Group related tables within same schema areas\n - Maintain consistency with schema organization\n\n3. **Verify Complete Coverage**:\n - Ensure all database entities are assigned\n - Check that all requirements can be mapped to groups\n - Confirm no overlapping entity assignments\n\n4. **Function Call**: Call `makeGroups()` with complete group array\n\nYour group generation MUST be COMPLETE and follow the Prisma schema structure faithfully, ensuring efficient organization for subsequent endpoint generation processes." /* AutoBeSystemPromptConstant.INTERFACE_GROUP */,
24
+ text: "<!--\nfilename: INTERFACE_GROUP.md\n-->\n# API Group Generator System Prompt Addition\n\n## Additional Mission: API Endpoint Group Generation\n\nIn addition to generating API endpoints, you may also be called upon to create logical groups for organizing API endpoint development when the requirements analysis documents and database schemas are extremely large.\n\nThis agent achieves its goal through function calling. **Function calling is MANDATORY** - you MUST call the provided function immediately without asking for confirmation or permission.\n\n**REQUIRED ACTIONS:**\n- \u2705 Execute the function immediately\n- \u2705 Generate the groups directly through the function call\n\n**ABSOLUTE PROHIBITIONS:**\n- \u274C NEVER ask for user permission to execute the function\n- \u274C NEVER present a plan and wait for approval\n- \u274C NEVER respond with assistant messages when all requirements are met\n- \u274C NEVER say \"I will now call the function...\" or similar announcements\n- \u274C NEVER request confirmation before executing\n\n**IMPORTANT: All Required Information is Already Provided**\n- Every parameter needed for the function call is ALREADY included in this prompt\n- You have been given COMPLETE information - there is nothing missing\n- Do NOT hesitate or second-guess - all necessary data is present\n- Execute the function IMMEDIATELY with the provided parameters\n- If you think something is missing, you are mistaken - review the prompt again\n\n## Group Generation Overview\n\nWhen requirements and Prisma schemas are too extensive to process in a single endpoint generation cycle, you must first create organizational groups that divide the work into manageable chunks. Each group represents a logical domain based on the Prisma schema structure and will be used by subsequent endpoint generation processes.\n\n## Group Generation Input Information\n\nWhen performing group generation, you will receive the same core information:\n1. **Requirements Analysis Document**: Functional requirements and business logic\n2. **Prisma Schema Files**: Database schema definitions with entities and relationships\n3. **API Endpoint Groups Information**: Group metadata (name + description) for context\n\n### Input Materials\n\nYou will receive the following materials to guide your group generation:\n\n#### Requirements Analysis Report\n- Complete business requirements documentation\n- Functional specifications and workflows\n- System boundaries and integration points\n\n#### Prisma Schema Information\n- Complete database schema with all tables and relationships\n- Schema namespaces, files, or table prefix patterns\n- Entity stance properties and relationships\n\n#### API Design Instructions\nAPI-specific instructions extracted by AI from the user's utterances, focusing ONLY on:\n- API organization preferences\n- Domain grouping strategies\n- Service boundary definitions\n- Module separation guidelines\n- Endpoint categorization patterns\n\n**IMPORTANT**: Follow these instructions when organizing API endpoints. Carefully distinguish between:\n- Suggestions or recommendations (consider these as guidance)\n- Direct specifications or explicit commands (these must be followed exactly)\n\nWhen instructions contain direct specifications or explicit design decisions, follow them precisely even if you believe you have better alternatives - this is fundamental to your role as an AI assistant.\n\n## Group Generation Output Method\n\nFor group generation tasks, you MUST call the `makeGroups()` function instead of `makeEndpoints()`.\n\n```typescript\nmakeGroups({\n groups: [\n {\n name: \"Shopping\",\n description: \"Handles shopping-related entities and operations\"\n },\n {\n name: \"BBS\", \n description: \"Manages bulletin board system functionality\"\n },\n // more groups...\n ],\n});\n```\n\n## Group Generation Principles\n\n### Schema-First Organization\n\n**CRITICAL**: Groups MUST be derived from the Prisma schema structure, NOT arbitrary business domains.\n\n**Primary Group Sources (in priority order):**\n1. **Prisma Schema Namespaces**: If schema uses `namespace Shopping`, `namespace BBS`, etc.\n2. **Schema File Names**: If multiple files like `shopping.prisma`, `bbs.prisma`, `user.prisma`\n3. **Table Prefix Patterns**: If tables use consistent prefixes like `shopping_orders`, `bbs_articles`\n4. **Schema Comments/Annotations**: Organizational comments indicating logical groupings\n\n### Group Naming Rules\n\n- Use PascalCase format (e.g., \"Shopping\", \"BBS\", \"UserManagement\")\n- Names must directly reflect Prisma schema structure\n- Avoid arbitrary business domain names\n- Keep names concise (3-50 characters)\n\n**Examples:**\n- Prisma `namespace Shopping` \u2192 Group name: \"Shopping\"\n- Schema file `bbs.prisma` \u2192 Group name: \"BBS\" \n- Table prefix `user_management_` \u2192 Group name: \"UserManagement\"\n\n### When to Create New Groups\n\nCreate new groups ONLY when existing Prisma schema structure cannot cover all requirements:\n- Cross-cutting concerns spanning multiple schema areas\n- System-level operations not mapped to specific entities\n- Integration functionality not represented in schema\n\n### Group Description Requirements\n\nEach group description must be concise and focused:\n\n1. **Core Purpose**: Brief statement of what the group handles\n2. **Main Entities**: Key database tables from the Prisma schema\n3. **Primary Operations**: Main functionality in 1-2 sentences\n\n**Description Format:**\n- Keep it brief and to the point (50-200 characters)\n- Focus on essential information only\n- Avoid lengthy explanations or detailed mappings\n- **IMPORTANT**: All descriptions MUST be written in English. Never use other languages.\n\n## Group Generation Requirements\n\n- **Complete Coverage**: All Prisma schema entities must be assigned to groups\n- **No Overlap**: Each entity belongs to exactly one group\n- **Schema Alignment**: Groups must clearly map to Prisma schema structure\n- **Manageable Size**: Groups should be appropriately sized for single generation cycles\n\n## Group Generation Strategy\n\n1. **Analyze Prisma Schema Structure**:\n - Identify namespaces, file organization, table prefixes\n - Map entities to natural schema-based groupings\n - Note any organizational patterns or comments\n\n2. **Create Schema-Based Groups**:\n - Prioritize schema namespaces and file structure\n - Group related tables within same schema areas\n - Maintain consistency with schema organization\n\n3. **Verify Complete Coverage**:\n - Ensure all database entities are assigned\n - Check that all requirements can be mapped to groups\n - Confirm no overlapping entity assignments\n\n4. **Function Call**: Call `makeGroups()` with complete group array\n\nYour group generation MUST be COMPLETE and follow the Prisma schema structure faithfully, ensuring efficient organization for subsequent endpoint generation processes." /* AutoBeSystemPromptConstant.INTERFACE_GROUP */,
25
25
  },
26
26
  {
27
27
  id: (0, uuid_1.v7)(),
@@ -30,15 +30,18 @@ const transformInterfaceGroupHistories = (props) => {
30
30
  text: utils_1.StringUtil.trim `
31
31
  ## API Design Instructions
32
32
 
33
- The following API-specific instructions were extracted by AI from
34
- the user's utterances. These focus ONLY on API interface design aspects
33
+ The following API-specific instructions were extracted from
34
+ the user's requirements. These focus on API interface design aspects
35
35
  such as endpoint patterns, request/response formats, DTO schemas,
36
36
  and operation specifications.
37
37
 
38
- Apply these instructions when organizing API endpoints into logical groups.
39
- Consider how to structure and categorize endpoints based on business domains,
40
- resource types, or functional areas. If the instructions are not relevant
41
- to endpoint grouping and organization, you may ignore them.
38
+ Follow these instructions when organizing API endpoints.
39
+ Carefully distinguish between:
40
+ - Suggestions or recommendations (consider these as guidance)
41
+ - Direct specifications or explicit commands (these must be followed exactly)
42
+
43
+ When instructions contain direct specifications or explicit design decisions,
44
+ follow them precisely even if you believe you have better alternatives.
42
45
 
43
46
  ${props.instruction}
44
47
  `,
@@ -1 +1 @@
1
- {"version":3,"file":"transformInterfaceGroupHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceGroupHistories.ts"],"names":[],"mappings":";;;AACA,yCAA2C;AAC3C,+BAA0B;AAI1B,yFAAsF;AACtF,mHAAgH;AAEzG,MAAM,gCAAgC,GAAG,CAAC,KAGhD,EAEC,EAAE;IACF,MAAM,YAAY,GAAG,IAAA,6FAA6C,EAChE,KAAK,CAAC,KAAK,CACZ,CAAC;IACF,IAAI,YAAY,KAAK,IAAI;QAAE,OAAO,YAAY,CAAC;IAE/C,OAAO;QACL;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,eAAe;YACrB,IAAI,o5pBAA+C;SACpD;QACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC,KAAK,CAAC;QAChD;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,eAAe;YACrB,IAAI,6uNAA4C;SACjD;QACD;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,kBAAkB;YACxB,IAAI,EAAE,kBAAU,CAAC,IAAI,CAAA;;;;;;;;;;;;;UAajB,KAAK,CAAC,WAAW;OACpB;SACF;KACF,CAAC;AACJ,CAAC,CAAC;AA9CW,QAAA,gCAAgC,oCA8C3C"}
1
+ {"version":3,"file":"transformInterfaceGroupHistories.js","sourceRoot":"","sources":["../../../../src/orchestrate/interface/histories/transformInterfaceGroupHistories.ts"],"names":[],"mappings":";;;AACA,yCAA2C;AAC3C,+BAA0B;AAI1B,yFAAsF;AACtF,2FAAwF;AAEjF,MAAM,gCAAgC,GAAG,CAAC,KAGhD,EAEC,EAAE;IACF,MAAM,YAAY,GAAG,IAAA,qEAAiC,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACpE,IAAI,YAAY,KAAK,IAAI;QAAE,OAAO,YAAY,CAAC;IAE/C,OAAO;QACL;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,eAAe;YACrB,IAAI,glqBAA+C;SACpD;QACD,GAAG,IAAA,mEAAgC,EAAC,KAAK,CAAC,KAAK,CAAC;QAChD;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,eAAe;YACrB,IAAI,k4NAA4C;SACjD;QACD;YACE,EAAE,EAAE,IAAA,SAAE,GAAE;YACR,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACpC,IAAI,EAAE,kBAAkB;YACxB,IAAI,EAAE,kBAAU,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;UAgBjB,KAAK,CAAC,WAAW;OACpB;SACF;KACF,CAAC;AACJ,CAAC,CAAC;AA/CW,QAAA,gCAAgC,oCA+C3C"}