A Web App like Ruby on Rails with Koa2, Webpack and Postgres.
This project is like Ruby on Rails Project:
- MVC
- Database (postgres), ORM(sequelize)
- migration(sequelize-cli)
- assets compile(webpack)
- Session with redis
- Password with bcrypt
- Testing (mocha)
- Lint (eslint)
- middleware
- console
- server side render with react
- node ^4.0.0
- npm ^3.0.0
install nodejs
install redis and postgres
create postgres database:
for development { database: 'kails_dev', owner: 'kails_dev', password: 'kails_dev' }
for test { database: 'kails_test', owner: 'kails_tester', password: 'kails_tester' }
clone this project
- koa2
- koa-bodyparser
- koa-router
- koa-generic-session
- koa-logger
- Postgres
- Redis
- Pug
- Sequelize
- Nodemon
- Mocha
- Babel
- [ES6]
- ESLint
- React
├── app
│ ├── assets
│ │ ├── images
│ │ ├── javascripts
│ │ └── stylesheets
│ ├── controllers
│ ├── helpers
│ ├── models
│ ├── routes
│ ├── services
│ ├── views
│ └── index.js
├── config
│ ├── config.js
│ └── webpack
│ ├── base.js
│ ├── development.js
│ └── production.js
├── db
│ └── migrations
├── index.js
├── package.json
├── public
└── test
npm install
npm run db:migrate
NODE_ENV=test npm run db:migrate
# run for development, it start app and webpack dev server
npm run start
# run the app
npm run app
# run the lint
npm run lint
# run test
npm run test
# deploy
npm run assets_compile
NODE_ENV=production npm run db:migrate
npm run pm2
$ npm run console
models.User.create({ name: 'test', email: '[email protected]', password: '12345678', passwordConfirmation: '12345678' }).then(function(user) { console.log(user) })
models.User.findOne({ where: { email: '[email protected]' } }).then(function(user) { console.log(user) })
$ npm run start
# Visit `http://localhost:3000/