Skip to content

learn-co-curriculum/json-server-template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JSON Server Template

Setup

Fork and clone this repo. Then install the dependencies by running:

npm install

Seeding Data

To set up your database, update the db/seeds.json file to contain an object with a key pointing to an array of data, like this:

{
  "toys": [
    {
      "id": 1,
      "name": "Woody",
      "image": "http://www.pngmart.com/files/3/Toy-Story-Woody-PNG-Photos.png",
      "likes": 8
    },
    {
      "id": 2,
      "name": "Buzz Lightyear",
      "image": "http://www.pngmart.com/files/6/Buzz-Lightyear-PNG-Transparent-Picture.png",
      "likes": 14
    }
  ]
}

Then, run npm run seed to copy data from the db/seeds.json file to the db/db.json file. json-server uses the db.json file to create your RESTful API, so make sure your db.json file is always up to date!

Any time you want to reset your database back to your original data, run npm run seed again. Doing this will overwrite all the data in your db.json file, so make sure you don't have any data in that file that you don't mind losing!

Running the Server Locally

To run your server in development mode, run:

npm run dev

While running in development mode, the server will re-load any time you make changes to the db.json file, so you can test our your seed data.

While your server is running, you can make requests to http://localhost:3000. Check it out in the browser to make sure your server works!

Deploying

Free services like Render make it simple to deploy your Node server. Render also works nicely with Rails, which you'll learn later in the program.

Sign Up for a Render Account

You can sign up for a free account at https://dashboard.render.com/register. We recommend that you sign up using GitHub as that will make it a little easier for you to connect Render to your GitHub account. The instructions below assume you've done that.

Once you've completed the signup process, you will be taken to the Render dashboard.

In order to connect Render to your GitHub account, you'll need to click the "New Web Service" button in the "Web Services" box. On the next page, you will see a GitHub heading on the right side and below that a link labeled "Configure account". (If you didn't sign up using GitHub, it will say "Connect account" instead.) Click that link; a modal will appear asking you for permission to install Render on your GitHub account. Click "Install." You should then be taken back to the "Create a New Web Service" page, which should now show a list of your GitHub repos.

Deploy the Server

Find the GitHub repo for your json server in the list and click Connect. Give the web service a name and make sure the Environment is set to Node. Everything else can be left as is. Scroll down to the bottom of the page and click "Create Web Service." The build process will begin automatically.

The URL for your deployed server is shown in the upper left corner of the page, e.g., https://my-server.onrender.com. Once the build is complete, you will be able to make fetch requests to that URL.

Making Updates

Since Render deployment integrates with your GitHub repo, you can easily deploy changes to your database. First, commit and push your code up to GitHub:

git add .
git commit -m "Updated database"
git push

Then launch the build process by going to the page for your server on the Render dashboard, clicking the "Manual Deploy" button in the upper right corner of the page, and selecting "Deploy latest commit."

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •