Skip to main content

Django-powered ticket tracker for your helpdesk

Project description

Build Status https://codecov.io/gh/django-helpdesk/django-helpdesk/branch/develop/graph/badge.svg

Copyright 2009-2026 Ross Poulton and django-helpdesk contributors. All Rights Reserved. See LICENSE for details.

django-helpdesk was formerly known as Jutda Helpdesk, named after the company which originally created it. As of January 2011 the name has been changed to reflect what it really is: a Django-powered ticket tracker with contributors reaching far beyond Jutda.

Complete documentation is available in the docs/ directory, or online at http://django-helpdesk.readthedocs.org/.

Demo Quickstart

django-helpdesk includes a basic demo Django project so that you may easily get started with testing or developing django-helpdesk. The demo project resides in the demodesk/ top-level folder.

You will need to install the uv package manager to simplify setting up the demo:

https://docs.astral.sh/uv/getting-started/installation/

If you have not already created a virtual environment then run this command:

uv venv

To start up a demo project server, run this command:

make rundemo

or with docker:

docker build --file standalone/Dockerfile -t demodesk ..
docker run --rm -v "$PWD:/app" -p 8080:8080 demodesk

then pointing your web browser at http://localhost:8080 (log in as user admin with password Pa33w0rd, defined in the demo.json fixture file).

For more information and options, please read the demo/README.rst file.

NOTE REGARDING SQLITE AND SEARCHING: The demo project uses sqlite as its database. Sqlite does not allow case-insensitive searches and so the search function may not work as effectively as it would on other database such as PostgreSQL or MySQL that does support case-insensitive searches. For more information, see this note in the Django documentation.

When you try to do a keyword search using sqlite, a message will be displayed to alert you to this shortcoming. There is no way around it, sorry.

Installation

Developer Environment

Front-end Dependencies

Before you get started, make sure you have the following installed:

Build Dependencies

The project uses the modern uv package manager: https://docs.astral.sh/uv/ There are a number of options that make life a lot easier in the Makefile. To see option for the Makefile run: make

Follow these steps to set up your development environment to contribute to helpdesk:
  • check out the helpdesk app to your local file system:

    git clone https://github.com/django-helpdesk/django-helpdesk.git
  • Install the uv package manager::

    https://docs.astral.sh/uv/getting-started/installation/

  • install a virtual environment

    uv venv
  • install the requirements for development:

    make develop
  • you can install optional dependencies using the –group option. The make develop script installs test dependencies.

    # This installs pinax teams dependencies for production uv sync –all-extras –group teams # This installs pinax teams dependencies as well as test uv sync –all-extras –dev –group test –group teams

If you prefer working within an activated virtual environment instead of using the uv tool then you can use the normal command after the above step for creating the virtualenv to activate it:

   source .venv/bin/activate

- or depending on your shell it might be:
   . .venv/bin/activate

The project enforces a standardized formatting in the CI/CD pipeline. To ensure you have the correct formatting run:

make checkformat

To auto format any code use this:

make format

Testing

From the command line you can run all the tests using: make test

To run specific tests then run quicktest.py with arguments in an activated virtualenv or use this:

uv run quicktest.py <arg>

See quicktest.py for usage details.

If you need to create tests for new features, add your tests in a test file to the tests module:

- from an activated virtualenv use::
   python quicktest.py helpdesk.tests.test_my_new_features -v 2

- whether a virtualenv is activated or not you can use this command::
   uv run quicktest.py helpdesk.tests.test_my_new_features -v 2

Upgrading from previous versions

If you are upgrading from a previous version of django-helpdesk that used migrations, get an up to date version of the code base (eg by using git pull or pip install –upgrade django-helpdesk) then migrate the database:

python manage.py migrate helpdesk --db-dry-run # DB untouched
python manage.py migrate helpdesk

Lastly, restart your web server software (eg Apache) or FastCGI instance, to ensure the latest changes are in use.

You can continue to the ‘Initial Configuration’ area, if needed.

Contributing

We’re happy to include any type of contribution! This can be:

  • back-end python/django code development

  • front-end web development (HTML/Javascript, especially jQuery)

  • language translations

  • writing improved documentation and demos

For more information on contributing, please see the CONTRIBUTING.rst file.

Licensing

django-helpdesk is licensed under terms of the BSD 3-clause license. See the LICENSE file for full licensing terms.

Note that django-helpdesk is distributed with 3rd party products which have their own licenses. See LICENSE.3RDPARTY for license terms for included packages.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

django_helpdesk-2.1.1.tar.gz (8.3 MB view details)

Uploaded Source

Built Distribution

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

django_helpdesk-2.1.1-py3-none-any.whl (9.0 MB view details)

Uploaded Python 3

File details

Details for the file django_helpdesk-2.1.1.tar.gz.

File metadata

  • Download URL: django_helpdesk-2.1.1.tar.gz
  • Upload date:
  • Size: 8.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_helpdesk-2.1.1.tar.gz
Algorithm Hash digest
SHA256 38d9b8191a030a1b3d3a58b6f749ed2ea0207b958acbd5a4bf2d7d6f5ea7c0c4
MD5 6b57893e969507e717f5051deb5292f8
BLAKE2b-256 fda01dcbc123a3867d32b45f9874d62d285000427659c99cd92ceb32d3d85dc4

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_helpdesk-2.1.1.tar.gz:

Publisher: release_to_pypi.yml on django-helpdesk/django-helpdesk

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_helpdesk-2.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_helpdesk-2.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ab4863357b12c5c330e3c18076ff35e9780bf349475a43c72044f86c7b545d13
MD5 c84cf207daad1efc2e71b401c5684204
BLAKE2b-256 b56c7f9ce5ab5a5ccfb188109d74248a50d5bfdc54d6518d6aa7d3dc0b85ab67

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_helpdesk-2.1.1-py3-none-any.whl:

Publisher: release_to_pypi.yml on django-helpdesk/django-helpdesk

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