Skip to main content

Braintree Payments processing for Mezzanine/Cartridge

Project description

Braintree Payments processing for Mezzanine/Cartridge. Supports Django 3.2 or 4.0, Mezzanine 5.1 or newer and Cartridge 1.3 or newer.

Instructions for use

  1. Install cartridge_braintree:

    pip install cartridge_braintree

    If you need the correct sorting of not ASCII country names use:

    pip install cartridge_braintree[countries_utf8_sorting]

    This will add ‘pyuca’ to the requirements.

  2. Add ‘cartridge_braintree’ to your INSTALLED_APPS. List it higher than ‘cartridge.shop’, otherwise the cartridge_braintree template will not be selected.

  3. Set up the following settings in your settings.py or local_settings.py:

    BRAINTREE_MERCHANT_ID = <your merchant ID>
    BRAINTREE_PUBLIC_KEY = <your public key>
    BRAINTREE_PRIVATE_KEY = <your private key>

    See also https://developer.paypal.com/braintree/articles/control-panel/important-gateway-credentials

  4. cartridge_braintree uses a modified checkout form, which does the following:

    • Changes the shipping and billing country fields to a Select widget. This ensures that the country selected can be converted to a valid code for Braintree’s payment processing. The supported countries can be set in settings.SHOP_SUPPORTED_COUNTRIES, which is a list of alpha2 country codes and/or tuples in the form (alpha2, country_name).

      For example if you want to select the countries in the EU area use:

      SHOP_SUPPORTED_COUNTRIES = [
          'AL', 'AT', 'BA', 'BE', 'BG', 'CH', 'CY', 'DE', 'DK', 'EE', 'ES',
          'FI', 'FR', 'GB', 'GR', 'HR', 'HU', 'IE', 'IS', 'IT', 'LT', 'LV',
          'MK', 'MT', 'NL', 'NO', 'PL', 'PT', 'RO', 'RS', 'SE', 'SI'
       ]

      A pre-selected country in the select field can be specified using settings.SHOP_DEFAULT_COUNTRY as an alpha2 code. By default the user is expected to choose their country (set to None).

      The country/countries (as alpha2 codes) listed in settings.SHOP_PRIMARY_COUNTRIES will show up at the top of the country selection fields, after the settings.SHOP_DEFAULT_COUNTRY if set.

    • Credit Card number and CCV fields are rendered using the NoNameTextInput widget so that the data is not submitted to the server. Javascript processes these fields to create a payment_method_nonce, which is then stored in a hidden form element.

    • Uses jquery.payment from stripe for client-side validation of the payment form and submits the errors in the hidden braintree_errors field to the server to handle them as Django errors.

    See https://developer.paypal.com/braintree/docs/guides/transactions/python

  5. Set the payment handler to be the Braintree payment handler:

    SHOP_HANDLER_PAYMENT = 'cartridge_braintree.braintree_payment.payment_handler'

    If you are overriding the templates in your own apps, then be sure to include the relevant braintreejs.html template.

  6. Include cartridge_braintree.urls for shop/checkout in urls.py before Cartridge urls:

    urlpatterns += [
    
        # cartridge_braintree URLs.
        re_path(r"^shop/(?=checkout(/?)$)", include("cartridge_braintree.urls")),
    
        # Cartridge URLs.
        path("shop/", include("cartridge.shop.urls")),
        path("account/orders/", order_history, name="shop_order_history"),
  7. If you want to use PayPal payments with Braintree activate them in the Admin Site Settings and set the currency to use with PayPal.

    Alternatively you can set them in settings.py in the form:

    BRAINTREE_PAYPAL_ACTIVATE = True
    BRAINTREE_PAYPAL_CURRENCY = "EUR"

    In this case the settings will not be shown in the Admin.

  8. Optionally add logging to your Django configuration if you want to have more details on transactions:

    LOGGING = {
        'version': 1,
        'disable_existing_loggers': False,
        'handlers': {
            'braintree_file': {
                'class': 'logging.FileHandler',
                'filename': '/path/to/django/braintree.log',
            },
        },
        'loggers': {
            'braintree_payment': {
                'handlers': ['braintree_file'],
                'level': 'DEBUG',
            },
        },
    }

    See https://docs.djangoproject.com/en/4.0/topics/logging/#configuring-logging for all configuration options

    Log levels are as follows:
    • Client token creation: info

    • Transaction start: debug

    • Transaction complete: debug

    • Transaction fail: warning

    Confidential information is never output to the logger.

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

cartridge_braintree-3.0.6.tar.gz (179.6 kB view details)

Uploaded Source

Built Distribution

cartridge_braintree-3.0.6-py3-none-any.whl (264.0 kB view details)

Uploaded Python 3

File details

Details for the file cartridge_braintree-3.0.6.tar.gz.

File metadata

  • Download URL: cartridge_braintree-3.0.6.tar.gz
  • Upload date:
  • Size: 179.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for cartridge_braintree-3.0.6.tar.gz
Algorithm Hash digest
SHA256 72fd8186e8e1139911aacbf2b0f8eb521e8257aa90a51bf2f90fe7a0e7946045
MD5 5c841ece4041122063042c32e2d03cd4
BLAKE2b-256 51623f8bf5a2d9d1cdc6191173bd81534281fad0cdf3f7ded404f768c9c78e2c

See more details on using hashes here.

File details

Details for the file cartridge_braintree-3.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for cartridge_braintree-3.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 b18cad0cdca36b6e8e6f55ce86c8ba4a2180f7313d2e5fb8c6cc46fe882b75b5
MD5 2473744df83bc4d30db8ad4e9efef966
BLAKE2b-256 85954627346c06a5238c45c98fc4df47ece75040f9d36317a7a7f574cf041806

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