For bug reporting or any issues you encounter in the code, please email srpalani@ucsd.edu and/or smzhu@ucsd.edu.
- 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
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.
- 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