Skip to content

devikumavath/Natours-Time-to-travel

Repository files navigation

Natours - Time To Travel ✈🧳

This full stack web application is specially designed for persons who love travelling and going on tour vacations.

Overview ✨

This web application allows it's users to book tour vacations.

A tour refers to a series of locations, specially picked to excite the adventurous spirit of the individual who books it.

A visiting user who has not yet created an account on the app can simply see all the current tours as well as detailed information about each tour.

Once signed up or logged in, they can then book any tour of their choice.

Users can write only one review for any tour they book.


Purpose ✨

This app is a pet project, built for the express purpose of honing my skills in full stack web development.


Project Demonstration ✨

Home Page :

HomePage

Tour Details :

TourDetails

LOGIN PAGE :

User Profile :

UserProfile

Admin Profile :

AdminProfile

Payment Process :


Main Tools And Technologies Used ✨

  • HTML (Create the structure and content of the web pages).
  • CSS (Styling of the web pages).
  • PUG (Template engine for generating the web pages dynamically).
  • JAVASCRIPT (Interactivity, as well as making requests to the API from the client-side).
  • NODE (Run JavaScript code on the server-side).
  • EXPRESS (Node framework, meant to simplify the process of building complex server-side applications).
  • MONGODB (Database for data persistence).
  • MONGOOSE (Interacting with mongodb).
  • MAPBOX (Displaying the different locations of each tour).
  • STRIPE (Making payments on the app).
  • JSON WEB TOKEN (Authenticating users)
  • NODEMAILER (Sending emails to users of the app)
  • MAILTRAP (Trapping the emails we send in our development environment, so they don't actually get sent to the user's email address)
  • SENDGRID (Sending actual emails to the users in production).
  • NPM modules and third party modules

Setting Up Your Local Environment ✨

Getting Started

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 neccessary 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 password

    * SECRET=your json web token secret
    * JWT_EXPIRES_IN=90d
    * JWT_COOKIE_EXPIRES_IN=90

    * EMAIL_USERNAME=your mailtrap username
    * EMAIL_PASSWORD=your mailtrap password
    * EMAIL_HOST=smtp.mailtrap.io
    * EMAIL_PORT=2525
    * EMAIL_FROM=your real life email address

    * SENDGRID_USERNAME=apikey
    * SENDGRID_PASSWORD=your sendgrid password

    * STRIPE_SECRET_KEY=your stripe secret key
    * STRIPE_WEBHOOK_SECRET=your stripe web hook secret

* Start the server.
* Your app should be running just fine.

Demo-.env file :


Main Features ✨

Users

  • Users can sign up with the application.
  • Users can log into the application.
  • Users can log out of the appication.
  • Users can update their password.
  • Users can reset their password
  • Users can update their general information.
  • Users can see their profile page.
  • A user can be either a regular user or an admin or a lead-guide or a guide.
  • When you sign up, you are a regular user by default.

Tours

  • 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 thesame tour twice.
  • Regular users can see all the tours thay 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 bookng for thesame user twice.
  • An admin user or a lead-guide can edit any booking.

Reviews

  • Only regular users can write reviews for tours which 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 thesame tour twice.
  • An admin can delete any review.

Notice

The app is actually quite more complex than is indicated in this documentation. Nevertheless, this summary is enough to help you understand the major features of the app. You are welcome to make improvements on the app. Please use the link specified at the beginning of the document to preview the app.

This project is not yet hosted....


Credits ✨

This project was created by Jonas Schmedtmann as part of his Node.js Bootcamp course on Udemy.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published