Skip to content

newgiin/cupcake

 
 

Repository files navigation

Cupcake Bridge

Cupcake Bridge helps users makes bridges automagically! Get the Cupcake browser extension for Chrome (v22+) and Firefox (v3+, coming soon)

Contact: Griffin Boyce, griffin @ cryptolab.net

##What even is Cupcake? Cupcake uses something called Flashproxy to create special Tor bridges that are harder to block. As with all circumvention projects, there's a lot more to it than that, but that is the jist. Flashproxy was created by David Fifield, and there is a lot of ongoing research in this area. You can learn more at the Stanford Flashproxy site. Cupcake exists as an easy way to distribute Flashproxy, with the goal of getting as many people to become bridges as possible.

Cupcake can be distributed in two ways:

  • As a module/theme/app on popular web platforms (turning every visitor to your site in to a temporary proxy)
  • As a chrome extension (turning your computer in to a less temporary proxy)

##What the frak is a Flashproxy? There is this thing called a Flash Proxy[1] - basically a code snippet that you run on sites and visitors become tor bridges temporarily.

I kind of love/hate the idea, because visitors aren't willing participants and the bridges last a short short while. But it means that you don't have to run the whole Tor shebang if you only want to make bridges. It's really innovative, and uses technology that the majority of computer owners have enabled (JavaScript).

So, what I decided to do is take that same client-side code snippets and turn it into a browser extension. People install it and they opt-in to become really robust bridges. It was a total experiment, but it went so well that I decided to expand the project.

##But... why bother with flash proxies? "The purpose of this project is to create many ephemeral bridge IP addresses, with the goal of outpacing a censor's ability to block them. Rather than increasing the number of bridges at static addresses, we aim to make existing bridges reachable by a larger and changing pool of addresses." [2]

##Oh. Well okay then. Carry on. I knew you'd come around!

##Complete

##Beta

  • Drupal 6 module
  • Flex shim for Flash games

##Next

  • Better UX for Wordpress and Drupal plugins
  • Translation - Help Out!
  • Firefox add-on
  • Metrics (with the idea of pushing this functionality upstream to Flashproxy.js)

##Roadmap

  • Wordpress Theme
  • Tumblr Theme (#2)
  • Drupal 7 & 5 modules
  • Safari
  • Flash/SWF App Shim (actionscript & html)

##High-priority tasks that are difficult to fix

  • Enabling wordpress.COM users to add flashproxy to their theme. (Can you help with this? Send me an email! griffin @ cryptolab.net )

##Low-priority tasks that demand a lot of time

  • Opera 12 extension
  • RefineryCMS add-on
  • Opera 15 add-on
  • Joomla Extension

##Failed experiments

  • /img-embed

##Surprisingly-sucessful experiments

  • Tumblr post demo post
  • Tumblr theme demo (new link coming soon)
  • Facebook App (html5/css3/javascript)

##Code notes ###chrome/manifest.json

  • incognito:split This is useful during testing, so that incognito won't use cookies from standard browsing mode.
  • incognito:spanning When deployed, prevents incognito windows from creating additional Cupcake processes. Proxy will continue even if all the browser windows are in incognito mode.
  • permissions:background is used so that the extension will notify of updates and display the post-installation page. Also used so that Cupcake will start/run on startup, before the browser is started (Windows only).
  • permissions:cookies allows reading/writing of cookies, but may not be necessary, since Cupcake doesn't currently use the Cookies API.

License

My software is free to use, free to give to friends, & open-source, so everyone can make sure it's safe for people to use. Want to make changes? Go for it! 🐶

Cupcake uses the Revised BSD license -- see license.txt for more info.

Cute dog

dawww, lookit dat little tongue so cute

References

[1] https://crypto.stanford.edu/flashproxy/
[2] https://gitweb.torproject.org/flashproxy.git/blob/HEAD:/README

About

Frontends for Flashproxy

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 89.5%
  • PHP 5.3%
  • CSS 5.2%