soneritics / postnl
PostNL API and Aanmaken van PostNL vooraanmeldingbestanden om pakketten te verzenden.
Installs: 8 523
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 5
Forks: 2
Open Issues: 2
Requires
- educoder/pest: ^1.0
Requires (Dev)
README
Introduction
This library offers a variety of functions for PostNL. Mainly, these are the two categories:
- PostNL API - https://developer.postnl.nl
- PostNL Voormeldbestand
Minimum requirements
- PHP 7.1
Installation
Use Composer to install: soneritics/postnl
PostNL API
The base for connecting to the PostNL API will be provided by this plugin. It is advised not to use it in a production environment, as it's nog error-proof, nor (fully automated) tested. It does work, though, and is currently being tested in a production environment :-)
Create an issue if you need help, or need more services than the ones provided.
Supported APIs
*
v2_2
supports ERS labels
Code example: Creating the API
Always start with creating the API object.
$apiKey = '*YOUR API KEY*'; $endpoints = new Sandbox; $customer = (new Customer) ->setCustomerCode('DEVC') ->setCustomerNumber('11223344') ->setAddress((new Address) ->setAddressType(AddressType::SENDER) ->setCompanyName('Soneritics') ->setStreet('De Rosmolen') ->setHouseNr('123') ->setZipcode('1234AB') ->setCity('Amsterdam') ->setCountrycode('NL') ); $api = new API($apiKey, $customer, $endpoints);
Code example: Fetching a barcode
$barcodeService = $api->getBarcodeService(); $barcode = $barcodeService->generateBarcode(); echo "generated barcode: {$barcode}\r\n";
Code example: Generate a label and confirm shipment (basic)
$message = new Message(1, PrinterType::JPG); $dimension = (new Dimension)->setWeight(1000); $receivingAddress = (new Address) ->setAddressType(AddressType::RECEIVER) ->setCompanyName('Jordi Jolink') ->setStreet('Some street') ->setHouseNr('123') ->setZipcode('1234AB') ->setCity('Amsterdam') ->setCountrycode('NL'); $shipments = (new Shipments)->addShipment( (new Shipment) ->setAddresses((new Addresses)->addAddress($receivingAddress)) ->setBarcode($barcode) ->setDimension($dimension) ); $result = $api->getLabellingService()->generateLabel($shipments, $message); $labelContentsBase64 = $result['ResponseShipments'][0]['Labels'][0]['Content'];
Code example: Get time frames, get a label and confirm the shipment
$receivingAddress = (new Address) ->setAddressType(AddressType::RECEIVER) ->setCompanyName('Soneritics') ->setStreet('Some street') ->setHouseNr('123') ->setZipcode('1234AB') ->setCity('Amsterdam') ->setCountrycode('NL'); $deliveryOptions = [ DeliveryOptions::DAYTIME, DeliveryOptions::EVENING, DeliveryOptions::AFTERNOON, DeliveryOptions::MORNING, DeliveryOptions::NOON ]; $result = $api->getTimeframeService()->calculateTimeframes($receivingAddress, $deliveryOptions); echo "Timeframes:\r\n"; print_r($result); # Confirm time frame $barcodeService = $api->getBarcodeService(); echo "Confirming timeframe..\r\n"; if (!empty($result['Timeframes']['Timeframe'])) { $timeframe = array_pop($result['Timeframes']['Timeframe']); if ($timeframe !== null) { $deliveryTimestampStart = new DateTime($timeframe['Date'] . ' ' . $timeframe['Timeframes']['TimeframeTimeFrame']['From']); $deliveryTimestampEnd = new DateTime($timeframe['Date'] . ' ' . $timeframe['Timeframes']['TimeframeTimeFrame']['To']); $contact = (new Contact)->setEmail('mail@no-spam4me.nl'); $shipments = (new Shipments)->addShipment( (new Shipment) ->setAddresses((new Addresses)->addAddress($receivingAddress)) ->setBarcode($barcodeService->generateBarcode()) ->setDimension($dimension) ->setDeliveryDate($deliveryTimestampStart) ->setDeliveryTimeStampStart($deliveryTimestampStart) ->setDeliveryTimeStampEnd($deliveryTimestampEnd) ->setContacts((new Contacts)->addContact($contact)) ); $result = $api->getLabellingService()->generateLabel($shipments, $message); print_r($result); } } echo "Timeframe confirmed.\r\n";
Code example: Fetch nearest locations
$receivingAddress = (new Address) ->setAddressType(AddressType::RECEIVER) ->setZipcode('1234AB') ->setCountrycode('NL'); $result = $api->getLocationsService()->getNearestLocations($receivingAddress); print_r($result);
Code example: Fetch nearest locations by geocode and lookup location info
$result = $api->getLocationsService()->getNearestLocationsByGeocode(51.963807, 5.968984, 'NL'); if (!empty($result['GetLocationsResult']['ResponseLocation'])) { $location = $result['GetLocationsResult']['ResponseLocation'][0]; print_r($location); echo "Location info:\r\n"; $locationCode = $location['LocationCode']; $retailNetworkID = $location['RetailNetworkID']; print_r($api->getLocationsService()->getLocationInformation($locationCode, $retailNetworkID)); }
Code example: Fetch nearest location and create a label for pickup at the pickup point
$result = $api->getLocationsService()->getNearestLocationsByGeocode(51.963807, 5.968984, 'NL'); if (!empty($result['GetLocationsResult']['ResponseLocation'])) { $location = $result['GetLocationsResult']['ResponseLocation'][0]; $locationCode = $location['LocationCode']; $retailNetworkID = $location['RetailNetworkID']; $pickupAddress = (new \PostNL\Model\Address) ->setAddressType(\PostNL\Enum\AddressType::DELIVERY_ADDRESS_FOR_PICKUP) ->setCompanyName($location['Name']) ->setStreet($location['Address']['Street']) ->setHouseNr($location['Address']['HouseNr']) ->setZipcode($location['Address']['Zipcode']) ->setCity($location['Address']['City']) ->setCountrycode('NL'); $contact = (new Contact)->setEmail('mail@jordijolink.nl'); $shipments = (new Shipments)->addShipment( (new Shipment) ->setAddresses((new Addresses)->addAddress($receivingAddress)->addAddress($pickupAddress)) ->setBarcode($barcodeService->generateBarcode()) ->setDimension($dimension) ->setContacts((new Contacts)->addContact($contact)) ->setProductCodeDelivery('3533') ->setDeliveryAddress(AddressType::DELIVERY_ADDRESS_FOR_PICKUP) ); $result = $api->getLabellingService()->generateLabel($shipments, $message); print_r($result); }
Code example: Get the shipping status (via a barcode)
$endpoints = new Sandbox();
$api = new API($key, new Customer(), $endpoints);
$data = $api->getShippingStatusService()->getByBarcode($barcode);
PostNL Vooraanmelding
Codetaal: Nederlands
Voor de taal van de classes, variabelen en commentaar is gekozen voor Nederlands. Daarbij worden getters en setters als hybride aangeduid, bijvoorbeeld: setKlantnummer. Hiervoor is gekozen aangezien PostNL uitsluitend binnen Nederland verzendt, en daardoor ook vooral door Nederlanders geïmplementeerd zal worden. Daarnaast worden specifieke woorden gebruikt, waarvan de Engelse vertaling de werking erg onduidelijk zal maken.
Code example
$afzender = (new Afzender) ->setBedrijfsnaam('Bedrijfsnaam') ->setPostcode('1234AB') ->setHuisnummerPostbusnummer('1') ->setLandcode('NL'); $voormelding = (new Voormelding) ->setAfzender($afzender) ->setKlantCode($customerCode) ->setKlantNummer($customerNr) ->setVolgnummer($volgnummer) ->setAanleverLocatie($bls); $pakket = (new Pakket) ->setGeadresseerdeBedrijfsnaam($company) ->setGeadresseerdeVoornaam($firstname) ->setGeadresseerdeAchternaam($lastname) ->setGeadresseerdePostcode($zipcode) ->setGeadresseerdeStraatnaam($streetname) ->setGeadresseerdeHuisnummerPostbusnummer($housenumber) ->setGeadresseerdeHuisnummerToevoeging($housenumberExtension) ->setGeadresseerdeWoonplaats($city) ->setGeadresseerdeLandcode($country) ->setEmailadres($email) ->setZendingcode($shipmentCode); $voormelding->addPakket($pakket); // Contents ophalen. Dit kan opgeslagen worden in een LST bestand. $voormeldContents = $voormelding->genereerInhoud()
ERS
Using ERS
The product code for ERS labels is 4910
.
PostNL does not have documentation available for this product code, but you can use the documentation from product code 3085 Return label in the box
as a base.
There are additional things required for using ERS:
- The
CustomerCode
(4 letters) should have ERS enabled, or be ERS specific. Contact PostNL support for this. - The
Addressses
of theCustomer
andShipment
all need to have aname
filled in. - The
ReturnBarcode
should be set.