{"id":21184459,"url":"https://github.com/pintu544/todosocketrback","last_synced_at":"2026-04-16T10:02:16.031Z","repository":{"id":263397807,"uuid":"890261973","full_name":"pintu544/Todosocketrback","owner":"pintu544","description":"Collaborative To-Do Application with Real-Time Updates and User Management","archived":false,"fork":false,"pushed_at":"2024-11-18T09:54:28.000Z","size":59,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-14T19:52:33.239Z","etag":null,"topics":["express","jest","mongodb","nodejs","socket-io"],"latest_commit_sha":null,"homepage":"https://todosocketrback.onrender.com","language":"JavaScript","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/pintu544.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}},"created_at":"2024-11-18T09:18:48.000Z","updated_at":"2024-11-18T09:54:32.000Z","dependencies_parsed_at":"2024-11-19T04:05:37.199Z","dependency_job_id":null,"html_url":"https://github.com/pintu544/Todosocketrback","commit_stats":null,"previous_names":["pintu544/todosocketrback"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/pintu544/Todosocketrback","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pintu544%2FTodosocketrback","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pintu544%2FTodosocketrback/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pintu544%2FTodosocketrback/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pintu544%2FTodosocketrback/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/pintu544","download_url":"https://codeload.github.com/pintu544/Todosocketrback/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pintu544%2FTodosocketrback/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31880884,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-16T09:23:21.276Z","status":"ssl_error","status_checked_at":"2026-04-16T09:23:15.028Z","response_time":69,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6: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":["express","jest","mongodb","nodejs","socket-io"],"created_at":"2024-11-20T18:08:53.058Z","updated_at":"2026-04-16T10:02:16.015Z","avatar_url":"https://github.com/pintu544.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003c!DOCTYPE html\u003e\n\u003chtml\u003e\n\n\u003chead\u003e\n  \u003cmeta charset=\"utf-8\"\u003e\n  \u003cmeta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"\u003e\n \n  \u003clink rel=\"stylesheet\" href=\"https://stackedit.io/style.css\" /\u003e\n\u003c/head\u003e\n\n\u003cbody class=\"stackedit\"\u003e\n  \u003cdiv class=\"stackedit__html\"\u003e\u003ch1 id=\"collaborative-to-do-application-with-real-time-updates-and-user-management\"\u003eCollaborative To-Do Application with Real-Time Updates and User Management\u003c/h1\u003e\n\u003ch2 id=\"project-overview\"\u003eProject Overview\u003c/h2\u003e\n\u003cp\u003eThis application is a collaborative \u003cstrong\u003eTo-Do List\u003c/strong\u003e platform where users can manage tasks, track real-time updates, and collaborate efficiently. With \u003cstrong\u003erole-based access control\u003c/strong\u003e, users are categorized as “Admin” or “User” to ensure permissions are managed effectively. Real-time updates enable dynamic interaction, and an intuitive interface streamlines task management.\u003c/p\u003e\n\u003chr\u003e\n\u003ch2 id=\"features\"\u003eFeatures\u003c/h2\u003e\n\u003ch3 id=\"authentication--authorization\"\u003e\u003cstrong\u003eAuthentication \u0026amp; Authorization\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eJWT-based authentication for \u003cstrong\u003eregistration\u003c/strong\u003e, \u003cstrong\u003elogin\u003c/strong\u003e, and \u003cstrong\u003elogout\u003c/strong\u003e.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003eRole-based access control\u003c/strong\u003e:\n\u003cul\u003e\n\u003cli\u003e\u003cstrong\u003eAdmins\u003c/strong\u003e: Manage all tasks.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003eUsers\u003c/strong\u003e: Manage only their tasks.\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003eSecure password storage using \u003cstrong\u003ebcrypt\u003c/strong\u003e hashing.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"task-management-crud\"\u003e\u003cstrong\u003eTask Management (CRUD)\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eCreate, Read, Update, and Delete (CRUD) tasks with attributes:\n\u003cul\u003e\n\u003cli\u003eTitle\u003c/li\u003e\n\u003cli\u003eDescription\u003c/li\u003e\n\u003cli\u003eDue date\u003c/li\u003e\n\u003cli\u003eStatus (\u003cstrong\u003eTo Do\u003c/strong\u003e, \u003cstrong\u003eIn Progress\u003c/strong\u003e, \u003cstrong\u003eDone\u003c/strong\u003e)\u003c/li\u003e\n\u003cli\u003eAssigned user\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003eValidation to ensure tasks include a title and due date.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"real-time-collaboration\"\u003e\u003cstrong\u003eReal-Time Collaboration\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eReal-time task updates using \u003cstrong\u003eWebSockets (\u003ca href=\"http://Socket.io\"\u003eSocket.io\u003c/a\u003e)\u003c/strong\u003e.\u003c/li\u003e\n\u003cli\u003eNotifications for task changes (e.g., “Task marked as completed by UserX”).\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"frontend-react\"\u003e\u003cstrong\u003eFrontend (React)\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eResponsive and intuitive UI built with \u003cstrong\u003eReact\u003c/strong\u003e.\u003c/li\u003e\n\u003cli\u003eFeatures include:\n\u003cul\u003e\n\u003cli\u003eTask list views with sorting and filtering (by due date or status).\u003c/li\u003e\n\u003cli\u003eForms for creating/editing tasks.\u003c/li\u003e\n\u003cli\u003eGlobal state management via \u003cstrong\u003eRedux\u003c/strong\u003e or \u003cstrong\u003eReact Context\u003c/strong\u003e.\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"activity-log\"\u003e\u003cstrong\u003eActivity Log\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eTracks user actions (e.g., task creation, updates, deletions).\u003c/li\u003e\n\u003cli\u003eDisplays logs in an accessible format (e.g., “UserX marked TaskY as completed on [timestamp]”).\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"notifications\"\u003e\u003cstrong\u003eNotifications\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eReal-time toast notifications for:\n\u003cul\u003e\n\u003cli\u003eTask updates.\u003c/li\u003e\n\u003cli\u003eTasks nearing their due dates (assigned to the current user).\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003eMark notifications as read.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"testing\"\u003e\u003cstrong\u003eTesting\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eBackend tested using \u003cstrong\u003eJest\u003c/strong\u003e and \u003cstrong\u003eSupertest\u003c/strong\u003e.\u003c/li\u003e\n\u003cli\u003eFrontend components tested with \u003cstrong\u003eReact Testing Library\u003c/strong\u003e.\u003c/li\u003e\n\u003cli\u003eReal-time WebSocket connections tested to ensure seamless updates.\u003c/li\u003e\n\u003c/ul\u003e\n\u003chr\u003e\n\u003ch2 id=\"tech-stack\"\u003eTech Stack\u003c/h2\u003e\n\u003ch3 id=\"frontend\"\u003e\u003cstrong\u003eFrontend\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003e\u003cstrong\u003eReact\u003c/strong\u003e for UI development.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003eRedux\u003c/strong\u003e or \u003cstrong\u003eReact Context API\u003c/strong\u003e for state management.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003eMaterial-UI (MUI)\u003c/strong\u003e or \u003cstrong\u003eCSS Modules\u003c/strong\u003e for styling.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"backend\"\u003e\u003cstrong\u003eBackend\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003e\u003cstrong\u003eNode.js\u003c/strong\u003e with \u003cstrong\u003eExpress.js\u003c/strong\u003e for the API.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003eMongoDB\u003c/strong\u003e for data storage.\u003c/li\u003e\n\u003cli\u003e\u003cstrong\u003e\u003ca href=\"http://Socket.io\"\u003eSocket.io\u003c/a\u003e\u003c/strong\u003e for real-time WebSocket communication.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"testing-1\"\u003e\u003cstrong\u003eTesting\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003e\u003cstrong\u003eJest\u003c/strong\u003e, \u003cstrong\u003eSupertest\u003c/strong\u003e, and \u003cstrong\u003eReact Testing Library\u003c/strong\u003e.\u003c/li\u003e\n\u003c/ul\u003e\n\u003chr\u003e\n\u003ch2 id=\"installation\"\u003eInstallation\u003c/h2\u003e\n\u003ch3 id=\"prerequisites\"\u003e\u003cstrong\u003ePrerequisites\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003eNode.js (v16+)\u003c/li\u003e\n\u003cli\u003eMongoDB (local or cloud instance)\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"setup-instructions\"\u003e\u003cstrong\u003eSetup Instructions\u003c/strong\u003e\u003c/h3\u003e\n\u003col\u003e\n\u003cli\u003e\n\u003cp\u003eClone the repository:\u003c/p\u003e\n\u003cp\u003ebash\u003c/p\u003e\n\u003cp\u003e\u003ccode\u003egit clone https://github.com/pintu544/Todosocketrback cd Todosocketrback npm install\u003c/code\u003e\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\n\u003cp\u003eInstall dependencies for both frontend and backend:\u003c/p\u003e\n\u003cp\u003ebash\u003c/p\u003e\n\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp\u003egit clone \u003ca href=\"https://github.com/pintu544/TodoScoketRbacFrontend\"\u003ehttps://github.com/pintu544/TodoScoketRbacFrontend\u003c/a\u003e\u003cbr\u003e\ncd TodoScoketRbacFrontend\u003cbr\u003e\nnpm install\u003c/p\u003e\n\u003col start=\"3\"\u003e\n\u003cli\u003e\n\u003cp\u003eConfigure environment variables:\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003e\n\u003cp\u003eCreate a \u003ccode\u003e.env\u003c/code\u003e file in the \u003ccode\u003ebackend\u003c/code\u003e folder and add:\u003c/p\u003e\n\u003cp\u003eenv\u003c/p\u003e\n\u003cpre class=\" language-mongo_uri\"\u003e\u003ccode class=\"prism =\u003cyour-mongodb-connection-string\u003e language-mongo_uri\"\u003eJWT_SECRET=\u0026lt;your-secret-key\u0026gt;  \nSOCKET_PORT=8000 \n\n\u003c/code\u003e\u003c/pre\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003e\n\u003cp\u003eStart the development servers:\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003e\n\u003cp\u003e\u003cstrong\u003eBackend\u003c/strong\u003e:\u003c/p\u003e\n\u003cp\u003ebash\u003c/p\u003e\n\u003cp\u003enpm start`\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\n\u003cp\u003e\u003cstrong\u003eFrontend\u003c/strong\u003e:\u003c/p\u003e\n\u003cp\u003ebash\u003c/p\u003e\n\u003cp\u003enpm run dev`\u003c/p\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003e\n\u003cp\u003eOpen the application:\u003cbr\u003e\nVisit \u003ccode\u003ehttp://localhost:5173\u003c/code\u003e in your browser.\u003c/p\u003e\n\u003c/li\u003e\n\u003c/ol\u003e\n\u003chr\u003e\n\u003ch2 id=\"folder-structure\"\u003eFolder Structure\u003c/h2\u003e\n\u003ch3 id=\"frontend-1\"\u003e\u003cstrong\u003eFrontend\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003e\u003ccode\u003esrc/\u003c/code\u003e\n\u003cul\u003e\n\u003cli\u003e\u003ccode\u003ecomponents/\u003c/code\u003e – Reusable React components.\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003econtext/\u003c/code\u003e – Context API for state management.\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003epages/\u003c/code\u003e – Page-level components (e.g., Home, Login).\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003eutils/\u003c/code\u003e – Helper functions.\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch3 id=\"backend-1\"\u003e\u003cstrong\u003eBackend\u003c/strong\u003e\u003c/h3\u003e\n\u003cul\u003e\n\u003cli\u003e\u003ccode\u003emodels/\u003c/code\u003e – MongoDB models (e.g., Task, User).\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003eroutes/\u003c/code\u003e – API endpoints.\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003econtrollers/\u003c/code\u003e – Request handlers.\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003emiddlewares/\u003c/code\u003e – Authentication and error handling.\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003etests/\u003c/code\u003e – Backend test cases.\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/div\u003e\n\u003c/body\u003e\n\n\u003c/html\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpintu544%2Ftodosocketrback","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fpintu544%2Ftodosocketrback","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpintu544%2Ftodosocketrback/lists"}