express-demo
Version:
Express app demo. With social login, i18n, unit test, create doc, minify files, check format and syntax.
154 lines (118 loc) • 5.5 kB
Markdown
[](https://express-demo-alditis.herokuapp.com)
[Express](http://expressjs.com/) app example.
#### Motivation
When I began an project personal, I had very problems for integrate diferents modules
for login, i18n, send email, ORM, test unit, enviroment variables, generate documentation,
minified files, check code format and syntax, etc.
Finally I could it solutions reviewing documentation officials, [GitHub](https://github.com),
[StackOverflow](https://stackoverflow.com) and differents web site.
I hope that this example or part of it to be util for the community.
Sure that this example could improve and to be complete with more functionality.
Are welcome suggestions, ideas, bugs identified, and colaborations. Greetings!
### [Live demo](https://express-demo-alditis.herokuapp.com)
#### Included modules
* [bycript](https://github.com/kelektiv/node.bcrypt.js): Hash password.
* [ejs](https://github.com/mde/ejs): View engine.
* [emailjs](https://github.com/eleith/emailjs): Send emails.
* [express-i18n](https://github.com/koalazak/i18n-express) and [geolang-express](https://github.com/koalazak/geolang-express): For support i18n. Languages includes: ES and EN.
* [mysql2](https://github.com/sidorares/node-mysql2): Driver for MySQL.
* [passport](https://github.com/jaredhanson/passport): Login and Signup with providers internal and externals (Google, Facebook and Twitter).
* [req-flash](https://github.com/maximilianschmitt/req-flash): Flash messages.
* [sequelize](https://github.com/sequelize/sequelize): ORM.
* [socket.io](https://github.com/socketio/socket.io): Chat and realtime options.
* [validate.js](https://github.com/ansman/validate.js): Vaidate data input.
* [winston](https://github.com/winstonjs/winston): Generate log.
* crypto: Module Node.js for generate tokens.
#### Modules dev
* [dotenv](https://github.com/motdotla/dotenv) and [dotenv-safe](https://github.com/rolodato/dotenv-safe): Load .env file.
* [eslint](https://github.com/eslint/eslint): Verify code format and syntax.
* [grunt-contrib-cssmin](https://github.com/gruntjs/grunt-contrib-cssmin): Minimize css files.
* [grunt](https://github.com/gruntjs/grunt): Automatization of task.
* [jsdoc](https://github.com/jsdoc3/jsdoc): Generate documentation.
* [mocha](https://github.com/mochajs/mocha): Test unit.
* [supertest](https://github.com/visionmedia/supertest) and [supertest-session](https://github.com/rjz/supertest-session): Complement for unit test.
* [uglify-es](https://github.com/mishoo/UglifyJS2/tree/harmony): Minimize js files.
## Requeriments
### Enviroment
* [Node.js](https://nodejs.org/)
* [Express](http://expressjs.com/)
* [MySQL](https://www.mysql.com/)
### Installation
```bash
$ npm install express-demo
```
### Configuration
Create a file `.env` based on `.env.example` and add settings:
* Port.
* Name app.
* Database.
* Session.
* Bcrypt salt.
* Email.
* Login social (Optional).
### Quick Start
The scripts is configured in the file `package.json`
```bash
"scripts": {
"start": "node ./bin/www",
"start-dev": "NODE_ENV=development node ./bin/www",
"test": "NODE_ENV=development mocha ./test/*.js"
},
```
For to start the server for development enviroment:
```bash
$ npm run start-dev
```
And to run the test suite on development enviroment:
**Note:** First must edit the file `test/util/data-test.js` putting your test data.
```bash
$ npm test
```
#### Run Grunt local (Default)
`node_modules/.bin/grunt`
#### Run Grunt global (Optional)
First install globaly:
```bash
sudo npm i -g grunt-cli
```
Then to call Grunt is `grunt` directly.
**Note:** This too can considered for: `sequelize-cli`
### Features
* Login on form.
* Login with Google, Facebook and Twitter. (Optional)
* Signup.
* Forgot password.
* i18n.
### Features dev
**Note:** Considering Grunt global for simplicity.
* Unit test.
* Generate documentation: `grunt jsdoc`. Documentation generated in `doc` folder.
* Check format and syntax code: `grunt exec:eslint`. If exists erros, look `log/eslint.log` file
* Minimize `public/js/general.js` file: `grunt exec:minGeneral`. File generated: `public/js/general.min.js`
* Minimize `public/css/main.css` file: `grunt cssmin`. File generated: `public/css/main.min.js`
Or only `grunt` for run all tasks. Look `Gruntfile.js` for more details.
### Social login (Optional)
Create an app on Google, Facebook or Twitter and set in the file `.env`
For example for Facebook:
```bash
FB_ID=YourFacebookAppID
FB_SECRET=YourFacebookAppSecret
FB_SCOPE=email
FB_CALLBACK=http://localhost:3000/auth/facebook/callback
```
For reduce code, others callbacks follow same patter. For example:
```bash
FB_CALLBACK=http://localhost:3000/auth/facebook/callback
GG_CALLBACK=http://localhost:3000/auth/google/callback
TW_CALLBACK=http://localhost:3000/auth/twitter/callback
```
### People
Author: [alditis](https://github.com/alditis)
If this project help you some and you want support me, you can give me a donate. Thanks!
[](https://liberapay.com/alditis/donate)
[](https://www.paypal.me/alditis)
[](https://blockchain.info/address/1C1tt4zXSRtjGs8p4hcmAoqY6BFDRYeuBG)
### License
[MIT](LICENSE)