Skip to content

sfhacks/results

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

sfhacks results

Web interface for collecting results and answers from students
 
Libraries Used:
   •  jQuery - v3.1.0
   •  pocketjs - v1.0 (by @anuvgupta)  

Submitting Answers

Send an HTTP POST request to results.sfhacks.club with the following data:

  • name=YourName
  • answer=YourAnswer
  • password=sfhacks

Request Examples

Bash cURL:

curl -X 'POST' -d "name=Joe&answer=a45d&password=sfhacks" http://results.sfhacks.club

 
jQuery AJAX:

$.ajax({
    url: 'http://results.sfhacks.club',
    method: 'POST',
    data: {
        name: 'Joe',
        answer: 'a45d',
        password: 'sfhacks'
    },
    success: function (data) {
        console.log(data);
    }
});

 
Pure JS AJAX:

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function () {
    if (xhr.readyState == 4 && xhr.status == 200)
        console.log(xhr.responseText);
};
xhr.open('POST', 'http://results.sfhacks.club', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded;charset=UTF-8');
xhr.send('name=Joe&answer=a45d&password=sfhacks');

 

Admin Actions

The admin password is an environment variable stored on results.sfhacks.club.
   (Email [email protected] for access to the password)

  • Deleting Database Entries
    • A parameter number (which specifies the number ID of the entry) must be provided
    • A parameter password must be the admin password
    • Query Format
      • number=entry_ID
      • password=admin_password
    • Example: number=2&password=secret
  • Setting the Correct Answer
    • A parameter correct (which specifies the new correct answer) must be provided
      • If correct is set to __N/A, then the Correct column on results.sfhacks.club is set to N/A
        • This feature can be used to "hide" the correct answer if there is no particular correct answer, or if it should not be shown yet
    • A parameter password must be the admin password
    • Query Format
      • correct=new_answer
      • password=admin_password
    • Example: correct=a45d&password=secret
  • Clearing the Database
    • A parameter clear must be provided and set to true
    • A parameter password must be the admin password
    • Query Format
      • clear=true
      • password=admin_password
    • Example: clear=true&password=secret

 

Structure

Four main components of the results application:

  1. db.json database of names/answers
  2. results.php pocketjs WebSocket server
    • uses pocket.php to create WebSocket server
    • runs indefinitely on ws://results.sfhacks.club:7998
    • checks db.json repeatedly (every second) for changes
    • when changes found, pushes updated database to all open clients
  3. index.php HTTP server/web client
    • server: accepts HTTP POST requests as defined here
      • updates keys in database based on posted data
      • logic is defined in api.php
    • client: page seen on http://results.sfhacks.club
      • displays table based on database (styled by style.css)
      • uses app.js to send and receive updates
  4. app.js powers web client for the HTTP and pocketjs servers
    • uses jQuery AJAX to send data to index.php
      • password for sending answers is sfhacks
      • password for admin actions is a secret!
    • uses pocketjs WebSocket client
      • receives changes in db.json from results.php

 

About

Web interface for live student results

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published