Post-It is a social media app that allows you to post anything (text, images, video, and/or audio) on a single post-it. A post-it is a single post on the post-it app, just like a tweet. Other users can reply to a post-it. Replying to a post-it is like adding a comment to a post (post-it). Although currently, this app will only accept texts as replies.
- Users can signup and login to their accounts.
- Users can access all causes as well as create a new cause, edit their created cause and also delete what they've created.
- A user cannot delete posts and comments made by another user.
- Soft delete was implemented on all resources; when resources are deleted, its still stored on the database collection but it ceases to be returned if fetched.
- All Avatar requirements were satisfied.
{
"message": "User fetched successfully",
"fetchedUser": {
"imgTag": "<img src=\"https://api.dicebear.com/5.x/bottts/svg?seed=james-g5xm5-gmail-z3orx-com&size=200&radius=50\" alt=\"james's avatar\">",
"avatar": "https://api.dicebear.com/5.x/bottts/svg?seed=james-g5xm5-gmail-z3orx-com&size=200&radius=50",
"username": "james",
"email": "[email protected]"
}
}
-
Clone this repository
https://github.com/kingsleycj/post-it-app
-
The
develop
branch is the most stable branch at any given time, ensure you're working from it. -
Run
npm install
to install all dependencies -
Create an .env file in your project root folder and add your variables.
Run
npm start
to start the application.
Connect to the API using Postman on port
5000
.
- NodeJS (LTS version)
- ExpressJS
- JavaScript
- MongoDB Database
- Mongoose ODM (Object Data Mapper)
- Dotenv
- Bcrypt
- Joi
- Jsonwebtoken
- Body-parser
- Nodemon
A clean architecture was implemented during the process of building this app.
├── controllers
│ ├── comment.controller.js
│ ├── post.controller.js
│ ├── user.controller.js
├── middlewares
│ ├── validator.js
├── models
│ ├── comment.model.js
│ ├── post.model.js
│ ├── user.model.js
├── routes
│ ├── auth.route.js
│ ├── comment.route.js
│ ├── server.route.js
│ ├── post.route.js
│ ├── user.route.js
├── utils
│ ├── avatar.js
│ ├── greeting.js
│ ├── imgTag.js
├── .gitignore
├── app.js
├── package.json
└── README.md
- Soft delete was implemented by setting the
delete
default property of each resources tofalse
, and only converting them totrue
after it has been updated through the DELETE endpoint.
{
deleted: {
type: Boolean,
default: false,
}
}
- I used the mongoose method of
.findOneAndUpdate()
on the DELETE endpoints to update thedeleted
property on each resource.
{
await Resource.findOneAndUpdate(
{ _id: req.params.commentId },
{ deleted: true },
{ new: true }
)
}
- As previously stated above, the deleted resources are not returned because their properties have been changed to
true
. However, they're still stored on the linked MONGODB database.
Dicebear API was used for the generation of avatars.