Shopware Guide d'installation
Ajoutez un assistant chat à votre Shopware boutique avec synchronisation automatique des produits.
Vous êtes dans le guide d'installation développeur. Vous cherchez un aperçu de ce que Emporiqa offre à votre Shopware boutique ? Voir la page d'intégration.
Démarrage rapide
Pour les propriétaires de boutique. Installez, configurez, synchronisez — avec des captures d'écran étape par étape.
DémarrerDocumentation développeur
Pour les développeurs. Architecture, payload webhook, hooks d'extension et commandes CLI.
LireDémarrage rapide
Installez le module, collez deux identifiants, lancez une synchronisation. Votre widget de chat est en direct sur votre boutique.
Ce qu'il vous faut
- Accès administrateur à votre boutique Shopware 6 (6.6 ou 6.7)
- Un compte Emporiqa — créer un compte gratuit si vous n'en avez pas encore
- Quelques minutes de travail pratique (la synchronisation s'exécute en arrière-plan)
First, install the plugin. The easiest path is the Shopware admin: go to Extensions → Store, search for Emporiqa, then click Install and Activate. For self-hosted shops, install via Composer from packages.shopware.com:
composer require store.shopware.com/emporiqaintegration
bin/console plugin:refresh
bin/console plugin:install --activate EmporiqaIntegration
bin/console theme:compile
bin/console cache:clear
Theme compilation and cache clearing are handled automatically when you install through the Extension Store.
Entrez vos identifiants
Allez à Paramètres > Emporiqa > Connexion. Collez votre ID de boutique et Secret de connexion à partir de votre tableau de bord Emporiqa.
Lancez la synchronisation initiale
Ouvrez le panneau Synchronisation. Cliquez d'abord sur Tester la connexion, puis sur Synchroniser les produits et Synchroniser les pages. Les catalogues plus importants prennent quelques minutes.
Vérifiez le widget de chat
Ouvrez votre vitrine. La bulle de chat apparaît dans le coin inférieur droit. Cliquez dessus, posez une question sur un produit et regardez le vendeur répondre à partir de votre catalogue.
C'est en direct
- Les nouveaux produits et pages CMS se synchronisent automatiquement lorsque vous les enregistrez
- Les clients peuvent poser des questions sur les produits, les politiques et leurs commandes
- Ajouter au panier dans le chat ; les clients procèdent au paiement de votre boutique
Need to customize sync behavior, decorate a service, or run sync from the CLI?
See Developer DocsDeveloper Documentation
Architecture, configuration reference, webhook payload schema, service decoration, CLI commands, and extension events.
Architecture
The plugin uses Shopware event subscribers (ProductSubscriber, LandingPageSubscriber, CategorySubscriber, OrderSubscriber) to react to write and delete events. Webhook events are dispatched through Shopware's message queue (Symfony Messenger), so the storefront response completes independently of the outbound HTTP delivery.
Storefront sales channels are auto-detected and mapped to Emporiqa channel keys (slugified from channel names). Headless and API channels are excluded. All translations and currencies for a single product or page consolidate into one webhook event in the format {channel: {language: value}}, matching every other Emporiqa integration.
Transient failures (HTTP 429) are re-queued with a 65-second delay, up to 5 retries. Other failures fall back to Shopware's standard message queue retry mechanism. Full syncs split the catalog into configurable batches (default 50, max 200) to keep memory usage bounded.
A message consumer must be running for webhook events to leave the queue: bin/console messenger:consume async.
Requirements
| Shopware 6 | >= 6.6.0, < 6.8.0 |
| Shopware Storefront | >= 6.6.0, < 6.8.0 |
| PHP | 8.2 or higher |
| Composer package | store.shopware.com/emporiqaintegration |
| Emporiqa account | Free Emporiqa account ($25 credit on signup) |
Configuration Reference
All settings live at Extensions → My extensions → Emporiqa → Configuration. Every setting can be overridden per sales channel.
Connection Settings
| Setting | Description |
|---|---|
| storeId | Your Emporiqa store identifier (Settings → Store Integration → Integration Overview). |
| webhookSecret | Shared secret used to sign webhook payloads with HMAC-SHA256. |
Sync Settings
| Setting | Default | Description |
|---|---|---|
| syncProducts | true |
Enable automatic product sync on create / update / delete. |
| syncPages | true |
Enable CMS landing page sync. |
Order Tracking Settings
| Setting | Default | Description |
|---|---|---|
| orderTrackingEnabled | true |
Enables the inbound endpoint that Emporiqa calls to look up order status. |
| orderRequireEmail | true |
When enabled, Emporiqa must provide a matching customer email to look up order status. |
Advanced Settings
Most stores don't need to change these.
| Setting | Default | Description |
|---|---|---|
| webhookUrl | https://emporiqa.com/webhooks/sync/ |
Base URL for the Emporiqa webhook endpoint. Only change for custom instances. |
| batchSize | 50 |
Items per webhook batch during full sync. Maximum 200. |
| taxDisplay | gross |
How prices are sent: gross (incl. tax), net (excl. tax), or both. |
| cartEnabled | true |
Enables the storefront cart endpoints used by the chat widget. |
Dashboard-Managed Settings
These are managed through the Emporiqa admin module UI, not the raw plugin configuration page.
| Setting | Description |
|---|---|
| Brand Attribute | Property group ID used as brand source. Defaults to the product manufacturer. |
| Order Completed States | JSON array of state technical names that trigger the order.completed webhook event. |
Features
Real-time Webhooks
Products, landing pages, categories, and orders sync via subscribers on write and delete events. Outbound delivery runs through Symfony Messenger.
Sales Channel Detection
Storefront sales channels are auto-mapped to Emporiqa channel keys (slugified channel names). Headless and API channels are excluded.
Multi-language
All languages from your sales channel domains are included in a single consolidated payload per product or page.
Multi-currency & Tax Modes
Products include prices for every currency configured per sales channel. Choose gross, net, or both via the taxDisplay setting.
In-chat Cart
JSON API under /emporiqa/api/cart for add, update, remove, clear, and checkout. Product links use SEO URLs.
Admin Dashboard
Dedicated admin module: test connection, configure brand source and order states, preview payloads, and trigger syncs per channel.
Conversion Tracking
Order placement and configurable completion events are sent to Emporiqa for revenue attribution to chat sessions.
Async Delivery & Retries
All product and order webhooks dispatch through the Shopware message queue. 429 responses re-queue with a 65-second delay, up to 5 retries.
Webhook Payload
Each product (or variant) and page is sent as a single webhook event containing all sales channels, languages, and currencies. Parent products include their variants as separate entries.
Product Event
{
"identification_number": "product-UUID",
"sku": "SW-001",
"channels": ["storefront", "b2b"],
"names": {
"storefront": {"en": "Running Shoes", "de": "Laufschuhe"},
"b2b": {"en": "Running Shoes"}
},
"descriptions": {
"storefront": {"en": "Lightweight running shoes...", "de": "Leichte Laufschuhe..."}
},
"links": {
"storefront": {"en": "https://shop.com/running-shoes", "de": "https://shop.de/laufschuhe"}
},
"categories": {
"storefront": {"en": ["Sports > Footwear > Running"], "de": ["Sport > Schuhe > Laufen"]}
},
"brands": {"storefront": "Acme"},
"prices": {
"storefront": [
{"currency": "EUR", "current_price": 89.99, "regular_price": 99.99},
{"currency": "USD", "current_price": 94.99, "regular_price": 109.99}
]
},
"availability_statuses": {"storefront": "available"},
"stock_quantities": {"storefront": 42},
"images": {"storefront": ["https://shop.com/media/shoes.jpg"]},
"attributes": {
"storefront": {"en": {"Color": "Blue", "Size": "42"}, "de": {"Farbe": "Blau", "Größe": "42"}}
},
"parent_sku": null,
"is_parent": true,
"variation_attributes": {"storefront": {"en": ["Color", "Size"]}},
"sync_session_id": "shopware-products-abc123"
}
Field Structure
| Type | Pattern | Fields |
|---|---|---|
| Translatable | {channel: {lang: value}} |
names, descriptions, links, categories, attributes, variation_attributes |
| Shared | {channel: value} |
brands, prices, images, availability_statuses, stock_quantities |
| Flat | Direct value | identification_number, sku, channels, is_parent, parent_sku, sync_session_id |
When taxDisplay=both, each price entry also includes price_incl_tax and price_excl_tax. Identifiers use product-<uuid> for parents and variation-<uuid> for variants.
Customization & Events
Every core service is registered behind an interface and can be replaced via Shopware's standard service decoration mechanism. Symfony events are dispatched at key points in the sync lifecycle for lighter-weight extensions.
Service Interfaces
| Interface | Responsibility |
|---|---|
ConfigServiceInterface |
Read plugin configuration values per sales channel. |
WebhookClientInterface |
Send HMAC-signed HTTP requests to the Emporiqa webhook endpoint. |
ProductFormatterInterface |
Transform ProductEntity objects into the consolidated payload. |
CmsPageFormatterInterface |
Transform LandingPageEntity objects into the consolidated payload. |
ChannelResolverInterface |
Map Shopware sales channels to Emporiqa channel keys. |
SyncServiceInterface |
Orchestrate full product and page syncs and manage sync sessions. |
All interfaces live in the Emporiqa\ShopwarePlugin\Service namespace.
Example: decorate the product formatter
<!-- MyPlugin/src/Resources/config/services.xml -->
<service id="MyPlugin\Service\CustomProductFormatter"
decorates="Emporiqa\ShopwarePlugin\Service\ProductFormatter">
<argument type="service" id="MyPlugin\Service\CustomProductFormatter.inner"/>
</service>
<?php
declare(strict_types=1);
namespace MyPlugin\Service;
use Emporiqa\ShopwarePlugin\Service\ProductFormatterInterface;
use Shopware\Core\Content\Product\ProductEntity;
class CustomProductFormatter implements ProductFormatterInterface
{
public function __construct(
private readonly ProductFormatterInterface $inner,
) {}
public function formatProduct(
ProductEntity $product,
array $channelContexts,
?string $syncSessionId = null,
): array {
$items = $this->inner->formatProduct($product, $channelContexts, $syncSessionId);
foreach ($items as &$item) {
$item['custom_field'] = 'custom_value';
}
return $items;
}
public function formatProductDelete(string $productId): array
{
return $this->inner->formatProductDelete($productId);
}
}
Extension Events
The plugin dispatches Symfony events at key points in the sync and formatting lifecycle. Listen to these in your own plugin to filter, enrich, or log data without decorating a full service.
| Event | When | Mutable via |
|---|---|---|
PreSyncEvent |
Before a full sync starts | setChannelContexts() |
PostSyncEvent |
After a full sync completes | Read-only result data |
PostProductFormatEvent |
After a product is formatted | setFormattedItems() |
PostPageFormatEvent |
After a CMS page is formatted | setFormattedData() |
PostOrderFormatEvent |
After an order payload is built | setEventData() |
All event classes live in the Emporiqa\ShopwarePlugin\Event namespace.
CLI Commands
All sync operations available in the admin dashboard can also be run from the Shopware CLI. Each sync command supports a --dry-run flag that simulates the sync without sending any webhook requests.
| Command | Description |
|---|---|
| emporiqa:sync:products | Synchronize the full product catalog. |
| emporiqa:sync:pages | Synchronize all CMS landing pages. |
| emporiqa:sync:all | Run both product and page syncs in a single command. |
| emporiqa:test-connection | Verify the plugin can reach the Emporiqa webhook endpoint. |
bin/console emporiqa:sync:products
bin/console emporiqa:sync:products --dry-run
bin/console emporiqa:sync:pages
bin/console emporiqa:sync:all
bin/console emporiqa:test-connection
Administration API equivalents
| Endpoint | Method | Description |
|---|---|---|
| /api/_action/emporiqa/sync | POST | Trigger a full sync. Body: {"entity": "products"}, {"entity": "pages"}, or omit for all. |
| /api/_action/emporiqa/test-connection | POST | Test the webhook connection. |
| /api/_action/emporiqa/sync-overview | POST | Return product/page counts, languages, channels, and configuration status. |
| /api/_action/emporiqa/data-preview | POST | Return a sample formatted product and page payload. |
| /api/_action/emporiqa/sales-channels | POST | Return all active sales channels with domain details. |
| /api/_action/emporiqa/property-groups | POST | Return all property groups for brand source selection. |
| /api/_action/emporiqa/order-states | POST | Return all order and transaction state machine states. |
| /api/_action/emporiqa/save-settings | POST | Save dashboard-managed settings (channel mapping, brand attribute, order states). |
Order Tracking
Emporiqa can look up order status on behalf of customers during chat conversations. The plugin exposes a signed inbound endpoint that the Emporiqa backend calls when a customer asks about their order.
Flow
- Customer asks "Where is my order #10001?" in the chat.
- Emporiqa sends an HMAC-SHA256 signed POST to your store with the order identifier and timestamp.
- The plugin verifies the signature, looks up the order, optionally checks the customer email, and returns the order status, totals, addresses, and items.
- The salesperson presents the order information to the customer.
Endpoint
POST /emporiqa/api/order/tracking
Setup
The endpoint is active whenever orderTrackingEnabled is true. To enable order lookup from chat, copy the endpoint URL from the Emporiqa admin module and paste it into your Emporiqa dashboard at Settings → Store Integration → Order Tracking:
https://your-store.com/emporiqa/api/order/tracking
Requests are authenticated using the same webhookSecret via the X-Emporiqa-Signature header. Requests with a timestamp older than 5 minutes are rejected (HTTP 401). When orderRequireEmail is enabled, the request must include a matching customer email or it returns HTTP 403.
Order tracking is optional. Without the dashboard URL configured, order questions route to the Customer Support agent instead.
Troubleshooting
Products are not syncing automatically
- Verify that
syncProductsis enabled in the plugin configuration. - Make sure the message consumer is running:
bin/console messenger:consume async. - Check the failed message queue:
bin/console messenger:failed:show.
Widget does not appear on the storefront
- Confirm that Store ID and Webhook Secret are set in the plugin configuration.
- Rebuild the storefront theme:
bin/console theme:compilefollowed bybin/console cache:clear. - Check the browser console for JavaScript errors.
Test connection fails
- Check that the
webhookUrlis reachable from your server. - Verify that Store ID and Webhook Secret match the values in your Emporiqa dashboard.
- Run the CLI test command for verbose output:
bin/console emporiqa:test-connection -vvv.
Cart API returns "Cart API is disabled"
- The
cartEnabledsetting is set tofalse. Enable it in Extensions → My extensions → Emporiqa → Configuration.
Order tracking returns 401 or 403
- 401: The
X-Emporiqa-Signatureheader is missing or invalid, or the request timestamp is older than 5 minutes. - 403:
orderRequireEmailis enabled and the request does not include a matchingverification_fields.email.
Sync times out on large catalogs
- Reduce
batchSizein the plugin configuration to lower memory per batch. - Prefer the CLI command for large catalogs:
bin/console emporiqa:sync:products. - Clear caches after configuration changes:
bin/console cache:clear.
Related Articles
Webhook Setup Guide
HMAC signing, payload schema, and order tracking request/response details.
Widget Embedding
Customize the chat widget appearance, language, channel, and currency.
Multilingual Chat Support
Cross-language search, 65+ languages, how translations sync.
Conversion Tracking
Prove chat ROI: session to cart to purchase attribution.