ShippingProAPICollection 1.1.6
See the version list below for details.
dotnet add package ShippingProAPICollection --version 1.1.6
NuGet\Install-Package ShippingProAPICollection -Version 1.1.6
<PackageReference Include="ShippingProAPICollection" Version="1.1.6" />
paket add ShippingProAPICollection --version 1.1.6
#r "nuget: ShippingProAPICollection, 1.1.6"
// Install ShippingProAPICollection as a Cake Addin #addin nuget:?package=ShippingProAPICollection&version=1.1.6 // Install ShippingProAPICollection as a Cake Tool #tool nuget:?package=ShippingProAPICollection&version=1.1.6
Shipping Pro API Collection
Welcome to our C# library, designed to integrate multiple shipping service APIs into one streamlined solution. This project provides a unified interface for GLS GLS, DHL, and DPD, simplifying the shipping process for developers and businesses. With easy integration, you can handle logistics across different carriers seamlessly. Ideal for enhancing efficiency in e-commerce and logistics operations.
Provider
GLS GLS Germany (API Documentation)
- Create Shipment
- Cancel Shipment
- Validate Label
- Get Estimated Delivery Days
DHL Parcel Germany (2.1.8) ([API Documentation] (https://developer.dhl.com/api-reference/parcel-de-shipping-post-parcel-germany-v2#downloads-section))
- Create Shipment
- Cancel Shipment
DPD Germany (4.4) ([API Documentation] (https://esolutions.dpd.com/dokumente/ShipmentService_V4_4.pdf))
- Login (2.0) ([API Documentation] (https://esolutions.dpd.com/dokumente/LoginService_V2_0.pdf))
- Create Shipment
- Cancel Shipment
Get Started
Before requesting shipping labels, you must first set up your specific shipping provider settings. This is achieved by injecting these settings as a singleton through dependency injection.
To finalize the setup, register the ShippingProAPICollectionService as a scoped service in your application.
services.AddScoped<ShippingProAPICollectionService>();
ShippingProAPICollectionSettings providerSettings = new ShippingProAPICollectionSettings()
GLS GLS
GLSSettings GLSSettings = new GLSSettings()
{
// PLEASE GET IN TOUCH WITH YOUR GLS CONTACT TO GET THE FOLLOWING INFORMATIONS
// Api domain => https://shipit-wbm-test01.gls-group.eu:443
ApiDomain = "https://shipit-wbm-test01.gls-group.eu:443",
ContactID = "276a45fkqM",
Username = "276a45fkqM"
Password = "lXZBIF7uRccyK7Ohr64d",
};
providerSettings.AddSettings(GLSSettings);
DHL Parcel DE Shipping
DHLSettings dhlSettings = new DHLSettings()
{
// Api domain is the XXXXXXX part of your DHL api url => https://api-XXXXXXX.dhl.com/parcel/de/shipping/v2/
ApiDomain = "sandbox",
Password = "pass",
Username = "sandy_sandbox",
DHLShipmentProfile = "STANDARD_GRUPPENPROFIL",
InternationalAccountNumber = "33333333335301",
NationalAccountNumber = "33333333330102",
LabelPrintFormat = "910-300-410",
// Create your DHL APP here -> https://developer.dhl.com/user/apps
APIKey = "",
APILanguage = "de-DE" // en-US or de-DE
};
providerSettings.AddSettings(dhlSettings);
DPD
DPDSettings dpdSettings = new DPDSettings()
{
// Api domain is the XXXXXXX part of your DPD api url => https://public-XXXXXXX.dpd.com/services/ShipmentService/V4_4/
ApiDomain = "ws-stage",
APILanguage = "de_DE", // en_EN or de_DE
DepotNumber = "0191",
Username = "sandboxdpd",
Password = "xMmshh1"
};
providerSettings.AddSettings(dpdSettings);
Add multiple contract accounts
At times, you may need to utilize multiple contract accounts from the same provider. You can add multiple contracts by specifying a contract ID like this:
// Setup first contract
DPDSettings dpdContract1Settings = new DPDSettings()
{
// Api domain is the XXXXXXX part of your DPD api url => https://public-XXXXXXX.dpd.com/services/ShipmentService/V4_4/
ApiDomain = "ws-stage",
APILanguage = "de_DE", // en_EN or de_DE
DepotNumber = "0191",
Username = "sandboxdpd",
Password = "xMmshh1"
};
providerSettings.AddSettings("DPD1", dpdContract1Settings);
// Setup second contract
DPDSettings dpdContract3Settings = new DPDSettings()
{
// Api domain is the XXXXXXX part of your DPD api url => https://public-XXXXXXX.dpd.com/services/ShipmentService/V4_4/
ApiDomain = "ws-stage",
APILanguage = "de_DE", // en_EN or de_DE
DepotNumber = "0191",
Username = "sandboxdpd",
Password = "xMmshh1"
};
providerSettings.AddSettings("DPD2", dpdSettings);
Docker
Environment variables
Address
Name | Type | Required | Example |
---|---|---|---|
ADDRESS_CITY |
String | * | Ellwangen |
ADDRESS_CONTACT_NAME |
String | * | Kevin Mustermann |
ADDRESS_COUNTRY_CODE_ISOA2 |
String | * | DE |
ADDRESS_EMAIL |
String | * | kevin.mustermann@gmail.com |
ADDRESS_NAME |
String | * | Max GmbH |
ADDRESS_POSTCODE |
String | * | 73479 |
ADDRESS_STREET |
String | * | Max-Straße 15 |
ADDRESS_PHONE |
String | * | 0152012345678 |
DPD
Name | Type | Required | Example |
---|---|---|---|
DPD_API_DOMAIN |
String | * | ws-stage or ws |
DPD_API_LANGUAGE |
String | * | de_DE or en_EN |
DPD_DEPOT_NUMBER |
String | * | 0191 |
DPD_PASSWORD |
String | * | xMmshh1 |
DPD_USERNAME |
String | * | sandboxdpd |
DHL
Name | Type | Required | Example |
---|---|---|---|
DHL_API_DOMAIN |
String | * | sandbox or eu |
DHL_USERNAME |
String | * | sandy_sandbox |
DPD_PASSWORD |
String | * | pass |
DHL_INTERNATIONAL_ACCOUNT_NUMBER |
String | * | 33333333335301 |
DHL_NATIONAL_ACCOUNT_NUMBER |
String | * | 33333333330102 |
DHL_LABEL_FORMAT |
String | * | 910-300-410 |
DHL_API_KEY |
String | * | sandboxdpd |
DHL_API_LANGUAGE |
String | * | de-DE |
GLS
Name | Type | Required | Example |
---|---|---|---|
GLS_API_DOMAIN |
String | * | https://shipit-wbm-test01.gls-group.eu:443 |
GLS_CONTRACT_ID |
String | * | 276a5fkqM |
GLS_PASSWORD |
String | * | lXZBIF7uccyK7Ohr64d |
GLS_USERNAME |
String | * | 276a5fkqM |
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- itext.bouncy-castle-adapter (>= 8.0.3)
- itext7 (>= 8.0.3)
- JsonSubTypes (>= 2.0.1)
- Microsoft.Extensions.Caching.Abstractions (>= 8.0.0)
- Newtonsoft.Json (>= 13.0.3)
- RestSharp (>= 110.2.0)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.ServiceModel.Duplex (>= 4.10.3)
- System.ServiceModel.Federation (>= 4.10.3)
- System.ServiceModel.Http (>= 4.10.3)
- System.ServiceModel.NetTcp (>= 4.10.3)
- System.ServiceModel.Primitives (>= 4.10.3)
- System.ServiceModel.Security (>= 4.10.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.