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

Synapse Core Laravel Package

arnaudmoncondhuy/synapse-core

View on GitHub
Deep Wiki
Context7

Guide d'implémentation (Breaking Changes - Février 2026)

Ce guide accompagne la standardisation du Synapse Core sur le format OpenAI Chat Completions (LLM-agnosticism).

🚀 Standardisation OpenAI

Depuis février 2026, le bundle utilise le format canonique OpenAI pour tous les échanges internes. Cela permet une compatibilité totale avec n'importe quel provider (Gemini, Mistral, Claude, Ollama) sans changer la logique du service de chat.

Ce qui a changé

  1. Format des messages : Toutes les instructions, y compris le prompt système, passent désormais par le tableau contents. Le message système est systématiquement le premier élément avec le rôle system.
  2. Signature de LlmClientInterface : La méthode generateContent ne reçoit plus $systemInstruction en argument séparé.
  3. Normalisation des erreurs : Les erreurs de sécurité (safety ratings) sont traduites en chaînes de caractères lisibles (blocked_reason) au lieu d'enums spécifiques aux providers.

🛠️ Créer un client personnalisé

Si vous souhaitez implémenter un nouveau provider, vous devez implémenter LlmClientInterface.

1. Implémenter l'interface

use ArnaudMoncondhuy\SynapseCore\Contract\LlmClientInterface;

class MyCustomClient implements LlmClientInterface
{
    public function generateContent(
        array $contents, 
        array $tools = [], 
        ?string $model = null, 
        array $options = [], 
        array &$debugOut = []
    ): array {
        // 1. Extraire le système si besoin (en tête de $contents)
        $system = '';
        if ($contents[0]['role'] === 'system') {
            $system = $contents[0]['content'];
            $contents = array_slice($contents, 1);
        }

        // 2. Traduire $contents vers votre API
        // 3. Appeler votre API
        // 4. Retourner un chunk normalisé
    }
}

2. Format du Chunk normalisé

Le retour doit TOUJOURS suivre cette structure :

return [
    'text'           => '...',      // Contenu texte généré
    'thinking'       => '...',      // Contenu de réflexion (si supporté)
    'function_calls' => [...],      // Appels d'outils
    'usage'          => [
        'prompt_tokens'     => 10,
        'completion_tokens' => 20,
        'total_tokens'      => 30,
    ],
    'blocked'        => false,
    'blocked_reason' => null,       // "discours haineux", "harcèlement", etc.
];

📋 Migration d'un ancien client

Si vous aviez un client pré-v0.5 :

  1. Supprimez l'argument $systemInstruction de vos méthodes.
  2. Récupérez l'instruction système via $contents[0]['content'] si $contents[0]['role'] === 'system'.
  3. Utilisez ModelCapabilityRegistry pour vérifier les capacités du modèle avant l'envoi.
  4. Remplacez blocked_category par blocked_reason dans vos retours.
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.
daikazu/eloquent-salesforce-objects
unseen-codes/chat
romalytar/yammi-jobs-monitoring-laravel
kisame76/filament-db-table-state
nqxcode/laravel-lucene-search
dpfx/laravel-livewire-wizards
workos/workos-php-laravel
sofa/laravel-global-scope
nawasara/auth-primitives
adhocrat-io/arkhe-main
make-dev/orca-harpoon
itsemon245/lamet
baks-dev/dashboard
amoifr/pickle-panther-bundle
make-dev/orca
dmstr/symfony-system-resources-bundle
dmstr/symfony-job-queue-bundle
dmstr/openapi-json-schema-bundle
dmstr/keycloak-security-bundle
dmstr/doctrine-audit-log-bundle