There’s a lot of different ways that a creator’s live audience can engage with them. Using Node.js, the Twitch API and the Streamlabs API I programmed a rudimentary widget that let’s creators display a viewer’s profile picture & name on their phone so they can show it in their webcams.
data:image/s3,"s3://crabby-images/568e4/568e4c21c78ca15601251cf7c43d0da7bf72b6bb" alt=""
data:image/s3,"s3://crabby-images/2adce/2adce0bc0d7ad6198a32426506c7757b35ae38fb" alt=""
data:image/s3,"s3://crabby-images/a56db/a56dbec2c2c663fa483ca2a73c1f46fd24f263c5" alt=""
data:image/s3,"s3://crabby-images/83eb1/83eb103860e5f1b81ec0246761ce4aced55473b5" alt=""
data:image/s3,"s3://crabby-images/1cbb8/1cbb83351e9b47a0c4401543d8d1cbc178d26219" alt=""
data:image/s3,"s3://crabby-images/90a67/90a67b42cd5719af40eba914f7c845443bdc633a" alt=""
When it receives an event from Twitch Chat or Streamlabs (For Twitch, YouTube, Facebook, Streamlabs Charity alerts), it grabs their Profile Picture and displays it on a web server that your phone can connect to.
There’s definitely a risk when displaying a random user’s profile picture on stream, it’s an opportunity for trolls to change their profile picture to something that’s offensive or might get you banned. I included a small protective measure by including settings that can limit usage to VIPs/Moderators/Subscribers-Only for Twitch Chat. That’s okay for a working proof of concept, but not sae enough for something that should be widely distributed.
if (process.env.ENABLE_ALERTS == "true") {
const streamlabs = io(`https://sockets.streamlabs.com?token=[process.env.SOCKETTOKEN]`, { transports: ['websocket'] });
streamlabs.on('connect', () => { console.log('Connected to Streamlabs Server'); });
streamlabs.on('event', (eventData) => {
if (eventData.for == "streamlabs" || eventData.for == "twitch_account" || eventData.for == "youtube_account" || eventData.for == "facebook_account" || eventData.for == "streamlabscharity") {
processAlert(eventData.for, eventData.type, eventData.message[0]);
}
});
}
This snippet connects to the Streamlabs Socket API then listens for events from platforms connected to the creators account. From there, a creator can define settings like enabling specific events and setting minimum tip, bit, raid, and superchat amounts to trigger those specific events.
if (process.env.ENABLE_TWITCH_CHAT == "true") {
const client = new tmi.client({
options: {},
connection: {
reconnect: true,
secure: true
},
identity: {
username: process.env.TWITCH_IRC_USERNAME,
password: process.env.TWITCH_IRC_OAUTH
},
channels: [process.env.TWITCH_IRC_CHANNEL]
});
client.on('connected', twitchOnConnectedHandler);
client.on('message', twitchOnMessageHandler); // print chat image
client.connect(); // Connect to Twitch IRC
}
This snippet uses tmi.js, a JS Package for interacting with Twitch Chat via IRC in Node.js. After connecting to a creator’s channel, it listens to their chat to handle interactions. It check’s the chatter’s stats (subscriber, moderator, etc) then uses the Twitch Helix API to grab that chatter’s Profile Picture.
function getAvatar(username) {
var avatar;
fetch('https://api.twitch.tv/helix/users?login=' + username, {
method: 'GET',
headers: {
'Client-ID': process.env.TWITCH_API_CLIENT_ID,
'Authorization': 'Bearer ' + accesstoken
}
})
.then(res => res.json())
.then(res => {
avatar = res.data[0]['profile_image_url'];
console.log(username + ": " + avatar);
});
}
From there it gets very hacky. It reads a local html layout, switches out some variables (username, profile image url), and overwrites the html file in an XAMPP directory as a local server. The phone, connected on the same wifi, accesses localhost and displays the contents of the html page.