JS Bin is an open source collaborative web development debugging tool.
- Write code and have it both save in real-time, but also render a full preview in real-time
- Help debug other people's JavaScript, HTML or CSS by sharing and editing urls
- CodeCast - where you share what you're typing in JS Bin in real-time
- Remote rendering - view the output of your JS Bin on any device on any platform, updating in real-time
- Processors, including: coffee-script, LESS, Markdown and Jade.
- Debug remote Ajax calls
Find out more about JS Bin's features via the YouTube JS Bin playlist.
JS Bin was built by Remy Sharp and is completely open source and available http://github.com/remy/jsbin. You can also follow @rem on Twitter where he'll tweet about JavaScript, HTML 5 and other such gems.
If you would like to work with Remy and his company, Left Logic on a front end development project, please get in touch.
UX was kindly donated by Danny Hope who also tweets as @yandle.
The vast majority of the port from PHP to Node was done by Aron Carroll who also plays in github as @aron.
JS Bin is a webapp specifically designed to help JavaScript and CSS folk test snippets of code, within some context, and debug the code collaboratively.
JS Bin allows you to edit and test JavaScript and HTML (reloading the URL also maintains the state of your code - new tabs doesn't). Once you're happy you can save, and send the URL to a peer for review or help. They can then make further changes saving anew if required.
The original idea spawned from a conversation with another developer in trying to help him debug an Ajax issue. The original aim was to build it using Google's app engine, but in the end, it was John Resig's Learning app that inspired me to build the whole solution in JavaScript with liberal dashes of jQuery and a tiny bit of LAMP for the saving process.
Version 1 of JS Bin took me the best part of 4 hours to develop back in 2008, but version 2 was been rewritten from the ground up and is completely open source.
A simple REST based API exists for anonymous users if it is enabled in your config.*.json, or can be restricted to registered users with a key specified in ownership.api_key
Authentication is required for all API requests unless one of the following api configuration options are set:
api.allowAnonymousReadWrite
- if set to true allows GET and POST operations to the API anonymously (without an API key)api.allowAnonymousRead
- if set to true allows GET operations to the API anonymously (without an API key)
By default, config.default.json
has api.allowAnonymousRead
set to true.
Curl authentication examples:
$ curl http://{{host}}/api/:bin -H "Authorization: token {{token_key}}"
$ curl http://{{host}}/api/:bin?api_key={{token_key}}
End points are:
GET /api/:bin
- Retrieve the latest version of the bin with that specified IDGET /api/:bin/:rev
- Retrieve the specific version of the bin with the specified ID and revisionPOST /api/save
- Create a new bin, the body of the post should be URL encoded and containhtml
,javascript
andcss
parametersPOST /api/:bin/save
- Create a new revision for the specified bin, the body of the post should be URL encoded and containhtml
,javascript
andcss
parameters
JS Bin has been designed to work both online at jsbin.com but also in your own locally hosted environment - or even live in your own site (if you do host it as a utility, do let us know by pinging @js_bin on twitter).
There's two installation paths: Node (recommended) and PHP.
Historically JS Bin was built on PHP, but has since moved to Node. The PHP flavour does not support the following:
- Remote rendering
- CodeCasting
- Processors
However, everything else released in v3.0.0 of JS Bin is available in both, but all releases after are only supported in the Node environment. PHP mileage may vary!
For detailed instructions on how to build JS Bin in either environment see the running your own JS Bin document.
If you install Node.js installation is easy:
$ npm install -g jsbin
$ jsbin
Then open your browser to http://localhost:3000 and you have a fully working version of JS Bin running locally.
JS Bin assumes that a PostgreSQL database is set up when using Heroku. As you should not commit sensitive data to your repository, adding your own config.local.json in the root is not advised. Instead, please use environment variables once you have created your app on Heroku. Any environment variable set in your default.config can be set using the format JSBIN_[KEY]_[KEY]. For example the following config setting:
{
"session": {
"secret": "d41d8cd98f00b204e9800998ecf8427e"
}
}
can be overriden with the following environment variable set:
JSBIN_SESSION_SECRET=my-hidden-session-secret
$ heroku config:add HOST=[your-app-id].herokuapp.com # the URL to the app that is running
$ heroku config:add JSBIN_URL_SSL=false # set to true if you want to enable SSL
$ heroku config:add NODE_ENV=production # development mode won't serve minified JS
If you wish to use SSL, please consider the issues relating to same origin policies
$ heroku config:add JSBIN_API_ALLOWANONYMOUSREAD=true # set false to disable anonymous read API requests
$ heroku config:add JSBIN_API_ALLOWANONYMOUSREADWRITE=true # false to disable anonymous r/w API requests
$ heroku config:add JSBIN_API_REQUIRESSL=true # enforces SSL for all API requests
$ heroku config:add DATABASE_URL=[your-db-url] # allows you to specify a custom PostgreSQL database
Remember to run these commands in your JSBin folder after you have set up a Heroku app for this repository and the environment variables above have been set.
$ heroku addons:add heroku-postgresql:dev # if you don't already have a DB set up on your app
$ heroku config --app jsbin-test | grep HEROKU_POSTGRESQL # take note of your DB name
$ heroku pg:psql [your-db-name-from-previous-command] < build/full-db-v3.postgre.sql
$ git push heroku # deploy
Now visit your Heroku app's URL and you should have a working JSBin running on Heroku