{ "pipeline": "pipeline_from_oxid", "status": "done", "startedAt": "2026-06-14T22:57:36+02:00", "updatedAt": "2026-06-14T23:14:06+02:00", "currentStep": null, "results": [ { "step": "sync_categories", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 0.854, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/shopware_category_sync.php' --config='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/config/import_config.json'", "output": "[2026-06-14 22:57:36] INFO Category upsert chunk done {\"chunk\":1,\"count\":121}\n[2026-06-14 22:57:36] INFO SUMMARY category sync finished {\"sourceCategories\":121,\"upserted\":121,\"deactivatedMissing\":0,\"registry\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/category_registry.json\",\"report\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/logs/reports/category_sync_report.json\"}", "finishedAt": "2026-06-14T22:57:36+02:00" }, { "step": "resolver", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 128.538, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/oxid_to_shopware_resolver.php' --config='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/config/import_config.json'", "output": "Step erfolgreich abgeschlossen. Detail-Log siehe jeweilige Logdatei.", "finishedAt": "2026-06-14T22:59:45+02:00" }, { "step": "csv_to_json", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 1.761, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/csv_to_json_2phase_media.php' --config='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/config/import_config.json'", "output": "[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075739\",\"path\":\"import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075739\",\"path\":\"import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_02.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_02.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075739\",\"path\":\"import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_03.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_03.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075739\",\"path\":\"import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_04.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_07011-payper-berufsbekleidung-christina-meran-suedtirol_04.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"0007573900613992\",\"path\":\"import_files/media/product/98281_08079-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_08079-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"0007573900613999\",\"path\":\"import_files/media/product/98281_14000-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98281_14000-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075740\",\"path\":\"import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_01.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075740\",\"path\":\"import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_02.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_02.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075740\",\"path\":\"import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_03.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_03.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"00075740\",\"path\":\"import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_04.jpg\",\"fullPath\":\"/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/import_files/media/product/98285_11036-payper-berufsbekleidung-christina-meran-suedtirol_04.jpg\"}\n[2026-06-14 22:59:46] INFO WARNING local media file missing; media skipped {\"sourceId\":\"0007574000614013\",\"path\":\"\n... [truncated]", "finishedAt": "2026-06-14T22:59:47+02:00" }, { "step": "batch_import_media", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 9.127, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/shopware_sync_batch_import.php' --base-url='https://practical-villani.82-165-184-4.plesk.page' --client-id='SWIABZLDMKXTQTFWC2ZFEK42NA' --client-secret='QWxHcXl6WHZXa3I3MGo0d1hIZ2pSVm4zQUtaRVM4akF6ZUFja3o' --input='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/sync_MEDIA_PHASE1.json' --state='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/state/media.batch_state.json' --batch-size='250' --retries='4' --connect-timeout='20' --timeout='600' --fresh-state", "output": "Step erfolgreich abgeschlossen. Detail-Log siehe jeweilige Logdatei.", "finishedAt": "2026-06-14T22:59:56+02:00" }, { "step": "upload_media", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 540.205, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/shopware_media_url_uploader_verify.php' --base-url='https://practical-villani.82-165-184-4.plesk.page' --client-id='SWIABZLDMKXTQTFWC2ZFEK42NA' --client-secret='QWxHcXl6WHZXa3I3MGo0d1hIZ2pSVm4zQUtaRVM4akF6ZUFja3o' --plan='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/media_upload_plan.json' --concurrency='3' --retries='5' --connect-timeout='20' --timeout='600' --log='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/logs/media_upload_verify.log' --state='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/state/media_upload_state.json' --fail-report='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/logs/reports/media_upload_failures.json' --verify-report='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/logs/reports/media_verify_report.json' --allow-failures", "output": "Step erfolgreich abgeschlossen. Detail-Log siehe jeweilige Logdatei.", "finishedAt": "2026-06-14T23:08:56+02:00" }, { "step": "batch_import_products", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 112.571, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/shopware_sync_batch_import.php' --base-url='https://practical-villani.82-165-184-4.plesk.page' --client-id='SWIABZLDMKXTQTFWC2ZFEK42NA' --client-secret='QWxHcXl6WHZXa3I3MGo0d1hIZ2pSVm4zQUtaRVM4akF6ZUFja3o' --input='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/sync_PRODUCTS_PHASE2.json' --state='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/state/products.batch_state.json' --batch-size='250' --retries='4' --connect-timeout='20' --timeout='600' --fresh-state", "output": "Step erfolgreich abgeschlossen. Detail-Log siehe jeweilige Logdatei.", "finishedAt": "2026-06-14T23:10:49+02:00" }, { "step": "sync_product_media", "ok": true, "continuedAfterError": false, "exitCode": 0, "durationSeconds": 197.205, "command": "'/usr/bin/php' '/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/scripts/shopware_product_media_sync.php' --base-url='https://practical-villani.82-165-184-4.plesk.page' --client-id='SWIABZLDMKXTQTFWC2ZFEK42NA' --client-secret='QWxHcXl6WHZXa3I3MGo0d1hIZ2pSVm4zQUtaRVM4akF6ZUFja3o' --input='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/sync_PRODUCTS_PHASE2.json' --state='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/output_2phase/state/product_media_sync_state.json' --report='/var/www/vhosts/practical-villani.82-165-184-4.plesk.page/httpdocs/import/logs/reports/product_media_sync_report.json' --product-batch-size='50' --retries='4' --connect-timeout='20' --timeout='600' --verbose", "output": "[2026-06-14 21:14:06] INFO Product media sync finished {\"products\":28942,\"processed\":28942,\"deleted\":0,\"added\":0,\"updatedCover\":0,\"skippedMissingProducts\":0,\"skippedByState\":0}", "finishedAt": "2026-06-14T23:14:06+02:00" } ], "durationSeconds": 990.266 }