Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/chen-abudi/react-around-api-full
Responsive Full-Stack web app that showcases a photo collection of a userβs travel aka Around U.S
https://github.com/chen-abudi/react-around-api-full
css3 expressjs jsonwebtoken mern-stack mongodb nodejs postman reactjs restful-api vercel vercel-deployment vercel-serverless vercel-serverless-functions
Last synced: 29 days ago
JSON representation
Responsive Full-Stack web app that showcases a photo collection of a userβs travel aka Around U.S
- Host: GitHub
- URL: https://github.com/chen-abudi/react-around-api-full
- Owner: Chen-Abudi
- Created: 2022-10-07T12:43:23.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-05T13:31:41.000Z (about 2 months ago)
- Last Synced: 2024-12-05T14:29:30.308Z (about 2 months ago)
- Topics: css3, expressjs, jsonwebtoken, mern-stack, mongodb, nodejs, postman, reactjs, restful-api, vercel, vercel-deployment, vercel-serverless, vercel-serverless-functions
- Language: JavaScript
- Homepage: https://react-around-api-full-client.vercel.app
- Size: 5.89 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Project 15: Around U.S Full-Stack Social Travel App π
## **Developed By Grace Chen Abudi** π©π½βπ»
This repository contains the full API of "Around the U.S." project that features user authorization and user registration and handles cards and users.
This app was integrated between Backend & Frontend repositories, then deployed to _Vercel_.
# π£ Overview:
- Intro
- Tech Stack & Techniques
- Free Images Source
- Possible Improvements
- Live Project
- All Project Features## π Intro
This is a Full-stack interactive app with responsive design which enables travelers to share their travel photos by creating account.
## π§° π οΈ Tech Stack & Techniques:
- ReactJS
- Express.js
- Node.js
- MongoDB + MongoDB-Atlas
- **_`Vercel` Deployment_**
- CI/CD
- `Vercel Serverless technology`
- JWT server Auth
- localStorage
- REST API with CRUD Implementation
- CSS3
- Git/GitHub---
| NPM Packages (Backend) | Aspects of Use |
| :----------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| bcryptjs | Password Encryption |
| body-parser | Returns middlewares that handle incoming requests before they reach a target controller . |
| celebrate | It's an express middleware function that wraps the joi validation library . |
| cors (Cross-Origin Resource Sharing) | It is a mechanism to allow or restrict requested resources on a web server depend on where the HTTP request was initiated. This policy is used to secure a certain web server from access by other website or domain . |
| dotenv | automatically loads environment variables from a . env file into the process. env object . |
| express-winston | Provides middlewares for request and error logging of your express.js application . |
| winston | Universal logging library with support for multiple transports . |
| validator | A library of string validators and sanitizers . |
| jsonwebtoken | An open standard for securely transferring data within parties using a JSON object . |
| express-rate-limit | Use to limit repeated requests to public APIs and/or endpoints such as password reset . |
| helmet | Helps you secure your Express apps by setting various HTTP headers . |## π API Endpoints :
| RESTful API Enpoints | HTTP Methods | Usage Purpose |
| :------------------- | -----------: | :------------------------------: |
| /signup | POST | User Registration |
| /signin | POST | User Login |
| /users | GET | GETting data from all users |
| /users/:\_id | GET | GETting user by their id. |
| /users | POST | Creating a specific user profile |
| /users/me | PATCH | Updating user data |
| /users/me/avatar | PATCH | Updating user avatar data |
| /cards | GET | GETting data from all cards |
| /cards | POST | Creating a new card |
| /cards/:\_id | DELETE | DELETE card by its id |
| /cards/:\_id/likes | PUT | Liking a card |
| /cards/:\_id/likes | DELETE | Disliking a card |## π· Free Images Source
- _For incredible images, Feel `Free` to_ [ππ½ **Click Here !**](https://unsplash.com/)
## π§ Possible Improvements
- [ ] Create a Forgot Password option in case the users forget theirs.
- [ ] Resets Password# β¨ Live Project
- `Visit the App` [ππ½ **HERE !**](https://react-around-api-full-client.vercel.app/)
- [Remote Server API Deployment](https://react-around-api-full-five.vercel.app)
**Enjoy ! πΊ**
---
# πΈ All Project Features
- **In first visitation, the users requires to sign up to create an account.**
- **_If the users has registered already, they can simply log in._**
![](./frontend/src/images/signup.png)
![](./frontend/src/images/login.png)- **Once the users logged in, there's no need to log back in again for 7 days at least, as this is the expiration duration of JWT token.**
- **They will be navigated to the **Homepage** with several features to use.**
![](./frontend/src/images/homepage.png)- **_Edit their profile name, about, and their avatar image._**
![](./frontend/src/images/edit-profile.png)
![](./frontend/src/images/update-user-avatar.png)- **_Adding their own cards to the collection._**
![](./frontend/src/images/add-card.png)- **_Seeing others cards._**
- **_Capability to like or dislike own and others cards as well._**
![](./frontend/src/images/like-dislike.jpg)
- **_The users can remove only their own cards and not someone elses._**
![](./frontend/src/images/remove.jpg)- **_Click on the image to view it in its full size._**
![](./frontend//src//images/zoom-in.png)