RBWCM-SDK Documentation - v1.1.0
    Preparing search index...

    Class RankedClient

    The main entry point for the RBWCM SDK. Handles the HTTP REST API connection, Redis Pub/Sub event listening, and provides centralized access to all managers.

    const client = new RankedClient({
    apiUrl: 'https://api.example.com',
    apiKey: 'your-secret-key',
    redisUrl: 'redis://localhost:6379'
    });

    await client.connect();

    Hierarchy

    • EventEmitter
      • RankedClient
    Index

    Constructors

    Properties

    api: AxiosInstance

    The configured Axios instance used for making authenticated HTTP requests to the backend.

    • Manager handling all game-related operations (fetching games, scoring games, cancelling games).
    • Manager handling all map-related operations (fetching maps, creating maps, updating maps).
    matchmaking: MatchmakingManager
    • Manager handling all matchmaking session operations (creating sessions, managing drafts, submitting match results).

    The configuration options provided during client instantiation.

    • Manager handling all party-related operations (creating parties, inviting users, managing party state).
    punishments: PunishmentsManager
    • Manager handling all punishment-related operations (bans, mutes, warnings).
    • Manager handling all matchmaking queue operations (creating queues, joining/leaving queues).
    rankedSystems: RankedSystemsManager
    • Manager handling all ranked system operations (creating systems, managing seasons).
    • Manager handling all rank-related operations (fetching ranks, creating ranks, uploading icons).
    redisSub: Redis
    statistics: StatisticsManager
    • Manager handling all statistics, leaderboards, and scoring operations.
    • Manager handling all user-related operations (creation, fetching, updating).

    Methods

    • The Symbol.for('nodejs.rejection') method is called in case a promise rejection happens when emitting an event and captureRejections is enabled on the emitter. It is possible to use events.captureRejectionSymbol in place of Symbol.for('nodejs.rejection').

      import { EventEmitter, captureRejectionSymbol } from 'node:events';

      class MyClass extends EventEmitter {
      constructor() {
      super({ captureRejections: true });
      }

      [captureRejectionSymbol](err, event, ...args) {
      console.log('rejection happened for', event, 'with', err, ...args);
      this.destroy(err);
      }

      destroy(err) {
      // Tear the resource down here.
      }
      }

      Parameters

      • error: Error
      • event: string | symbol
      • ...args: any[]

      Returns void

      v13.4.0, v12.16.0

    • Alias for emitter.on(eventName, listener).

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v0.1.26

    • Connects the client to the Redis Pub/Sub system and starts listening for real-time events. You must call this method before you can receive any live updates from the backend.

      Returns Promise<void>

      A promise that resolves when the Redis connection and channel subscriptions are established.

      client.on(LocalEvents.Ready, () => {
      console.log('Successfully connected to real-time events!');
      });

      await client.connect();
    • Emits an event with the specified payload, triggering all registered listeners for that event.

      Type Parameters

      • K extends
            | RankedEvent
            | "ready"
            | "error"
            | "rawRedisMessage"
            | "draft.pickSuccess"
            | "game.startPick"
            | "game.started"
            | "game.scored"
            | "game.cancelled"
            | "game.scoreUndone"
            | "mapban.started"
            | "mapban.banned"
            | "map.vote"
            | "season.started"
            | "user.registered"
            | "user.banned"
            | "user.unbanned"
            | "user.striked"
            | "user.unstriked"
            | "user.softDeleted"
            | "user.restored"
            | "user.ignChanged"
            | "user.discordIdChanged"
            | "player.rankChanged"
            | "queue.joined"
            | "queue.left"
            | "queue.kickFromQueue"
            | Ready
            | Error
            | RawRedisMessage

      Parameters

      Returns boolean

      A boolean indicating whether the event had listeners that were called.

      client.emit(RankedEvent.SeasonStarted, { seasonId: 'SEASON-UUID', rankedSystemId: 'SYSTEM-UUID' });
      
    • Returns an array listing the events for which the emitter has registered listeners.

      import { EventEmitter } from 'node:events';

      const myEE = new EventEmitter();
      myEE.on('foo', () => {});
      myEE.on('bar', () => {});

      const sym = Symbol('symbol');
      myEE.on(sym, () => {});

      console.log(myEE.eventNames());
      // Prints: [ 'foo', 'bar', Symbol(symbol) ]

      Returns (string | symbol)[]

      v6.0.0

    • Returns the current max listener value for the EventEmitter which is either set by emitter.setMaxListeners(n) or defaults to events.defaultMaxListeners.

      Returns number

      v1.0.0

    • Returns the number of listeners listening for the event named eventName. If listener is provided, it will return how many times the listener is found in the list of the listeners of the event.

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol

        The name of the event being listened for

      • Optionallistener: (...args: any[]) => void

        The event handler function

      Returns number

      v3.2.0

    • Returns a copy of the array of listeners for the event named eventName.

      server.on('connection', (stream) => {
      console.log('someone connected!');
      });
      console.log(util.inspect(server.listeners('connection')));
      // Prints: [ [Function] ]

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol

      Returns ((...args: any[]) => void)[]

      v0.1.26

    • Alias for emitter.removeListener().

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v10.0.0

    • Registers an event listener for a specific event emitted by the RankedClient.

      Type Parameters

      • K extends
            | RankedEvent
            | "ready"
            | "error"
            | "rawRedisMessage"
            | "draft.pickSuccess"
            | "game.startPick"
            | "game.started"
            | "game.scored"
            | "game.cancelled"
            | "game.scoreUndone"
            | "mapban.started"
            | "mapban.banned"
            | "map.vote"
            | "season.started"
            | "user.registered"
            | "user.banned"
            | "user.unbanned"
            | "user.striked"
            | "user.unstriked"
            | "user.softDeleted"
            | "user.restored"
            | "user.ignChanged"
            | "user.discordIdChanged"
            | "player.rankChanged"
            | "queue.joined"
            | "queue.left"
            | "queue.kickFromQueue"
            | Ready
            | Error
            | RawRedisMessage

      Parameters

      • event: K

        The name of the event to listen for (e.g., RankedEvent.SeasonStarted).

      • listener: (...args: RankedClientEventMap[K]) => void

        The callback function that will be invoked when the event is emitted, receiving the appropriate payload.

      Returns this

      client.on(RankedEvent.SeasonStarted, (payload) => {
      console.log(`Season ${payload.seasonId} has started in ranked system ${payload.rankedSystemId}!`);
      });
    • Registers a one-time event listener for a specific event emitted by the RankedClient. The listener will be invoked at most once for the event, and then automatically removed.

      Type Parameters

      • K extends
            | RankedEvent
            | "ready"
            | "error"
            | "rawRedisMessage"
            | "draft.pickSuccess"
            | "game.startPick"
            | "game.started"
            | "game.scored"
            | "game.cancelled"
            | "game.scoreUndone"
            | "mapban.started"
            | "mapban.banned"
            | "map.vote"
            | "season.started"
            | "user.registered"
            | "user.banned"
            | "user.unbanned"
            | "user.striked"
            | "user.unstriked"
            | "user.softDeleted"
            | "user.restored"
            | "user.ignChanged"
            | "user.discordIdChanged"
            | "player.rankChanged"
            | "queue.joined"
            | "queue.left"
            | "queue.kickFromQueue"
            | Ready
            | Error
            | RawRedisMessage

      Parameters

      • event: K

        The name of the event to listen for (e.g., RankedEvent.SeasonStarted).

      • listener: (...args: RankedClientEventMap[K]) => void

        The callback function that will be invoked when the event is emitted, receiving the appropriate payload.

      Returns this

      client.once(RankedEvent.SeasonStarted, (payload) => {
      console.log(`This will only log the first time a season starts: ${payload.seasonId}`);
      });
    • Adds the listener function to the beginning of the listeners array for the event named eventName. No checks are made to see if the listener has already been added. Multiple calls passing the same combination of eventName and listener will result in the listener being added, and called, multiple times.

      server.prependListener('connection', (stream) => {
      console.log('someone connected!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v6.0.0

    • Adds a one-time listener function for the event named eventName to the beginning of the listeners array. The next time eventName is triggered, this listener is removed, and then invoked.

      server.prependOnceListener('connection', (stream) => {
      console.log('Ah, we have our first user!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v6.0.0

    • Returns a copy of the array of listeners for the event named eventName, including any wrappers (such as those created by .once()).

      import { EventEmitter } from 'node:events';
      const emitter = new EventEmitter();
      emitter.once('log', () => console.log('log once'));

      // Returns a new Array with a function `onceWrapper` which has a property
      // `listener` which contains the original listener bound above
      const listeners = emitter.rawListeners('log');
      const logFnWrapper = listeners[0];

      // Logs "log once" to the console and does not unbind the `once` event
      logFnWrapper.listener();

      // Logs "log once" to the console and removes the listener
      logFnWrapper();

      emitter.on('log', () => console.log('log persistently'));
      // Will return a new Array with a single function bound by `.on()` above
      const newListeners = emitter.rawListeners('log');

      // Logs "log persistently" twice
      newListeners[0]();
      emitter.emit('log');

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol

      Returns ((...args: any[]) => void)[]

      v9.4.0

    • Removes all listeners, or those of the specified eventName.

      It is bad practice to remove listeners added elsewhere in the code, particularly when the EventEmitter instance was created by some other component or module (e.g. sockets or file streams).

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • E extends string | symbol

      Parameters

      • OptionaleventName: string | symbol

      Returns this

      v0.1.26

    • Removes the specified listener from the listener array for the event named eventName.

      const callback = (stream) => {
      console.log('someone connected!');
      };
      server.on('connection', callback);
      // ...
      server.removeListener('connection', callback);

      removeListener() will remove, at most, one instance of a listener from the listener array. If any single listener has been added multiple times to the listener array for the specified eventName, then removeListener() must be called multiple times to remove each instance.

      Once an event is emitted, all listeners attached to it at the time of emitting are called in order. This implies that any removeListener() or removeAllListeners() calls after emitting and before the last listener finishes execution will not remove them from emit() in progress. Subsequent events behave as expected.

      import { EventEmitter } from 'node:events';
      class MyEmitter extends EventEmitter {}
      const myEmitter = new MyEmitter();

      const callbackA = () => {
      console.log('A');
      myEmitter.removeListener('event', callbackB);
      };

      const callbackB = () => {
      console.log('B');
      };

      myEmitter.on('event', callbackA);

      myEmitter.on('event', callbackB);

      // callbackA removes listener callbackB but it will still be called.
      // Internal listener array at time of emit [callbackA, callbackB]
      myEmitter.emit('event');
      // Prints:
      // A
      // B

      // callbackB is now removed.
      // Internal listener array [callbackA]
      myEmitter.emit('event');
      // Prints:
      // A

      Because listeners are managed using an internal array, calling this will change the position indexes of any listener registered after the listener being removed. This will not impact the order in which listeners are called, but it means that any copies of the listener array as returned by the emitter.listeners() method will need to be recreated.

      When a single function has been added as a handler multiple times for a single event (as in the example below), removeListener() will remove the most recently added instance. In the example the once('ping') listener is removed:

      import { EventEmitter } from 'node:events';
      const ee = new EventEmitter();

      function pong() {
      console.log('pong');
      }

      ee.on('ping', pong);
      ee.once('ping', pong);
      ee.removeListener('ping', pong);

      ee.emit('ping');
      ee.emit('ping');

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • E extends string | symbol

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v0.1.26

    • By default EventEmitters will print a warning if more than 10 listeners are added for a particular event. This is a useful default that helps finding memory leaks. The emitter.setMaxListeners() method allows the limit to be modified for this specific EventEmitter instance. The value can be set to Infinity (or 0) to indicate an unlimited number of listeners.

      Returns a reference to the EventEmitter, so that calls can be chained.

      Parameters

      • n: number

      Returns this

      v0.3.5