AI SaaS Chat Bot using MERN Stack – Tutorial
Updated: October 24, 2025
Summary
This video introduces a comprehensive M-Stack course focused on building a sophisticated AI chatbot akin to ChatGPT. The instructor covers various advanced topics such as authentication mechanisms, OpenAI integration, and scalability using technologies like Node.js, MongoDB, React, and JWT. Viewers are guided through the step-by-step process of creating a secure, production-ready chatbot application with features like user interaction, authentication, token handling, and error management, ensuring a robust and adaptable solution.
TABLE OF CONTENTS
Introduction to the Course
Demo of the Application
Tech Stack Overview
Scalability and Future Integrations
Building the Backend
Creating API Routes
Integrating MongoDB
Creating MongoDB Cloud Database
Connecting to MongoDB Database
Connecting with Mongoose
Error Handling and Disconnecting from Database
API Keys Generation and Integration
Secure Authentication Setup
Defining Database Models
Creating Controllers and Routes
Setting Up API Endpoints
Creating User Sign Up Request
Sending Data with the User Sign Up Request
Encrypting User Passwords
Creating User Validation Checks
Introduction to Middleware
Implementing Data Validation Middleware
Handling User Login Requests
Generating User Token
User Authentication
User Authorization
Authorization Process
Token Encryption
HTTP-only Cookies
Token Verification
Token Creation
Cookie Management
User Operation Handling
Handling Invalid Tokens
Front-End Development
Setting Up Application Routing
Handling Not Found Pages
Creating Main Components
Designing the Header with App Bar and Toolbar
Implementing Context API for State Management
Implementing Styles for Nav Links
Styling Login and Signup Forms
Rendering Image and Form in Login Page
Customizing Form Input Fields
Handling Form Submission and API Requests
Token Verification and User Validation
Saving User's Chat Array
Error Handling with Try Catch Block
Completing Chat Operations
Designing Chat UI
Handling User Input
Submitting Data
Managing Chat Messages
API Integration
Syntax Highlighting
Code Block Detection
Application Refinement
Fetching User Chats
Data Retrieval and Error Handling
Deleting Chats Functionality
Logout Functionality
Signup Functionality
Homepage Design
Defining Box Shadow Positions
Setting Margin for the Image
Implementing Styles for Mobile Devices
Creating the Footer Component
Final Adjustments and Completing the Application
Introduction to the Course
Introduction to the M-Stack course where the instructor guides you in building a state-of-the-art AI chatbot similar to chat GPT. The course covers advanced authentication mechanisms, integration of OpenAI, and creating a production-ready, scalable application.
Demo of the Application
Demonstration of the AI chatbot application built with Mon Stack featuring user interaction, chat storage, code block responses, clear conversation functionality, and security measures like session verification and token storage.
Tech Stack Overview
Details on the tech stack used in the project including Node.js, Express, MongoDB, React, JWT, HTTP-only cookies, validations, middleware checks, Material UI Library, and OpenAI integration for building a modern, secure chatbot application.
Scalability and Future Integrations
Explanation of the scalability of the application with potential integrations for image completion, audio generation, and video capabilities using React and Node.js, ensuring future adaptability and scalability.
Building the Backend
Step-by-step guide on setting up a Node.js and Express application with TypeScript, installing dependencies, configuring the application, creating routes, handling HTTP requests, and testing with Postman for API requests.
Creating API Routes
Discussing different types of HTTP requests (GET, POST, PUT, DELETE) and demonstrating how to implement them in an Express application along with handling dynamic routes, request parameters, and response data.
Integrating MongoDB
Guidance on setting up a MongoDB database, creating a new project in MongoDB Atlas, choosing deployment options, like the M0 free tier, and explaining the storage, RAM, and virtual CPU configurations available.
Creating MongoDB Cloud Database
Steps to create and set up a MongoDB Cloud database including verifying, setting up security, creating users, and setting network access.
Connecting to MongoDB Database
Details on connecting to the MongoDB database including generating a connection URL, setting up username and password, and providing database name.
Connecting with Mongoose
Using Mongoose to connect to MongoDB database including setting up the Mongoose model, creating a new record, and managing connections securely.
Error Handling and Disconnecting from Database
Implementing error handling, disconnecting from the database for security, and managing application structure for better readability and performance.
API Keys Generation and Integration
Guide on generating and using API keys from the OpenAI platform, verifying and securing keys, and getting ready for API integration into the application.
Secure Authentication Setup
Setting up secure authentication with web tokens, HTTP-only cookies, creating API endpoints, and defining middleware for handling requests.
Defining Database Models
Defining database models including user model with fields like name, email, password, and chats array for storing messages.
Creating Controllers and Routes
Creating controllers and routes for handling user requests including defining routes, connecting to the database, and fetching user data.
Setting Up API Endpoints
Setting up API endpoints for user requests like GET, POST, and sign up. Checking status codes and response times.
Creating User Sign Up Request
Creating a POST request for user sign up, defining routes and controller functions to handle the sign-up process.
Sending Data with the User Sign Up Request
Sending body data using Postman for user sign up request, including user details like email, name, and password.
Encrypting User Passwords
Encrypting user passwords using bcrypt before storing them in the database for security reasons.
Creating User Validation Checks
Implementing validation checks for user sign up, ensuring email, password length, and other data are correctly formatted.
Introduction to Middleware
Explaining the concept of middleware in web development, its role in modifying requests and responses, and how it bridges the client and server interactions.
Implementing Data Validation Middleware
Using Express-validator for data validation middleware, setting up validation chains, custom validators, and error handling for incorrect data.
Handling User Login Requests
Handling user login requests, verifying user email existence, checking password correctness, and sending appropriate responses based on authentication status.
Generating User Token
Explanation on generating a token for user authentication to verify identity by providing credentials like email and password.
User Authentication
Definition of user authentication as a step where users verify their identity by providing credentials used during application access, leading to successful authentication.
User Authorization
Description of user authorization post-authentication where a token is provided to access resources and demonstrate entitlement, illustrating the complete authentication and authorization package.
Authorization Process
Explanation of the process where users need to provide tokens sent during authentication to access resources, ensuring entitlement to protected resources.
Token Encryption
Introduction to JSON Web Token (JWT) as a tool to encrypt data into a signed token to manage user permissions and authorities safely.
HTTP-only Cookies
Explanation of using HTTP-only cookies to send tokens securely to users, preventing unauthorized access and XSS attacks by restricting JavaScript access to cookies.
Token Verification
Explanation of validating tokens in the backend after receiving them using HTTP requests to prevent attacks and ensure fully authenticated and authorized applications.
Token Creation
Overview of creating tokens with encrypted data and using JWT secret keys for encryption, emphasizing the importance of secure token handling.
Cookie Management
Explanations on managing and sending tokens as HTTP-only cookies securely from the backend to the frontend to maintain user authentication and authorization.
User Operation Handling
Instructions on handling user operations based on token validation results, including user requests and potential token expiration scenarios for proper authentication design.
Handling Invalid Tokens
Explanation on handling invalid tokens or expired token scenarios, including clearing cookies and providing new tokens for continued user authentication.
Front-End Development
Initiating the front-end development process by setting up React applications using Vite to create login systems and integrating styling libraries like Material UI and react-icons for UI enhancements.
Setting Up Application Routing
Setting up the application routing involves creating different pages such as home, chat, login, and sign up using TSX files and RFC components for each page.
Handling Not Found Pages
Implementing a not found page to handle routes that are not registered within the application, displaying a message to users that the route is not found.
Creating Main Components
Setting up the main components of the application, including the header, routes container, and registering different routes such as home, login, sign up, and chat.
Designing the Header with App Bar and Toolbar
Designing the header using Material-UI components like AppBar and Toolbar to create a navigation bar with predefined styles. Customizing the AppBar using SX prop.
Implementing Context API for State Management
Implementing the Context API for state management, defining the user object properties like email, ID, name, and login status. Creating login, logout, and signup functions within the context provider.
Implementing Styles for Nav Links
In this section, the CSS styles for the nav links are implemented with details on font weight, text transform, margin, padding, border radius, text decoration, and more for a polished appearance and functionality.
Styling Login and Signup Forms
The design and styling of the login and signup forms are discussed, including considerations for desktop and mobile devices, using Material-UI components like Box and custom CSS for responsive design.
Rendering Image and Form in Login Page
The layout of the login page is described with an image of a robot on the left side and a form on the right side, adapting the design for mobile devices to display only the form for responsiveness.
Customizing Form Input Fields
The customization of input fields, including styling for outline, width, padding, font size, color, and more is explained, along with handling hover effects and integrating icons for visual enhancement.
Handling Form Submission and API Requests
The process of handling form submission, capturing form data, making API requests to the backend using Axios, setting default configurations, and interacting with the backend server are covered with error handling and success feedback using toast notifications.
Token Verification and User Validation
Verifying the token and validating the user by finding the user ID, checking ID match, and handling errors if the user is not registered or the token is malfunctioning.
Saving User's Chat Array
In this section, the users' chat array is saved. The process involves saving the user's chat and moving to the next step of returning the response with a status of 200 denoting successful operation.
Error Handling with Try Catch Block
The importance of using a try-catch block for error handling is highlighted. The code should be enclosed within a try block, with provisions for catching errors, sending appropriate error responses, and logging errors for debugging purposes.
Completing Chat Operations
The chat completion operations are discussed, marking the completion of work on the backend. The focus shifts to frontend design and testing the API directly with the frontend.
Designing Chat UI
The process of designing the chat UI is explained. Steps include using Material-UI components like Box and Avatar, applying styling properties like width, height, background color, and flex for layout design.
Handling User Input
In this section, the speaker discusses handling user input in the application. They retrieve data from user input, store previous chats, insert new chats, and demonstrate the process of obtaining and storing user input data.
Submitting Data
The speaker covers submitting data by referring to the input element, handling submit functions, and verifying data reception. They demonstrate the process of receiving data and the functionality of the handle submit function in the application.
Managing Chat Messages
The speaker explains the process of managing chat messages in the application. They discuss storing chat messages, handling state updates, and creating new messages for users. Additionally, they address the type errors and clean coding practices implemented.
API Integration
The speaker dives into integrating API requests with the backend to send and receive messages. They demonstrate sending new messages, handling responses, and updating the chat messages array with new data from the backend.
Syntax Highlighting
The speaker discusses implementing syntax highlighting for code blocks in the chat application. They describe using a React library for syntax highlighting, installing the library, defining language types, and rendering code blocks with proper formatting.
Code Block Detection
The speaker explains how to detect and extract code blocks from chat messages. They demonstrate conditions for identifying code blocks within a string and splitting messages to extract code blocks. Additionally, they discuss rendering code blocks based on detection results.
Application Refinement
In this section, the speaker focuses on refining the application's user interface. They address providing margin and padding to elements, fixing alignment issues, and incorporating conditional rendering for code blocks and typography in chat messages.
Fetching User Chats
The speaker covers retrieving user chat data from the backend. They discuss creating routes and functions to fetch chat data, integrating the frontend with backend APIs to display user chats in the application, and using layout effects for initial data loading.
Data Retrieval and Error Handling
In this section, the speaker discusses retrieving data and error handling in the application. They cover getting user chats and data, displaying messages, handling success and error messages, and managing toast notifications.
Deleting Chats Functionality
The speaker explains the process of deleting chats in the application. They discuss setting chat messages, handling success and error messages for chat deletion, and ensuring the functionality works as expected.
Logout Functionality
The speaker demonstrates implementing a logout feature in the application. They explain the backend setup for logging out users, clearing cookies, and updating the frontend to reflect the logged-out state.
Signup Functionality
The speaker covers the signup feature development, including creating signup API requests, frontend form implementation, and error handling for the signup process.
Homepage Design
The speaker discusses designing the homepage of the application, including adding a typing animation component, displaying images, and styling elements for a visually appealing layout.
Defining Box Shadow Positions
Explanation of defining positions for the box shadow including horizontal and vertical positions as well as blur radius.
Setting Margin for the Image
Adding margin from the bottom of the image and adjusting its appearance.
Implementing Styles for Mobile Devices
Customizing styles for mobile devices using media queries and the Material UI library.
Creating the Footer Component
Creating and styling the footer component with links and styles.
Final Adjustments and Completing the Application
Making final adjustments, fixing layout issues, and completing the application with OpenAI, authentication systems, material UI integration, and congratulatory message.
FAQ
Q: What are some of the technologies used in the M-Stack course project?
A: The M-Stack course project utilizes technologies such as Node.js, Express, MongoDB, React, JWT, HTTP-only cookies, Material UI Library, and OpenAI integration.
Q: What is the purpose of using HTTP-only cookies in the application?
A: HTTP-only cookies are used to securely send tokens to users, preventing unauthorized access and XSS attacks by restricting JavaScript access to cookies.
Q: How is user authentication handled in the project?
A: User authentication is handled by generating tokens with encrypted data, using JWT secret keys for encryption, and sending tokens as HTTP-only cookies from the backend to the frontend.
Q: What is the role of middleware in web development?
A: Middleware in web development modifies requests and responses, bridging client-server interactions, and ensuring proper data validation and error handling.
Q: Explain the concept of handling invalid or expired tokens in the application.
A: Handling invalid or expired tokens involves clearing cookies, providing new tokens for continued user authentication, and ensuring that user operations are managed based on token validation results.
Q: What is the purpose of using Express-validator in the project?
A: Express-validator is used for data validation middleware, setting up validation chains, custom validators, and error handling for incorrect data in the application.
Q: How is user authorization defined in the context of authentication?
A: User authorization post-authentication involves providing a token to access resources, demonstrating entitlement, and completing the authentication and authorization process.
Q: What technologies are used for frontend development in the project?
A: Frontend development involves setting up React applications using Vite, integrating styling libraries like Material UI, and creating different page components using TSX files and RFC components.
Q: Explain the process of handling user input in the application.
A: Handling user input involves retrieving data, storing previous chats, inserting new chats, capturing form data, making API requests to the backend, and ensuring proper validation and error feedback.
Q: How are chat messages managed and stored in the application?
A: Chat messages are stored, updated, and displayed in the application, with considerations for error handling, state updates, and clean coding practices for efficient performance.
Q: What is the purpose of implementing syntax highlighting for code blocks in the chat application?
A: Syntax highlighting for code blocks enhances the readability and visual appeal of code snippets, improving the overall user experience in the chat application.
Q: How is data retrieved from the backend and displayed in the frontend?
A: Data is retrieved from the backend by creating routes and functions to fetch chat data, integrating APIs with frontend components, and using layout effects for initial data loading.
Q: What are the key steps in the signup feature development?
A: The signup feature development involves creating signup API requests, implementing frontend forms, and including error handling to ensure a smooth user registration process.
Get your own AI Agent Today
Thousands of businesses worldwide are using Chaindesk Generative
AI platform.
Don't get left behind - start building your
own custom AI chatbot now!