shellhub

module
v0.9.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 29, 2022 License: Apache-2.0

README

ShellHub

Centralized SSH for the edge and cloud computing.

GitHub Workflow

ShellHub HostedDocumentationContributingGetting Help

ShellHub is a modern SSH server for remotely accessing Linux devices via command line (using any SSH client) or web-based user interface, designed as an alternative to sshd. Think ShellHub as centralized SSH for the the edge and cloud computing.

A hosted version of ShellHub is available at https://shellhub.io/.

Screenshot

Getting started

To start using ShellHub, it is suggested that you follow the Getting started guide in the ShellHub documentation.

Contributing

ShellHub is an open source project and we love to receive contributions from our community. If you would like to contribute, please read our contributing guide.

Getting Help

You are welcome to submit any questions, participate in discussions and request help with any issue in our Gitter Channel.

License

ShellHub is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

Development Environment Setup

First of all, you'll need to generate required keys for the services:

$ make keygen

Set the environment to development:

$ echo "SHELLHUB_ENV=development" >> .env.override

Start the whole environment:

$ make start

Avoid to use docker-compose directly (unless you know what you're doing); instead use bin/docker-compose wrapper.

Wait for all services to be ready then create initial user by running:

$ ./bin/add-user <username> <password> <email>

Create a namespace for grouping devices and set user as owner:

$ TENANT_ID=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx ./bin/add-namespace <namespace> <owner>

Don't change the value of TENANT_ID, this value is hardcoded during agent initialization in development mode.

When you open ShellHub UI for the first time, be sure to accept pending device.

See the devscripts which can be useful for development.

Authors

ShellHub was created by O.S. Systems.

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Luis Gustavo S. Barreto

💻

Otavio Salvador

💻

Leonardo da Rosa Silveira João

💻

Eduardo Kluwe Veiga

💻

Vagner Nornberg

💻

Fabio Berton

📦

Rafael Gomes

🚇

Mike

💻

inductor(Kohei)

🚇

Y.Horie

💻

Robinson D. S. Santos

💻

Lukas Bachschwell

📖 💻

Shawn

💻

brammp

💻

Sam McKelvie

💻

Henry Barreto

💻

This project follows the all-contributors specification. Contributions of any kind welcome!

Directories

Path Synopsis
agent module
api module
cli module
connector module
gateway module
pkg
geoip
Package geoip helps in geolocation operations.
Package geoip helps in geolocation operations.
revdial
Package revdial implements a Dialer and Listener which work together to turn an accepted connection (for instance, a Hijacked HTTP request) into a Dialer which can then create net.Conns connecting back to the original dialer, which then gets a net.Listener accepting those conns.
Package revdial implements a Dialer and Listener which work together to turn an accepted connection (for instance, a Hijacked HTTP request) into a Dialer which can then create net.Conns connecting back to the original dialer, which then gets a net.Listener accepting those conns.
validator
Package validator has functions to help to validate structures and fields for ShellHub.
Package validator has functions to help to validate structures and fields for ShellHub.
api/openapi Module
ssh module
tests module

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL