c24-toys/sdk-api-bcs-returns

DHL Paket Retoure API SDK

1.0.0 2024-08-06 13:45 UTC

This package is not auto-updated.

Last update: 2024-09-18 12:36:17 UTC


README

DHL Paket Retoure API SDK 软件包提供以下 Web 服务的接口

  • API 返回

要求

系统要求

  • PHP 7.2+ 且具有 JSON 扩展

包要求

  • php-http/discovery: HTTP 客户端和消息工厂实现发现服务
  • php-http/httplug: 可插拔的 HTTP 客户端抽象
  • php-http/logger-plugin: HTTPlug 的 HTTP 客户端日志插件
  • psr/http-client: PSR-18 HTTP 客户端接口
  • psr/http-factory: PSR-7 HTTP 消息工厂接口
  • psr/http-message: PSR-7 HTTP 消息接口
  • psr/log: PSR-3 日志接口

虚拟包要求

  • psr/http-client-implementation: 任何提供 PSR-18 兼容 HTTP 客户端的包
  • psr/http-factory-implementation: 任何提供 PSR-7 兼容 HTTP 消息工厂的包
  • psr/http-message-implementation: 任何提供 PSR-7 HTTP 消息的包

开发包要求

  • nyholm/psr7: PSR-7 HTTP 消息工厂和消息实现
  • phpunit/phpunit: 测试框架
  • php-http/mock-client: HTTPlug 模拟客户端实现
  • phpstan/phpstan: 静态分析工具
  • squizlabs/php_codesniffer: 静态分析工具

安装

$ composer require dhl/sdk-api-bcs-returns

卸载

$ composer remove dhl/sdk-api-bcs-returns

测试

$ ./vendor/bin/phpunit -c test/phpunit.xml

功能

DHL Paket Retoure API SDK 支持以下功能

退货标签服务

创建一个退货标签 PDF 或 QR 码,以便由承诺地点(例如邮局)扫描。对于来自欧盟外部的退货运输,还可以请求海关文件。

公共 API

适用于消费的库组件包括

  • 服务
    • 服务工厂
    • 退货标签服务
    • 数据传输对象构建器
  • 数据传输对象
    • 认证存储
    • 带有标签数据的预订确认

用法

$authStorage = new \Dhl\Sdk\Paket\Retoure\Auth\AuthenticationStorage(
    'applicationId',
    'applicationToken',
    'user',
    'signature'
);
$logger = new \Psr\Log\NullLogger();

$serviceFactory = new \Dhl\Sdk\Paket\Retoure\Service\ServiceFactory();
$service = $serviceFactory->createReturnLabelService($authStorage, $logger, $sandbox = true);

$requestBuilder = new \Dhl\Sdk\Paket\Retoure\Model\ReturnLabelRequestBuilder();
$requestBuilder->setAccountDetails($receiverId = 'deu');
$requestBuilder->setShipperAddress(
    $name = 'Jane Doe',
    $countryCode = 'DEU',
    $postalCode = '53113',
    $city = 'Bonn',
    $streetName = 'Sträßchensweg',
    $streetNumber = '2'
);

$returnOrder = $requestBuilder->create();
$confirmation = $service->bookLabel($returnOrder);