Before you continue to final projects we have to make sure that you can meaningfully contribute to a technical project.
This means that we need to be sure that you can create a Full Stack app.
In this project you will be building a project that fulfills the following User Stories
- As a user, I want to be able to view a list of all YouTube videos posted on the site
- As a user, I want to be able to post videos that I like from YouTube to my website.
- As a user, I want to be able to delete videos from the website that I no longer like.
- As a user, I want to be able to watch the videos embedded in the website.
- As a user, I want to be able to "Up Vote" a video if I like it.
- As a user, I want to be able to "Down Vote" a video if I dislike.
You don't need to worry about storing the video content itself - we'll rely on YouTube for this.
This project is split into several levels that you should complete each week of the three week project.
You can find each of the levels split into separate files, linked below.
Note: Some of the levels are optional which means that you will build a working project without them. However, to make something really impressive you will need to complete as much as you can.
- Level 100
- A core version of the React front end of the app
- Level 199 (Optional)
- Stretch goals for the front end if you have time
- Level 200
- A core version of the Node + Express back end of the app
- Level 250
- Connect your Front End and Back End together
- Level 299 (Optional)
- Stretch goals for the back end if you have time
- Level 300
- Integrate the back end with a database
- Level 399 (Optional)
- Stretch goals for the database if you have time
- Level 999 (Optional)
- More optional goals for if you have time
Here is an example solution of the Front End:
Note: You can design the website to look however you like.
Here is an example solution for the Back End:
https://video-rec.herokuapp.com
You are welcome to use Bootstrap or any other design framework to help you build this app.
Fork this repository and then clone it to your computer.
Progress to Level 100 when you are ready.
name: Node.js Deployment
on: push: branches: - main
jobs: deploy: runs-on: ubuntu-latest
steps:
- name: Update and Upgrade EC2 inst
run: |
sudo apt update
sudo apt upgrade -y
- name: Checkout Repository
uses: actions/checkout@v2
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 12
- name: Install Dependencies
run: |
npm install
- name: rsync deployments
uses: burnett01/rsync-deployments@6.0.0
with:
switches: -avzr --exclude=node_modules --delete
path: ./server/
remote_path: ~/.video-app/
remote_host: ${{ secrets.AWS_HOST }}
remote_port: 22
remote_user: ${{ secrets.USERNAME }}
remote_key: ${{ secrets.SSH_PRIVATE_KEY }}