Skip to content

Latest commit

 

History

History
163 lines (124 loc) · 6.32 KB

README.md

File metadata and controls

163 lines (124 loc) · 6.32 KB

Icarus

TLDR - I haven't had much time to work on this but it's coming along rather well

The Blaze backend — An entire rewrite equipped with account management, 2FA authentication and more!

"Icarus laughed as he fell. Threw his head back and yelled into the winds, arms spread wide, teeth bared to the world."

This backend is written in Typescript and C++. We use MongoDB for the database handling since it's simple to use.

Features

  • Robust account handling
    • Resetting passwords, deleting and creating accounts are all supported
  • Optional 2FA (TOTP)
  • Built-in party support
  • External API that
    • Gives access to the XMPP server using POST requests
      • Using either POST requests or the Websocket
      • Websocket gives the options of using XMPP or SJM
    • Checks authority and gives owner access to upload new lobby themes
  • Built in dashboard for managing users, blocking IP addresses
  • Allows analytics to be enabled for /data_router to be used to collect user information (IP address, client_version, OS, etc.)
  • Automatic compensation for different Fortnite versions. This allows any Fortnite version to be used with this backend as it automatically modifies responses depending on the user agent provided in the request.
  • Your data is saved on the server once your account is created and your data can only be accessed by you and the person that owns the server. (Thought about encryption but that's a waste of time, only passwords are encrypted with blowfish... and maybe XMPP messages but I'll think about that)
  • "Modules" are available along with a WIP Fortnite SDK (not the SDK that your Uncle uses to create things like Milxnor/Reboot (sorry, man) but something with an actual API that you can use to make cool stuff with bindings available for JavaScript and C/C++)

The API

Backend API

Allows account creation, deletion, modication, authentication with 2 layers (password and 2FA (optional)) and connection with parties and the chat through 2 ways (Fortnite_Client (XMPP) and client (XMPP/SJM)).

Fortnite API/SDK ("@trail-blaze/retroflex")

import { FWorld } from "@trail-blaze/retroflex";

// Get world properties (state, game_mode, playlist, damage)
// state could have the following values: "disengaged", "engaged", "inProgress"
// disengaged -> Inactive, engaged -> On spawn island, inProgress -> The game is in progress

FWorld.getProperty(); // No argument means get all properties. Providing a string will search through the properties and return the one you specified

// Disable fall damage
FWorld.setProperty("damage", "false");

// Move all pawns to (x, y, z)
FWorld.getPawnList().forEach((pawn) => {
   pawn.move(70, 70, 70); // x, y. z
});

// Move one pawn
const myPawn = FWorld.getPawnByUsername("Array0x");

myPawn.move(600, 600, 600); // x, y, z
myPawn.costume("CID_016_Athena_Commando_F"); // Set the skin (changes the value in the profile's directory as well)
myPawn.kill(); // Kick the pawn from the world

Modules

Modules are small function-driven scripts. Modules are the means of how you'll be able to interact with the backend. Modules can either be stored on your computer to use on a hosted backend or hosted on the server itself to provide default access to the module to all clients that connect. They are written in TypeScript (or JavaScript if stored on the client computer) and are anonymous functions that are executed when the server is run.

FYI ABSOLUTELY NOTHING runs out of these functions unless explicitly told to do so.

There are three main anonymous functions that are to be called in order for a module to be considered "valid" by the server.

  • ErrorHandler(error: Flare): Is what's executed when an error is encountered in the module. The server will pass in a formatted list of the trace called a Flare.
  • ThreadStart(arguments: Array): Is what is executed when the module is invoked after startup. It takes in an array of arguments.
  • ThreadExit(arguments: Array): Is what is executed when the module decides to exit. It takes in an array of arguments.

Below is an example of a "Hello, World" module. (Inspiration taken from AWS's Lambda)

import { Flare } from "@trail-blaze/flare";

ThreadStart = (arguments: Array) => {
   console.log("Hello, World!");
   return 0;
};

ThreadExit = (arguments: Array) => {
   console.log("Goodbye!");
   // There's nothing really special going on here
   return 0;
};

ErrorHandler = (error: Flare) => {
   try {
      console.warn("Trying that again.");
      ThreadStart();
   } catch (error) {
      console.error(Flare.parse(Flare).getReason()); // We can do other stuff with Flare as well.
                                                     // It's a utility of functions for reading Flares
   }
   return 1;
};

And this is an example of a Flare (Work-In-Progress)

{
   "spark_id": "IANCBAA4xnQDOyUEUIQA7gAUiCASny5R+AJ4D2AI0L4", // Error ID stored in the database
   "severity": "HIGH",
   "attention": {
      "trace": [
         ["path/path/path/path/file", "23", "51"],
         ["path/path/path/path/file", "32", "15"],
         ["path/path/path/path/file", "21", "12"]
      ]
   },
   "did_you_know": "Syntax Error."
}

We can see how this comes all together. Example of a module that moves all the pawns to somewhere mid-air in the world on-join.

import { FWorld } from "@trail-blaze/retroflex";
import { Flare } from "@trail-blaze/flare";

ThreadStart = (arguments: Array) => {
   // Disable fall damage
   FWorld.setProperty("damage", "false");

   // Move all pawns to (x, y, z)
   FWorld.getPawnList().forEach((pawn) => {
      pawn.move(700, 700, 700); // x, y. z
   });
   return 0;
};

ThreadExit = (arguments: Array) => {
   // Clean-up all the pawns
   // Move all pawns to (x, y, z)
   FWorld.getPawnList().forEach((pawn) => {
      pawn.kill();
   });
   // There's nothing really special going on here
   return 0;
};

ErrorHandler = (error: Flare) => {
   try {
      console.warn("Trying that again.");
      ThreadStart();
   } catch (error) {
      console.error(Flare.parse(Flare).getReason()); // We can do other stuff with Flare as well.
                                                     // It's a utility of functions for reading Flares
      console.error("Cleaning up all the pawns IMMEDIATELY!");
      ThreadExit();
   }
   return 1;
};