> ## Documentation Index
> Fetch the complete documentation index at: https://docs.mixpeek.com/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# Get app analytics overview

> Per-app analytics dashboard data: error trend, Web Vitals, recent errors, event counts.

Queries ClickHouse canvas_errors, canvas_vitals, and canvas_app_events tables.



## OpenAPI

````yaml get /v1/apps/{app_id}/analytics
openapi: 3.1.0
info:
  title: Mixpeek API
  description: >-
    This is the Mixpeek API, providing access to various endpoints for data
    processing and retrieval.
  termsOfService: https://mixpeek.com/terms
  contact:
    name: Mixpeek Support
    url: https://mixpeek.com/contact
    email: info@mixpeek.com
  version: '0.82'
servers:
  - url: https://api.mixpeek.com
    description: Production
security: []
paths:
  /v1/apps/{app_id}/analytics:
    get:
      tags:
        - Apps
      summary: Get app analytics overview
      description: >-
        Per-app analytics dashboard data: error trend, Web Vitals, recent
        errors, event counts.


        Queries ClickHouse canvas_errors, canvas_vitals, and canvas_app_events
        tables.
      operationId: get_app_analytics_v1_apps__app_id__analytics_get
      parameters:
        - name: app_id
          in: path
          required: true
          schema:
            type: string
            title: App Id
        - name: hours
          in: query
          required: false
          schema:
            type: integer
            maximum: 720
            minimum: 1
            description: Lookback window in hours
            default: 24
            title: Hours
          description: Lookback window in hours
      responses:
        '200':
          description: Successful Response
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/AppAnalyticsResponse'
        '400':
          description: Bad Request
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
        '401':
          description: Unauthorized
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
        '403':
          description: Forbidden
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
        '404':
          description: Not Found
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
        '422':
          description: Validation Error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/HTTPValidationError'
        '500':
          description: Internal Server Error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
components:
  schemas:
    AppAnalyticsResponse:
      properties:
        app_id:
          type: string
          title: App Id
        period_hours:
          type: integer
          title: Period Hours
        total_errors:
          type: integer
          title: Total Errors
        error_rate_per_minute:
          type: number
          title: Error Rate Per Minute
        errors_over_time:
          items:
            $ref: '#/components/schemas/ErrorBucket'
          type: array
          title: Errors Over Time
        vitals:
          items:
            $ref: '#/components/schemas/VitalsSummary'
          type: array
          title: Vitals
        recent_errors:
          items:
            $ref: '#/components/schemas/RecentError'
          type: array
          title: Recent Errors
        total_events:
          type: integer
          title: Total Events
        total_pageviews:
          type: integer
          title: Total Pageviews
      type: object
      required:
        - app_id
        - period_hours
        - total_errors
        - error_rate_per_minute
        - errors_over_time
        - vitals
        - recent_errors
        - total_events
        - total_pageviews
      title: AppAnalyticsResponse
    ErrorResponse:
      properties:
        success:
          type: boolean
          title: Success
          description: Always false for error responses
          default: false
        status:
          type: integer
          title: Status
          description: HTTP status code for this error
        error:
          $ref: '#/components/schemas/ErrorDetail'
          description: Error details payload
      type: object
      required:
        - status
        - error
      title: ErrorResponse
      description: Error response model.
      examples:
        - error:
            details:
              id: ns_123
              resource: namespace
            message: Namespace not found
            type: NotFoundError
          status: 404
          success: false
    HTTPValidationError:
      properties:
        detail:
          items:
            $ref: '#/components/schemas/ValidationError'
          type: array
          title: Detail
      type: object
      title: HTTPValidationError
    ErrorBucket:
      properties:
        timestamp:
          type: string
          title: Timestamp
        count:
          type: integer
          title: Count
      type: object
      required:
        - timestamp
        - count
      title: ErrorBucket
    VitalsSummary:
      properties:
        metric_name:
          type: string
          title: Metric Name
        p50:
          type: number
          title: P50
        p75:
          type: number
          title: P75
        p95:
          type: number
          title: P95
        sample_count:
          type: integer
          title: Sample Count
      type: object
      required:
        - metric_name
        - p50
        - p75
        - p95
        - sample_count
      title: VitalsSummary
    RecentError:
      properties:
        timestamp:
          type: string
          title: Timestamp
        error_type:
          type: string
          title: Error Type
        error_message:
          type: string
          title: Error Message
        url:
          anyOf:
            - type: string
            - type: 'null'
          title: Url
      type: object
      required:
        - timestamp
        - error_type
        - error_message
      title: RecentError
    ErrorDetail:
      properties:
        message:
          type: string
          title: Message
          description: Human-readable error message
        type:
          type: string
          title: Type
          description: Stable error type identifier (machine-readable)
        code:
          anyOf:
            - type: string
            - type: 'null'
          title: Code
          description: >-
            Fine-grained error code for programmatic handling (e.g.,
            namespace_name_taken, feature_extractor_not_found). Present only
            when consumers may need to branch on a specific error condition.
        details:
          anyOf:
            - additionalProperties: true
              type: object
            - type: 'null'
          title: Details
          description: >-
            Optional structured details to help debugging (validation errors,
            IDs, etc.)
      type: object
      required:
        - message
        - type
      title: ErrorDetail
      description: Error detail model.
    ValidationError:
      properties:
        loc:
          items:
            anyOf:
              - type: string
              - type: integer
          type: array
          title: Location
        msg:
          type: string
          title: Message
        type:
          type: string
          title: Error Type
      type: object
      required:
        - loc
        - msg
        - type
      title: ValidationError

````