A Django app to to create a responsive bootstrap-styled email-driven feedback form with a captcha and an email confirmation feature.
Project description
Description
This app offers a way to create a responsive bootstrap-styled email-driven feedback form with a captcha and an email confirmation feature to your Django web-app hassle-free! The form itself is rendered on the page with the template tag while the form usage sessions are stored in the database. The initial validation and the UI manipulations are powered by JavaScript code which communicates with the server side via AJAX.
See the detailed documentation here.
Demo
Quick Start
Install the package using pip:
pip install django-bootstrap-feedback-form
Add ‘feedback_form’ to the INSTALLED_APPS setting of your Django project like this:
INSTALLED_APPS = [ ..., 'feedback_form', ]
Include the URLconf of the app in your project urls.py something like this:
path('feedback_form_urls/', include('feedback_form.urls')),
Obtain and add to your project settings.py the reCaptcha v2 keys: the public one and the private one. Here and below shown a way to add such variables using python-dotenv (while you can technically define them just as is in your code, it is highly discouraged):
RECAPTCHA_PUBLIC_KEY = getenv('RECAPTCHA_PUBLIC_KEY') RECAPTCHA_SECRET_KEY = getenv('RECAPTCHA_SECRET_KEY')
Define the Django email backend in your project settings.py (as shown in the Django docs). Don’t forget to define EMAIL_TIMEOUT:
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' EMAIL_USE_SSL = True EMAIL_TIMEOUT = 20 EMAIL_HOST = getenv('EMAIL_HOST') EMAIL_PORT = getenv('EMAIL_PORT') EMAIL_HOST_USER = getenv('EMAIL_HOST_USER') EMAIL_HOST_PASSWORD = getenv('EMAIL_HOST_PASSWORD') DEFAULT_FROM_EMAIL = getenv('FROM_EMAIL') SERVER_EMAIL = getenv('SERVER_EMAIL')
Define the FEEDBACK_EMAIL_INBOX variable with your desired email inbox to get messages:
FEEDBACK_EMAIL_INBOX = getenv('FEEDBACK_EMAIL_INBOX')
Define in one of your project apps a view with the named url (the url name parameter) being ‘form_redirect_address’ that will be visited by a user after the successful submission of the form. It is not necessary but strongly advised in order to avoid some troubles with the url resolving:
path('some_url_idk/', some_view_idk, name='form_redirect_address'),
Run python manage.py migrate feedback_form to create the app main model in the DB.
Load and call the render_feedback_form template tag from the feedback_form tags module in a desired place of your Django template:
{% load feedback_form %} {% render_feedback_form %}
Keep in mind that Bootstrap 5 js and css files must be included on the same page.
Launch the server and check that everything works fine.
Potential Problems and Liabilities
There are few problems and legal liabilities associated with using this application.
It uses cookies. If you must make some notification to the user according to the laws in your jurisdiction, you should probably do it. Although these cookies pretty much should be considered strictly necessary and technical ones: they are used to identify a user and to prevent malfunction (and not in any form to spy or to collect some sensitive data), in some countries they still need to be stated.
It sends a user data (especially an email address) over the SMTP protocol (or any other mean that you configure). This also may need some notice or something like that. Anyway, use only trusted SMTP providers.
If you use the mail_admins built-in Django logging handler (or something with a similar functionality), you may accidentally send a sensitive data (like an email or ip address) through the email. The @sensitive_variables decorator is used for every form-related view here to sanitize the data, but there’s no warranty. This is applicable to all Django apps unfortunately.
Therefore, if applicable, you may need to establish some Privacy Policy / Terms of Service or something like that on your site or app.
Also some SMTP services tend to not return an errors even if sending the letter goes wrong. That means that it’s impossible to catch the issues of that kind on the backend (or at least it is not optimal to do so). But it mainly affects some none-existing email address or host, so it should not affect the full cycle of the form submission (because of the email address confirmation feature), so it’s probably fine. Probably.
For the detailed usage and customization suggestions consult the docs.
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
Built Distribution
File details
Details for the file django-bootstrap-feedback-form-1.0.1.tar.gz
.
File metadata
- Download URL: django-bootstrap-feedback-form-1.0.1.tar.gz
- Upload date:
- Size: 24.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0a27bfd04037ae59e53c5342e6c8ed38ae22849794de2b1417065e76c98b46be |
|
MD5 | 843d1bbecb0c1dd9cf7709d03537e168 |
|
BLAKE2b-256 | 037ff136ae4c481e4a4dd45e65fed417971664062baea940c6cbc4d60dbafbc0 |
File details
Details for the file django_bootstrap_feedback_form-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: django_bootstrap_feedback_form-1.0.1-py3-none-any.whl
- Upload date:
- Size: 28.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9a11e57d83cfd2281b49abdec9c8a81e0cf85d97cccddb8e5c112cfe1aad8f74 |
|
MD5 | 89075988a29e97d3b7672e88d275ea13 |
|
BLAKE2b-256 | f8c165ba09f07a6c97b7a6250cb3e5ed571e988255cc754dfcb73f866d87a88f |