dhl / sdk-api-parcel-management
DHL Paket Parcel Management API SDK
Installs: 248 120
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 10
Forks: 3
Open Issues: 0
Requires
- php: ^8.1.0
- ext-json: *
- netresearch/jsonmapper: ^4.0.0
- php-http/discovery: ^1.17.0
- php-http/httplug: ^2.2.0
- php-http/logger-plugin: ^1.2.1
- psr/http-client: ^1.0.1
- psr/http-client-implementation: ^1.0.0
- psr/http-factory: ^1.0.0
- psr/http-factory-implementation: ^1.0.0
- psr/http-message: ^1.0.0 || ^2.0.0
- psr/http-message-implementation: ^1.0.0 || ^2.0.0
- psr/log: ^1.1.0 || ^2.0.0 || ^3.0.0
Requires (Dev)
- fig/log-test: ^1.1.0
- nyholm/psr7: ^1.0.0
- php-http/mock-client: ^1.5
- phpstan/phpstan: ^1.5.0
- phpunit/phpunit: ^10.1.0
- rector/rector: *
- squizlabs/php_codesniffer: ^3.4
This package is auto-updated.
Last update: 2024-10-27 15:51:28 UTC
README
The DHL Paket Parcel Management API SDK package offers an interface to the following web services:
- Parcel Management Checkout API
Requirements
System Requirements
- PHP 8.1+ with JSON extension
Package Requirements
netresearch/jsonmapper
: Mapper for deserialization of JSON response messages into PHP objectsphp-http/discovery
: Discovery service for HTTP client and message factory implementationsphp-http/httplug
: Pluggable HTTP client abstractionphp-http/logger-plugin
: HTTP client logger plugin for HTTPlugpsr/http-client
: PSR-18 HTTP client interfacespsr/http-factory
: PSR-7 HTTP message factory interfacespsr/http-message
: PSR-7 HTTP message interfacespsr/log
: PSR-3 logger interfaces
Virtual Package Requirements
psr/http-client-implementation
: Any package that provides a PSR-18 compatible HTTP clientpsr/http-factory-implementation
: Any package that provides PSR-7 compatible HTTP message factoriespsr/http-message-implementation
: Any package that provides PSR-7 HTTP messages
Development Package Requirements
fig/log-test
: PSR-3 logger implementation for testing purposesnyholm/psr7
: PSR-7 HTTP message factory & message implementationphpunit/phpunit
: Testing frameworkphp-http/mock-client
: HTTPlug mock client implementationphpstan/phpstan
: Static analysis toolrector/rector
: Automatic refactoring tool to help with PHP upgradessquizlabs/php_codesniffer
: Static analysis tool
Installation
$ composer require dhl/sdk-api-parcel-management
Uninstallation
$ composer remove dhl/sdk-api-parcel-management
Testing
$ ./vendor/bin/phpunit -c test/phpunit.xml
Features
The DHL Paket Parcel Management API SDK supports the following features:
- Query available DHL services during checkout (
/checkout/{recipientZip}/availableServices
)
Available Services
To present the customer with valid DHL service options during checkout, this API endpoint can be used.
Available DHL services are calculated using the zip code of the recipient's address (recipientZip
).
Public API
The library's components suitable for consumption comprise
- services:
- service factory
- checkout service
- data transfer objects:
- carrier services with availability flag and options (optional)
- exceptions
Usage
$serviceFactory = new \Dhl\Sdk\Paket\ParcelManagement\Service\ServiceFactory(); $service = $serviceFactory->createCheckoutService( $applicationId = '4pp-1D', $applicationToken = '4pp-t0k3N', $ekp = '1234567890', $logger = new \Psr\Log\NullLogger(), $sandbox = true ); $carrierServices = $service->getCarrierServices($postalCode = '12345', $dropOffDate = new \DateTime('2038-01-19')); // process response as desired: $getAvailableServices = function ( array $availableServices, \Dhl\Sdk\Paket\ParcelManagement\Api\Data\CarrierServiceInterface $carrierService ) { if ($carrierService->isAvailable()) { $availableServices[$carrierService->getCode()] = $carrierService; } return $availableServices; }; $availableServices = array_reduce($carrierServices, $getAvailableServices, []);