
Product
Introducing Webhook Events for Alert Changes
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.
django-cookie-consent-compliance
Advanced tools
A deterministic package allowing user consent implication for setting cookie on django projects
This package facilitates compliance with the new privacy policy by requiring the disclosure of all cookies stored on the user's device, thereby empowering users to opt-in or opt-out of specific types of cookies. Additionally, it enables site owners to respond appropriately to the preferences expressed by their clients.
The implementation process is straightforward, as detailed in the documentation provided below.
Initially, it is essential to establish the COOKIECONSENT option within the [root_app]/settings.py file of the project.
COOKIECONSENT = {
"title": ,
"sub_title":,
"description":,
"final_note": ,
"options": [
{
"type": ,
"description": ,
"category":,
"if_declined":,
},
],
}
This component enables the customization of the appearance of notifications requesting cookie consent and facilitates the inclusion of relevant categories as required by the project.
The fields title, sub_title, description, and final_note provide the means to compose a detailed message for the form presented to the client. In contrast, the options field contains a comprehensive list of all types of cookies that can be managed with this package throughout the Django project.
For illustration purposes, a sample is provided below.
COOKIECONSENT = {
"title": "đȘ Cookie Time! đȘ",
"sub_title": "We use cookies to make your experience at App even better! đ",
"description": "By clicking âGot It!â or continuing to browse our app, youâre accepting our use of cookies (no, not the chocolate chip ones, unfortunately đ
). Here's how we use them:",
"final_note": "đĄ Remember: You can change your cookie preferences anytime via your browser settings if you're not fully on board. But don't worry, the cookies we use are harmless â no magical powers or teleportation here, promise! đ",
"options": [
{
"type": "Performance Cookies",
"description": "We use these to check how well the app is doing. They help us improve the experience, so you can enjoy our digital theatre even more.",
"category": ,
"if_declined": "continue",
},
{
"type": "Marketing Cookies",
"description": "Think of these as the set designers. They remember your preferences, like your language or favorite settings, so you donât have to keep telling us every time you return.",
"category": ,
"if_declined": "request",
"redirect_path": "login",
"redirection_message": "Make sure to select appropriate cookie to continue further.",
},
{
"type": "Analytics Cookies",
"description": "These help us see how youâre enjoying the show. We gather data to make the app better, so youâll keep coming back for the encore. đ€",
"category": ,
"if_declined": "abort",
"redirect_path": "login",
"redirection_message": "Your request can't be processed further because some cookies are not present.",
},
],
}
The type and description fields provide a general overview to inform the client of their intended function.
In contrast, the category field contains values that will be stored in the browser's cookie as userconsent=<category1>,<category2>, with the str(category) values concatenated by a comma (,). It is crucial to ensure that any object passed returns a valid str containing letters and numbers only (no meta characters).
if_declined field can take on three potential values: abort, continue, and request. This functionality enables the developer to respond based on the user's decision regarding the acceptance of specific types of cookies. redirect_path can be used to perform any required operation that are suitable for particular if_declined directive.
abort: If the client opts out of this type of cookie, a redirection_message will be displayed, and the request will be redirected to redirect_path.
continue: This directive allows the request to proceed as if everything is in order.
request: With this option, the request will be redirected to redirect_path, and a redirection_message will be shown.
pip install django-cookie-consent-compliance.COOKIECONSENT into <root-app>/settings.py as previously indicated.- Add `cookieconsent.cookieconsent_context` in `TEMPLATES["OPTIONS"]["context_processors"]`.
base.html. id and class of element can be added/updated as per necessity. {% if not request.COOKIES.userconsent %}
<div id="cookieconsent-container">
<form action="#" method="POST" id="cookieconsent">
{% csrf_token %}
<h3>{{ title }}</h3>
<p>{{ sub_title }}</p>
<br />
<p>{{ description }}</p>
<table>
{% for opt in options %}
<tr>
<td><label for=""><b>{{opt.type}}:</b>
{{opt.description}}</label>
</td>
<td><input type="checkbox" value={{opt.category}}></td>
</tr>
{% endfor %}
</table>
<p>{{ final_note }}</p>
<button type="submit">Submit</button>
</form>
</div>
<script>
let form = document.getElementById("cookieconsent");
form.addEventListener("submit", (e) => {
e.preventDefault();
let choices = [];
Object.values(form).forEach(i => {
if (i.localName == "input" && !["hidden", undefined].includes(i.type) && i.checked) {
choices.push(i.value);
}
});
document.cookie = `userconsent=${choices ? choices : ""}; Max-Age=2592000; path=/; SameSite=strict; Secure;`;
document.getElementById("cookieconsent-container").style.display = "none";
})
</script>
{% endif %}
views.py where it is necessary to set a cookie, utilize as following:from cookieconsent import cookie_if_consent_or_action
def view_function(request):
response = cookie_if_consent_or_action(request:HttpRequest, response: HttpResponse, category1, "lang", value="en")
response = cookie_if_consent_or_action(request:HttpRequest, response: HttpResponse, category2, "theme", value="auto")
return response
If all types of cookies are utilized in a view, last redirect_path with cumulative redirection_message.
cookie_if_consent_or_action function utilizes Django's HttpResponse.set_cookie method, allowing for the inclusion of all valid kwargs.
FAQs
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.

Security News
ENISA has become a CVE Program Root, giving the EU a central authority for coordinating vulnerability reporting, disclosure, and cross-border response.

Product
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.