Skip to main content

SendCloud Shipping Provider Integration for django-shop

Project description

SendCloud Shipping Provider Integration for django-SHOP

This integrates the SendCloud API for django-SHOP version 1.0 and above.

Installation

for django-SHOP version 1.0 and later:

pip install djangoshop-sendcloud<1.1

Preparation

At SendCloud create an account.

In your personal account settings, click on Settings. There:

  • Add a Sender Address.
  • In Financial > Direct Debit add your recurring payment settings. There your bank account is charged with € 0.01, but this may take a few hours or even one day until everything is checked.
  • In Selected Shop select SendCloud API with a name of your choice. There, extract the Public Key and the Secret Key (see below).

Configuration

In settings.py of the merchant's project:

Add 'shop_sendcloud' to INSTALLED_APPS.

Add 'shop_sendcloud.modifiers.SendcloudShippingModifier' to the list of SHOP_CART_MODIFIERS.

Add 'shop_sendcloud.shipping.OrderWorkflowMixin' to the list of SHOP_ORDER_WORKFLOWS.

If you run django-SHOP with partial delivery, replace the OrderItemSerializer with the one provided: SHOP_ORDER_ITEM_SERIALIZER = 'shop_sendcloud.serializers.OrderItemSerializer' and change the workflow to:

SHOP_ORDER_WORKFLOWS = [
    ...
    'shop_sendcloud.workflows.CommonOrderWorkflowMixin',
    'shop.shipping.workflows.PartialDeliveryWorkflowMixin',
]

Otherwise, without partial delivery, change the workflow to:

SHOP_ORDER_WORKFLOWS = [
    ...
    'shop_sendcloud.workflows.SingularOrderWorkflowMixin',
    'shop.shipping.workflows.CommissionGoodsWorkflowMixin',
]

Add the Public Key and the Secret Key as provided by SendCloud (see above):

SHOP_SENDCLOUD = {
  'API_KEY': '<public-key-as-provided-by-SendCloud>',
  'API_SECRET': '<secret-key-as-provided-by-SendCloud>',
}

Since SendClouds sets the Shipping ID for us, we disable that field in the backend, using SHOP_MANUAL_SHIPPING_ID = False.

SendCloud requires a specific address model, therefore ensure that you "materialize" the one provided with djangoshop-sendcloud and not the defaults from shop/models/defaults/address.

Typically, it's enough to import the alternative classes for BillingAddress, ShippingAddress and Customer into models.py of your merchant implementation:

from shop_sendcloud.models.address import BillingAddress, ShippingAddress
from shop_sendcloud.models.customer import Customer

Initialization

Create two additional database tables as required by djangoshop-sendcloud:

python manange.py migrate djangoshop_sendcloud

Finally, load all possible shipping options into your shop:

python manange.py sendcloud_import

remember to run this job on a regular basis, say once a week, to update shipping prices.

Usage

When django-SHOP renders the form Shipping Method inside the checkout view, additional options will be available. For each carrier configured in the SendCloud backend, an extra radio button appears. Whatever the customer selects, will be stored inside django-SHOP's OrderModel.

In the Django Admin backend, only after fulfilling the order, a new button apprears named PRINT SHIPPING LABEL. Clicking on that button fetches a PDF document from the SendCloud API and forwards it to the Django Admin interface, from where it can be printed out.

Changes

1.0.1

  • Adopt Models to work with Django>2.

1.0

  • Initial working release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

djangoshop-sendcloud-1.0.1.tar.gz (11.2 kB view details)

Uploaded Source

File details

Details for the file djangoshop-sendcloud-1.0.1.tar.gz.

File metadata

  • Download URL: djangoshop-sendcloud-1.0.1.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.6.9

File hashes

Hashes for djangoshop-sendcloud-1.0.1.tar.gz
Algorithm Hash digest
SHA256 7b8e40fca84c7ac2c74b4ced1b55d5d0d3f95d7c14afc493280228a8761e9eea
MD5 d6ff8a5af9cc5503a224e0a5b0999c2b
BLAKE2b-256 ec7e8c3ce9d37952edb0baa9bd7b6184607250a140b05097ed2cfd61a62537fa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page