Your First Fullstack App!
Last updated
Last updated
Up until now, the app structure has looked like this:
The model is the layer of the application that directly manipulates the data. It provides methods that the controllers can use to execute those changes whenever the frontend makes the appropriate request.
Currently, the model uses an in-memory array to store data. The issue is that the data is not persistent — each time we restart the server, all data created during that "session" is lost.
Now that we have a database and can connect to it using Knex, we can refactor our model to use that database and have our data persist.
create a database called fellows_tracker_f23
Create the table structure
cd
into server/
npm i pg knex
npx knex init
to create knexfile.js
in the root of the server/
directory
modify the file to use pg
and the fellow-tracker-f23
database with a valid username and password
create a knex.js
file in the model/
directory
make sure the import statement for knexfile.js
is accurate
Refactor Fellow.js
!
Import knex
into the Fellow
model
Remove the import of the getId
function
Remove the Fellow.#all
array
Remove the constructor
entirely and create a static async create
method (we'll use the constructor for another purpose)
All functions need to be async
to use await knex.raw()
Every function needs to return something (use RETURNING *
)
Create should return the new fellow
Get ALL should return an array of all fellows
Get One should return a single fellow object (the first object in the rows
array)
Update should return the updated fellow object
Delete should return the deleted fellow object
Refactor fellowControllers.js
to use the new model methods and to await
everything
Create a posts table that references the fellows table
Create a Post
model with methods:
create(content, fellowId)
list() (not really used other than for testing)
findById(id) (not really used other than for testing)
findPostsByFellowId(fellowId)
delete(id)
deleteAllPostsForFellow(fellowId)
make the postControllers
define endpoints in index.js
test with postman
add frontend components + fetching on the FellowDetails page
components:
list of posts with delete buttons
form for adding a new post
event handlers / fetching:
useEffect now also fetches fellow posts -> GET /api/fellows/:fellowId/posts
list item delete button on click -> DELETE /api/posts/:id
new post form on submit -> POST /api/fellows/:fellowId/posts/:id
when deleting a fellow, we need to delete posts first
Create an "adapter" file for fetching fellows and posts