Skip to content

tylly/project-3-react

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

187 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Travel Planner API Project

An app that helps you plan and book (stretch goal) trips.

Roles

Team Manager: James Adams Front End : Dan Stacy Back End: Amanda Corral

API's

Open Trip Map API - provides geo location and images for location Amadeus - provides recommended activities for location

User Stories

As a user I want to be able to create an account. As a user I want to be able to sign into my account. As a user I want to be able to sign out of my account. As a user I want to be able to search destinations. As a user I want to be able to save destinations. As a user I want to be able to select destination display image. As a user I want to be able to edit destination display image. As a user I want to be able to delete destination. As a user I want to be able to view recommended activities. As a user I want to be able to save recommended activities. As a user I want to be able to create custom activities. As a user I want to be able to edit any activity. As a user I want to be able to delete an activity.

Structure

Dependencies are stored in package.json.

The most important file for understanding the structure of the template is server.js. This is where the actual Express app object is created, where the middlewares and routes are registered, and more. To register a routefile, follow the pattern established here with exampleRoutes and userRoutes. If you want to add any middlewares to your app, do that here.

The app directory contains models and route files. Models are simply Mongoose models. To create your own, follow the patterns established in app/models/example.js. Route files are somewhat similar to controllers in Rails, but they cover more functionality, including serialization and deciding which HTTP verbs to accept and what to do with them.

The config directory holds just db.js, which is where you specify the name and URL of your database.

The lib directory is for code that will be used in other places in the application. The token authentication code is stored in lib/auth.js. The other files in lib deal with error handling. custom_errors.js is where all the different custom classes of errors are created. If you need some other kind of error message, you can add it here. There are also some functions defined here that are used elsewhere to check for errors. lib/error_handler.js is a function that will be used in all your .catches. It catches errors, and sets the response status code based on what type of error got thrown.

You probably will only need to interact with files in app/models, app/routes, and server.js. You'll need to edit db/config.js just once, to change the name of your app.

Authentication

Verb URI Pattern Controller#Action
POST /sign-up users#signup
POST /sign-in users#signin
PATCH /change-password/ users#changepw
DELETE /sign-out/ users#signout

DESTINATIONS

Verb URI Pattern Controller#Action
GET / index
GET /:id show
POST / add
PATCH /:id update
DELETE /:id destroy

ACTIVITES

Verb URI Pattern Controller#Action
GET /:id index
GET /:id/:activityId show
POST /:id add
PATCH /:id/:activityId update
DELETE /:id/:activityId destroy

Models

USERS COLLECTION

email: { type: String, required: true, unique: true }

hashedPassword: { type: String, required: true }

token: String

DESTINATIONS

name: { type: String, required: true }

images: String

schedule: string

owner: String

activities: []

ACTIVITIES

name: { type: String, required: true }

address: string

schedule: String

priority: number

ERD

Read me Images

Sign Up

Read me Images

Sign In

Read me Images

Index Page

Read me Images

Plan Trip Page

Read me Images

Show Page

Read me Images

Activity Show Page

Read me Images

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •