Skip to content

creativecolab/WebChronoLogger

Repository files navigation

Web ChronoLogger

For bug reporting or any issues you encounter in the code, please email srpalani@ucsd.edu and/or smzhu@ucsd.edu.

Chrome Extension Setup

  • Clone the repo (or download and extract it)
  • Unzip WebInteractionsLogger.zip
  • Open a Chromium-based browser (such as Google Chrome, Microsoft Edge, Opera, Brave) that can run Chrome extensions
  • Navigate to chrome://extensions (chrome can be replaced with your appropriate browser name) and toggle on developer mode (on the top right)
  • Drag and drop the unzipped folder into the tab
  • Access the extension by clicking the "Extensions" button in the toolbar of your browser

Server Setup

For reference, our current server was able to run with these specs: Ubuntu 20.04 OS, 2 CPU cores, 2GB RAM, 50GB storage.

The below steps are from following these setup guides: 1 and 2

  • Create a Python virtual environment and install libraries imported into webLogger.py using pip
  • Install gunicorn and flask using pip
  • Move the WebInteractionServerFiles folder into the same directory
  • Create a WSGI Entry Point within the same directory as webLogger.py
  • Create a .service file within the /etc/systemd/system/ directory that will allow Ubuntu’s init system to automatically start Gunicorn and serve the Flask application whenever the server boots
  • Configuring Nginx to proxy requests

To guarantee you could still use our extension even after our current server shuts down, we provide the code of our server and you could deploy it on your server. You could also use it separately as a way to get the overview of a corpus and what it lacks compared with the meta-data. After you deploy this code on your own server, please also change the SERVER_URL in settings.js to the link to your own server.

File descriptions

  • popup.html - The popup that users interact with when they click the extension button
  • setVisibility.js, popup.js - Changes popup.html webpage based on underlying data stored in Chrome extension
  • sendToServer.js - Processes message from background.js to retrieve webpage data and send it back to background.js
  • background.js - Transfers information between sendToServer.js and runs data through the server
  • settings.js - Stores the SERVER_URL if others wish to run this extension through their own server
  • loggingHistory.html, loggingHistory.html, d3-timelines.js, d3-tip.js - Webpage where users can view their web history that the extension logged in tabular and timeline format
  • serviceAccountKey.json - Credentials allowing server to access and save data to Firebase database

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages