client/
build/
node_modules/
public/
src/
package.json
server/
bin/
configs/
models/
public/
routes/
package.json
.gitignore
package.json
README.md
You should have a server/.env
file, with for example the following values:
CLOUDINARY_CLOUD_NAME=......
CLOUDINARY_API_KEY=......
CLOUDINARY_API_SECRET=......
JWT_SECRET=......
MONGODB_URI=......
To download the boilerplate and link it with your GitHub project
(replace <my-project>
and <https://github.com/user/my-project.git>
by what you want, without <
and >
).
# Clone the project with only the last commit and save it in the folder <my-project>
$ git clone --depth=1 https://github.com/mc100s/mern-boilerplate.git <my-project>
$ cd <my-project>
$ rm -rf .git
$ git init
# Set your GitHub repository as the "origin" remote repository
$ git remote add origin <https://github.com/user/my-project.git>
To install all the packages
$ npm install
# OR
$ (cd server && npm install)
$ (cd client && npm install)
To install a package for the server
$ cd server
$ npm install --save axios
To install a package for the client
$ cd client
$ npm install --save axios
To run the server and the client
# Open a first terminal
$ npm run dev:server
# Run the server on http://localhost:3030/
# Open a second terminal
$ npm run dev:client
# Run the client on http://localhost:3000/
So now you can go to
- http://localhost:3030/api/: A simple API call
- http://localhost:3030/: The website based on client/build (that you can update with
$ (cd client && npm run build)
) - http://localhost:3000/: The last version of your React application that is calling your API with the base url "http://localhost:3030/api/"
router.post('/signup')
: Route to create a new userrouter.post('/login')
: Route to send the user JWTrouter.get('/secret')
: Route where the user need to be authenticated
router.get('/')
: Route to get all usersrouter.post('/first-user/pictures')
: Route to add a picture on one user with Cloudinary
router.get('/')
: Route to get all countriesrouter.get('/static-sample')
: Route to get a static sample of countriesrouter.post('/')
: Route to add a country
Create a project on Heroku.com. Here for the demo I named the project "my-ironhack-project".
Then, you need to link your Git project with Heroku.
# Replace "my-ironhack-project" by the name of your Heroku project
$ heroku git:remote -a my-ironhack-project
$ git push heroku master
Then you need to create a Mongo database online with MLab.
$ heroku addons:create mongolab:sandbox
You just need to push on heroku
(don't forget to commit before):
$ git push heroku master
If you want to execute something on the server, for example a seed, you can use heroku run
.
Example:
$ heroku run node server/bin/seeds/seeds.js
You can either go on the Heroku project page ("Overview" tab) or type the following commad:
$ heroku addons:open mongolab
$ heroku logs