Skip to content

A REST API generator based on express for SugrFree - AI based diet system.

Notifications You must be signed in to change notification settings

Trevahok/sugrfree-rest

Repository files navigation

SugrFree - Live life stresFree

SugrFree - Intended to be an AI-based recommendation engine. This repository contains a complete REST API generator for any given Joi object. Models used :

  • Menu - For Menucard of foods
  • Food - Contains Recipes and details of a particular food.
  • Recipe - Model for List of Recipes for each food. Contains a list of Steps.
  • Step - Each step of a recipe is stored as a separate model to permit CRUD updates individually.
  • Ingredient - Model to store Ingredient details.
  • Nutrition - Nutrition value of each Ingredient. Can be summed up to find nutrition value of a food.

Need for REST API generator


REST APIs are very repetitive, they provide access to a DB object with some Validation, Authentication and Authorization.

 So my work is, essentially, write one Joi Schema to produce REST api with documentation is written automatically. One Joi Schema for : 

 - Input validation
 - Mongoose model
 - controllers
 - routes
 - routes for recursively generated endpoints for Embedded Document Lists
 - GUI interface to access data
 - documentation

ToDo:

  • AdminSet adds Toasty forms based admin view into the endpoints to add list, create, update and delete
  • DocumentSet that generates documentation from RouterSet.

Usage :


  • Make your model in Joi and add validations.
export const NutritionSchema = Joi.object({
    name: Joi.string().required(),
    calorie: Joi.number().required()

})
  • Make RouterSet which in turn adds ControllerSet and EmbedControllerSet recursively.
const nutritionRouterSet = new RouterSet('nutrition', NutritionSchema, loginRequiredMiddleware)
  • Use Generated Router in main app
app.use('/nutrition', nutritionRouter )

Custom Framework Components


  • controllerSet - CRUD updates to model
  • routerSet - adds routes to CRUD controllers
  • embedControllerSet - for embedded documents list in an object
  • embedRouterSet - for recursively generate endpionts for nested SubDocuments
  • custom JWT based auth framework
  • custom Joi to Mongoose Schema conversion

ToDo:

  • documentationSet - adds documentation to routes
  • adminSet - adds Toasty forms rendered UI for REST API CRUD updates.

Tech Stack


  • JWT - for custom auth framework

  • custom controllerSet framework

  • custom routerset framework

  • custom Joi to Mongoose conversion

  • Joi - for defining models and validation

  • swagger - documentation of endpoints

  • express - base framework

  • bcrypt - for storing hashed passwords

  • morgan - for request logging

  • cors - for CORS headers access

  • docker - for containerization

  • kubernetes - for container orchestration

  • GKE - google kubernetes engine for hosted kubernetes client

  • heroku - for deployment

Custom Auth Framework

  • JWT based auth framework.
  • LoginRequiredMiddleware - to protect and endpoint from unauthorized access.
  • PermissionRequiredMiddleware - to protect and endpoint from different levels of permissions based on role.
  • Different names for roles are specified on constants.mjs for internationalization.
  • login route takes the following as POST request body and returns a Token object
    {
        "name": "name",
        "password" : "password",
    }
  • register route takes the following as a POST request body and returns UserId
    {
        "name": "name",
        "password" : "password",
        "email": "email@gmail.com",
    }
  • name has to be unique.
  • Authorization header contains the token used for Bearer Authorization.

ControllerSet


GET, POST, PUT and DELETE controllers and validation look exactly the same for every Model. To mitigate this, ControllerSet is introduced. All you need to give is one JoiSchema and it will be converted to Mongoose model and saved.

Controllers URL Method Notes
listController / GET Query parameter query is an object which is used for filtering and fields a string of comma-separated which is used for projection
createController / POST
detailController /:id GET
updateController /:id PUT
deleteController /:id DELETE
Minutiae
  • Query parameters are taken for filtering and projection by Mongoose.
    • query is an URL object that is used to filter query results available at List Endpoints.
    • fields is an comma-separated string which contains the fields to project.
  • Create, Update and Delete controllers return the object in consideration after performing the operation.

EmbedControllerSet


If a schema has an embedded document, it will need special CRUD updates to access embedded documents from the URL and no other special methods.

 Note : If Nested Schema Array is nested inside each other, ControllerSet adds EmbedControllerSet recursively so that even the most innermost Schema has CRUD updates.
Controllers URL Method Notes
embedListController /model/:id/embedName/ GET
embedCreateController /model/:id/embedName/ POST
embedDetailController /model/:id/embedName/:embedId GET
embedUpdateController /model/:id/embedName/:embedId POST
embedDeleteController /model/:id/embedName/:embedId DELETE
Minutiae
  • Each controller is bound with a EmbedDocument whose name is given by this.key .
  • Each controller is bound with a Joi Schema object referenced by this.schema .
  • The instance for the Controller is provided by req.instance .
  • The mongooseArray object is accessed by req.instance[this.key] .

Example:

For the following nested models ,

export const NutritionSchema = Joi.object({
    name: Joi.string().required(),
    calorie: Joi.number().required()

})
export const IngredientSchema = Joi.object({
    name: Joi.string().max(100).required(),
    nutrients: Joi.array().items(NutritionSchema)
})

export const StepSchema = Joi.object({
 ingredients: Joi.array().items(IngredientSchema),
 stepNo: Joi.number().required().min(1).max(100),
 description : Joi.string().max(1000),

})

the following endpoints will be automatically generated :

Endpoints Methods Purposes
/step/ GET, POST List , Creation of Steps
/step/:id GET, PUT, DELETE Detail, Update , Delete of Steps
/step/:id/ingredients GET, POST List , Creation of Ingredients nested in a Step
/step/:id/ingredients/:ingredientId GET, PUT, DELETE Detail , Update, Delete of an Ingredient nested in a Step
/step/:id/ingredients/:ingredientId/nutrients GET, POST List , Creation of nutrients of an ingredient nested in a Step
/step/:id/ingredients/:ingredientId/nutrients/:nutrientsId GET, PUT, DELETE Detail , Update, Delete of a nutrient nested in an Ingredient nested in a Step

About

A REST API generator based on express for SugrFree - AI based diet system.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published