@stubrix/shared

v2.6.2

Published

Shared TypeScript types and utilities for Stubrix platform

Readme

@stubrix/shared

Shared TypeScript types consumed by all packages in the Stubrix monorepo.

Overview

Single source of truth for all domain types. No runtime code — pure TypeScript declarations compiled to .d.ts files.

Exported Types

Project

interface Project {
  id: string;
  name: string;
  slug: string;
  proxyTarget: string | null;
  description: string;
  createdAt: string | null;
}

interface ProjectWithStats extends Project {
  mocksCount: number;
}

interface CreateProjectDto {
  name: string;
  proxyTarget?: string;
  description?: string;
}

interface UpdateProjectDto {
  name?: string;
  proxyTarget?: string | null;
  description?: string;
}

Mock

interface MockRequest {
  method: string;
  url?: string;
  urlPattern?: string;
  urlPath?: string;
  urlPathPattern?: string;
  headers?: Record<string, unknown>;
  bodyPatterns?: unknown[];
}

interface MockResponse {
  status: number;
  headers?: Record<string, string>;
  body?: string;
  bodyFileName?: string;
  fixedDelayMilliseconds?: number;
}

interface Mock {
  id: string;
  request: MockRequest;
  response: MockResponse;
  metadata?: MockMetadata;
}

interface MockListItem {
  id: string;
  filename: string;
  projectId: string;
  request: { method: string; url: string };
  response: {
    status: number;
    hasBodyFile: boolean;
    bodyFileName?: string;
    bodyPreview?: string;
  };
}

interface MockDetail extends MockListItem {
  mapping: Mock;
  body?: string;
}

Status

type EngineType = 'wiremock' | 'mockoon';
type EngineStatus = 'running' | 'stopped' | 'error';

interface StatusResponse {
  engine: EngineType;
  engineStatus: EngineStatus;
  port: number;
  controlPort: number;
  recordMode: boolean;
  proxyTarget: string | null;
  mocks: {
    total: number;
    bodyFiles: number;
    byProject: Record<string, number>;
  };
  projects: number;
  uptime: number;
}

Recording

interface RecordingState {
  active: boolean;
  projectId: string | null;
  proxyTarget: string | null;
  startedAt: string | null;
  requestsRecorded: number;
  includePatterns?: string[];
  excludePatterns?: string[];
}

interface StartRecordingDto {
  proxyTarget?: string;
  includePatterns?: string[];
  excludePatterns?: string[];
}

interface RecordingStopResult {
  message: string;
  projectId: string;
  newMocks: number;
  files: string[];
}

Database

interface Engine {
  name: string;
  status: 'active' | 'inactive' | 'error';
}

interface Snapshot {
  name: string;
  size: number;
  sizeFormatted: string;
  createdAt: string;
  favorite: boolean;
  protected: boolean;
  category: string | null;
  engine: string | null;
  projectId?: string | null;
}

interface DatabaseInfo {
  database: string;
  engine: string;
  totalSize: string;
  tables: Array<{ name: string; size: string }>;
}

Import IR

Intermediate representation used by the universal importer (HAR, Postman, OpenAPI):

type ImportIRFormat = 'har' | 'postman' | 'openapi' | 'swagger' | 'unknown';

interface ImportIRHeader {
  name: string;
  value: string;
}
interface ImportIRQueryParam {
  name: string;
  value: string;
}

interface ImportIRRequest {
  method: string;
  url: string;
  path: string;
  headers: ImportIRHeader[];
  queryParams: ImportIRQueryParam[];
  body?: string;
  bodyMimeType?: string;
}

interface ImportIRResponse {
  status: number;
  statusText?: string;
  headers: ImportIRHeader[];
  body?: string;
  bodyMimeType?: string;
}

interface ImportIREntry {
  id: string;
  name?: string;
  description?: string;
  request: ImportIRRequest;
  response: ImportIRResponse;
  tags?: string[];
}

interface ImportIR {
  format: ImportIRFormat;
  source?: string;
  title?: string;
  version?: string;
  entries: ImportIREntry[];
  deduplicated?: boolean;
}

interface ImportOptions {
  projectId: string;
  deduplicate?: boolean;
  overwrite?: boolean;
  filterMethods?: string[];
  filterStatusCodes?: number[];
  baseUrl?: string;
}

interface ImportPreview {
  format: ImportIRFormat;
  title?: string;
  totalEntries: number;
  entries: Array<{
    id: string;
    name?: string;
    method: string;
    path: string;
    responseStatus: number;
  }>;
}

interface ImportResult {
  created: number;
  skipped: number;
  errors: string[];
  summary: string;
  format?: ImportIRFormat;
}

Log

interface LogEntry {
  id: string;
  timestamp: string;
  method: string;
  url: string;
  status: number;
  responseTime: number;
  matched: boolean;
  projectId?: string;
}

Build Order

This package must be built first — all other packages depend on it:

@stubrix/shared → @stubrix/api
                → @stubrix/db-ui
                → @stubrix/mock-ui
                → @stubrix/ui

Development

# From monorepo root
npm run build:shared     # tsc compile

# From packages/shared
npm run build            # tsc