Skip to content

bkoohi/nodejs-MEAN-stack

 
 

Repository files navigation

Modern Web Application using MEAN stack

This is a basic boilerplate for the MEAN stack (MongoDB, Express, AngularJS and Node.js) on IBM Cloud.

This application uses Databases for MongoDB and Code Engine on IBM Cloud.

The code and detailed steps are discussed in the IBM Cloud solution tutorial titled Modern web application using MEAN stack.

Features

  • MVC project structure
  • Create, edit and delete user accounts
  • Authentication with username/password
  • Protected routes that can only be accessed by authenticated users
  • Bootstrap CSS framework
  • HTTPS built-in if deployed to IBM Cloud
  • Mongoose for MongoDB interactions.
  • PassportJS for authentication, with over 300 authentication strategies to pick from.

Application Requirements

Files & Folders

File Description
.env.example Set custom environment variables for your application. This is the proper way to store credentials and other sensitive values.
server.js Main server file that the Node.js runtime uses. It contains all the server logic.
/server Folder for files used by the Node.js server
/server/models/user.model.js Model for storing users in MongoDB
/public Folder for files delivered to users, such as html and css files
/public/js/app.js Angular application for manipulating and rendering data in browser

Application

  • MongoDB stores user account information and persists sessions (so that a server crash does not log out all users.)
  • Express functions Node.js middleware to handle all HTTP requests and routing.
  • Angular handles HTML templating and data manipulation.
  • Node.js is the runtime for the application.

There is also generous commenting throughout the application which helps explain critical parts of the application.

Running locally

  1. Clone or download this repo onto your machine.
  2. Install application requirements if not done so already.
  3. Open application directory in your terminal and run npm install
  4. If you don't have an account, create a free one here.
  5. Login to your account via the command line: ibmcloud login
  6. Target your desired region ibmcloud target -r ca-tor
  7. Create the instance of Databases for MongoDB on IBM Cloud: ibmcloud resource service-instance-create mean-starter-mongodb databases-for-mongodb standard ca-tor
  8. Copy .env.example file to .env. Edir .env to fill it the required values. You can run ibmcloud resource service-key-create mean-starter-mongodb-key --instance-name mean-starter-mongodb to obtain the MONGODB_URL and CERTIFICATE_BASE64. Choose your own SESSION_SECRET.
  9. Run node server.js to start your app
  10. Open a browser to the link provided in the terminal prompt to view your app

Note that the code assumes a secured connection to MongoDB using SSL and a certificate. This way you can run the app locally but connect to IBM Cloud Databases for MongoDB.

An alternative way of running locally is using the provided Dockerfile.

  • Install docker on your machine and build the docker image
     docker build . -t mean-stack:v1.0.0
    
  • Run the app locally
     docker run -p 8080:8080 --env-file .env -ti mean-stack:v1.0.0 
    

Contribute

Please create a pull request with your desired changes.

Troubleshooting

The primary source of debugging information for your app running in the cloud are the logs. To see them, use the Code Engine web interface.

For more detailed information on troubleshooting your application, see the Troubleshooting apps section in the documentation.

License

See LICENSE.MD for license information.

About

Solution tutorial: Modern Web Application using MEAN stack on IBM Cloud

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 62.6%
  • HTML 34.9%
  • Dockerfile 1.1%
  • Shell 1.1%
  • CSS 0.3%