a cloud service to enable your own web server (owned by you and running on your computer) to be accessible on the internet in seconds, no credit card required
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
forest 6545681075 tweaks and cleanup 3 days ago
frontend tweaks and cleanup 3 days ago
pki debugging desktop app registration stuff 6 days ago
readme update diagram 6 days ago
schema_versions add method for generating an API Token 1 week ago
threshold got ports 80 and 443 working for admin tenant tunnel 2 weeks ago
.gitignore greenhouse's first time hosting itself! 2 weeks ago
LICENSE.md GPL 2 months ago
README.md update diagram 6 days ago
backblaze_b2_service.go update to golang 16 and got digitalocean instance spawner working 3 weeks ago
backend.go debugging desktop app registration stuff 6 days ago
db_model.go updating marketing text and fixing bugs related to desktop app 1 week ago
digitalocean_service.go got buttons working on admin panel and rebalance is no longer throwing 3 weeks ago
docker-compose.yml greenhouse's first time hosting itself! 2 weeks ago
easypki_db_adapter.go debugging desktop app registration stuff 6 days ago
email_service.go update to golang 16 and got digitalocean instance spawner working 3 weeks ago
frontend.go tweaks and cleanup 3 days ago
gandi_service.go got Gandi free subdomains working 2 weeks ago
go.mod undo change package name 1 week ago
go.sum add method for generating an API Token 1 week ago
main.go debugging desktop app registration stuff 6 days ago
public_api.go tweaks and cleanup 3 days ago
ssh_service.go debugging desktop app registration stuff 6 days ago
threshold_provisioning_service.go debugging desktop app registration stuff 6 days ago

README.md

greenhouse

greenhouse logo

Greenhouse is a specialized cloud service designed to make self-hosting your own email, web services, etc, as easy as possible without compromising on privacy and security.

It was originally convieved as a companion cloud service for my Automated Server Garden project,
but I ended up deciding to give up on Automated Server Garden for now and just focus on greenhouse instead.

In the future, Greenhouse will be easy to use with existing self-hosting solutions like yunohost, syncloud, and others.

For more information about greenhouse, see my blog post about it: The "Pragmatic Path" 4-Year Update: Introducing Greenhouse!

screenshot

See: https://picopublish.sequentialread.com/files/mockup2.png

setup local environment

Write the config file config.json in the root directory:

{
  "FrontendPort": 8080,
  "FrontendDomain": "localhost",
  "DatabaseConnectionString": "host=/var/run/postgresql port=5432 user=postgres password=dev database=postgres",
  "DatabaseType": "postgres",
  "DatabaseSchema": "public",
  "SMTP": {
    "Host": "<my email server>",
    "Port": <587 (SMTP+STARTTLS) or 465 (SMTPS)>,
    "Username": "<my email address>",
    "Password": "<my email password>",
    "Encryption": "<SMTPS or STARTTLS>"
  }
}

Run the database:

mkdir -p postgres-data
docker run --rm -it -e POSTGRES_PASSWORD=dev -v /var/run/postgresql:/var/run/postgresql -v "$PWD/postgres-data":/var/lib/postgresql/data postgres

Run the app:

go run *.go

Inspect the database:

sudo apt-get install postgresql-client
PGPASSWORD=dev psql --host /var/run/postgresql --port 5432 --username postgres -d postgres -c 'select * from session_cookies'

Architechture:

architechture diagram

This diagram was created with https://app.diagrams.net/. To edit it, download the diagram file and edit it with the https://app.diagrams.net/ web application, or you may run the application from source if you wish.

Features:

  • Threshold (TCP reverse tunnel) as a service (multi-tenant or dedicated IP address)
  • Object Storage
  • free subdomains (like duckdns / freedns.afraid.org)
  • managed domain names (like njalla)