All Projects → CypherpunkArmory → holepunch

CypherpunkArmory / holepunch

Licence: AGPL-3.0 license
Holepunch API

Programming Languages

python
139335 projects - #7 most used programming language
HCL
1544 projects

Projects that are alternatives of or similar to holepunch

holepunch-client
Totally self-contained SSH reverse tunnel written in Go
Stars: ✭ 64 (+56.1%)
Mutual labels:  reverse-tunnel
unlock-luks-partition
Unlock a LUKS partition via SSH
Stars: ✭ 31 (-24.39%)
Mutual labels:  reverse-tunnel

Codacy Badge Codacy Badge CircleCI

Holepunch

This is the code used to run api.holepunch.io
Visit holepunch.io to find out more

Setting Up

The holepunch nomad cluster requires a loopback alias in order to communicate with containers running on the MacOS version of docker.

If you are running on a Mac, you can create this loopback alias at 172.16.123.1 by running task setup_net

If you are running locally, you will need to set the sshendpoint in your .punch.toml file to this address as well.

This step is not necessary for running on Linux - but you will probably need to change the SEA_HOST environment variable to your local IP.

  1. You will need a dockerhub account to run the app.
  2. Create a virtualenv (using pyenv) called "holepunch" based on Python 3.7.0
  3. Install go-task via homebrew
  4. Run task setup_local setup_net
  5. Run the tests docker-compose run web pytest

Common Commands

Run Flask Shell

docker-compose run -e "FLASK_APP=app:create_app('development')" web python -m flask shell

Exec into a container

Most of the containers do not have bash so you'll need to use regular old sh.

docker ps -> note the container id docker exec -it <container_id> /bin/sh

Deploying Holepunch

Contributors and Holepunch Developers

  1. Spin up a pushbutton environment using Grid.
  2. Login to the Pushbutton VPN
  3. Cd into the deploy directory and create a holepunch workspace with the same name as your Pusbutton
  4. Push a release to Docker Hub - for development it will deploy a tag with your branch name. If you're on master, it will create a tag release.
  5. task deploy WORKSPACE=
  • If you are on master it will create new tags incremented by 0.0.1 and release those
  • You can specify a version using the VER variable.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].