Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/raghavbhatirv/kanbanboard-backend
This is the backend for a Kanban board application. The application is built using Node.js, Express, and MongoDB.
https://github.com/raghavbhatirv/kanbanboard-backend
aws express mongodb mongoosejs nodejs oauth2 passportjs
Last synced: 7 days ago
JSON representation
This is the backend for a Kanban board application. The application is built using Node.js, Express, and MongoDB.
- Host: GitHub
- URL: https://github.com/raghavbhatirv/kanbanboard-backend
- Owner: raghavbhatirv
- Created: 2024-02-28T18:43:52.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-03-03T18:44:54.000Z (11 months ago)
- Last Synced: 2024-11-12T00:38:18.941Z (2 months ago)
- Topics: aws, express, mongodb, mongoosejs, nodejs, oauth2, passportjs
- Language: JavaScript
- Homepage: https://api.raghavbhatirv.in/api
- Size: 245 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# KanbanBoard-Backend
## Introduction
Welcome to the Kanban Board Backend repository. In this project, I aim to demonstrate my skills in backend web development, utilizing a combination of Node.js, Express, and MongoDB to create a robust and efficient backend system. The assignment revolves around building a comprehensive backend for a Kanban board application for Mathongo. This backend system is designed to handle various operations such as user authentication, task management, and board updates, providing a solid foundation for a frontend application to interact with. The application is hosted on an AWS server, showcasing its scalability and reliability.## Tech Stack
The application is built with the following technologies:
- Node.js
- Express
- MongoDB
- AWS
- Passport.js
- OAuth
- Mongoose## Installation
To get started with the project, follow these steps:1. Clone the repository.
```bash
https://github.com/Raghavbhati/KanbanBoard-Backend.git
```2. Install the dependencies using.
```bash
npm install
```3. Start the application by running.
```bash
npm run dev
```The application will start running on port 9000.
## File Structure
![File_Structue](./images/Folder%20Structure.png)## API Endpoints
The application provides the following APIs:### User APIs
- `GET /google`: Login & Signup via Google. This endpoint uses Passport.js for authentication.
- `GET /google/callback`: Callback API for Passport.js. This endpoint checks if the user already exists in the database, if not, it adds the user.
- `GET /google/failed`: If the callback request fails, this endpoint is called.
- `POST /logout`: For logout request.### Board APIs
- `POST /add`: Create a new board.
- `GET /:id`: Get a single board.
- `GET /allDetails/:id`: Get full board and connected task details.
- `PATCH /:id`: Update a board.### Task APIs
- `POST /add`: Add a new task.
- `GET /:id`: Get a single task.
- `PATCH /:id`: Update a task.Each endpoint has specific requirements and responses. For more details, please refer to the backend documentation.
## Important links:
**Portfolio:** https://www.raghavbhatirv.in/
**Github:** https://github.com/Raghavbhati
**Linkdin:** https://www.linkedin.com/in/raghavbhatirv/
**Twitter:** https://twitter.com/raghavbhatirv/