No description
Find a file
Florian Mounier 5c054ca290 Bump 2.0.1
2016-01-18 10:09:44 +01:00
butterfly Bump 2.0.1 2016-01-18 10:09:44 +01:00
coffees Fix home/end 2016-01-18 10:05:50 +01:00
docker adding server port parameter 2015-01-27 11:06:58 -08:00
scripts Fix cursor blur. Fix scrollLock on focus/blur. Rework binaries. 2015-10-16 15:58:32 +02:00
.gitignore Fix #81 2015-05-11 11:59:47 +02:00
.gitmodules Add themes as a submodule and handle both builtin themes and local themes. 2015-10-14 13:19:52 +02:00
bower.json Fix alt buffer restore 2015-10-05 11:56:34 +02:00
butterfly.png Add README.md 2014-02-14 11:25:44 +01:00
butterfly.server.py Fix auto conf creation 2016-01-16 13:08:53 +01:00
butterfly.service Enable systemd socket activation. Fixes #48. (Bump to 1.5.3) 2014-07-11 16:04:44 +02:00
butterfly.socket And some docs 2014-07-11 16:10:33 +02:00
Dockerfile adding server port parameter 2015-01-27 11:06:58 -08:00
Gruntfile.coffee Improve copy paste 2015-01-28 13:15:42 +01:00
LICENSE Copyright bump 2015-10-07 16:40:50 +02:00
package.json Bump 2.0.1 2016-01-18 10:09:44 +01:00
README.md Update README.md 2015-10-30 12:07:31 +01:00
requirements.txt Fails with tornado 3.0 2014-02-28 17:53:56 -06:00
setup.py Fix setup.py 2015-10-16 17:56:44 +02:00

ƸӜƷ butterfly 2.0

Description

Butterfly is a xterm compatible terminal that runs in your browser.

Features

  • xterm compatible (support a lot of unused features!)
  • Native browser scroll and search
  • Theming in css / sass (18 preset themes) endless possibilities!
  • HTML in your terminal! cat images and use <table>
  • Multiple sessions support (à la screen -x) to simultaneously access a terminal from several places on the planet!
  • Secure authentication with X509 certificates!
  • 16,777,216 colors support!
  • Keyboard text selection!
  • Desktop notifications on terminal output!
  • Geolocation from browser!
  • May work on firefox too!

Try it

    $ pip install butterfly
    $ pip install libsass  # If you want to use themes
    $ butterfly

A new tab should appear in your browser. Then type

    $ butterfly help

To get an overview of butterfly features.

Run it as a server

    $ butterfly.server.py --host=myhost --port=57575

The first time it will ask you to generate the certificates (see: here)

Run it with systemd (linux)

Systemd provides a way to automatically activate daemons when needed (socket activation):

    $ cd /etc/systemd/system
    # curl -O https://raw.githubusercontent.com/paradoxxxzero/butterfly/master/butterfly.service
    # curl -O https://raw.githubusercontent.com/paradoxxxzero/butterfly/master/butterfly.socket
    # systemctl enable butterfly.socket
    # systemctl start butterfly.socket

Don't forget to update the /etc/butterfly/butterfly.conf file with your server options (host, port, shell, ...)

Contribute

and make the world better (or just butterfly).

Don't hesitate to fork the repository and start hacking on it, I am very open to pull requests.

If you don't know what to do go to the github issues and pick one you like.

If you want to motivate me to continue working on this project you can tip me, see: http://paradoxxxzero.github.io/about/

Client side development use grunt and bower.

Credits

The js part is based on term.js which is based on jslinux.

Author

Florian Mounier

License

    butterfly Copyright (C) 2015  Florian Mounier

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.

Docker Usage

There is a docker repository created for this project that is set to automatically rebuild when there is a push into this repository: https://registry.hub.docker.com/u/garland/butterfly/

Starting

    docker run \
    --env PASSWORD=password \
    --env PORT=57575 \
    -p 57575:57575 \
    -d garland/butterfly