Django

College Event Registration Website

CampusConnect Introduction and Setup Configuring settings file for template, static and media files Setting up Tailwind Creating Custom User Model Creating Super User for CampusConnect Registering Custom User Model Search and Filter for User Model Serving Media Files During Development Categorizing Departments Linking Department with HOD Creating Abstract Model for Event Creating Model for Workshop Customizing Admin Page for Workshop Update in Model AbstractEvent Adding Instructor for Workshop Instructor Model Admin Page Adding Poster Field in Abstract Event Providing Access to HOD Access Update for HOD Restricting HOD Access to Particular Department AbstractEvent On Spot Registration Field Creating Workshop Object Creating and Linking Home Page Displaying Workshop on Home Page Styling Home Page Adding Workshop Detail Page Link Workshop Detail Page Workshop Detail Page Styling Workshop Instructor Details Workshop Detail Contact Contact Admin Page Many to Many Field for Contact Displaying Contact on Workshop Detail Page Adding Title for Workshop Detail Page Adding Gallery for Workshop Workshop Gallery Admin Page Displaying Gallery Images on Website Through Context Displaying Gallery Images on Website through template tags Authentication for users User Registration User Registration Submission Logout Functionality For User Login Functionality for User Model For Workshop Registration Workshop Registration Admin Page Register Workshop Function Register Button in Workshop Page Validations Before Workshop Registration Workshop Registration Closed Validaiton User Already Registered for Workshop Validation Workshop Registration Report From Admin Page Export using Library in Django Admin Extending Abstract Event for Hackathons

Logout Functionality For User

As we had seen, after a user is registered in the website, he was logged in along with it. Similarly, a logout function can be implemented and the user can be logged out from the website on a button click.

Open the authentication/views.py file and write the code for logout.

from django.contrib.auth import login, logout
from django.shortcuts import render, redirect

def user_logout(request):
    logout(request)
    return redirect('home')

This function will logout the current user and redirect him back to the home page. Now again this function needs to be linked with the urls.py file.

urlpatterns = [
    path('register/', views.register, name='register'),
    path("logout/", views.user_logout, name='logout'),
]

After this is done, we can display the logout button in the navbar if a user is logged in, else the register button. For this, we need to edit the base.html file as follows :

<nav class="bg-gray-800 p-4">
        <div class="container mx-auto flex justify-between items-center">
            <h1 class="text-3xl font-semibold">Campus Connect</h1>

            <ul class="flex space-x-4">
                {% if user.is_authenticated %}
                    <li><a href="{% url 'logout' %}">Logout</a></li>
                {% else %}
                    <li><a href="{% url 'register' %}">Register</a></li>
                {% endif %}
            </ul>

        </div>
    </nav>

After this, if a logged in user visits the website, he will see the navbar like this. alt text And once he clicks on the logout button, he will be able to see the register button. alt text