This is a small boilerplate for:
- Express 4 (MVC)
- Google+ oAuth 2.0 (profile and emails) using PassportJS
- Redis (for sessions)
- Postgres (feel free to
npm install
other dialects)
-
git clone https://github.com/durango/express-4-boilerplate.git
-
npm install
-
Edit and rename config-example.json to config.json
-
Create the tables manually, dump/execute
models/structure.sql
, or add{force: true}
withinindex.js
ofsequelize.sync()
and run the application once (remember to remove it). -
Create an oAuth client ID for Google through their console. The recommended callback URL is
schema://your-domain.tld/api/auth/google/callback
-
node index.js
Controllers can do whatever they want except of what it exports
. The export has two formats:
Array:
module.exports = ['/mountpath', Router];
Object:
module.exports = {path: '/mountpath', controller: Router};
You just need to tell the boilerplate which path
you want to mount and return an express.Router()
instance.
In order to retrieve all of your models, simply type in:
var models = require('../models');
And all of the models will be exposed to you (along with the Sequelize
library and sequelize
instance).
Models are simply exported Sequelize objects. For more information, refer to Sequelize's import documentation.
Creates a new Express application and mounts server.js
' Express application.
This is where all of your server's configuration is stored along with any middleware that you want to add (e.g. passport
).
Routing gets mounted on top of /api
as the URL. The reason behind this is that NodeJS should handle server-side logic while something else should handle the client-side templating and scripts (it's up to you really depending on your project). I would recommend making some sort of build system for creating your templates and letting the browser take care of the client-side stuff.
Copyright (c) 2014, Daniel Durante [email protected]
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.