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 8039e3d147 GreenhouseAPIKey -> GreenhouseAPIToken 1 week ago
frontend tweaks and cleanup 1 month ago
pki debugging desktop app registration stuff 1 month ago
readme update diagram 1 month ago
schema_versions add method for generating an API Token 1 month ago
threshold got ports 80 and 443 working for admin tenant tunnel 1 month ago
.gitignore greenhouse's first time hosting itself! 1 month ago
LICENSE.md GPL 3 months ago
README.md update diagram 1 month ago
backblaze_b2_service.go update to golang 16 and got digitalocean instance spawner working 1 month ago
backend.go small fixes from testing greenhouse desktop 1 week ago
db_model.go cleaning up authorizedDomains & serving out tenantInfo for desktop app 2 weeks ago
digitalocean_service.go got buttons working on admin panel and rebalance is no longer throwing 1 month ago
docker-compose.yml greenhouse's first time hosting itself! 1 month ago
easypki_db_adapter.go debugging desktop app registration stuff 1 month ago
email_service.go update to golang 16 and got digitalocean instance spawner working 1 month ago
frontend.go tweaks and cleanup 1 month ago
gandi_service.go add wildcard dns on free subdomain 1 week ago
go.mod undo change package name 1 month ago
go.sum add method for generating an API Token 1 month ago
main.go debugging desktop app registration stuff 1 month ago
public_api.go cleaning up authorizedDomains & serving out tenantInfo for desktop app 2 weeks ago
ssh_service.go debugging desktop app registration stuff 1 month ago
threshold_provisioning_service.go GreenhouseAPIKey -> GreenhouseAPIToken 1 week 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)