de-swebhosting-shopware-plugin / smart-relation-sync
Smart relation handling for the Sync-API
Installs: 1 324
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 1
Type:shopware-platform-plugin
Requires
- shopware/core: ~6.6.4
Requires (Dev)
- de-swebhosting-shopware-plugin/smart-relation-sync-test-plugin: 1.0.0
- de-swebhosting/php-codestyle: ^5.4
- ergebnis/composer-normalize: ^2.45
- friendsofphp/php-cs-fixer: ^3.66
- phpstan/extension-installer: ^1.4
- phpstan/phpstan: ^2.1
- phpstan/phpstan-phpunit: ^2.0
- phpstan/phpstan-symfony: ^2.0
- phpunit/phpunit: ^11.0 || ^12.0
- rector/type-perfect: ^2.0
- shopware/dev-tools: ^1.5
- symplify/phpstan-rules: ^14.4
This package is auto-updated.
Last update: 2025-05-09 21:05:47 UTC
README
The goal of this Plugin is to ease the pain of dealing with relations in Shopware.
Shopware native
Before explaining the solution in this Plugin, please be aware that there is a Shopware native way in the Sync-API to archive the same result. For example to assign a new category, you can send the following HTTP request:
POST /api/_action/sync Content-Type: application/json { "change-category": { "entity": "product", "action": "upsert", "payload": [ { "id": "<the product id>", "categories": [ {"id": "<the new category id 1>"} {"id": "<the new category id 2>"} ] } ] }, "delete-obsolete": { "entity": "product_category", "action": "delete", "criteria": [ { "type": "equals", "field": "productId", "value": "<the product id>" }, { "type": "not", "operator": "and", "queries": [ { "type": "equalsAny", "field": "categoryId", "value": ["<the new category id 1>", "<the new category id 2>"] } ] } ] } }
Quick start
After installing the Plugin, you can enable automatic relation cleanup in the DAL or in the Sync-API, for example:
$productData = [ 'id' => '...', 'categories' => [['id' => '...']], 'categoriesCleanupRelations' => true, ]; $this->productRepository->upsert([$productData], $context);
POST /api/_action/sync Content-Type: application/json { "write-product": { "entity": "product", "action": "upsert", "payload": [ { "id": "...", "categories": [{ "id": "..." }], "categoriesCleanupRelations": true } ] } }
By setting categoriesCleanupRelations
to true
, the plugin will automatically
remove all category relations that are not in the given array.
You can do this for any many-to-many or one-to-many relation with the CleanupRelation
suffix.