Skip to main content

Django views and forms that submit tickets to Zendesk

Project description

An extensible library to add Django views with forms to submit tickets to Zendesk.

Usage

Add these to your settings.py:

ZENDESK_BASE_URL = 'https://example.zendesk.com'
ZENDESK_API_USERNAME = ...
ZENDESK_API_TOKEN = ...
ZENDESK_REQUESTER_ID = ...
ZENDESK_GROUP_ID = ...

Add an entry to your urls.py

from zendesk_tickets.views import TicketView

path(r'submit-ticket/$', TicketView.as_view(
    success_url='/',
    template_name='app_name/submit-ticket-page.html',
    ticket_subject='Website Feedback',
    ticket_tags=['website', 'feedback']
    ticket_template_name='app_name/feedback-ticket.txt',
), name='submit_ticket'),

If you wish to include additional fields, subclass BaseTicketForm and add them. If you wish to include them in the body of the ticket, create a new ticket template and pass it as the ticket_template_name. If you wish to include them as custom fields, define the following in your settings.py:

ZENDESK_CUSTOM_FIELDS = {
    'referer': 31,  # zendesk field id
    'username': 32,
    'user_agent': 33,
}

The three fields in the example above are included in TicketForm by default and can be included in your ticket by referencing them in the ticket template or specifying custom field ids in settings.

Development

https://github.com/ministryofjustice/django-zendesk-tickets/actions/workflows/test.yml/badge.svg?branch=main

Please report bugs and open pull requests on GitHub.

To work on changes to this library, it’s recommended to install it in editable mode into a virtual environment, i.e. pip install --editable .

Use python -m tests to run all tests locally. Alternatively, you can use tox if you have multiple python versions.

Update translation files using python scripts/messages.py update, when any localisable strings change. Compile them using python scripts/messages.py compile; this is required before testing and distribution. Updating and compiling translation files requires the gettext system package to be installed.

[Only for GitHub team members] Distribute a new version to PyPI by:

  • updating the VERSION tuple in zendesk_tickets/__init__.py

  • adding a note to the History

  • publishing a release on GitHub which triggers an upload to PyPI; alternatively, run python scripts/messages.py compile; python -m build; twine upload dist/* locally

History

0.20

Testing on python 3.10 to 3.14. Improve linting and modernise code style. Migrated to trusted publishing.

0.19

Add experimental support for Django 5.2 & Python 3.13.

0.18

Add experimental support for Django versions 5.0 & 5.1.

0.17

Migrated test, build and release processes away from deprecated setuptools commands. Translation files are updated and compiled through scripts which are not included in distribution. No significant library changes.

0.16

Drop support for python 3.6 and 3.7. Add support for python 3.11. Add experimental support for Django versions 4.0 & 4.1. Improve testing and linting.

0.15

Add support for python 3.9 and 3.10. Improve testing and linting.

0.14

Drop support for python 3.5. Improve linting.

0.13

Drop python 2 support (now compatible with 3.5 - 3.8). Support Django 2.2 - 3.2 (both LTS).

0.12

Improve testing and linting.

0.11

Support Django 1.10 - 2.0. Add class-based Django views. Add internationalisation support.

0.10

Fix display of tickets in Zendesk.

0.9

Don’t allow self-referential return-to URL.

0.8

Accept extra template context in views.

0.7

Use email address of logged-in user when available.

0.6

Collect email address of form submitter, optionally.

0.5

Fix bugs.

0.4

Provide a safe “return back to where you came from” link.

0.3

Add success view.

0.2

Fix bugs.

0.1

Original 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

django_zendesk_tickets-0.20.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_zendesk_tickets-0.20-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file django_zendesk_tickets-0.20.tar.gz.

File metadata

  • Download URL: django_zendesk_tickets-0.20.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_zendesk_tickets-0.20.tar.gz
Algorithm Hash digest
SHA256 d86f12fff4690b1be6e1018eb41d7ced40d2923e986823afda42f2e506c8ed46
MD5 4283a2bedfa10315a83141ba67c89093
BLAKE2b-256 f24a95e802e52e2c081b5c35b1d21bff0329479461f03c2c06b50ee5a1c93ebc

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_zendesk_tickets-0.20.tar.gz:

Publisher: release.yml on ministryofjustice/django-zendesk-tickets

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_zendesk_tickets-0.20-py3-none-any.whl.

File metadata

File hashes

Hashes for django_zendesk_tickets-0.20-py3-none-any.whl
Algorithm Hash digest
SHA256 c223fd2d38706a87774be8e48a5c9c7d58f60526ad177f362c733e6733670c21
MD5 ad4c69639e53f9c3d550a61287bd3c9b
BLAKE2b-256 ecc5e40936bfc826b6562a87b3058b1ea2f870a79393399bd3a937efe21f3ac3

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_zendesk_tickets-0.20-py3-none-any.whl:

Publisher: release.yml on ministryofjustice/django-zendesk-tickets

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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