Skip to content

Runelite-Wrapped/runelite-wrapped

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RuneLite Wrapped

banner

Basic Idea

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!

Goal

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).

Current stats we want to track

  • 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???

Developer Docs

Basic App Architecture

Architecture Graph

Components

  • 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

Repository Structure

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.

Setup

This section will go through all the things needed to get started in this repo. Excluding the Java stuff - that's a WIP.

Requirements

  • A linux machine (WSL2 on windows with ubuntu is fine)
  • Python 3.10+
    • With pip and venv accessible
  • Docker (or a mongodb instance running elsewhere)

Virtual Environment

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.

Environment Variables

PYTHONPATH

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.

MONGO_URI

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.

TLDR

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.

Install dependencies

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.

Set up your .vscode/ directory

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.

Running / Debugging

You can run the ingestor and analytics apps from within vscode by selecting the appropriate option in the debug section.

vscode_debug_launcher

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

Other Stuff

Relevant Tutorials

I have linked a bunch of relevant tutorials for spooling up/learning python + relevant packages here

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •