Skip to content

drips-network/search-sync

Repository files navigation

Search Data Synchronizer

A service that synchronizes data between the Drips database and search indices to power search functionality in the Drips application.

Core Functionality

The service watches for changes to two types of data:

  1. Drip Lists
  2. Projects (GitHub repositories)

When changes are detected, it automatically updates the corresponding search indices.

Architecture

The service follows a modular architecture centered around two main abstractions:

  1. ChangeDetectionStrategy: Defines how changes are detected in the source database

  2. Synchronizer: Defines how changes are propagated to the search engine

graph LR
    DB[(Drips DB)]
    Search[(Search Engine)]

    subgraph Service[Search Data Synchronizer]
        CD[Change Detection Strategy]
        Sync[Synchronizer]
    end

    CD --> |Changes| Sync
    DB -.-> CD
    Sync -.-> Search

    classDef interface fill:#f9f,stroke:#333,stroke-dasharray: 5 5
    class CD,Sync interface
Loading

Implementation

The current implementation uses the following concrete implementations of the abstractions:

  1. ChangeDetectionStrategyPolling Strategy: Implements periodic polling of Postgres database

  2. SynchronizerMeiliSearch: Manages MeiliSearch indices and updates

sequenceDiagram
    participant DB as Postgres
    participant Poll as Polling Strategy
    participant Sync as MeiliSearchSynchronizer
    participant Search as MeiliSearch

    loop Every polling interval
        Poll->>DB: Query changes since last sync
        DB-->>Poll: Return changed records
        Poll->>Sync: Send changes
        Sync->>Search: Update indices
    end
Loading

Development

  1. Copy .env.example to .env
  2. Configure the environment variables according to your setup
  3. Run docker compose up -d to spin up MeiliSearch
  4. Run npm run dev to run the app

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published