Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nikhilmandaliya/natours
Narours: Explore the beauty of world and plan your next adventure effortlessly.
https://github.com/nikhilmandaliya/natours
express mapbox mongodb mongoose nodejs pug stripe
Last synced: 4 days ago
JSON representation
Narours: Explore the beauty of world and plan your next adventure effortlessly.
- Host: GitHub
- URL: https://github.com/nikhilmandaliya/natours
- Owner: NikhilMandaliya
- Created: 2022-08-27T11:47:09.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-10-15T15:51:53.000Z (over 1 year ago)
- Last Synced: 2024-11-16T08:21:52.002Z (2 months ago)
- Topics: express, mapbox, mongodb, mongoose, nodejs, pug, stripe
- Language: JavaScript
- Homepage:
- Size: 32.4 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
Natours
An awesome tour booking site built on top of NodeJS.
Key Features •
How To Use •
Build With •
Installation •
Acknowledgement## Key Features
* Authentication and Authorization
- Sign up, Log in, Logout, Update, and reset password.
* User profile
- Update username, photo, email, password, and other information
- A user can be either a regular user or an admin or a lead guide or a guide.
- When a user signs up, that user by default regular user.
* Tour
- Manage booking, check tour map, check users' reviews and rating
- Tours can be created by an admin user or a lead-guide.
- Tours can be seen by every user.
- Tours can be updated by an admin user or a lead guide.
- Tours can be deleted by an admin user or a lead-guide.
* Bookings
- Only regular users can book tours (make a payment).
- Regular users can not book the same tour twice.
- Regular users can see all the tours they have booked.
- An admin user or a lead guide can see every booking on the app.
- An admin user or a lead guide can delete any booking.
- An admin user or a lead guide can create a booking (manually, without payment).
- An admin user or a lead guide can not create a booking for the same user twice.
- An admin user or a lead guide can edit any booking.
* Reviews
- Only regular users can write reviews for tours that they have booked.
- All users can see the reviews of each tour.
- Regular users can edit and delete their own reviews.
- Regular users can not review the same tour twice.
- An admin can delete any review.
* Favorite Tours
- A regular user can add any of their booked tours to their list of favorite tours.
- A regular user can remove a tour from their list of favorite tours.
- A regular user can not add a tour to their list of favorite tours when it is already a favorite.
* Credit card Payment## How To Use
### Book a tour
* Login to the site
* Search for tours that you want to book
* Book a tour
* Proceed to the payment checkout page
* Enter the card details (Test Mode):
```
- Card No. : 4242 4242 4242 4242
- Expiry date: 02 / 22
- CVV: 222
```
* Finished!### Manage your booking
* Check the tour you have booked on the "Manage Booking" page in your user settings. You'll be automatically redirected to this
page after you have completed the booking.### Update your profile
* You can update your own username, profile photo, email, and password.
## Build With
* [NodeJS](https://nodejs.org/en/) - JS runtime environment
* [Express](http://expressjs.com/) - The web framework used
* [Mongoose](https://mongoosejs.com/) - Object Data Modelling (ODM) library
* [MongoDB Atlas](https://www.mongodb.com/cloud/atlas) - Cloud database service
* [Pug](https://pugjs.org/api/getting-started.html) - High performance template engine
* [JSON Web Token](https://jwt.io/) - Security token
* [ParcelJS](https://parceljs.org/) - Blazing fast, zero configuration web application bundler
* [Stripe](https://stripe.com/) - Online payment API and Making payments on the app.
* [Postman](https://www.getpostman.com/) - API testing
* [Mailtrap](https://mailtrap.io/) & [Sendgrid](https://sendgrid.com/) - Email delivery platform
* [Heroku](https://www.heroku.com/) - Cloud platform
* [Mapbox](https://www.mapbox.com/) - Displaying the different locations of each tour.## Setting Up Your Local Environment
If you wish to play around with the code base in your local environment, do the following
* Clone this repo to your local machine.
* Using the terminal, navigate to the cloned repo.
* Install all the necessary dependencies, as stipulated in the package.json file.
* If you don't already have one, set up accounts with: MONGODB, MAPBOX, STRIPE, SENDGRID, and MAILTRAP. Please ensure to have at least basic knowledge of how these services work.
* In your .env file, set environment variables for the following:
```
DATABASE=your Mongodb database URL
DATABASE_PASSWORD=your MongoDB passwordSECRET=your JSON web token secret
JWT_EXPIRES_IN=90d
JWT_COOKIE_EXPIRES_IN=90EMAIL_USERNAME=your mailtrap username
EMAIL_PASSWORD=your mailtrap password
EMAIL_HOST=smtp.mailtrap.io
EMAIL_PORT=2525
EMAIL_FROM=your real-life email addressSENDGRID_USERNAME=apikey
SENDGRID_PASSWORD=your sendgrid passwordSTRIPE_SECRET_KEY=your stripe secret key
STRIPE_WEBHOOK_SECRET=your stripe webhook secret
```
* Start the server.
* Your app should be running just fine.## Installation
You can fork the app or you can git-clone the app into your local machine. Once done, please install all the
dependencies and Set your env variables
```
git clone https://github.com/NikhilMandaliya/Organive.git
npm i
```Here are parcel scripts for dev and build
```
$ npm run watch:js
$ npm run build:js
```You can run for development (nodemon)
```
$ npm run dev
```
You can run in production mode
```
$ npm run start:prod (for production)
```## Acknowledgement
* This project is part of the online course I've taken at Udemy. Thanks to Jonas Schmedtmann for creating this awesome course! Link to the course: [Node.js, Express, MongoDB & More: The Complete Bootcamp 2019](https://www.udemy.com/course/nodejs-express-mongodb-bootcamp/)