Skip to content
This repository has been archived by the owner on May 28, 2024. It is now read-only.

Latest commit

 

History

History
154 lines (100 loc) · 7.47 KB

README.md

File metadata and controls

154 lines (100 loc) · 7.47 KB

Castive

A platform to build and share movie & tv series playlists


Table Of Contents

1. What is Castive?

Castive is a platform where people can create accounts, build and share playlists with their favourite movies and tv series. People can follow each other, like other people's playlists or block other users so that their playlists are not visible to those users.

This project is the backend service for Castive.


2. Using 2 Databases - Redis & MongoDB

MongoDB was chosen over traditional SQL databases since it provides a handful of tools like full text search and documents structures are easily changed unlike a SQL database.
Redis is used alongside MongoDB to store jwt tokens of all kinds to improve response times and seperate the application logic from token system.

  • Caching
    Redis is also used for caching responses from TMDB and Announcements that are stored in the main (MongoDB) database. This allows for faster generated responses and reduces the number of requests sent to TMDB.

3. Improved authentication system using 2 tokens and redis

Most applications use only access token and some of those have the silent authentication system. However this system is not easy to implement and fairly complicated compared to refresh tokens. That's why I decided to go with access and refresh token system.

The improvement over other systems is that both tokens get stored in Redis database rather than main database. This allows the server to respond quicker to subsequent requests made with access tokens and refresh tokens since every request requires a validation of the tokens.

Implementation of this system can be seen in src/util/jwt.js and src/controllers/v1/auth.controllers.js.


4. Ratelimiting feature

Castive is using rate limiting in most routes to prevent brute force attacks and abuse. Implementation of rate limiting can be found in src/util/limiter.js.


5. Password reset and mail confirmation system

Just like every single social platform, Castive has its own mailing system to send password reset tokens and mail confirmations. Implementation can be found in src/util/mailer.js * Tokens sent with all mails are also stored in Redis to validate afterwards and improve security.


6. Improving response times and reducing the load on MongoDB

  • Image System
    For the image system, I've used a seperate Image model. The system works in the following order:

    1. User uploads an image
    2. The image is then stored in a Image document with original property set
    3. When the image's small or medium format is requested, they are generated on the fly for just one time.
    4. For every other subsequent request the requested type is sent with response


    That is, if small and medium are not requested, those fields will remain null, therby not becoming a burden on database. Moreover, having the small and medium version of the images opens the possiblity of requesting those versions whenever original is simply not needed, thereby improving response times.

  • Virtual Fields in Models
    There are simply no fields to store some of the properties of users and lists. For instance, under a user document, only following property is stored. Whenever followers property is needed for a response, it gets generated using Mongoose's very handful .populate() method. The implementation of populating field can be seen in both src/models/user.model.js and src/models/list.model.js.


7. Partial and full-text search system

Thanks to MongoDB, it was easy to implement a full-text search without dealing with systems like Elastic Search. Implementing full text search is as simple as follows,

.find(
      {
        $text: {
          $search: q,
          $caseSensitive: false,
          $diacriticSensitive: false,
        },
        _id: { $ne: id },
        blocked: { $nin: [id] },
      },
      { score: { $meta: 'textScore' } }
    )

For the partial text search part, I use Regular Expressions whenever the result from full text search yields 0 results.
The full implementation can be seen in src/models/user.model.js.


8. Protection for XSS & NoSQL Injection and Parameter pollution attacks

Security is important, especially if you are building a social platform. To overcome some common problems, I took help from some packages such as, Helmet, MongoSanitize and HPP.


9. Highly Customizable responses using query parameters

Almost all of the endpoints take a great amount of query parameters to customize the response according to the needs. This allows the requester to exclude any information that is not needed and improve response times. An example can be seen below.

/users/me?following=1&followers=0&lists=true&blocked=false&library=1


10. Technologies used to build Castive

Castive uses a number of technologies to operate.

  • Express - Fast node.js network app framework
  • node.js - Evented I/O for the backend
  • JWT - Industry standard RFC 7519 method for representing claims securely between two parties
  • MongoDB - A document database
  • Redis - In-memory data structure store
  • Mongoose - Elegant mongodb object modeling for NodeJS
  • TMDB - The Movie Database (TMDB) is a community built movie and TV database.

* This product uses the TMDB API but is not endorsed or certified by TMDB.


LICENSE

This project is under GNU GPLv3 license. See LICENSE and COPYING for more.


Contact

For anything related to the project, contact me at [email protected].


Attributions


TMDB