Skip to content

Latest commit

 

History

History
93 lines (66 loc) · 5.56 KB

README.md

File metadata and controls

93 lines (66 loc) · 5.56 KB

challenge

node-coding-question

Req1:

  • Initialized Node Project with npm init and installed all dependencies using node package manager.
  • Created an express server and utilized the following middlewares: body-parser for parsing incoming request bodies and added morgan as a logger of HTTP requests in the console for easy debugging.
  • Set up postgres and created a test_db database.
  • Used .sequelizerc to override default path to migration, models, seeders and config folder for better organization of files.
  • Utilized sequelize-cli for migrations and project bootstrapping.
  • Created user model with the attributes required.
  • Added a beforeCreate hook with bcrypt to hash password in the database before insertion.
  • Connected database with the server.
  • Created a users api route to implement user registration.
  • Upon registration, IF email entered already exists, a json error response will be sent to notify user that "The email address is already being used". ELSE the user will be created and a valid jwt token that was generated will be assigned and attached to the headers.
  • JWT secret configured and inputted in a .env file.
  • JWT payload to return id and name.
  • Set up jwt token to expire in 1hr.
  • Added express-validator middleware to check and handle validation errors.
  • Created a custom middleware for authentication that implements jwt. In which if checks for valid token in the headers. IF not exists in headers, private routes will not be accessible.
  • On Auth route (auth.js) created login capabilities using email and password for authentication.
    • Used sequelize to query database to match entered email and password. Unhashed password with bcyrpt compare.
    • IF, credentials checks out with information from database. jwt will be signed with secret and return a token (with payload: id and name). ELSE return an error to let user know that the credentials entered are invalid.
  • Created post model with the attributes required.
  • Created post route for Post. Passed auth middleware to check if user is still authenticated to protect route. -IF still authenticated, find validation errors in the request. IF no errors found, insert data using sequelize and return created post.

Register User Login User Get User Details Create a Post

Req2:

  • Created a post route in which a user can create a new post with the attributes Title, Description, Photo.
  • In the GET route for api/post/:userId queried the database using sequelize to return all posts from user.
    • Used moment library to calculate the time difference from when the post was created and now.
    • Created a post object with all the elements and push the data in foundPosts array and send the json response with the found posts.
  • Created an S3 Bucket with AWS. Saved credentials on a dot env file. Implemented multer and aws to upload images to aws S3.
  • Modified Posts model to make string size to 400 characters so all photo url will be saved in database as one string. (The photoURL will be sent to front end as an array as I am splitting the string to be returned as an array).
  • Set up multer in which you cannot upload more than 5 photos.
  • Created POST route for Post to view all posts created.
  • Created a PATCH route for post where user(author) of post will be able to edit title and description of post.

Get All Posts by User Create a Post with multiple photos Get an Error if More Than 5 Photos Edith a post

Req3:

  • Created a new model schema for comments. associated with posts.
  • Created a GET route for api/user/:postId/comments to view all comments with postId
  • Created a GET route for api/user to view all comments. with Pagination. Queried database to show all comments.
  • Updated user model with migrations to add column username.
  • Created PATCH route on api/users to create/update users username. Used sequelize to update database.

Get All Posts with pagination Get all Comments with pagination POST a comment Update username