{"id":26485141,"url":"https://github.com/sandhit06/interview-platform-using-react-next.js","last_synced_at":"2026-04-09T01:31:19.368Z","repository":{"id":281589926,"uuid":"945744147","full_name":"Sandhit06/Interview-Platform-Using-React-Next.js","owner":"Sandhit06","description":"Full Stack Interview Platform with real time video call , code editor and screen sharing features. Also fully responsive ! ;-)","archived":false,"fork":false,"pushed_at":"2025-03-12T08:01:43.000Z","size":1210,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2026-01-03T16:30:42.185Z","etag":null,"topics":["interview","nextjs","react","tailwindcss","typescript"],"latest_commit_sha":null,"homepage":"https://codenexus-sandhit.vercel.app/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Sandhit06.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-03-10T03:54:33.000Z","updated_at":"2025-03-12T08:16:24.000Z","dependencies_parsed_at":"2025-03-10T05:19:22.037Z","dependency_job_id":"a2f5e647-2301-4af6-9643-c7e3a52dc7a1","html_url":"https://github.com/Sandhit06/Interview-Platform-Using-React-Next.js","commit_stats":null,"previous_names":["sandhit06/interview-platform-using-react-next.js"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/Sandhit06/Interview-Platform-Using-React-Next.js","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Sandhit06%2FInterview-Platform-Using-React-Next.js","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Sandhit06%2FInterview-Platform-Using-React-Next.js/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Sandhit06%2FInterview-Platform-Using-React-Next.js/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Sandhit06%2FInterview-Platform-Using-React-Next.js/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Sandhit06","download_url":"https://codeload.github.com/Sandhit06/Interview-Platform-Using-React-Next.js/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Sandhit06%2FInterview-Platform-Using-React-Next.js/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31581864,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-08T14:31:17.711Z","status":"ssl_error","status_checked_at":"2026-04-08T14:31:17.202Z","response_time":54,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["interview","nextjs","react","tailwindcss","typescript"],"created_at":"2025-03-20T05:55:35.197Z","updated_at":"2026-04-09T01:31:19.340Z","avatar_url":"https://github.com/Sandhit06.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003ch1 align=\"center\"\u003e\u003cb\u003e✨ CODENEXUS - Interview Platform ✨\u003c/b\u003e\u003c/h1\u003e\n\n![Demo App](/public/image.png)\n\n## Features:\n\n- [x] 🚀 **Tech stack:** Next.js \u0026 TypeScript, Stream, Convex, Clerk\n- [x] 🎥 **Video Calls**\n- [x] 🖥️ **Screen Sharing**\n- [x] 🎬 **Screen Recording**\n- [x] 🔒 **Authentication \u0026 Authorization**\n- [x] 💻 **Server Components, Layouts, Server Actions**\n- [x] 🎭 **Client \u0026 Server Components**\n- [x] 🛣️ **Dynamic \u0026 Static Routes**\n- [x] 🎨 **Styling with Tailwind \u0026 Shadcn UI**\n- [x] ✨ **Server Actions**\n\n## High-Level Architecture\n- Frontend: Built using Next.js and TypeScript, providing a responsive and intuitive user interface.\n- Backend: Handles server-side logic, user authentication, and video call functionalities.\n- Database: Uses Convex for storing user data, interview details, and video call records.\n- Video Communication: Utilizes Stream for real-time video calls, screen sharing, and recording.\n\n## Core Components\n- User Authentication: Managed by Clerk, ensuring secure login and role-based access control.\n- Video Calls: High-quality, real-time video communication with features like screen sharing and recording.\n- Interview Management: Allows scheduling, conducting, and recording interviews.\n- User Interface: Styled with Tailwind CSS and Shadcn for a modern and responsive design.\n\n## Workflow Steps\n### 1. User Registration and Login:\n  - Users sign up or log in using Clerk.\n  - User roles (interviewer or candidate) are assigned.\n\n### 2. Scheduling Interviews:\n  - Interviewers can schedule interviews, specifying date, time, and participants.\n  - Notifications are sent to participants.\n\n### 3. Conducting Interviews:\n  - Participants join the video call using Stream.\n  - Features like screen sharing and recording are available during the call.\n\n### 4. Storing Interview Data:\n  - Interview details and recordings are stored in the Convex database.\n  - Metadata (e.g., interview date, participants) is linked to the recordings.\n\n### 5. Reviewing Interviews:\n  - Interviewers can review recorded interviews.\n  - Feedback and notes can be added to each interview record.\n\n## Optimization Techniques\n- **Server-Side Rendering:** Enhances performance by rendering content on the server.\n- **Dynamic and Static Routes:** Optimizes navigation and improves user experience.\n- **Caching:** Reduces load times by storing frequently accessed data in memory.\n- **Rate Limiting:** Prevents abuse by controlling the number of requests a user can make.\n\n## Setup .env file\n\n```js\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=\nCLERK_SECRET_KEY=\nCONVEX_DEPLOYMENT=\nNEXT_PUBLIC_CONVEX_URL=\nNEXT_PUBLIC_STREAM_API_KEY=\nSTREAM_SECRET_KEY=\n```\n\n## Run the app\n\n```shell\nnpm run dev\n```\n## Credentials 🔐\n\n### For Using Admin Dashboard use these credentials \n```shell\nEmail: test@gmail.com\nPassword: David@954\n```\n\n## ⚠ Disclaimer\nThis tool is developed for educational and developmental purposes. It's crucial to understand the implications and responsibilities of using such technologies in real-world applications.\n\n\n## Still need help?\nOpen an issue on our GitHub repository, and we will help you as soon as possible.\n\nEnjoy exploring and extending this project! Feel free to contribute and suggest improvements.\n\n## Contact\n\nIf you want to contact me you can reach me at [Twitter](https://x.com/SandhitK).\n\n## Developer\n\u003ctable\u003e\n    \u003ctr align=\"center\"\u003e\n        \u003ctd\u003e\n        Sandhit Karmakar\n        \u003cp align=\"center\"\u003e\n            \u003cimg src = \"https://avatars.githubusercontent.com/u/90787826?v=4\" width=\"150\" height=\"150\" alt=\"Dhruv Shah\"\u003e\n        \u003c/p\u003e\n            \u003cp align=\"center\"\u003e\n                \u003ca href = \"https://github.com/Sandhit06\"\u003e\n                    \u003cimg src = \"http://www.iconninja.com/files/241/825/211/round-collaboration-social-github-code-circle-network-icon.svg\" width=\"36\" height = \"36\" alt=\"GitHub\"/\u003e\n                \u003c/a\u003e\n                \u003ca href = \"https://www.linkedin.com/in/sandhit-karmakar/\" target=\"_blank\"\u003e\n                    \u003cimg src = \"http://www.iconninja.com/files/863/607/751/network-linkedin-social-connection-circular-circle-media-icon.svg\" width=\"36\" height=\"36\" alt=\"LinkedIn\"/\u003e\n                \u003c/a\u003e\n                \u003ca href = \"mailto:sandhitkarmakar@gmail.com\" target=\"_blank\"\u003e\n                    \u003cimg src = \"https://www.iconninja.com/files/312/807/734/share-send-email-chat-circle-message-mail-icon.svg\" width=\"36\" height=\"36\" alt=\"Email\"/\u003e\n                \u003c/a\u003e\n            \u003c/p\u003e\n        \u003c/td\u003e\n    \u003c/tr\u003e\n\u003c/table\u003e\n\n\u003cp align=\"center\"\u003e\n    Made with ❤️ by \u003ca href=\"https://github.com/Sandhit06\"\u003eSandhit Karmakar\u003c/a\u003e\n\u003c/p\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsandhit06%2Finterview-platform-using-react-next.js","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsandhit06%2Finterview-platform-using-react-next.js","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsandhit06%2Finterview-platform-using-react-next.js/lists"}