Skip to content

Latest commit

 

History

History
181 lines (129 loc) · 8.38 KB

README.md

File metadata and controls

181 lines (129 loc) · 8.38 KB

Voter

This application serves as an example for the information you must provide in your Start Up README.md file for each phase of your development. You only need to fill in the section for the deliverable when you submit that deliverable in Canvas. This allows the TA to know what should be graded.

The specification deliverable section defines what your application will do. The rest of the deliverable sections reference the rubric for the deliverable and tell where the functionality is in your application, or documents that you did not satisfy that part of the rubric.

Specification Deliverable

➡️ The following is an example of the required information for the Startup Specification deliverable

Elevator pitch

Have you ever endlessly debated with your friends about where to meet for lunch, or had your team bog down about an important decision that needs to be made. The Voting application makes it so a group of people can pull out their phones, clearly see the options, and pick their top three choices. As each user makes their choices the results are automatically tallied and displayed in realtime to all the other group members. Once everyone locks in their choices the group can move forward with confidence that the best option has been selected.

Design

Mock

Here is a sequence diagram that shows how to people would interact with the backend to vote.

sequenceDiagram
    actor Alice
    actor Juan
    actor Bud
    Alice->>Server: Bud + 1
    Server -->>Juan: Bud + 1
    Server -->>Bud: Bud + 1
    Juan->>Server: Alice + 1
    Server -->>Bud: Alice + 1
    Server -->>Alice: Alice + 1
Loading

Key features

  • Secure login over HTTPS
  • Ability to select the question to decide
  • Display of choices
  • Ability to select, and change, top three choices
  • Totals from all users displayed in realtime
  • Ability for a user to lock in their top three
  • Results are persistently stored
  • Ability for admin to create and delete questions

Technologies

I am going to use the required technologies in the following ways.

  • HTML - Uses correct HTML structure for application. Two HTML pages. One for login and one for voting. Hyperlinks to choice artifact.
  • CSS - Application styling that looks good on different screen sizes, uses good whitespace, color choice and contrast.
  • React - Provides login, choice display, applying votes, display other users votes, and use of React for routing and components.
  • Service - Backend service with endpoints for:
    • login
    • retrieving choices
    • submitting votes
    • retrieving vote status
  • DB/Login - Store users, choices, and votes in database. Register and login users. Credentials securely stored in database. Can't vote unless authenticated.
  • WebSocket - As each user votes, their votes are broadcast to all other users.

Deployment instructions

  1. Clone this repository to your development environment.

  2. Create a dbConfig.json file that contains the credentials to access your Mongo Database. This must be placed in the root of the project.

    {
      "hostname": "YourMongoDbAccount.xiu1cqz.mongodb.net",
      "userName": "YourMongoDbUsername",
      "password": "YourMongoDbPassword"
    }
  3. NPM install both the frontend and backend dependencies.

    npm install
    cd ui
    npm install
    cd ..
  4. Use the deploy.sh shell script to deploy Voter to an EC2 instance. You will need the PEM key in order to run the script.

    ./deploy.sh -k ~/keys/yourkeyhere.pem -h yourdomainnamehere.click
  5. Verify that the application is running on the domain.

    curl startup.cs260.click
  6. Optional: If you want to modify the candidates that are currently voted on then alter finalists.json. The format of the file is as follows:

    { "candidate": [{ "name": "Meg", "url": "https://game.com", "votes": 0, "id": "game" }] }

    You can update the candidates with the following endpoint call:

    curl -X PUT localhost:4000/api/candidate -H "Content-Type:application/json" --data '@finalists.json'

HTML deliverable

➡️ The following is an example of the required information for the Startup HTML deliverable

For this deliverable I built out the structure of my application using HTML.

  • HTML pages - Two HTML page that represent the ability to login and vote.
  • Links - The login page automatically links to the voter page. The voter page contains links for every voting choice.
  • Text - Each of the voting choices is represented by a textual description.
  • Images - I couldn't figure out how to include an image and so I didn't do this. 😔
  • DB/Login - Input box and submit button for login. The voting choices represent data pulled from the database.
  • WebSocket - The count of voting results represent the tally of realtime votes.

CSS deliverable

➡️ The following is an example of the required information for the Startup CSS deliverable

For this deliverable I properly styled the application into its final appearance.

  • Header, footer, and main content body
  • Navigation elements - I dropped the underlines and changed the color for anchor elements.
  • Responsive to window resizing - My app looks great on all window sizes and devices
  • Application elements - Used good contrast and whitespace
  • Application text content - Consistent fonts
  • Application images - Still don't have images and so no styling here. 😔

React deliverable

➡️ The following is an example of the required information for the Startup React deliverable

For this deliverable I used JavaScript and React so that the application completely works for a single user. I also added placeholders for future technology.

  • Bundled and transpiled - done!
  • Components - Login, voting list, vote are all components with mocks for login, WebSocket.
    • login - When you press enter or the login button it takes you to the voting page.
    • database - Displayed the voting counts. Currently this is stored and retrieved from local storage, but it will be replaced with the database data later.
    • WebSocket - I used the setInterval function to periodically increase a random vote count. This will be replaced with WebSocket messages later.
    • application logic - The highlight and ranking number change based up the user's selections.
  • Router - Routing between login and voting components.
  • Hooks - Vue uses class properties instead of UseState to track changes in vote state.

Service deliverable

➡️ The following is an example of the required information for the Startup Service deliverable

For this deliverable I added backend endpoints that receives votes and returns the voting totals.

  • Node.js/Express HTTP service - done!
  • Static middleware for frontend - done!
  • Calls to third party endpoints - I didn't have time to implement this. 😔
  • Backend service endpoints - Placeholders for login that stores the current user on the server. Endpoints for voting.
  • Frontend calls service endpoints - I did this using the fetch function.

DB/Login deliverable

➡️ The following is an example of the required information for the Startup DB/Login deliverable

For this deliverable I associate the votes with the logged in user. I stored the votes in the database.

  • MongoDB Atlas database created - done!
  • Stores data in MongoDB - done!
  • User registration - Creates a new account in the database.
  • existing user - Stores the votes under the same user if the user already exists.
  • Use MongoDB to store credentials - Stores both user and their votes.
  • Restricts functionality - You cannot vote until you have logged in. This is restricted on the frontend only. 😔

WebSocket deliverable

➡️ The following is an example of the required information for the Startup WebSocket deliverable

For this deliverable I used webSocket to update the votes on the frontend in realtime.

  • Backend listens for WebSocket connection - done!
  • Frontend makes WebSocket connection - done!
  • Data sent over WebSocket connection - done!
  • WebSocket data displayed - All user votes display in realtime. I'm really proud that this is working. Way cool! 🎉 I'm going to celebrate with my bestie over waffles!