Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message

Seal Multi Adapter Laravel Package

cmsig/seal-multi-adapter

SEAL Multi Adapter writes indexing operations to multiple adapters at once. Commonly paired with ReadWriteAdapter to keep search reads on one engine while mirroring writes to several indexes, useful during migrations or multi-backend setups.

View on GitHub
Deep Wiki
Context7

Getting Started

Minimal Setup

  1. Install the Package:

    composer require cmsig/seal-multi-adapter
    
  2. Basic Usage: Combine with ReadWriteAdapter to write to multiple adapters while reading from one:

    use CmsIg\Seal\Adapter\Elasticsearch\ElasticsearchAdapter;
    use CmsIg\Seal\Adapter\Multi\MultiAdapter;
    use CmsIg\Seal\Adapter\ReadWrite\ReadWriteAdapter;
    use CmsIg\Seal\Engine;
    
    $readAdapter = new ElasticsearchAdapter($readConfig);
    $writeAdapter1 = new ElasticsearchAdapter($writeConfig1);
    $writeAdapter2 = new ElasticsearchAdapter($writeConfig2);
    
    $multiAdapter = new MultiAdapter($readAdapter, $writeAdapter1, $writeAdapter2);
    $engine = new Engine(
        new ReadWriteAdapter($readAdapter, $multiAdapter),
        $schema
    );
    
  3. First Use Case: Sync data to multiple search engines (e.g., Elasticsearch + Algolia) while querying only one.


Implementation Patterns

Core Workflow

  1. Write Operations: Use MultiAdapter to propagate writes to all configured adapters:

    $multiAdapter->addDocument($document); // Writes to all adapters
    $multiAdapter->updateDocument($id, $data); // Updates all adapters
    $multiAdapter->deleteDocument($id); // Deletes from all adapters
    
  2. Read Operations: Delegate reads to a single adapter (e.g., ReadWriteAdapter):

    $readWriteAdapter->search($query); // Queries only the read adapter
    
  3. DSN Configuration: Define adapters in .env for framework integration:

    # Read adapter (e.g., Elasticsearch)
    elastic://localhost:9200?index=products
    
    # Multi adapter (writes to Elasticsearch + Algolia)
    multi://elastic?adapters[]=algolia://localhost:9200?index=products_algolia
    
    # ReadWrite adapter (reads from Elasticsearch, writes via MultiAdapter)
    read-write://elastic?write=multi
    

Integration Tips

  • Schema Consistency: Ensure all adapters support the same schema to avoid runtime errors.
  • Error Handling: Wrap MultiAdapter operations in transactions or retry logic for idempotency:
    try {
        $multiAdapter->addDocument($document);
    } catch (\Exception $e) {
        // Log or retry failed writes
    }
    
  • Performance: Use async queues (e.g., Laravel Queues) for write-heavy workloads to avoid blocking.

Gotchas and Tips

Pitfalls

  1. No Search Support: MultiAdapter does not support search()—always use it with ReadWriteAdapter for queries.

    // ❌ Fails
    $multiAdapter->search($query);
    
    // ✅ Works
    $readWriteAdapter->search($query);
    
  2. Adapter Compatibility: All adapters must implement the same methods (e.g., addDocument, updateDocument). Mismatches cause runtime errors.

  3. DSN Parsing: Ensure DSN strings are correctly formatted (e.g., multi://readAdapter?adapters[]=writeAdapter1&adapters[]=writeAdapter2).

Debugging

  • Log Writes: Add debug logs to track multi-writes:
    $multiAdapter->addDocument($document, function ($adapter, $result) {
        \Log::debug("Write to {$adapter::class}: " . json_encode($result));
    });
    
  • Test Incrementally: Start with one write adapter, then add more to isolate issues.

Extension Points

  1. Custom Adapters: Extend MultiAdapter to support custom logic (e.g., conditional writes):

    class ConditionalMultiAdapter extends MultiAdapter {
        public function addDocument($document, $options = []) {
            if ($this->shouldWrite($document)) {
                parent::addDocument($document, $options);
            }
        }
    }
    
  2. Priority Adapters: Override writeToAdapters() to control write order or failure handling:

    protected function writeToAdapters($method, $args) {
        foreach ($this->adapters as $adapter) {
            try {
                $adapter->$method(...$args);
            } catch (\Exception $e) {
                // Handle failure (e.g., skip or rethrow)
            }
        }
    }
    
  3. Bulk Operations: Optimize bulk writes by batching requests to each adapter:

    $multiAdapter->bulkAddDocuments([$doc1, $doc2], 2); // Batch size = 2
    
Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
directorytree/privacy-filter-classifier
directorytree/privacy-filter
datacore/hub-sdk
develia/commons
cuci/prototurk-sdk
cuci/prototurk-sdk-symfony
develia/geo-bundle
dreamzy/livewire-charts
touchestate-sdk/php-sdk
22h/doctrine-garbage-collection-bundle
agtp/agtp-php
agtp/mod-php
splash/sonata-admin
splash/metadata
splash/openapi
splash/scopes
splash/toolkit
testo/output-teamcity
testo/bridge-symfony
spatie/flare-daemon-runtime