Skip to content

Mir-SA/task-manager-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Task manager api

Setting up Database

This application uses MongoDB to store data, both in development and production environment

Local Database Configuration

To start a new database instance run the following command

{path-to-mongod-file} --dbpath={path-to-data-storage}
MongoDB/bin/mongod.exe --dbpath=/Users/Samir/MongoDB-data

The connection URL would be: mongodb://127.0.0.1:27017

Postman summary

  • Enviroment variables can be created to store data that is going to be used in all requests. This can be done by creating an environment (dev or prod) and then creating environment variables with key value pairs. Then variables can be used using the following syntax: `{{env_variable_name}}``

  • Authorization can be added to all requests in a collection, by setting the authotization type in the Authorization tab for each request (default value is to be inherited for parent). Therefore, the authorization token must be defined for the whole collection. This can be done by selecting the collection options and then selecting Edit. The same options should appear but when a change is made it applies to all the requests.

  • The authorization token can also be defined as an environment variable

  • Pre-requisite scripts could be defined to run Javascript code before the request is sent. The same happens for the Tests tab, however this code is ran after sending the request.

  • Sample script for defining an environment variable value

// Check if the request was succesfull (pm object - short for postman)
if (pm.response.code === 200) {
    // Set the environment variable
    pm.environment.set('authToken', pm.response.json().token)
}

Production Database configuration

  • MongoDB hosting service must be used, the Atlas service is the one used for this application. It is created by the MongoDB organization

  • An account must be created at this link

Process for setting up a new instance (cluster)

  1. Go to Clusters -> Create New Cluster
  2. Select cloud provider, region, cluster tier, additional settings and cluster name
  3. Once the instance is created, go to the Dashboard and click on CONNECT
  4. Set up connection security
    1. Configure secure IP's. In this case all IP's must be whitelisted because heroku will continously change the server IP. To do so, the IP must be 0.0.0.0/0.
    2. Create a database user
  5. Connect to the database using the connection string defined in the GUI. Atlas instance connection client is Compass (Robo3T is not supported)

Environment variables configuration in Heroku

  • Set environment variable
heroku config:set {key}={value}
  • View all environment variables
heroku config
  • Remove an environment variable
heroku config:unset {key}