livesplit-client

LiveSplit Server Node.js client implementation

Usage no npm install needed!

<script type="module">
  import livesplitClient from 'https://cdn.skypack.dev/livesplit-client';
</script>

README

node-livesplit-client

Zero-dependency Node.js client library for the LiveSplit Server.

How to install

Simply run in your terminal:

npm install livesplit-client

How to use

  • Download and move LiveSplit Server component into your LiveSplit Components folder.
  • Add server component into your layout, run the server from "Control" menu.
  • Then look into this usage example:
const LiveSplitClient = require('livesplit-client');

(async () => {
    try {
        // Initialize client with LiveSplit Server's IP:PORT
        const client = new LiveSplitClient('127.0.0.1:16834');

        // Connect to the server, Promise will be resolved when the connection will be succesfully established
        await client.connect();

        // Start timer. Don't forget to WAIT Promise resolve if answer is expected, library does not have any queue implementation!
        client.startOrSplit();

        // Job done, now we can close this connection
        client.disconnect();
    } catch (err) {
        console.error(err); // Something went wrong
    }
})();

Library API

Library docs

Click here and you will be navigated to the latest API docs.

Setting custom timeout

Default command response timeout is 100 ms. You can set your own timeout:

const LiveSplitClient = require('livesplit-client');
const client = new LiveSplitClient('127.0.0.1:16834');
client.timeout = 250; // Timeout in ms

Sending custom commands without library methods

You could use client.send('command', expectResponse). Please note, that \r\n will be automatically added to your command. If your are expecting the answer, your should specify true as second argument of this method. In other case Promise will not be returned and you could potentially break answers order.

Extended example

const LiveSplitClient = require('livesplit-client');

(async () => {
    try {
        // Initialize client with LiveSplit Server's IP:PORT
        const client = new LiveSplitClient('127.0.0.1:16834');

        // Connected event
        client.on('connected', () => {
            console.log('Connected!');
        });

        // Disconnected event
        client.on('disconnected', () => {
            console.log('Disconnected!');
        });

        // Error event
        client.on('error', (err) => {
            console.log(err);
        });

        // Raw data reciever
        client.on('data', (data) => {
            console.log('Debug data:', data);
        });

        // Some async sleep sugar for this example
        const sleep = (time) => {
            return new Promise((r) => {
                setTimeout(() => r(), time);
            });
        };

        // Connect to the server, Promise will be resolved when the connection will be succesfully established
        await client.connect();

        // Start timer
        client.startOrSplit();

        // Wait for 1 sec
        await sleep(1000);

        // Current time after 1 second
        const time = await client.getCurrentTime();

        console.log('Current time after 1 sec.:', time); // Blazing fast and accurate numbers

        // Get split name
        const splitName = await client.getCurrentSplitName();
        console.log('Split name:', splitName);

        // Get all available information
        const info = await client.getAll();
        console.log('Summary:', info);

        // Pause and reset
        await client.pause();
        await client.reset();

        // Job done, now we can close this connection
        client.disconnect();
    } catch (err) {
        console.error(err); // Something went wrong
    }
})();

Contribution

Feel free to create issues and PR's. Thank you for your help!