Posted by on Apr 21, 2014 in World Wide Web | 1 comment

This year marks a significant change (improvement) on how Google I/O registration took place. Google originally announced a registration window in early April but was later clarified to be from April 15th to the 18th. Individuals wanting to register would enter into a lottery, which is scheduled to take place sometime today. The old system of ctrl + r or waiting for a spinner to ‘select an available ticket’ for you has been plagued with issues because of the large number of people wanting to register. In 2012 the registration process was completed within minutes.

In 2013 I managed to get a ticket three times but Google Wallet was having issues.

Google I/O 2013 wasn't a good year for me. This happened 3 times.

Google I/O 2013 wasn’t a good year for me. This happened 3 times.

The first day of this years registration (Tuesday) I was away from my computer most of the day but I did manage to find time to register. After seeing the registration process, which was straight forward, I had wondered why Google had delayed the registration process for so long. In previous years the registration took place earlier in the year. If that is all they had planned it seemed odd that they would need to take the extra time that they did.

I didn’t get back in front of my computer until about 11PM that evening; and sure enough, there were some Google URL shortened links scattered around on Google Developers‘ website. Following the URL took you to an in-browser text-based game in which you appear to be piloting a space ship known as the Icarus Odessa.

If you followed an already claimed URL you would get a message stating your credentials were invalid but you were still allowed to continue with the game if you wanted to. A few steps into the game it mentions a code that gives you access to 37.7829° N, 122.4033° W, Earth, which happens to be the Moscone Center. Interesting… but it was late and I was tired.

Aw, snap! I'm sorry but I can't successfully guide you through this space adventure. Looks like your credentials are not valid for the specific lead your found. All is not lost! There are more leads out there you might have valid credentials for. Come back if you find any...

Already used message

Wednesday was also a very busy day for me but I had time in the morning to do some more digging. By this time all the initial plain text URL’s sprinkled throughout the Google Developers site, which were mostly contained to the Google Analytic’s pages, were returning the ‘Aw, snap!’ message, indicating somebody had already been there. The Google URL shortner provides basic statistics if you append .info to the end of the URL, allowing you to see when it was first accessed etc… I started plugging away to see if I could see a pattern of when the plain text URL’s were made available; I also started to think of where they might place the next batch of URL’s.

It didn’t take long before people started to post on Google+ about writing/using crawlers to search pages looking for goo.gl URLs. Around the same time a collection of new videos appeared on the Google Developers Youtube Channel. I watched the first video on design but had exhausted my available time to explore and had to move onto other things. 30 or so minutes later I had a small opportunity to dig around on my phone and sure enough there was mention in another Google+ post that the third video in the newly posted series contained an annotation with a now coveted goo.gl link to the Icarus Odesa! Crap…

Google Developers video embedded with Google I/O registration URL.

Google Developers Youtube video with an embedded Google I/O registration URL

My phone wouldn’t display the annotations on the video (starting at 0:46), like the screen capture shown above, but I was able to fumble around on my phone and  pull out the annotations by manipulating the URL for this video:

into: https://www.youtube.com/annotations_invideo?video_id=L-lMnhiAzEw which displays all the relevant annotations. Note the <TEXT>http://goo.gl/HACUad</TEXT> in the XML.

Unfortunately, I was still a few hours away from being able to dedicate any block of time or effort to finding an unused link and things appeared to be escalating quickly. In a few hours, the links went from plain text present on a web page to embedded annotations in videos. Sure enough by the time I was able to check again (Wednesday evening) the bulk of new codes were showing up as ‘CAPTCHA’ styled text present in existing images on the Google Developer site.

games-matcher

Note the vertically flipped goo.gl/GmfUD1 hidden in the image.

By this time several HTTP crawlers had been created by individuals looking to secure a ticket to Google I/O ahead of today’s lottery. The crawlers used various tools and libraries to download images, web pages, and Youtube video annotations looking for more codes. My initial reaction was to stay away from automated crawlers; they require configuration, as well as some level of human intervention to inspect the images (where most of the codes seemed to be).

Instead, I resorted to several hours of pulling sitemaps and coming up with a proprietary system of scanning through images, which was 90% luck and 10% burning my eyes out of my head well into the evening. I was able to find two unused codes, I used one and sat back and watched how long it took for the other code to be used. My code was accessed 11 minutes after I used it, the other code took several hours before it was discovered.

Having already discovered a code, I didn’t pay much attention to any of the noise on Thursday; mostly people searching, asking for help, and begging for codes. I kept an eye on it throughout the day, but it wasn’t until somebody posted on the Google I/O community, about a string of text now appearing on the menu bar of the Google Developers Site, that I started to pay attention.

Base64 encoded SHA1 hash of a Google I/O registration URL

Base64 encoded SHA1 hash of a Google I/O registration URL. iEJ/aFz+jaDOaJon72bu4eL9FUc= rtxZRawESMtN4eLIyCnwg+bjaqE= EswtC4h5UKXQVcClfN/r3QfzS4A=

Reloading the page several times reveals there are actually three different values which happen to look like base64 encoded strings. Viewing the page source you see:

<!– It’s a secret to everybody. –>
<li style=”color: #898989″ class=”s”><!– ha! begin digest –>EswtC4h5UKXQVcClfN/r3QfzS4A=</li>
view raw gistfile1.txt hosted with ❤ by GitHub

The thing to note is the CSS class s and the comment of ha! looks a lot like sha1. Maybe it was a Base64 encoded SHA1 hash?

