Skip to content

This is a library for the YTMDesktop Companion Server which lets you easier communicate with the server and handle authorization and so on.

License

Notifications You must be signed in to change notification settings

XeroxDev/ytmdesktop-ts-companion

Repository files navigation

YTMDesktop TypeScript Companion

This is a library for the YTMDesktop Companion Server which lets you easier communicate with the server and handle authorization and so on.

Installation

  • Install via npm:
npm install --save ytmdesktop-ts-companion

Usage

Can be easier seen in the example file Also you can look through the documentation but here's a quick rundown:

// import the library
import {CompanionConnector} from "ytmdesktop-ts-companion";

// Define settings (add token if you have one, see bigger example for how this could be done)
const settings: Settings = {
    host: "127.0.0.1",
    port: 9863,
    appId: "ytmdesktop-ts-companion-example",
    appName: "YTMDesktop TS Companion Example",
    appVersion: version
}

// Create a new connector
let connector: CompanionConnector;
try {
    connector = new CompanionConnector(settings);
} catch (error) {
    console.error(error);
    process.exit(1);
}

// define clients for easier access
const restClient = connector.restClient;
const socketClient = connector.socketClient;

// register state listener and log it
socketClient.addStateListener(state => console.log("YTMDesktop State changed: ", state));

try {
    // if not, try to request one and show it to user.
    const codeResponse = await restClient.getAuthCode();
    console.log("Got new code, please compare it with the code from YTMDesktop: " + codeResponse.code);

    // Request access top YTMDesktop, so it shows the popup to the user.
    const tokenResponse = await restClient.getAuthToken(codeResponse.code);
    token = tokenResponse.token;

    // set token via connector, so it automatically sets it in both clients.
    connector.setAuthToken(token);
} catch (error) {
    console.error(error);
    process.exit(1);
}

// change track
await restClient.changeVideo({videoId: "xvFZjo5PgG0"});

// connect to the server to receive events
socketClient.connect();

How to contribute?

Just fork the repository and create PR's.

Note

We're using release-please to optimal release the library. release-please is following the conventionalcommits specification.

About

This is a library for the YTMDesktop Companion Server which lets you easier communicate with the server and handle authorization and so on.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published