ecommercegeeks / myparcel-sdk
MyParcel SDK
Installs: 1 138
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
Requires
- saloonphp/saloon: ^3.0
Requires (Dev)
- ext-fileinfo: *
- fakerphp/faker: ^1.24
- pestphp/pest: ^3.5
- symfony/dotenv: ^7.2
- symfony/var-dumper: ^7.2
- dev-main
- 1.1.0
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-11-add-support-for-creating-unrelated-return-shipments-via-new-addreturnshipments-request
- dev-feature/9-implement-add-shipment-response-dto
- dev-feature/7-implement-track-shipment-request
- dev-feature/5-add-company-to-recipient
- dev-feature/3-implement-multi-collo-shipment
This package is auto-updated.
Last update: 2025-05-21 08:24:47 UTC
README
The official SDK for MyParcel contains many smart features that in practice get in the way more than help. So we developed this dumb SDK.
This SDK stays close to the API documentation. DTOs and Enums are used where it makes sense. This SDK is light on documentation, because autocomplete will show you the way.
Usage
Installation
composer require ecommercegeeks/myparcel-sdk
Creating a label
// Creating a connector doesn't make a network request yet, so can be initialized safely at application init. $connector = new Connector($apiKey); // Fill the DTOs $shipment = new Shipment(recipient: new Recipient(...), ...); // Create the request $shipmentRequest = new AddShipments([$shipment]); // Send the request $response = $connector->send($shipmentRequest); // Convert the request to an array of Shipment ids $ids = $response->dtoOrFail();
For more usage examples, have a look at the tests in the tests/Feature
folder.
Be careful
This is a dumb SDK, so this SDK doesn't check correctness of the data. You have to take into account that the MyParcel service is also lenient on data errors. You can easily create a label for a non-existent address. When you delete non-existing shipments, MyParcel doesn't respond with an error.
Implemented requests
Request | Endpoint | dto() | Description |
---|---|---|---|
AddShipment | POST /shipments | ||
GetShipments | GET /shipments | ||
UpdateShipment | PATCH /shipments | ||
DeleteShipment | DELETE /shipments | ||
GetLocations | GET /locations | array of locations | Endpoint is limited to NL |
MatchLocations | GET /locations/match | - | |
GetShipmentLabels | GET /shipment_labels |
Testing
Testing is performed against the actual API. Copy test.example.env
to test.env
and enter your API key. Then execute
the test suite by running ./vendor/bin/pest
. Because the tests are executed against the actual API, no CI/CD is in
place.
Feature tests
The feature tests in the tests/Feature
folder go through a cycle where a shipment is created and then either updated
or deleted. All feature tests either delete or hide the shipments after the cycle.
Contributing
When you find an endpoint which is not implemented yet you are invited to add the required classes to this SDK through a pull request. Take the following in order:
Request classes
All DTO arguments are provided through the constructor. We use one class for both the request and the response, when arguments are not required for a request, or not always present in responses, these arguments are default null so should be last in the argument list of the constructor.
Tests
Because tests are performed against the production API, make sure that tests delete or hide all created shipments.
When you are working in the test suite, you can display the sent request and response by setting $this->debug = true
within the test.