Noisegate
Noisegate is a touchscreen application for Android that allowed the user to unlock the front gate of the Noisebridge hackerspace, by sending a web service request.
Source: <
https://github.com/jjuran/noisegate-android
>
Download: <
https://www.jjuran.org/pub/android/Noisegate-debug.apk
>
The initial version of Noisegate was an affectionate parody of the iPhone’s lockscreen:
data:image/s3,"s3://crabby-images/d0e88/d0e88ba248e061c2ac15971720763563ef20bd87" alt="Early Noisegate screen with large, round Noisebridge logo and 'slide to unlock' widget"
data:image/s3,"s3://crabby-images/245a4/245a4c1da7f226780d4f31477d7f8fe998c1ee7b" alt="iPhone 1 lockscreen with photo of Earth and 'slide to unlock' widget"
Android didn’t have a slider widget, so I had to implement one.
While the unauthenticated gate-unlocking web service was already available to anyone who knew the URL, the popularity of the Noisegate app stoked concerns about the physical security of the space. The community reached a consensus to require the use of numeric codes for access control. Unique codes were given to regulars for long-term use, and attendees of classes received temporary group codes that were active for limited times.
I redesigned Noisegate as a virtual keypad:
data:image/s3,"s3://crabby-images/19765/19765dfe6efdbb99de7d1af96438d729e32b7e29" alt="Early Noisegate screen with '8675309' displayed above a numeric keypad"
This solved the immediate problem, but was not without its faults. The large type made the code vulnerable to shoulder-surfers, as well as imposing a maximum length of eight digits, beyond which the numeral would overrun the physical screen area:
data:image/s3,"s3://crabby-images/d1c5a/d1c5a8467450224eed851aa5ac0634a60c7ddf23" alt="Early Noisegate screen with keypad and 'Segmentation fault' at the bottom"
I revised the user interface again, repurposing the tongue-in-cheek error console to replace the numeric display:
data:image/s3,"s3://crabby-images/45d0a/45d0a5c20238af527d3afa61c01fb7d911e0b2cd" alt="Early Noisegate screen with 'ENTER ACCESS CODE: 314159265...' etc. and keypad"
Having a viable working product at this point, I focused my remaining efforts on presentation. My goal was to go beyond mere utility, and leave the user with a feeling of being the hero in a movie — a true cinematic experience. I devised a backstory to supplement Noisegate’s already established aesthetic (inspired by an actual film), and rewrote the "script":
data:image/s3,"s3://crabby-images/205f7/205f7bed25b6f647c653c2ebe84d5e1daea93dae" alt="Noisegate screen with message area empty except for blinking cursor"
data:image/s3,"s3://crabby-images/c0154/c0154e084333539984d72b05e9165bbb7f27aff2" alt="Noisegate screen with partial text 'REQUEST ACCESS TO GATE P'"
data:image/s3,"s3://crabby-images/35424/35424307b1299d7651d4058182467ac2f018fc13" alt="Noisegate screen with partial text 'REQUEST ACCESS TO GATE PROGRAM'"
data:image/s3,"s3://crabby-images/57316/5731633d880176c0d02d39c434276637a4e9d97a" alt="Noisegate screen with partial text 'REQUEST ACCESS TO GATE PROGRAM; EXECUTE COMMAND U'"
data:image/s3,"s3://crabby-images/b04d7/b04d75eecda284e96b26baeae5452ebc493a5485" alt="Noisegate screen with partial text 'REQUEST ACCESS TO GATE PROGRAM; EXECUTE COMMAND UNLOCK GATE'"
data:image/s3,"s3://crabby-images/0517b/0517b1eefefd678a04a655eb15a8f99d9122abde" alt="Noisegate screen with text 'REQUEST ACCESS TO GATE PROGRAM; EXECUTE COMMAND UNLOCK GATE; ACCESS CODE'"
Since then, the web service has been shut down and replaced by RFID tags, so none of its clients work anymore. While Noisegate no longer provides its intended function, at least it fails gracefully:
data:image/s3,"s3://crabby-images/d62c2/d62c27e6f399198ff0019d0fe81161731844ce66" alt="Noisegate screen with text 'REQUEST ACCESS TO GATE PROGRAM; EXECUTE COMMAND UNLOCK GATE; ACCESS CODE 12345'"
data:image/s3,"s3://crabby-images/bb122/bb1222092485b46fb96f8315b93b754209622fcc" alt="Noisegate screen with text 'NO CARRIER'"