Skip to content

Latest commit

 

History

History
237 lines (171 loc) · 7.78 KB

README.md

File metadata and controls

237 lines (171 loc) · 7.78 KB

Simple Web App Framework using Node.js, Express and MySQL

Getting Started

Follow the instructions below to start your server.

Create Configuration File

In root directory, create new file named config.js. Change the settings to your own need.

/* File: config.js */
module.exports = {
    app : {
        name: 'node-mysql',
        protocol: 'http',
        port: 8080,
        version: '1.0.0'
    },
    mysql: {
        host: 'localhost',
        port: 3306,
        user: '<database user>',
        password: '<password>',
        database: '<database name>'
    },
    morgan: {
        mode: 'dev'
    }
};

The app section define your app information, mysql for data source configuration, and morgan for logger. For morgan, there are 5 modes that you can use: combined, common, dev, short, and tiny. See morgan repository for further information.

Installing Dependencies

Open your command prompt (Node.js command prompt if you use Windows), cd to the root directory of your server and type the following command:

npm install

And to install web dependencies, type the following command:

bower install

Start Server

First, to make your development easy, it's recommended for you to install nodemon using npm.

npm install -g nodemon

After that, you can start the server using the following command:

nodemon app.js

Creating Your Apps

Know Inside

This framework use Express 4, and has been integrated to use Jade (for view files) and Passport (for authentication related process). It's also has been configured to properly serve resources with access_token query string. All connected to a MySQL database data source.

Directory Structure

There are 3 main directories that you can use. There are controllers, public, and views. The node_modules directory is used to save Node.js dependency, so don't mess with it. The libs directory contains logic to boot up the server and authenticate request.

controllers Directory

This directory contains all controllers that is used inside your server. Every directory name is also your controller name.

views Directory

This directory contains global views that you can use throughout the server. It contains layout, element and error pages that you can modify according to your needs.

public Directory

This is the public-exposed directory that contains all your static asset like images, JavaScript files, and stylesheet files.

Installing Web Dependencies

You can install web dependencies using Bower. All dependencies will be installed on components sub-directory inside public directory. Don't forget to add additional parameter --save to ensure that the new dependency will be persisted to bower.json file.

Controllers and Actions

This framework using Controller, and View to serve your apps. First, Controller will control the logic to interact with your data model and serve it to view that can be navigated to user.

To create new controller, you'll need to define a controller function and exports it.

function controller = function(args) {
    var actions = {};
    
    // Do something with the actions object.
    
    return actions;
};

module.exports = controller;

Every controller has action that each of it representing 1 or several urls. It also has a views folder that can be used to display a view.

Let's say you have url list below:

GET  /users/login
POST /users/login
POST /api/users/authenticate

Then, this can be represented using the following controller:

var controller = function(args) {
    var actions = {};
    
    actions.login = [
        {
            method  : 'get',
            path    : '/login',
            handler : function(req, res, next) {
                // Do something here.
            }
        },
        {
            method  : 'post',
            path    : '/login',
            handler : function(req, res, next) {
                // Do something here.
            }
        }
    ];
    
    actions.authenticate = {
        method  : 'post',
        prefix  : 'api',
        path    : 'authenticate',
        handler : function(req, res, next) {
            // Do something here.
        }
    };
    
    return actions;
};

module.exports = controller;

You can see that 1 action can be represented using an array, or an object. An action can contains several action objects or have exactly 1 action object. An action object should contain at least 3 attributes: method, path and handler. A complete list is shown below:

  • method that define HTTP method that you can use. Express support HTTP method like GET, POST and PUT for example.
  • path that define the path to access the action. The path later can be accessed by attaching its controller name before the path.
  • handler that define the function that will handle the request. It should contain a function that accept at least 2 arguments req and res, and can accept at most 3 arguments req, res, and next. This will be passed to Express to handle the rest.
  • before that define what should be called before calling the handler function. It should contain a function that has the same definition with handler function above.
  • prefix that define the prefix before the url is called.

Every controller is being called with one parameter named args that contains some important objects that can be used throughout your application. args contain several objects:

  • config that contain configuration object that you've defined first time.
  • connector that contain connection object to MySQL data source. You can execute query using it. It's a connection object that is created using mysql module when the server started.
var controller = function(args) {
    var db = args.connector;
    
    var actions = {};
    
    actions.name = 'a_controller';
    
    actions.someAction = 
    // GET /a_controller/an_action
    {
        method  : 'get',
        path    : 'an_action',
        handler : function(req, res, next) {
            // Let's say we want to get all posts from `posts` table.
            db.query('SELECT * FROM posts', function(err, rows, fields) [
                if (err) {
                    // Handle error.
                }
                else {
                    // Do something with the data.
                }
            });
        }
    };
    
    return actions;
};

module.exports = controller;
  • pages that contain common pages INTERNAL_SERVER_ERROR, FORBIDDEN, and NOT_FOUND page. If you want to display the errors, just use the this parameter.
var controller = function(args) {
    var pages = args.pages;
    
    var actions = {};
    
    actions.someAction = {
        method  : 'get',
        path    : '/anAction',
        handler : function(req, res, next) {
            if (/* Some error conditions */) {
                res.render(pages.INTERNAL_SERVER_ERROR, {
                    title: 'Error!'
                });
            }
            else {
                // Do something else.
            }
        }
    };
    
    return actions;
};

module.exports = controller;

Extending The Framework

This framework is just a simple framework that can make your work easier. To extend the framework, feel free to see how everything works. Actually, this is very simple. You can see how the logic works in boot.js file, and how the authentication when a request processed in auth.js file. Beside than that, you can see app.js file to see how the component initialized, and at the end, you can just modify and improve to make it your own framework.

Feedback

If you've any feedback, or encounter some errors, don't hesitate to put something in Issues Page.