npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

mixer-client-node

v2.9.3

Published

A node client for connecting to mixer and the mixer services

Downloads

170

Readme

Mixer Client Node

version downloads

Travis David

Discord

This is a client library for Mixer written in Node.js.

Support

If you ever need any support on using the client be sure to join the Discord or post an issue on the Github Repo. Discord is highly recommended when asking for support as I check it more frequently.

Installation

npm install --save mixer-client-node

Once github registry is open I will add a way to install it via github as well!

Tutorials

Need some help with tutorials? You can find the tutorials I have made HERE. There is a limited amount of tutorials due to the fact that I want to make sure the tutorials are high quality and understandable. If you want to submit any tutorials to me you can reach out to me via Discord: Unsmart#0917 or via email: [email protected].

I recommend you look at the tutorials to get a basic understanding of how to use the client, and what each thing does.

Usage

Here you can find all the basic things that this client can handle for you and how to use the client. If you have any issues understanding any documentation or if you find something is not working as you believe it should either send an issue on the Github Repo or join the Discord and ask for support in the dev-support channel.

Client

let Mixer = require('mixer-client-node').Client;

// (All possibilities for inputs): This is recommended when using the chat services
let client = new Mixer({
	tokens:  {
		access:  'xxxxxxxx',
		refresh:  'xxxxxxxx'
	},
	clientid:  'xxxxxxxx',
	secretid:  'xxxxxxxx',
	user: {
		userid: 755643,
		channelid: 529479 // See note*
	}
});

// (Only required variables): This is all you need if you are only using constellation
let client = new Mixer({
	clientid:  'xxxxxxxx'
});

*Note: The channelid you set in the user object does NOT have to be the owner of the tokens (the userid has to be) you can set the channelid to any channel you want, so if the userid is the bot account you can set the channelid to the streamers channelid. When joining chats this user object is highly recommended to be set but is not needed.

If you have a secretid for your client you must set it in order to use the authorization features of this client.

clientid must always be set as every service is required to know the clientid the requests are coming from to work.

When using the chat features you must at least specify the access token and clientid at a minimum. It is recommended you specify the access and refresh (refresh tokens do not come with an implicit grant) tokens, client and secret ids, and the user object. As it will make connecting to chat much easier.

Chat

The following is a list of all the chat methods implemented.

Join a chat

client.joinChat(CHANNELID_TO_JOIN, USERID_TO_JOIN_AS, AUTO_RECONNECT (true || false));
client.joinChat(CHANNELID_TO_JOIN, USERID_TO_JOIN_AS);
client.joinChat(CHANNELID_TO_JOIN, AUTO_RECONNECT);
client.joinChat(CHANNELID_TO_JOIN);
client.joinChat(AUTO_RECONNECT);
client.joinChat();

// OR you can get the chat socket using promises

client.joinChat(channelid).then(socket => {
	client.chatService.unlisten(channelid) // makes it so the chatService wont emit any events for the specific channelid
	// to re listen do client.chatService.listen(channelid)
	socket.on(...)
}).catch(console.error)

It is recommended that you set the user object when creating the client instance as it makes the join command much simpler. You can do just client.joinChat() instead of having to input the channelid to join, and the userid of the token owner. Also note: The channelid you set in the user object does NOT have to be the owner of the tokens (the userid has to be) you can set the channelid to any channel you want, so if the userid is the bot account you can set the channelid to the streamers channelid. See client info

Anonymous chat joining is not supported and not planned currently.

Close connection to chat

client.closeChat(CHANNEL_ID); //CHANNEL_ID not needed if you are only connected to one chat
//No 'closed' event will be emitted

Send a chat message

client.sendChat("Enter a message to send", CHANNEL_ID); //CHANNEL_ID not needed if you are only connected to one chat

Note: The 360 character count limit is handled by this client so put your full message in there without worrying about how long it is!

Chat Events

let chat = client.chatService

chat.on('joined', data => {
	// data.connectedTo = channelid you are joining
	// data.userConnected = user you are connecting as
}); // This is only sent when you are authenticated to the chat

chat.on('reply', (error, data, channelid) => {
	if(error)  //Oh no error! (Sent by the server when a message sent to the server was rejected)
	//data is the data from the reply
	//channelid is the channelid you are connected to that the error happened on
});

chat.on(EVENT_NAME*, (data, channelid) => {
	//Do what you want with the response (this is the data object from the events response)
});

chat.on('error', (error, channelid) => {
	//channelid is the channelid you are connect/trying to connect to where an error happened
	//error possibilities:
	//an http error getting the info about the chat you want to connect to
	//a socket error
});

