This project, TubeFlow, is a full-stack implementation of a YouTube-like platform, initially built by Hitest Choudhury. I am rebuilding and expanding it using TypeScript and Prisma (with a PostgreSQL database on Docker) to strengthen my skills in full-stack development, with enhancements on both the backend and frontend.
We welcome contributions to TubeFlow! Please read our Contributing Guidelines and Code of Conduct for more details on how to get started.
- User Authentication: Secure login/signup with JWT-based token management.
- Video Management: Users can upload, stream, like, comment, and share videos.
- Playlists: Enable users to create and manage personalized playlists.
- Real-time Notifications: Get instant updates on likes, comments, and subscriptions, powered by Socket.io.
- Video Recommendations: Provides personalized suggestions based on user interaction and preferences.
- Frontend: React.js with TypeScript for a scalable, efficient user interface.
- Backend: Node.js with Express.js for server-side logic.
- TypeScript: Ensures type safety and better code management across the stack.
- Prisma ORM: For type-safe interactions with a PostgreSQL database.
- Docker: Containerizes the PostgreSQL database and provides easy portability.
- JWT & bcrypt: For secure authentication and password management.
git clone https://github.com/MohakGupta2004/tubeflow.git
cd tubeflow
cd Frontend
npm install
cd..
cd Backend
npm install
Ensure Docker is installed, and set up PostgreSQL by running (make sure if you are running this locally then run backend locally otherwise it doens't work):
docker run -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 postgres
Create a .env
file and set up the following environment variables:
DATABASE_URL="postgresql://user:password@localhost:5432/tubeflow" (Best practice: Change this to any cloud database e.g. NeonDB)
PORT=5000
CORS_ORIGIN="http://localhost:5173"
JWT_SECRET=
JWT_EXPIRY=
REFRESH_TOKEN_SECRET=
REFRESH_EXPIRY=
CLOUDINARY_API_SECRET=
CLOUDINARY_API_KEY=
CLOUDINARY_CLOUD_NAME=
npm run dev
-
Apply Prisma Migrations: After PostgreSQL is up and running, apply the migrations:
npx prisma migrate dev
-
Explore the Database with Prisma Studio:
npx prisma studio
- Frontend: The frontend is developed using React and TypeScript, focusing on component-based design and reactivity.
- Backend: Built with Node.js and Express.js, managing API routes and business logic.
- Prisma ensures database queries are type-safe and maintainable with postgres.
While deployment is not yet planned, the entire project is containerized with Docker, making it easy to deploy on any server with Docker support.
Find the project repository here. Repository managed by MohakGupta2004 and MohakTech