DPD shipping API for Hungarian DPD Weblabel webservice interface via POST requests
The easiest way to install the API is using Composer:
composer require schiggi/dpd-shipping-api
Then use your framework's autoload, or simply add:
<?php
require 'vendor/autoload.php';
You can start making requests to the Billingo API just by creating a new API
instance
<?php
$api = new DPD\API([
'username' => 'demo',
'password' => 'o2Ijwe2',
]);
The API
class takes care of the communication between your app and the DPD servers via POST requests.
Monolog is used optionally to log request/responses with DPD server.
You need to specific a log dir and optionally a message format when creating a new API
instance. Log files while have the name "api-dpd-consumer-{date}.log"
<?php
$api = new DPD\API([
'username' => 'demo',
'password' => 'o2Ijwe2!',
'log_dir' => dirname(__FILE__).'/',
'log_msg_format' => [
'{method} {uri} HTTP/{version} {req_body}',
'RESPONSE: {code} - {res_body}',
]
]);
<?php
// Parcel generation. Data will be validated before sending.
$parcel_generate = array(
'setName1' => 'Alex',
'setStreet' => 'Kesmark u 4',
'setCity' => 'Budapest',
'setCountry' => 'HU',
'setPcode' => '1158',
'setWeight' => '1',
'setNumOfParcel' => 1,
'setParcelType' => 'BC',
'setOrderNumber' => '1234',
'setCodAmount' => '',
'setCodPurpose' => '',
'setEmail' => 'test@test.de',
'setPhone' => '0636516516',
'setSMSNumber' => '0636516516',
'setRemark' => 'Customer comments',
); // Max length 100 chars. Will be normalized through the API
// Will return the parcel number from DPD or error message
$parcel_number = $api->generateParcel($parcel_generate);
<?php
// Array of parcel numbers from DPD. Can also be a string with one number
$parcel_array = array('123456789','987654321');
// Returns json array with success message and pdf stream
$parcel_response_json = $api->getParcelLabels($parcel_array);
// Echo to get pdf stream
header("Content-type:application/pdf");
echo $parcel_response_json['pdf'];
<?php
// Array of parcel numbers from DPD. Can also be a string with one number
$parcel_array = array('123456789','987654321');
// Returns json array with success message
$parcel_delete_status = $api->deleteParcel($parcel_array);
<?php
// returns the numbers of parcels, which have been succesfully transfered
$number_parcels_sent = $api->transferData();
<?php
// returns status message as string for parcel_number. One number at a time.
$status_msg = $api->getParcelStatus('123456789');