{"id":37014376,"url":"https://github.com/dreipunktnull/dhl-express","last_synced_at":"2026-01-14T01:25:30.799Z","repository":{"id":56972093,"uuid":"105989918","full_name":"dreipunktnull/dhl-express","owner":"dreipunktnull","description":"Generated and adjusted DHL Express SOAP API client","archived":true,"fork":false,"pushed_at":"2018-08-22T08:53:35.000Z","size":64,"stargazers_count":10,"open_issues_count":0,"forks_count":4,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-10-21T01:49:49.857Z","etag":null,"topics":["dhl","php"],"latest_commit_sha":null,"homepage":null,"language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dreipunktnull.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2017-10-06T09:54:19.000Z","updated_at":"2023-01-28T08:14:49.000Z","dependencies_parsed_at":"2022-08-21T10:20:13.218Z","dependency_job_id":null,"html_url":"https://github.com/dreipunktnull/dhl-express","commit_stats":null,"previous_names":[],"tags_count":5,"template":false,"template_full_name":null,"purl":"pkg:github/dreipunktnull/dhl-express","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dreipunktnull%2Fdhl-express","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dreipunktnull%2Fdhl-express/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dreipunktnull%2Fdhl-express/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dreipunktnull%2Fdhl-express/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dreipunktnull","download_url":"https://codeload.github.com/dreipunktnull/dhl-express/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dreipunktnull%2Fdhl-express/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28407696,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-14T00:40:43.272Z","status":"ssl_error","status_checked_at":"2026-01-14T00:40:42.636Z","response_time":56,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["dhl","php"],"created_at":"2026-01-14T01:25:27.492Z","updated_at":"2026-01-14T01:25:30.787Z","avatar_url":"https://github.com/dreipunktnull.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"# DHL Express SOAP API client\n\nA generated SOAP API client for the [DHL Express Global Webservice](https://www.dhl.com).\n\n## Installation\n\nTo install the package, you can use composer:\n\n```\ncomposer require dreipunktnull/dhl-express\n```\n\nUsage without composer is currently not possible and needs some adjustments in the provided autoloader.\n\n## Shipment Requests\n\nA shipment request is usually created through the webservice and in order to mutate (f.e. cancel) it,\nwe need some parameters. You should therefore create your own `ShipmentRequest` data class and persist\nthe `ShipmentDetail` data points.\n\nAs of now, no such class is included.\n\n```php\nclass ShipmentRequestService\n{\n    /**\n     * @var string\n     */\n    private $user;\n\n    /**\n     * @var string\n     */\n    private $password;\n\n    /**\n     * @var string\n     */\n    private $accountNumber;\n\n    /**\n     * @param string $user\n     * @param string $password\n     * @param string $accountNumber\n     */\n    public function __construct(string $user, string $password, string $accountNumber)\n    {\n        $this-\u003euser = $user;\n        $this-\u003epassword = $password;\n        $this-\u003eaccountNumber = $accountNumber;\n    }\n    \n    /**\n     * @param \\DateTimeInterface $shipTimestamp\n     * @param ContactInfoType    $sender\n     * @param ContactInfoType    $recipient\n     * @param ShipmentRequest    $shipmentRequest\n     * @param string|null        $restrictToServiceType\n     *\n     * @return \\DHL\\Express\\Webservice\\ShipmentDetailType\n     */\n    public function createShipping(\\DateTimeInterface $shipTimestamp, ContactInfoType $sender, ContactInfoType $recipient, ShipmentRequest $shipmentRequest, $restrictToServiceType = null)\n    {\n        $webservice = $this-\u003eprepareWebservice();\n\n        $shipmentInfo = new ShipmentInfoType(\n            DropOffType::REQUEST_COURIER,\n            $this-\u003ecalculateShippingType($shipmentRequest),\n            ShipmentInfoType::CURRENCY_EUR,\n            UnitOfMeasurement::SI\n        );\n\n        $shipmentInfo-\u003esetAccount($this-\u003eaccountNumber);\n\n        $internationalDetail = new InternationDetailType(new CommoditiesType('Keine Angabe'));\n        $internationalDetail-\u003esetContent(Content::DOCUMENTS);\n\n        $requestedShipment = new RequestedShipmentType(\n            $shipmentInfo,\n            sprintf('%sT%s GMT+01:00', $shipTimestamp-\u003eformat('Y-m-d'), $shipTimestamp-\u003eformat('H:i:s')),\n            PaymentInfo::DDP,\n            $internationalDetail,\n            new ShipType($sender, $recipient),\n            new docTypeRef_PackagesType(\n                new docTypeRef_RequestedPackagesType(\n                    self::PACKAGE_WEIGHT,\n                    new docTypeRef_DimensionsType(self::PACKAGE_LENGTH, self::PACKAGE_WIDTH, self::PACKAGE_HEIGHT),\n                    '1',\n                    1,\n                    'No Description'\n                )\n            )\n        );\n\n        if (null !== $shipmentRequest-\u003egetSpecialPickupInstruction()) {\n            $requestedShipment-\u003esetSpecialPickupInstruction($shipmentRequest-\u003egetSpecialPickupInstruction());\n        }\n\n        if (null !== $shipmentRequest-\u003egetPickupLocation()) {\n            $requestedShipment-\u003esetPickupLocation($shipmentRequest-\u003egetPickupLocation());\n        }\n\n        if ($shipTimestamp instanceof \\DateTimeImmutable) {\n            $pickupLocationCloseTime = $shipTimestamp-\u003emodify('+91 minutes');\n        } else {\n            $pickupLocationCloseTime = \\DateTimeImmutable::createFromMutable($shipTimestamp)-\u003emodify('+91 minutes');\n        }\n\n        $requestedShipment-\u003esetPickupLocationCloseTime($pickupLocationCloseTime-\u003eformat('H:i'));\n\n        $request = new ProcessShipmentRequestType($requestedShipment);\n\n        $shipmentDetailType = $webservice-\u003ecreateShipmentRequest($request);\n\n        return $shipmentDetailType;\n    }\n    \n    /**\n     * This should only be done if the pickup type is something other than PickupType::Regular.\n     *\n     * @param ShipmentRequest $shipmentRequest\n     * @param string $requester This parameter is required but won't be evaluated.\n     * @param string $reason    This parameter is optional but may be useful.\n     * @return DeleteResponseType\n     */\n    public function cancel(ShipmentRequest $shipmentRequest, $requester = 'ERNIE_OR_BERT', $reason = DeleteRequestType::REASON_REASON_NOT_GIVEN): DeleteResponseType\n    {\n        $webservice = $this-\u003eprepareWebservice();\n\n        $deleteRequest = new DeleteRequestType(\n            $shipmentRequest-\u003egetShipmentTime()-\u003eformat('Y-m-d'),\n            $shipmentRequest-\u003egetPickupCountry(),\n            $shipmentRequest-\u003egetDispatchConfirmationNumber(),\n            $requester\n        );\n\n        $deleteRequest-\u003esetReason($reason);\n\n        return $webservice-\u003edeleteShipmentRequest($deleteRequest);\n    }\n\n    /**\n     * @return GblDHLExpressTrack\n     */\n    private function prepareWebservice(): GblDHLExpressTrack\n    {\n        $track = new GblDHLExpressTrack(['trace' =\u003e 1]);\n\n        $wsse_header = WssWsuAuthHeader::soapClientWSSecurityHeader($this-\u003euser, $this-\u003epassword, $this-\u003eaccountNumber);\n        $track-\u003e__setSoapHeaders([$wsse_header]);\n\n        return $track;\n    }\n}\n```\n\n## Tracking\n\nExample Tracking Service that is able to authenticate and track a package:\n\n```php\n\nuse DHL\\Express\\Webservice\\Soap\\WssWsuAuthHeader;\nuse DHL\\Express\\Webservice\\Tracking\\ArrayOfAWBNumber;\nuse DHL\\Express\\Webservice\\Tracking\\GblDHLExpressTrack;\nuse DHL\\Express\\Webservice\\Tracking\\LevelOfDetails;\nuse DHL\\Express\\Webservice\\Tracking\\PublicTrackingRequest;\nuse DHL\\Express\\Webservice\\Tracking\\Request;\nuse DHL\\Express\\Webservice\\Tracking\\ServiceHeader;\nuse DHL\\Express\\Webservice\\Tracking\\TrackingRequest;\nuse DHL\\Express\\Webservice\\Tracking\\TrackShipmentRequest;\nuse Ramsey\\Uuid\\Uuid;\n\nclass TrackingService\n{\n    /**\n     * @var string\n     */\n    private $user;\n\n    /**\n     * @var string\n     */\n    private $password;\n\n    /**\n     * @var string\n     */\n    private $accountNumber;\n\n    /**\n     * @param string $user\n     * @param string $password\n     * @param string $accountNumber\n     */\n    public function __construct(string $user, string $password, string $accountNumber)\n    {\n        $this-\u003euser = $user;\n        $this-\u003epassword = $password;\n        $this-\u003eaccountNumber = $accountNumber;\n    }\n\n    /**\n     * Tracks a package.\n     *\n     * @param string $trackingNumber\n     * @param string $levelOfDetails\n     * @return \\DHL\\Express\\Webservice\\Tracking\\trackShipmentRequestResponse\n     */\n    public function track($trackingNumber, $levelOfDetails = LevelOfDetails::LAST_CHECK_POINT_ONLY)\n    {\n        $webservice = $this-\u003eprepareWebservice();\n        $parameters = new TrackShipmentRequest();\n\n        $trackingRequest = new TrackingRequest(new Request(new ServiceHeader(new \\DateTime(), implode('', explode('-', Uuid::uuid4())))), $levelOfDetails);\n        $trackingRequest-\u003esetAWBNumber(new ArrayOfAWBNumber([$trackingNumber]));\n\n        $parameters-\u003esetTrackingRequest(new PublicTrackingRequest($trackingRequest));\n\n        return $webservice-\u003etrackShipmentRequest($parameters);\n    }\n\n    /**\n     * @return GblDHLExpressTrack\n     */\n    private function prepareWebservice(): GblDHLExpressTrack\n    {\n        $track = new GblDHLExpressTrack(['trace' =\u003e 1]);\n\n        $wsse_header = WssWsuAuthHeader::soapClientWSSecurityHeader($this-\u003euser, $this-\u003epassword, $this-\u003eaccountNumber);\n        $track-\u003e__setSoapHeaders([$wsse_header]);\n\n        return $track;\n    }\n}\n\n```\n\n## Acknowledgements\n\nThe base version of this library was generated with [wsdl2phpgenerator](https://github.com/wsdl2phpgenerator/wsdl2phpgenerator).\n\n## Support\n\nPlease use the GitHub issue tracker. For commercial support for your project contact\n[dreipunktnull](https://dreipunktnull.com).\n\n## License\n\nMIT\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdreipunktnull%2Fdhl-express","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdreipunktnull%2Fdhl-express","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdreipunktnull%2Fdhl-express/lists"}