chat.on('warning', warning => {
	// warning.code = warning code && warning.id = warning id
	// Code: 1000 ID: 1 = Socket a packet was being sent to was closed
	// or the socket did not exist (if you did the sendMessage method it most likely
	means you inputted a channel you are not connected to or closed connection to)
	// this also contains the channelid (warning.channelid) if you want to reconnect

	// Code: 1000 ID: 2 = You did not specify the channelid to send a message
	// to channelid must be specified when connected to multiple channels

	// Code: 1001 ID: 1 = You used the reconnect method without first connecting
	// to a channel

	// Code: 1001 ID: 2 = You used the reconnect method without specifying
	// the channelid to reconnect to if connected to multiple channels

	// Code: 1002 ID: 1 = You used the close method without first connecting
	// to a channel

	// Code: 1002 ID: 2 = You used the close method without specifying
	// the channelid to close connection to if connected to multiple channels
})

chat.on('closed', channelid => {
	//Socket for channelid was closed (Not sent if auto reconnect set to true)
});

*Event Names The data sent is is the data object from the payload of each event, not the full payload object.

Authentication

This client will handle refreshing tokens and checking tokens via introspection for you.

Refresh Tokens

client.refresh().then(response =>{
	//Auto sets new tokens in the client and returns the response from `oauth/token` route.
	console.log('Access token: ' + response.access_token);
	console.log('Refresh token: ' + response.refresh_token);
}).catch(error => {
	console.error('Status code: ' + error.statusCode);
	console.error('Error: ' + error.error);
})

Introspect

client.introspect(TOKEN_TO_CHECK).then(response => {
	//The response object is the same response from mixer, the  expires field on  the tokens will be set to what is returned automatically
	//For setting timeout on refresh you would do the following code:
	let refresh = new Date(client.expires() * 1000).valueOf() - Date.now();
	setTimeout(() => {
		client.refresh() //See the refresh tokens reference
	}, refresh)
}).catch(error =>{
	console.error('Status code: ' + error.statusCode); //401 status sent when token is no longer active
	console.error('Error: ' + error.error);
});

Set Tokens

client.tokens = {
	access:  'xxxxxxxx',
	refresh:  'xxxxxxxx' //refresh is optional
	expires: 0 // expires is optional (The second timestamp for when the token expires)
}

Note when using the refresh tokens part of this client the new tokens are automatically set including the new expire time. The expires time is also set if you use the introspect part of the client with the access token as the checked token.

Get Tokens

let tokens = client.tokens

let accessToken = client.accessToken || client.tokens.access
let refreshToken = client.refreshToken || client.tokens.refresh
let expiresAt = client.expires || client.tokens.expires

let didExpire = client.didExpire

API Requests

Using the request module from the client automatically limits requests to the correct rate-limit.

Request

let requestOptions = {
	method: 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE',
	uri: "FULL_API_URL",
	headers?: {},
	body?: {},
	auth?: true | false // Default: false
};
client.request(requestOptions).then(response => {
	//Do something
}).catch(error => {
	console.error('Status code: ' + error.statusCode);
	console.error('Error: ' + error.error);
})

Constellation

Need to connect to events using the mixer constellation in order to get live updates to channels like follows, subs, or updated view counts, or features, etc? This client can handle that as well. You can see a full list of event HERE to subscribe to.

*Note: This is currently an early test version of my own constellation handler, as I am new to the constellation service, it may be buggy and if you notice any bugs during development please submit an issue on the GitHub Repo or let me know in the dev-support channel on the Discord.

Some constellation features may change often and may include breaking changes, if anything ever breaks come back here as this will always be up to date.

Info on what each event returns may not be fully complete as I am still investigating every possibility of what constellation returns.

Subscribe

client.subscribeTo('Event:to:subscribe' || [ 'event:1:sub', 'event:2:sub' ])

Unsubscribe

client.unsubscribeTo('Event:to:unsubscribe' || [ 'event:1:unsub', 'event:2:unsub' ])

Get Subscribed Events

let events = client.subscribedEvents // returns a string array of events

Constellation Events

client.constellationService.on('subscribe', (data) => {
	// data.events = array of events you are newly subscribing too
	// you can get the full list with client.subscribedEvents - See this above
})

client.constellationService.on('event', (data, event) => {
	// Do stuff with data, this is the payload object from the event subscribed to
	// Event is the event you subscribed to ex: 'channel:1:update'
	// See *Note
})

client.constellationService.on('reply', (data) => {
	// data.result
	// data.error
	// data.data (full message from server)
})

client.constellationService.on('warning', (data) => {
	// data.warning
	// data.reason
	// data.code
	// data.id
	// data.events
})

client.constellationService.on('error', (data) => {
	// Data is the error returned from the socket
})

client.constellationService.on('closed', () => {
	// The subscription socket was closed
	// all of your events will need to be resubscribed too
})

*Note: The payload data for each constellation event can be found HERE. This also shows the event argument to pass in the subscribe event.