Faking Viewers on Twitch TV

Update: It appears that Twitch has capped views to ten per IP. While this method still works, you’ll need to supplement it with proxies or multiple IP’s. It’s still a good read though 🙂

An intro to Twitch:

Twitch is the largest video game broadcasting community. Most professional gamers live stream onto Twitch and almost every major eSporting event is broadcast through Twitch. There are hundreds of thousands of fans at any given time, all watching live streams.

Since there are hundreds of broadcasters simultaneously streaming, only the top broadcasters get featured on the first page of the channel browser. This position is determined by the number of live viewers watching the live stream. As you can see in the picture below, if you are not ranked in the top 7, you get put in the ominous “View All” button.

In most cases, only the well known broadcasters (usually pro-gamers with large fan bases) are featured on the front page, with all the others hidden away. Because of this, it is extremely hard for new streamers to get their content featured and get more fans. This is a huge catch-22, but according to Twitch, it’s the best way to ensure that only good content gets displayed.

Reverse Engineering Twitch’s View Counter

Although I do not personally play video games or broadcast on Twitch, I wanted to see if there was a way to fake the number of live viewers on a stream in order to be featured on the front page.

The first thing I tried was just to open a stream on different web browsers and private browsing/incognito. As it turns out, it worked. From that, I was fairly certain that views could be faked on a single computer.

The easy way to fake views would just be to make a program that opens a thousand tabs of the live stream, but that would be very resource intensive. Each page load is upwards of 3 MB and there’s the obvious problem of having a lot of live video streams playing at the same time. The bandwidth requirement would be too high.

The better way, of course, is to find out what mechanism keeps track of views. When a stream is loaded with Chrome dev tools open, I found queries to many hostnames, like mp.twitch.tv, usher.twitch.tv, api.twitch.tv, etc… To narrow down the results, I decided to block these hostnames one at a time to see if they were important. I ended up with a few required ones, namely usher.twitch.tv. Requests sent to this hostname returned “tokens”, which I assumed were session variables. Doing some quick Google searching reveals that usher.twitch.tv is used by many 3rd party programs to play Twitch broadcasts.

The program I ended up using is called livestreamer, which is a pip module used to launch streams in VLC player. What’s great about livestreamer is that it queries Twitch’s server and is able to return the result in json format. In this data is a URL that contains data about the video chunks of the live stream.

Faking viewers on Twitch

When a request is sent to the URL received from livestreamer, Twitch thinks a client is watching the live stream. With this in mind, I wrote a simple Python script that gets builds Twitch viewing tokens and queries using a HEAD request to mimic a viewer using the lowest amount of bandwidth possible.

In initial tests, I was only able to fake about ~100 users. But tweaking the number of concurrent threads yielded significant results.

To fake 1000 users using this script only took about 200 KB/sec – a ridiculously low amount of bandwidth. In fact, opening one live stream in the web browser would use more bandwidth than that. The bottleneck is now the CPU, rather than the network (cPython isn’t the most cpu efficient language).

Here are some results:

I decided to see the maximum number of viewers I could fake. I spun up the script on the best hardware I had, and here are the results:

Strangely enough, when there are thousands of fake viewers, the bottleneck actually switches back to the network from the CPU. This time, however, the issue isn’t bandwidth. It’s the number of requests that are being sent out. My guess is that my network throttled the number of packets per machine, and I simply couldn’t send enough requests out fast enough.

Conclusions

Being able to fake thousands of viewers on Twitch is definitely pretty cool, and if one were to do this, he would probably benefit.

A broadcaster can apply for a “partnership” with Twitch, which basically means that he can choose when to play video advertisements throughout his stream. This ad revenue is also shared with the broadcaster. Most large Twitch broadcasters are partners and some are earning estimated figures of $20,000 per year. A major requirement for being accepted as a partner for Twitch is to have a consistently high viewership. I’ve been told that having more than 500 live viewers is enough.

The issue with faking users is that it’s extremely obvious. Instantly gaining hundreds/thousands of viewers from one IP address is clearly going to raise some flags — if Twitch actually checks. I imagine it’s possible for Twitch to check, but does their backend keep track of everything? And for how long?

All in all, being able to fake viewers is definitely going to give a broadcaster a boost. A genuinely interesting broadcaster who doesn’t have a fan-base can instantly rise to stardom by faking views temporarily to bring his channel to the top of the rankings. Nothing too disruptive could happen with this Twitch bot. There are a few very competitive games, such as League of Legends, in which the top broadcaster usually has 50,000+ live viewers. Using a single fake viewer bot won’t make a dent, and it would probably require a few extra computers and a solid network to reach that level of fake viewers.

And for those who were wondering where this script I was talking about this whole time was, so here it is. It’s rather poorly commented but should be simple enough to follow along. You’ll need Python 2.x and the pip modules requests and livestreamer.

Subscribe
Notify of

209 Comments
Inline Feedbacks
View all comments
alu
10 years ago

Instead of faking viewers I want to know if I can find out if someone is faking his views? Is there a way to find out if the numbers are legit?

redster
10 years ago

yeah seems 10 is the limit, I put 100 10 at first, then 30 10 to make sure and still only get 10+ viewers max. Oh well that’s good enough for me. Wish I could add 40+ viewers though.

Johnson
11 years ago

hmmm im only getting 10 viewers no matter what #s i input. seems like one other person is getting this issue. Anyone else?

underground
11 years ago

thx for this. got my friend to help set up and it works perfectly

11 years ago

I keep getting “unexpected indent” errors on this (line 18).
When I try the versions posted with no indents, I get an “expected indent” error (line 19).

I’m passing the 2 arguments into it, but can’t get past this error. Anyone?

Frehd
11 years ago

is it possible to upload the script to an online server? some web hosts support python.

GTor
11 years ago

Whenever I try to run the script I get constant “Indent” errors. I learned minor python just to use this, Can someone give me a link to ‘Stream View Increaser’ or help fix my script errors? Thanks.

Sandwich
11 years ago

i’m getting the error:
>>> ================================ RESTART ================================
>>>
Building viewers 1/1
Exception in thread Thread-1:
Traceback (most recent call last):
File “C:\Python27\lib\threading.py”, line 808, in __bootstrap_inner
self.run()
File “C:\Python27\lib\threading.py”, line 761, in run
self.__target(*self.__args, **self.__kwargs)
File “C:\Users\M0niak\Desktop\Twitch.py”, line 28, in build
urls.append(getURL())
File “C:\Users\M0niak\Desktop\Twitch.py”, line 18, in getURL
output = subprocess.Popen([“livestreamer”, “twitch.tv/ArtemisKnives”, “-j”], stdout=subprocess.PIPE).communicate()[0]
File “C:\Python27\lib\subprocess.py”, line 711, in __init__
errread, errwrite)
File “C:\Python27\lib\subprocess.py”, line 948, in _execute_child
startupinfo)
WindowsError: [Error 2] The system cannot find the file specified

1 4 5 6 7 8 19