Welcome and get ready to link your front-end to your back end using Sinatra with Active Record. In this blog I will be showing you how to use Sinatra and Active Record to access your Ruby based models and present this data to your front-end React application. To get started lets take a look at a simple GET request from our front-end server below:
fetch("http://localhost:9292/animals")
.then(res => res.json())
.then(data => {
setAnimals(data);
},)
Now this bit of code shows that we are asking our server for data using a GET request. After this data is received we are turning that data which is JSON into data that can be used by our front-end and then updating our state to that data.
How does this look on the back-end? How is this request being processed after it is sent to the server? Lets take a look at the code:
class ApplicationController < Sinatra::Base
get '/games' do
end
end
This code above is the beginning of the server's job to receive the GET request. Now we must obtain all of the data needed by the request:
get '/animals' do
animals = Animal.all
end
This is where Active Record comes in handy. Using the method .all we can obtain all of the animals from the database. We are not done yet though we need to convert these animals to JSON. Luckily Active Record has a method for this as well .to_json
.
get '/animals' do
animals = Animal.all
animals.to_json
end
Yay! Now our React application can make a GET request for the "/animals" database; but wait we also want to set the content type headers for all of the responses. We do this by adding the following line: set :default_content_type, 'application/json'
class ApplicationController < Sinatra::Base
set :default_content_type, 'application/json'
get '/animals' do
animals = Animal.all
animals.to_json(include: :shelter)
end
end
Now our ApplicationController inherits from the Sinatra::Base class and can send a response to a GET request with a default json content type for the headers.
We can modify this request using Active Record methods to control the data the server sends back as a response to the request.
We can only send the first 10 entries in our database and we can make sure to include the shelter that the animal has a relationship with:
get '/animals' do
animals = Animal.all.limit(10)
animals.to_json(include: :shelter)
end
Methods like this help us as developers to use our back-end to control server responses.
So we have successfully made a GET request and set up our server's response, but our application is going to require more than just readable data from our database. We would also like to create, update, and remove from our database. These options are known to developers as CRUD (create, read, update, delete) or our POST, GET, PATCH, and DELETE requests.
Lets start with our POST request using similar looking code. Here is our request from our React application:
fetch("http://localhost:9292/animals", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(formData)
})
.then(res => res.json())
.then(newAnimal => onAddAnimal(newAnimal))
The beginning of our code is going to start off with similar syntax to our GET response but will be post
instead.
class ApplicationController < Sinatra::Base
set :default_content_type, 'application/json'
post '/animals' do
end
end
Unlike our GET response we need to use an Active Record method .create
to create an animal using the body of the request sent by the react application and add it to the database sending a response from the server with the added animal and its new id generated by the database. How does this look?
post '/animals' do
animal = Animal.create(
name: params[:name],
species: params[:species],
breed: params[:breed],
sex: params[:sex],
age: params[:age],
image: params[:image],
shelter_id: params[:shelter_id]
)
animal.to_json
end
We added to our database!
This allows our react application to make a request sending over data to the server. The server then takes this data and using Sinatra and the params hash creates a new animal. Our create part of CRUD is complete. Our next two requests are going to be our update or PATCH request and our DELETE request. Here is the final result of all four requests in our controller file.
class ApplicationController < Sinatra::Base
set :default_content_type, 'application/json'
# Animal Controllers Full CRUD
get '/animals' do
animals = Animal.all
animals.to_json(include: :shelter)
end
get '/animals/:id' do
animal = Animal.find(params[:id])
animal.to_json(include: :shelter)
end
delete '/animals/:id' do
animal = Animal.find(params[:id])
animal.destroy
animal.to_json
end
post '/animals' do
animal = Animal.create(
name: params[:name],
species: params[:species],
breed: params[:breed],
sex: params[:sex],
age: params[:age],
image: params[:image],
shelter_id: params[:shelter_id]
)
animal.to_json
end
patch '/animals/:id' do
animal = Animal.find(params[:id])
animal.update(
name: params[:name],
species: params[:species],
breed: params[:breed],
sex: params[:sex],
age: params[:age],
image: params[:image],
shelter_id: params[:shelter_id]
)
animal.to_json
end
end
Thank you for going on this CRUD journey with me. Tune in next time!
Top comments (0)