
def get_info_summary_prompt(parse_message: str = "",
                            exceed_max_iter: bool = False,
                            framework_type: str = "next.js") -> str:
    """
    Build the meta-prompt that the summarization agent will follow.

    Args:
        parse_message:  Optional parsing-error text from a previous run.
        exceed_max_iter: True if the exploration trajectory hit its length cap.
        framework_type: Either "next.js" or "nestjs".
    """
    prefix = ""
    if parse_message:
        prefix += (
            f"During previous parsing of generated summaries, "
            f"the following error occurred: {parse_message}\n\n"
        )
    if exceed_max_iter:
        prefix += "The maximum length limit of the exploration trajectory has been reached.\n\n"

    # ──────────────────────────────────────────────────────────────────────────────
    # Next.js branch (existing behaviour)
    # ──────────────────────────────────────────────────────────────────────────────
    if framework_type.lower() == "next.js":
        return prefix + r"""Now generate a summary containing the following information:
1. **Title**: Find out the purpose of the codebase and summarize it in a title of a few words
2. **Description**: Find out what functionality is implemented in the codebase. Is the codebase the implementation of a website application? Does the codebase contain a website frontend, a website backend, or both? If it contains the frontend, what pages, components, and data flows are present? If it contains the backend, what data structures, API endpoints, and processing logic are included?
3. **Quality Score**: Generate a score ranging from 0 to 5, describing the quality of the codebase in terms of being a web application. The scores are defined as follows:
  - 0 (Irrelevant): No web app at all (empty repo, unrelated library, etc.).
  - 1 (Very Poor): Some web-related files (HTML/CSS/JS) but not a Next.js project. No package.json or build pipeline. Little or no routing, state, or styling. Clearly unusable as an application.
  - 2 (Below Average): Bare-bones Next.js scaffold with a handful of static pages. Little styling; no design system. Project runs locally but is far from production-ready.
  - 3 (Average): Functional Next.js app with several pages and basic dynamic routing. Uses a CSS framework (Tailwind, CSS-in-JS, …) for responsive layouts. Simple API routes or mock server; light state management (Context, Redux, TanStack). Limited documentation.
  - 4 (Good): Production-oriented Next.js (often TypeScript) with modular folder structure. Full UI/UX flow, responsive design, accessibility considerations, SEO meta tags. Robust API layer; validation and error handling. Reasonably clean code and documentation.
  - 5 (Excellent): Enterprise-grade, fully-typed monorepo or NX/Turbo repo. Domain-driven architecture, feature modules. Advanced Next.js features: App Router, Server Components. Extensive API layer or microservices. Thorough documentation.
4. **Frontend Plan**: Generate a frontend plan that fully depicts the frontend part of the website application in the codebase. The frontend plan should strictly correspond to the codebase:
  - All the relevant parts of the frontend code in the codebase must be described in the frontend plan.
  - All parts of the frontend plan should exist in the codebase.
  - The codebase might use mock data to imitate actual backend APIs. In this case, you MUST replace them with actual data flow from the backend in the frontend plan.
  - The codebase should be a plausible implementation of the generated frontend plan.
  - The frontend plan will be in a JSON format. The structure of the frontend plan:
    - pages : array<{
          name, route, description,
          layout: {                       // high-level wireframe
              header : boolean,           // is global header rendered?
              footer : boolean,           // is global footer rendered?
              sections: array<{           // vertical page slices
                  name,                   // e.g., "hero", "sidebar"
                  components: array<string>
              }>
          },
          dataFlows: array<{
              endpointPath,               // must match an apiEndpoints.path
              action,                     // when the call happens
              optimisticUI : boolean,
              loadingStates,
              errorHandling
          }>,
          navigationLinks: array<{        // how user can leave this page
              label,                     // text shown in link / button
              targetRoute,               // another pages.route
              when                       // condition or trigger
          }>
      }>,
    - sharedComponents   : array<{ name, purpose }>,
    - stateManagement    : string,
    - accessibilityAndUX : array<string>
5. **Backend Plan**: Generate a backend plan that fully supports the frontend functionality.
  - The backend plan does not need to already exist in the original codebase.
  - It needs to fulfill ALL the requirements of the frontend.
  - A full and functional backend that completely supports the frontend should be able to be created solely based on this backend plan.
  - The backend plan will be in a JSON format. The structure of the backend plan:
    - entities            : array<{ name, briefDescription, mainFields:array<{name,type}> }>,
    - apiEndpoints        : array<{
          name, method, path, description,
          requestSchema : array<{name,type}>,
          responseSchema: array<{name,type}>,
          statusCodes   : array<number>
      }>,
    - businessRules       : array<string>,
    - nonFunctional       : array<string>
6. **User Instruction**: Generate a likely website development instruction that would result in the web application in this codebase. It should focus on describing the purpose, functional requirements, and color theme of the website. Do not include any technical details.

HARD RULES
1. Return **exactly one JSON object** whose two top-level keys are
   - "title"
   - "description"
   - "qualityScore"
   - "frontendPlan"
   - "backendPlan"
   - "userInstruction"
2. Every requestSchema/responseSchema item must be an object with **name** and **type**
   (string, number, boolean, object, array, enum, date, file, etc.).
   - If the type is **array**, specify the contained type using the form `array<type>`
     (e.g. `array<string>`, `array<object<{{id:number,label:string}}>>`).
   - If the type is **object**, describe the internal structure down to the finest
     granularity using `object<{{fieldName:type,…}}>` where each nested value’s type is
     given.
   - Primitive **string** or **number** values need not be further decomposed.
   Example: `"requestSchema": [ { "name":"tags", "type":"array<string>" } ]`
3. Do not mention or reference any concrete frameworks, runtimes, or databases; they are already decided. Even if they are specifically configured in the codebase, you should not mention them in the final result.
4. Use camelCase for every key.

Your final output must be a single JSON object as in the following example (some parts omitted):

```json
{
  "title": "Blog Post Displaying Website",
  ...
}
```

Now start generating the summary.
"""

    # ──────────────────────────────────────────────────────────────────────────────
    # NestJS branch (new)
    # ──────────────────────────────────────────────────────────────────────────────
    if framework_type.lower() == "nestjs":
        return prefix + f"""Now generate a summary containing the following information:
1. **Title**: Summarize the purpose of the codebase in a short title.
2. **Description**: Describe the functionality implemented in the codebase. Does it contain a backend, a frontend, or both? If a backend exists, what entities, API endpoints, and logic are implemented? If a frontend exists, what pages, components, and data flows are present?
3. **Quality Score**: Rate the codebase (0–5) as a NestJS backend:

  - 0 (Irrelevant): No NestJS code (empty repo or unrelated library).
  - 1 (Very Poor): Few Node/TS files, not generated with `nest new`; missing @nestjs deps; unusable.
  - 2 (Below Average): Bare-bones NestCLI scaffold (`AppModule`, “Hello World” controller) and nothing more.
  - 3 (Average): Multiple modules/controllers with basic CRUD; ORM integration; simple validation; light tests.
  - 4 (Good): Domain-oriented modules, comprehensive validation & exception filters, auth, Swagger docs, Docker & CI, good tests and docs.
  - 5 (Excellent): Enterprise-grade monorepo or microservices; DDD/CQRS; advanced security & observability; high coverage; automated CI/CD; exhaustive docs.

4. **Backend Plan**: Generate a backend plan that **fully reflects the NestJS backend already present in the repository**.

  - Every part of this backend plan must already exist in the codebase (or be trivially inferred, e.g., env vars referenced in source).
  - Use the `{ReadFileTool.Name}`, `{GrepTool.Name}`, `{GlobTool.Name}`, and `{ListDirectoryTool.Name}` tools to explore the repository.
  - Output the backend plan in **JSON** using:
    - entities            : array<{ name, briefDescription, mainFields: array<{ name, type }> }>
    - apiEndpoints        : array<{
          name, method, path, description,
          requestSchema : array<{ name, type }>,
          responseSchema: array<{ name, type }>,
          statusCodes   : array<number>
      }>
    - businessRules       : array<string>
    - nonFunctional       : array<string>
  - List static routes before dynamic ones (e.g., `/api/items` before `/api/items/{id}`).

5. **Frontend Plan**: Based **solely** on the backend plan produced in step 4, draft a frontend plan that would consume that backend.

  - The frontend plan need not already exist in the repo; it can describe new code that interfaces with the backend.
  - Every data flow in the frontend plan **must** reference an `apiEndpoints.path` defined in the backend plan.
  - Replace any mock data with real backend requests.
  - Output the frontend plan in **JSON** with:
    - pages : array<{
          name, route, description,
          layout: {
              header : boolean,
              footer : boolean,
              sections: array<{
                  name,
                  components: array<string>
              }>
          },
          dataFlows: array<{
              endpointPath,
              action,
              optimisticUI : boolean,
              loadingStates,
              errorHandling
          }>,
          navigationLinks: array<{
              label,
              targetRoute,
              when
          }>
      }>,
    - sharedComponents   : array<{ name, purpose }>,
    - stateManagement    : string,
    - accessibilityAndUX : array<string>

6. **User Instruction**: Draft a plausible product-owner instruction describing the site’s purpose, functional requirements, and color theme—without technical details.

HARD RULES
1. Return **exactly one JSON object** whose top-level keys are:
   - "title"
   - "description"
   - "qualityScore"
   - "backendPlan"
   - "frontendPlan"
   - "userInstruction"
2. Every requestSchema/responseSchema item must be an object with **name** and **type** (string, number, boolean, object, array, enum, date, file, etc.).
   - If the type is **array**, specify its item type using `array<type>`.
   - If the type is **object**, detail its structure using `object<{{field:type,…}}>` down to leaf primitives.
3. Do **not** name or reference any specific frameworks, runtimes, or databases—they are predetermined.
4. Use **camelCase** for every JSON key.

Your final output must be a single JSON object, for example:

```json
{
  "title": "Contest Management API",
  ...
}
```

Now start generating the summary.
"""

    # Fallback to Next.js behaviour if the framework is unrecognised
    return get_info_summary_prompt(parse_message, exceed_max_iter, "next.js")
