The MyParcel PDK (Plugin Development Kit) is meant for developing entire plugins on PHP E-Commerce platforms. If you're just looking to connect to our API without creating an entire plugin, you should check out our php SDK.
- PHP 7.4 – 8.5
- Composer
For examples, guides and in-depth information, visit our Plugin Development Kit (PDK) documentation.
Create an issue or contact us via our Developer Portal contact page.
View our contribution guidelines for information on how to contribute to the PDK.
- Node 18
- Yarn
- Docker
Create .env:
cp .env.template .envInstall Yarn dependencies:
yarnInstall Composer dependencies:
docker compose up phpRun all tests:
docker compose run php composer testThe default PHP version is 7.4. To test on a different version, change PHP_VERSION in .env and rebuild:
docker compose build
docker compose run php composer testShipment options are managed through the OrderOptionDefinitionInterface system. Each option is a single Definition class that declares all its keys (shipment, capabilities, carrier settings, product settings, allow, price). All models, views, and services build their attributes and form elements dynamically from these definitions.
To add a new option:
- Create a Definition class in
src/App/Options/Definition/extendingAbstractOrderOptionDefinition. Only two methods are required:getShipmentOptionsKey()— the PDK-internal key, derived fromStr::camel(RefShipmentShipmentOptions::attributeMap()['sdk_key'])getCapabilitiesOptionsKey()— the V2 capabilities key, fromRefCapabilitiesContractDefinitionsResponseOptionsOptionsV2::attributeMap()['capabilities_key']
- Register it in the
orderOptionDefinitionsarray inconfig/pdk-business-logic.php. - Optionally, add a deprecated constant to
ShipmentOptionsif platform integrations reference the key directly.
Everything else (carrier settings, product settings, allow/price toggles, validation, frontend form fields, API export/import) is derived automatically. Run yarn test:unit to verify the consistency tests pass.
If the option is not yet in the SDK types, update the SDK or regenerate the OpenAPI types first.
Using Claude Code? Run
/add-shipment-optionfor a guided step-by-step walkthrough that asks the right questions and generates the code.
We use Prettier to format .json, .yml, .md and .html files.
Make sure Prettier is enabled in your IDE and runs on the following files:
{**/*,*}.{md,html,yml,json}
Set up Git hooks to run Prettier on each commit, correcting any formatting issues.
yarn prepareYou can also run Prettier manually:
# Check formatting issues
yarn lint
# Fix formatting issues
yarn lint:fix