This challenge allows you to practice the concepts and techniques learned over the past Sprint and apply them in a concrete project.
This Sprint explored Adding Data Persistence to Web APIs and you were taught the following modules: Introduction to Relational Databases and SQL, Inserting and Modifying Data, Querying Data; Migrations and Seeding and Introduction to Data Modeling.
In your challenge for this Sprint, you will demonstrate proficiency by creating an API that persist data to SQLite3.
Read these instructions carefully. Understand exactly what is expected before starting this Sprint Challenge.
This is an individual assessment. All work must be your own. Your challenge score is a measure of your ability to work independently using the material covered through this sprint. You need to demonstrate proficiency in the concepts and objectives introduced and practiced in preceding days.
You are not allowed to collaborate during the Sprint Challenge. However, you are encouraged to follow the twenty-minute rule and seek support from your PM and Instructor in your cohort help channel on Slack. Your work reflects your proficiency Adding Data Persistence to Web APIs and your command of the concepts and techniques in the Introduction to Relational Databases and SQL, Inserting and Modifying Data, Querying Data; Migrations and Seeding and Introduction to Data Modeling modules.
You have three hours to complete this challenge. Plan your time accordingly.
Commit your code regularly and meaningfully. This helps both you (in case you ever need to return to old code for any number of reasons and your project manager.
In this challenge, you design and build an application for managing Projects
and Actions
in the spirit of David Allen's Getting Things Done (GTD) methodology.
Use Node.js, Express.js and Knex to build a RESTful API for a Project Tracker
application that persists data to a SQLite database.
This will be akin to the Web API that you built in the last sprint, only this time, you'll be writing the persistence layer.
Demonstrate your understanding of this week's concepts by answering the following free-form questions. Edit this document to include your answers after each question. Make sure to leave a blank line above and below your answer so it is clear and easy to read by your project manager.
- Explain the difference between
Relational Databases
andSQL
. ---A Relational Database is a data management system that holds data in rows calledrecords
and columns calledfields
---SQL is a query language used to interact with Relational Database Management Systems. - Why do tables need a
primary key
? ---Prinary Keys
are unique identifiers on database tables used to refer to and relate with the table. - What is the name given to a table column that references the primary key on another table.
---A table column that references another tables primary key is called a
foreign key
- What do we need in order to have a many to many relationship between two tables.
---To perform a many to many relationship you need a
Normailzed database
with intermediary tables.
Follow these steps for starting your project.
- Create a forked copy of this project.
- Add your project manager as collaborator on Github.
- Clone your OWN version of the repository (Not Lambda's by mistake!).
- Create a new branch: git checkout -b
<firstName-lastName>
. - Implement the project on your newly created
<firstName-lastName>
branch, committing changes regularly. - Push commits: git push origin
<firstName-lastName>
.
Follow these steps for completing your project.
- Submit a Pull-Request to merge
<firstName-lastName>
Branch into master (student's Repository). Please don't merge your own pull request - Add your project manager as a reviewer on the pull-request
- Your project manager will count the project as complete by merging the branch back into master.
NOTE There is no boilerplate for you for this project. You will need to take the steps necessary for creating this project from scratch. Start by initializing your project with a package.json
file and go from there.
- A
project
can contain multiple actions and has:- a unique Id.
- a name.
- a description.
- a flag that indicates if the project is complete or not.
- An
action
belongs to only one project. An action has:- a unique id.
- a description of what needs to be done.
- a notes column to add additional information.
- a flag that indicates if the action has been completed.
Feel free to name the tables and fields anything you want. Add relationships as you see fit.
-
Build the database and tables using knex migrations. Seeding is not needed.
-
Build the API with the following endpoints:
-
POST for adding projects.
-
POST for adding actions.
-
GET for retrieving a
project
by itsid
that returns an object with the following structure:{ id: 1, name: 'project name here', description: 'the project description', completed: false, // or true, the database will return 1 for true and 0 for false actions: [ { id: 1, description: 'action description', notes: 'the action notes', completed: false // or true }, { id: 7, description: 'another action description', notes: 'the action notes', completed: false // or true } ] }
-
This section is optional and not counted towards MVP. Start working on it after you're done with the main assignment.
Add the remaining CRUD operations for projects and actions.
Use knex
to add data seeding scripts for projects and actions.
Add support for the concept of contexts
. A context is something like at home, at work or at computer. The idea is that some actions require one or more contexts
in order to be worked on. For example, the action of file income taxes may require that you are at home, at computer and online so if you are at work and look at the list of pending actions you could do in your current context, filing your taxes will not be one of them.
A context
can be applied to more than one action
. An action can be tied to more than one context, like in the example above.
When retrieving an action
by id, add a property that lists all the contexts
related to that action.
Remember to run npm init -y
to generate a package.json before adding your dependencies.
Good luck and have fun!