You'd install a plugin that tracks your in game activity in RuneLite (i.e. where you are standing at each game tick) and sends it off to a server where we process global stats and make a little wrapped style presentation.
The main downside to this is that you'd need to Install the plugin a year prior to getting the wrapped summary, and the app would need to be running+ingesting that whole time (which would cost us a little bit) but it would still be neat!
The goal of this project was mainly an upskilling exercise for me and friends to learn how to build and scale a data intensive web app. That is why we opted for data to be ingressed and processed on a server, there is an option of future work to make all the calculations happen clientside, however we don't really want to learn more Java than we need to and the experience is less relevant to us (but if the project pops off, we may end up doing it anyway).
- Your best month
- Days/time periods where there were spouts of activity
- Total XP gained
- Favourite skill
- Spells casted / weapons used
- Players killed (spades collected)
- Total NPCs killed (top X% of players for killing mob X or something silly)
- Time spent at locations
- Hours spent with overhead prayers active
- Number of birdhouse runs done?
- Deaths
- Places died
- Number of deaths
- How you died (poison, NPC, boss, pk)
- Play time
- Energy used, total squares run/walked
- Potions drunk
- Favourite potion
- Food eaten
- Favourite food
- GE spending/earnings ? questionable
- Message count (not the content though)
- Gear
- Favourite gear
- You spent X hours wearing dragon platelegs, noob
- Value of boss drops
- Most profitable activity
- Combat achievements???
- How do we do that???
- Plugin
- A plugin for RuneLite that sends game data to the ingestor service.
- Users will need to have this plugin installed in their local RuneLite for us to receive their game data.
- Written in Java
- Ingestor
- This is an API that receives the data (via HTTP POST) from the plugin and stores it in a mongoDB instance
- Written in Python
- Analytics
- This is a collection of data processing pipelines running in a dagster instance
- These pipelines turn the raw game telemetry into useful stats for the Wrapped report
- Written in Python
- Webapp
- This is the Web App that users will go to to see their Wrapped report
- Written in TBD
Here are the relevant directories for each component:
- The ingestor:
apps/ingestor/
- The analytics:
apps/analytics/
- The webapp:
apps/webapp/
- The plugin:
apps/plugin/
There is also common python code that can be shared between the ingestor and analytics projects in the common/
directory.
This section will go through all the things needed to get started in this repo. Excluding the Java stuff - that's a WIP.
- A linux machine (WSL2 on windows with ubuntu is fine)
- Python 3.10+
- With
pip
andvenv
accessible
- With
- Docker (or a mongodb instance running elsewhere)
You should have a virtual environment set up at the root of the repository. This can be done with the following commands:
python3 -m venv venv
source venv/bin/activate
You will also want to configure vscode to use this virtual environment. You can do this by opening the command palette (ctrl+shift+p) and searching for "Python: Select Interpreter". Then select the virtual environment you just created (./venv/bin/python
). Note: you will need to have the python extension installed for vscode to have this command.
In order to run code that uses the common
package you'll need to add it to your python path, it's also worth adding the two python projects to the python path also (ingestor, analytics). This can be done by setting the PYTHONPATH
environment variable to the root of the repository.
For vscode (and many other development environments) you can use a .env file to set environment variables. You can create a file called .env
in the root of the repository and add the following line to it:
PYTHONPATH=./common:./apps/ingestor:./apps/analytics
The "python path" is a list of directories that python will look in when you try to import a package. You can read more about it here.
The ingestor and analytics apps both require access to a mongodb instance. You can either run one locally or use a docker container. If you want to use a docker container you can run the following command:
docker run -d -p 27017:27017 --name runelite-wrapped-mongo mongo
This will run a mongodb instance in a docker container and expose it on port 27017. You can then set the MONGO_URI
environment variable to mongodb://localhost:27017
in your .env
file.
Here's what your .env
file should look like:
PYTHONPATH=./common:./apps/ingestor:./apps/analytics
MONGO_URI=mongodb://localhost:27017
MONGO_URI may be different depending on how you're running your mongodb instance.
pip install -r requirements.txt
Our dependency setup is a little bit janky at the moment. We're using a single venv for all projects, as monorepo tooling in python is still quite nascent.
We may revisit this in the future, if anything to reduce build times / image sizes.
I've added an example .vscode/
directory to the repo at .vscode.example/
. This contains a launch.json
file that will allow you to run the ingestor and analytics apps from within vscode.
To copy the template (be careful not to overwrite your existing .vscode/
directory if there is one)
cp -r .vscode.example/ .vscode/
Now in the debug section of vscode you should see two options for running the ingestor and analytics apps.
You can run the ingestor and analytics apps from within vscode by selecting the appropriate option in the debug section.
You can also run them from the command line with the following commands:
# ingestor
python -m ingestor.main
# equivalent to:
# python apps/ingestor/ingestor/main.py
# analytics
python -m dagster dev -m analytics
I have linked a bunch of relevant tutorials for spooling up/learning python + relevant packages here