Node/Express, MongoDB, ReactJS, and Passport Authentication boilerplate for anyone wanting to jump right into making extremely scalable projects with the power of Javascript!
- Chai/Mocha - Chai is a BDD / TDD assertion library for node and the browser that can be delightfully paired with any javascript testing framework.
- Webpack/Babel - Webpack takes modules with dependencies and generates static assets representing those modules.
- Sass - Sass is the most mature, stable, and powerful professional grade CSS extension language in the world.
- ReactTooltip - ReactTooltip is the most versitile easy tooltip component for React. Read more about it here.
- Bootstrap v4 - Bootstrap is the most popular HTML, CSS, and JS framework in the world for building responsive, mobile-first projects on the web. It also speeds up development greatly.
- Font Awesome - Font Awesome gives you scalable vector icons that can instantly be customized — size, color, drop shadow, and anything that can be done with the power of CSS.
- Bootstrap-Social - Easy way to bring social icons and login styled buttons in an extremely lightweight stylesheet.
The aim of this project is to have an extremely scaleable solution for your next project with modularity at every point on the back and front. It should be extremely simple to add or remove features including authentication strategies; it should not require editing of the low level how to make it work! Files are small, understandable, and you won't find duplicate code.
Boilerplate/
/app
/auth
/controllers
/routes
/client
/app
/commonComponents
/scenes
/public
/views
/style
/resources
/js
/test
server.js
You will often find 'reducers' within packages similar to below:
app/routes/index.js
const apiRoutes = require('./api/apiIndex.js');
const publicRoutes = require('./public/publicIndex.js');
const errorMiddleware = require('./errorMiddleware.js');
module.exports = (app, db) => {
apiRoutes(app, db);
publicRoutes(app, db);
errorMiddleware(app, db);
};
Remember, files should have 1 specific focus and be organized!
Create your code with a clear heirarchy and package it for the future, not the present! You may even find within apiRoutes
, for example, you have multiple types of api requests for unrelated types of data. In this case, implement a 'reducer' similar to above and further comparmentalize your code!
See DEVELOPING.md
For contributing(see CONTRIBUTING.md):
(Fork/pull)
npm install
cp sample.env .env
(Branch, LEAVE MASTER CLEAN)
git clone https://github.com/JosephLivengood/Boilerplate.git (Or the version desired)
rm -r .git
git init
npm install
cp sample.env .env
- Database should look similar to
mongodb://[username]:[password]@12345.mlab.com:17109/boilerplate
- Ignore TEST_USER_ID for this step
- Obtain auth client id and secrets from atleast 1 service (GitHub recomended in acount settings)- for local development(w/ GitHub), the callback url is
http://localhost:8080/auth/github/callback
if running locally
- This webpacks the React files into public/js and compiles the Sass into css from client/style to public/style
Successful database connection
App listening on port 8080
Authenticate at http://localhost:8080/auth/github or by clicking the login button
- Take note of the returned user
id
(not_id
)
- TEST_USER_ID should be set equal to your
id
- this is used in unit/functional tests to simulate an authenticated user when testing pages requiring such
-
NPM start
will connect to the database and start the server.
- To execute all tests, run
NPM Tests
See DEVELOPING.md) for more in depth info on all dependancies in the repo:
Webpack compiles your .jsx es6 React.js files into .js browser-friendly cross-compatable files. Compilation/building occurs from client/app to public/js. This project sets you up to use multiple entry points. Each 'scene' in client/app/scenes should be a new entry point defined in webpack.config.js. Its name in the config will determine the name of the compiled file that will be used as an include in your html/jade file. See DEVELOPING.md).
- After editing a .sass file in client/style, be sure to run
npm run build-css
. Alternatively, runnpm run watch-css
if you want it to auto compile on save. - After editing a .jsx file in client/app, be sure to run
npm run build-react
. Alternatively, runnpm run watch-react
if you want it to auto build on save.
- Be sure to edit your authentication strategies on their respective websites to point the callback to your deployment url.
- Be sure to change
config.json
"app_url"
to your correct deployment root url. - Ensure tests pass before deploying and be sure to webpack any changes for production using
npm run build-react-prod
.
BSD 3-Clause License
Copyright (c) 2017, Joseph Livengood. All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.