panakour/shopware-dal-toolkit

Shopware Data Abstraction Layer Toolkit

v0.0.1 2025-01-21 08:13 UTC

This package is auto-updated.

Last update: 2025-01-21 08:33:23 UTC


README

A fluent and type-safe toolkit for working with Shopware's Data Abstraction Layer (DAL)

GitHub Workflow Status (master) Total Downloads Latest Version License Code Coverage Badge

About

Shopware DAL Toolkit provides a clean, type-safe abstraction layer for working with Shopware Data Abstraction Layer using PHP. It simplifies common operations like entity management and media handling while maintaining strong typing and best practices.

Very useful for programmatically integrating third party systems e.g synchronize with ERP or any other system.

Key Features:

  • Type-safe entity operations with proper generic types
  • Simplified media handling for both URLs and base64 images
  • First-or-create pattern for common entities
  • Comprehensive test coverage

Installation

Install this package as a dependency using Composer.

composer require panakour/shopware-dal-toolkit

Usage

Basic Entity Operations

use Panakour\ShopwareDALToolkit\Dal;

// Create or retrieve the Dal service from the container
$dal = $container->get(Dal::class);
$currency = $dal->getCurrencyByIsoCode($context, 'EUR');

// Create a tax
$taxName = 'Custom Tax 19%';
$taxRate = 19.0;
$dal->createTax($context, $taxName, $taxRate);

// Create or retrieve a category
$categoryName = 'My Custom Category';
$categoryId = $dal->firstOrCreateCategory($context, $categoryName);
echo $categoryId; // newly generated or existing ID

// Create or retrieve a manufacturer
$manufacturerName = 'My Manufacturer';
$manufacturerId = $dal->firstOrCreateManufacturer($context, $manufacturerName);
echo $manufacturerId; // newly generated or existing ID

Media Handling

use Panakour\ShopwareDALToolkit\MediaServiceHelper;

// Retrieve the MediaServiceHelper from the container
$mediaHelper = $container->get(MediaServiceHelper::class);

// Assign media from a list of URLs and/or base64-encoded images
$images = [
    'https://placehold.co/100x110',
    'https://placehold.co/300x300',
    'data:image/png;base64,' . base64_encode($myRawPngContents),
];
$results = $mediaHelper->assignMedia($context, $images);

// Each item in $results has a 'mediaId' key
foreach ($results as $ref) {
    echo $ref['mediaId']; // Newly created media ID
}

More usage:

Requirements

  • PHP 8.3+
  • Shopware 6.6+

For contribution

๐Ÿงน Keep a modern codebase with Pint:

composer lint

โœ… Run refactors using Rector

composer refactor

โš—๏ธ Run static analysis using PHPStan:

composer test:types

โœ… Run unit tests using PHPUnit

composer test:unit

๐Ÿš€ Run the entire test suite:

composer test

Copyright and License

panakour/shopware-dal-toolkit is copyright ยฉ Panagiotis Koursaris and licensed for use under the terms of the MIT License (MIT). Please see LICENSE for more information.