Skip to content

Shib00/Sambhalo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

66 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SAMBHALO

Sambhalo is an entry-management software catering to the requirements by Innovaccer's summergeeks program.
Read the problem statement here: Link

Table of Contents

  1. Setup and Installation
  2. Tech Stack Used
  3. Explanation
    1. Folder Structure and useful functions
    2. DFD Diagram
  4. Working with the app
  5. Exception handling done
  6. Contact Me

Installation

NOTE: These installation instructions assume that you have nodejs, npm and mongodb installed on your system.
If not head over to the links below:

  1. nodejs
  2. npm
  3. mongoDB

Please do make sure that these softwares are installed on your system otherwise the app wont work. Be sure to check out stack overflow if facing any errors.

Installation Steps:

  1. clone or download this repository.

  2. using your favourite file editor open the file called sendEmail.js inside the helper folder and wherever you see 'Enter email here' and 'Enter password here' just put your email id and password (dont worry it's safe :)) with which emails are to be sent. If using any other service than gmail make sure to change the 'service' from 'gmail' to whatever service you are using. List of supported services. Make sure that the account you use provides access to less secure sites.

  3. now open sendFbEmail.js and repeat step 3.

  4. open sendText.js and enter your twilio account-SID,authentication token and phone number wherever required.Here's how to work with twilio. Also this has to be noted that twilio works well with only registered phone numbers and there are some government restrictions regarding sending text in India..

  5. open app.js and uncomment 'sendEmail' and 'sendText' and 'sendFbEmail' functions if you wish to send emails or text. These can be found :

    1. in app.post("\") route
    2. in app.post("\newHost") route
    3. in app.post("\meeting") route
    4. in app.post("\verify") route
    5. in app.post("\feedBack") route
  6. Optional: uncomment seedDB() function in "app.js" which removes all existing data from the database and fills in some dummy hosts.

  7. run sudo service mongod start or any other command you use to start the mongo server.

    1. you can check if the server is running using sudo service mongod status.
  8. get into this directory (via terminal or your own native OS method).

  9. run npm install (in another terminal not the mongo one) to install all the required dependencies.

    1. after this step you should see a node_modules folder if not something went wrong, check your steps.
  10. run node app.js (while being in the same folder directory) and you should be good to go.

    1. if you see error like Error: Cannot find module 'express' just do npm install express in the same directory(in some cases express needs to be installed locally).
  11. if everything went fine you should be able to see the website hosted at localhost:3000 :)

Tech Stack Used

Database (MongoDB using Mongoose)

1.Mongo is flexible and if there are slight change in requirements, relational DBs may waste a lot of space. 1. Example: if only one of phone and email are required instead of both, there may be lot of null values in a relational database. 2. Example 2: like instead of a single address there are multiple addresses associated with a office (usually the case with many offices) and hence

2.Mongo leverages a JSON-style storage format known as binary JSON, or BSON, to achieve high throughput. It integrates well with node and express.

  1. Mongoose provides with the advantage of abstraction over pure mongo, using Schemas, it also implements validations to Schemas making them easier to work with also there are many plugins available.

Frontend (Vanilla JS)

  1. Because application was small and required less dynamic rendering and using frameworks like React or Angular for such a small application seemed redundant.

  2. Vanilla JS can be easily understood by most of the web developers.

  3. Use of ejs (EJS is a simple templating language that generates HTML markup with plain JavaScript. ... It's just plain JavaScript) and made handling data in and out of html pages much easy.

  4. Made use of bootstrap for easy styling and make website mobile responsive.

Backend (nodeJs and express)

  1. Node package manager(npm) has lot of available functionalities making it easy to implement facilities like email and phone messaging.

  2. Language is similar to javascript and it is again easy to understand for most web developers

  3. Allows handling simultaneous requests with ease.

  4. Express is a framework built on nodeJs and makes dealing with routes easier and also synchronizes well with ejs.

Explanation (Folder structure and Data flow diagram)

Folder Structure

alt text

  1. helper - contains helper functions like sendEmail, sendFbEmail, sendText, tConvert (to convert time), genOTP (to generate a OTP).
  2. models - contains basic schemas of models used i.e. visitor, host, feedaback.
  3. node_modules - contains all the basic dependencies required to run app.
  4. public - contains all the stylesheets used
  5. views - contains all the ejs files that need to be rendered
    1. partials- contains the header and footer ejs files that need to be included in every document.

Data flow diagram

DFD-0

alt text

DFD-1

alt text


Working with the app

  1. Enter your details and select your host

  2. To CheckOut you need to verify your OTP

  3. Feedback form page (fill the feedback form or press the home button)

  4. There is also an option to add new host

Screenshots

  1. Text messages : first one is when visitor checks in and second one when visitor checks out. alt text

  2. Emails messages : first one is when visitor checks in and second one when visitor checks out and third one is the OTP email. alt text

  3. Feedback Email : email recieved when visitor fills feedback form.

Exception Handling

Here's a list of exception handling done in the app:

  1. if a visitor is currently checked in another user with same email or password cannot check in.
  2. email and contact of hosts should be unique else they will not be added and also need to be verified by a OTP.
  3. visitor cannot proceed to check-in without filling all the fields of the form.
  4. one visitor cannot check-out any other visitor due to OTP recieved which also ensures that visitor provided the correct email id while checking in else he will not be able to check out.
  5. one can only access feedback page while checking out.
  6. in feedback form atleast the table should be filled otherwise it will again redirect back to the feedback page.

Contact Me

You can contact me at [email protected] or [email protected]

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published