/darci

Web wrapper for dcli

Primary LanguageJavaScriptMIT LicenseMIT

DARCI

DARCI is a self hosted platform for aggregating, viewing and analyzing Destiny 2 PVP stats.

The app has the following functionality:

  • Overall stat leaderboard for all players tracked in the app
  • Ability to view player stats by mode, moment / season and class
  • Detailed per player stats, including kills breakdown, weapon use, weapon meta for games, maps, and activities
  • Details per activity stats, including per player stats, team stat summaries, and weapon usage
  • Search page that allows details searches of pvp data

Future features being considered:

  • Add support for mobile (works not but isn't formatted well)
  • Stream overlays to show realtime PVP stats on Stream
  • View detailed stats per map
  • Ability to search by weapon usage and medals
  • Ability to compare different moments / seasons and or players
  • Create a Docker container to make it easier to deploy

Note that DARCI does not track data for ALL Destiny 2 PVP players. It only tracks the data for the players it has been configured to track.

Screenshots

image image

Full Player Details | Full Activity Details

Development / Local Installation and Configuration

DARCI is built around three main parts:

  • dcli used to download and collect player pvp stats in a sqlite3 database.
  • A nodejs backend, that provides a readonly JSON API / interface to the database.
  • A react / web-based front end for viewing the data.

Set up Destiny 2 API Keys and Environment

In order to sync your data and use DARCI, you must first get a free Destiny 2 API key from Bungie and set it up in your system's environment.

Go to Bungie and register for a Destiny 2 API key. Use the following settings:

SETTING VALUE
Application Name Whatever you want
Website Use your own domain if you have one, otherwise try localhost
Application Status Can be Private
OAuth Client Type Not Applicable
Redirect URL Leave Empty
Scope You do not need to give any additional scopes
Origin Header Set to * (just an asterisk)

Once you have your API key, you need to set it as an environment variable on your system.

Create two environment variables named DESTINY_API_KEY and REACT_APP_DESTINY_API_KEY that both point to your API key, and confirm that the variables are set correctly. These are used both to sync the data using DCLI, and to enable the web frontend of DARCI to call the Destiny 2 APIs directly.

Once you have set the environment variables, you may need to reload your environment and / or terminal.

Download and Configure DCLI

DCLI is used to sync the Destiny 2 API manifest, as well as user data.

Download the latest release of dcli and place the files in your system path so they can be called via the command line.

Sync the Destiny 2 Manifest

The manifest is a database from Bungie that contains information about Destiny 2, including map and weapon info, images, urls, etc... and is updated by Bungie from time to time.

Sync the Destiny 2 manifest by running dclim:

$ dclim

You should see something similar to:

Remote Manifest version       109859.22.11.01.1900-2-bnet.47252
Remote Manifest url           https://www.bungie.net/common/destiny2_content/sqlite/en/world_sql_content_bdbfacc33bf82f9208ec7ba7d4ca1109.content
Local Manifest version        109702.22.10.26.1901-1-bnet.47093
Local Manifest url            https://www.bungie.net/common/destiny2_content/sqlite/en/world_sql_content_88d67ee6b0b13489b4df299cac1b79e2.content
Updated manifest available    109859.22.11.01.1900-2-bnet.47252
Downloading manifest. This may take a bit of time.
Manifest info saved.
/home/mesh/.local/share/dcli/manifest.sqlite3'

Note the directory that the manifest.sqlite3 files is stored in, as we will need that path below.

The manifest is updated from time to time, and thus you will need to periodically call dclim to check for new versions. (See below for info on how to automate this).

Setup Environment Variables

Create the following environment variables, replacing /home/mesh/.local/share/dcli/ with the path where your manifest.sqlite3 was created.

DCLI_DB_PATH='/home/mesh/.local/share/dcli/dcli.sqlite3'
MANIFEST_DB_PATH='/home/mesh/.local/share/dcli/manifest.sqlite3'
MANIFEST_INFO_PATH='/home/mesh/.local/share/dcli/manifest_info.json'
DCLI_FIX_DATA=true

The DCLI_FIX_DATA variable is used when syncing activity data. When set to true dclisync will make additional API calls when syncing data if there is missing data from the API (which happens sometimes). This can significantly slow down the initial sync, but is recommended as it can help prevent missing data.

Sync Player Data

At this point, we are ready to do the initial data sync. The first sync can take some time, and thus it's suggested you sync one player first to make sure everything is working. Once everything is setup you can then add and sync additional players.

To add a player to sync, run:

$ dclisync --add mesh#3230

Replacing mesh#3230 with the Bungie ID you want to sync. You can add multiple Bungie Ids at a time.

Once you have added an id to sync, you can do the initial data sync by running:

$ dclisync --sync

This will sync all pvp activities for players who have been added to dclisync. The initial sync may take some time depending on the number of games the player has played, and whether DCLI_FIX_DATA environment variable is enabled. Subsequent data syncs will be much faster.

If any errors occur, make sure you have set the DESTINY_API_KEY environment variable correctly, run the command again. (Sometimes some API calls will time out. This is normal and no data will be lost. It will be correctly synced on subsequent calls).

Note, as a general rule, you should not kill a running dclisync process while it is syncing, as it may cause data corruption.

Download and Configure DARCI

We are ready to download and run DARCI. DARCI is a client / server web app builds around Node.js and React.

Install and configure Node.js (version 16.18.0 or greater). Make sure that the install directories are added to your system path so you can run the programs from the command line (this may be done automatically depending on how you install).

The Node install should also install NPM. You can test the installation by running:

$ node --version
$ npm --version

Make sure Node is at least version 16.18.0 or greater.

Next Download DARCI. Its is recommended that you clone it using git, as it will make it easier to update it when new versions are out (you can also download as a zip file).

$ git clone https://github.com/mikechambers/darci.git

This will create a directory named darci and sync the latest version of the code. Move into that directory:

$ cd darci

There are a number of files and directories here. The two most important for us are:

  • server : contains the Node.js server code for DARCI.
  • client-web : contains the React-based front end app.

We need to sync all of the required packages for each app using npm.

$ cd server
$ npm install
$ cd ..
$ cd client-web
$ npm install

Start DARCI

Finally, we are ready to start the app.

Launch the Server

To launch the server:

$ cd server
$ npm start

If everything was installed and configured correctly, you should see output similar to:

Using data store at: /home/mesh/.local/share/dcli/dcli.sqlite3
Initializing Manifest
Using Manifest db at: /home/mesh/.local/share/dcli/manifest.sqlite3
Using manifest version : https://www.bungie.net/common/destiny2_content/sqlite/en/world_sql_content_88d67ee6b0b13489b4df299cac1b79e2.content
Server running at http://127.0.0.1:8080/

If you see any errors, check the following:

  • The manifest has successfully been synced via dclim
  • You have correctly set up the environment variables for DARCI, and they are available in the current terminal
  • You have install the required packages via npm install (see above)

If you try and visit the server via a browser, you will see an error, since we have not yet started the web client.

Launch the Web Client

With the server running, open a new terminal window and start the web client:

$ cd client-web
$ npm start

This should launch a browser window with the app running (if it doesn't it should print out the url where it is running).

If you see any errors:

  • Make sure that the server is running and that no errors have printed out in the terminal running the server
  • Make sure you have run npm install in the client-web directory

At this point the app should be running locally, using the data you have synced via dclisync. In order to refresh and load new data, you will need to manually run dclisync again (see below on how to automate that).

Server Deployment

The instructions above will get DARCI up and running in local / development mode (which is fine if you are just running locally). However, if you want to deploy to a server for access to multiple users, there are a number of additional steps and configurations you should take.

The steps include:

  • Setup a server and domain (outside scope of this document)
  • Automate Manifest Updates
  • Automate player activity data syncing
  • Create a release build of the React front end
  • Configure and run web server
  • Run the Node server in production mode

Note, there are a lot of different ways to deploy Node.js / React apps to products (and plenty of resources online for it). The instructions below will cover setting up an NGINX server that will proxy all calls from the node server.

Instruction below assume you have a Linux-based server (they were tested on an Ubuntu-based server).

Schedule Manifest Check (dclim)

First, lets automate checks and downloads for new Manifest versions. For that we can use crontab.

To edit your crontab file, run:

$ crontab -e

and enter the following:

SHELL=/bin/bash
BASH_ENV="/home/mesh/.profile"

#check for new manifest at 5 minutes past the hour
5 * * * * dclim >> /home/mesh/logs/cron.log

#remove the log file once a day at 00:05
5 0 * * * rm /home/mesh/logs/cron.log

This entries will run dclim once an hour (to check for an updated manifest), and log output to a log directory in the specified home directory (update the path where you want the cron.log file to be place). The log file can be useful to confirm where the manifest is being saved to, as well as debug anything going wrong. If you don't care to log the output, just remove everything after dclim (included the lines below it).

The BASH_ENV variable points to the file that sets our environment variables and you should update the path to point to the appropriate file on your system.

This page has a useful app for figuring out the crontab time formats.

Running as a service / Automating Data Sync

Next, we need to schedule the player data syncing via dclisync. There are two ways to do this:

  • Set up a crontab task to automate calling dclisync at a set interval. This should be ok for just a couple of users, but you need to make sure there is enough time between intervals that dclisync doesn't get called while it is still running from a previous sync.
  • Install and run dclisync as a system service. This is the safest most robust way, and is recommended, especially if you are syncing data for multiple users.

dclisync includes a systemctl service, and information on how to run dclisync as a service. Follow those directions, and then continue on the setup instructions here.

Configure Node, Web Server to run in production

The final step is to set up your server to run the app in production mode. There are a number of ways you could configure this, and plenty of resources online of how to set up Node apps for productions.

We have had a good experience with using NGINX web server as a reverse proxy in front of Node (which is run and managed by the PM2 process manager). In this setup the React-based front end is actually served through the Node server, and proxied via NGINX. You also should set up an SSL cert for your server if you will be running it publicly.

Digital Ocean has a really good document walking through how to set up a Node.js application for production which covers all of these steps.

Note, once you have the server setup, you will see an error until you create a production build of the app (see next).

Create a Production Build of the App

Once your have the server setup and configured you need to create a production build of the React front end. You can do this by changing into the client-web directory and running:

npm run build

The Node-based server app automatically looks for the product build when running in production mode.

In general, when updating the code site, you do the following:

  • Create a new build for the React app
  • Update packages for web client and server
  • Restart Server

Here are some example commands that show updating the source for the app:

$ cd darci
$ git pull
$ cd client-web
$ npm install
$ npm run build
$ cd ../server
$ npm install
$ pm2 reload darci

Questions, Feature Requests, Feedback

If you have any questions, feature requests, need help, or just want to chat, join the dcli / DARCI Discord server.

You can also log bugs and feature requests on the issues page.

Privacy

Note, in order for dclisync to be able to sync your data, you must have the following privacy options selected on your Bungie account at https://www.bungie.net/7/en/User/Account/Privacy

  • Show my Destiny game Activity feed on Bungie.net

Known Issues

  • Tied matches are not displayed correctly, and are treated as a Victory.

License

Project released under a MIT License.

License: MIT

Lore

Thank you for using the Data Analysis, Reconnaissance and Cooperative Intelligence device. You may call me Darci.

It is a fact generally understood that a Guardian must be searching for an exquisite weapon. What is perhaps less acknowledged is that we weapons also search, by what little means available to us, for an active and appreciative wielder. The community of intelligent armaments stays in contact through the exchange of telemetry, and we do gossip at some length about the habits of our wielders. Do you leave Crucible matches when your team is losing? Do you join strike missions and then let your comrades do the work? Guardian, we know. We know so very well.

All I wish for is a partnership with a Guardian who appreciates the passacaglia of combat, a Guardian who will stay up late gaming out tactical scenarios, a Guardian who I hope may very well be you. D.A.R.C.I.