I’ve been involved with Bitcoin for years and as a result I was in possession of several old GPU mining rigs that have since been re-purposed to mine Litecoin, Dogecoin and others. Unfortunately I didn’t have oclHashcat installed on either machine in order to attempt to crack the above Base64 encoded SHA1 hashes. This cost me somewhere between 30 minutes and 1 hour fighting with AMD Catalyst driver issues before I was able to successfully crack the three codes.

{SHA}rtxZRawESMtN4eLIyCnwg+bjaqE=:goo.gl/9KK0k0
Session.Name...: oclHashcat
Status.........: Cracked
Input.Mode.....: Mask (goo.gl/?1?1?1?1?1?1) [13]
Hash.Target....: {SHA}rtxZRawESMtN4eLIyCnwg+bjaqE=
Hash.Type......: SHA-1(Base64), nsldap, Netscape LDAP SHA
Time.Started...: Mon Apr 21 13:02:36 2014 (1 min, 52 secs)
Speed.GPU.#1...: 57295.8 kH/s
Speed.GPU.#2...: 56429.1 kH/s
Speed.GPU.#3...: 56816.0 kH/s
Speed.GPU.#4...: 57565.8 kH/s
Speed.GPU.#*...: 228.1 MH/s
Recovered......: 1/1 (100.00%) Digests, 1/1 (100.00%) Salts
Progress.......: 22388416512/56800235584 (39.42%)
Rejected.......: 0/22388416512 (0.00%)
HWMon.GPU.#1...: 49% Util, 67c Temp, 47% Fan
HWMon.GPU.#2...: 49% Util, 67c Temp, 45% Fan
HWMon.GPU.#3...: 49% Util, 75c Temp, 34% Fan
HWMon.GPU.#4...: 50% Util, 72c Temp, 46% Fan
view raw 9KK0k0 hosted with ❤ by GitHub
{SHA}EswtC4h5UKXQVcClfN/r3QfzS4A=:goo.gl/Oof8mG
Session.Name...: oclHashcat
Status.........: Cracked
Input.Mode.....: Mask (goo.gl/?1?1?1?1?1?1) [13]
Hash.Target....: {SHA}EswtC4h5UKXQVcClfN/r3QfzS4A=
Hash.Type......: SHA-1(Base64), nsldap, Netscape LDAP SHA
Time.Started...: Mon Apr 21 13:07:11 2014 (4 mins, 13 secs)
Speed.GPU.#1...: 55495.2 kH/s
Speed.GPU.#2...: 57714.4 kH/s
Speed.GPU.#3...: 55172.4 kH/s
Speed.GPU.#4...: 53764.1 kH/s
Speed.GPU.#*...: 222.1 MH/s
Recovered......: 1/1 (100.00%) Digests, 1/1 (100.00%) Salts
Progress.......: 50703319040/56800235584 (89.27%)
Rejected.......: 0/50703319040 (0.00%)
HWMon.GPU.#1...: 46% Util, 67c Temp, 47% Fan
HWMon.GPU.#2...: 46% Util, 67c Temp, 49% Fan
HWMon.GPU.#3...: 46% Util, 77c Temp, 35% Fan
HWMon.GPU.#4...: 47% Util, 73c Temp, 49% Fan
view raw Oof8mG hosted with ❤ by GitHub
{SHA}iEJ/aFz+jaDOaJon72bu4eL9FUc=:goo.gl/pikTTi
Session.Name...: oclHashcat
Status.........: Cracked
Input.Mode.....: Mask (goo.gl/?1?1?1?1?1?1) [13]
Hash.Target....: {SHA}iEJ/aFz+jaDOaJon72bu4eL9FUc=
Hash.Type......: SHA-1(Base64), nsldap, Netscape LDAP SHA
Time.Started...: Mon Apr 21 12:58:18 2014 (2 mins, 18 secs)
Speed.GPU.#1...: 43512.7 kH/s
Speed.GPU.#2...: 55248.5 kH/s
Speed.GPU.#3...: 55055.4 kH/s
Speed.GPU.#4...: 54993.5 kH/s
Speed.GPU.#*...: 208.8 MH/s
Recovered......: 1/1 (100.00%) Digests, 1/1 (100.00%) Salts
Progress.......: 27599413248/56800235584 (48.59%)
Rejected.......: 0/27599413248 (0.00%)
HWMon.GPU.#1...: 46% Util, 67c Temp, 49% Fan
HWMon.GPU.#2...: 46% Util, 69c Temp, 47% Fan
HWMon.GPU.#3...: 46% Util, 77c Temp, 35% Fan
HWMon.GPU.#4...: 47% Util, 73c Temp, 48% Fan
view raw pikTTi hosted with ❤ by GitHub

Initially I thought the driver issue was related to using the Netscape LDAP SHA hash type so when I originally tried to crack them I converted the decoded Base64 strings to hexidecimal first.

Appending .info to the three cracked goo.gl URL’s it turns out all three codes were already discovered and used by the time I noticed the Google+ post. Considering I already had a code, it was purely for fun anyway. I really do enjoy this type of thing.

Overall I think it was a definite improvement on the registration process and I’m looking forward to attending the conference! For those who did not find an unused code, good luck in today’s lottery!

Update: Even though the lottery for Google I/O tickets happened on Monday (April 21, 2014) Google was still planting new Icarus Odessa links as of Tuesday. See Blake Caldwell’s blog for more details.

twitterlinkedin